Updated documentation for new APIs.

This commit is contained in:
nifi 2010-02-09 08:29:58 +00:00
parent 27d5e2338a
commit a6c6522548
4 changed files with 71 additions and 63 deletions

View file

@ -5,7 +5,7 @@
\defgroup esb The ESB Embedded Sensor Board \defgroup esb The ESB Embedded Sensor Board
The ESB (Embedded Sensor Board) is a prototype wireless sensor network The ESB (Embedded Sensor Board) is a prototype wireless sensor network
device developed at Freie Universität Berlin. device developed at FU Berlin.
<img src="img/esb/esb.jpg" align="right"> <img src="img/esb/esb.jpg" align="right">
@ -99,21 +99,21 @@ Adam Dunkels, SICS, which is very well suited when programming small
embedded systems. embedded systems.
The Contiki OS can be found at: The Contiki OS can be found at:
http://www.sics.se/~adam/contiki/ http://www.sics.se/contiki/
Unzip the Contiki OS at (for example) C:\\ Unzip the Contiki OS at (for example) C:\\
and you will get the following directories among others: and you will get the following directories among others:
- contiki-2.x/core - the contiki operating system - contiki-2.x/core - the contiki operating system
- contiki-2.x/platform/esb - the contiki operating system drivers, etc for the ESB - contiki-2.x/platform/esb - the contiki operating system drivers, etc for the ESB
- contiki-2.x/platform/esb/apps/ - example applications for the ESB - contiki-2.x/examples/esb/ - example applications for the ESB
\subsection winintro-testing Testing the tools \subsection winintro-testing Testing the tools
Now everything necessary to start developing Contiki-based sensor net Now everything necessary to start developing Contiki-based sensor net
applications should be installed. Start cygwin and change to the applications should be installed. Start cygwin and change to the
directory <tt>contiki-2.x/platform/esb/</tt>. Then call <tt>make directory <tt>contiki-2.x/examples/esb/</tt>. Then call <tt>make
beeper.co</tt>. beeper.esb</tt>.
If you get an error about multiple cygwin dlls when compiling, you If you get an error about multiple cygwin dlls when compiling, you
need to delete <tt>cygwin1.dll</tt> from the MSP430 GCC toolchain need to delete <tt>cygwin1.dll</tt> from the MSP430 GCC toolchain
@ -129,7 +129,7 @@ for sending to the ESB nodes. Depending on the \c SPEC it might even
startup the application that sends the executable to the startup the application that sends the executable to the
node. Typically you would write things like <tt>"make beeper.u"</tt> node. Typically you would write things like <tt>"make beeper.u"</tt>
to get the file <tt>beeper.c</tt> compiled, linked and sent out to the to get the file <tt>beeper.c</tt> compiled, linked and sent out to the
ESB node ESB node.
\subsection winintro-testing-shell Some basic shell commands \subsection winintro-testing-shell Some basic shell commands
@ -158,9 +158,9 @@ directory and run
<tt>make burn-nodeid.u nodeid=X</tt> <tt>make burn-nodeid.u nodeid=X</tt>
Where <tt>X</tt> is the node ID that will be burned into EEPROM. The where <tt>X</tt> is the node ID that will be burned into EEPROM. The
<tt>burn-nodeid</tt> program stores the node ID in EEPROM, reads it <tt>burn-nodeid</tt> program stores the node ID in EEPROM, reads it
back, and writes the output back, and writes the output to the serial port.
@{ @{

View file

@ -6,7 +6,7 @@ The ESB is equipped with an MSP430 microcontroller. The first step to
getting started with Contiki for the ESB is to install the development getting started with Contiki for the ESB is to install the development
tools for compiling Contiki for the MSP430. tools for compiling Contiki for the MSP430.
For Windows users, see \ref esb-winintro For Windows users, see \ref esb-win-setup
@{ @{

View file

@ -4,29 +4,32 @@
\section sensors Sensor functions \section sensors Sensor functions
Some sensors generate events when the sensors change. It is always Each sensor has a set of functions for controlling it and query it for
possible to query the state of a sensor through a set of query functions. its state. Some sensors also generate an events when the sensors
change. A sensor must be activated before it generates events or
relevant values.
\subsection quickref-sensors-events Sensor events - SENSORS_ACTIVATE(sensor) - activate the sensor
- SENSORS_DEACTIVATE(sensor) - deactivate the sensor
- sensor.value(0) - query the sensor for its last value
- \ref sensors_event_button_down - the button has been pressed - \ref sensors_event - event sent when a sensor has changed (the data
- \ref sensors_event_button_up - the button has been depressed argument will referer to the actual sensor)
- \ref sensors_event_humidity - a change in humidity has been detected
- \ref sensors_event_light - a change in light has been detected
- \ref sensors_event_motion - motion has been detected
- \ref sensors_event_sound - sound has been detected
- \ref sensors_event_temperature - temperature has changed
- \ref sensors_event_vibration - vibration has been detected
\subsection quickref-sensors-query Sensor query functions Example for querying the button:
- sensors_battery() - query the battery voltage level - \ref SENSORS_ACTIVATE(button_sensor) - activate the button sensor
- sensors_button() - query the on-board button - \ref button_sensor.value(0) - the button has been pressed or not
- sensors_mic() - query the microphone
- sensors_pir() - query the passive IR sensor (motion detector) \subsection quickref-sensors Sensor on the ESB platform
- sensors_radiosignal() - query the radio signal strength
- sensors_temp() - query the temperature sensor - \ref battery_sensor - query the battery voltage level
- sensors_vib() - query the vibration sensor - \ref button_sensor - query the on-board button
- \ref pir_sensor - query the passive IR sensor (motion detector)
- \ref radio_sensor - query the radio signal strength
- \ref sound_sensor - query the microphone
- \ref temperature_sensor - query the temperature sensor
- \ref vib_sensor - query the vibration sensor
\section quickref-leds LED functions \section quickref-leds LED functions
@ -45,10 +48,10 @@ possible to query the state of a sensor through a set of query functions.
\section quickref-timers Timer functions \section quickref-timers Timer functions
Contiki supports two types of timers: event timers and simple Contiki provides a set of timer libraries. Event timers generates an
timers. Event timers generates an event when the timer expires, event when the timer expires and callback timers call a function when
whereas the simple timer has to be actively queried to check when it the timer expires. The simple timers on the other hand have to be
has expired. actively queried to check when they have expired.
\subsection quickref-etimer Event timers \subsection quickref-etimer Event timers
@ -57,6 +60,13 @@ has expired.
- etimer_reset() - set an expired event timer to the next interval - etimer_reset() - set an expired event timer to the next interval
- etimer_restart() - restart an event timer from the current point in time - etimer_restart() - restart an event timer from the current point in time
\subsection quickref-ctimer Callback timers
- ctimer_expired() - check if a callback timer has expired
- ctimer_set() - set a callback timer
- ctimer_reset() - set an expired callback timer to the next interval
- ctimer_restart() - restart a callback timer from the current point in time
\subsection quickref-timer Simple timers \subsection quickref-timer Simple timers
- timer_expired() - check if a simple timer has expired - timer_expired() - check if a simple timer has expired

View file

@ -64,12 +64,29 @@ TCP/IP'.
\section slipintro-setup Setup ESB for over the air programming \section slipintro-setup Setup ESB for over the air programming
-# Make sure you have the latest version of contiki (older versions of Make sure you have the latest version of Contiki (older versions of
contiki might not work with SLIP under Windows) Contiki might not work with SLIP under Windows).
-# Install the contiki kernel by running
-# Each node needs an IP address for OTA to work. The node id
is used to construct an IP address for the node. If you specify 2 as
node id, the node will have the IP address 172.16.1.2. Each node
should have its own unique node id. To set the node id move to the
directory '<tt>contiki-2.x/examples/esb</tt>' and run
\code \code
make core.u make burn-nodeid.u nodeid=X
\endcode \endcode
Use the number 1, 2, 3, etc, as the node id (\c X) for the nodes. This
will give the nodes the IP addresses 172.16.1.1, 172.16.1.2, etc. The
node id only needs to be set once for each node and it will remain
even when new applications are uploaded onto the node.
-# You need to compile a core and upload it onto the nodes. All nodes
must run the same core. Move to the directory
'<tt>contiki-2.x/examples/esb</tt>' and run
\code
make WITH_CODEPROP=1 core
make WITH_CODEPROP=1 core.u
\endcode
to upload the core to your nodes.
-# Attach the ESB node to the serial port and make sure it is -# Attach the ESB node to the serial port and make sure it is
turned on. Select your ESB SLIP connection in your 'Network turned on. Select your ESB SLIP connection in your 'Network
Connections' and choose 'Connect' (or double click on it). If Connections' and choose 'Connect' (or double click on it). If
@ -84,37 +101,18 @@ ping 172.16.1.1
If everything works the node should click and reply to the pings. If everything works the node should click and reply to the pings.
\section slipintro-send Send programs over the air You also need a program to send the application to connected
Contiki applications to be installed via radio are compiled somewhat
different compared to normal applications.
Each node needs an IP address for OTA to work. A node id can be
specified when you upload the contiki kernel to a node and this is
used to construct an IP address for the node. If you specify 2 as
node id, the node will have the IP address 172.16.1.2. Each node
should have its own unique node id.
You need to compile a core and upload it onto the nodes. All nodes
must run the same core. Move to the directory
'<tt>contiki-2.x/platform/esb</tt>' and run
\code
make
make core.u nodeid=X
\endcode
to upload the core to your nodes. Use the number 1, 2, 3, etc,
as the node id (\c X) for the nodes. This will give the nodes the IP
addresses 172.16.1.1, 172.16.1.2, etc.
Then you need a program to send the application to connected
nodes. Compile it by running nodes. Compile it by running
\code \code
make send make send
\endcode \endcode
\section slipintro-send Send programs over the air
Contiki applications to be installed via radio are compiled somewhat
different compared to normal applications.
Make sure you have a node with IP address 172.16.1.1 connected to your Make sure you have a node with IP address 172.16.1.1 connected to your
serial port and have SLIP activated. Then compile and send a serial port and have SLIP activated. Then compile and send a
testprogram by running testprogram by running