WikiStart

Version 38 (Anthony Rowe, 02/14/2007 04:26 pm)

1 25 Anthony Rowe
2 10 Anthony Rowe
{{{
3 10 Anthony Rowe
#!html
4 10 Anthony Rowe
<table border="0">
5 17 Anthony Rowe
<br>
6 17 Anthony Rowe
<tr><td valign="top" style="height:500px;"> 
7 12 Anthony Rowe
<div class="menu_active">Overview</div>
8 30 Anthony Rowe
<div class="menu"><a href="/nano-RK/wiki/Quick-Start" class="menu">Quick-Start</a></div>
9 24 Anthony Rowe
<div class="menu"><a href="/nano-RK/wiki/Documentation" class="menu">Documentation</a></div>
10 23 Anthony Rowe
<div class="menu"><a href="/nano-RK/wiki/People" class="menu">People</a></div>
11 24 Anthony Rowe
<div class="menu"><a href="/nano-RK/wiki/Links" class="menu">Links</a></div>
12 31 Anthony Rowe
<div class="menu"><a href="/nano-RK/wiki/Pubs" class="menu">Publications</a></div>
13 10 Anthony Rowe
</td>
14 10 Anthony Rowe
15 25 Anthony Rowe
<td valign="top" style="width:100%;padding-left:50px">
16 10 Anthony Rowe
}}}
17 28 Anthony Rowe
= nano-RK: A Preemptive Real-Time Resource Centric Kernel for Sensor Networks =
18 9 Anthony Rowe
Nano-RK is a reservation-based real-time operating system (RTOS) from [http://www.cmu.edu Carnegie Mellon University] with multi-hop networking support for use in wireless sensor networks. Nano-RK currently runs on the FireFly Sensor Networking Platform as well as the [wiki:MicaZ] motes. It includes a light-weight embedded resource kernel (RK) with rich functionality and timing support using less than 2KB of RAM and 16KB of ROM. Nano-RK supports fixed-priority preemptive multitasking for ensuring that task deadlines are met, along with support for CPU, network, as well as, sensor and actuator reservations. Tasks can specify their resource demands and the operating system provides
19 34 Anthony Rowe
timely, guaranteed and controlled access to CPU cycles and network packets. Together these resources form virtual energy reservations that allows the OS to enforce system and task level energy budgets. 
20 5 Anthony Rowe
21 32 Anthony Rowe
22 32 Anthony Rowe
Nano-RK has the following features:
23 32 Anthony Rowe
 * C GNU tool-chain
24 32 Anthony Rowe
 * Classical Preemptive Operating System Multitasking Abstractions
25 32 Anthony Rowe
 * Real-Time Priority Based Scheduling
26 33 Anthony Rowe
 * Built-in Fault Handling
27 35 Anthony Rowe
  * Task Timing Violations
28 35 Anthony Rowe
  * Stack Integrity
29 35 Anthony Rowe
  * Unexpected Node Restarts
30 35 Anthony Rowe
  * Resource Over-Use 
31 34 Anthony Rowe
  * Low Voltage Detection
32 32 Anthony Rowe
33 37 Anthony Rowe
Nano-RK supports various link layer protocols including:
34 36 Anthony Rowe
 * [wiki:RT-Link] for collision free Real-Time communication
35 38 Anthony Rowe
 * {wiki:WiDOM] a collision free priority based link layer
36 1
 * [wiki:b-mac] for low-power contention based communication
37 37 Anthony Rowe
38 37 Anthony Rowe
Nano-RK supports comes with the following network layer protocols:
39 37 Anthony Rowe
 * [wiki:Flooding] for when you really don't care
40 36 Anthony Rowe
 * [wiki:DSR] for ad-hoc routing