Time-sensitive Intermittent Computing Meets Legacy Software

Abstract

Tiny energy harvesting sensors that operate intermittently, without batteries, have become an increasingly appealing way to gather data in hard to reach places at low cost. Frequent power failures make forward progress, data preservation and consistency, and timely operation challenging. Unfortunately, state-of-the-art systems ask the programmer to solve these challenges, and have high memory overhead, lack critical programming features like pointers and recursion, and are only dimly aware of the passing of time and its effect on application quality. We present Time-sensitive Intermittent Computing System (TICS), a new platform for intermittent computing, which provides simple programming abstractions for handling the passing of time through intermittent failures, and uses this to make decisions about when data can be used or thrown away. Moreover, TICS provides predictable checkpoint sizes by keeping checkpoint and restore times small and reduces the cognitive burden of rewriting embedded code for intermittency without limiting expressibility or language functionality, enabling numerous existing embedded applications to run intermittently.

Publication
To appear in ACM International Conference on Architectural Support for Programming Languages and Operating Systems (ASPLOS 2020)

GitHub Repository: https://github.com/TUDSSL/TICS

Avatar
Vito Kortbeek
PhD Student at the Embedded and Networked Systems Group

My research interests include intermittent computation support, compilers and static analysis.