Title : 
A context aware cache controller to bridge the gap between theory and practice in real-time systems
         
        
            Author : 
Allard, Yannick ; Nelissen, Geoffrey ; Goossens, Joel ; Milojevic, Dragomir
         
        
            Author_Institution : 
PARTS Res. Centre, Univ. libre de Bruxelles (ULB), Brussels, Belgium
         
        
        
        
        
        
            Abstract : 
Nowadays, most processing platforms make use of cache memories to improve the execution speed of the tasks running on the processors. However, when a processor switches from a task to another, the caches must be reloaded with the context of the upcoming task. This is time consuming and is usually not predictable and thus affects the worst-case execution time of the task. Such unpredictability should be avoided in real-time systems in which the instant at which a result is available is as important as the result itself. In this paper, we present a hardware component named hardware context switch (HwCS) which replaces the standard L1 cache controller of a processor. It divides the cache in two interchangeable layers and enables to save or restore the content of one layer while the second is simultaneously used as a usual cache by the processor. Saving the cache content after a preemption and restoring this content before resuming the execution of the preempted task, makes the preemption overheads negligible in comparison to the task worst-case execution times. It is theoretically proven that the existing scheduling theory can be used “as is” with the HwCS by simply reducing the task deadlines, thereby bridging the gap between theory and practice. The HwCS has been implemented in an uniprocessor system as a proof of concept. The first results show a neat improvements on the processor utilisation for a small cost in silicon surface.
         
        
            Keywords : 
cache storage; microcontrollers; real-time systems; ubiquitous computing; HwCS; cache content; cache memories; context aware cache controller; hardware component; hardware context switch; interchangeable layers; preemption overheads; processor utilisation; real-time systems; silicon surface; standard L1 cache controller; task deadlines; task worst-case execution times; uniprocessor system; Program processors; Switches;
         
        
        
        
            Conference_Titel : 
Embedded and Real-Time Computing Systems and Applications (RTCSA), 2014 IEEE 20th International Conference on
         
        
            Conference_Location : 
Chongqing
         
        
        
            DOI : 
10.1109/RTCSA.2014.6910503