This tutorial outlines a working procedure to install TinyOS 1.x with all the tools required to develop applications for the XBow MicaZ Platform on an Ubuntu Linux system. These instructions have been tested with Ubuntu and Kubuntu Dapper, but it should not be too difficult to apply them to any other Debian based Linux distribution.
Instructions:
- Install the following packages using any conventional APT package manager: cvs, gcc, gperf, graphviz, m4, and make.
apt-get install cvs gcc gperf graphviz m4 make
- Install the following DEB packages manually: avr-libc_20030512cvs-2_i386.deb, avr-binutils_2.13.2.1-2_i386.deb, avr-gcc_3.3tinyos-2_i386.deb, tinyos-tools_1.1.0-2_i386.deb, ibmjava2-142-ia32-sdk_1.4.2-6_i386.deb, and ibmjava2-javacomm_1.4.2-6_i386.deb. Afterwards, mark the packages to be held by the package manager, so they won't be automatically upgraded by the system.
dpkg -i avr-libc_20030512cvs-2_i386.deb
dpkg -i avr-binutils_2.13.2.1-2_i386.deb
dpkg -i avr-gcc_3.3tinyos-2_i386.deb
dpkg -i tinyos-tools_1.1.0-2_i386.deb
- Checkout the latest TinyOS 1.x files from the CVS repository into the /opt/ directory. Afterwards, chown the directory and its contents to your own user.
cd /opt/
sudo cvs -d:pserver:anonymous@tinyos.cvs.sourceforge.net/cvsroot/tinyos \
login
sudo cvs -d:pserver:anonymous@tinyos.cvs.sourceforge.net/cvsroot/tinyos \
co tinyos-1.x
sudo chown -R `whoami` tinyos-1.x
- Create the TinyOS Environment variables by appending the appropriate shell code to your ~/.bashrc file. Afterwards, close and reopen the terminal to start a session with the new environment.
cat bashrc-append.txt >> ~/.bashrc
- Download the nesC Compiler source code and apply the following patches: builtin_offset.patch.nesc, static-clex.patch.nesc, and noinline.patch.nesc. Afterwards, build and install it.
tar xzf nesc-1.1.3.tar.gz
cd nesc-1.1.3
patch -p1 < builtin_offset.patch.nesc
patch -p0 < static-clex.patch.nesc
patch -p1 < noinline.patch.nesc
./configure
make
sudo make install
- Build and install the remaining TinyOS tools.
cd $TOSROOT/tools/scripts/
sudo make install prefix=/usr/local
sudo ln -s $TOSROOT/tools/src/motelist/motelist-linux \
/usr/local/bin/motelist
cd $TOSROOT/tools/java/
make
- Configure the Javax Comm library to use the appropriate serial ports by editing /opt/IBMJava2-142/jre/lib/javax.comm.properties.
Additional Resources:
- TinyOS Plugin for Eclipse
- TinyDT - TinyOS Plugin for the Eclipse Platform
- TinyosIDE Eclipse Plugin by Richard Tynan