Abstract
We consider a class of interrupt-driven programs that model the kernel API libraries of some popular real-time embedded operating systems and the synchronization mechanisms they use. We define a natural notion of data races and a happens-before ordering for such programs. The key insight is the notion of disjoint blocks to define the synchronizes-with relation. This notion also suggests an efficient and effective lockset based analysis for race detection. It also enables us to define efficient “sync-CFG” based static analyses for such programs, which exploit data race freedom. We use this theory to carry out static analysis on the FreeRTOS kernel library to detect races and to infer simple relational invariants on key kernel variables and data-structures.
Author supplied keywords
Cite
CITATION STYLE
Chopra, N., Pai, R., & D’Souza, D. (2019). Data Races and Static Analysis for Interrupt-Driven Kernels. In Lecture Notes in Computer Science (including subseries Lecture Notes in Artificial Intelligence and Lecture Notes in Bioinformatics) (Vol. 11423 LNCS, pp. 697–723). Springer Verlag. https://doi.org/10.1007/978-3-030-17184-1_25
Register to see more suggestions
Mendeley helps you to discover research relevant for your work.