Difference between revisions of "TinyOS Tutorials"
(61 intermediate revisions by 39 users not shown) | |||
Line 1: | Line 1: | ||
+ | These brief tutorials are intended to get you started with TinyOS. They show you the basics of writing, compiling, and installing TinyOS applications. They introduce the basic TinyOS abstractions: computation, communication, sensing, and storage. The later tutorials go a little deeper into some of the more advanced areas of TinyOS, such as handling interrupts, power management, and how platforms are organized. | ||
+ | |||
=Working Group Tutorials= | =Working Group Tutorials= | ||
+ | <ul> | ||
+ | =='''<li>[[Getting Started with TinyOS]]</li>'''== | ||
+ | Lesson 1 introduces the major concepts of TinyOS: components, modules, configurations and interfaces. It shows you how to compile and install a TinyOS program on a mote. | ||
+ | |||
+ | =='''<li>[[Modules and the TinyOS Execution Model]]</li>'''== | ||
+ | Lesson 2 explains the TinyOS execution model, looking more closely at modules. It explains events, commands and their relationships to interfaces in greater depth, introducing split-phase operations. It explains tasks, the basic mechanism in TinyOS for components to cooperatively share the processor. | ||
+ | =='''<li>[[Mote-mote radio communication]]</li>'''== | ||
+ | Lesson 3 introduces the TinyOS communication model. There is an exercise that illustrates sending and receiving messages. | ||
+ | =='''<li>[[Mote-PC serial communication and SerialForwarder]]</li>'''== | ||
+ | Lesson 4 introduces the the TinyOS toolchain for PCs and laptops to communicate with motes. It describes the concept of a packet source, the mig tool, and SerialForwarder. | ||
+ | =='''<li>[[Sensing]]</li>'''== | ||
+ | Lesson 5 explains how to sample sensors in TinyOS. There is an exercise that periodically samples a sensor and displays the value on the leds. | ||
+ | ==='''<li>[[ADC]]</li>'''=== | ||
+ | Lesson 5.1 explains how to use lesson 5 to sample any adc in TinyOS. There is an exercise that periodically samples any adc and sends its value via serial port. | ||
+ | =='''<li>[[Boot Sequence]]</li>'''== | ||
+ | Lesson 6 details the boot sequence and, in doing so, answers the question, "But where is main()?". | ||
+ | =='''<li>[[Storage]]</li>'''== | ||
+ | Lesson 7 introduces the TinyOS storage model. Sample applications illustrate the use of the Mount, ConfigStorage, LogRead and LogWrite interfaces. | ||
+ | =='''<li>[[Resource Arbitration and Power Management]]</li>'''== | ||
+ | Lesson 8 introduces the TinyOS resource arbitration and power management model. There are two exercises in this tutorial. The first one illustrates how to gain access to predefined shared resources. The second one illustrates how to create your own shared resource. In both tutorials, the process for controlling the power states of the resource is presented. | ||
+ | =='''<li>[[Concurrency]]</li>'''== | ||
+ | Lesson 9 introduces the TinyOS concurrency model. Tasks are revisited and async code is introduced. This tutorial is currently unfinished. | ||
+ | =='''<li>[[Platforms]]</li>'''== | ||
+ | Lesson 10 provides a better understanding of the difference between "make micaz" and "make telosb," including how these commands map into underlying files, directories, and definitions. It is not necessary for most TinyOS developers, but is included as a starter's guide for people who wish to understand the make system better or wish to design a new platform. | ||
+ | =='''<li>[[TOSSIM]]</li>'''== | ||
+ | Lesson 11 introduces TOSSIM, a TinyOS simulator. TOSSIM allows you to compile your TinyOS applications into a simulation framework, where you can perform reproducible tests and debug your code with standard development tools. | ||
+ | =='''<li>Network Protocols</li>'''== | ||
+ | * '''[[Network Protocols|Dissemination and Collection (Old Link)]] | ||
+ | Lesson 12 introduces two basic multihop protocols, Dissemination and Collection. Dissemination reliably delivers small data items to every node in a network, while collection delivers small data items from every node in a network to designated collection roots. | ||
+ | |||
+ | * '''[[Dissemination]] | ||
+ | This tutorial introduces multihop data dissemination. Dissemination reliably delivers small data items to every node in a network | ||
+ | |||
+ | * '''[[Tymo]]''' | ||
+ | This lesson introduces another multihop protocol that allows sending data to an addressed node. It is based on the DYMO routing protocol. | ||
+ | |||
+ | * '''[[Deluge T2]]''' | ||
+ | Deluge is a system for efficiently updating the code image running on a network of motes running TinyOS. | ||
+ | |||
+ | *'''[[BLIP Tutorial]] (2.1.1)''' | ||
+ | This tutorial explains how to compile, configure, and commission a 6lowpan/IPv6 subnet using <tt>blip</tt>, the TinyOS IPv6 stack. | ||
+ | |||
+ | *'''[[BLIP 2.0]] (2.1.2 and svn''' | ||
+ | Information on the latest version of the IPv6 stack and associated protocols. | ||
+ | |||
+ | *'''[[TinyRPL]]''' | ||
+ | This tutorial introduces the IETF RPL IPv6 routing protocol implementation in TinyOS. | ||
+ | |||
+ | =='''<li>[[TinyOS Toolchain]]</li>'''== | ||
+ | Lesson 13 describes the details of the TinyOS toolchain, including the build system, how to create your own Makefile, and how to find out more information on the various tools included with TinyOS. | ||
+ | =='''<li>Building a simple but full-featured application</li>'''== | ||
+ | Lesson 14 goes through the process of building a simple anti-theft application using many of the features and services of TinyOS 2. Lesson 14 is found in the tinyos-2.x/apps/AntiTheft directory. The powerpoint slides found there (also available in pdf form) go over the basic principles of TinyOS, and show how to build the accompanying AntiTheft application. Please start by reading the README.txt file in the AntiTheft directory. | ||
+ | |||
+ | To run the AntiTheft demo you will need [[mica2]] or micaz motes, and some mts310 sensor boards (you can also use mts300 boards, though you will lose the movement detection functionality). If you do not have this hardware, the slides and AntiTheft code should still provide a good overview of TinyOS 2. | ||
+ | |||
+ | =='''<li>[[The TinyOS printf Library]]</li>'''== | ||
+ | Lesson 15 describes the details of using the TinyOS printf library to print debug messages to your PC from a TinyOS application running on a mote. | ||
+ | =='''<li>[[Writing Low-Power Applications]]</li>'''== | ||
+ | This lesson demonstrates how to write low power sensing applications in TinyOS. At any given moment, the power consumption of a wireless sensor node is a function of its microcontroller power state, whether the radio, flash, and sensor peripherals are on, and what operations active peripherals are performing. This tutorial shows you how to best utilize the features provided by TinyOS to keep the power consumption of applications that use these devices to a minimum. | ||
+ | |||
+ | =='''<li>[[TOSThreads Tutorial]]</li>'''== | ||
+ | This lesson demonstrates how to use the TOSThreads library to create and manipulate user-level threads in TinyOS. It also walks through the steps of adding TOSThreads support to split-phase services. | ||
+ | |||
+ | =='''<li>[[CC2420 Security Tutorial]]</li>'''== | ||
+ | This lesson introduces and illustrates how the CC2420 in-line security features can be enabled on a step-by-step basis. | ||
+ | </ul> | ||
+ | |||
+ | =Other Tutorials= | ||
+ | <ul> | ||
+ | =='''<li>[[Ipsn2009-tutorial]]</li>'''== | ||
+ | </ul> | ||
+ | |||
+ | =User Contributed Tutorials= | ||
+ | <ul> | ||
+ | =='''<li>[[Platform Creation and Testing]]</li>'''== | ||
+ | == '''<li>[[Rssi Demo]]</li>'''== | ||
+ | This lesson describes how to get RSSI readings from incoming packets or for noise floor estimation. | ||
+ | </ul> | ||
− | + | [[Category:Tutorials]] | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− |
Latest revision as of 14:00, 24 October 2011
These brief tutorials are intended to get you started with TinyOS. They show you the basics of writing, compiling, and installing TinyOS applications. They introduce the basic TinyOS abstractions: computation, communication, sensing, and storage. The later tutorials go a little deeper into some of the more advanced areas of TinyOS, such as handling interrupts, power management, and how platforms are organized.
Contents
- 1 Working Group Tutorials
- 1.1 Getting Started with TinyOS
- 1.2 Modules and the TinyOS Execution Model
- 1.3 Mote-mote radio communication
- 1.4 Mote-PC serial communication and SerialForwarder
- 1.5 Sensing
- 1.6 Boot Sequence
- 1.7 Storage
- 1.8 Resource Arbitration and Power Management
- 1.9 Concurrency
- 1.10 Platforms
- 1.11 TOSSIM
- 1.12 Network Protocols
- 1.13 TinyOS Toolchain
- 1.14 Building a simple but full-featured application
- 1.15 The TinyOS printf Library
- 1.16 Writing Low-Power Applications
- 1.17 TOSThreads Tutorial
- 1.18 CC2420 Security Tutorial
- 2 Other Tutorials
- 3 User Contributed Tutorials
Working Group Tutorials
- Getting Started with TinyOS
- Modules and the TinyOS Execution Model
- Mote-mote radio communication
- Mote-PC serial communication and SerialForwarder
- Sensing
- ADC
- Boot Sequence
- Storage
- Resource Arbitration and Power Management
- Concurrency
- Platforms
- TOSSIM
- Network Protocols
- BLIP Tutorial (2.1.1)
- BLIP 2.0 (2.1.2 and svn
- TinyOS Toolchain
- Building a simple but full-featured application
- The TinyOS printf Library
- Writing Low-Power Applications
- TOSThreads Tutorial
- CC2420 Security Tutorial
Lesson 1 introduces the major concepts of TinyOS: components, modules, configurations and interfaces. It shows you how to compile and install a TinyOS program on a mote.
Lesson 2 explains the TinyOS execution model, looking more closely at modules. It explains events, commands and their relationships to interfaces in greater depth, introducing split-phase operations. It explains tasks, the basic mechanism in TinyOS for components to cooperatively share the processor.
Lesson 3 introduces the TinyOS communication model. There is an exercise that illustrates sending and receiving messages.
Lesson 4 introduces the the TinyOS toolchain for PCs and laptops to communicate with motes. It describes the concept of a packet source, the mig tool, and SerialForwarder.
Lesson 5 explains how to sample sensors in TinyOS. There is an exercise that periodically samples a sensor and displays the value on the leds.
Lesson 5.1 explains how to use lesson 5 to sample any adc in TinyOS. There is an exercise that periodically samples any adc and sends its value via serial port.
Lesson 6 details the boot sequence and, in doing so, answers the question, "But where is main()?".
Lesson 7 introduces the TinyOS storage model. Sample applications illustrate the use of the Mount, ConfigStorage, LogRead and LogWrite interfaces.
Lesson 8 introduces the TinyOS resource arbitration and power management model. There are two exercises in this tutorial. The first one illustrates how to gain access to predefined shared resources. The second one illustrates how to create your own shared resource. In both tutorials, the process for controlling the power states of the resource is presented.
Lesson 9 introduces the TinyOS concurrency model. Tasks are revisited and async code is introduced. This tutorial is currently unfinished.
Lesson 10 provides a better understanding of the difference between "make micaz" and "make telosb," including how these commands map into underlying files, directories, and definitions. It is not necessary for most TinyOS developers, but is included as a starter's guide for people who wish to understand the make system better or wish to design a new platform.
Lesson 11 introduces TOSSIM, a TinyOS simulator. TOSSIM allows you to compile your TinyOS applications into a simulation framework, where you can perform reproducible tests and debug your code with standard development tools.
Lesson 12 introduces two basic multihop protocols, Dissemination and Collection. Dissemination reliably delivers small data items to every node in a network, while collection delivers small data items from every node in a network to designated collection roots.
This tutorial introduces multihop data dissemination. Dissemination reliably delivers small data items to every node in a network
This lesson introduces another multihop protocol that allows sending data to an addressed node. It is based on the DYMO routing protocol.
Deluge is a system for efficiently updating the code image running on a network of motes running TinyOS.
This tutorial explains how to compile, configure, and commission a 6lowpan/IPv6 subnet using blip, the TinyOS IPv6 stack.
Information on the latest version of the IPv6 stack and associated protocols.
This tutorial introduces the IETF RPL IPv6 routing protocol implementation in TinyOS.
Lesson 13 describes the details of the TinyOS toolchain, including the build system, how to create your own Makefile, and how to find out more information on the various tools included with TinyOS.
Lesson 14 goes through the process of building a simple anti-theft application using many of the features and services of TinyOS 2. Lesson 14 is found in the tinyos-2.x/apps/AntiTheft directory. The powerpoint slides found there (also available in pdf form) go over the basic principles of TinyOS, and show how to build the accompanying AntiTheft application. Please start by reading the README.txt file in the AntiTheft directory.
To run the AntiTheft demo you will need mica2 or micaz motes, and some mts310 sensor boards (you can also use mts300 boards, though you will lose the movement detection functionality). If you do not have this hardware, the slides and AntiTheft code should still provide a good overview of TinyOS 2.
Lesson 15 describes the details of using the TinyOS printf library to print debug messages to your PC from a TinyOS application running on a mote.
This lesson demonstrates how to write low power sensing applications in TinyOS. At any given moment, the power consumption of a wireless sensor node is a function of its microcontroller power state, whether the radio, flash, and sensor peripherals are on, and what operations active peripherals are performing. This tutorial shows you how to best utilize the features provided by TinyOS to keep the power consumption of applications that use these devices to a minimum.
This lesson demonstrates how to use the TOSThreads library to create and manipulate user-level threads in TinyOS. It also walks through the steps of adding TOSThreads support to split-phase services.
This lesson introduces and illustrates how the CC2420 in-line security features can be enabled on a step-by-step basis.
Other Tutorials
User Contributed Tutorials
- Platform Creation and Testing
- Rssi Demo
This lesson describes how to get RSSI readings from incoming packets or for noise floor estimation.