1. Design and implementation of an operating system for composable processor sharing
- Author
-
Marcus Ekerhult, Andrew Nelson, Anca Molnos, Jude Angelo Ambrose, Aleksandar Milutinovic, Kees Goossens, Andreas Hansson, Electronic Systems, and CompSOC Lab- Predictable & Composable Embedded Systems
- Subjects
Processor sharing ,MicroBlaze ,Source lines of code ,Computer Networks and Communications ,Computer science ,business.industry ,MPSoC ,computer.software_genre ,Artificial Intelligence ,Hardware and Architecture ,Composability ,IR-75058 ,Embedded system ,Operating system ,System integration ,System on a chip ,EWI-18977 ,Isolation (database systems) ,METIS-279121 ,business ,computer ,Software - Abstract
Multi-Processor Systems on Chip (MPSoC) run multiple independent applications, often developed by different parties. The applications share the hardware resources, e.g. processors, memories and interconnect. The sharing typically causes interference between the applications, which severely complicates system integration and verification. Even if the applications are verified in isolation, the system designer must verify the combined behaviour, leading to an explosion in design complexity. Composable MPSoCs have no interference between applications, thus allowing independent design and verification. For an MPSoC to be composable, all the hardware resources must offer composability. A particularly challenging resource is the processors, often purchased as off-the-shelf intellectual property. In this work we present the design and implementation of CompOSe, a light-weight (only 1500 lines of code) composable operating system for MPSoCs. CompOSe uses fixed-size time slices, coupled with a composable scheduler, to enable composable processor sharing. Using instances of ARM7, ARM11 and the Xilinx MicroBlaze we experimentally demonstrate the ability to provide temporal composability, even in the presence of dynamic application behaviour and multiple use cases. We do so using a diverse set of processor architectures, without requiring any hardware modifications. We also show how CompOSe allows slack to be distributed within and between applications through a novel two-level scheduler and slack-distribution system.
- Published
- 2011