TinyOS was introduced by Jason Hill at the University of Berkeley in 2000. TinyOS is an open-source, BSD-based operating system that uses the nesC programming language to control and manage wireless sensor networks (WSN). The sensor devices (called motes) in such networks are characterized by low power, limited memory, and a very small form factor.
The basic principle of any operating system (OS) is to provide the development of reliable application software by providing a convenient and safe abstraction of hardware resources. In PCs and servers, the OS allocates application processing threads to processors, maps, and virtual addresses to locations in memory, and manipulates disks, networks, and peripherals on the application’s behalf.
TinyOS is essentially built on a “component-based architecture” to reduce co-size to around 400 to 500 bytes and an “events-based design” that eliminates the need for even a command shell. The components-based architecture uses “nesC” which is a C programming language designed for networking embedded systems.
Each code snippet consists of simple functions placed within components and complex functions integrating all the components together. TinyOS has been adopted by thousands of developers worldwide, on many platforms, for a broad range of wireless sensor networks.
Applications of Tiny OS in IoT
- Environmental Monitoring: TinyOS systems can be embedded in a small sensor, they are useful in monitoring air pollution, forest fires, and natural disaster prevention.
- Smart Vehicles: smart vehicles are autonomous and can be understood as a network of sensors. These sensors communicate through low-power wireless area networks (LPWAN) which makes TinyOS a perfect fit.
- Smart Cities: TinyOS is feasible for the low-power sensor requirements of smart cities’ utilities, power grids, Internet infrastructure, and other applications.
Wireless sensor networks (WSNS) are embedded but general-purpose, supporting a variety of applications, incorporating heterogeneous components, and capable of rapid deployment in new environments. A typical TinyOS ‘mote’ platform has 10 KB of RAM, and 100 KB of RÓM, and consumes 10 µA to 25 mA, depending on which components are active.
TinyOS was designed specifically for WSNs. It introduces a structured event-driven execution model and a component-based software design that supports a high degree of concurrency in a small footprint, enhances robustness, and minimizes power consumption while facilitating the implementation of sophisticated protocols and algorithms.
TinyOS is an embedded, component-based operating system and platform for low-power wireless devices, such as those used in wireless sensor networks (WSNs), smartdust, ubiquitous computing, personal area networks, building automation, and smart meters. It is written in the programming language nesC, as a set of cooperating tasks and processes.
It began as a collaboration between the University of California, Berkeley, Intel Research, and Crossbow Technology was released as free and open-source software under a BSD license, and has since grown into an international consortium, the TinyOS Alliance. nesC (pronounced “NSE-see”) is an extension to the C programming language designed to embody the structuring concepts and execution model of TinyOS. It is a work scheduler and a collection of drivers for microcontrollers and other ICS used in wireless embedded platforms.
TinyOS programs are built of software components, some of which present hardware abstractions. Components are connected to each other using interfaces. TinyOS provides interfaces and components for common abstractions such as packet communication and routing. sensing, actuation, and storage.
TinyOS is fully non-blocking: it has one call stack. Thus, all input/output (I/O) operations that last longer than a few hundred microseconds are asynchronous and have a callback. TinyOS uses nesC’s features to link these callbacks, called events, statically.
To support larger computations, TinyOS provides tasks, which are similar to a Deferred Procedure Call and interrupt handler bottom halves. This simple concurrency model is typically sufficient for I/O-centric applications, but its difficulty with CPU-heavy applications has led to the development of a thread library for the OS, named TOSThreads.
Comparisons with Contiki OS, Tiny OS, and RIOT OS
There are two other OSs, called Contiki OS and Tiny Os, which are suitable for IoT applications. But RIOT fares better when it comes to memory usage and support.
Features | Contiki OS | Tiny OS | RIOT OS |
---|---|---|---|
Minimum RAM and ROM needed | <2KB <30KB | <1KB <4KB | <1.5KB 5KB |
C and C++ support | Partial | No support (nestC Compiler) | Full Support |
Multi-threading | No (Proto threads are used here) | No | Yes |
Real-time capabilities | No | No | Yes |
Read other IoT tutorials