Compositional Scheduling Analysis Using Standard Event Models by Richter, Kai
Compositional Scheduling Analysis
Using Standard Event Models
The SymTA/S Approach
KAI RICHTER
Dissertation, 2005
Institute of Computer and Communication Network Engineering
Department of Electrical Engineering and Information Technology
Technical University Carolo-Wilhelmina of Braunschweig
Braunschweig, Germany
K
a
i
 
R
i
c
h
t
e
r
 
 
 
 
 
 
 
 
 
C
o
m
p
o
s
i
t
i
o
n
a
l
 
S
c
h
e
d
u
l
i
n
g
 
A
n
a
l
y
s
i
s
 
U
s
i
n
g
 
S
t
a
n
d
a
r
d
 
E
v
e
n
t
 
M
o
d
e
l
s



Compositional Scheduling Analysis
Using Standard Event Models
The SymTA/S Approach
KAI RICHTER
Dissertation, 2005
Institute of Computer and Communication Network Engineering
Department of Electrical Engineering and Information Technology
Technical University Carolo-Wilhelmina of Braunschweig
Braunschweig, Germany

Compositional Scheduling Analysis
Using Standard Event Models
(Kompositionelle Schedulinganalyse
mit Standard-Ereignismodellen)
Von der Gemeinsamen Fakulta¨t fu¨r Maschinenbau und Elektrotechnik
der Technischen Universita¨t Carolo-Wilhelmina zu Braunschweig
zur Erlangung der Wu¨rde
eines Doktor-Ingenieurs (Dr.-Ing.)
genehmigte Dissertation
eingereicht am: 25. Oktober 2004
mu¨ndliche Pru¨fung am: 22. Dezember 2004
von: Dipl.-Ing. Kai Robert Richter
aus: Northeim, Bundesrepublik Deutschland
Referent: Prof. Dr.-Ing. Rolf Ernst
Referent: Prof. Dr. Petru Eles
Vorsitzender: Prof. Dr. Jo¨rn-Uwe Varchmin
2005

COMPOSITIONAL SCHEDULING ANALYSIS
USING STANDARD EVENT MODELS
The SymTA/S Approach
KAI RICHTER
Institute of Computer and Communication Network Engineering
Department of Electrical Engineering and Information Technology
Technical University of Braunschweig
Braunschweig, Germany
ii COMPOSITIONAL SCHEDULING ANALYSIS
Abstract
The ever increasing advances in silicon and communication technology al-
low the integration of increasing functionality in digital embedded systems,
ranging from mobile phones through multimedia home platforms to automo-
tive control networks. Embedded system designers have to cope with this in-
creasing system complexity whilst still building competitive systems to sur-
vive the market pressure, thus requiring increasing productivity. Component
and sub-system specialization and re-use provide this productivity, but system
integration is becoming a new bottleneck because the resulting heterogeneous
system must be analyzed and verified. This thesis focuses on the performance
and timing verification aspect.
Many embedded systems are real-time systems and must meet a variety of
timing requirements, such as deadlines and limited load or bandwidth, under
all possible corner-case operating conditions. But verification is difficult as
timing properties depend heavily on interactions between tasks in the system
and on the scheduling of individual tasks and communications. Unfortunately,
the current practice of specialization and re-use results in increasingly hetero-
geneous systems, which specifically complicates the scheduling analysis prob-
lem. Even today’s best practice of timed simulation is increasingly unreliable,
mainly because the corner cases are extremely difficult to find and debug, and
it is even more difficult to find simulation patterns to cover them all.
As an alternative, formal scheduling analysis techniques systematically ana-
lyze corner cases and provide guaranteed bounds on certain timing properties.
Many approaches have been proposed, but most of them are limited to sub-
problems, such as a single operating system. They ignore the complex, hetero-
geneous nature of today’s applications and architectures, and they cannot be
reasonably combined because they use different underlying analysis models.
Few approaches target more complex and heterogeneous systems and have
their application in specific areas, such as network processor design. These
approaches, however, are often too unwieldy and complex to be accepted or
iv COMPOSITIONAL SCHEDULING ANALYSIS
understood by the embedded system industry. We summarize that none of the
existing techniques is sufficiently general to comprehensively cover arbitrary
heterogeneous systems.
The main objective of this thesis is to develop a scheduling analysis pro-
cedure that a) can cope with the increasing complexity and heterogeneity of
embedded systems, b) provides the modularity and flexibility that the estab-
lished, re-use driven system integration style requires, and c) facilitates system
integration using a comprehensible analytical model.
In this thesis, a novel, structured analysis model is presented, that elegantly
captures the system-level component interactions using intuitive event models.
These event models represent the interfaces between different components, and
the clear interface structure allows their efficient adaptation to different ana-
lytical models. Several previously incompatible component and sub-system
analysis techniques can now –for the first time– be heterogeneously combined
into a system-level analysis. This allows the modular integration of heteroge-
neous system parts, whilst providing designers with the flexibility to use their
preferred local techniques without compromising global scheduling analysis.
Based on this structured analysis model, we define a sound analysis pro-
cedure that consists of few comprehensible steps. The procedure is general
enough that it can also detect and solve subtle design pitfalls, such as schedul-
ing anomalies or cyclic dependencies, which are virtually impossible to find
using simulation. The sound view on the component interactions substantially
improves designers’ understanding of the key integration problems, and allows
them to influence and control these interactions to optimize the system glob-
ally.
The application of the approach is demonstrated in detail using a variety of
expressive examples and experiments. As the new analysis procedure can be
efficiently applied in practice, it provides a serious and promising complement
to simulation. It allows comprehensive system integration and optimization,
and it provides much more reliable performance analysis results, at the same
time requiring far less computation time.
Kurzfassung
Als Folge des technologischen Fortschritts bei Halbleitern und Kommuni-
kationsmedien werden heute zunehmend mehr Funktionen in digitalen, ein-
gebetteten Systemen integriert. Beispiele reichen von relativ kleinen Mobil-
telefonen u¨ber Multi-Media Heimgera¨te bis hin zu vernetzter Automobilelek-
tronik. Um konkurrenzfa¨hige Produkte zu entwickeln muss die steigende Sys-
temkomplexita¨t bewa¨ltigt werden. Die dazu notwendige Entwurfsproduktivita¨t
wird vermehrt durch die Wiederverwendung und Integration von spezialisier-
ten Systemkomponenten (Hardware und Software) erreicht, was allerdings zu
neuen Engpa¨ssen fu¨hrt, denn die Integration und das resultierende heterogene
Gesamtsystem muss analysiert und verifiziert werden. Die vorliegende Arbeit
befasst sich mit Kernfragen der Performanz- und Echtzeitanalyse solcher Sys-
teme.
Eingebettete Systeme sind zumeist Echtzeitsysteme und mu¨ssen eine Viel-
zahl von Zeit- und Performanzanforderungen erfu¨llen, z. B. maximale Reak-
tionszeiten oder vorgegebene Kommunikationsbandbreiten, und zwar unter Be-
achtung aller Randfa¨lle (worst-case). Die Echtzeiteigenschaften ha¨ngen stark
vom Zusammenspiel der Einzelkomponenten sowie deren Scheduling durch
Betriebssysteme und Kommunikationsprotokolle ab. Unglu¨cklicherweise fu¨hrt
gerade die Wiederverwendung von spezialisierten Komponenten zu einer He-
terogenita¨t, die die Schedulinganalyse zusa¨tzlich erschwert. Als Folge sind die
nach dem Stand der Technik eingesetzten Simulationsverfahren zusehends un-
zuverla¨ssig, da die kritischen Randfa¨lle in der Praxis kaum mehr vollsta¨ndig
bestimmt werden ko¨nnen.
Als Alternative zur Simulation zeichnen sich formale Methoden gerade bei
der Betrachtung von Randfa¨llen durch ein systematisches und zuverla¨ssiges
Vorgehen aus. Der Großteil existierender Ansa¨tze ist jedoch auf spezielle
Teilprobleme beschra¨nkt, z. B. die isolierte Analyse eines Betriebssystems.
Aufgrund der unterschiedlichen zugrundeliegenden Analysemodelle sind diese
Ansa¨tze inkompatibel zueinander und eignen sich nicht zur Analyse heteroge-
vi COMPOSITIONAL SCHEDULING ANALYSIS
ner Systeme. Einige wenige Ansa¨tze erfassen zwar komplexere Systeme aus
speziellen Anwendungsgebieten, z. B. Netzwerkprozessoren, sind jedoch fu¨r
den Allgemeinfall zu unhandlich und finden daher nur eine geringe Akzep-
tanz. Zusammenfassend stellen wir fest, dass es heute keine hinreichend all-
gemeingu¨ltige Technik zur umfassenden Schedulinganalyse von heterogenen
Systemen gibt.
Das Hauptziel dieser Arbeit ist die Entwicklung eines Verfahrens zur Sche-
dulinganalyse, das a) die steigende Komplexita¨t und Heterogenita¨t angemes-
sen erfasst, b) u¨ber die Modularita¨t und Flexibilita¨t verfu¨gt, die mit Wieder-
verwendung und Integration erforderlich ist, und c) die Integration durch ein
nachvollziehbares Analysemodell unterstu¨tzt.
Diese Arbeit stellt ein neues, strukturiertes Analysemodell vor, das die kom-
plexen Abha¨ngigkeiten auf der Systemebene mit Hilfe von intuitiven Ereignis-
modellen erfasst. Diese Ereignismodelle bilden die Schnittstellen zwischen
unterschiedlichen Komponenten, und die klare Strukturierung ermo¨glicht die
effiziente Anpassung dieser Schnittstellen an verschiedenartige Analysemo-
delle. Dadurch ko¨nnen nun erstmals mehrere unterschiedliche, vormals inkom-
patible Teilsystemanalysen wiederverwendet und unter Beibehaltung der Sys-
temstruktur heterogen zu einer Gesamtsystemanalyse zusammengesetzt wer-
den (Komposition). Dies erlaubt die modulare Integration von unterschied-
lichen Systemteilen und gibt Entwicklern gleichzeitig die no¨tige Flexibilita¨t,
ihre bevorzugten lokalen Entwurfsmethoden zu benutzen, ohne auf die globale
Schedulinganalyse verzichten zu mu¨ssen.
Das Analysemodell bildet die Grundlage fu¨r ein allgemein anwendbares
Analyseverfahren, das aus wenigen intuitiven Schritten besteht. Das Verfah-
ren ermo¨glicht Entwicklern, auch diejenigen subtilen Performanzprobleme zu
erkennen und aufzulo¨sen, die beispielsweise durch Schedulinganomalien oder
komplexe zyklische Abha¨ngigkeiten hervorgerufen werden und in der Simula-
tion praktisch unerkannt bleiben. Durch die Darstellung der Komponentenin-
teraktionen mittels versta¨ndlicher Ereignismodelle ko¨nnen die Kernprobleme
der Integration nachvollzogen werden. Weiterhin kann gezielt auf die Kom-
ponenteninteraktion Einfluss genommen und das System global optimiert wer-
den.
Das Verfahren und die Anwendung wird an einer Reihe aussagekra¨ftiger
Beispiele und Experimente im Detail erla¨utert. Es ist in der Praxis sehr ef-
fizient einsetzbar, womit sich eine ernstzunehmende und vielversprechende
Erga¨nzung zur heute etablierten Performanz-Simulation ero¨ffnet. Im Vergleich
ermo¨glicht das neue Verfahren eine umfassende Systemintegration und -opti-
mierung und liefert zuverla¨ssige Analyseergebnisse in deutlich ku¨rzerer Zeit.
Acknowledgments
This thesis summarizes the key scientific results of my research at the In-
stitute of Computer and Communication Network Engineering (IDA) at the
Technical University of Braunschweig, Germany.
First of all, I would like to express my sincere gratitude to my advisor Pro-
fessor Rolf Ernst for introducing me to embedded real-time systems research,
and for supporting me finding my way through. His visionary and challenging
ideas –in combination with his patience, insight, and guidance– made this the-
sis possible and SymTA/S a successful project. I also want to thank Professor
Petru Eles for his constructive comments related to my research and my dis-
sertation, and for agreeing to co-examine this work, and Professor Jo¨rn-Uwe
Varchmin for chairing the examination committee.
I have had the pleasure to work together with a group of very talented,
fun, and challenging people. Many thanks to Dirk Ziegenbein and Marek Jer-
sak, my wonderful colleagues and friends in the SPI project. Marek again
for our fruitful ongoing collaboration in the SymTA/S project, and for shar-
ing the boldness to turn it into an entrepreneurial partnership. I also want to
thank my junior colleagues Jo¨rn-Christian Braam, Arne Hamann, Rafik Henia,
Ruben Jubeh, Razvan Racu, Simon Schliecker, and Jan Staschulat who en-
riched the SymTA/S project both scientifically and personally. Thanks also to
Hans Gro¨nniger and to all other contributors in the SPI and SymTA/S projects.
Further thanks go to the research groups of Professor Lothar Thiele in Zu¨rich
and Professor Ju¨rgen Teich in Paderborn/Erlangen, especially to Simon Ku¨nzli
and Christian Haubelt, and to others for cooperations in many projects.
I want to thank the institute staff for providing and maintaining a profes-
sional but still personal work environment, the labs for repeatedly helping me
repairing my bike and electronic gadgets, Prof. Ernst again for funding the
institute’s fully-automatic high-end espresso machine, and Gwylim Jones for
proof-reading the manuscript.
viii COMPOSITIONAL SCHEDULING ANALYSIS
I want to thank my parents for recognizing and intensifying my scientific-
technical interests early, and for encouraging me to study engineering. Most
importantly, I want to thank my beloved and charming Alexandra for her sup-
port and understanding for the effort it took me writing up this thesis, for her
patience when I was coming home late or working in the week-ends, and for
the love and the joy we share in our personal life.
Finally, I like to thank all people who expected to be honored explicitly here.
This line is dedicated to you!
Contents
List of Figures xv
List of Tables xix
1 INTRODUCTION 1
1.1 Inﬂuences on HW/SW System Performance 3
1.2 Performance Simulation and Coverage 6
1.3 Objectives & Outline 8
2 SCHEDULING AND PERFORMANCE ANALYSIS 11
2.1 Component Scheduling Analysis 11
2.1.1 Rate-Monotonic Scheduling 12
2.1.2 Other Static-Priority Schedulers 14
2.1.3 Dynamic Priority Assignments 17
2.1.4 Time-Driven Scheduling 18
2.1.5 Other Scheduling Strategies 19
2.1.6 Industrial Application 19
2.2 System-Level Extensions 20
2.2.1 Homogeneous Multi-Processors 20
2.2.2 Holistic Schedulability Analysis 21
2.3 Flow-Based Analysis 23
2.3.1 Event Vectors 23
2.3.2 Arrival Curves 24
2.4 Previous Own Work 25
2.5 Summary & New Approach 25
2.5.1 Evaluation 25
2.5.2 Revised Objectives & Basic Idea 27
2.5.3 Key Challenges 27
x COMPOSITIONAL SCHEDULING ANALYSIS
2.5.4 Detailed Outline 29
3 INPUT EVENT MODELS 31
3.1 Task Activation and Event Streams 31
3.2 Common Properties of Event Streams 32
3.3 Strictly Periodic Events 33
3.3.1 The η(∆t) Functions 33
3.3.2 The δ(n) Functions 37
3.4 Event Streams vs. Event Models 38
3.5 Periodic Events with Jitter 39
3.5.1 The η(∆t) Functions 39
3.5.2 The δ(n) Functions 42
3.5.3 Event Model Deﬁnition 43
3.6 Sporadic Events 44
3.6.1 The η(∆t) Functions 44
3.6.2 The δ(n) Functions 45
3.6.3 Event Model Deﬁnition 46
3.7 Sporadically Periodic Events 46
3.7.1 The η(∆t) Functions 46
3.7.2 The δ(n) Functions 48
3.7.3 Event Model Deﬁnition 49
3.8 Summary 49
4 OUTPUT EVENT MODELS 51
4.1 Periodic Task Activation 51
4.1.1 Constant Response Times 52
4.1.2 Response Time Intervals and Output Jitter 52
4.1.3 Inheritance of Input Jitter 53
4.1.4 Event Streams with Large Jitters 55
4.2 Implications of Large Jitters 57
4.2.1 Propagation of Large Jitters 58
4.2.2 Limitations and Ineﬃciencies 60
4.2.3 Modeling Alternatives 61
4.3 A New Model: Periodic Events with Burst 62
4.3.1 The η(∆t) Functions 63
4.3.2 The δ(n) Functions 64
4.3.3 Bounding the Minimum Output Distance 65
4.4 Sporadic Task Activation 65
Contents xi
4.4.1 Constant Response Time 66
4.4.2 Response Time Interval 66
4.4.3 Decreasing Inter-Arrival Times 67
4.4.4 Sporadically Periodic Task Activation 67
4.5 Conditional Output Generation 68
4.5.1 Constant Response Times 68
4.5.2 Response Time Intervals 69
4.5.3 Input with Jitter and Burst 69
4.6 New Sporadic Models with Jitter and Burst 70
4.6.1 Sporadic Events with Jitter 70
4.6.2 Sporadic Events with Burst 71
4.6.3 Sporadic Activation and Conditional Output 72
4.7 A Six-Class Model Set 72
4.8 Summary 74
5 EVENT MODEL INTERFACES 77
5.1 Introductory Example 77
5.2 Event Stream Compatibility Tests 80
5.3 Interface Veriﬁcation 81
5.3.1 Graphical Veriﬁcation 83
5.3.2 Formal Veriﬁcation 85
5.3.3 Interface Quality 88
5.4 Existing Interfaces 89
5.5 Lossless Event Model Interfaces 90
5.5.1 Strictly Periodic → Periodic with Jitter 90
5.5.2 Periodic with Jitter → Periodic with Burst 90
5.5.3 Strictly Sporadic → Sporadic with Jitter 91
5.5.4 Sporadic with Jitter → Sporadic with Burst 91
5.5.5 Model Reductions 91
5.6 Lossy Event Model Interfaces 92
5.6.1 Transforming Periodic into Sporadic Models 92
5.6.2 Sporadic with Jitter → Strictly Sporadic 93
5.6.3 Sporadic with Burst → Strictly Sporadic 94
5.7 Composite Event Model Interfaces 96
5.7.1 Strictly Periodic → Periodic with Burst 96
5.7.2 Strictly Sporadic → Sporadic with Burst 97
5.7.3 Strictly Periodic → Sporadic with Jitter 97
5.7.4 Strictly Periodic → Sporadic with Burst 98
xii COMPOSITIONAL SCHEDULING ANALYSIS
5.7.5 Periodic with Jitter → Strictly Sporadic 98
5.7.6 Periodic with Jitter → Sporadic with Burst 99
5.7.7 Periodic with Burst → Strictly Sporadic 99
5.7.8 Periodic with Burst → Sporadic with Jitter 99
5.7.9 Sporadic with Burst → Sporadic with Jitter 99
5.8 Including Sporadically Periodic Events 99
5.8.1 Tindell’s Burst → Sporadic with Burst 100
5.8.2 Sporadic with Burst → Tindell’s Burst 103
5.9 Summary 106
6 EVENT ADAPTATION FUNCTIONS 109
6.1 Introductory Example 109
6.2 Periodic Synchronization 111
6.2.1 Shaper Implementation 111
6.2.2 Shaper Properties 112
6.2.3 The Conservative Approach 113
6.2.4 Corner-Case Analysis 114
6.2.5 Formal Shaper Analysis 117
6.3 Periodic Shaping of Jitter and Burst 121
6.3.1 Small Jitters 121
6.3.2 Large Jitters and Bursts 125
6.3.3 System-Level Inﬂuence of Jitter 127
6.3.4 Optimizations 128
6.3.5 Experiment 131
6.4 Sporadic Shaping 134
6.4.1 Transient Load Reduction 134
6.4.2 Shaper Delay and Backlog 136
6.4.3 Experiments 141
6.4.4 Shaping Sporadic Streams 146
6.5 Automatic Shaping 147
6.6 Polling 149
6.6.1 Input Buﬀer 150
6.6.2 Execution Load and Response Time 151
6.6.3 Output Event Streams 152
6.7 Summary 154
Contents xiii
7 SYSTEM-LEVEL ANALYSIS PROCEDURE 157
7.1 System Analysis Model 158
7.1.1 Model Elements and Parameters 158
7.1.2 Model Structure and Dependencies 158
7.1.3 Environment Modeling 159
7.1.4 Local Scheduling 159
7.2 The System-Level Analysis Procedure 159
7.3 Local and Global Constraint Veriﬁcation 164
7.3.1 Environmental Constraints 164
7.3.2 Internal Event Streams 164
7.3.3 Local Task and Resource Properties 164
7.3.4 Path Constraints 164
7.3.5 Buﬀer Constraints 166
7.4 Cyclic Event Stream Dependencies 166
7.4.1 The Starting Point 166
7.4.2 Cyclic Analysis 167
7.4.3 Convergence and Termination 168
7.5 Example 169
7.5.1 System Set-Up 169
7.5.2 Analysis Set-Up 172
7.6 Iterative Analysis 173
7.6.1 Analysis Cycle 0: Starting Point Generation 173
7.6.2 Analysis Cycle 1 173
7.6.3 Analysis Cycle 2 176
7.6.4 Analysis Cycle 3 178
7.6.5 Analysis Cycle 4: Termination 179
7.6.6 Sink Task Input Requirements 179
7.6.7 Results 181
7.7 Optimizations 184
7.7.1 Full Re-Synchronization 184
7.7.2 Dynamic Bus Load Reduction 185
7.7.3 Reducing the Bus Speed 186
7.7.4 Concluding Remarks 187
7.8 Summary 187
8 SUMMARY AND CONCLUSION 189
8.1 Summary 189
8.2 Extensibility 190
xiv COMPOSITIONAL SCHEDULING ANALYSIS
8.3 Outlook and Future Work 192
8.4 Conclusion 192
Bibliography 195
List of Figures
1.1 Complex HW/SW Building Block 2
1.2 System Integration using a Shared Bus 3
1.3 Complex Execution Sequences 4
1.4 Scheduling Anomaly in Distributed Systems 5
1.5 Non-Functional Performance Dependency Cycles 6
2.1 Scope of Component-Level Analysis 12
2.2 Scheduling Diagram of Rate-Monotonic Scheduling 13
2.3 Scope of Homogeneous Shared-Memory Multiproces-
sor Analysis 21
2.4 Scope of Homogeneous Flow-Based Scheduling Analysis 23
2.5 Heterogeneous Flow-Based Scheduling Analysis 28
3.1 Time Intervals and Number of Events of Periodic Event
Streams 34
3.2 Maximum Number of Events of Periodic Event Streams 35
3.3 Upper Bound Arrival Curve of Strictly Periodic Events 36
3.4 Lower Bound Arrival Curve of Strictly Periodic Events 37
3.5 Both Arrival Curves of Strictly Periodic Events 37
3.6 Time Intervals and Number of Events of Periodic Events
with Jitter 40
3.7 Upper Bound Arrival Curve of Periodic Events with Jitter 40
3.8 Lower Bound Arrival Curve of Periodic Events with Jitter 42
3.9 Both Arrival Curves of Periodic Events with Jitter 42
3.10 Upper Bound Arrival Curve of Sporadic Events 44
3.11 Both Arrival Curves of Sporadic Events 45
3.12 Upper Bound Arrival Curve of Sporadically Periodic Events 47
xvi List of Figures
3.13 Both Arrival Curves of Sporadically Periodic Events 48
4.1 Periodic Task with Constant Response Time 52
4.2 Inheritance of Response Time Jitter at Task Output 53
4.3 Non-Constant Response Times in a Task Chain 54
4.4 Early and Late Scheduling Diagrams 54
4.5 Upper-Bound Arrival Curve of Periodic Events with
“Large” Jitter 56
4.6 Lower- Bound Arrival Curve of Periodic Events with
“Large” Jitter 57
4.7 An Example of Output Events with “Large” Jitter 58
4.8 Distributed System Example 58
4.9 Scheduling with Simultaneous Task Activation due to
Large Jitters 59
4.10 Scheduling with Large Jitter but Bounded Inter-Arrival Time 60
4.11 Comparison between two Schedules 61
4.12 Upper-Bound Arrival Curve of Periodic Events with
Burst: “Large” Jitter and a Minimum Distance 63
4.13 Upper- and Lower-Bound Arrival Curves of Periodic
Events with Burst 64
4.14 Sporadic Task Execution with Constant Response Time 66
4.15 Worst-Case Output Timing of Sporadic Tasks 67
4.16 Two Corner Cases of Conditional Output Production 69
4.17 Upper- and Lower-Bound Arrival Curves of Sporadic
Events with Jitter 70
4.18 Upper- and Lower-Bound Arrival Curves of Sporadic
Events with Burst 71
4.19 Self-Contained Six-Class Event Model Set 73
5.1 Introductory Example: Unidirectional Task-Task Com-
munication via Event Streams 78
5.2 Worst-Case Event Timing 79
5.3 Problem Illustration 80
5.4 Graphical Representation of Stream Coverage 83
5.5 η(∆t) Curves of EMIFP+J→S 84
5.6 Existing Atomic Event Model Interfaces 89
5.7 η(∆t) Curves of EMIFP+J→S+J 93
5.8 η(∆t) Curves of EMIFS+J→S 94
5.9 η(∆t) Curves of EMIFS+B→S 95
List of Figures xvii
5.10 Existing Composite Event Model Interfaces 96
5.11 Two Paths from Strictly Periodic to Sporadic with Jitter 98
5.12 η(∆t) Curves of EMIFB→S+B 100
5.13 An Abstract View of the Curves of EMIFB→S+B 102
5.14 η(∆t) Curves of EMIFS+B→B 103
5.15 Comparison of Four EMIFS+B→B Choices 105
5.16 All Existing Event Model Interfaces 107
6.1 Introductory Example 110
6.2 Application of Event Adaptation Functions EAF 111
6.3 Buffering of Strictly Periodic Events 112
6.4 Avoiding Buffer Underrun by Pre-loaded Buffer 113
6.5 Additional Delay 114
6.6 Over-dimensioning of Buffer Size 114
6.7 Event Input and Output Curves of Buffer Underrun Situation 115
6.8 Case 2: Event Availability and Output Curves 116
6.9 Case 1: Event Availability and Output Curves 117
6.10 Synchronization of Jitter: Case 1 without Adaptation 121
6.11 Synchronization of Jitter: Case 2 without Adaptation 122
6.12 Synchronization of Jitter: Case 1 with Adaptation 123
6.13 Synchronization of Jitter: Case 2 with Adaptation 124
6.14 Overwriting an Unnecessarily Pre-Loaded Event 129
6.15 Event Curves with Optimized Buffer Set-Up 129
6.16 Scheduling Diagram of Un-shaped System 132
6.17 Scheduling Diagram of System with Periodic Shaper 133
6.18 Influence of Sporadic Shaping on Upper-Bound Event Curves 135
6.19 Scheduling Diagram of Sporadic Shaping with a Time-
Out of 200 136
6.20 Single Critical Event in Sporadic Shaping 137
6.21 Two Critical Events in Sporadic Shaping 139
6.22 Scheduling Diagram of System Sporadic Shaper with a
Time-Out of 400 142
6.23 Scheduling Diagram of System Sporadic Shaper with a
Time-Out of 140 143
6.24 Scheduling Diagram of System Sporadic Shaper with a
Time-Out of 90 144
6.25 Scheduling Diagrams of All Experiments 145
6.26 Periodic Polling Task and the Involved Event Streams 149
xviii List of Figures
6.27 Polling a Periodic Stream with Burst 150
6.28 Output Stream of Conditional-Output Polling Tasks 153
6.29 Existing Event Adaptation Functions 154
7.1 System Model Example 158
7.2 System-Level Analysis Procedure 160
7.3 Input Event Stream Capturing 161
7.4 Path Latencies and Constraints 165
7.5 System-Level Analysis Turns into a Convergence Problem 167
7.6 Detailed System Example 169
7.7 SymTA/S Model of Example System 172
7.8 CPU Scheduling Diagram of First Analysis Cycle 174
7.9 Bus Scheduling Diagram of First Analysis Cycle 175
7.10 CPU Scheduling Diagram of Second Analysis Cycle 176
7.11 Bus Scheduling Diagram of Second Analysis Cycle 177
7.12 CPU Scheduling Diagram of Third Analysis Cycle 178
7.13 Required Event Adaptation Functions EAF 180
7.14 Scheduling Diagrams of All Analysis Cycles 183
7.15 Bus Scheduling Diagram with Sporadic Shaper 186
List of Tables
3.1 Parameters and Characteristic Functions of the Four
Most Popular Event Models 50
4.1 The η(∆t) Functions of the New Models 73
4.2 The δ(∆t) Functions of the New Models 73
6.1 Task Parameters of Example System 131
6.2 Experiment without Shaper 132
6.3 Experiment with Periodic Shaper at Task T2’s Input 133
6.4 Experiment with Sporadic Shaper with a Time-Out of 200 141
6.5 Experiment with Sporadic Shaper with a Time-Out of 400 142
6.6 Experiment with Sporadic Shaper with a Time-Out of 140 143
6.7 Experiment with Sporadic Shaper with a Time-Out of 90 144
6.8 Overview of Delay and Backlog of All Experiments 146
7.1 Experiment Results 182
7.2 Path Properties of All Experiments 185
7.3 Path Properties of All Experiments with Reduced Bus Speed 187
xx List of Tables
Chapter 1
INTRODUCTION
There is increasing competition in major digital embedded system markets.
Examples range from relatively small system-on-chip (SoC) such as network
and telecom processors, through more complex consumer electronics such as
multi-media home platforms and mobile appliances, to physically distributed
systems in the automotive and avionics domain.
Today, major design goals include high quality and reliability at a com-
petitive cost. Depending on the application, other goals such as low power,
size, and weight might also be important. In addition, ever shorter market
windows with decreasing product lifetime cycles must be met. As silicon tech-
nology advances, more and more functions can be implemented on a single
chip. These time-to-market and cost pressures require remarkable productivity
improvements (design gap).
It is obvious that design from scratch does not provide the amount of pro-
ductivity required to build competitive systems in time. Industry responds by
defining and re-using legacy and IP (intellectual property) components and
sub-systems to implement the application functions. These pre-designed and/or
supplied components represent the atomic building blocks of today’s architec-
tures.
In the area of SoC design, industry offers an increasing number of config-
urable processor cores, hardware accelerators, peripherals as well as communi-
cation infrastructure, protocols, and entire network-on-chip solutions. There is
often more than one bus or network on a single chip, and chip design gradually
moves from core centric SoC to communication centric MpSoC design.
The same trend can be observed in the area of physically distributed sys-
tems, such as automotive, where heterogeneous component integration has al-
ready been in practice for several years. Car manufacturers have turned into
system houses that integrate hardware and software IP components, including
2 Introduction
Core
RTOS
I/O Int
Bus-
CTRL
Timer
Timer
Drivers
RTOS-APIs
Application
CoPro
cache
MEM
private
private
private
private
s
h
a
re
d
Bus / Network
Hardware
Software
Architecture
Application
basic func.
Figure 1.1. Complex HW/SW Building Block
operating systems (with OSEK/VDX [80] as a de facto OS standard with many
flavors) and so called basic functions, or whole electronic control units (ECUs)
from different suppliers. The integration is based on standardized communi-
cation infrastructure, such as controller area network (CAN [85]), local in-
terconnect network (LIN [72]), the time-triggered protocol (TTP [125]), and
Flexray [36].
Figure 1.1 shows a typical building block of today’s systems. Almost every-
thing is re-used or supplied externally. Such programmable processors and/or
configurable co-processors give ECU designers the amount of flexibility to
customize these components quickly with respect to a dedicated distinguish-
ing application. The increasing (re-) use of software functions is a key step
for increasing productivity. In turn, software dominated systems require op-
erating systems, APIs, and drivers to control the function execution on shared
processors, which further complicates the design process.
This component specialization, optimization, and customization, required to
design competitive systems, results in increasingly heterogeneous distributed
systems with heterogeneous cores, communications, memories, and schedul-
ing strategies. Figure 1.2 shows an example, where the already complex sub-
system of Figure 1.1 now becomes merely a small part of a larger system.
The integration process is becoming the major challenge including HW/SW
component and sub-system interfacing, design space exploration, integration
verification, and design process integration. This dissertation focuses on the
verification aspect.
System verification can be further separated into function verification and
architecture performance and timing verification. Function verification is con-
cerned with the correct implementation of a specified function. Roughly speak-
ing, it is verifying that the system calculates the correct output for a given
system input. Target architecture performance verification checks if the archi-
tecture is able to execute (or perform) a given application, thereby meeting
Inﬂuences on HW/SW System Performance 3
M2IP2M3
M1
DSPIP1
HWCPU
M2
IP2M3
M1
DSP
IP1HW
CPU
integration
sub-system 1
sub-system 2
T1
system bus
Sens
Sens
T2
T3
Figure 1.2. System Integration using a Shared Bus
a set of non-functional constraints including processing and communication
deadlines, memory requirements, etc.. Closely related, function timing analy-
sis provides detailed information about the actual timing of the application, or
parts of it. These verification issues are particularly important for all real-time
systems and require consideration of non-functional performance dependen-
cies. The complexity furthermore increases with system size and architectural
hardware/software heterogeneity. This thesis focuses on performance and tim-
ing analysis for heterogeneous architectures.
1.1 Inﬂuences on HW/SW System Performance
Complex hardware and software component interactions result in a variety
of performance pitfalls, including transient overload, buffer under- and over-
flows, missed deadlines, and architecture dependent dead- or life-locks. The
ITRS [104] names system level performance verification as one of the top-
three MpSoC design issues. The same problem has been recognized by the
“AUTOSAR development partnership” [7], in which large parts of the Euro-
pean automotive industry aim at establishing an open standard for automotive
E/E architectures. The leading German electronics magazine [2] says “net-
working and the increasing software complexity pose key challenges on future
automotive system design, and requires re-consideration of integration prac-
tice, and cooperations”. But why is it so complex?
4 Introduction
worst-case
situation
burst
jitter
burst
p
rio
rity
output eventsinput events
T1
buffering
T3
T1
T2T2 T2
t t = tworst case
buffering
M1
HW
CPUSens
T3
T2
T1
T3
T2
T1
Figure 1.3. Complex Execution Sequences
HW and SW integration involves resource sharing based on operating sys-
tems and bus/network protocols. Resource sharing requires scheduling that
results in a confusing variety of performance dependencies at run-time, which
are induced by the architecture and not reflected in the system function.
As an example, Figure 1.3 shows a CPU sub-system executing three inde-
pendent tasks: T1 to T3. Scheduling is preemptive and follows static priorities;
a popular OS setup. Although the operating system activates all tasks peri-
odically with periods T1, T2, and T3, respectively, the scheduling diagram in
Figure 1.3 shows that the resulting execution sequence is rather complex.
Due to scheduling, the lower priority tasks T2 and T3 are preempted or de-
layed by the higher level task T1. T2 can further preempt or delay T3. Such
preemptions and delays disturb the initially periodic task execution. As Fig-
ure 1.3 shows, T1 can noticeably delay the completion time of T2, resulting
in a jitter on T2’s output. More complexly, T1 can delay several executions of
T3. After T1 completes, T3 –with its input buffers filled– runs in “burst” mode
with its execution frequency only limited by the available processor perfor-
mance. This leads to transient output bursts for T3, modulated by T1 execution
and possibly further disturbed by T2 preemptions. A worst-case scenario for
T3 with maximum delay and preemption, maximum buffering, and maximum
task response time is highlighted in the figure.
Even this relatively small example with only three tasks, comprehensibly il-
lustrates the tremendous influence of resource sharing on system performance
and task timing. Figure 1.3 shows that the influence of scheduling heavily in-
creases with decreasing task priorities. Hence, realistic systems with more (up
to 30 and more) tasks and priority levels result in even more complex execution
scenarios.
The example above does not even include data-dependent task execution
times, which are typical for software systems. Furthermore, operating system
overhead is neglected. Both effects have to be considered during analysis and
Inﬂuences on HW/SW System Performance 5
M2IP2M3
M1
DSPIP1
HWCPUSens
bus
sub-system 1
sub-system 2
CPUM1
system bus
HW
P3
minimum
execution time
ª minimum
bus load
ª maximum
bus load
maximum
execution time
T
Figure 1.4. Scheduling Anomaly in Distributed Systems
further complicate the problem. We conclude that finding corner cases which
reveal all influences of scheduling on a single CPU is already challenging.
System integration introduces another type of performance dependencies.
Figure 1.4 shows an example. The system of Figure 1.3 is now only a sub-
system and is integrated with a second DSP application using a shared bus
or network-on-chip (NoC). The curved arrows in Figure 1.4 illustrate perfor-
mance dependencies between the CPU and DSP sub-systems. These depen-
dencies are not reflected in the system function but result from system inte-
gration and network arbitration, required to schedule transmissions over the
shared communication bus.
These dependencies can turn component (e. g. CPU) best-case behavior into
system worst-case behavior, and vice versa –a so called scheduling anomaly.
Recall the T3 burst execution from Figure 1.3 and consider that T3’s execution
time can vary from one execution to the next (data-dependency). There are
two critical execution scenarios, called corner cases: The minimum execution
time of T3 corresponds to the maximum transient bus load (number of T3 out-
puts and, hence, transmissions over time), slowing down other component’s
communication. In turn, a maximum execution time results in less frequent
data transmissions, and thus represents the minimum bus load during a burst.
Larger systems will exhibit even more complex communication patterns.
An additional performance pitfall in distributed system design occurs when
cyclic performance dependencies are introduced during system integration.
These dependencies are subtle and difficult to detect if the integration process
does not consider component details. Figure 1.5 highlights a non-functional
event stream dependency cycle in the system of Figure 1.4 that is only intro-
duced by communication sharing. Upon receipt of new sensor data, the CPU
activates task T1 which preempts T3 and thus affects the execution timing of
T3. Figure 1.3 illustrates this preemption. Task T3’s output, in turn, enters
the network on channel C2, where it now interferes with the arriving sensor
data on C1. The interference of the two functionally independent channels, C1
6 Introduction
pre-emption
interference  
HWSens
T1
C1 C2
T3
Figure 1.5. Non-Functional Performance Dependency Cycles
and C2, closes the dependency cycle, since the sub-system in Figure 1.3 was
originally cycle-free.
The complex run-time effects shown in Figures 1.3, 1.4 and 1.5 lead to
complex system-level performance corner cases, which, during performance
verification, have to be considered and checked against given performance
constraints such as buffer constraints, end-to-end deadlines (e.g. from Sen-
sor to HW in Figure 1.4), and many others. Essentially, if all corner cases
satisfy the performance constraints, then the system is guaranteed to satisfy
the constraints under all possible operation conditions. Conversely, each cor-
ner case that is not considered during verification reduces the reliability of the
system with respect to performance and timing. However, many corner cases
are extremely difficult to find. Just consider the T3 communication schedul-
ing anomaly in Figure 1.4, and recall that the T3 bursts further depend on the
execution behavior (execution time, activation period) of T1 (see Figure 1.3).
1.2 Performance Simulation and Coverage
Today, test and simulation are the preferred means of function and perfor-
mance verification. While test can only be applied to the final design or a proto-
type, simulation is supported at all abstraction levels. High-level languages are
often used for first proofs of concept. They allow an executable specification of
the intended functional behavior, which can be simulated. The interface stan-
dardization efforts, such as VSIA [131] and Accellera [1] in the SoC domain,
and the mentioned bus protocols and hardware dependent software layers that
the OSEK/VDX standard [80] defines for automotive systems, supports inte-
gration of blocks and components (function and architecture). They target an
easy-to-use “cut&paste” design style, since the individual components can be
easily pulled from a library and connected to each other. This drastically im-
proves design productivity. Standardized operating systems and APIs have the
same goal.
Performance Simulation and Coverage 7
The executable architecture model is then also simulated. Simulation is
supported at all levels, ranging from RTL or gate-level to cycle-accurate co-
simulation of the entire hardware/software system using tools such as Mentor
Seamless CVE [77], or Axys MaxSim [8]. Recently VaST, who started in the
SoC and consumer electronics market, extended its CoMET [129] design and
simulation environment to also cope with the specific problems of automotive
system design. Simulation has some obvious advantages. Using the same sim-
ulation environment, the same verification patterns, and benchmarks already
available from functional verification, designers have elegant means to test an
architecture design against a functional specification.
The co-simulation times are extensive because performance simulation re-
quires detailed timed models that are usually more complex than the un-timed
–or simplified– models used in function verification. This is a major bottleneck
during design, and becomes particularly painful in iterative design space explo-
ration, reducing optimization possibilities, and consequently, system quality.
Abstract simulation using, for instance, Cadence VCC [19], is faster and pro-
vides temporary relief but comes at the cost of introducing yet another model.
Test is the fastest but can only be applied very late in the design process; and
more important than the speed, there is a serious, conceptual limitation to test-
and simulation-based performance verification that becomes critical as com-
plexity increases.
While function verification can also check for correct functional component
(integration) interactions, the complex component performance dependencies
that integration, and especially resource sharing introduces, are only partially
visible in the system function, if at all. As a consequence, function verification
patterns will most likely miss some of the critical performance corner cases
illustrated in the preceding section. Identifying all performance corner cases
is extremely difficult, and it is even more difficult to find patterns that reach all
of them.
So, where do we get the patterns from? On the one hand, re-using the pat-
terns from function verification is not sufficient because they do not reflect
architecture dependencies that scheduling introduces. On the other hand, com-
ponent verification patterns –if available– are not sufficient, either, because
they do not cover the complex component interactions that result from system
integration.
In other words, corner case identification and pattern generation, which are
the critical steps in performance simulation, are unfortunately not composi-
tional as the design is. This is a key disadvantage of simulation. If the system
is sufficiently simple, an integrator might manually add new patterns. But this
requires detailed knowledge of component implementations which is often not
available to the integrator in this high-level “cut&paste” design style. An ad-
ditional problem is that corner cases appear and disappear as new components
8 Introduction
are added or modified. This shows that manual pattern generation for com-
plex systems with multiple cores and buses is virtually impossible and not a
practical option.
Two different reactions to this problem can be observed in industry. First,
designers apply more extensive test with more patterns. This is likely to cover
more of the mentioned performance corner cases. However, due to the lack
of a systematic pattern generation procedure, this apparent improvement does
not represent a real advantage as it compromises reliability and increases the
design risk. Designers do not know if their patterns cover all corner cases,
since there is no means to check this coverage. In effect, test- and simulation-
based performance verification is increasingly unreliable as systems grow and
we ultimately believe that it will run out of steam soon.
Alternatively, designers can deliberately waive system efficiency and en-
force static, synchronous systems [127, 126] using static resource sharing strate-
gies. This is specifically popular for communication infrastructure scheduling
as the center of all integration efforts. A variety of new TDMA-based proto-
cols such as TTP [125, 64], Flexray [36], TTCAN [25], and Sonics [107] have
been offered in recent years. Such protocols decouple component timing and
eliminate a large part of the complex dependencies, so that system-level tim-
ing is easily predictable. In other words, the synchronous or static approach
benefits from the fact that component and system integration does not add new
performance corner cases. It is possible to oversee the individual components,
coverage can be manually controlled, and simulation and test can provide very
reliable results.
But this simplicity comes at huge efficiency price that increases with system
size. There are areas where this is acceptable, such as in the military and
avionics industries, where the need for system reliability and dependability
dominates other optimization goals such as cost and utilization. However, the
conservative and less efficient static approach does not scale well to the high-
volume low-cost consumer field with multimedia, telecommunications, mobile
appliances, etc., where future MpSoC will integrate multiple heterogeneous
OS and complex networks protocols. It does also not meet the requirements of
the strongly heterogeneous automotive integration process.
1.3 Objectives & Outline
The key intention of our research is to develop a more systematic perfor-
mance verification procedure for heterogeneous distributed real-time systems,
essentially needed to increase system efficiency and quality and to reduce de-
sign cost and risk. To be applicable in practice, the technique must consider the
established (IP) re-use driven “cut&paste” design style, i. e. it must be compo-
sitional and modular.
Objectives & Outline 9
Formal approaches become attractive as simulation and test fall short. There
has been much activity in the real-time systems research community over the
last 30 years. Formal performance analysis, such as the popular rate-monotonic
analysis [73] (RMA), systematically tackles the corner case problems and is
already used in practice. Many of the existing contributions are directly appli-
cable to individual local components of the examples shown earlier in this in-
troduction, some focus on single tasks, some on scheduling, some on networks,
etc.. However on the one hand, the approaches do hardly scale as systems grow
in size and complexity, and none of them is sufficiently general for arbitrary
heterogeneous systems. On the other hand, the underlying models are often
mutually incompatible and hence lack the required modularity, which prevents
them from being used in system-level analysis. In particular the complex com-
ponent interactions and the heterogeneous resource sharing (scheduling), that
result from system integration, are major sources of analysis complexity. The
existing work will be described in detail soon. For this introduction we sum-
marize that formal performance and timing analysis of heterogeneous real-time
systems is not possible at present.
This thesis presents a new approach which we call SymTA/S (Symbolic
Timing Analysis for System) that provides modular and flexible integration
support for components and their underlying scheduling analysis models. Key
of the approach is the definition of model interfaces between several hetero-
geneous sub-system techniques [94]. Such interfaces allow the combination
of previously incompatible local models and techniques, which fosters a struc-
tured system-level analysis model [101] that can be efficiently and elegantly
solved [98]. Known techniques, with their specific limitations and restrictions,
can be applied locally to the individual components without compromising
global analysis.
The resulting modular system view supports the understanding of complex
component interactions, and allows these dependencies to be controlled and
optimized during component design and system integration. This enables a
novel, comprehensive and reliable system integration procedure. The approach
has been proven valuable in the area of network centric SoC [97] and in the
automotive domain [56, 95], where operating systems and bus protocols have
already been de-facto standardized.
The next chapter provides a broad overview of existing formal scheduling
analysis approaches. We specifically discuss the applicability to heteroge-
neous and distributed systems, and the modularity of the proposed techniques.
Through an evaluation of the known work, we refine the work objectives and
propose our basic idea. Finally, we identify the main challenges and outline
our solution.
In Chapters 3 and 4, we look at the component and task input-output mod-
els (event models) that popular work on scheduling analysis uses. We highlight
10 Introduction
key inefficiencies that prevent their direct modular application in system-level
analysis, and we provide a novel structured and self-contained set of standard
event models. These are the system-level interfaces for our compositional ap-
proach.
Model incompatibilities, which represent a major challenge with respect to
modularity and flexibility, are systematically analyzed in Chapter 5. Appropri-
ate event model interfaces are developed. In Chapter 6, we extend the inter-
faces by so called event adaptation functions, that use traffic shaping in order
to control and optimize the streams that connect the sub-systems.
Event model interfaces and traffic shaping enable a novel iterative analysis
procedure which we present in Chapter 7. A set of experiments demonstrates
the application of the approach and validates the underlying ideas. Finally,
Chapter 8 summarizes the key contributions of this thesis. Current extensions
and future work directions are briefly outlined, before we draw our conclu-
sions.
Chapter 2
SCHEDULING AND
PERFORMANCE ANALYSIS
The influence of scheduling on the timing and the performance of embed-
ded applications and HW/SW architectures and platforms has been subject to
research for several decades. When dealing with hard real-time systems, the
goal is to calculate guaranteed bounds on timing properties such as execution
times and buffering delays as well as processor and network load. A host of
formal models and methods has been published. Abstract system models are
commonly used to identify corner cases that lead to worst-case and best-case
system timing behavior. The sought-after properties are obtained by symbolic
simulation or are conservatively calculated.
This chapter summarizes key contributions out of the host of work on timing
and specifically scheduling analysis. The survey starts from classical real-time
scheduling analysis theory and then targets multiprocessor and system-level
extensions, some of them use a quite different view on system-level schedul-
ing. We evaluate the properties of the existing work with respect to the given
objectives.
A novel idea for how system-level scheduling analysis can be made more
systematic, more comprehensive, and more effective than known approaches is
formulated. The key challenges are highlighted to be solved later in this thesis.
2.1 Component Scheduling Analysis
Components in this context are individually scheduled sub-systems, usually
either a processor or a bus/network. The scope of such component-level anal-
ysis is illustrated in Figure 2.1. Since the general concepts are very similar
for task and communications scheduling, we do not particularly differentiate
between them. The concepts of core time, response time, and load are valid for
both, and scheduling analysis can account for operating system and protocol
overhead. Rather, we selected few landmark and representative component-
12 Scheduling and Performance Analysis
M2IP2M3
Communication
DSPIP1
HWSens M1CPU
RTOS
T1
T2
T3
(a) Single-CPU Scheduling Analysis
Communication
arbitr. protocol
M2IP2M3
M1
DSPIP1
HWCPUSens
T1
T2
T3
(b) Bus/Network Arbitration Analysis
Figure 2.1. Scope of Component-Level Analysis
level scheduling analysis approaches to illustrate their basic common concepts
and key differences.
2.1.1 Rate-Monotonic Scheduling
In their seminal paper on scheduling analysis, Liu and Layland [73] pro-
posed rate-monotonic scheduling (RMS) as an optimal static priority assign-
ment for independent periodic tasks with deadlines at the end of their periods.
Optimal means that no other priority assignment yields better schedulability.
RMS assigns static priorities to tasks according to their periods, the smaller the
period the higher the priority.
Liu and Layland provided a sufficient schedulability test [73] based on the
processor utilization approach. They calculate the accumulative load or uti-
lization1 U of all tasks in the system. The (maximum) load of each task is
its maximum execution time Ci divided by its activation period Ti. Liu and
Layland discovered that such a system with deadlines at the end of the periods
is schedulable, if this utilization is below a certain bound that depends on the
number of tasks n:
U =
n∑
i=1
Ci
Ti
≤ n(2 1n − 1) (2.1)
Exact utilization-based schedulability tests were first proposed by Lehoczky,
Sha and others [70, 106]. In general, a successful schedulability test guarantees
that a) the system is schedulable, and b) all tasks meet their deadlines which
are at the end of the period.
1the terms load and utilization are often used interchangeably in literature
Component Scheduling Analysis 13
T1
T1 T1 T1
T2 T2
T2
T3
T3
0
t
R1
T3
R2 R3
task activation
task termination/completion
Figure 2.2. Scheduling Diagram of Rate-Monotonic Scheduling
Joseph and Pandya [60] developed a first response time calculation for RMS.
The response time of a task provides more detailed information about the tim-
ing of a task than load or utilization models. It represents the externally observ-
able behavior of a task under the influence of scheduling. Joseph and Pandya
measured the response time from the task activation to the task completion or
termination. Figure 2.2 shows the scheduling diagram of three tasks that are
activated periodically. The first response time Ri of each task is shown.
Joseph and Pandya provided a guaranteed worst-case response time calcula-
tion. They recognized that a task experiences its largest number of preemptions
by higher-priority tasks when all tasks are activated simultaneously [60], a sit-
uation called the critical instant of a task. Figure 2.2 shows the critical instant
of all three tasks. Liu and Layland [73] proved that a task that meets its first
deadline at its critical instant, will also meet all later deadlines.
The response time of task Ti is calculated as the sum of the tasks own worst-
case execution time Ci plus its worst-case interference Ii. The interference
term Ii determines how much preemption task Ti will experience due to higher
priority tasks Tj during it own execution. hp(i) is the set of higher priority
tasks. The deadline Di is at the end of the period Ti.
Ri = Ci +
∑
j∈hp(i)
Cj
⌈
Ri
Tj
⌉
︸ ︷︷ ︸
# of preemptions︸ ︷︷ ︸
interference term Ii
≤ Di = Ti (2.2)
Knowledge of the critical instant is very important in schedulability or schedul-
ing analysis. The critical instant is, by definition, a worst-case scenario in the
sense that no other scenario will yield a larger response time, or a higher load
respectively.
14 Scheduling and Performance Analysis
2.1.2 Other Static-Priority Schedulers
Since the publication of the first response time approach for RMS [60], a
multitude of researchers have extended the applicability, enhanced the accu-
racy, and improved the efficiency of response time calculations for this and
other system set-ups. In the next few paragraphs, we select a few landmark
contributions out of this huge field where two groups, Burns and Wellings from
the University of York, England, and Lehoczky, Rajkumar (both Carnegie Mel-
lon University) and Sha from the University of Illinois at Urbana-Champaign,
can be mentioned as outstanding contributors.
2.1.2.1 Deadline-Monotonic Priority Assignment
For deadlines shorter than periods, Leung and Whitehead [71] proved that
the deadline-monotonic scheduling (DMS) approach [69, 5] is the optimal pri-
ority assignment, where the task with the shortest deadline is given the highest
priority. They enhanced the sufficient load-based schedulability test of Equa-
tion 2.1. More interesting in the context of this thesis is that the response time
approach [60] of Equation 2.2 can deal with arbitrary priority assignments, so
it also applies to DMS.
2.1.2.2 Arbitrary Deadlines
Allowing deadlines larger than periods has conceptual consequences, since
tasks can now re-arrive before the previous activation has completed. In other
words, tasks can preempt or interfere with themselves, and it is no longer suf-
ficient to check if the first deadline is met. Instead, all activations that lead to
self-interference must be checked.
Lehoczky [69] introduced the concept of a busy period or busy window as a
generalization of the concept of a critical instant, that elegantly re-uses the re-
sponse time approach of Equation 2.2. A busy window captures q consecutive
task executions as a single, clustered execution, and a combined response time
wi(q) for such task clusters can be calculated:
wi(q) = q Ci︸ ︷︷ ︸
core time of
q executions
+
∑
j∈hp(i)
Cj
⌈
wi(q)
Tj
⌉
(2.3)
With information about the activation timing, the individual response time
of each qth execution is calculated following Equation 2.4. For the details, we
refer to [69].
Ri(q) = wi(q)︸ ︷︷ ︸
resp. time of
q executions
− (q − 1) Ti︸ ︷︷ ︸
activation time of
qth execution
(2.4)
Component Scheduling Analysis 15
Finally, the overall maximum response Ri time is the maximum of these indi-
vidual response times Ri(q):
Ri = max
q
(Ri(q)) (2.5)
2.1.2.3 Extended Task Activation
The model of purely periodic tasks is too static and insufficient to capture
reactive embedded system behavior, and other activation principles have been
investigated.
Release Jitter. Tick-scheduling [4, 121], i. e. a scheduling that periodi-
cally tests task activation conditions, can induce a so called release jitter. This
is the time between the actual arrival time of an activating event, or the time a
general activation condition becomes true, and the time this is recognized for
scheduling. Tick-schedulers and other polling systems typically induce such
delays. Audsley [4] and Tindell [121] investigated the properties of release
jitter.
A jitter does not change the average period of a task, but the activating
events are allowed to deviate with respect to their original period. Hence, in
certain circumstances, events can arrive earlier than in case of purely periodic
events. This changes the critical instant and effectively increases the number
of possible worst-case preemptions. The response-time calculations must con-
sider this [4]:
Ri = Ci +
∑
j∈hp(i)
Cj
⌈
Ri + Jj
Tj
⌉
︸ ︷︷ ︸
interference term Ii
≤ Di = Ti − Ji (2.6)
Compared to Equation 2.2, the jitter Jj adds to the numerator, increases the
number of preemptions, and results in a larger response time. Additionally, the
deadline must be adjusted accordingly to avoid self-interference, otherwise the
windowing techniques (see Section 2.1.2.2) must be applied.
As we will see in Chapter 4, there are other sources of jitter, especially in
distributed systems. Scheduling, execution, and communication often delay
data for a non-constant time, thereby inducing significant jitter to the output
production of tasks, and hence to the activation of successor tasks. Detailed
properties of event arrival and task activation models (or event models) will be
given in Chapter 3.
Sporadic Tasks. Sprunt et. al. [108] differentiated sporadic tasks as a spe-
cial class of aperiodic tasks for which the utilization can be bounded. They
defined a minimum inter-arrival time d−i of task Ti as a minimum period, cor-
responding to a maximum allowed frequency [108, 105] . For the purpose of
16 Scheduling and Performance Analysis
worst-case response time analysis, sporadic tasks are usually treated as peri-
odic tasks. So, Equation 2.2 as well as Lehoczky’s windowing technique also
apply to sporadic tasks.
Sporadic Bursts. Later, Audsley [4] and Tindell [121] proposed another
type of sporadic task activation. The model of sporadically periodic events,
also called sporadic bursts, allows events to be captured that occur temporarily
periodically (as a burst) within sporadically bounded distances. Event arrival is
bounded to at most b events within an outer period of TO. An inner period T I
bounds the minimum inter-arrival time between two successive events. Auds-
ley [4] provided the necessary extensions to the response time calculations (see
Equation 2.7). Tindell [121] finally applied Lehoczky’s windowing technique.
The term Bi captures the blocking time which is explained in the next section.
Ri = Ci + Bi +
∑
j∈hp(i)
Cj
⎛
⎜⎜⎝min
⎛
⎜⎜⎝
⎡
⎢⎢⎢⎢⎢
Ri − TOj
⌊
Ri
TOj
⌋
T Ij
⎤
⎥⎥⎥⎥⎥ , bj
⎞
⎟⎟⎠+ bj
⌊
Ri
TOj
⌋⎞⎟⎟⎠
(2.7)
2.1.2.4 Shared Resources
Audsley and Burns deeply investigated the impact of shared resources on
scheduling and analysis [3]. Shared variables, drivers or any other critical
sections [113] typically lead to additional delays, not reflected by the priority
relation of tasks. A so called blocking time Bi was introduced as a correction
term that is added to the response time Ri. This blocking time captures the
maximum delay a task can experience due to critical sections of lower-priority
tasks. This was already illustrated in Equation 2.7.
Such shared resources and the use of semaphores and monitors can lead
to a situation known as priority inversion [105, 3]. Several proposals have
been made to reduce the effect of priority inversion, e. g. the priority ceiling
protocol [105, 3], the priority inheritance protocol [105, 24], and the kernelized
monitor protocol [24].
2.1.2.5 Synchronous, Asynchronous, and Incomplete Task
Sets
Most of the above techniques use the idea of a critical instant or busy win-
dow in order to determine a single worst-case scheduling scenario. For the
rate-monotonic approach as illustrated in Figure 2.2 this leads to synchronous
task activation. A periodic task set where all tasks are activated simultaneously
is referred to as a synchronous task set [73].
Component Scheduling Analysis 17
In an asynchronous task set, the tasks need not necessarily be activated si-
multaneously but with a known or bounded phase delay. Such phase delays
are usually called offsets [120, 82]. Interestingly such asynchronous task sets
are harder to analyze than synchronous task sets. Leung and Whitehead [71]
indicated large variations in the algorithmic complexity of seemingly similar
scheduling and analysis problems. Baruah et. al. [10] investigated these issues
further and found out that much of the schedulability analysis of asynchronous,
periodic task sets is NP-hard in the strong sense. However, a set of practically
useful approximations exist that perform in polynomial time. Tindell [120]
and later Palencia and Harbour et. al. [82, 83] presented a reasonable analyti-
cal model that utilizes task offsets to obtain significantly tighter bounds of the
response time. They also optimized offsets of tasks according to task prece-
dence relationships due to e. g. communication between tasks.
Finally, there is the class of asynchronous task sets with unknown offsets,
called incomplete task sets [10], where only the periods are known but offset
information is not available. Analysis must assume any choice of offsets. This,
interestingly, reduces analysis complexity, since in most situations the worst-
case scenario of an incomplete set is identical with that of the corresponding
synchronous task set, leading to the known critical task instant.
Static-priority based scheduling is one of the most popular fields in real-
time systems research. There are countless other publications, each focusing
on other aspects, but most of them have the roots presented above. For an
extensive overview we refer to three popular books [63, 17, 74]. A compact
but incomplete overview paper is available from Fidge [34].
2.1.3 Dynamic Priority Assignments
Liu and Layland also provided an analytical model for an optimal dynamic
priority assignment policy, called earliest deadline first (EDF) [73]. In EDF,
the task with the nearest deadline is selected for execution. In contrast to
RMS and DMS, the relative priorities between tasks can change dynamically at
run-time under EDF scheduling [3], considerably complicating the predictions
needed for worst-case analysis. The field of dynamic priorities also knows
some key contributors, Stankovic from the University of Virginia in Char-
lottesville, Buttazzo from Scula Superiore S. Anna in Pisa, Italy, and Jeffay
and Baruah from the University of North Carolina at Chappel Hill.
Generally, EDF scheduling analysis suffers from comparable problems to
static priority scheduling. Liu and Layland’s utilization approach for purely
periodic task activation [73] is quite simple. A periodic task set is schedulable
under EDF, if and only if the following condition is satisfied:
n∑
i=i
Ci
Ti
≤ 1 (2.8)
18 Scheduling and Performance Analysis
Ci is the core execution time of task Ti and Ti is its period. First response
time approaches were proposed by Spuri [109, 110] and are considerably more
complex. In particular the critical instant is no longer easy to determine. Spuri
introduced the notation of a deadline busy period [110] to ease the response
time calculations.
Other issues such as jitter, sporadic tasks and bursts, semaphores, etc. have
also been analyzed. For further overview readings on static and dynamic prior-
ities, we refer to Fidge [34] and Buttazzo [17]. Detailed information on EDF is
available from Jeffay’s thesis [51] and the EDF Book [111] that also discusses
several variants of EDF such as slack-based and least laxity first scheduling.
Complexity issues can be found in compact form in [9]. Other work provides
interesting comparisons between rate-monotonic and EDF [18, 136].
2.1.4 Time-Driven Scheduling
Priority-driven scheduling is proven optimal and efficient under many cir-
cumstances. However, it usually results in a dynamic system behavior at run
time, especially if incomplete task sets are considered. In contrast, time-driven
scheduling assigns more or less fixed time slots to tasks. Each task can occupy
the processor (or other resource such as a bus) for the given amount of time.
When the time-slot expires, the next task is given access to the resource. There
are two popular variants of time-driven scheduling: time-division multiple ac-
cess (TDMA) and round robin (RR).
2.1.4.1 Time-Division Multiple Access
In TDMA, time slots are assigned to tasks regardless if the tasks are active,
i. e. request the resource, or not. This results in a fully static task behavior. The
timing of one task does no longer depend on the behavior of any other task,
and the scheduling can be easily predicted. The worst-case response time of a
task Ti with period Ti, time slot si, and overall TDMA turn-time t is given by:
Ri = Ci︸︷︷︸
own core exe. time
+ (t− si)︸ ︷︷ ︸
other slot times
×
⌈
Ci
si
⌉
︸ ︷︷ ︸
max. number of slots required
(2.9)
In case of task recurrence, Lehoczky’s windowing technique [69] for analyz-
ing arbitrary deadlines can be applied with minor modifications. The schedul-
ing analysis for TDMA is far less complex than the priority driven scheduling
strategies, and there are considerably less publications on this topic. Further-
more, TDMA is less popular for task scheduling on processors but often used
for communication scheduling (bus arbitration). An extensive overview on
TDMA communication scheduling and its commercial application in the time-
triggered protocol (TTP) [125, 64] can be found in Kopetz’ book [65]. Other
Component Scheduling Analysis 19
industrial TDMA solutions can be found in the time-triggered controller area
network protocol [25] (TTCAN) and in FlexRay [36].
The static nature of TDMA, although very welcome when analysis is con-
cerned, can result in substantial inefficiencies that can become disabling as
systems grow in size. Unused time slots cannot be assigned to waiting tasks,
hence the system might often idle, even under heavy load.
2.1.4.2 Round Robin
Round robin avoids this inefficiency by releasing a time slot if not required.
This avoids unnecessary idle times and results in a compact schedule. The
Token Ring (IEEE 802.5) communication protocol [50] with its “early token
release” is an example for a round robin system.
Round robin systems perform much better than TDMA on average, but have
TDMA performance in the worst-case situation. Therefore, the worst-case load
and response time calculations can be re-used from TDMA. A comparison
between TDMA and RR performance with a large set of experiments can be
found in [20].
2.1.5 Other Scheduling Strategies
Cyclic or cyclo-static [31] scheduling is popular for signal processing appli-
cations. They have proved to be very efficient for synchronous data-flow [68]
(SDF) applications [68, 66], a popular class of signal processing applications.
However, such applications need not necessarily always be scheduled stati-
cally [75] but can be optimized using EDF scheduling [145]. Mok [78] has
exploited cyclo-static task behavior to reduce response times in dynamic sys-
tems. First-come first-served (FCFS) –also known as first-in-first-out (FIFO)–
scheduling has also been analyzed [139].
In general, countless scheduling strategies exist, including layered and hi-
erarchical scheduling and nested run-time systems, e. g. in Flexray [36] with
priority-driven scheduling “inside” TDMA; and every variation might require
the existing analytical models and methods to be re-thought and adjusted based
on core execution times, activation models, etc.. This thesis is not intended to
thoroughly explain all existing work on scheduling and its analysis, and at this
point we will stop the survey on single-processor or single bus scheduling and
analysis.
2.1.6 Industrial Application
Nearly all of the aforementioned, and many more, scheduling strategies can
be found in commercial systems. We have already highlighted the role of em-
bedded software and operating systems and the increasing importance of net-
works and protocols in the introduction. Likewise, key analytical contributions
20 Scheduling and Performance Analysis
such as rate-monotonic analysis, release jitter analysis, response time analysis
for arbitrary deadlines, time-slot optimization, etc. have been commercially
adopted –as long as they can be efficiently automated, i. e. they are not NP-
complete or NP-hard.
Tools such as TriPacific’s RapidRMA [124], Livedevices’ Real-Time Archi-
tect [33], Comet [129] from VaST, and Vector’s CANAlyzer [130] target pro-
cessor or bus scheduling analysis. They re-use core formal methods and ex-
tend them to capture specific operating system characteristics such as context
switch time and OS primitives. In our own projects [16, 56], we have analyzed
the ERCOSEK [32] automotive operating system from ETAS and could suc-
cessfully extend the rate-monotonic approach to capture the complex priority
and OS function structure. The RTEMS [79] operating system has also been
analyzed [26].
These tools target a single component –processor or bus. The TTP Soft-
ware Development Suite [126] from TTTech goes a little further and supports
the design and dimensioning of multi-controller networks based on the time-
division multiple access paradigm. This is eased by the static nature of such
time-triggered systems, where dependencies such as scheduling anomalies are
rare.
2.2 System-Level Extensions
Compared to the countless contributions on single-processor scheduling anal-
ysis, there are considerably less proposals for how these techniques can be ex-
tended to analyze larger systems where distributed tasks communicate with,
and depend on each other, as we mentioned in the introduction. The key is to
capture these dependencies in the analytical model, which can be complex and
possibly leads to virtually unsolvable equations. But it is essentially needed to
safely resolve the additional pitfalls such as the scheduling anomalies [37] of
Section 1.1.
2.2.1 Homogeneous Multi-Processors
The class of homogeneous shared-memory multiprocessors is a straight-for-
ward extension of single-processor systems. Task communication is not ex-
plicit but implicit through shared memory, a communication that can be mod-
eled as shared resource access (see Section 2.1.2.4). Figure 2.3 highlights a
shared-memory multiprocessor sub-system to illustrate the scope of these ap-
proaches.
The generalized rate-monotonic scheduling (GRMS) theory [63, 74] pro-
vides key ideas for multiprocessor extensions [106]. Similar extensions are
known for EDF [111, 51] and other schedulers. Fundamentals of multiproces-
sor synchronization can be found in [91].
System-Level Extensions 21
M2CPU3M3
M1
Communication
DSPCPU2
HWCPU1Sens
RTOS RTOS
T1
T2
T3
Figure 2.3. Scope of Homogeneous Shared-Memory Multiprocessor Analysis
More complex systems exhibit, in addition to the resource conflicts due to
shared-memory access, precedence dependencies where one task “waits” for
the data from another one. Fully cyclic executives, i. e. systems that apply pe-
riodic (cyclic) scheduling regardless of the actual communication dynamics,
behave like pipelines and ensure proper precedences. Blazewicz and Jeffey
derived local task deadlines from end-to-end constraints [11, 51] under EDF
scheduling. Mathur, Dasdan, and Gupta [76, 28] introduced a rate-based ap-
proach that calculates maximum task frequencies for cyclic tasks. However,
the necessity of fully periodic schedules is an overly constraining require-
ment [6]. It leads to static system behavior and considerably reduces system
utilization and efficiency.
2.2.2 Holistic Schedulability Analysis
Audsley et. al. [6] recognized that static cyclic scheduling is not sufficient
for the requirements of dynamic, reactive embedded real-time systems, and
they identified dynamic scheduling under precedence constraints to be a major
challenge to multiprocessor scheduling analysis.
Tindell [120] introduced the notion of time-offsets of tasks, which were
already known not to be easy to handle (see Section 2.1.2.5), to model task
delays that result from precedences. The response time of one task (the pre-
decessor) becomes the time-offset of another task (the successor), ensuring
that the precedence is fulfilled without compromising dynamic scheduling and
analysis. This way, Tindell and Clark [122] could establish, in addition to the
known response time calculations, timing equations for all dependencies in
the system. The result is an equation set that entirely captures system timing
with all its dependencies, and they called their approach holistic schedulability
analysis [122]. The approach was first applied to a system of distributed tasks,
preemptively scheduled under fixed priorities, communicating over a TDMA
22 Scheduling and Performance Analysis
bus. Later, they also investigated the automotive, priority-based CAN (con-
troller area network) bus [123].
The idea was adopted by other researchers. Gutierrez, Palencia, and Har-
bour extended Tindell’s idea by allowing dynamic offsets [82] to consider vari-
ations in task response times. They also provided an enhanced best-case re-
sponse time analysis [40, 81] to improve worst-case schedulability analysis,
a topic strongly related to the problem with scheduling anomalies [37]. Their
basic holistic analysis approach [41, 83] has been extended to support complex
task communication and synchronization mechanisms [42]. Later, they applied
similar ideas to EDF scheduling [84]. The “Modeling and Analysis Suite for
Real-Time Applications” (MAST) [45, 128] can be configured to analyze dif-
ferent system set-ups.
Because of the importance of tight dynamic offset data, an increasing num-
ber of researchers is investigating best-case scheduling and, in particular, re-
sponse time analysis for single processors [62, 47, 92, 49]. However, the num-
ber of groups focusing on holistic techniques for distributed systems is still
relatively small.
Yen and Wolf [137, 138] used virtual delay tasks to model offsets in static
priority scheduling. Eles and Pop –like Tindell and Clark– analyzed sys-
tems with priority-driven task scheduling combined with a TDMA bus pro-
tocol [87, 29] and derived heuristics for bus access optimizations. Later, they
extended their ideas to also support hybrid communication protocols with static
(time-triggered) and dynamic (event-triggered) messages [88]. This allows
configuration of the system from fully static (for instance using TTP [125])
to mixed (Flexray bus [36]) to highly dynamic (CAN [85]) systems, providing
a more structured view on the individual influences. They also accounted for
conditional task dependencies and task synchronization [30]. Pop’s thesis [86]
provides a detailed overview.
The holistic approach, as a straight-forward extension of single-processor
scheduling analysis with offsets, appears as an intuitive procedure to tackle
multiprocessor scheduling. Unfortunately, many practically relevant schedul-
ing analysis problems have recursive solutions and have been proven NP-hard
even for seemingly simple system configurations [73, 71]; and the complex-
ity of the holistic analysis is even higher [10, 9]. Often, the whole equation
set with manifold dependencies needs to be iteratively solved. To manage
complexity, all mentioned groups propose approximations and furthermore re-
strict themselves to homogeneous task scheduling, either with fixed priorities
or EDF. Communication is mostly considered static using TDMA protocols
which apparently reduces dynamic dependencies and substantially simplifies
the system timing equations. Finally, complex applications with e. g. cyclic
dependencies are mostly not discussed, this would introduce just another anal-
ysis iteration.
Flow-Based Analysis 23
Arbitr. Protocol
M2
IP2M3
M1
Communication
HW
DSP
CPU1
CPU2
RTOS
RTOSRTOS
ES ES ES ES
ESES
Sens
ES: event stream
T1
T2
T3
Figure 2.4. Scope of Homogeneous Flow-Based Scheduling Analysis
Despite these weaknesses, the holistic approach appears as an efficient and
practically useful technology for special classes of distributed systems, such as
automotive, where fixed priority tasks and periodic communications are cur-
rent practice. The Volcano tool chain [132] applies the holistic approach to au-
tomotive applications and analyses the priority-driven CAN communication at
the system level. Interestingly, Volcano –as TTTech does– requires their own,
proprietary bus access hardware and software drivers to be used with their ap-
proach. This specifically hinders the integration of legacy or other components,
which is considered a serious disadvantage in industry.
2.3 Flow-Based Analysis
Even before Tindell’s holistic approach appeared, another approach to sys-
tem-level scheduling analysis was published. Gresser [38, 39] viewed tasks
as independently scheduled and locally analyzable entities that communicate
or interact via event streams. The scope of the flow-based approach is illus-
trated in Figure 2.4. The event streams (ES) represent interfaces between the
individual components and sub-systems. This gives structure, not only to the
involved equations, but also enables a structured solution procedure, which
is considered a major advantage over the monolithic, unwieldy equations of
holistic analysis.
2.3.1 Event Vectors
Gresser introduced event vectors to model task activation for event-driven
EDF scheduling. The model is very powerful and can capture periodic events,
24 Scheduling and Performance Analysis
jitter, and burst in a uniform manner. As a key contribution, his local EDF
scheduling analysis does not only provide task response times but also the
corresponding output event streams using the same event vector notation. In
this way, the output of one task can be directly used for activation modeling
and analyzing a dependent task, because task output and task activation use the
same model. In other words, events are seen as traveling or flowing through the
network of tasks and communications and activate the corresponding actions.
This turns system-level scheduling into a flow-analysis problem that can be
iteratively solved.
Mathematically speaking, Gresser also creates a set of equations to cap-
ture system timing, just like the holistic models. However, Gresser’s approach
yields a structured timing model. Each component has its own, relatively com-
prehensible set of equations for local scheduling analysis. At the system level,
these component equations are combined into a system-level model through
the input/output specifications of the tasks, based on the event vectors. The
analysis of the system benefits from this structure. Starting at system inputs,
analysis follows the flow of events and locally analyzes one component after
another, until all components have been successfully analyzed, or a constraint
is violated.
2.3.2 Arrival Curves
Thiele et. al. [116] defined another flow model specifically targeting net-
work processor design. Where Gresser defined event vectors, Thiele et. al. use
arrival curves to capture incoming (and outgoing) requests. And instead of
suitable standard scheduling equations, they propose to use service curves for
modeling resource availability, and apply a newly developed algebra, called
real-time calculus [116], to establish relations between input and output curves
of a component. The basic ideas have roots in network calculus [27, 15, 14].
They started using continuous arrival curves with numerical representa-
tions [116], and the initially proposed [117] curve processing was restricted to
preemptive static priority scheduling [22]. They subsequently extended their
model to also account for non-preemptive packet processing, as found in real-
world network processors, and to support other scheduling strategies. But ar-
bitrary curves quickly appeared insufficient for key analytical observations,
and they resorted to approximation models to bound arbitrary curves [23].
Chakraborty’s thesis [21] provides an adequate overview.
From a system-level perspective, both Gresser and Thiele define an event
model and propagate event streams through locally analyzable components in
a global iterative analysis. The clear separation of a) local component analysis
and b) component coupling through event streams breaks down the complexity
of the overall problem and gives confidence to analysts and designers. The
Summary & New Approach 25
iterative way of analysis enabled by the event stream view is also a suitable
way to understand the complex dependencies that distributed systems exhibit.
2.4 Previous Own Work
In our own research projects, we have investigated general system models
for the verification of non-functional requirements, specifically with respect to
scheduling [93]. Our SPI (System Property Intervals) model [141, 144] was
introduced as an intermediate design representation to interface between ex-
isting models of computation and analytical task models. A particular goal
of the SPI project was to reach a reasonable level of abstraction that allows
a homogeneous view of heterogeneously specified systems, e. g state machines
coupled with data-flow graphs. We have shown how specification languages
with different models of computation such as the state-based SDL [103] and
the data-flow based Matlab/Simulink [115] can be transformed into the SPI
model [53, 59], and how timing constraints can be captured using event mod-
els [57].
Much of this work was carried out in close co-operation with Thiele’s group
at the Swiss Federal Institute of Technology, Zurich. This group had a sim-
ilar model called FunState [119, 118, 112], and basic concepts, such as the
representation of operational modes [143] and function variants [99], were de-
veloped together. For overview readings we refer to [144], while Ziegenbein’s
thesis [140] provides a detailed introduction into SPI.
Another project, SymTA/P (Symbolic Timing Analysis for Processes) tar-
gets running time analysis of single tasks [134, 135] by program path analysis
and architecture modeling with many optimizations. An extensive summary
can be found in Wolf’s thesis [133]. First ideas of breaking down the com-
plexity of SPI into smaller sub-problems, that can be combined together with
SymTA/P and the aforementioned work on scheduling analysis, were proposed
in [142]. We have investigated the role of scheduling analysis in flexibility
analysis [96, 100, 46]. Finally, the SymTA/S project brought together key
ideas of both projects SPI and SymTA/P [146]. This thesis presents the basic
approach underlying SymTA/S, while extensions are surveyed in the summary.
2.5 Summary & New Approach
This summary will conclude the review on existing techniques with an eval-
uation of their applicability in the area of heterogeneous, distributed embedded
systems, and with respect to the thesis objectives defined in the introduction.
2.5.1 Evaluation
We have seen that the single-processor models (see Section 2.1) such as
rate-monotonic scheduling are comparably easy to set-up, to understand, and
26 Scheduling and Performance Analysis
to analyze. The number of industrial applications that utilize such technolo-
gies shows its importance in real-time system design as well as its acceptance
in industry. However, these techniques have a significant disadvantage, they
are limited to a single processor or bus. There are in fact extensions that target
multiprocessors (Section 2.2.1), which re-use much of the established single-
processor scheduling models which is considered a major advantage. Most of
these extensions, however, require cyclic schedules which decouples the indi-
vidual tasks from each other and simplifies the analysis. Such systems suffer
from a reduced efficiency, and these techniques do not represent a relevant
solution for the design of competitive embedded systems.
The holistic approach (Section 2.2.2), in principle, captures highly dynamic
interactions between tasks on different processors and covers more efficient
systems that are not restricted to having periodic, cyclic schedules. In practice,
however, the approach often suffers from its complexity in general. The re-
sulting recursive system level equation set is not easily understandable which
counters the demand for simple models that designers can oversee.
There are few specialized classes of applications, such as those which use
TDMA-based communications, for which efficient holistic models exist. The
cyclic nature of TDMA decouples the task dependencies to a reasonable degree
and simplifies the equation set and its solutions. However such models lack the
flexibility to support the “cut&paste” design style. Exchanging components
is complex and usually requires the derivation of a new equation set. This
modeling complexity seems one of the main reasons why holistic models have
so far been only developed for specialized classes of architectures. This is also
reflected in the MAST tool [45, 128] which requires a specific holistic analysis
algorithm for each system class.
The flow-based approaches of Section 2.3, with their clear separation into
local scheduling analysis and the global event stream flow, break down the
complexity and provide a structured and comprehensible view of system-level
scheduling. Comprehensibility is an important requirement for designers. An-
other key advantage over the holistic approaches is the higher flexibility with
respect to system size and heterogeneity. Thiele et. al. [116] can include static
or dynamic priority scheduling with preemptive or non-preemptive behavior.
Although Gresser [38, 39] only demonstrated his approach for EDF schedul-
ing, one could theoretically include any sub-system scheduling strategy for
which an analysis exists that supports the flow models. This provides the nec-
essary modularity to support “cut&paste” system integration. We summarize
that the flow-based approaches appear most promising for handling the com-
plex system-level scheduling problems of today’s system.
The flexibility, however, has its limitations. Thiele and Gresser define a
novel and very generalized flow model for their approaches that must be ho-
mogeneously used during system analysis. Although these general models the-
Summary & New Approach 27
oretically include the standard models from real-time systems research, none
of the existing analytical contributions from Section 2.1 is directly supported
because they use more constrained models. RMS (rate-monotonic scheduling)
for instance knows of periods and deadlines but has no notion of event vectors
nor arrival curves and can, hence, not be re-used.
2.5.2 Revised Objectives & Basic Idea
After this evaluation we shall now rephrase and particularize the objectives
of this thesis. There are three key requirements:
1 We are seeking an approach that meets current industrial design practice,
i. e. the approach shall provide the flexibility and scalability of the hetero-
geneous “cut&paste” design style, different system parts need be indepen-
dently configurable.
2 We want to re-use as much work on local component scheduling analysis
as possible. This allows the integration of established techniques and tools
for sub-systems and increases system understanding and the acceptance of
the approach.
3 The system-level analysis must be comprehensible (enough) so that design-
ers can follow the underlying principles. Complex mathematics, models,
and algorithms are extremely unlikely to attract designers in industry and
must be avoided.
Basically, meeting the above requirements means combining the advantages
of the existing work in a reasonable way. We want to re-use the local tech-
niques from Section 2.1 for sub-system and component analysis. This makes
the details of the analysis understandable and allows designers to (re-)use es-
tablished local techniques and models. Then, we will combine the individual
models using the flow-based approach (Sec. 2.3). The event stream view en-
ables an analysis procedure that follows the system-level dependencies that
scheduling introduces in an understandable way. It also provides the flexibility
and scalability that todays design style requires.
2.5.3 Key Challenges
A key problem with this idea is the incompatibility of the local input and out-
put models. The existing flow-based approaches define a single event model for
component and task inputs and outputs to be homogeneously used. But the host
of known local techniques uses a big variety of input activation models. We
summarized a few in Section 2.1.2.3. In order to re-use those techniques, the
flow-based framework must support a heterogeneous mixture of event models.
These models are fundamentally different from the event vectors or arrival
curves, and are also incompatible with each other. Furthermore, output event
28 Scheduling and Performance Analysis
M1CPU1
RTOS
Sens HW
M2DSP
RTOS
IP2M3CPU2
RTOS
Arbitr. Protocol
Communication
F F F F
FF
A B X C
ED
event model
transformations
event model
transformations
T1
T2
T3
Figure 2.5. Heterogeneous Flow-Based Scheduling Analysis
models have hardly been investigated in literature so far. These are –as will
be shown in Chapter 4– usually more complex than input models and increase
the model diversity further. Figure 2.5 shows the example system split into 5
computation sub-systems and the integration bus. Each component brings a
different event model as its interface to other components (A..X). The CPU1
sub-system even has two different models at input (B) and output (X). This
illustrates the key challenge: finding a solution to the event model incompati-
bility problem in system-level scheduling analysis.
This thesis describes a way to overcome this event model incompatibility.
We will introduce Event Model Interfaces and Event Adaptation Functions to
transform one model into another, as indicated in Figure 2.5. The importance
of transformations between different event models has been widely neglected
in literature. In general, global heterogeneous system analysis using standard
techniques is currently not possible since the respective local analysis tech-
niques use incompatible event models.
The event model transformations essentially provide the missing link be-
tween the local (re-)use of known models and the flow-based global analysis
procedure that relies on common model interfaces. Developing such event
Summary & New Approach 29
model transformations, together with a system-level analysis procedure that
utilizes heterogeneous event models are the main contributions of this thesis.
2.5.4 Detailed Outline
In the next Chapter, we survey once again the existing local scheduling and
analysis approaches, but this time with special focus on the used input or task
activation models. The vast majority of techniques share few common models.
The way specific model properties are used and exploited in the analysis is
also rather similar. This helps to classify models and to provide the necessary
parameter extractions for the event model transformation step.
No less important for this step is the knowledge of the task output event
streams that is analyzed in Chapter 4. Interestingly, output event streams and
models have received far less attention than input models, most probably be-
cause their importance for system-level analysis had not been demonstrated
before. Scheduling and task execution have a remarkable influence on out-
put timing and can lead to complex event streams. We will see that not all
output streams can be covered by parameters used for input activation model-
ing. Therefore, we marginally extend the known input event models without
significantly complicating them. In contrast, a new self-contained and struc-
tured event model set is proposed that can be consistently used for input and
output modeling. As an efficient compromise between model simplicity and
completeness, we call these models standard event models.
After the basic input and output models have been defined, the next two
chapters are concerned with the actual model incompatibility. In Chapter 5, we
first of all investigate those situations where mathematical parameter transfor-
mations are sufficient to transform one model into another without changing
the actual stream timing. This is usually the case if the target model of the
transformation is more general than the source model. We call such transfor-
mations Event Model Interfaces.
Transformations from a more general into a more constrained model are an-
alyzed in Chapter 6. They are considerably more complex, since they require
key properties of the stream timing to be changed. So called Event Adaptation
Functions apply automatic traffic shaping to match the required properties. We
also explain how designers can manually control the shaping process and opti-
mize the system. Shaping is very popular and powerful in the area of network
optimization, and it can be elegantly included in the new approach.
Chapter 7 brings together all concepts and presents our novel compositional
system-level scheduling analysis procedure, based on standard event models
and standard sub-system techniques. A set of experiments is carried out, which
explain the analysis procedure step by step. We specifically discuss complex-
ity issues and propose reasonable solutions for cyclic dependencies, that often
30 Scheduling and Performance Analysis
turn the iterative flow analysis into a convergence problem. Such cyclic depen-
dencies in dynamic systems have hardly been analyzed before.
In Chapter 8, we conclude this thesis with a summary, and identify and
evaluate different possible extensions for further research.
Chapter 3
INPUT EVENT MODELS
This chapter reviews in detail the four most popular event models from the
literature on real-time systems. The discussion specifically identifies the com-
mon properties of event models and provides characteristic functions for these
properties.
3.1 Task Activation and Event Streams
Local scheduling analysis techniques typically use event models to capture
incoming load.
We have already used this statement repeatedly in the previous chapters.
It is, however, not always fully obvious that the statement is true. In many
publications, the model definitions are implicit, i. e. they are part of, or they
result from, some other definitions. Rate-monotonic scheduling, for instance,
does not explicitly define a model of periodic events, the whole theory just
assumes periodically executed tasks.
Furthermore, not all publications treat task activation as “incoming load”.
Again in RMS theory, tasks are assumed to execute periodically but it is not
specified how they are activated. In practice, periodic task execution is achieved
using a system timer that periodically emits interrupt requests. These timer
interrupts define an event stream that activates the task. Such activation is usu-
ally considered time-triggered. Periodic execution is often found in relatively
deterministic (or static) systems, but also has its application in sporadic and
asynchronous environments where periodic polling is a popular mechanism to
obtain deterministic scheduling.
In other situations, a task such as a communication driver is not activated by
a timer event but upon the reception of a protocol frame from an external bus.
More precisely, a bus-controller hardware block is first responsible for collect-
ing the bits and bytes from the bus wires. Then, it signals the reception of
32 Input Event Models
the whole frame to the driver task, again, using an appropriate interrupt. Such
task activation is usually considered event-triggered. Driver tasks and other
“sporadic servers” [108] are often found in dynamic systems which operate in
non-deterministic environments.
Other tasks may be activated upon some timeout event relative to another
event, and direct task activation is also possible. However, task activation
can always be modeled by events, regardless whether time-triggered or event-
triggered, periodic or sporadic. This way, tasks are always reactive, they react
to their activating event. Just the source of the event can vary from very deter-
ministic system timers to highly dynamic environmental requests.
This illustrates the task model used in this thesis. Tasks are activated by
event streams; and each task consumes one event per activation. Hence, the
stream of activating events is considered an input event stream, providing in-
formation about the incoming load. Similar observations will be presented for
output event streams in Chapter 4, and a distinction between activating inputs
and output generation provides a reasonable formal foundation for the event
model interfaces in Chapter 5.
There are four input event models, which are of major importance in real-
time scheduling theory:
strictly periodic events,
periodic events with jitter,
sporadic events, and
sporadically periodic events, often called “sporadic bursts”.
These four event models are sufficient to cover the vast majority of popular
local scheduling and analysis techniques, such as introduced in Section 2.1.
3.2 Common Properties of Event Streams
In order to compare different event streams, we need to capture their com-
mon properties; common in the sense that they apply to all four event models
mentioned (and others). These properties lay the foundation for all later com-
patibility tests, and they permit the derivation of event model interfaces and
adaptations.
All scheduling analysis strategies exploit two key properties of an incom-
ing event stream. First, they require the number of events that arrive within a
given interval of time to be known. With this information, the analysis algo-
rithms predict, for instance, the number of task activations, or the number of
preemptions by a higher-priority task. Second, all analysis techniques require
a minimum temporal separation (or distance) between a given number of suc-
cessive events in a stream to be known. This is used to predict future event
arrival times, required to derive deadlines or determine busy windows.
Strictly Periodic Events 33
Definition 3.1. (Event Stream)
An Event Stream S is a numerical representation of the possible timing of event
occurrences (or event arrivals). An event stream is deﬁned by four characteris-
tic functions:
η+ : R+ → N+ , (3.1)
η− : R+ → N+ , (3.2)
δ− : N+ \ {0, 1} → R+ , and (3.3)
δ+ : N+ \ {0, 1} → R+ . (3.4)
The function η+(∆t) returns the maximum number of possible event occur-
rences within a time interval of size ∆t1. Likewise, the function η−(∆t) re-
turns the minimum number of event occurrences in that interval ∆t.
The functions δ−(n) and δ+(n) return the minimum and maximum distance
between n successive events in the stream.
These four characteristic functions are further used in the actual analysis
algorithms. We start the survey with strictly periodic events.
3.3 Strictly Periodic Events
Strictly periodic event streams are characterized by one single parameter,
the period T , which must be a positive and non-zero real. The characteristic
functions are defined based on this parameter.
3.3.1 The η(∆t) Functions
Very often, the calculations of η+(∆t) and η−(∆t) are not explicit but hid-
den in the overall theory. Liu and Layland [73], for instance, provided a suf-
ficient schedulability test based on the system utilization U as the sum of the
utilization portions of all tasks:
U =
n∑
i=1
Ci
Ti
< n(2
1
n − 1) (3.5)
Ci represents the worst-case execution time of task Ti. This is divided by
the task’s period Ti to determine the task’s long-term average load in percent
of the avaliable processor performance. As part of a more complex but ex-
act schedulability test [73], they calculate the worst-case workload within an
interval of ∆t:
w(∆t) =
n∑
i=1
(⌈
∆t
Ti
⌉
Ci
)
(3.6)
1The set R+ contains all non-negative reals, including zero. Likewise, N+ contains all non-negative inte-
gers, including zero.
34 Input Event Models
Ș=2 Ș=2
Ș=1
Ș=1
ǻt
ǻt
T T T T
Figure 3.1. Time Intervals and Number of Events of Periodic Event Streams
The worst-case response time (Ri) approach of Joseph and Pandya [60] con-
tains similar terms:
Ri = Ci +
∑
j∈HP(i)
(⌈
Ri
Tj
⌉
Cj
)
< Di = Ti (3.7)
In both equations 3.6 and 3.7, the rounded term calculates the maximum
number of task activations within a given amount of time. And the subsequent
worst-case calculations further use this term. Basically, the maximum number
η+P of periodic events
2 (P) within a given amount of time ∆t is given by:
∀∆t > 0 : η+P (∆t) =
⌈
∆t
T
⌉
(3.8)
The number of events that can arrive within some time ∆t is one of the key
properties used in scheduling and schedulability analysis techniques, not only
periodic or rate-monotonic.
A more general way to approach this function is to first think of continuous
functions. Figure 3.1 shows a periodic event stream and several intervals of
size ∆t. Obviously the number of events within an interval can vary and de-
pend on the absolute position of the interval within an event stream. We can
easily determine the average number of periodic of events η˜ within a given ∆t:
η˜P(∆t) =
∆t
T
(3.9)
Upper-Bound Arrival Function. When the continuous function is
known, the discrete maximum numbers are then obtained by appropriate round-
ing. With respect to Figure 3.1, rounding corresponds to aligning one of the
interval bounds to event arrival times. Time is considered to increase to the
2We will use the index P to specify periodic event streams, and later event models
Strictly Periodic Events 35
Ș+=2Ș+=1
ǻt = T
Ș+=1
ǻt < T T < ǻt < 2T
T T T T
Figure 3.2. Maximum Number of Events of Periodic Event Streams
right. Figure 3.2 shows three left-closed right-open time intervals that are left-
aligned to events. The combination of left-side alignment and left-closeness
ensures maximum values for η. Practically speaking, the first event is just
included in the interval (at the left bound), and all others arrive as soon as
possible. No other interval would yield a higher number of events. This prop-
erty has already been exploited by Liu and Layland in their seminal paper on
scheduling analysis [73].
Basically, the upper-bound η+(∆t) function is obtained by rounding up the
average number as calculated by Equation 3.9. This function was already pro-
vided by Equation 3.8:
∀∆t > 0 : η+P (∆t) = η˜P(∆t) =
⌈
∆t
T
⌉
The restriction to ∆t > 0 has an intuitive practical reason. The term on
the right hand side of the equation is commonly found in many response time
algorithms to calculate the number of preemptions during the non-zero execu-
tion time of a periodic task. Hence, ∆t = 0 is not practically important. For
the formal issues later in this thesis, we define the function value to be zero (0)
for ∆t = 0. This is also consistent with the mentioned half-openness of the
interval. A half-open interval of width zero represents an empty set. Hence, no
event occurrence time can be included. A general reasoning about how to best
model and capture time and its influences on computer systems can be found
in [102].
The η(∆t) functions allow event arrival curves to be drawn, which are
known from other work [27] . The maximum function η+(∆t) leads to the
upper bound arrival curve, shown in Figure 3.3. Specifically the left closeness
lets the interval just “catch” the first event. The actual as-soon-as possible
event arrival scenario, which is illustrated using the arrows below the figure,
illustrates the correspondence between an arrival curve and the relative timing
of events.
Lower-Bound Arrival Function. While an upper bound is sufficient
for single processor system analysis, distributed systems exhibit scheduling
36 Input Event Models
T 2T 3T 4T0
Ș+(ǻt)
ǻt
1
2
3
4
5
T
t
t
' ' )(~K
T T T T
Figure 3.3. Upper Bound Arrival Curve of Strictly Periodic Events
anomalies [37] which can turn subsystem best-case into system worst-case be-
havior, and vice versa. Therefore, also the best-case, i. e. the situation with
minimum load, needs to be known. In order to calculate such best-case situa-
tions, the minimum number of events within a given interval of time needs to
be known.
The calculations are similar to those that yield the maximum number. But
instead of left-closed intervals, we need to consider right-closed intervals, since
the event to which the interval is aligned must just be excluded (just “missed”)
from the interval. So the first event that is actually included in the right-closed
intervals arrives after one full period T . All later events arrive strictly periodi-
cally.
These observations lead to the lower bound arrival curve shown in Fig-
ure 3.4. Specifically the right-closed half-openness lets the interval miss the
first event. The curve straight-forwardly yields the actual function for the mini-
mum number of events during time interval ∆t, given by Equation 3.10. Again,
we round the η˜ function, but this time we round down since we are looking for
minima.
∀∆t > 0 : η−P (∆t) = η˜P(∆t) =
⌊
∆t
T
⌋
(3.10)
Figure 3.5 shows both the upper- and the lower-bound arrival curves. The
actual values of η(∆t) can vary between these two curves and is illustrated by
the gray area. Mathematically, this is captured by the following equation:
η−P (∆t) ≤ ηP(∆t) ≤ η+P (∆t) (3.11)
Strictly Periodic Events 37
T 2T 3T 4T0
Ș–(ǻt)
1
2
3
4
5
ǻt
T T T T
T
t
t
' ' )(~K
Figure 3.4. Lower Bound Arrival Curve of Strictly Periodic Events
T 2T 3T 4T0
ǻt
1
2
3
4
5
T
t'
Ș(ǻt)
Figure 3.5. Both Arrival Curves of Strictly Periodic Events
The uncertainty, i. e. the difference between both bounds, can be captured
by the uncertainty interval ηI(∆t):
ηP(∆t) ∈ ηIP(∆t) =
[
η−P (∆t); η
+
P (∆t)
] (3.12)
3.3.2 The δ(n) Functions
As already mentioned in Section 3.2, there is a second function of central
importance. The δ(n) functions returns the distance ∆t between n (at least
two) successive events in the stream. There is a minimum and a maximum
value of that function, distinguished by δ−(n) and δ+(p). Roughly speaking,
38 Input Event Models
the δ(n) functions are the inverse of the η(∆t) functions. The key difference
is that the η(∆t) functions start at ∆t = 0, while δ(n) is not defined –and
obviously makes no sense– for n < 2.
It is intuitive that the distance between two events in a periodic stream al-
ways (minimum and maximum) equals the period T , the distance between
three events is twice the period, and so on, resulting in Equation 3.13.
∀ n ∈ N \ {0, 1} : δ−P (n) = δ+P (n) = (n− 1)T (3.13)
Many analysis techniques require a minimum temporal separation (or dis-
tance) of two events (δ−(2)) in order to check for task recurrence. In Equa-
tion 3.7, this information is used to formulate a deadline for task Ti. In pe-
riodic events, the distance between any two events simply equals the period
T , and the tasks deadline is set to this distance. Analysis techniques for other
event streams apply other deadlines to guarantee non-recurring tasks. These
deadlines can be derived from the event stream’s characteristic functions. In
Section 2.1.2.2, we mentioned the windowing technique of Lehoczky [69] and
Tindell [121]. They calculated the size of the busy window wi(q) for a given
number q of invocations of task Ti using Equation 2.3. In order to determine
the actual response time of the task, the invocation time of the qth invocation
relative to the start of the first invocation is subtracted from w(q). This invo-
cation time equals the distance between q successive events (see Equations 2.4
and 2.5):
Ri = max
q=1,2,...
(
wi(q)− (q − 1)Ti︸ ︷︷ ︸
δ−i (q)
) (3.14)
Equation 3.14 is of major importance for several response time techniques
for tasks with arbitrary deadlines, and it applies to other event streams, as well.
A detailed explanation of the windowing technique and busy periods can be
found in [69, 121, 122].
3.4 Event Streams vs. Event Models
We have seen that strictly periodic streams share key common properties.
They are characterized by a single parameter, the period T , and all scheduling
analysis techniques that are based on strictly periodic event streams exploit the
given characteristic functions. These commonalities are captured by an event
model.
Definition 3.2. (Event Model)
An Event Model EM is a set of event streams that share common qualitative
properties. An Event Model deﬁnes:
a) a parameter tuple πEM that captures the common properties of the streams.
One parameter tuple is associated with each stream in the set. We deﬁne
ΠEM as the set of all possible parameter tuples πEM.
Periodic Events with Jitter 39
b) the four characteristic functions, η+EM(∆t), η
−
EM(∆t), δ
−
EM(∆t), and δ
+
EM(∆t),
based on the parameter tuple πEM. These functions apply to all streams in
the set.
c) a function
SEM : ΠEM → EM (3.15)
that returns an event stream with the speciﬁc parameters πEM provided as
the arguments to that function.
An event stream SEM is an element of an Event Model EM, if and only
if it has a valid parameter tuple π ∈ ΠEM and the characteristic functions
associated, that the event model deﬁnes.
This allows the model of strictly periodic events to be formally defined:
EMP = { SP(πP) | πP ∈ ΠP = {(T )|T ∈ R+ \ {0}},
η+P (∆t) =
⌈
∆t
T
⌉
,
η−P (∆t) =
⌊
∆t
T
⌋
,
δ−P (n) = (n− 1)T,
δ+P (n) = (n− 1)T}
(3.16)
3.5 Periodic Events with Jitter
The assumption of strictly periodic tasks is overly restrictive. Many periodic
systems exhibit a so called jitter that captures the distortion a periodic stream
might experience. Figure 3.6 shows a periodic event stream with jitter. The
period is given by T ∈ R+ \ {0}, the jitter by J ∈ R+. Jitter adds uncertainty
to the model of strictly periodic events. The events arrive periodically on aver-
age, but each individual event is allowed to deviate (indicated by the left-right
arrows) with respect to a virtual reference period (gray). The jitter parame-
ter actually bounds the maximum deviation. Many approaches to scheduling
analysis with jitter assume a jitter that is less than the task period (J < T ).
3.5.1 The η(∆t) Functions
Figure 3.6 contains four half-open intervals of equal width. In Figure 3.1,
we have seen that the maximum and minimum observable number of events for
strictly periodic events differs by at most one (1). In Figure 3.6, the numbers
differ by three (3), although all intervals are left-aligned to an event.
40 Input Event Models
Ș=3
T T T T
J J J J
J
Ș=0
Ș=2
Ș=1
Figure 3.6. Time Intervals and Number of Events of Periodic Events with Jitter
T–J 2T–J 3T–J 4T–J0
Ș+(ǻt)
ǻt
1
2
3
4
5
T T T T
J J J J J
–J
la
te
e
a
rl
y
e
a
rl
y
e
a
rl
y
e
a
rl
y
T
Jt
t
' ' )(~K
Figure 3.7. Upper Bound Arrival Curve of Periodic Events with Jitter
Upper-Bound Arrival Function. To which event shall the intervals be
aligned? Again, the existing work on scheduling theory provides the answer.
Jitter models were first considered by Locke [75]. He constructed a worst
case event arrival scenario as follows. In a stream of events, he assumed one
event to arrive as late as possible within the maximum allowed time deviation,
and all subsequently arriving events as early as possible after that first event.
This scenario as well as the resulting upper bound arrival curve are drawn in
Figure 3.7.
In the worst-case situation, all events in the jittered stream (except the first
one) re-arrive J earlier than in a strictly periodic stream. More precisely, only
the first event arrives later but also the time offset of ∆t is shifted by the same
Periodic Events with Jitter 41
amount, namely the jitter J . Compared to the upper bound arrival curve of the
strictly periodic events (Fig. 3.3), the curve of the jitter stream has been shifted
to the left by J , and has the following continuous η˜+(∆t) function:
∀∆t > 0 : η˜+P+J(∆t) =
∆t + J
T
(3.17)
The actual η+ function is given by Equation 3.18.
∀∆t > 0 : η+P+J(∆t) =
⌈
η˜+(∆t)
⌉
=
⌈
∆t + J
T
⌉
(3.18)
To demonstrate the use of such models, we briefly introduce Audsley’s jitter
analysis [4] that extends the approach of Joseph and Pandya [60] and captures
the influence of jitter on the response time. In his model, the maximum number
of events for a given time interval is used to determine the so called worst-case
interference Ii. Audsley calculated the response time as follows:
Ri ≤ Di = Ti (3.19)
Ri = Ji + ri (3.20)
ri = Ci + Ii (3.21)
Ii =
∑
j∈HP(i)
(⌈
ri + Ji
Ti
⌉
︸ ︷︷ ︸
η+P+J(ri)
Cj
)
(3.22)
Lower-Bound Arrival Function. A situation with the minimum num-
ber is shown in Figure 3.8. The interval is right-closed half-open and aligned
to an “early” event. Due to the left-openness of the interval, this event is just
missed. All other events arrive “late”, i. e. they experience the maximum de-
viation. This time, the curve has been shifted to the right and the continuous
η˜−(∆t) function is:
∀∆t > 0 : η˜−P+J(∆t) =
∆t− J
T
(3.23)
Since this function can be negative for ∆t less than the jitter J , the rounded
value must be bounded to at least zero:
∀∆t > 0 : η−P+J(∆t) = max
(
0,
⌊
∆t− J
T
⌋)
(3.24)
Figure 3.9 shows both the upper- and the lower-bound arrival curve. Com-
pared to periodic event streams (see Figure 3.5), the uncertainty has increased.
42 Input Event Models
T+J 2T+J 3T+J 4T+J0
Ș–(ǻt)
ǻt
1
2
3
4
J
J
e
a
rl
y
J
la
te
J
la
te
J
la
te
la
te
J
T T T T
T
Jt
t
' ' )(~K
Figure 3.8. Lower Bound Arrival Curve of Periodic Events with Jitter
5
0
ǻt
1
2
3
4
T
Jt '
T
Jt '
–J +J
Ș(ǻt)
Figure 3.9. Both Arrival Curves of Periodic Events with Jitter
3.5.2 The δ(n) Functions
In contrast to strictly periodic events where the distance between any two
events was constant, events with jitter can be “early” or “late”. Subsequently,
the distance between events can differ.
Minimum Distance. The minimum distance δ−(2) between 2 events in
a periodic stream with jitter intuitively is the period minus the jitter. The dif-
ference between 3 events is one period larger, and so on. This information was
Periodic Events with Jitter 43
already used to construct the scenario with the maximum number of events,
shown in Figure 3.7.
∀ n ∈ N \ {0, 1} : δ−P+J(n) = (n− 1)T − J (3.25)
Audsley exploited this property to formulate appropriate deadlines for tasks
when recurrence is prohibited. The analysis in Equations 3.19 and 3.20 illus-
trate the influence of the δ− function on task deadlines:
ri ≤ Ti − Ji = δ−P+J(2) (3.26)
The windowing techniques (see Equation 3.14) can also work with periodic
events with jitter.
Maximum Distance. The maximum distance between two events is the
period plus the jitter. The difference between three events is one period larger,
and so on, leading to Equation 3.27:
∀ n ∈ N \ {0, 1} : δ+P+J(n) = (n− 1)T + J (3.27)
3.5.3 Event Model Deﬁnition
From the properties of periodic event streams with jitter, we can derive the
formal definition of the model of periodic events with jitter:
EMP+J = { SP+J(πP+J) | πP+J ∈ ΠP+J =
{(T, J) | T ∈ R+ \ {0}, J ∈ R+, J < T} ,
η+P+J(∆t) =
{ ⌈
∆t+J
T
⌉
∆t > 0
= 0 ∆t = 0
,
η−P+J(∆t) = max
(
0,
⌊
∆t− J
T
⌋)
,
δ−P+J(n) = (n− 1)T − J,
δ+P+J(n) = (n− 1)T + J}
(3.28)
The model of periodic events with jitter is very powerful. In addition to
static, strictly periodic events, the concept of jitter allows the modeling of dy-
namic event streams with uncertain, only partially known behavior within a
generally periodic stream. Basically, the regular nature of periodic events still
lays the foundation of all predictability issues, whether with jitter or not.
Besides periodic events, there is the class of aperiodic events [108] which
arrive irregularly. In general, such aperiodic events cannot be subject to any
real-time analysis since key characteristics like the maximum number of event
44 Input Event Models
0
Ș+(ǻt)
ǻt
1
2
3
4
5
d – 2d – 3d – 4d –
d – d – d – d –

 ' '
d
t
t)(~K
Figure 3.10. Upper Bound Arrival Curve of Sporadic Events
arrivals η(∆t) can not be safely bounded. However, there is one sub-class of
aperiodic events, called sporadic events, with special properties that allow a
minimum of predictability and analyzability.
3.6 Sporadic Events
In contrast to periodic events, sporadic events arrive irregularly. There is
no average period, repetition time, or frequency. However, sporadic events
still allow the maximum event arrival to be bounded, since they have a known
minimum separation in time between any successive events, called the inter-
arrival time d− [108, 3].
3.6.1 The η(∆t) Functions
Upper-Bound Arrival Function. The maximum number of events can
be easily calculated from the inter-arrival time. Intuitively, the number is equal
to the maximum number of events of a periodic stream with a period equal to
the inter-arrival time. In other words, the worst-case behavior (maximum num-
ber of events) of a sporadic stream is a strictly periodic stream [108]. So, the
same considerations, equations, and curves can be re-used from Section 3.3.
The curve is shown in Figure 3.10, and the η+ function is given by Equa-
tion 3.29.
Sporadic Events 45
d –0
Ș(ǻt)
ǻt
1
2
3
4
5

'
d
t
2d – 3d – 4d –
Figure 3.11. Both Arrival Curves of Sporadic Events
∀∆t > 0 : η˜+S (∆t) =
∆t
d−
∀∆t > 0 : η+S (∆t) =
⌈
η˜+S (∆t)
⌉
=
⌈
∆t
d−
⌉
(3.29)
Lower-Bound Arrival Function. Sporadic events only have a mini-
mum distance defined, required to bound the maximum number of events. The
minimum number is not bounded and must be assumed to be zero (0). That
means, in the best case, there is not a single event occurrence:
∀∆t > 0 : η−S (∆t) = 0 (3.30)
The corresponding curve is trivially zero. Both curves are combined into
Figure 3.11. The figure illustrates the effect of sporadic event sources. The un-
certainty linearly increases with increasing ∆t, while it is constant for periodic
models.
3.6.2 The δ(n) Functions
Minimum Distance. We have already mentioned that a sporadic stream
shows strictly periodic properties in the worst case with maximum event ar-
rival, given that TP = d−S . The η
+(∆t) functions of both streams equal for all
∆t. Quite similarly, also the δ−(n) function are identical. The actual function
is given by Equation 3.31. This is used by the work in [121] to find termination
conditions for the windowing technique.
∀ n ∈ N \ {0, 1} : δ−S (n) = (n− 1)d− (3.31)
46 Input Event Models
Maximum Distance. Due to the sporadic nature, the maximum distance
is infinity. In other words, sporadic events need not arrive at all:
∀ n ∈ N \ {0, 1} : δ+S (n) =∞ (3.32)
3.6.3 Event Model Deﬁnition
The model of sporadic events is given by:
EMS = { SS(πS) | πS ∈ ΠS = {(d−) | d− ∈ R+ \ {0} ,
η+S (∆t) =
⌈
∆t
d−
⌉
,
η−S (∆t) = 0 ,
δ−S (n) = (n− 1)d−,
δ+S (n) =∞}
(3.33)
3.7 Sporadically Periodic Events
Sporadically periodic events [4] represent a specialized class of sporadic
events. Other work [121] uses the same model but refers to such streams as
sporadically bursty (B), where each appearance of several events is considered
a burst.
A stream is characterized by three parameters. An outer period TO, defining
the minimum temporal separation of the successive bursts, a burst length b
determining the maximum number of events within one burst, and the inner
period T I defining a minimum distance between two events within a burst.
3.7.1 The η(∆t) Functions
Upper-Bound Arrival Function. Again, some simple considerations
help to construct a scenario with maximum number of events. The measure-
ment interval is aligned to the first event within a burst. Subsequent events in
that burst arrive as soon as possible –similar to the “early” events in periodic
streams with jitter–, i. e. with their inner period. Each subsequent burst has the
same properties. And the bursts re-arrive as soon/often as possible, i. e. with
their outer period. A scenario with a burst length of b = 4 and the correspond-
ing upper-bound arrival curve is shown in Figure 3.12. The curve illustrates
bursts and idle periods. It shows the (worst-case) periodic nature “within” a
burst as well as the sporadic nature of the appearance of the “bursts” itself.
The η+(∆t) function is given by Equation 3.34. The equation separates: a)
a number of  ∆t
TO
 full bursts of b events each, and b) the remaining sporadic
events in the remaining time interval ∆t −  ∆t
TO
TO, eventually bounded by
Sporadically Periodic Events 47
0
ǻt
3
4
5
7
1
2
3TI2TITI
6
Ș+(ǻt)
8
TO+TI TO+3 TI
TO TO+2 TI
b b
Iinner T
t
t
' ' )(~K
Oouter T
t
bt
' ' )(~K
Figure 3.12. Upper Bound Arrival Curve of Sporadically Periodic Events
the maximum burst length b.
∀∆t > 0 : η+B (∆t) =
⌊
∆t
TO
⌋
b︸ ︷︷ ︸
full bursts
+min
(⌈
∆t− ⌊ ∆t
TO
⌋
TO
T I
⌉
, b
)
︸ ︷︷ ︸
remaining events
(3.34)
This function can be found in the response time approaches of Tindell [121]
and Audsley [4].
In contrast to the three other models, no equally simple continuous η˜+ func-
tion exists. We can, however, provide two continuous ones, each one focusing
on a different issue of sporadically periodic events. When we apply the inner
period to η˜+P of equation 3.9, we obtain η˜
+
inner bounding the maximum fre-
quency during bursts in Figure 3.12. Similarly, we can find η˜+outer when using
the outer period and the burst length, providing a long-term average number of
events. Both these curves are shown in Figure 3.12.
Lower-Bound Arrival Function. Sporadically periodic events –as a
generalized class of sporadic events– do not need to appear at all. Hence, the
η− function is assumed zero:
∀∆t > 0 : η−B (∆t) = 0 (3.35)
48 Input Event Models
0
ǻt
3
4
5
7
1
2
6
Ș(ǻt)
8
IT
t'
OT
t
b
'
3TI2TITI TO
Figure 3.13. Both Arrival Curves of Sporadically Periodic Events
Both event arrival curves are combined in Figure 3.13.
3.7.2 The δ(n) Functions
Minimum Distance. Similar to Equation 3.34, the actual calculation of
the minimum distance δ−(n) distinguishes full bursts and a remainder:
∀ n ∈ N \ {0, 1} : δ−B (n) =
⌊
n− 1
b
⌋
TO︸ ︷︷ ︸
full bursts
+((n− 1)−
⌊
n− 1
b
⌋
b)T I︸ ︷︷ ︸
remaining events
(3.36)
Maximum Distance. The maximum event distance of any sporadic event
stream is infinity:
∀ n ∈ N \ {0, 1} : δ+B (n) =∞ (3.37)
Summary 49
3.7.3 Event Model Deﬁnition
The model of sporadically periodic events is given by:
EMB = { SB(πB) |
πB ∈ ΠB = {(TO, T I , b) | TO ∈ R+ \ {0}, T I ∈ R+,
b ∈ N+ \ {0}, TO ≥ T I × b} ,
η+B (∆t) =
⌊
∆t
TO
⌋
b +min
(⌈
∆t− ⌊ ∆t
TO
⌋
TO
T I
⌉
, b
)
,
η−B (∆t) = 0 ,
δ−B (n) =
⌊
n− 1
b
⌋
TO + ((n− 1)−
⌊
n− 1
b
⌋
b) T I ,
δ+B (n) =∞}
(3.38)
3.8 Summary
The use of abstract event stream is essential for many scheduling analysis
techniques such as RMS (rate-monotonic scheduling). We have defined event
streams and event models, and we have reviewed the four most popular event
models in literature: strictly periodic (P), periodic with jitter (P+J), sporadic
(S), and sporadically periodic or sporadic bursts (B). These models require
only a few key parameters in order to describe the behavior of a stream.
Using examples such as in Equations 3.7 and 3.22, we have shown how
these parameters are used in scheduling analysis. Four characteristic func-
tions apply to all event streams. For instance, the maximum number of events
η+(∆t) is required to determine the number of preemptions of a task. The
minimum distance between events δ−(n) is used to restrict task deadlines (see
Equation3.26) or to correctly capture for task recurrence as in Equation 3.14.
These two functions capture the key event stream properties in the area of
classical scheduling analysis that targets maximum (worst-case) task and com-
munication response times. Approaches that target distributed systems addi-
tionally require the minimum number of events and the maximum distance, to
determine minimum response times, in turn required to resolve system-level
scheduling anomalies. We have explained these effects in Section 2.2.2. We
conclude this chapter with an overview of the characteristic functions of the
four event models in Table 3.1.
50 Input Event Models
π
η
+
(∆
t)
η
−
(∆
t)
δ−
(n
)
δ+
(n
)
P
T
⌈ ∆t T
⌉
⌊ ∆t T
⌋
(n
−
1)
T
(n
−
1)
T
P+
J
T
,J
⌈ ∆t
+
J
T
⌉
m
ax
( 0,
⌊ ∆t
−
J
T
⌋)
(n
−
1)
T
−
J
(n
−
1)
T
+
J
S
d
−
⌈ ∆t d−
⌉
0
(n
−
1)
d
−
∞
B
T
O
,T
I
,d
⌊ ∆t TO
⌋ b+
0
⌊ n−
1
b
⌋ TO
+
∞
m
in
(⌈ ∆
t
−
⌊ ∆t TO
⌋ TO
T
I
⌉ ,b)
( (n
−
1)
−
⌊ n−
1
b
⌋ b)T
I
Table 3.1. Parameters and Characteristic Functions of the Four Most Popular Event Models
Chapter 4
OUTPUT EVENT MODELS
We have seen how event models are used to capture task activation. Strictly
periodic events, for instance, might be generated by a timer interrupt. The other
models, however, aim at capturing the partially non-deterministic behavior of
event sources, i. e. other tasks that produce the events that activate tasks. This
already shows that event timing needs not only be considered at task input but
also at task’s outputs.
This chapter investigates task input-output timing behavior and specifically
analyzes the output event generation. This is absolutely necessary for the com-
ponent integration step mentioned in Section 2.5. One task’s output becomes
another task’s input. We also need appropriate output event models, otherwise
two models cannot be reasonably coupled [101, 98]. The key goal in this con-
text is a consistent and systematic use of event models.
We use expressive examples to introduce the basic concepts of output mod-
eling. We start with simple, constrained task configurations such as periodic
tasks with deterministic timing behavior. We then gradually add more con-
cepts, especially all possible sources of non-determinism like jitters, sporadic
event sources, and conditional task execution.
4.1 Periodic Task Activation
We have mentioned in Section 3.1 that task activation can always be mod-
eled as event triggered, if we can properly describe the event sources that pro-
duce these events. However so far, only relatively simple event sources have
been considered, such as a system timer with a fixed frequency. Such event
generation is a form of output production, the timer outputs events, and can
be described using the periodic event model. In the local analysis techniques
mentioned in Section 2.1, such event models are directly used as input event
models, i. e. activating events, for a task.
52 Output Event Models
input
output
R constant response time
T1
(a) Constant Response Time
T T T T
T
input:
periodic
output:
periodic
R
T
RR
T
R
T
R
input-output delay
(b) Periodic Input and Periodic Output
Figure 4.1. Periodic Task with Constant Response Time
4.1.1 Constant Response Times
Periodic output production generally applies to all tasks that are activated
periodically and have a constant input-output delay, i. e. a constant response
time. In this thesis we assume that a task produces its output on completion.
So the output generation times of the ith output are equal to the task completion
times of the ith task execution:
tout(i) = tin(i) + R(i) (4.1)
A periodic task T1 with a constant response time together with its periodic
input and output streams is shown in Figure 4.1(a). It is quite clear that, except
in the case of a constant phase delay which is not considered by event models,
both input and output streams have equivalent properties, they are identical:
S1,out = S1,in = SP(Tin) (4.2)
4.1.2 Response Time Intervals and Output Jitter
Such a simple and static input-output behavior is, however, not commonly
the case. Sophisticated architectures include pipelines and caches might stall
the task, i. e. enforce wait cycles, in a seemingly non-deterministic manner.
Secondly, the task might have a data-dependent control flow using if-then-
else statements or data-dependent loop counts. Scheduling introduces de-
lays that far exceed other architecture influences. Depending on the behav-
ior of other tasks on the same resource, the number of preemptions can be
Periodic Task Activation 53
input
output
R–
R+
response time interval with
response time jitter
JR
T1
(a) Non-Constant Response Time
R–RR+ R+
T T T T
R– R+ R–RR+
e
a
rl
y
la
te
la
te
T
input:
periodic
output:
periodic with jitter JRJR
(b) Periodic Output with Jitter
Figure 4.2. Inheritance of Response Time Jitter at Task Output
smaller or larger. We have already seen such tasks in the introduction (see
Figure 1.3). The result is a non-constant task response time, represented by an
interval constrained by upper and lower response time bounds, as indicated in
Figure 4.2(a):
R1(i) ∈ R1 = [R−1 ;R+1 ] (4.3)
Even if activated strictly periodically, the output of such a task inherits the
response time jitter J1,R. Figure 4.2(b) shows an execution scenario with vary-
ing response times. The minimum or shortest response time results in an early
output while the maximum response leads to a late output. So, the output jitter
equals the response time jitter which is the difference between the two response
time interval bounds:
J1,out = J1,R = R+1 −R−1 (4.4)
The output stream of task T1 is:
S1,out = SP+J(T1,in, R+1 −R−1 ) (4.5)
4.1.3 Inheritance of Input Jitter
Such periodic streams with jitter can activate other tasks. Figure 4.1.3 shows
a chain of tasks. Task T1 is taken from the previous example and is known to
have a strictly periodic activation and an output jitter. This output jitter turns
into the input jitter of task T2.
54 Output Event Models
T1
periodic periodic w/ jitter
T2 T3 T4
? ? ?
R3
–
R3
+
R2
–
R2
+
R1
–
R1
+
R4
–
R4
+
Figure 4.3. Non-Constant Response Times in a Task Chain
R3
–
R2
–
R1
–
R4
–
R3
+
R2
+
R1
+
R4
+
J2,in = J1,out
early
late
J3,in = J2,out
J4,in = J3,out
J4,out
Figure 4.4. Early and Late Scheduling Diagrams
Tindell and Clark [122] studied such systems and they recognized that a
possible input jitter is also inherited at the task’s output, just as the (internal)
response time jitter is inherited. In other words, the response time jitters accu-
mulate along a task chain, where each task adds its response time jitter from
input to output:
Ji,out = Ji,in + Ji,R
= Ji,in + (R+i −R−i ) (4.6)
Hence, the output stream is given by:
Si,out = SP+J(Ti,in, Ji,in + Ji,R) (4.7)
The early and late execution sequence diagrams and the jitter accumulation
are shown in Figure 4.3.
The jitter plays an important role in system-level scheduling. It captures
the scheduling influences of one task at the input of another. This is also the
basic underlying idea of the holistic analysis techniques published by Tindell
and Clark [122] and Gutierrez, Palencia, and Harbour[41]. They establish re-
sponse time equations for each task in the system. For dependent tasks, these
equations are mutually dependent, resulting in a complex equation set to be
solved.
Periodic Task Activation 55
Best-case response times R− were initially simply considered zero, result-
ing in unnecessarily large jitters. Since then, many improvements of best-case
analysis have been proposed. Tindell [120] captured static phase information,
the phase delay between the activation of two successive tasks. He called this
phase offset [120] within a transaction. Palencia and Harbour [82] extended
this approach to dynamic offsets. Other groups have been studying best-case
analysis, too [62, 47, 92, 49]. Interestingly, most of the work is done no ear-
lier than 30 years after Graham forecasted an increase in the importance of
best-case analysis when resolving scheduling anomalies [37].
4.1.4 Event Streams with Large Jitters
Improving best-case analysis helps to increase the accuracy of the jitter cal-
culation. The improvements, however, do not reduce the actual jitter, which
monotonically increases along task chains and can even exceed the original
period. We mentioned in Section 3.5 that many of the known scheduling and
analysis techniques require jitters less than periods to be applicable. A jitter
equal to the period would result in the simultaneous arrival of two task activa-
tions, in turn leading to task recurrence. Not all analysis approaches consider
recurrence but require that one execution is finished before the next activation
arrives.
There are few extensions. Lehoczky [69] and Tindell [121] introduced the
notion of arbitrary deadlines and presented response time analysis techniques
that are not restricted to any deadlines. Their techniques allow for large jitters,
and we extend the jitter model from Section 3.5 by allowing arbitrary jitters:
πP+J ∈ ΠP+J = {(T, J)|T ∈ R+ \ {0}, J ∈ R+} (4.8)
The consequences on the characteristic functions are explained in the following
sections.
4.1.4.1 The η(∆t) Functions
Upper-Bound Arrival Function. To construct the upper bound arrival
scenario, we apply the well known technique from Section 3.5. We assume
the first event arriving as late as possible and all others arriving as early as
possible. This has already been used in constructing worst-case event arrival
in the previous chapter. Figure 4.5 shows an upper bound arrival for an event
stream where the jitter is larger than the period. The curve has almost the
same properties as the curves of streams with jitters less than periods. So, the
η+(∆t) function can be reused from Equation 3.18 in Section 3.5:
∀∆t > 0 : η+P+J(∆t) =
⌈
∆t + J
T
⌉
(4.9)
56 Output Event Models
0
Ș+(ǻt)
ǻt
3
4
5
6
1
2
3T–J 4T–J 5T–J
T T T T
J
T
e
a
rl
y
la
te e
a
rl
y
e
a
rl
y
–J
wait
T
Jt
t
' ' )(~K
Figure 4.5. Upper-Bound Arrival Curve of Periodic Events with “Large” Jitter
There are, however, some important differences between jitter less than pe-
riods, and jitter equal to or larger than periods. In Figure 4.5, we see that
the first three events now arrive seemingly simultaneously, i. e. within an in-
terval of ∆t = 0 time units. But for reasons explained in Section 3.3.1, the
η(∆t) function is defined to be zero at ∆t = 0. To calculate the number
of events that arrive simultaneously (n0), we need to determine the limes for
∆t → 0,∆t > 0:
n0 = lim
∆t→0,∆t>0
η+(∆t) =
⌊
J
T
⌋
+ 1
Another important observation in Figure 4.5 is that the second and third
event also experience a delay, although they should be assumed early. This
is because events in a stream must usually maintain the order in which they
arrive, i. e. events are not allowed to “overtake” each other and thus have to
“wait”. This preserves the causality of input and output streams of a task,
and it is also the best strategy to reduce the maximum “waiting time” of each
individual event. Hence, the second and third event cannot be early in the sense
of immediately. This is an important property of large jitters. In other words,
there is an implicit minimum inter-arrival time of zero that preserves the order
of events.
Implications of Large Jitters 57
0
Ș+(ǻt)
ǻt
3
1
2
e
a
rl
y
la
te
la
te
J
T T T T
J
T+J 2T+J+J
T
Jt
t
' ' )(~K
Figure 4.6. Lower- Bound Arrival Curve of Periodic Events with “Large” Jitter
Lower-Bound Arrival Function. The lower bound arrival curve is
shown in Figure 4.6. Clearly, the function known from small jitters (Sec. 3.5)
applies which was already given by Equation 3.24:
∀∆t > 0 : η−P+J(∆t) = max
(
0,
⌈
∆t− J
T
⌉)
(4.10)
4.1.4.2 The δ(n) Functions
The fact that several events can arrive simultaneously also affects the δ−(n)
function. Other than in Equation 3.25, the minimum distance between two
events can be zero. In the above example it is even zero for n = 3. The actual
δ−(n) function is given by Equation 4.11:
∀ n ∈ N,n ≥ 2 : δ−P+J(n) = max (0, (n− 1)T − J) (4.11)
The maximum distance between events is not affected in concept. The equa-
tions from the jitter model as introduced in Section 3.5 are still valid:
∀ n ∈ N,n ≥ 2 : δ+P+J(n) = (n− 1)T + J (4.12)
4.2 Implications of Large Jitters
A key property of streams with large jitters (we will use the formulation
large jitter for jitter larger than the period) is the possibly simultaneous arrival
of events. However, tasks are not usually activated simultaneously but with
a certain delay. The execution sequence of Figure 4.7 provides an example.
58 Output Event Models
T3
T1
T2
p
rio
rity
T1
T2
T3
T3 response times
maximum
minimum
T3
T2
1
buffering
Figure 4.7. An Example of Output Events with “Large” Jitter
Point-To-Point Link
T2
T1
T3
CPU1
RTOS1
T5
T4
CPU2
RTOS2
periodic with large jitter
Figure 4.8. Distributed System Example
It contains a zoomed view of Figure 1.4 and shows the worst-case buffering
scenario of task T3.
All tasks are activated periodically without any input jitter. Scheduling fol-
lows static priorities, T1 has the highest and T3 the lowest priority. The periods
are T1, T2, and T3, respectively. Task T3 is blocked for several periods and
then executes several times in a row (bursty). The scheduling diagram illus-
trates that the response time jitter (the best-case to worst-case difference) far
exceeds the period. In other words, task T3 has a large output jitter. We will
now analyze the effect of this large output jitter on the scheduling and analysis
of other tasks.
4.2.1 Propagation of Large Jitters
Figure 4.8 shows a distributed system. CPU1 scheduling has just been an-
alyzed above. We use the output stream of T3 to determine the activation and
Implications of Large Jitters 59
n0,4 T4 – J4
T5
p
rio
rity
T5 response times 
T4 response times
maximum
minimum
T4
n0 simultaneous events 
T4
T5
maximum minimum
Figure 4.9. Scheduling with Simultaneous Task Activation due to Large Jitters
execution behavior of T4 in CPU2 scheduling analysis. First, we must propa-
gate the stream parameters:
S4,in = S3,out
= SP+J(T3, J3,R)
Now, we can perform all kinds of scheduling analyses based on this T4 in-
put stream representation. We assume that scheduling follows static priorities
where task T4 has a higher priority than task T5. Figure 4.9 shows a scheduling
diagram of the second resource.
Due to the large jitter, worst-case scheduling analysis for both tasks must
assume the simultaneous arrival of n0,4 task T4 activations, just as introduced
in Section 4.1.4.1. In effect, task T4 is simultaneously activated and the cor-
responding executions interfere with each other. This has two important con-
sequences. Firstly, task T4 has a large maximum response time and –again– a
large output jitter. Secondly, this burst execution also leads to a large maximum
response time for task T5. After the burst phase is over, the first task activation
under “normal” conditions arrives at n0,4 T4 − J4 after the beginning of the
burst.
It is quite obvious that the simultaneous arrival of multiple task activations
has a major (negative) impact on the maximum response times and subse-
quently to the response time jitters and the overall jitters in the system; and
large jitters, in turn, lead to the assumption of simultaneous events. The exam-
ples show that scheduling dependencies and input jitter inheritance and accu-
60 Output Event Models
T4
T5
p
rio
rity T4 response times
4
T5
T5 response times 
T5
minimum
maximum
T3
T4
n0,4 T4 – J4
Figure 4.10. Scheduling with Large Jitter but Bounded Inter-Arrival Time
mulation (see Sec. 4.1.3) can quickly lead to extremely large jitters and sub-
sequently to high transient loads and wide response time intervals. Reducing
the pessimism in the jitter analysis is a critical task, since it results in less
pessimistic response times. Tighter response time intervals, in turn, result in
tighter jitters.
4.2.2 Limitations and Ineﬃciencies
In practice, simultaneous activations of the same task rarely occur as a result
of jitter. When we take a closer look at the execution and scheduling of the
tasks, particularly task T3 on the resource CPU1 (Fig. 4.7) , we see that the
output events are not produced simultaneously, although it executes several
times in a row. Hence, T4 on resource CPU2 is not activated simultaneously.
Figure 4.10 shows a scheduling scenario where activations arrive one after
another instead of simultaneously. For comprehensibility, the scheduling of
task T3 on the CPU1 is included in the figure. Task T4 is activated when task
T3 finishes.
Compared to the situation of simultaneous activation, we observe vast im-
provements in worst-case response times for both tasks, T4 and T5. Task T4
does not interfere with itself and the variations in the response time are little,
if we assume a relatively constant core execution time. Furthermore, the same
effect (no burst execution of T4) allows task T5 to exploit the “gaps” in the
schedule, so T5 experiences at most two preemptions by T4, compared to five
in the case of simultaneous T4 activation (see Fig. 4.9). For a better under-
Implications of Large Jitters 61
T4
T5
p
rio
rity
bounded maximum frequency
simultaneous arrival
simultaneous
arrival
reduction of maximum
T4 response time
reduction of maximum
T5 response time
T5
T4
T4
4
T5
T5
4
Figure 4.11. Comparison between two Schedules
standing, Figure 4.11 shows a detailed comparison between the two schedules.
The reductions in the maximum response time bound are highlighted. These
directly translate into reductions of the output jitter pessimism.
This optimization was possible since task T3 does not output events simul-
taneously, but with a certain amount of time between two successive events.
The knowledge that there is a time separation between the events originates
from detailed information about the execution and scheduling of T3 on CPU1.
Unfortunately, this information is not preserved in the output stream represen-
tation, simply because the model of periodic events with jitter is unable to cap-
ture this property. In other words, the information is lost in the output stream
representation. Subsequently, CPU2 analysis must assume simultaneous event
arrival, with the known inefficiencies.
4.2.3 Modeling Alternatives
The model of periodic events with large jitter has critical limitations in its
expressive power. In order to exploit the non-simultaneous arrival of events
in scheduling analysis of CPU2, we need an event stream representation that
utilizes such information.
62 Output Event Models
We have summarized in Section 3.7 the model of sporadically periodic
events or sporadic bursts. This event model has a notion of a minimum inter-
arrival time or inner period that provides the required concepts to prevent si-
multaneous event arrival. The model thereby bounds the maximum transient
event frequencies during bursts, just as observed in the above example. So, this
event model is able to capture the non-simultaneous property of output events.
But the model of sporadically periodic events has another limitation: it is
based on sporadic events and is thus unable to capture the periodic nature of
the original input stream. In effect, best case analysis potentially assumes too
few preemptions, resulting in underestimations for the minimum response time
of tasks, in turn leading to larger output jitters. So, what else can we do?
In Figure 4.7, we have observed a known temporal separation between
events in periodic streams with jitter. Therefore, we also introduce the concept
of minimum inter-arrival to periodic models with jitter as a direct extension for
large jitter support.
Quite interestingly, this extension has never been proposed before. This
means that, as yet, no event model exists to capture the effects of increasing
jitter in distributed, periodic systems to a reasonable level of accuracy. Con-
versely, the existing models seem more a collection of independently defined
formalisms rather than a sound and systematic way to capture the key effects
of scheduling and execution in distributed environments. These insufficiencies
lead to overly conservative results which considerably degrades system-level
analysis possibilities.
4.3 A New Model: Periodic Events with Burst
We introduce the idea of a minimum inter-arrival time or inner period to the
model of periodic events with jitter. The result is a very powerful model which
we call periodic events with burst (P+B) as a direct extension of the standard
jitter model. A periodic stream with burst is characterized by three parameters.
A period T , a jitter J , and a minimum event distance d. Simply speaking, the
model captures a normal jitter, just as introduced in Section 3.5. Additionally
the maximum transient event frequency is bounded, just as in the model of
sporadically periodic events (see Section 3.7).
The event model of periodic events with burst is given by:
EMP+B = { SP+B(πP+B) |
πP+B ∈ ΠP+B = {(T, J, d) | T ∈ R+ \ {0}, J ∈ R+, d ∈ R+} ,
η+P+B(∆t), η
−
P+B(∆t), δ
−
P+B(n), δ
+
P+B(n)}
(4.13)
The four characteristic functions are introduced in the following sections.
A New Model: Periodic Events with Burst 63
0
Ș+(ǻt)
ǻt
3
4
5
6
5
1
2
T
Jt
d
t ' '
4T–J 5T–J 6T–J3d –2d –d 7T–J
sporadic stream
characteristics
during burst
jitter characteristics during non-bursts
T
Jt
tjitter
' ' )(~K
d
t
tsporadic
' ' )(~K
Figure 4.12. Upper-Bound Arrival Curve of Periodic Events with Burst: “Large” Jitter and a
Minimum Distance
4.3.1 The η(∆t) Functions
Upper-Bound Arrival Function. Figure 4.12 shows the resulting up-
per bound arrival curve. We can distinguish two regions for ∆t, each region
dominated by another effect. Large values of ∆t reflect the long term behav-
ior of the stream that is periodic with jitter. Under this “normal” behavior, the
stream is characterized by its large jitter, just as mentioned in Section 4.1.4.
The curve can be described by Equation 4.9.
Small ∆ts capture the behavior during bursts, and the worst-case arrival is
dominated by the minimum event distance d to bound the maximum transient
frequency during the burst. Such behavior is already known from the two spo-
radic models in Sections 3.6 and 3.7, and the curve is given by Equation 3.29.
After the burst has finished, the event stream returns to its “normal” behavior.
Basically, both effects (and the corresponding η+ functions) overlap each
other. Both bound the maximum number of events. The resulting η+(∆t)
function is the minimum of the two individual functions:
∀∆t > 0 : η+P+B(∆t) = min
(⌈
∆t
d
⌉
,
⌈
∆t + J
T
⌉)
(4.14)
64 Output Event Models
0
Ș(ǻt)
3
4
5
6
5
T
Jt '
1
2

'
d
t
ǻt
T
Jt '
+J
Figure 4.13. Upper- and Lower-Bound Arrival Curves of Periodic Events with Burst
The transition from the “burst” phase into the “normal” operation appears
at the intersection of the curves of the two regions; more precisely, at the inter-
section of the corresponding continuous curves:
η˜+sporadic region(∆t) = η˜
+
jitter region(∆t)
⇔ ∆td = ∆t+JT
⇔ ∆t = J dT−d
(4.15)
Lower-Bound Arrival Function. The minimum distance has been in-
troduced to bound the maximum event frequencies. The lower bound function
usually deals with minimum frequencies and is not influenced by the newly
added property, and it equals the one given by Equation 4.10 in Section 4.1.4:
∀∆t > 0 : η−P+B(∆t) = max
(
0,
⌈
∆t− J
T
⌉)
(4.16)
The corresponding η−(∆t) curve has already been introduced in Figure 4.6.
Both upper and lower bound arrival curves are shown in Figure 4.13.
4.3.2 The δ(n) Functions
Minimum Distance. Since we have introduced a parameter bounding
the minimum distance between two successive events, the δ(n) functions also
change compared to the function from large jitters as introduced in Section 4.1.4.
Similar to the η+ function, two regions can be distinguished, each dominated
Sporadic Task Activation 65
by another effect. During the burst phase, the sporadic nature of minimum
event distance dominates, while the period and jitter dominate the other re-
gion. The function is given by the following equation:
∀ n ∈ N,n ≥ 2 : δ−P+B(n) = max ((n− 1)d , (n− 1)T − J) (4.17)
Maximum Distance. Similar to the lower-bound event arrival function,
the maximum distance is not affected by the proposed extension, and the func-
tion from the “normal” jitter model as given by Equation 3.27 applies:
∀ n ∈ N,n ≥ 2 : δ+P+B(n) = δ+P+J(n) = (n− 1)T + J (4.18)
4.3.3 Bounding the Minimum Output Distance
During bursts, several executions or instances of a single task interfere with
each other, as seen in Figures 4.7 and 4.9, they are re-activated before previous
activations have completed. This effect is known as task recurrence [69, 121].
In practice, such situations could eventually be handled in several ways in-
cluding the termination (kill) of the current task instance or a real preemption.
Such implementations, however, do not guarantee causality between input and
output event streams, and they are not considered further here.
We want to guarantee input-output causality, hence a newly arriving task
activation must be blocked until all preceding activations have successfully
completed. Examples are given in Figures 4.7 and 4.9. A task requires at least
its minimum response time to execute. Hence, the minimum response time
represents an additional lower bound on the minimum output distance during
output bursts. Finally, there is a third bound that might dominate the output
during input bursts:
Si,out = SP+B
(
Ti,out = Ti,in ,
Ji,out = Ji,in + Ji,R ,
di,out = max
(
Ti,out − Ji,out︸ ︷︷ ︸
as with jitter
, R−i︸︷︷︸
during
output
bursts
, di,in − Ji,R︸ ︷︷ ︸
during input bursts
) )
(4.19)
The third bound is related to transient frequencies that increase from input to
output, similar to the increase in jitter, and is explained in detail in the next
section.
4.4 Sporadic Task Activation
While periodic events (with or without jitter) have a certainly deterministic
behavior, i. e. their arrival can be predicted to a certain extent, sporadic events
66 Output Event Models
input:
sporadic
output:
sporadic
input-output delay
input
output
R constant response time
T1
R R R R
d–inǻt1>d
–
in ǻt2>d
–
in
d–out=d
–
in
ǻt1>d
–
out ǻt2>d
–
out
1 2 3 4
Figure 4.14. Sporadic Task Execution with Constant Response Time
arrive seemingly irregularly. Sporadic task activation models have proven pow-
erful in modeling the behavior of such non-deterministic event sources, for
instance customer requests to servers. Details have already been reviewed in
Section 3.6. This section focuses on the effect of execution and scheduling
on the properties of sporadic event streams, just as we have done above for
periodic streams.
4.4.1 Constant Response Time
A constant response time represents a constant input-output delay, and the
task output equals the task input except a constant phase delay. We have al-
ready observed this behavior for periodic events in Section 4.1.1. Hence, the
output stream equals the input stream:
S1,out = S1,in = SS(d−1,in) (4.20)
4.4.2 Response Time Interval
Sporadic events that enter a system experience the same types of distortion
as periodic events. The stream timing changes from a task’s input to the task’s
output, response time intervals lead to increasing uncertainty about the output
event arrival curves. We have already analyzed the effects of non-constant
response times to task input-output timing in Section 4.1.2. In the case of
periodic events, we could easily use the known jitter event model to capture
this effect. But the concept of a jitter is unknown for sporadic events which
only define a minimum inter-arrival time. So, we need a different approach.
The worst-case situation is shown in Figure 4.15. Two effects contribute to
the “worst-caseness” here: a) the two task activations arrive with their mini-
mum inter-arrival time, i. e. no other two successive task activations will ever
arrive closer in time, and b) a “late” output event is followed by an “early”
Sporadic Task Activation 67
d–in
R–R+
e
a
rl
y
la
te
input
output
ǻtout = d
–
out = d
–
in – JR
ǻtout
Figure 4.15. Worst-Case Output Timing of Sporadic Tasks
one, i. e. the response time jitter reduces the event distance from input to out-
put further, just as already known from jitters (see Sec. 4.1.3). Essentially both
mentioned effects must coincide to yield the worst case. A larger input distance
will result in a larger output distance, as will a different response time distri-
bution. From these observations, we can calculate the sought-after minimum
output inter-arrival time:
Si,out = SS(d−i,out = d−i,in − Ji,R) (4.21)
This also represents the third bound in Equation 4.19.
4.4.3 Decreasing Inter-Arrival Times
Similar to increasing jitters, the minimum inter-arrival time usually decreases
from input to output, the amount of decrease is the response time jitter. If we
consider a chain of several tasks, we can easily imagine that the reduction given
by Equation 4.21 could theoretically lead to negative results for dout. Clearly,
negative event distances simply do not make any sense, and a zero minimum
inter-arrival time translates into a infinite worst-case event frequency, we would
need to assume an infinite number of events all arriving simultaneously.
We have already discussed the problem of simultaneous event arrival in Sec-
tion 4.2.2 for the jitter model. We introduced the notion of an output event dis-
tance as an additional bound to the basic jitter model (which we now call the
model of periodic events with burst). And we could show that the minimum
response time bounds this output distance. This bound not only applies to the
output event distance in the newly introduced model of periodic events with
burst (see Equation 4.19). It is a general bound on the output timing of any
task and also applies to the model of sporadic events, and Equation 4.21 turns
into:
Si,out = SS
(
d−i,out = max
(
d−i,in − Ji,R, R−i
))
(4.22)
4.4.4 Sporadically Periodic Task Activation
The model of sporadically periodic events (or sporadic bursts) from Sec-
tion 3.7 also defines a minimum inter-arrival time, also called inner period T I
(see Section 3.7). The minimum response time represents a bound to this inner
68 Output Event Models
period, too. Furthermore, the response time jitter, introduced in Section 4.1.2,
influences both the inner and the outer output period:
Si,out = SB
(
TOi,out = max
(
TOi,in − Ji,R, bi,in × T Ii,out︸ ︷︷ ︸
mathematical bound
)
,
T Ii,out = max
(
T Ii,in − Ji,R, R−i
)
,
bi,out = bi,in
)
(4.23)
The mathematical bound on the outer period captures the fact that the maxi-
mum average frequency b
TO
does not exceed the maximum transient frequency
bounded by 1
T I
.
4.5 Conditional Output Generation
The previous section focused on the propagation of sporadic event streams
that are inputed into a system from its environment. However, sporadic envi-
ronments are not the only source for sporadic events, they can also result from
originally periodic sources in the presence of conditional communication.
Conditional output generation means that a task does or does not produce
output events, and the decision depends on the results of some calculations
internal to the task, for instance within either the then or the else block of
an if-then-else statement. In other words, the output production depends
on the internal functionality of the task. Scheduling analysis often abstracts
from such internal functional details and only looks at relatively simple corner
cases of task execution without considering the conditions that lead to either
case.
4.5.1 Constant Response Times
Again, we start with the situation of a constant response time. We can iden-
tify two corner-case scenarios. In the scenario of Figure 4.16(a), the task al-
ways produces an event at completion time. This obviously results in a purely
periodic output, just as introduced in the case of unconditional output produc-
tion (see the introduction of this chapter). The other extreme is a scenario in
which the task never produces any output. This is illustrated in Figure 4.16(b).
One already introduced model that captures such behavior is the model of
sporadic events. Figure 3.11 in Section 3.6 nicely illustrates the two behavioral
corner-cases. So, conditional output production transforms a periodic input
stream into a sporadic output stream:
Si,out = SS(Ti,in) (4.24)
Conditional Output Generation 69
input:
periodic
output:
periodic
T T T
R
ǻt=T
T T T
R
ǻt=T
R
ǻt=T
R
ǻt=T
R
ǻt=T
R
ǻt=T
R
(a) “Always” Output
input:
periodic
output:
"none"
T T T
R
T T T
R R RRRR
no
output
no
output
no
output
no
output
no
output
no
output
no
output
ǻtĺf
(b) “Never” Output
Figure 4.16. Two Corner Cases of Conditional Output Production
4.5.2 Response Time Intervals
The situation is more complex when we consider response time intervals.
Again, we can distinguish two corner-case scenarios. In the “always output”
scenario, the output is periodic with jitter as introduced in Section 4.1.3. And
for the “no output” scenario, we need some kind of sporadic model. However,
a model capturing periodic with jitter as one bound and “no output” as the other
bound is not known in literature. The same applies to conditional tasks that are
activated periodically with burst. We have to resort to the model of strictly
sporadic events. The minimum inter-arrival time is calculated according to the
observations from increasing jitters in generally periodic streams. This is valid
because the periodic stream with jitter represents the upper output bound, and
the sporadic model defines an upper bound, only:
Si,out = SS
(
max
(
Ti,in − Ji,R, R−i
)) (4.25)
4.5.3 Input with Jitter and Burst
If the task is already activated with a jitter (or even burst), then we can easily
extend Equation 4.25:
Si,out = SS
(
max
(
Ti,in − Ji,in − Ji,R, di,in − Ji,R, R−i
)) (4.26)
We see that the minimum inter-arrival time continually decreases along
task chains, representing increasing frequencies. These increasing frequen-
70 Output Event Models
0
Ș(ǻt)
ǻt
3
4
5
6
5
1
2
3T–J 4T–J 5T–J 6T–J
T
Jt '
Figure 4.17. Upper- and Lower-Bound Arrival Curves of Sporadic Events with Jitter
cies, however, are not a property of the actual system behavior but of the event
stream representation that suffers from considerable modeling inefficiencies.
4.6 New Sporadic Models with Jitter and Burst
So far, we have identified two key effects that task execution and schedul-
ing impose on output event streams: a) jitters increase from inputs to outputs
(see Sec. 4.1.3) and finally lead to bursts (Sec. 4.3), and b) conditional com-
munication turns periodic inputs into sporadic output behavior (Sec. 4.5). The
two effects are apparently orthogonal, and it is relatively straight-forward to
combine the already known concepts used to capture both individual effects.
4.6.1 Sporadic Events with Jitter
We extend the sporadic model to also capture a possible input jitter. The
model of sporadic events with jitter is defined by:
EMS+J = { SS+J(πS+J) |
πS+J ∈ ΠS+J = {(T, J)|T ∈ R+ \ {0}, J ∈ R+} ,
η+S+J(∆t), η
−
S+J(∆t), δ
−
S+J(n), δ
+
S+J(n)}
(4.27)
with the characteristic functions defined below.
New Sporadic Models with Jitter and Burst 71
0
Ș(ǻt)
3
4
5
6
5
T
Jt '
1
2

'
d
t
ǻt
Figure 4.18. Upper- and Lower-Bound Arrival Curves of Sporadic Events with Burst
In the “always” case, periodic with jitter provides an upper bound on η+(∆t)
and a lower bound on δ−(n):
∀∆t > 0 : η+S+J(∆t) = η+P+J(∆t) =
⌈
∆t + J
T
⌉
(4.28)
∀ n ∈ N,n ≥ 2 : δ−S+J(n) = δ−P+J(n) = max (0, (n− 1)T − J) (4.29)
In the other case, the bounds are zero for η−(∆t), and infinity for δ+(n) re-
spectively, formally capturing the sporadic nature of the model. We call this
model sporadic events with jitter, with the index S+J. The combined upper
and lower bound arrival curves are shown in Figure 4.17.
4.6.2 Sporadic Events with Burst
To avoid the inefficiencies of large jitters, we also define the model of spo-
radic events with burst (S+B):
EMS+B = { SS+B(πS+B) |
πS+B ∈ ΠS+B = {(T, J, d) | T ∈ R+ \ {0}, J ∈ R+, d ∈ R+} ,
η+S+B(∆t), η
−
S+B(∆t), δ
−
S+B(n), δ
+
S+B(n)}
(4.30)
The combined upper and lower bound arrival curves are shown in Fig-
ure 4.18. The characteristic functions are given by:
∀∆t > 0 : η+S+B(∆t) = η+P+B(∆t) = min
(⌈
∆t
d
⌉
,
⌈
∆t + J
T
⌉)
(4.31)
72 Output Event Models
∀∆t > 0 : η−S+B(∆t) = 0 (4.32)
∀ n ∈ N,n ≥ 2 : δ−S+B(n) = δ−P+B(n) = max ((n− 1)d , (n− 1)T − J)(4.33)
∀ n ∈ N,n ≥ 2 : δ+S+B(n) =∞ (4.34)
4.6.3 Sporadic Activation and Conditional
Output
The combination of sporadic activation (with or without jitter or burst) and
conditional output production does not lead to new output models. In one
corner case, we have to assume periodic input and “always output”, leading to
periodic output. In the other case, we assume zero input, i. e. the task is not
even executed, or it executes but does not produce output. The result is the
same: zero output production. The output is in the model of sporadic events.
The jitter or the burstiness can be determined just as in the case of periodic
activation in Section 4.5.
4.7 A Six-Class Model Set
Figure 4.7 shows all output event models and indicates the transitions inves-
tigated in this chapter. We define six of these models as standard event models,
that form a six-class model set. We derived this model set from two key obser-
vations. Jitters increase from inputs to outputs and can lead to bursts in both
periodic and sporadic models. Conditional output production turns a periodic
model into its sporadic “counterpart”, while sporadic cannot become “more
sporadic” but can induce jitter and burst.
As a key property, this six-class model set is self-contained, i. e. no effect
brings us out of these models, and key stream information such as an average
period are preserved. Just using the popular models from literature (they are
highlighted in the figure) is not sufficient. They lack the expressive power to
consistently handle the effects of large jitter. Burst (the consequence of large
jitters) has not yet been considered in periodic models, while jitter has not yet
been considered in sporadic models. The three new models close this concep-
tual modeling gap and overcome the mentioned insufficiencies. As another
simplification, we can use the same parameters for sporadic and periodic mod-
els. Instead of a minimum inter-arrival time d−, we refer to this value as the
sporadic period T .
Two tables summarize the characteristic functions of the six models. Ta-
ble 4.1 contains the upper and lower event arrival functions η(∆t), while Ta-
ble 4.2 summarizes the event distance functions δ(∆t).
The known model of “sporadically periodic” events introduced by Audsley,
Tindell, and others [4, 121] does not easily fit into the other model’s classi-
fication, although it has similarities with the model of sporadic events with
A Six-Class Model Set 73
spora-
dically
periodic
increasing jitter due to execution/scheduling
strictly
periodic
T
periodic
w/ jitter
T, J
periodic
w/ burst
T, J, d
strictly
sporadic
sporadic
w/ jitter
sporadic
w/ burst
s
p
o
ra
d
ic
 o
u
tp
u
t 
d
u
e
 t
o
c
o
n
d
it
io
n
a
l
ta
s
k
s
 f
u
n
c
ti
o
n
existing models
TO, TI, b
Figure 4.19. Self-Contained Six-Class Event Model Set
η+(∆t) η−(∆t)
model π both periodic(P) sporadic(S)
P/S < T >
‰
∆t
T
ı —
∆t
T

0
P/S+J < T, J >
‰
∆t + J
T
ı
max
„
0,
—
∆t− J
T
«
0
P/S+B < T, J, d > min
„‰
∆t + J
T
ı
,
‰
∆t
d
ı«
max
„
0,
—
∆t− J
T
«
0
Table 4.1. The η(∆t) Functions of the New Models
δ−(∆t) δ+(∆t)
model π both periodic(P) sporadic(S)
P/S < T > (n− 1)T (n− 1)T ∞
P/S+J < T, J > max (0, (n− 1)T − J) (n− 1)T + J ∞
P/S+B < T, J, d > max ((n− 1)d, (n− 1)T − J) (n− 1)T + J ∞
Table 4.2. The δ(∆t) Functions of the New Models
74 Output Event Models
burst, which we illustrate by overlapping boxes in Figure 4.7. Its interpre-
tation of burst, however, is not based on the observation of large jitters. On
the contrary, the model has no notion of jitter, and hence, it suffers from “ar-
tificially” increasing frequencies when used for modeling output streams, as
we have demonstrated in Section 4.4. The model has its application in mod-
eling complex non-deterministic environments, e. g. in control engineering or
transportation systems, but is less popular for modeling internal system depen-
dencies. However, we shall see in the next chapter, that we can find transfor-
mations between the model of sporadically periodic events into the model of
sporadic events with burst, and vice versa. This allows sporadically periodic
streams (and possibly others) to be captured by the newly defined six-class
model.
4.8 Summary
In this chapter, we have systematically investigated the effects of execution,
scheduling, and conditional communication on the generation of events and,
subsequently, the representation of output event streams. We have seen that
the existing event models have major insufficiencies in reasonably capturing
the effects of large jitters, and we extended them to systematically support
jitters and bursts without degrading modeling accuracy.
We defined two classes, periodic and sporadic, and we have three models
in each class: strict, with jitter, and with burst. That means that we keep on
with the models of periodic events with and without jitter, but define a burst
as the consequence of large jitter. In order to limit the maximum transient
frequency, we additionally define a minimum distance between any two events,
similar to the inner period in the model of sporadically periodic events [4,
121]. The sporadic class generalizes the class of periodic models, in that one
corner-case scenario is implicitly set to “no output”, i. e. the η−(∆t) functions
are set to zero. That means, every sporadic stream can be assumed to be the
corresponding periodic stream in the worst case, which is consistent with the
early application of sporadic events in real-time analysis [108].
There are three advantages of these six models over the four previously
identified well known ones. First, the transition from strict to jitter to burst
is intuitive. Second, periodic and sporadic streams use the same underlying
models and parameters, which further reduces the complexity. The major ad-
vantage of this new set of models, however, is a conceptional one: The new
set of models is self-contained with respect to input-output stream modeling.
No transformation brings us out of these six models. Jitters are allowed to far
exceed the period, and our new definition of burst is just the intuitive charac-
terization of the effects of large jitters. The six-class model set appears as an
efficient compromise between model simplicity and intuition on the one hand,
and completeness on the other hand, and finally applicability. Because we only
Summary 75
applied slight extensions to the known models from literature, the new mod-
els can be directly –without any approximation– applied in connection with
established local analysis techniques which we consider a major advantage.
This sufficiency of a bounded set of intuitively structured models is likely to
attract system designer’s and architect’s attention to the overall ideas of formal
real-time analysis.

Chapter 5
EVENT MODEL INTERFACES
In the two preceding chapters, we have introduced the models popularly
found as input and output event models in scheduling analysis. Input event
models capture task activation in response to incoming events. Output models
capture the production of events, i. e. the production of workload for other tasks
or communications. There are several popular and practically used input event
models, and there are even more –and more complex– output event models. In
a larger system, some components typically require certain input event models
or streams, otherwise they can not be scheduled or analyzed. There are sev-
eral practically important reasons for such an input requirement. For instance,
the limited availability of analysis (tools) for a particular component forces
designers to use the model dictated by the analysis (tool). Other components
might have been already implemented, such as a DSP running a static periodic
schedule, constraining the acceptable input further. This chapter introduces
Event Model Interfaces that allow transformations from one event model into
another to meet the mentioned input model requirements.
We will first define terms that help to capture the event model interfacing
problem formally. Then, we shall derive conditions that an interface must meet,
and determine compatibility tests. Finally, the existing event model interfaces
are derived. We start with the six-class model set, as introduced in the previous
chapter, then we consider the specialties of Audsley’s and Tindell’s model of
sporadically periodic events [4, 121].
5.1 Introductory Example
Figure 5.1 shows an example of two CPUs connected through a direct point-
to-point line. T1 on CPU1 sends data events to T4 on CPU2 via the event
stream S1,4. Other tasks are implemented on both resources, too, but they are
of no interest for this example.
78 Event Model Interfaces
event stream S1,4
Point-To-Point Link
T2
T3
T1
CPU1
RTOS1
T5
T4
CPU2
RTOS2
Figure 5.1. Introductory Example: Unidirectional Task-Task Communication via Event
Streams
The operating systems (RTOS) on both resources implement different re-
source sharing or scheduling strategies, a simple form of heterogeneous schedul-
ing. We make the following assumptions on both tasks:
from the scheduling analysis of T1 we know that the output events are
generally periodic with period T1 but may experience a bounded jitter J1
(e. g. resulting from preemptions by other processes). The jitter is less than
the period: J1 < T1.
T4 is part of an IP (intellectual property) component. No internal details
are known except a maximum allowed frequency f+4 , which corresponds
to a sporadic input event model with a required minimum inter-arrival time
(sporadic period) T4,req.
The two event streams (periodic events with jitter versus sporadic events)
are apparently incompatible, i. e. they are provided in different event mod-
els, and hence, have different parameters and different characteristic functions.
Therefore, the output stream of task T1 can not be directly used for analyzing
task T4. However, the incompatibility can be solved by deriving the required
parameters of the target event stream (in this case sporadic events) from the
known properties of the source event stream.
Figure 5.2 illustrates the periodic stream with jitter coming from task T1. It
is defined by its period T1 and its jitter J1. The model of sporadic events de-
fines a single parameter, the minimum period T4 (minimum distance) between
any two successive events. The jitter event stream at T1’s output is generally
periodic with a period of T1 but allows each event to deviate in time. Now con-
sider two successive events, the first being as late as possible (t1 = t0+J1) and
the second one –belonging to the next period– as early as possible, i. e. without
any jitter delay (t2 = t0+T1). Obviously, no other two events can arrive closer
in time. So, the sought-after minimum temporal separation of two successive
Introductory Example 79
1J
1T 1T 1T
e
a
rl
y
la
te
1112 JTtt  
t
1t0t 2t
Figure 5.2. Worst-Case Event Timing
events with jitter is given by the following equation:
T4,in = t2 − t1 = T1 − J1 (5.1)
This parameter transformation represents an event model interface. We in-
troduce the terms source stream and target stream to distinguish between the
source and target of the transformation, and formally define event model inter-
faces.
Definition 5.1. (Event Model Interface)
An Event Model Interface EMIF is a function that maps a source event
stream provided in a source event model, to a target event stream in the re-
quired target model.
EMIF source→target : EMsource → EMtarget
Starget = EMIF source→target(Ssource) (5.2)
Depending on the specific properties of the involved event models, the do-
main of an interface, i. e. the event streams that can be successfully trans-
formed, might be constrained to only a subset of the entire event model, i. e. not
all streams in the source model can be transformed into a stream in the target
model. For instance, the jitter must be less than the period in our example,
otherwise Equation 5.1 would yield a zero or negative minimum period for the
sporadic stream. The full definition of the event model interface of the example
is:
EMIFP+J→S : {SP+J(T, J) ∈ EMP+J|J < T} → EMS
Starget = SS(Ttarget = Tsource − Jsource) (5.3)
80 Event Model Interfaces
T1 T4
S1,out=SP+J(T1,J1) R4,in={SS | T  T4,req}
?
Figure 5.3. Problem Illustration
We have manually derived an appropriate parameter T4,in from the known
parameters of task T1’s output. A sporadic stream with a given minimum pe-
riod T4,in apparently seems to be a valid representation also for some streams
that are periodic with jitter. In the next section, we introduce a set of tests that
allow the entire problem to be formally captured.
5.2 Event Stream Compatibility Tests
We have already formally defined event streams and event models in Chap-
ter 3. An event model is defined as the set of all event streams that share
common properties. For instance, the output stream of task T1 is given in the
model of periodic events with jitter, i. e. the stream is an element of the model:
S1,out = SP+J(T1, J1) ∈ EMP+J (5.4)
Task T4 requires a sporadic input stream, the allowed minimum period is
further restricted to be at least T4,req. Hence, the acceptable set of input streams
is only a subset of the model of strictly sporadic events. We call this subset an
event stream requirement R.
Definition 5.2. (Event Stream Requirement)
An Event Stream Requirement R is a non-empty set of event streams.
A given event stream S is said to meet a given event stream requirementR,
if and only if S is an element ofR.
We formulate the input stream requirement R4,in of task T4 to contain all
sporadic streams with a sporadic period of T4,req and larger:
R4,in =
{SS(T )| T ≥ T4,req} ⊆ EMS (5.5)
The entire problem definition is illustrated in Figure 5.3. We said that the
periodic output stream with jitter does not meet the sporadic input requirement.
Mathematically speaking, the output stream S1,out of task T1 is not included in
the input requirement R4,in of task T4:
S1,out /∈ R4,in (5.6)
Interface Veriﬁcation 81
Moreover, S1,out is not even in the right model:
S1,out ∈ EMP+J
S1,out /∈ EMS (5.7)
The transformed input stream, however, is in the right model:
S4,in = SS(T1 − J1) ∈ EMS (5.8)
When also the sporadic period T4,in is within the allowed range, the trans-
formed stream meets the target input requirement (see Definition 5.2):
S4,in meets R4,in
⇔ S4,in ∈ R4,in
⇔ (S4,in ∈ EMS) ∧ (T4,in ≥ T4,req) (5.9)
The above definitions allow the given situation of the example to be formally
captured. Specifically, the event model (in)compatibility can be determined us-
ing set-containment conditions, such as in Equation 5.6. In the example, we
have resolved the incompatibility using an appropriate parameter transforma-
tion. However, we have not yet formally verified that the event model interface
of Equation 5.3 is correct.
5.3 Interface Veriﬁcation
Event model interfaces must transform a given source stream into a target
model representation such, that the possible event timing of the source stream
is fully covered by the possible timing of the target stream. Otherwise, the
scheduling analysis of the target task is not able to consider all event arrival
scenarios that can actually occur. We can check this coverage using the four
characteristic functions.
Definition 5.3. (Event Stream Coverage Test)
The Event Stream Coverage Test SC is a function that takes as arguments
a source event stream Ssource and a target event stream Starget and returns a
boolean value.
Let Z be the set of all possible event streams S. Then, SC is deﬁned by:
SC : Z × Z → {0, 1} (5.10)
SC(Ssource,Starget) returns 1 (true), if the source stream Ssource is covered by
the target stream Starget, and 0 (false) otherwise.
82 Event Model Interfaces
A source event stream Ssource is covered by a target event stream Starget, if
and only if all of the following four conditions are true:
∀∆t ∈ R+ : η+Ssource(∆t) ≤ η+Starget(∆t) (5.11)
∀∆t ∈ R+ : η−Ssource(∆t) ≥ η−Starget(∆t) (5.12)
∀ n ∈ N+ \ {0, 1} : δ−Ssource(n) ≥ δ−Starget(n) (5.13)
∀ n ∈ N+ \ {0, 1} : δ+Ssource(n) ≤ δ+Starget(n) (5.14)
We shall soon see that the transformation of Equation 5.3 successfully passes
this test, and hence represents a correct event model interface. In Section 5.3.2,
we will proof that the following equation holds:
∀SP+J(T, J), J < T : SC(SP+J(T, J),SP(T − J)) = 1 (true) (5.15)
In addition, we define a Requirement Coverage Test, that generalizes the just
introduced event stream coverage test such that it is also applicable to an event
stream requirement.
Definition 5.4. (Requirement Coverage Test)
The Requirement Coverage Test RC is a function that takes as arguments a
source event stream Ssource and a target event stream requirement Rtarget and
returns a boolean value.
Let Z be the set of all possible event streams S, and P(Z) be its power set.
Then,RC is deﬁned by:
RC : Z × P(Z) → {0, 1} (5.16)
RC(Ssource,Rtarget) returns 1 (true), if the stream Ssource is covered by the
requirementRtarget, and 0 (false) otherwise.
An event stream Ssource is covered by an event stream requirementRtarget, if
and only if the source stream Ssource is covered by at least one element of the
target requirement:
RC(Ssource,Rtarget) =
(∃Starget ∈ Rtarget : (SC(Ssource,Starget) = 1)) (5.17)
This requirement coverage test lets us formally test, if the output stream of
task T1 can be transformed into the model of strictly sporadic events EMS at
all. This is only possible, if the following equation holds:
RC(S1,out, EMS) != 1 (true) (5.18)
Interface Veriﬁcation 83
Ș(ǻt)
ǻt
Ș+ (ǻt)target
Ș– (ǻt)target
loss of
accuracy
Ș+ (ǻt)source
Ș– (ǻt)source
(a) Example of Covered Event Streams
Ș(ǻt)
ǻt
Ș+ (ǻt)source
Ș+ (ǻt)target
Ș– (ǻt)target Ș– (ǻt)source
invalid regions
(b) Example of Non-Covered Event Streams
Figure 5.4. Graphical Representation of Stream Coverage
The mentioned coverage tests are applicable to arbitrary streams including
numerical streams, for which no abstract properties and parameters are known,
e. g. the numerical arrival and service curves that Thiele et al. use [116]. In
fact, parameterized event models allow the coverage to be formally checked
more efficiently than numerical representations. The characteristic functions,
however, are sufficient for the verification of an interface.
5.3.1 Graphical Veriﬁcation
The graphical representation of the characteristic functions illustrates the
meaning of stream coverage. Figure 5.4 shows two examples. In Figure 5.4(a),
the η functions of the source stream reside between the corresponding η func-
tions of the target stream. More precisely, the η+source(∆t) curve is below the
η+target(∆t)-curve (condition 5.11 is true), and the η−source(∆t) curve is above the
η−target(∆t) curve (condition 5.12 is true). Assuming that also the δ functions
are covered, we can formulate this coverage by:
SC(Ssource,Starget) = 1(true) (5.19)
Figure 5.4(b) shows a scenario where both conditions 5.11 and 5.12 are
violated. The source stream is not covered by the target stream:
SC(Ssource,Starget) = 0(false) (5.20)
We will now verify the coverage of the event model interface of our initial
example. The interface was given by Equation 5.3. Again, we start from the
graphical representation, which is given in Figure 5.5. In addition to the integer
functions η+(∆t) and η−(∆t), the “unrounded” versions of these functions
(η˜+ and η˜−) are also shown in the figure as dotted lines. In those regions where
the η˜+ curve of the target stream is above the η˜+ curve of the source stream, the
84 Event Model Interfaces
5
0
1
2
3
4
Ș(ǻt)
ǻt
S,4WT
t'
JP
JP

'
,
,
1
1
W
W
T
Jt
JP
JP

'
,
,
1
1
W
W
T
Jt
critical
points
loss of
accuracy
JPJP   ,, 11 WW JT
Figure 5.5. η(∆t) Curves of EMIFP+J→S
η+ condition (Equation5.11) is obviously fulfilled. And the regions where the
target curve is not above the source curve –the region with the critical points–
require only a minimum of additional information. In this case, it is enough to
understand that, if the jitter is less than the period, then the two curves intersect
at ∆t = TP+J − JP+J > 0, and both discrete η+ functions have a value of one
in that area, which also fulfills the η+ condition. The curves furthermore show
that also the η− condition of Equation 5.12 is met.
Interface Veriﬁcation 85
5.3.2 Formal Veriﬁcation
Depending in the involved streams, the formal verification of event stream
containment can be complex. In the example, we have the following streams:
Ssource = S1,out = SP+J(T1, J1)
Starget = S4,in = SS(T4 = T1 − J1)
From the previous chapter, we know the characteristic functions of these
two streams (in their interval notation):
ηIS1,out(∆t) =
[
max
(
0,
⌊
∆t− J1
T1
⌋)
;
⌈
∆t + J1
T1
⌉]
δIS1,out(n) = [max (0, (n− 1)T1 − J1) ; (n− 1)T1 + J1]
ηIS4,in(∆t) =
[
0;
⌊
∆t
T4
⌋]
δIS4,in(n) = [(n− 1)T4;∞]
5.3.2.1 η− Compatibility Test
Because of the sporadic nature of the target event stream, condition 5.12 can
be trivially proved:
η−1,out(∆t) = max
(
0,
⌊
∆t−J1
T1
⌋)
≥ 0 = η−4,in(∆t)
q.e.d. (5.21)
5.3.2.2 δ+ Compatibility Test
Checking test 5.14 is trivial, too:
δ+S1,out(n) = (n− 1)T1 + J1 ≤ ∞ = δ+S4,in(n)
q.e.d. (5.22)
86 Event Model Interfaces
5.3.2.3 δ− Compatibility Test
Checking condition 5.13 is slightly more complex. Note that δ(n) is only
defined for n ≥ 2:
n ≥ 2 | − 1,×(−J1,out)
⇔ −(n− 1)J1,out ≤ −J1,out |+ (n− 1)T1,out
⇔ (n− 1)(T1,out − J1,out) ≤ (n− 1)T1,out − J1,out
⇔ (n− 1)T4,in ≤ (n− 1)T1,out − J1,out
⇔ δ−4,in(n) ≤ δ−1,out(n)
q.e.d.
(5.23)
5.3.2.4 η+ Compatibility Test
Checking the η+ condition from Equation 5.11 is more difficult. The proof
is split into two parts. The first part considers time intervals of size ∆t ≤
T4,in = T1,out−J1,out, while the second part treats larger ∆ts. First, we will see
that both η+(∆t) functions have a value of 1 (one) for 0 < ∆t ≤ T1,out−J1,out.
We start with the periodic stream with jitter:
0 < ∆t ≤ T1,out − J1,out |+ J1,out
⇔ 0 < J1,out < ∆t + J1,out ≤ T1,out | × 1T1,out , T1,out > 0
⇔ 0 < J1,outT1,out <
∆t+J1,out
T1,out
≤ 1 |
⇒ 0 < ∆t+J1,outT1,out  = 1
⇒ η+1,out(∆t) = 1
(5.24)
Next, we proof that η+(∆t) = 1 for 0 < ∆t ≤ T4,in = T1,out−J1,out on the
sporadic event stream:
0 < ∆t ≤ T1,out − J1,out | × 1T1,out−J1,out , T1,out > J1,out > 0
⇔ 0 < ∆tT1,out−J1,out ≤ 1 |
⇒ 0 <  ∆tT1,out−J1,out  = 1
⇔ 0 <  ∆tT4,in  = 1
⇒ η+4,in(∆t) = 1
(5.25)
From equations 5.24 and 5.25, we have shown that
∀∆t ≤ T4,in = T1,out − J1,out : η+1,out(∆t) = η+4,in(∆t) = 1. (5.26)
Interface Veriﬁcation 87
The substitution
∆t > T1,out − J1,out
⇔ ∆t = T1,out − J1,out + x, x > 0
⇔ x = ∆t− (T1,out − J1,out) > 0 (5.27)
is used to show that condition 5.11 is also met for ∆t > T4,in = T1,out−J1,out:
J1,out > 0 | − J1,out
⇔ 0 > −J1,out |+ T1,out
⇔ T1,out > T1,out − J1,out |()−1
⇔ 1T1,out < 1T1,out−J1,out | × x, x > 0
⇔ xT1,out < xT1,out−J1,out |+ 1
⇔ 1 + xT1,out < 1 + xT1,out−J1,out |x = ∆t− (T1,out − J1,out) > 0
⇔ 1 + ∆t−(T1,out−J1,out)T1,out < 1 +
∆t−(T1,out−J1,out)
T1,out−J1,out
⇔ 1 + ∆t+J1,outT1,out −
(T1,out)
T1,out
< 1 + ∆tT1,out−J1,out −
(T1,out−J1,out)
T1,out−J1,out
⇔ 1 + ∆t+J1,outT1,out − 1 < 1 + ∆tT1,out−J1,out − 1
⇔ ∆t+J1,outT1,out < ∆tT1,out−J1,out |
⇒ ∆t+J1,outT1,out  ≤  ∆tT1,out−J1,out 
⇔ ∆t+J1,outT1,out  ≤  ∆tT4,in 
⇒ η+1,out(∆t) ≤ η+4,in(∆t)
(5.28)
Finally, equations 5.26 and 5.28 provide:
∀∆t > 0 : η+1,out(∆t) ≤ η+4,in(∆t)
q.e.d. (5.29)
With all four conditions met, the event stream coverage test of Section 5.3
returns 1 (true), and the transformation of Equation 5.1 in fact provides a valid
EMIF for the transformation from a periodic stream with jitter into a spo-
radic stream without jitter. However, we have seen that the formal proofs can
be complex. Where reasonable, we shall use intuitive and comprehensible
graphical proofs, as presented in Section 5.3.1, rather than complex mathe-
matical equations.
88 Event Model Interfaces
5.3.3 Interface Quality
In addition to event stream coverage, there are two other interesting prop-
erties of that event model interface, which Figure 5.5 nicely reveals. First, we
see that for large ∆t, the curves diverge, i. e. the distance between the upper
[lower] bound curves of the source and the target stream increases. This is
because the single parameter of the target model of strictly sporadic events is
not able to capture all details of the source stream (periodic with jitter), but can
only conservatively approximate or bound them at the cost of lost accuracy,
indicated by the white arrows. We call such interfaces lossy interfaces.
An interface that transforms a source stream into a target stream without
loss of accuracy is called lossless. Lossless transformation requires the char-
acteristic functions –and thus the curves– of the source and the target stream
to be identical. We can use the coverage test to check if an interface is loss-
less, since the coverage test must be successful in both directions, otherwise
the characteristic functions would differ:
EMIF source→target is lossless ⇔
SC(Ssource,Starget) = SC(Starget,Ssource) = 1 (5.30)
Likewise, we can check for lossiness using the following test:
EMIF source→target is lossy ⇔ SC(Starget,Ssource) = 0 (5.31)
Second, we look at small ∆ts, especially the two critical points where the
curves are identical. This illustrates the tightness of the transformation in
Equation 5.3. Any smaller value for T4,in would violate the η+-condition in
this critical region, while larger values would result in further accuracy loss,
even for ∆t < T1,out − J1,out. In other words, the transformation is –although
lossy– optimal in the sense that no other valid transformation with less accu-
racy loss can be found.
We can also formalize an optimality test. We are looking for the interfaces
that yield the tightest target stream. Let EMIF1 and EMIF2 be two event
model interfaces that transform a source stream Ssource into the target streams
Starget,1 and Starget,2, respectively. We assume that both interfaces are correct,
i. e. the event stream coverage test from Definition 5.3 is successful:
SC(Ssource,Starget,1) = 1(true) ∧ SC(Ssource,Starget,2) = 1(true) (5.32)
If the target stream Starget,1 is covered by the target stream Starget,2, then the
interface EMIF1 is tighter that EMIF2:
EMIF1 is tighter than EMIF2
⇔ SC(Starget,1,Starget,2) = 1(true) (5.33)
Existing Interfaces 89
strictly
periodic
periodic
w/ jitter
periodic
w/ burst
strictly
sporadic
sporadic
w/ jitter
sporadic
w/ burst
Figure 5.6. Existing Atomic Event Model Interfaces
Finally, an interface EMIFopt is optimal, if and only if it is at least as tight
as (and thus covers) any other interface EMIFX for the same event stream
combination:
EMIFopt,source→target is optimal
⇔ ∀EMIFX,source→target = EMIFopt,source→target :
SC(Starget,opt,Starget,X) = 1(true) (5.34)
We will see that for all interface-able model combinations within the six-
class model set, a single optimal interface can be found.
5.4 Existing Interfaces
Mathematically speaking, finding an EMIF for a specific combination of
event models (EMsource → EMtarget) equals solving Equation 5.2 such that for
at least some Ssource ∈ EMsource, the requirement coverage test is successful:
RC(Ssource, EMtarget) = 1 (true) (5.35)
If this test is not successful for all streams in the source event model, then
the domain of the interface must be constrained accordingly. The event model
interface from the introductory example (see Equation 5.3) is an example for an
interface with a constrained domain. Furthermore, we are looking for optimal
interfaces with respect to Equation 5.34.
Due to the non-linearities in the characteristic functions, a formal procedure
can be complex. In most cases, the empirical approach is more promising.
We have seen in the example, that the graphical representations of the char-
acteristic functions provides a comprehensible illustration of the problem. In
particular the continuous η˜ functions are well suited to supplement textually
90 Event Model Interfaces
motivated model transformations, so that detailed mathematical derivations are
reduced to a minimum. Correctness and optimality proofs are provided where
necessary.
We will now summarize the existing event model interfaces with respect
to the six-class model set. We shall start with atomic interfaces, shown in
Figure 5.6. Lossless interfaces are illustrated by straight lines, lossy ones by
dotted lines in that figure. Later, we will compose other interfaces from these
atomic ones. Our initial example from periodic with jitter into strictly sporadic
is an example for a non-atomic interface.
5.5 Lossless Event Model Interfaces
Lossless interfaces exist only for the transformations already investigated in
the preceding chapter. We saw that execution and scheduling adds distortion
or non-determinism to task outputs. So, we needed output models that support
this additional expressive power (modeling capabilities) compared to the input
models. In other words, the output models are more general than the input
models, and a lossless transformation is possible.
5.5.1 Strictly Periodic → Periodic with Jitter
The transformation itself is trivial. The period of the source stream is pre-
served, and the jitter in the target stream is zero:
EMIFP→P+J : EMP → EMP+J
Starget = SP+J(Ttarget = Tsource, Jtarget = 0) (5.36)
The proofs are trivial. With the J being 0 (zero), the characteristic functions
of the periodic with jitter target model (see Section 3.5) are reduced to the
functions of the periodic stream (see Section 3.3). This transformation is loss-
less because the corresponding characteristic functions are identical, captured
by the following equation:
SC(SP(T ),SP+J(T, 0)) = SC(SP+J(T, 0),SP(T )) = 1 (5.37)
5.5.2 Periodic with Jitter → Periodic with Burst
The same idea applies to this transformation. The period and the jitter of
the source stream is preserved, and the minimum distance is set accordingly.
This reduces the characteristic functions of the newly defined burst model (see
Section 4.3) into those of the jitter model (see Section 3.5):
EMIFP+J→P+B : EMP+J → EMP+B
Starget = SP+B
⎛
⎝ Ttarget = Tsource,Jtarget = Jsource,
dtarget = max(0, Tsource − Jsource)
⎞
⎠ (5.38)
Lossless Event Model Interfaces 91
This interface is lossless because Equation 5.30 is true.
5.5.3 Strictly Sporadic → Sporadic with Jitter
The systematic orthogonalization of jitter on the one hand, and the dual-
ity between sporadic and periodic models on the other hand, has an important
practical impact. Each lossless transformation between standard event mod-
els in the periodic domain has its equivalent transformation in the sporadic
domain. So, this S → S+J transformation is identical to the equivalent trans-
formation in the periodic domain (P → P+J), mentioned in Section 5.5.1.
EMIFS→S+J : EMS → EMS+J
Starget = SS+J(Ttarget = Tsource, Jtarget = 0) (5.39)
5.5.4 Sporadic with Jitter → Sporadic with Burst
Again, this is just the sporadic version of the transformation from periodic
with jitter into periodic with burst. The equivalent EMIF applies:
EMIFS+J→S+B : EMS+J → EMS+B
Starget = SS+B
⎛
⎝ Ttarget = Tsource,Jtarget = Jsource,
dtarget = max(0, Tsource − Jsource)
⎞
⎠ (5.40)
5.5.5 Model Reductions
We have seen that a strictly periodic event stream can be modeled as a pe-
riodic stream with a zero jitter without accuracy loss. Practically speaking, a
zero jitter can be considered as “no jitter”. That means the stream actually
has the same characteristic functions as a strictly periodic stream without jit-
ter. This allows the event model interface of Equation 5.36 to be inverted,
i. e. the target and source stream can be exchanged, as already indicated by
Equation 5.30. We call such transformations model reductions. They differ
from general event model interfaces in that their domain is restricted to special
cases, e. g. a zero jitter. Similarly, we can transform a burst stream into a jit-
tery stream, if and only if the minimum distance between events in the original
burst stream fulfills the requirements of the jitter models. Both reductions are
applicable to periodic and sporadic streams.
Reduction EMIFs
EMIF
P+Jred→P : {SP+J(T, J) ∈ EMP+J|J = 0} → EMP
Starget = SP(Ttarget = Tsource) (5.41)
92 Event Model Interfaces
EMIF
P+Bred→P+J : {SP+B(T, J, d) ∈ EMP+B|d = max(0, T − J)}
→ EMP
Starget = SP+J(Ttarget = Tsource, Jtarget = Jsource) (5.42)
EMIFS+Jred→S : {SS+J(T, J) ∈ EMS+J|J = 0} → EMS
Starget = SS(Ttarget = Tsource) (5.43)
EMIFS+Bred→S+J : {SS+B(T, J, d) ∈ EMS+B|d = max(0, T − J)}
→ EMP
Starget = SS+J(Ttarget = Tsource, Jtarget = Jsource) (5.44)
Such model reductions are always lossless, just like their lossless inverse
transformations. But they are only applicable to special case situations such
as a zero jitter. In practice, there is no difference between the event timing in
a strictly periodic event stream and a stream with a zero jitter. It is merely a
matter of modeling that becomes important in an automatic interfacing proce-
dure, where parameters must be well-defined. In Sections 5.6.2 and 5.6.3, we
will see also lossy transformations from sporadic with jitter and burst into the
model of strictly sporadic events. Therefore, we explicitly indicate a reduction
interface by “red→” (see the EMIF equations above).
5.6 Lossy Event Model Interfaces
Besides the lossless transformations, there is a set of lossy transformations
with slightly different properties.
5.6.1 Transforming Periodic into Sporadic Models
As Figure 5.6 shows, there are three lossy transformations from a periodic
model into its sporadic counterpart. Compared to the aforementioned lossless
interfaces, these transformations follow the second systematic concept of the
six-class model set, the concept of conditional event production and unknown
task behavior that has been discussed in Section 4.5. Figure 5.7 shows the
curves of the transformation of periodic with jitter into sporadic with jitter
which nicely illustrates the accuracy loss. The corresponding interfaces are
straight-forward:
EMIFP→S : EMP → EMS
Starget = SS(Ttarget = Tsource) (5.45)
Lossy Event Model Interfaces 93
5
0
1
2
3
4
Ș(ǻt)
ǻt
JS
JS
JP
JP



 ' '
T
Jt
T
Jt
JP
JP

'
T
Jt
loss of
accuracy
Figure 5.7. η(∆t) Curves of EMIFP+J→S+J
EMIFP+J→S+J : EMP+J → EMS+J
Starget = SS+J
(
Ttarget = Tsource,
Jtarget = Jsource
)
(5.46)
EMIFP+B→S+B : EMP+B → EMS+B
Starget = SS+B
⎛
⎝ Ttarget = Tsource,Jtarget = Jsource,
dtarget = dsource
⎞
⎠ (5.47)
In each of the three transformations, the parameters of source and target
model are identical, so also the upper bound arrival function and the minimum
distance of the transformation’s source and target model are identical. This
clearly fulfills Equations 5.11 and 5.13. Only the lower bound event arrival
functions η−(∆t) [upper-bound distance functions δ+(n)] differ, since these
are implicitly zero [infinity] for the sporadic target model. But Equations 5.12
and 5.14 are fulfilled, so the interfaces provide valid transformations.
The fact that they are lossy is easily seen in Figure 5.7, and can by mathe-
matically checked using Equation 5.31.
5.6.2 Sporadic with Jitter → Strictly Sporadic
There are two more lossy atomic interfaces. The first one, shown in Fig-
ure 5.8, transforms sporadic events with jitter into the model of strictly spo-
radic events. Because of the systematic model structure, we can re-use much
94 Event Model Interfaces
5
0
1
2
3
4
Ș(ǻt)
ǻt
ST
t'
JS
JS

'
T
Jt
critical
points
loss of
accuracy
JSJS   JT
JSJS   JT2
JSJS   JT3
Figure 5.8. η(∆t) Curves of EMIFS+J→S
of the work from the introductory example, where we transformed a periodic
stream with jitter into a sporadic stream:
EMIFS+J→S : {SS+J(T, J) ∈ EMS+J|J < T} → EMS
Starget = SS(Ttarget = Tsource − Jsource) (5.48)
We can directly re-use the relatively complex proofs of the η+- and δ−-
conditions from Sections 5.3.2.4 and 5.3.2.2. The remaining proofs are trivial:
η−S+J(∆t) = 0 ≥ 0 = η−S (∆t)
q.e.d. (5.49)
δ+S+J(n) =∞ ≤ ∞ = δ+S (n)
q.e.d. (5.50)
All four compatibility conditions from Section 5.3 are fulfilled.
5.6.3 Sporadic with Burst → Strictly Sporadic
Figure 5.9 shows the η curves of this transformation which is relatively
straight-forward. The sought-after parameter of the sporadic model (the spo-
radic period TS) represents a minimum inter-arrival time. In the model of
bursty events, this is directly given by the minimum distance dS+B, but essen-
Composite Event Model Interfaces 95
5
0
1
2
3
4
Ș(ǻt)
critical
points
loss of
accuracy
BSS 
' '
d
t
T
t
BS
BS

'
T
Jt
BSd
BSd2
BSd3
BSd4
Figure 5.9. η(∆t) Curves of EMIFS+B→S
tially must be larger than zero to avoid infinite event frequencies:
EMIFS+B→S : {SS+B(T, J, d) ∈ EMS+J|d > 0} → EMS
Starget = SS(Ttarget = dsource) (5.51)
Without formal proofs, we can easily see in Figure 5.9 that the target model
just captures the transient frequency during bursts to fulfill the η+ condition in
the critical points. When the burst region is over, the target curve is above the
source curve and both curves diverge. Hence, the transformation is lossy.
All lossy interfaces share a key property. They transform a more detailed
and sometimes more constrained source stream into a more general target
model. This comes at the cost of lost accuracy. While the transformations
from periodic models into their sporadic counterparts preserve the details of
the upper-bound arrival functions η+ (and the minimum distance δ−), the
lower-bound arrival functions η− were –very simplifying– set to zero. In ef-
fect, the maximum system load remains constant, the transformation just adds
non-determinism to the model. In contrast, the other two mentioned trans-
formations reduce only accuracy in the upper-bound arrival function (and the
minimum distance function). This results in higher average frequencies and
hence higher system load an analysis must assume. We have already identified
this phenomenon as a modeling insufficiency in Section 4.4.3.
96 Event Model Interfaces
strictly
periodic
periodic
w/ jitter
periodic
w/ burst
strictly
sporadic
sporadic
w/ jitter
sporadic
w/ burst
Figure 5.10. Existing Composite Event Model Interfaces
5.7 Composite Event Model Interfaces
The atomic event model interfaces introduced thus far can be concatenated
to compose a number of additional lossless and lossy interfaces. Mathemati-
cally, the transformation functions are composed:
Starget = EMIF source→target (Ssource)
= (EMIF intermediate→target ◦ EMIF source→intermediate)︸ ︷︷ ︸
function composition
(Ssource)
= EMIF intermediate→target(EMIF source→intermediate (Ssource)︸ ︷︷ ︸
Sintermediate
)
= EMIF intermediate→target (Sintermediate)
(5.52)
Figure 5.10 gives an overview of the existing composite interfaces, which
are summarized briefly in the following paragraphs.
5.7.1 Strictly Periodic → Periodic with Burst
This transformation can be composed of the transformation from strictly
periodic into periodic with jitter (see Equation 5.36), and the transformation
Composite Event Model Interfaces 97
from periodic with jitter into periodic with burst (see Equation 5.38):
EMIFP→P+B : EMP → EMP+B
EMIFP→P+B = EMIFP+J→P+B ◦ EMIFP→P+J
Starget = SP+B
⎛
⎝ Ttarget = Tsource,Jtarget = 0,
dtarget = Tsource
⎞
⎠ (5.53)
5.7.2 Strictly Sporadic → Sporadic with Burst
EMIFS→S+B : EMS → EMS+B
EMIFS→S+B = EMIFS+J→S+B ◦ EMIFS→S+J
Starget = SP+B
⎛
⎝ Ttarget = Tsource,Jtarget = 0,
dtarget = Tsource
⎞
⎠ (5.54)
Equation 5.54 shows the sporadic counterpart of the previous composition in
the periodic domain. The resulting interface is, of course, lossless, too. There
are no other lossless interfaces.
5.7.3 Strictly Periodic → Sporadic with Jitter
This transformation can be achieved as a two-step composition in two ways,
each possibility represents a different path from the source to the target model.
The two possible paths are illustrated in Figure 5.11. One possibility has a pe-
riodic stream with jitter as an intermediate model, the other one first transforms
the source stream into the model of strictly sporadic events:
EMIFP→S+J : EMP → EMS+J
EMIFP→S+J = EMIFP+J→S+J ◦ EMIFP→P+J
= EMIFS→S+J ◦ EMIFP→S
Starget = SS+J(Ttarget = Tsource, Jtarget = 0) (5.55)
It is not really surprising that both possibilities yield the same composed
interface. In Section 4.7, we mentioned the orthogonality of the two axes. The
horizontal axis where the jitter increases and finally leads to transient bursts,
and the vertical axis with its transformation from periodic into sporadic mod-
els. Both of the non-atomic transformations above are composed of atomic
ones from both of these axes. The concept of jitter has been added, and a
transformation from periodic to sporadic has been made. The transformation
order independency just underlines the observed orthogonality.
Furthermore, it is obvious that the composed transformation is lossy since
both include the lossy transformation from periodic into sporadic. In general,
98 Event Model Interfaces
strictly
periodic
periodic
w/ jitter
periodic
w/ burst
strictly
sporadic
sporadic
w/ jitter
sporadic
w/ burst
1
2
Figure 5.11. Two Paths from Strictly Periodic to Sporadic with Jitter
a composite transformation is lossy if at least one of its atomic transformations
is lossy.
5.7.4 Strictly Periodic → Sporadic with Burst
In this case we have two atomic transformations on the horizontal axis and
one on the vertical axis. Again, the result is independent of the order in which
the corresponding atomic transformations are applied:
EMIFP→S+B : EMP → EMS+B
EMIFP→S+B = EMIFP+B→S+B ◦ EMIFP+J→P+B ◦ EMIFP→P+J
= EMIFS+J→S+B ◦ EMIFP+J→S+J ◦ EMIFP→P+J
= EMIFS+J→S+B ◦ EMIFS→S+J ◦ EMIFP→S
Starget = SS+B(Ttarget = Tsource, Jtarget = 0, dtarget = Tsource)
(5.56)
5.7.5 Periodic with Jitter → Strictly Sporadic
This is our initial example for which only one possible composition exists.
We first transform the periodic stream with jitter into the model of sporadic
events with jitter (see Sec. 5.6.1), and then further into the model of strictly
sporadic events (see Sec. 5.6.2). This concatenation can be mathematically
expressed by:
EMIFP+J→S : {SP+J(T, J) ∈ EMP+J|J < T} → EMS
EMIFP+J→S = EMIFS+J→S ◦ EMIFP+J→S+J
Starget = SS(Ttarget = Tsource − Jsource)
Including Sporadically Periodic Events 99
5.7.6 Periodic with Jitter → Sporadic with Burst
On both possible paths, one via periodic with burst and another via sporadic
with jitter, the resulting composite EMIF is:
EMIFP+J→S+B : EMP+J → EMS+B
EMIFP+J→S+B = EMIFP+B→S+B ◦ EMIFP+J→P+B
= EMIFS+J→S+B ◦ EMIFP+J→S+J
Starget = SS+J
⎛
⎝ Ttarget = Tsource,Jtarget = Jsource,
dtarget = max(0, Tsource − Jsource)
⎞
⎠ (5.57)
5.7.7 Periodic with Burst → Strictly Sporadic
The only possible path is through sporadic with burst:
EMIFP+B→S : {SP+B(T, J, d) ∈ EMP+B|d > 0} → EMS
EMIFP+B→S = EMIFS+B→S ◦ EMIFP+B→S+B
Starget = SS(Ttarget = dsource) (5.58)
5.7.8 Periodic with Burst → Sporadic with Jitter
This interface is obtained by concatenating the interfaces EMIFP+B→S+B,
EMIFS+B→S, and EMIFS→S+J:
EMIFP+B→S+J : EMP+B → EMS+J
EMIFP+B→S+J = EMIFS→S+J ◦ EMIFS+B→S ◦ EMIFP+B→S+B
Starget = SS+J(Ttarget = Tsource, Jtarget = Jsource) (5.59)
5.7.9 Sporadic with Burst → Sporadic with Jitter
Here, two atomic interfaces are required:
EMIFS+B→S+J : EMS+B → EMS+J
EMIFS+B→S+J = EMIFS→S+J ◦ EMIFS+B→S
Starget = SS+J(Ttarget = Tsource, Jtarget = Jsource) (5.60)
5.8 Including Sporadically Periodic Events
After presenting event model interfaces for all possibly transformations with-
in the six-class model set, we will now show how the model of sporadically pe-
riodic events, as defined by Audsley and Tindell [4, 121], can be transformed
into this six-class model, and vice versa. We have explicitly excluded their
model from the six-class model because of its inability to efficiently handle
jitter as a key influence of scheduling and execution which we mentioned in
100 Event Model Interfaces
0
ǻt
3
5
7
1
2
6
Ș(ǻt)
O
T
t
b
B
B
'
9
10
critical point
critical point
loss of
accuracy
BSB 
' '
d
t
T
t
I
I
Tb BB )1( 
I
TB
4b  B
O
TB
Bb2
A
C
B
BS
BS

'
T
Jt
Figure 5.12. η(∆t) Curves of EMIFB→S+B
Section 4.2.3. But despite its weaknesses in capturing outputs, the model has
proven very valuable for specific input descriptions.
To no surprise, the model of sporadically periodic events shares key con-
cepts with the newly introduced model of sporadic events with burst. Even
though both models are based on fundamentally different observations, they
describe a generally periodic event stream as an upper bound for long-term ob-
servations, and additionally bound the maximum transient event frequencies.
So, both have a certain notion of bursts. In order to avoid confusion when deal-
ing with these two models, we will refer to the model of sporadically periodic
events as “Tindell’s burst model”, indicated by the index B.
In the following sections, we concentrate on transformations between these
two models. More interfaces can be obtained using the idea of interface com-
position (see Section 5.7) and are not explicitly mentioned further.
5.8.1 Tindell’s Burst → Sporadic with Burst
Figure 5.12 illustrates the η(∆t) curves of this transformation. The η− con-
dition is trivially met because of the sporadic nature of both models. To meet
also the η+ condition, we have to derive the period TS+B, the jitter JS+B, and
the minimum distance dS+B for the model of sporadic events with burst. The
three straight lines labeled A, B, and C represent three continuous η˜+ functions
Including Sporadically Periodic Events 101
that help in finding the interface. Line A captures the timing behavior of both
curves during the initial burst, line B represents the long-term behavior of the
sporadic model with bursts, and line C captures the repetition rate of “Tindell
bursts”.
For small ∆ts, the minimum inter-arrival time dominates the worst-case
event arrival of η+(∆t). Line A in Figure 5.12 illustrates that both η+ curves
are identical. It is relatively obvious that the minimum distance dS+B of the
target model is exactly the inner period T IB of Tindell’s burst model:
dS+B = T IB (5.61)
In order to find the other parameters, we concentrate on two critical points in
the curves of Figure 5.12. The left-most critical point at
∆tcrit,1 = (bB − 1)T IB (5.62)
captures the end of the first “Tindell burst”. In the example, the burst length
equals four (b = 4). The second critical point marks the end of the second
Tindell burst, and other critical points appear at the end of each burst, but they
are not shown. We need to choose the period and the jitter of the sporadic
event stream with bursts such that all critical points of Tindell’s burst model
are covered.
Apparently, this is guaranteed when lines B and C are parallel, and line A
meets line B at ∆tcrit,1, given by Equation 5.62. We start by deriving the period
TS+B, which equals the average maximum frequency of the events in Tindell’s
burst model:
TS+B =
TOB
bB
(5.63)
Now, we can derive the remaining jitter parameter that determines the horizon-
tal displacement of line B with respect to line C. We known that lines A and B
must meet at ∆tcrit,1 = (bB − 1)T IB . At that point, the η+(∆t) functions that
describe the lines must be equal. We resolve the equation to obtain the jitter
parameter:
η+B (∆tcrit,1) = η
+
S+B(∆tcrit,1)
⇔ η+B ((bB − 1)T IB) = η+S+B((bB − 1)T IB)
⇔ (bB − 1)T IB + JS+B = (bB − 1)TS+B |Equation 5.63
⇔ JS+B = (1− 1bB )TOB − (bB − 1)T IB (5.64)
102 Event Model Interfaces
0
ǻt
Bb
BSB 
' '
d
t
T
t
I
BS
BS

'
T
Jt
OT
t
b
B
B
'
Ș(ǻt)
OTB
OTB2
OTB3
Bb3
Bb2
av
era
ge
pe
rio
d
BS J
B
A
C
Figure 5.13. An Abstract View of the Curves of EMIFB→S+B
We finally combine Equations 5.61, 5.63, and 5.64 to obtain the event model
interface:
EMIFB→S+B : EMB → EMS+B
Starget = SS+B
⎛
⎜⎝ Ttarget =
TOsource
bsource
,
Jtarget = (1− 1bsource )TOsource − (bsource − 1)T Isource,
dtarget = T Isource
⎞
⎟⎠
(5.65)
This transformation from Tindell’s burst model into the new model of spo-
radic events with burst (B → S+B) is lossy. This can be easily seen in Fig-
ure 5.12. But this kind of lossiness is quite different from the other lossy
transformations within the six-class models. Those transformation could in
fact very tightly capture the stream behavior form small ∆t but suffered an
increasing inaccuracy with increasing ∆t, either or the η− side, as for the
transition from periodic into sporadic (see Section 5.6.1), or in the η+ side,
as for the transformation from sporadic with burst into strictly sporadic (see
Section 5.6.3).
The interface EMIFB→S+B has, interestingly, a bounded long-term accu-
racy loss. In some points in time, specifically all critical points which we have
Including Sporadically Periodic Events 103
5
0
1
2
3
Ș(ǻt)
BS
BS

'
T
Jt
BSd
BSd2
BSd3
B
6
BSS 
 
d
t
T
t
I
ƩƩ
A
7
9
C
O
TB
critical point
critical
point
loss of
accuracy
4b  B
Bb2
ǻt
O
TB2
O
T
t
b
B
B
'
Figure 5.14. η(∆t) Curves of EMIFS+B→B
mentioned to reappear at the end of every Tindell burst, the functions have
even identical values. Figure 5.13 provides a more abstract view on the contin-
uous η˜ functions of this transformation. We can see that the sawtooth shaped
curve of the source stream regularly meets the linear jitter curve of the target
stream. This bounded accuracy loss shows that the newly introduced model
of sporadic events with burst is not overly inaccurate when capturing Tindell’s
burst model.
5.8.2 Sporadic with Burst → Tindell’s Burst
Figure 5.14 illustrates the details of the transformation from the model of
sporadic events with burst into Tindell’s burst model. One parameter, the inner
period T IB of Tindell’s burst model, is found quite trivial; it equals the minimum
distance dS+B of the sporadic event model with burst:
T IB = dS+B (5.66)
This guarantees that the maximum transient frequencies are bounded, illus-
trated by line A in the figure.
The derivation of the other two parameters, the burst length bB and the outer
period TOB , is considerably more complex. Figure 5.14 highlights two critical
points. The first one is determined by the end of the burst of the sporadic stream
104 Event Model Interfaces
with burst, or the time where the transient burst turns into a periodic stream
with a large jitter. We have thoroughly discussed such behavior in Section 4.3.
According to Equation 4.15, this happens at time ∆tcrit,1:
∆tcrit,1 =
JS+B dS+B
TS+B − dS+B
(5.67)
It is quite clear that the burst of the target stream must cover this source
burst. In other words, the sought-after burst length of the target bB must not be
smaller than the number of events at the aforementioned point in time ∆tcrit,1.
This way, we can formulate a lower bound for bB:
bB ≥ η+S+B(∆tcrit,1)
bB ≥ η+S+B
(
JS+B dS+B
TS+B − dS+B
)
bB ≥
⌈
JS+B
TS+B − dS+B
⌉
(5.68)
The second critical point in Figure 5.14 captures the beginning of the second
Tindell burst in the target stream, at ∆tcrit,2. At this time, the η+ functions of
both source and target streams increase from bB to bB + 1. In other words,
∆tcrit,2 equals the minimum distance between bB + 1 events in both streams:
∆tcrit,2 = δ−S+B(bB + 1)
!= δ−B (bB + 1) (5.69)
We apply the minimum event distance functions δ−(n) to obtain the outer
period TOB :
δ−B (bB + 1) = δ
−
S+B(bB + 1)
TOB = ((bB + 1)− 1)TS+B − JS+B
= bBTS+B − JS+B (5.70)
Although this equation provides a linear relation between the two remaining
parameters bB and TOB , neither of the values can be explicitly determined. We
known only a lower bound for Tindell’s burst length parameter bB, given by
Equation 5.68. As other information is not available, there is a certain amount
of freedom how the interface can be parameterized. We can choose any burst
length bB that fulfills Equation 5.68, and the outer period TOB is then obtained
from the linear relation given by Equation 5.70. With respect to the curve
representation, that means that we can choose the second critical point to be
anywhere on the η+ curve of the source stream (line B).
We illustrate this by a qualitative comparison between four different param-
eter sets. Figure 5.15 shows the η curves of four different EMIFS+B→B. All
Including Sporadically Periodic Events 105
0
ǻt
OT
t
b
1,
1,
B
B
'
BS
BS

'
T
Jt
Ș(ǻt)
13b
BSB 
' '
d
t
T
t
I
1,
1,Bb
1,2 Bb
1,BT
1,2 BT 1,3 BT
B
A
C
(a) Medium Burst Length
0
ǻt
Ș(ǻt)
! 1,1,1, ,, BBB bTT
IO
BA
C
OT
t
b
2,
2,
B
B
'
BSB 
' '
d
t
T
t
I
2,
2,Bb
2,BT 2,2 BT 2,3 BT
2,2 Bb
2,3 Bb
BS
BS

'
T
Jt
(b) Smaller Burst, Higher Load
0
ǻt
BS
BS

'
T
Jt
Ș(ǻt)
! 1,1,1, ,, BBB bTT
IO
A
C
OT
t
b
3,
3,
B
B
'
BSB 
' '
d
t
T
t
I
3,
3,Bb
3,BT
! 2,2,2, ,, BBB bTT
IO3,2 Bb
B
(c) Larger Burst, Reduced Load
0
ǻt
BS
BS

'
T
JtȘ(ǻt)
OT
t
b
2,
2,
B
B
'
BSB 
' '
d
t
T
t
I
2,
A
C
fo2,Bb
fo2,BT
B
(d) Infinite Burst, Minimum Load
Figure 5.15. Comparison of Four EMIFS+B→B Choices
interfaces share the same source stream but they differ in their specific values
for bB and TOB . We see that, in contrast to the transformation in the opposite
direction, the accuracy loss generally increases with increasing ∆t for all four
curves. Depending on the chosen interface parameters bB and TOB , the accuracy
loss, however, can have considerably different characteristics.
Figure 5.15(a) shows a reference interface with an arbitrary (but valid) choice
of bB and TOB . Figure 5.15(b) has a smaller burst length bB. In effect, the ac-
curacy loss between the two critical points in the figure is less compared to
the first interface in Figure 5.15(a). However, this optimization for small ∆t
comes at the cost of larger accuracy loss for larger ∆t beyond the second crit-
ical point. Basically, a small burst length results in a small outer period, rep-
106 Event Model Interfaces
resenting a higher long-term load. The gray curve represents the η+ function
from the reference example and allows a direct comparison.
An example with a larger burst length is shown in Figure 5.15(c). Again, we
have included the curves of the two previous examples as gray curves to allow
quick comparison. We see that the larger burst length bB leads to an increasing
transient accuracy loss for small ∆t (between the two critical points). On the
other hand, the long-term loss is reduced. Figure 5.15(c) finally contains a
rather theoretical but interesting paradoxical case. The average load is reduced
to a minimum, the curves B and C are parallel. To achieve this, we would
need to set the burst length to infinity, which basically contradicts the initial
objective of load reduction.
We see that, while each realistic interface is “better” than others for specific
regions of ∆t, none will be optimal over all others for all ∆ts. On the contrary,
an infinite set of Pareto-optimal interfaces exist. For a given source stream
Ssource, two Pareto-optimal interfaces have target streams Starget,1 and Starget,2,
which do not fully contain each other:
SC(Starget,1,Starget,2) = 0(false) ∧ SC(Starget,2,Starget,1) = 0(false) (5.71)
This enables a trade-off between short-term transient accuracy loss versus long-
term average loss. The actual choice could possibly be influenced by other,
external objectives such as a schedule length (which would bound the “inter-
esting” regions for ∆t) or a latency constraint, and are not considered further
here.
5.9 Summary
We have introduced a set of definitions to formally capture the event stream
interfacing problem in the presence of multiple different event streams with dif-
ferent characteristics. The curve representation of the characteristic functions
of event streams provide a very comprehensible illustration of the interfacing
step. Several tests enable us to check if a given source stream can be trans-
formed to meet a specific target requirement, and if this transformation can
be performed without accuracy loss. The availability of parameterized models
allows an efficient, formal interfacing procedure. The event stream coverage
test, however, does not essentially require parameterized models, it also ap-
plies to situations in which only the event curves are known. Consequently, it
is generally possible to capture any event stream with our six-class model set,
as long as the stream is (or can be) described as a upper- and lower-bound event
curves, including the numerical curves from Thiele’s work [116] and Gresser’s
event vectors [39].
We have derived eighteen event model interfaces within the six-class model.
When we also consider the six situations of identical source and target mod-
els, where no transformation is actually required, we can now solve two thirds
Summary 107
strictly
periodic
periodic
w/ jitter
periodic
w/ burst
strictly
sporadic
sporadic
w/ jitter
sporadic
w/ burst
sporadically
periodic
Figure 5.16. All Existing Event Model Interfaces
(24 out of 36) of the theoretically possible event model combinations. Some
of these interfaces impose specific restrictions to the source stream parame-
ters. For instance, the minimum event distance must be larger than zero when
transforming an event stream with burst into a strictly sporadic stream.
Finally, we have presented transformations between the model of sporadic
events with burst and Tindell’s burst model in both directions. This also shows
that event model interfacing is not limited to the newly introduced six-class
model set, and that it is generally possibly to include other event models in
this interfacing procedure, with totally different parameters. All introduced in-
terfaces are illustrated in Figure 5.16. Solid lines represent lossless interfaces,
while dotted lines illustrate lossy ones.

Chapter 6
EVENT ADAPTATION FUNCTIONS
In the previous chapter, we introduced the concept of event model interfaces
to transform event streams given in one event model, into another event model.
These interfaces represent mathematical model transformations. We defined a
set of compatibility tests that these transformations must fulfill, and derived the
transformations for a set of event model combinations. We could see that there
are, however, situations for which no plain event model interface exist. These
are those situations, which fail the requirement coverage test of Definition 5.4.
This chapter introduces Event Adaptation Functions (EAF) that change the
event stream timing of a given source stream such that the target requirement
can be met. In contrast to event model interfaces that are introduced for mod-
eling and analysis purposes, adaptation functions represent additional design
elements, usually buffers and timers, that must be implemented.
An introductory example first illustrates the problem and allows us to for-
mally define the adaptation problem. Then, we derive adaptation functions for
those model combinations, for which a plain EMIF does not exist. We will
see that traffic shaping that is known from network design [27] can be used to
modify the timing of events to comply with given constraints. We distinguish
between periodic shaping and sporadic shaping. Finally, we investigate the
properties of polling and its influence on input and output event streams .
6.1 Introductory Example
Recall the example of Figure 5.1. A producer task T1 outputs an event
stream that does not meet the input requirement of the receiver task T4. The
sender produces a periodic event stream with jitter (see Equation 5.4):
S1,out = SP+J(T1, J1) ∈ EMP+J
110 Event Adaptation Functions
T1 T4
S1,out=SP+J(T1,J1) R4,in={SP}=EMP
?
Figure 6.1. Introductory Example
But in contrast to the example from the previous chapter, the receiver task
T4 now requires strictly periodic input events:
R4,in = EMP (6.1)
The problem formulation is illustrated in Figure 6.1. Again, the models are
incompatible:
S1,out = SP+J(T1, J1) /∈ R4,in = EMP (6.2)
This time, the requirement coverage test from Definition 5.4 fails:
RC(Ssource,R4,in) = 0(false) (6.3)
We can easily prove this by showing that one of the conditions (Equations 5.11
to 5.14) is false. But before that we need to make a few assumptions. It is ob-
vious that, if an event model interface exists, the transformations target stream
would have the same period as the source stream:
Starget = S4,in = SP(T1,out) (6.4)
We now choose η+(∆t) and claim that the η+ condition of Equation 5.11 is
not fulfilled:
J1 > 0 |+∆t
⇔ ∆t + J1 > ∆t | 1T1 , T1 > 0
⇔ ∆t+J1T1 > ∆tT1
⇔ ∆t+J1T1 ≤ ∆tT1
⇔ η+source(∆t) ≤ η+source(∆t)
q.e.d.
(6.5)
This is sufficient to show that no plain event model interface exists. In other
words, an event stream parameter transformation that resolves this situation
does not exist, and we need another approach. Basically, a jitter can be seen
as distortion that has been (accidentally) added to a initially periodic stream
and must be eliminated now. Jitter elimination is commonly performed by
re-synchronizing the stream to its original period.
Periodic Synchronization 111
T1 T4
S1,out=SP+J(T1,J1) R4,in={SP}=EMP
SEAF,out=SP(T1)REAF,in={SP+J}=EMP+J
EAF
Figure 6.2. Application of Event Adaptation Functions EAF
6.2 Periodic Synchronization
Traffic shaping uses buffering and time-triggering and delays events in order
to generate some specific communication timing characteristics. All incoming
events are temporarily stored for a certain amount of time to obtain the required
output characteristics. Figure 6.2 shows the example with an additional FIFO
buffer between the two known application tasks. This shaper accepts any peri-
odic stream with jitter at its input, and the output stream of task T1 meets this
requirement:
S1,out = SP+J(T1, J1) ∈ REAF ,in = EMP+J (6.6)
At its output, the shaper produces a periodic stream with the input stream’s
original period (see Equation 6.4), thereby fulfilling the input requirement of
user task T4:
SEAF ,out = SP(T1) ∈ R4,in = EMP (6.7)
6.2.1 Shaper Implementation
Shaping requires appropriate buffer memory and some means to control the
timing. A shaper can be implemented on the same resource as the sending or
the receiving task. The local memory that is usually connected to the CPU
can be used to temporarily store the (data) events. Often, a CPU has periph-
eral timer units connected or on-chip (micro-controller) that can be used for
controlling the output timing. This way, the shaper becomes (part of) the com-
munication driver of the run-time system. A shaper can also be implemented as
a dedicated system function using additional design elements such as a small
micro-controller or a dedicated HW block in an ASIC with a small memory and
a timer. This thesis is not intended to theorize about the actual implementation
but focuses on the properties of shapers and their implementation-independent
impact on the system-level scheduling and analysis task. In this context, we
need to consider that periodic shapers have their own internal timing and a lo-
cal buffer. We are interested in a) the required buffer size to dimension (and
112 Event Adaptation Functions
0
delay delaydelay
T1T1
T1 T1
t
EAF
buffer empty
buffer full
Ȣin
Ȣout
t0,in t0,out
Figure 6.3. Buffering of Strictly Periodic Events
optimize) system memory, and b) the buffering delay which adds to path laten-
cies and contributes to the system timing properties.
6.2.2 Shaper Properties
We start with applying periodic shaping to a periodic stream with a zero
jitter, i. e. to a strictly periodic stream. In this case, the output of T1 could
potentially be EMIF-transformed into a strictly periodic stream (see Sec-
tion 5.5.5) that meets the input requirement of T4. But a shaper between both
tasks considerably changes the situation.
We mentioned that a shaper is usually implemented with its own internal
timer which might not be synchronized with either the senders or the receivers
input-output timing. This makes the situation more complex than in case of a
plain EMIF .
Figure 6.3 illustrates a strictly periodic shaping scenario. Two event se-
quences are shown. The sequence ςin presents the input to the shaper coming
from T1, and the shapers output ςout becomes the new input of task T4. Both
sequences are identical except a constant non-zero phase difference, or offset
difference t0,out − t0,in. This phase delay exists because of unsynchronized
timers.
A buffer of size one seems to be sufficient in the example. However, it is
limited to those situations, where the shaper starts outputting events after the
first event has been produced by task T1 (case 1). This must not necessarily
be the case, because –again– the two tasks are not temporally correlated. Fig-
ure 6.4 illustrates another situation (case 2), where the shaper outputs the first
event earlier than the sender (t0,out < t0,in). In this case, we need to pre-load
the buffer to avoid buffer underrun.
Periodic Synchronization 113
T1 T1T1
T1 T1T1
0
t
t0,int0,out
EAF
buffer empty
buffer full
Ȣin
Ȣout
delay delaydelay
Figure 6.4. Avoiding Buffer Underrun by Pre-loaded Buffer
6.2.3 The Conservative Approach
We see that the two cases require a different buffer set-up. If we know in
advance which the system behavior will be, we use the corresponding set-up
for the buffer. However, in most cases, it is not clear which task –sender or
shaper– will be earlier than the other, so we need to conservatively set up the
buffer to guarantee correct behavior in both cases 1 and 2. Hence, we will need
one pre-loaded (data) event to avoid buffer underrun, and another free buffer
to avoid overflow. That means the buffer must be able to store two events.
This has consequences for the minimum and maximum delay in case 1
(early input). Compared to the scenario in Figure 6.3, the initial pre-loaded
event results in an additional delay of exactly one period, illustrated in Fig-
ure 6.5. Similarly, the buffer of size two represents an over-dimensioning in
case 2 (early output). Although it does not affect the event timing, 50 percent
of the buffer memory seems wasted. Figure 6.6 shows a scenario where the
second buffer is never used.
Such seemingly unnecessary over-dimensioning is not an artificial result
from the proposed shaping approach. Rather, the conservative approach is the
only solution in practice and cannot be optimized in situations, when no spe-
cific information about the exact requirements of the communication, i. e. a
timer synchronization, is available. And this is very often the case when sub-
systems are integrated without considering all side effects in detail. In other
cases, the amount of pre-loaded data in a FIFO buffer might be constrained
by the application. Signal processing applications, for instance, use buffer
pre-load to implement specific functional details such as recursive filter func-
tions of a certain degree [68], based on the theory of synchronous data-flow
(SDF) [67].
114 Event Adaptation Functions
0
T1 T1T1
T1 T1T1
t
delay0
EAF
one event
buffer full
delay delaydelay
Ȣin
Ȣout
t0,in t0,out
Figure 6.5. Additional Delay
buffer empty
one event
T1 T1T1
T1 T1T1
0
t
Ȣin
Ȣout
delay delaydelay
t0,int0,out
delay0
EAF
Figure 6.6. Over-dimensioning of Buffer Size
In all situations, the conservative design avoids subtle design pitfalls, since
accidentally disregarding either case 1 or 2 could potentially result in memory
over- or underflow and/or an unexpected temporal (and possibly functional)
behavior.
6.2.4 Corner-Case Analysis
In the previous chapter, we have seen that the characteristic curves provide
an excellent starting point for formal considerations of event model interfacing.
The curves also help in formalizing the idea and challenges of event adapta-
tion, because they are well suited to illustrate the properties of the corner-case
scenarios 1 and 2.
We start with case 2, where event input was assumed late and output early.
Figure 6.7 shows the corner-case event curves: the as-late-as-possible shapers
Periodic Synchronization 115
T 2T 3T 4T0
Ș(ǻt)
1
2
3
4
5
ǻt
»
¼
»
«
¬
«' '
1
inEAF, )(
T
t
tK
event time-travel
»
»
º
«
«
ª' '
1
out,EAF )(
T
t
tK
Figure 6.7. Event Input and Output Curves of Buffer Underrun Situation
input curve, given by the lower-bound event arrival function
η−EAF ,in(∆t) =
⌊
∆t
T1
⌋
,
and the as-early-as-possible shaper output curve, given by
η+EAF ,out(∆t) =
⌈
∆t
T1
⌉
.
This curve representation reveals exactly the aforementioned problem of buffer
underrun. We see that the output curve η+EAF ,out(∆t) is (except for integer mul-
tiples of the period) above the input curves, i. e. there are more events outputted
than arrived. The arrows in Figure 6.7 illustrate that the events would need to
time-travel, an apparently impossible solution.
6.2.4.1 Avoiding Buﬀer Underrun
The pre-loaded events move the curve up. We therefore introduce the notion
of available events, which are the input events plus the pre-loaded ones:
ηEAF ,av(∆t) = ηEAF ,in(∆t) + 1 (6.8)
116 Event Adaptation Functions
preload
T 2T 3T 4T0
Ș(ǻt)
1
2
3
4
5
ǻt
,
eventpreloaded
in,av, 1)()(  
 tt ƩƩ
EAFEAF
KK
»
»
º
«
«
ª
 
1
out, )(
T
t
t
ƩƩ
EAF
K
Figure 6.8. Case 2: Event Availability and Output Curves
Now, we must make sure that there are always enough events available for
being outputted to prevent buffer underrun. This can be easily proven:{
0 if ∆tT1 ∈ N
1 otherwise
}
=
⌈
∆t
T1
⌉
−
⌊
∆t
T1
⌋
⇒ 1 ≥
⌈
∆t
T1
⌉
−
⌊
∆t
T1
⌋
|+
⌊
∆t
T1
⌋
⇔
⌊
∆t
T1
⌋
+ 1 ≥
⌈
∆t
T1
⌉
⇔ η−EAF ,in(∆t) + 1 ≥ η+EAF ,out(∆t)
⇔ η−EAF ,av(∆t) ≥ η+EAF ,out(∆t)
q.e.d.
Figure 6.8 shows the corresponding curves, which are identical except for
integer multiples of the period. The lower-bound availability function η−EAF ,av
is right-continuous, while the upper-bound output function η+EAF ,out is left-
continuous at these points; more a mathematical detail than a useful property
in practice. In this situation, all events experience a zero buffering delay, and
the buffer does just not underrun.
6.2.4.2 Avoiding Buﬀer Overﬂow
In case 1, the input events arrive before the corresponding output events.
The worst-case event curves for this scenario are: the as-soon-as-possible
Periodic Synchronization 117
T 2T 3T 4T0
Ș(ǻt)
1
2
3
4
5
ǻt
delay
»
¼
»
«
¬
«
 
1
out, )(
T
t
t
ƩƩ
EAF
K
,
eventpreloaded
1
av, 1)( »
»
º
«
«
ª
 
T
t
t
ƩƩ
EAF
K
backlogpreload
Figure 6.9. Case 1: Event Availability and Output Curves
event input curve and the as-late-as-possible event output curve. Figure 6.9
shows both curves. We are looking for the maximum required buffer size and
the maximum delay. The two arrows between the curves directly provide the
sought-after information. The horizontal distance between the curves captures
the relative time between the arrival and release of a buffered event, and hence
represents the input-output delay of the EAF . And the vertical distance pro-
vides the difference between the number of events arrived and released within
a given period of time ∆t, and hence the number of events stored in the buffer
over ∆t.
6.2.5 Formal Shaper Analysis
Cruz formalized this idea as network calculus [27]. He applied the approach
to the horizontal and vertical distances between continuous network traffic ar-
rival curves and network node service curves to obtain the servicing delay and
the buffering backlog. Later, Boudec [15] and Thiele et. al. [116] used corre-
sponding methods to analyze scheduling. According to Cruz [27], the backlog
can be calculated by:
backlogEAF = sup
∆t>0
{ηEAF ,av(∆t)− ηEAF ,out(∆t)} (6.9)
118 Event Adaptation Functions
Calculating the delay is usually more complex. Cruz [27] provided no cal-
culations but only a general set property:
delayEAF = sup
∆t>0
{
inf
τ>0
{
ηEAF ,in(∆t) ≤ ηEAF ,out(∆t + τ)
}} (6.10)
Both properties depend on the characteristic functions η(∆t) and δ(n) of the
involved curves. And since these functions return intervals with a lower and
an upper bound, the backlog and delay calculation must consider this, i. e. we
will also determine minimum and maximum values, requiring to carefully con-
sider minimum and maximum values inside the sup and inf functions, or their
discrete versions min and max, respectively.
6.2.5.1 Buﬀering Backlog
The maximum backlog captures the number of events that wait for being
actually outputted to the consumer task T4. The maximum backlog thus repre-
sents the required shaper buffer size:
backlog+EAF = sup
∆t>0
{
η+EAF ,av(∆t)− η−EAF ,out(∆t)
}
= max
∆t>0
{⌈
∆t
T1
⌉
+ 1−
⌊
∆t
T1
⌋}
= 1 + max
∆t>0
{ ⌈
∆t
T1
⌉
−
⌊
∆t
T1
⌋
︸ ︷︷ ︸
=
8<
: 0 if
∆t
T1
∈ N
1 otherwise
}
= 1 + 1 = 2 (6.11)
The minimum backlog can be calculated in a similar fashion, only that we
are looking for infima [minima] instead of suprema [maxima]:
backlog−EAF = inf∆t>0
{
η−EAF ,av(∆t)− η+EAF ,out(∆t)
}
= min
∆t>0
{⌊
∆t
T1
⌋
+ 1−
⌈
∆t
T1
⌉}
= 1− max
∆t>0
{⌈
∆t
T1
⌉
−
⌊
∆t
T1
⌋}
= 1− 1 = 0 (6.12)
Both values backlog−EAF = 0 and backlog
+
EAF = 2 are unsurprising. The
minimum backlog corresponds to the minimum buffering requirements and
can be found in case 2. These should be zero, otherwise we would have over-
Periodic Synchronization 119
or under-dimensioned the system, mainly through a inappropriate number of
pre-loaded events in the buffer. The maximum buffer size of two is necessary
in case 1.
6.2.5.2 Buﬀering Delay
We mentioned that, for arbitrary curves and functions, the delay can not be
calculated in a straight-forward way (see Equation 6.10). The actual calcula-
tions depend heavily on the η functions. Fortunately, the use of standard event
models provides us with well-formed curves, and we can follow a constructive
approach. We create the inverse functions of η, and the sought-after delay cor-
responds to the vertical distance between the two inverse curves. The vertical
distance can be calculated straight-forwardly, as Equation 6.9 shows.
Let two functions Γ−(n) and Γ+(n) determine the minimum and maximum
time delay until the nth next event arrival for any possible point in time t.
These functions represent the inverse of the η functions, such that
η+(Γ−(n)) = n, and η−(Γ+(n)) = n.
With these functions, Equation 6.10 turns into:
delayEAF = sup
n>0
{ΓEAF ,out(n)− ΓEAF ,in(n)} (6.13)
The actual Γ functions can be derived as follows. Γ−(n), as the inverse of
η+(∆t) determines the shortest possible delay ∆t until the arrival of the nth
next event, measured from any possible point in time t. For the minimum delay,
we have to assume immediate event arrival at ∆t = 0, and the subsequent
events arrive as soon as possible. We start with the shortest delay until the 1st
event arrival, which apparently is zero:
Γ−(1) = 0.
For all other n > 1, we can use the δ− function that we introduced in Chapter 3.
This δ−(n) function determines the minimum distance between n successive
events. This is identical with the minimum delay until the nth next event ar-
rival. Again, we assume immediate arrival of the 1st next event. So, Γ−(n) is
given by
∀ n > 0 : Γ−(n) =
{
0 if n = 1
δ−(n) if n > 1 (6.14)
The observation that the first event just defines the beginning of the observation
interval ∆t helped in deriving the Γ− function. The opposite assumption lets
us define Γ+(n). Again, we have to assume that an event arrival defines the
beginning of the observation interval, but this time, we have to assume that this
event has just been missed and is not actually included. It rather appears as the
120 Event Adaptation Functions
0th event, and all other events arrive as late as possible. Hence, we are looking
for the maximum distance between n plus one (the 0th one) events:
∀ n > 0 : Γ+(n) = δ+(n + 1) (6.15)
The minimum and maximum distance of the shaper’s periodic output events
are known from Equation 3.13 in Chapter 3. It remains to determine the cor-
responding functions for the available events in the shaper buffer. We have
obtained the η function of the EAF output by moving the curve up by one
event. For the Γ, and subsequently the δ functions, this corresponds to moving
the curves to the right by one event:
∀ n > 0 : ΓEAF ,av(n) =
{
0 if n = 1
ΓEAF ,in(n− 1) if n > 1 (6.16)
The first event (n = 1) is immediately available (Γ = 0), since it is pre-loaded
into the buffer.
We can now determine the minimum and maximum delay of the buffer using
Equations 6.13, 6.14, 6.15, 6.16, and the characteristic δ function given by
Equation 3.13. We start with the maximum delay. Since the property “delay”
does not meaningfully apply to the pre-loaded event, we consider the distance
between the curves only for n > 1:
delay+EAF = sup
n>1
{
Γ+EAF ,out(n)− Γ−EAF ,av(n)
}
= max
n>1
{
Γ+EAF ,out(n)− Γ−EAF ,in(n− 1)
}
= max
(
Γ+EAF ,out(2)− 0,maxn>2
{
Γ+EAF ,out(n)− Γ−EAF ,in(n− 1)
})
= max
(
δ+EAF ,out(3),maxn>2
{
δ+EAF ,out(n + 1)− δ−EAF ,in(n− 1)
})
= max
(
2 T1,max
n>2
{nT1 − (n− 2)T1}
)
= max (2 T1, 2 T1)
= 2 T1 (6.17)
Periodic Shaping of Jitter and Burst 121
T1 2T1 3T1 4T10
Ș(ǻt)
1
2
3
4
5
ǻt
T1–J1 2T1–J1 3T1–J1 4T1–J1
delaybacklog
»
¼
»
«
¬
«
 
1
out, )(
T
t
t
ƩƩ
EAF
K
»
»
º
«
«
ª  
1
1
in, )(
T
Jt
t
ƩƩ
EAF
K
Figure 6.10. Synchronization of Jitter: Case 1 without Adaptation
We conclude this Section with the calculation of the minimum buffering
delay:
delay−EAF = infn>1
{
Γ−EAF ,out(n)− Γ+EAF ,av(n)
}
= min
n>1
{
Γ−EAF ,out(n)− Γ+EAF ,in(n− 1)
}
= min
n>1
{
δ−EAF ,out(n)− δ+EAF ,in(n)
}
= min
n>1
{(n− 1)T1 − (n− 1)T1}
= 0 (6.18)
We can find both minimum and maximum delay in the Figures 6.9 and 6.8.
6.3 Periodic Shaping of Jitter and Burst
Above, we have demonstrated and formally captured the influence of peri-
odic shaping applied to strictly periodic streams. If the shapers input stream
exhibits jitter (or burst), the situation is more complex. However, we can use
the same ideas to determine the backlog and the delay in both known corner
cases.
6.3.1 Small Jitters
We start with considering jitters less than periods. Figure 6.10 shows the
shapers input and output curves of case 1, where the input arrives early and is
122 Event Adaptation Functions
0
Ș(ǻt)
1
2
3
4
5
ǻt
event time-travel
»
»
º
«
«
ª
 
1
out, )(
T
t
t
ƩƩ
EAF
K
¸¸¹
·
¨¨©
§
»
¼
»
«
¬
«  
1
1
in, ,0min)(
T
Jt
t
ƩƩ
EAF
K
T1 2T1 3T1 4T1
T1+J1 2T1+J1 3T1+J1
Figure 6.11. Synchronization of Jitter: Case 2 without Adaptation
outputted late. We see that the maximum buffering delay is 2T1− (T1−J1) =
T1 + J1 and the required buffer size is two.
Case 2 with late input and early output is shown in Figure 6.11. Again, we
see that events would need to time-travel. In contrast to the case of strictly
periodic shaper input, the elimination of jitter requires two events, since the
2nd event is outputted even before the first one arrives at the shapers input.
Therefore, the event availability functions ηEAF ,av is:
ηEAF ,av(∆t) = ηEAF ,in(∆t) + 2 = η1,out(∆t) + 2
6.3.1.1 Buﬀering Backlog
We can now calculate the maximum and minimum backlog.
backlog+EAF = sup
∆t>0
{
η+EAF ,av(∆t)− η−EAF ,out(∆t)
}
= max
∆t>0
{
η+EAF ,in(∆t) + 2− η−EAF ,out(∆t)
}
= max
∆t>0
{⌈
∆t + J1
T1
⌉
+ 2−
⌊
∆t
T1
⌋}
= 2 + max
∆t>0
{ ⌈
∆t + J1
T1
⌉
−
⌊
∆t
T1
⌋
︸ ︷︷ ︸
=
(
1 if (∆t mod T1) + J < T1
2 otherwise
}
= 2 + 2 = 4 (6.19)
Periodic Shaping of Jitter and Burst 123
0
Ș(ǻt)
1
2
3
4
5
ǻt
delaybacklogpreload
2)(
1
1
av, »
»
º
«
«
ª  
T
Jt
t
ƩƩ
EAF
K
T1 2T1 3T1 4T1
T1–J1 2T1–J1 3T1–J1 4T1–J1
»
¼
»
«
¬
«
 
1
out, )(
T
t
t
ƩƩ
EAF
K
Figure 6.12. Synchronization of Jitter: Case 1 with Adaptation
backlog−EAF = inf∆t>0
{
η−EAF ,av(∆t)− η+EAF ,out(∆t)
}
= min
∆t>0
{
η−EAF ,in(∆t) + 2− η+EAF ,out(∆t)
}
= min
∆t>0
{
max
(
0,
⌊
∆t− J1
T1
⌋)
+ 2−
⌈
∆t
T1
⌉}
)
= 2− max
∆t>0
{⌈
∆t
T1
⌉
−
⌊
∆t− J1
T1
⌋}
= 2− 2 = 0 (6.20)
We see that the maximum backlog is four events. This is twice as much as in
the case of purely periodic event production. The additional uncertainty caused
by the jitter a) requires one more pre-load event, and b) can result in one more
“early” event. The minimum backlog is –again– zero. Both properties can be
seen in Figures 6.12 and 6.13.
6.3.1.2 Buﬀering Delay
In order to determine the minimum and maximum buffering delay, we first
need the Γ function. When the η functions are shifted up by two events, the Γ
124 Event Adaptation Functions
2,0min)(
1
1
av, ¸¸¹
·
¨¨©
§
»
¼
»
«
¬
«  
T
Jt
t
ƩƩ
EAF
K
preload
0
Ș(ǻt)
1
2
3
4
5
ǻt
delaybacklog
T1 2T1 3T1 4T1
T1+J1 2T1+J1 3T1+J1
»
»
º
«
«
ª
 
1
out, )(
T
t
t
ƩƩ
EAF
K
Figure 6.13. Synchronization of Jitter: Case 2 with Adaptation
needs to be shifted right by two events:
∀ n > 0 : ΓEAF ,out(n) =
{
0 if n ≤ 2
Γ1,out(n− 2) if n > 2 (6.21)
Now, we can determine the delay following Equation 6.13. We need not
look at n ≤ 2:
delay+EAF = sup
n>2
{
Γ+EAF ,out(n)− Γ−EAF ,av(n)
}
= max
n>2
{
Γ+EAF ,out(n)− Γ−EAF ,in(n− 2)
}
= max
(
Γ+EAF ,out(3),maxn>3
{
Γ+EAF ,out(n)− Γ−EAF ,in(n− 2)
})
= max
(
δ+EAF ,out(4),maxn>3
{
δ+EAF ,out(n + 1)− δ−EAF ,in(n− 2)
})
= max
⎛
⎝ 3 T1︸︷︷︸
first event
,max
n>3
{
nT1 + J1 −max
(
0, (n− 3)T1)
)}⎞⎠
= max
⎛
⎜⎝ 3 T1︸︷︷︸
first event
,max
n>3
{
nT1 + J1 − (n− 3)T1︸ ︷︷ ︸
=3 T1+J1
}⎞⎟⎠
= 3 T1 + J1 (6.22)
Periodic Shaping of Jitter and Burst 125
We see that the first event possibly experiences a shorter delay than all later
ones. This can also be seen in Figure 6.12. The minimum delay is:
delay−EAF = infn>2
{
Γ−EAF ,out(n)− Γ+EAF ,av(n)
}
= min
n>2
{
Γ−EAF ,out(n)− Γ+EAF ,in(n− 2)
}
= min
n>2
{
δ−EAF ,out(n)− δ+EAF ,in(n− 1)
}
= min
n>2
{nT1 − ((n− 1)T1 + J1)}
= T1 − J1 (6.23)
Interestingly, the minimum delay is not zero, as it was for periodic production
in Section 6.2. The pre-load of two events is necessary to cover the worst-case
jitter which can be any value less than the period T1. Smaller jitters result
is additional delays. Equation 6.23 shows that this additional delay increases
with decreasing jitters.
6.3.2 Large Jitters and Bursts
Intuitively, larger jitters increase the necessary buffer pre-load, along with
the overall buffer size and the delay. The actual numbers depend on the size of
the jitter relative to the period. We assume a number of k pre-loaded events in
the shaper buffer. The event availability function is:
ηEAF ,av(∆t) = ηEAF ,in(∆t) + k (6.24)
In order to avoid buffer underrun, we have to choose k such that the backlog
is at least zero. We also want to be optimal, i. e. we are looking for the smallest
integer k that fulfills the following inequation:
backlog−EAF
!≥ 0
⇒ η−EAF ,av(∆t)− η+EAF ,out(∆t) ≥ 0
⇔ η−EAF ,in(∆t) + k ≥ η+EAF ,out(∆t)
⇔ k ≥ η+EAF ,out(∆t)− η−EAF ,in(∆t)
⇔ k ≥
⌈
∆t
T1
⌉
−max
(
0,
⌊
∆t−J1
T1
⌋)
⇔ k ≥
⌈
T1+J1
T1
⌉
⇒ kmin = 1 +
⌈
J1
T1
⌉
126 Event Adaptation Functions
This is the general formula to determine how many pre-loaded events are
required. The formula also applies to small or zero jitter. In case of jitters less
than periods, k turns into 2, and for zero jitter k = 1, just as in the previous
sections.
6.3.2.1 Buﬀering Backlog
With a pre-load of kmin events, the minimum backlog is apparently zero,
any larger value leads to undesired inefficiencies. With a known k, we can
now actually calculate the maximum backlog:
backlog+EAF = sup
∆t>0
{
η+EAF ,av(∆t)− η−EAF ,out(∆t)
}
= max
∆t>0
{
η+EAF ,∈(∆t) + kmin − η−EAF ,out(∆t)
}
= max
∆t>0
{
min
(⌈
∆t + J1
T1
⌉
,
⌈
∆t
d1
⌉)
︸ ︷︷ ︸
=
⌈
∆t+J1
T1
⌉
for ∆t ≥ J1 d1T1−d1 ,
see Equation 4.15
+kmin −
⌊
∆t
T1
⌋}
= max
∆t>0
{⌈
∆t + J1
T1
⌉
+ kmin −
⌊
∆t
T1
⌋}
= kmin + max
∆t>0
{ ⌈
∆t + J1
T1
⌉
−
⌊
∆t
T1
⌋
︸ ︷︷ ︸
=
8>><
>>:
J1T1  if (∆t mod T1)
+(J1 mod T1) < T1
J1T1 + 1 otherwise
}
= kmin +
⌈
J1
T1
⌉
+ 1
= kmin + kmin = 2kmin (6.25)
We can see that the burst-specific parameter d1, capturing the minimum event
distance during a burst, has no influence on the backlog and, as we will see in
the next paragraph, on the delay.
Periodic Shaping of Jitter and Burst 127
6.3.2.2 Buﬀering Delay
The maximum delay is:
delay+EAF = sup
n>k
{
Γ+EAF ,out(n)− Γ−EAF ,av(n)
}
= max
n>k
{
Γ+EAF ,out(n)− Γ−EAF ,in(n− k)
}
= max
(
Γ+EAF ,out(k + 1), maxn>k+1
{
Γ+EAF ,out(n)− Γ−EAF ,in(n− k)
})
= max
(
δ+EAF ,out(k + 2), maxn>k+1
{
δ+EAF ,out(n + 1)− δ−EAF ,in(n− k)
})
= max
⎛
⎜⎝(k + 1)T1, max
n>k+1
{
nT1 −
(
(n− k − 1)T1 − J1
)︸ ︷︷ ︸
=(k+1) T1+J1
}⎞⎟⎠
= (k + 1) T1 + J1 (6.26)
Finally, the minimum delay is given by:
delay−EAF = infn>k
{
Γ−EAF ,out(n)− Γ+EAF ,av(n)
}
= min
n>k
{
Γ−EAF ,out(n)− Γ+EAF ,in(n− k)
}
= min
n>k
{
δ−EAF ,out(n)− δ+EAF ,in(n− k + 1)
}
= min
n>k
{(n− 1)T1 − (((n− k + 1)− 1)T1 + J1)}
= (k − 1)T1 − J1 (6.27)
6.3.3 System-Level Inﬂuence of Jitter
An interesting observation is that the minimum distance d1 that reduces
transient event frequencies during a burst does not affect periodic shaping at
all. Figure 6.12 illustrates that the maximum delay and backlog are observed
in the region where the jitter characteristics dominate the stream behavior. We
conclude the section about jitter and burst with an analysis of the relationship
between the jitter and the shaper properties.
When we use the optimal, i. e. the smallest valid buffer pre-load of kmin, the
minimum delay is bounded by the period T1:
delay−EAF = (kmin − 1) T1 − J1
=
⌈
J1
T1
⌉
T1 − J1
⇒ 0 ≤ delay−EAF < T1 (6.28)
128 Event Adaptation Functions
For the maximum delay, we obtain:
delay+EAF = (kmin + 1) T1 + J1
=
(⌈
J1
T1
⌉
+ 2
)
T1 + J1
=
⌈
J1
T1
⌉
T1 + J1 + 2 T1
⇒ 2 J1 + 2 T1 ≤ delay+EAF < 2 J1 + 3 T1 (6.29)
We can see that the maximum delay grows twice as fast as the jitter. This
shows the enormous influence of jitter on the overall system timing. The same
applies to the backlog:
backlog+EAF = kmin + kmin = 2kmin
= 2
⌈
J1
T1
⌉
≥ 2 J1
T1
(6.30)
6.3.4 Optimizations
The concepts of periodic shaping introduced so far conservatively assume a)
a fully independent shaper timer, b) strict FIFO communication semantics, and
c) a known fixed buffer pre-load. We have mentioned that this is not an unusual
requirement. Signal processing applications constrain the buffer pre-load in
order to implement a specific functionality [68]. These constraints enforce a
conservative design as explained above. In other situations, the communication
between the two tasks might be less constrained, e. g. if there is a pre-load or
not does not affect the application. We can take control over the individual
situations and easily eliminate the mentioned inefficiencies, such as unused
buffer or large delays. Again, we start with the simple case of a purely periodic
sender T1. Recall the buffering scenarios depicted in Figures 6.3 and 6.4. The
former starts with an empty buffer while the later starts with one pre-loaded
event. A shaper task can easily distinguish both situations from one another
at system run-time and dynamically choose the appropriate buffer set-up. The
natural solution is to start with a dummy event in the buffer which is skipped if
unnecessary. Such a situation is depicted in Figure 6.14. Essentially the first
arriving event allows prediction of the future timing and the optimal buffer set-
up to be chosen. The corresponding input and output event curves are shown in
Figure 6.15. We see that a pre-load does not need to be considered for corner-
case analysis. In effect, the buffer size can be reduced from two to one event.
And the delay is also reduced from 2T to 1T . Moreover, we can implement the
Periodic Shaping of Jitter and Burst 129
0
T1T1
T1 T1
t
EAF
buffer empty
buffer full
Ȣin
Ȣout
t0,in t0,out
time of prediction
Figure 6.14. Overwriting an Unnecessarily Pre-Loaded Event
0
Ș(ǻt)
1
2
3
4
5
ǻt
delaybacklog
T1 2T1 3T1 4T1
»
¼
»
«
¬
«
 
1
out, )(
T
t
t
ƩƩ
EAF
K
»
»
º
«
«
ª
 
1
in, )(
T
t
t
ƩƩ
EAF
K
Figure 6.15. Event Curves with Optimized Buffer Set-Up
shaper using a simple register instead of a FIFO, since a register has exactly
the right destructive write semantics that we need here.
In the case of task T1 producing events with jitter, the situation is slightly
different. Depending on the actual jitter-to-period ratio, the corner cases dif-
fer by more than one required pre-load (see the linear dependency of kmin in
Section 6.3), which results in more than two distinguishable situations, one for
each possible buffer pre-load level. And secondly, a jitter adds uncertainty to
the actual event arrival timing. This generally complicates the dynamic pre-
diction of the actual situation. But we can use a modified FIFO buffer that is
initially empty, and outputs dummy events on underrun. While we have used
130 Event Adaptation Functions
an intermediate available event function (Equation 6.24) for the conservative
calculations, the newly automatic dynamic pre-load prediction allows applica-
tion of the backlog and delay calculations to the actual input and output event
stream:
backlog+EAF = sup
∆t>0
{
η+EAF ,in(∆t)− η−EAF ,out(∆t)
}
= sup
∆t>0
{⌈
∆t + J1
T1
⌉
−
⌊
∆t
T1
⌋}
= sup
∆t>0
{ ⌈
∆t + J1
T1
⌉
−
⌊
∆t
T1
⌋
︸ ︷︷ ︸
=
8>><
>>:
J1T1  if (∆t mod T1)+
(J1 mod T1) < T1
J1T1 + 1 otherwise
}
=
⌈
J1
T1
⌉
+ 1 = kmin (6.31)
We see that the required buffer size (the backlog) equals the required number
of pre-loaded events kmin (see Equation 6.25). This is possible, since pre-
loaded events are being substituted as new events arrive at the shapers input,
preventing the buffer from overflowing.
The maximum delay is:
delay+EAF = sup
n>0
{
Γ+EAF ,out(n)− Γ−EAF ,in(n)
}
= max
(
Γ+EAF ,out(1), sup
n>1
{
Γ+EAF ,out(n)− Γ−EAF ,in(n)
})
= max
(
δ+EAF ,out(2), sup
n>1
{
δ+EAF ,out(n + 1)− δ−EAF ,in(n)
})
= max
⎛
⎜⎝ T1︸︷︷︸
first event
, sup
n>1
{
nT1 − ((n− 1)T1 − J1)︸ ︷︷ ︸
=T1+J1
}⎞⎟⎠
= T1 + J1 (6.32)
We can now compare these results with those from the non-optimized FI-
FOs, given by Equations 6.30 and 6.29. We see that both the maximum de-
lay and the maximum backlog still increase with increasing jitter J1, but the
values were reduced by a factor of two. The optimized shaper overwrites pre-
loaded events, thereby circumventing the conservative buffer set-up, minimiz-
ing buffering requirements and reducing delays.
Periodic Shaping of Jitter and Burst 131
task C T J , d priority
T1 20 150 - 1
T2 90 400 1100, 10 2
T3 40 200 - 3
Table 6.1. Task Parameters of Example System
The mentioned optimizations, however, can temporarily disorder the events
in the FIFO-communication, especially during the communication of the first
events during system start-up. So, the optimizations can not be applied to
systems which require the complete event order to be maintained, such as SDF.
6.3.5 Experiment
We will now illustrate the application of periodic shaping to a system of
three tasks, T1, T2, and T3. Tasks T1 and T3 are activated strictly periodically
with the periods T1 and T3, respectively. Task T2 is a reactive task, activated
periodically (period T2) but with a huge jitter J2 that exceeds the period many
times. The minimum event distance is 10. All tasks have different core exe-
cution times C1, C2, and C3. Scheduling follows static priorities, task T1 has
the highest priority, and task T3 the lowest. Table 6.1 summarizes the actual
values. The average processor utilization is:
U =
3∑
i=1
Ci
Ti
=
20
150
+
90
400
+
40
200
= 55.83%
The busy period [69, 121] of the worst-case scheduling scenario is shown
in Figure 6.16, generated by the SymTA/S tool [114], an in-house tool based
on the key contributions of this thesis. In the depicted scheduling scenario, all
tasks are activated simultaneously (critical instant, see Section 2.1.1) and, ac-
cording to the upper-bound event arrival functions η+(∆t), re-arrive as early
as possible. The small arrows mark activation times. We see the strictly peri-
odic execution of the highest priority task T1 at tact,T1,1 = 0, tact,T1,2 = 150,
tact,T1,3 = 300, and so on. It is not preempted, and has also a strictly periodic
completion behavior, i. e. the output jitter is zero.
Task T2 is activated three times within a very short time period, at tact,T2,1 =
0 and tact,T2,2 = 10, and tact,T2,3 = 20, the fourth activation arrives at tact,T2,4 =
100. This burst activation is due to the large jitter. We see that the first activa-
tion has not yet completed when the fourth activation arrives. Hence, the task’s
input queue must be able to store four tokens or events. In other words, the ex-
ecution backlog, which is determined as a side effect of the arbitrary deadline
analysis [69, 121], is 4 (four). The four executions are subsequently completed
at tcomp,T2,1 = 110, tcomp,T2,2 = 220, tcomp,T2,3 = 330, and tcomp,T2,4 = 420.
132 Event Adaptation Functions
Figure 6.16. Scheduling Diagram of Un-shaped System
task execution response output
backlog time jitter
T1 1 20 -
T2 4 320 1330
T3 3 480 440
Table 6.2. Experiment without Shaper
The maximum response time is observed for the fourth activation:
R+2 = tcomp,T2,4 − tact,T2,4 = 420− 100 = 320
Later activations arrive periodically with the period T2 = 300, but need not be
considered for worst-case response time analysis. The non-constant response
times add further distortion to the input stream, resulting in an output jitter of
1330.
The lowest-priority task T3 is activated periodically at tact,T3,1 = 0, tact,T3,2 =
200, ..., but it is blocked until all activations of higher-level tasks have been
completed at time t = 420. The first execution terminates at tcomp,T3,1 = 480.
Meanwhile, a second and a third activation have arrived, which complete at
tcomp,T3,2 = 630 and tcomp,T3,2 = 670. This burst execution requires an exe-
cution backlog buffer of 3 (three). The output jitter is 440, and the minimum
distance is 40. The detailed results of this experiment are shown in Table 6.2.
We now insert an optimized periodic shaper at the input of task T2. We know
that the required number of pre-loaded tokens equals the maximum backlog
equals the required buffer size. This number kmin is given by Equation 6.25:
backlog+EAF = kmin = 1 +
⌈
J2
T2
⌉
= 1 +
⌈
1100
400
⌉
= 4
Equation 6.32 yields the shaper’s maximum buffering delay:
delay+EAF = T2 + J2 = 400 + 1100 = 1500
Periodic Shaping of Jitter and Burst 133
Figure 6.17. Scheduling Diagram of System with Periodic Shaper
task shaper exe. total buffer task total output
backlog backlog buffer delay response delay jitter
T1 - 1 1 - 20 20 -
T2 4 1 5 1500 110 1610 20
T3 - 1 1 - 150 150 110
Table 6.3. Experiment with Periodic Shaper at Task T2’s Input
We need to store up to 4 tokens in the shaper buffer to synchronize the
stream to its original period which results in a maximum buffering delay of
1500 time units. Now, the inputs of all tasks are strictly periodic resulting in
a relatively deterministic schedule. The worst-case scheduling diagram is de-
picted in Figure 6.17. All tasks complete execution before their next activation,
and the execution backlog is 1 (one). That means that we have fully eliminated
the burst execution of tasks T2 and T3 and need to analyze the first activation
of each task, only. We can directly read the worst-case response times from the
diagram. The detailed results of this experiment are summarized in Table 6.3.
We see that the original system requires all together 8 buffer places to cap-
ture the execution backlog. The system with the periodic shaper, even though
we have inserted an additional buffer into the system, requires only 7 buffer
places, 4 to buffer the shaping backlog at task T2’s input, and one to buffer the
execution backlog of each tasks. The elimination of the burst has even more
positive effects on scheduling. The schedule is rather deterministic and the
execution backlog of all tasks is one. In turn, the worst-case number of pre-
emptions is heavily reduced, which tremendously reduces task response times:
from 320 to 110 for task T2, and from 480 to 150 for task T3. Finally and
maybe less obvious in this example, the output of a more deterministic task
is also more deterministic. The output jitters have been heavily reduced, from
1330 to 20 for task T2, and from 440 to 110 for T3. This leads to more deter-
ministic activation of a possibly connected task. In other words, the influence
134 Event Adaptation Functions
of the inserted shaper is not limited to a single component. Rather, periodic
shaping has a sustainable, positive effect on the entire system schedulability.
These improvements basically result from the equalization (or balancing)
that shaping applies to jittery or bursty event streams. Essentially, the reduc-
tion of dynamic load peaks, such as bursts, reduces the timing uncertainty or
non-determinism, in fact resulting in more static and regular system behavior.
A comparison between Figures 6.16 and 6.17 illustrates the effects of more
deterministic streams. The worst-case number of preemptions decreases, and
task recurrence is fully eliminated.
Periodic shaping means synchronizing a jittery or bursty stream to its origi-
nal period. The buffering delays that result from periodic shaping can be huge,
and they increase with increasing jitter. In the above experiments, we see that
shaping can add up to 1500 time units to the input events of task T2 events. The
result is an effective response time of of task T2 of 1600 instead of 320 in the
un-shaped system. Such an effect can cancel out other improvements, and pe-
riodic shaping becomes a trade-off among conflicting goals such as efficiency
and predictability. However, we do not necessarily need to fully eliminate jitter
and/or burst if we want to optimize the system, as the next section shows.
6.4 Sporadic Shaping
As a key impact on scheduling, periodic shaping produces gaps in the sched-
ule which can now be exploited by other, lower-priority tasks to execute. This
subsequently reduces the number of preemptions and finally leads to a more
deterministic system. With periodic shaping, we pay for this improvement with
long buffering delays. But to produce these gaps, we do not necessarily need
to fully synchronize a jittery or bursty stream to its original period, if we can
find other means to reduce the influence of bursts execution.
6.4.1 Transient Load Reduction
Where periodic shaping used a strictly periodic timer, sporadic shaping uses
an equally simple time-out mechanism. Whenever an event is released at the
shapers output, the time-out mechanism must make sure that no further events
are released before a certain amount of time, the minimum output distance, has
expired. Buffered events are released as soon as possible without violating the
minimum output distance. The network theory refers to such shapers as greedy
shapers [15, 14].
The time-out concept is easily applicable to the proposed set of event mod-
els, since the minimum output distance has a direct influence on the minimum
inter-arrival time parameter of the burst models. When sporadic shaping with
a time-out value of dEAF ,out is applied to a periodic stream with jitter or burst
Sporadic Shaping 135
0
ǻt
1
1
T
Jt Ʃ

in,EAFd
tƩ 
out,EAFd
tƩ
1T
tƩ
delaybacklog


 
in,1
in,1
1
EAF
EAF
dT
dJ
tƩ 


 
out,1
out,1
2
EAF
EAF
dT
dJ
tƩ
)(~ tƩK
Figure 6.18. Influence of Sporadic Shaping on Upper-Bound Event Curves
(SEAF ,in), then the resulting output stream is given by:
SEAF ,out = SP+B(TEAF ,in, JEAF ,in,max(dEAF ,out, δ−EAF ,in(2)) (6.33)
We see that the jitter is not affected by sporadic shaping but that a sporadic
shaper imposes a minimum bound on the inter-arrival time of events. Fig-
ure 6.18 illustrates how the upper-bound event curve (η+(∆t)) changes due to
sporadic shaping. Bursts that in the original stream arrive with a minimum dis-
tance of dEAF ,in are slowed down by increasing the allowed minimum distance
to dEAF ,out. This slow-down corresponds to decreasing the initial slope of the
η+ curve. For large ∆t, the function does not change.
The sporadic time-out value dEAF ,out can be used to adjust the maximum
transient frequencies of a stream. The gray region in Figure 6.18 illustrates the
valid parameter range. The slow-down is clearly limited by the average slope,
determined by the period T1:
dEAF ,out
!≤ TEAF ,in = T1 (6.34)
Larger values would apparently correspond to decreasing the average frequency
and must be avoided. Values smaller than or equal to the original minimum dis-
tance do not change the timing of the stream, even though they are formally
allowed.
With respect to the example from Section 6.3.5, we now replace the periodic
shaper by a sporadic shaper with a time-out value of 200:
S4,in = SEAF ,out = SP+B(400, 1100, 200)
136 Event Adaptation Functions
Figure 6.19. Scheduling Diagram of Sporadic Shaping with a Time-Out of 200
This means that input events of task T2 are delayed by the shaper such that
they activate task T2 with a minimum distance of 200. Effectively, the second
activation of task T2, which arrived at t = 10 without shaping (see Figure 6.16),
is now delayed to arrive no earlier than at t = 200. We already know from
Figure 6.17 that the first activation completes at time t = 150. An earliest
possible re-activation of task T2 at t = 200 has obviously no influence on
the worst-case scheduling scenario, as the diagram in Figure 6.19 shows. The
execution backlog of all tasks is one.
6.4.2 Shaper Delay and Backlog
The network calculus ideas that were introduced in Section 6.2.5 can be ap-
plied to determine the shaper properties. But this time, the worst case buffering
delay and backlog are found within the non-linear burst region, complicating
the calculations. Instead of resolving the network calculus equations, we di-
rectly target at determining the curve distances graphically.
During a burst, all the incoming events have their minimum original dis-
tance, and all burst events except the first one have to be delayed. The second
needs to be delayed only a little bit, the third one a bit more (more precisely,
double as much as the second one), the third one three times as much as the
first one, and so on. Finally, the last event of the burst is delayed for the longest
time. It also leads to the highest buffer fill level. During non-bursts, no events
need be buffered, hence the minimum delay and backlog are zero.
According to Equation 4.15, the burst period ends at
∆tburst,in =
J1 dEAF ,in
T1 − dEAF ,in (6.35)
At that point, both the horizontal and vertical distances have their maximum
values. But we have used the continuous event functions η˜+(∆t) to illustrate
the problem in Figure 6.18. To determine the maximum backlog and delay for
Sporadic Shaping 137

critK

critK
Ș+(ǻt)
ǻt
max. delay
max. backlog

crittƩinburst,crit tt ƩƩ  

critical event
)(in, tƩ

EAF
K
)(out, tƩ

EAF
K
Figure 6.20. Single Critical Event in Sporadic Shaping
the discrete event functions, we need to identify the critical event that leads to
worst-case buffering.
6.4.2.1 The Critical Event
If the last event in a burst arrives exactly at the theoretical end of the burst
given by Equation 6.35, then there is only one critical event. This happens
if the end of the burst ∆tburst,in is an integer multiple of the minimum input
distance dEAF ,in:
∆tburst,in
dEAF ,in
=
J1 dEAF,in
T1−dEAF,in
dEAF ,in
=
J1
T1 − dEAF ,in
!∈ N (6.36)
Figure 6.20 illustrates the situation. The maximum backlog and delay are
shown, bounded by ∆t+crit −∆t−crit and η+crit − η−crit, respectively. We start with
η+crit:
η+crit = η
+
EAF ,in(∆t
−
crit) + 1 =
⌈
∆t−crit
dEAF ,in
⌉
+ 1
=
⎡
⎢⎢⎢
J1 dEAF,in
T1−dEAF,in
dEAF ,in
⎤
⎥⎥⎥+ 1 =
⌈
J1
T1 − dEAF ,in︸ ︷︷ ︸
∈N
⌉
+ 1 (6.37)
We have to add 1 to the value of the η+(∆t) function at that point because
this function is left-continuous and has just not yet increased to η+crit at ∆t−crit.
138 Event Adaptation Functions
Calculating η−crit is straight-forward:
η−crit = η
+
EAF ,out(∆t
−
crit) =
⌈
∆t−crit
dEAF ,out
⌉
=
⎡
⎢⎢⎢
J1 dEAF,in
T1−dEAF,in
dEAF ,out
⎤
⎥⎥⎥ (6.38)
We obtain as the maximum backlog:
backlog+EAF = η
+
crit − η−crit
= 1 +
⌈
J1
T1 − dEAF ,in︸ ︷︷ ︸
∈N
⌉
−
⌈
J1
T1 − dEAF ,in
dEAF ,in
dEAF ,out
⌉
(6.39)
To determine the maximum buffering delay, we calculate the delay between
the η+critth input and output event:
delay+EAF = δ
−
EAF ,out(η
+
crit)− δ−EAF ,in(η+crit)
= (η+crit − 1)dEAF ,out − (η+crit − 1)dEAF ,in
= (η+crit − 1)(dEAF ,out − dEAF ,in)
=
⌈
∆tcrit
dEAF ,in
⌉
(dEAF ,out − dEAF ,in)
=
⌈
J1
T1 − dEAF ,in︸ ︷︷ ︸
∈N
⌉
(dEAF ,out − dEAF ,in) (6.40)
Equation 6.36 ensures that some of the rounded terms are integers and do
not essentially need rounding. We have not further simplified this because the
same equations will be soon applied to other non-integer situations.
6.4.2.2 Two Critical Event Candidates
If the last event in a burst does not exactly meet the end of the burst ∆tburst,in
given by Equation 6.35, then there are two candidates for the critical event, the
last event directly before and the first event directly after ∆tburst,in. Obviously,
one of these events experiences the maximum backlog and delay, respectively.
We therefore determine these properties for both events. The two candidates
are shown in Figure 6.21. We start by determining ∆tcrit,1 which is the largest
integer multiple of the minimum input distance dEAF ,in less than or equal to
∆tburst,in:
∆tcrit,1 =
⌊
∆tburst,in
dEAF ,in
⌋
dEAF ,in (6.41)
Sporadic Shaping 139
Ș+(ǻt)
ǻt

crit,2tƩ

crit,1tƩ
2
1
two critical events
inburst,tƩ

crit,2K

crit,1K
)(in, tƩ

EAF
K
)(out, tƩ

EAF
K
Figure 6.21. Two Critical Events in Sporadic Shaping
The backlog of this event can be calculated using Equations 6.37, 6.38, and 6.39:
backlog+EAF ,1 = η
+
crit,1 − η−crit,1
= η+EAF ,in(∆tcrit,1) + 1− η+EAF ,out(∆tcrit,1)
=
⌈
∆tcrit,1
dEAF ,in
⌉
+ 1−
⌈
∆tcrit,1
dEAF ,out
⌉
=
⎡
⎢⎢⎢
⌊
∆tburst,in
dEAF,in
⌋
dEAF ,in
dEAF ,in
⎤
⎥⎥⎥+ 1−
⎡
⎢⎢⎢
⌊
∆tburst,in
dEAF,in
⌋
dEAF ,in
dEAF ,out
⎤
⎥⎥⎥
= 1 +
⌊
∆tburst,in
dEAF ,in
⌋
−
⌈⌊
∆tburst,in
dEAF ,in
⌋
dEAF ,in
dEAF ,out
⌉
= 1 +
⌊
J1
T1 − dEAF ,in
⌋
︸ ︷︷ ︸
η+crit,1
−
⌈⌊
J1
T1 − dEAF ,in
⌋
dEAF ,in
dEAF ,out
⌉
︸ ︷︷ ︸
η−crit,1
(6.42)
140 Event Adaptation Functions
The delay is obtained using Equation 6.40:
delay+EAF ,1 = δ
−
EAF ,out(η
+
crit,1)− δ−EAF ,in(η+crit,1)
= (η+crit,1 − 1)dEAF ,out − (η+crit,1 − 1)dEAF ,in
= (η+crit,1 − 1)(dEAF ,out − dEAF ,in)
=
⌊
J1
T1 − dEAF ,in
⌋
(dEAF ,out − dEAF ,in) (6.43)
The arrival time of the second candidate can be determined similarly to the
calculation in Equation 6.41, but this time we are looking for the event arrival
time greater than or equal to ∆tburst,in; and because the event arrives after the
end of the burst, we need to consider a periodic behavior with jitter rather than
a sporadic behavior with a minimum distance:
∆tcrit,2 =
⌈
∆tburst,in
dEAF ,in
⌉
T1 − J1 (6.44)
The backlog of this event is::
backlog+EAF ,2 = η
+
crit,2 − η−crit,2
= η+EAF ,in(∆tcrit,2)︸ ︷︷ ︸
after end of input burst
+1− η+EAF ,out(∆tcrit,2)︸ ︷︷ ︸
output still bursty
=
⌈
∆tcrit,2 + J1
T1
⌉
+ 1−
⌈
∆tcrit,2
dEAF ,out
⌉
= 1 +
⎡
⎢⎢⎢
⌈
∆tburst,in
dEAF,in
⌉
T1 − J1 + J1
T1
⎤
⎥⎥⎥−
⎡
⎢⎢⎢
⌈
∆tburst,in
dEAF,in
⌉
T1 − J1
dEAF ,out
⎤
⎥⎥⎥
= 1 +
⌈
J1
T1 − dEAF ,in
⌉
︸ ︷︷ ︸
η+crit,2
−
⎡
⎢⎢⎢
⌈
J1
T1−dEAF,in
⌉
T1 − J1
dEAF ,out
⎤
⎥⎥⎥︸ ︷︷ ︸
η−crit,2
(6.45)
The delay is obtained using Equation 6.40:
delay+EAF ,2 = δ
−
EAF ,out(η
+
crit,2)︸ ︷︷ ︸
output still bursty
− δ−EAF ,in(η+crit,2)︸ ︷︷ ︸
after end of input burst
= (η+crit,2 − 1)dEAF ,out − (η+crit,2 − 1)T1 − J1
= (η+crit,2 − 1)(dEAF ,out − T1) + J1
=
⌈
J1
T1 − dEAF ,in
⌉
(dEAF ,out − T1) + J1 (6.46)
Sporadic Shaping 141
task shaper exe. total buffer task total output
backlog backlog buffer delay response delay jitter
T1 - 1 1 - 20 20 -
T2 3 1 4 500 110 610 1120
T3 - 1 1 - 150 150 110
Table 6.4. Experiment with Sporadic Shaper with a Time-Out of 200
Finally, we choose the larger value of both candidates:
backlog+EAF = max(backlog
+
EAF ,1, backlog
+
EAF ,2)
= max
(
1 +
⌊
J1
T1 − dEAF ,in
⌋
−
⌈⌊
J1
T1 − dEAF ,in
⌋
dEAF ,in
dEAF ,out
⌉
,
1 +
⌈
J1
T1 − dEAF ,in
⌉
−
⎡
⎢⎢⎢
⌈
J1
T1−dEAF,in
⌉
T1 − J1
dEAF ,out
⎤
⎥⎥⎥
)
(6.47)
delay+EAF = max( delay
+
EAF ,1, delay
+
EAF ,2)
= max
( ⌊
J1
T1 − dEAF ,in
⌋
(dEAF ,out − dEAF ,in),
⌈
J1
T1 − dEAF ,in
⌉
(dEAF ,out − T1) + J1
)
(6.48)
These are the general formulas for backlog and delay determination. In
case of single critical event, both values ∆tcrit,1 and ∆tcrit,2 are identical and
the general backlog calculations of Equation 6.47 can be reduced to those of
Equation 6.39. The same applies to the delay calculations
6.4.3 Experiments
Now that we have derived a formal framework for sporadic shaping, we can
determine the properties of the initial example. Detailed results are given in
Table 6.4. Compared to the solution with the periodic shaper (see Table 6.3),
the required shaper buffer can be reduced from 4 to 3, and the buffering delay
has decreased from 1500 to 500, reducing the effective task T2 response time
from 1610 to 610 time units. As a side-effect, the output jitter of task T2 could
not be reduced.
In order to illustrate the application of sporadic shaping, we have varied the
time-out value of the shaper. The next experiments start with the maximum
142 Event Adaptation Functions
Figure 6.22. Scheduling Diagram of System Sporadic Shaper with a Time-Out of 400
task shaper exe. total buffer task total output
backlog backlog buffer delay response delay jitter
T1 - 1 1 - 20 20 -
T2 3 1 4 1100 110 1210 1120
T3 - 1 1 - 150 150 110
Table 6.5. Experiment with Sporadic Shaper with a Time-Out of 400
possible time-out value, which is (see Equation 6.34) the original period of
400 time units. Then we gradually decrease the time-out value to 140, and
finally 90 time-units. A detailed comparison shows the impact of shaping and
the trade-offs that provide room for optimizations.
6.4.3.1 400-Time Units Shaper
With a time-out of 400, we apply as much sporadic shaping as possible,
larger time-out values are not possible. The worst-case scheduling diagram
is shown in Figure 6.22, again being identical to those with periodic shaping,
and also to sporadic shaping with a time-out of 200. The reason is –again–
the large minimum distance that prevents task T2 from re-arriving during the
so called critical scheduling instant. Table 6.5 shows the detailed results of
the experiment. While the periodic shaper required a buffer of size 4, the
maximum required buffer size of the sporadic shaper is only 3, just as in the
case of a 200 time-unit time-out. The buffering delay is between the delays of
the previous experiments.
6.4.3.2 140-Time Units Shaper
A reduction of the time-out value below 150 time units results in more com-
plex worst-case scheduling diagrams, since now, re-activations of task T2 need
be considered during analysis. Figure 6.22 shows the worst-case scheduling
diagram.
Sporadic Shaping 143
Figure 6.23. Scheduling Diagram of System Sporadic Shaper with a Time-Out of 140
task shaper exe. total buffer task total output
backlog backlog buffer delay response delay jitter
T1 - 1 1 - 20 20 -
T2 3 1 4 320 110 430 1120
T3 - 2 2 - 260 260 220
Table 6.6. Experiment with Sporadic Shaper with a Time-Out of 140
Task T2 re-arrives at t = 140 and preempts T3 which, in turn, re-arrives
at t = 200 before it has completed. Two more re-arrivals of T2 disturb the
execution of T3 further. Finally, the critical scheduling instant is finished at t =
560. The figure shows that the response time of task T2 has not increased, since
there is at most one preemption by T1. However, the lowest priority task T3 is
now being preempted more often than with larger time-out values. Hence, its
response time increases and even exceeds its own activation period, resulting
in larger execution backlog. The detailed results are shown in Table 6.6.
We see that task T3 suffers from the decreasing time-out values, although the
required shaper buffer remains constant compared to the previous experiment.
However, the buffering (or shaping) delay has further decreased from 500 to
320.
6.4.3.3 90-Time Units Shaper
In the final experiment, we reduce the time-out to 90. The scheduling di-
agram in Figure 6.24 illustrates that the resulting scheduling is already very
complex, again. There is almost no difference compared to the un-shaped ver-
sion of Figure 6.16. Only the total input backlog of task T2 is now partitioned
into a shaping backlog of 2 and an execution backlog of 2, while the un-shaped
version requires an execution backlog of 4. The detailed results are shown in
Table 6.7.
144 Event Adaptation Functions
Figure 6.24. Scheduling Diagram of System Sporadic Shaper with a Time-Out of 90
task shaper exe. total buffer task total output
backlog backlog buffer delay response delay jitter
T1 - 1 1 - 20 20 -
T2 2 2 4 170 150 320 1160
T3 - 3 3 - 480 480 440
Table 6.7. Experiment with Sporadic Shaper with a Time-Out of 90
6.4.3.4 Experiment Summary
We have seen that very large time-out values result in the same worst-case
scheduling as the periodic version with much less delay. In contrast, very
small time-out values result in properties similar to the un-shaped version. In
the middle range, there are interesting possibilities of optimizing the system
by trading buffering requirements against delays against output jitters, and the
individual task’s delays against each other. Figure 6.25 allows a direct com-
parison of the worst-case scheduling scenarios of all experiments. The top
scheduling diagram is taken from the experiment with a periodic shaper, the
other diagrams illustrate the influence of decreasing time-out values from top
to bottom. The bottom diagram shows the up-shaped version.
Table 6.8 provides the detailed results. The bold numbers represent optimal
values for a specific property. We see that, in this experiment, each set-up is
optimal with respect to a particular property. This is not necessarily the case,
as the fourth row of Table 6.8 already indicates. The sporadic shaper with a
time-out of 140 shares the optimal task T2 backlog with four other solutions
and has non-optimal values for all other properties. However, it still represents
a Pareto-optimal solution, since neither of the other solutions outperforms it in
all properties. Usually, a higher number of time-out values results in a wider
Pareto front of sub-optimal solutions, which can be traded against each other.
Sporadic Shaping 145
periodic shaper
sporadic shaper 400
sporadic shaper 200
sporadic shaper 140
sporadic shaper 90
unshaped system
Figure 6.25. Scheduling Diagrams of All Experiments
146 Event Adaptation Functions
Shaping
P 400 200 140 90 –
Accumulated Backlog
(shaper + execution)
T1 1 1 1 1 1 1
Ta
sk T2 5 4 4 4 4 4
T3 1 1 1 2 3 3
Total 7 6 6 7 8 8
Accumulated Delay
(shaper + response)
T1 20 20 20 20 20 20
Ta
sk T2 1610 1210 610 430 320 320
T3 150 150 150 260 480 480
Output Jitter
T1 - - - - - -
Ta
sk T2 20 1120 1120 1120 1160 1330
T3 110 110 110 220 440 440
Table 6.8. Overview of Delay and Backlog of All Experiments
6.4.4 Shaping Sporadic Streams
So far, we have applied shaping solely to periodic streams with jitter and
burst. Periodic shaping eliminates a jitter by re-synchronizing the events to the
original period, sporadic shaping reduces the strength of a burst by increasing
the minimum inter-arrival time between events. It is quite obvious that periodic
shaping cannot be applied to sporadic streams, at least not in the way presented
in Section 6.2. But we can clearly apply sporadic shaping to sporadic streams.
The same concepts that have been introduced also apply to sporadic shaping.
The shaper’s output stream will then be:
SEAF ,out = SS+B(TEAF ,in, JEAF ,in,max(dEAF ,out, δ−EAF ,in(2)) (6.49)
The maximum backlog and delay calculation from Equations 6.47 and 6.48
apply.
6.4.4.1 Maximum Sporadic Shaping
There is, however, an interesting situation that one could call “sporadic syn-
chronization”. If we choose the maximum allowed time-out value dEAF ,out,
which is equal to the original sporadic period TEAF ,in, then the resulting stream
is:
SEAF ,out = SS+B(TEAF ,in, JEAF ,in, TEAF ,in) (6.50)
Automatic Shaping 147
We can now apply the additional event model interface from Section 5.6.3 to
transform that stream into a strictly sporadic (S) stream:
SEAF ,out = SS(TEAF ,in) (6.51)
In other words, under specific circumstances, we can apply a lossless event
model transformation:
EMIFS+B→S : {SS+B(T, J, d) ∈ EMS+B|d = T} → EMS
Starget = SS(Ttarget = Tsource) (6.52)
Together with a sporadic shaper, this interface allows sporadic streams to be
virtually re-synchronized to their original sporadic period. The standard cal-
culations apply to the dimensioning of the shaper buffer and to obtaining the
shaping delay.
6.5 Automatic Shaping
So far, we have considered shaping as a means to manually optimize schedul-
ing locally. There is, however, another very important application of shaping.
We have seen in the previous chapter, that there exist situations, in which the
requirement coverage test of Definition 5.4 fails, that compares the character-
istic functions of a stream against the allowed range of the requirement. In
these situations, no plain event model interface can be found. Shaping, how-
ever, changes the specific parameters of a stream, along with the characteristic
functions. Apparently, a given input stream Si,in can possibly be shaped such
that the resulting stream meets a given input requirement Ri,in in cases where
no plain EMIF is available.
We have shown in Section 6.4.3 that the actual impact of shaping varies
heavily with the choice of the shaper. Depending on the shaping type, periodic
or sporadic, and on the time-out value, task activation can be deliberately con-
trolled and optimized by the designer. In other words, designers can exploit
alternatives when shaping streams. However, for an automatic procedure, that
we will introduce in Chapter 7, we need a clear, unambiguous rule to select a
shaper. Therefore, we first define appropriate goals of an automatic shaping.
We can distinguish optimizations from necessities as follows. A task’s input
requirement must essentially be met, otherwise the task can not be analyzed.
This is a necessity. When shaping cannot be avoided, we want to reduce the in-
fluence of shaping on the overall system to a minimum, i. e. we are looking for
a shaper with the minimum backlog and delay. In other words, the input stream
shall be shaped as little as possible but as much as necessary. Everything be-
yond these necessities can be subject to further user-controlled optimization,
and is called user-controlled shaping.
148 Event Adaptation Functions
Definition 6.1. (Automatic Shaper)
An Automatic Shaper EAF auto is a function that takes as argument an event
stream SEAF auto,in and a requirementR, and returns a shaped stream SEAF auto,out.
Let Z be the set of all possible event streams S, and P(Z) be its power set.
Then, EAF auto is deﬁned by:
EAF auto : Z × P(Z) → Z
SEAF auto,out = EAF auto(SEAF auto,in,R) (6.53)
If possible, the function shapes the provided event stream such, that
a) the shaper’s output event stream is covered by the given requirement
RC(SEAF auto,out,R) = 1(true) , and (6.54)
b) the required amount of buffering and buffering delay is minimized. The
corresponding parameters backlog+EAF auto , backlog
−
EAF auto , delay
+
EAF auto , and
delay−EAF auto are associated with the Automatic Shaper.
If there exists no shaper that fulﬁlls the given requirement R according to
Equation 6.54, the function returns the un-shaped source stream, and the four
parameters have a value of zero (0).
The experiments of Section 6.4.3 have shown us that sporadic shaping has
a smaller influence than periodic shaping, and that smaller possible time-out
values result in less buffering and less delay. Hence, sporadic shapers are fa-
vored over periodic shapers for automatic shaping. Furthermore, an automatic
shaper must have the minimum possible time-out value that is just sufficient to
meet the input requirement with respect to the allowed minimum event distance
δ−. The minimum possible value is taken from all allowed streams (Ri,in) that
support the actual input period and the actual input jitter:
dEAF auto,out = minS∈{Sx∈Ri,in|Tx=Ti,in∧Jx≥Ji,in}
(δ−S (2)) ≤ δ−Si,in(2) (6.55)
Practically speaking, the minimum time-out value must be selected according
to the maximum allowed transient input frequency, given that the period and
the jitter are within the allowed range.
We have mentioned in Section 6.4.1 that sporadic shaping never reduces the
jitter, it can only reduce transient event frequencies. In case the input jitter
exceeds the maximum allowed jitter, then the set
{Sx ∈ Ri,in|Tx = Ti,in ∧ Jx ≥ Ji,in}
is empty, and no appropriate dEAF auto,out can be found using Equation 6.55.
There is one exception, which we called maximum sporadic shaping in Sec-
tion 6.4.4. This eliminates the jitter of a sporadic stream by choosing the max-
imum possible timeout value, which is the sporadic period TS of the stream.
Polling 149
T1
T4
S4,data=S1,out
S4,act=SP(T4,act)
S4,out=?
R4=?
backlog4,data=?
delay4,data=?
Figure 6.26. Periodic Polling Task and the Involved Event Streams
In case of the input stream is periodic with a too large jitter, a periodic shaper
of Section 6.2 must be used. In the introductory example of this chapter, we
have shown that the original period of the stream must be clearly compatible
with the task input requirement (see Equation 6.4).
6.6 Polling
In Section 6.2, we have shown how periodic streams can be re-synchronized
to their original period. An experiment has shown how such periodic shapers
can result in a periodic execution of an otherwise very dynamic task, thereby
substantially reducing peak loads and increasing the determinism.
Periodic task execution, however, does not necessarily always require strictly
periodic inputs. Polling is a popular mechanism to also apply periodic execu-
tion to asynchronous inputs, including sporadic streams. The behavior of a
polling task is influenced by two event streams. A strictly periodic one that
activates the task, and another arbitrary one that influences the tasks functional
behavior. Figure 6.26 shows a polling task T4 and the two streams, one acti-
vating event stream S4,act and one data stream S4,data coming from task T1.
In other words, the activation scheme does not reflect communication and
vice versa. Rather, a polling task is not activated upon the availability of inputs
but is time-driven. When activated, then it tests its inputs for available data,
and the task’s behavior might further depend on the success or failure of the
test.
There are four parameters that must be determined, as illustrated in Fig-
ure 6.26. The buffer is needed to synchronize the data input to the periodic
execution, and we need to determine the data buffering delay delay+4,data and
backlog backlog+4,data. Furthermore, the execution delay, i. e. the response time
150 Event Adaptation Functions
0
Ș(ǻt)
1
2
3
4
5
ǻt
delaybacklog
»
¼
»
«
¬
«
 
1
act4 )(
T
t
t
ƩƩ
,
K
)()( out1,data4, tt ƩƩ
  KK
6
Figure 6.27. Polling a Periodic Stream with Burst
R4,data, is required to finally determine the output stream S4,out of the polling
tasks.
6.6.1 Input Buﬀer
A task that periodically polls its input, implicitly performs shaping on the
input stream. When both sender and receiver have the same period, polling
corresponds to periodic shaping introduced in Section 6.2. Depending on the
possible jitter or burst, it requires buffering and induces a delay, and the back-
log and delay calculations from Equations 6.32 and 6.31 can be re-used. Such
periodic task activation is often found in systems with loosely coupled task
communication. The buffer synchronizes tasks which run independent sched-
ules but still share a common periodicity or frequency as part of their combined
function, e. g. in distributed filter functions.
When the timing of the receiver (its period) is nearly independent of the in-
put data, the situation resembles key characteristics of sporadic shaping. Sim-
ilar to condition 6.34, the polling task must be at least as fast as the input data
arrives on stream S4,data to prevent buffer overflows:
T4,in ≥ T4,act (6.56)
This requirement is based on the assumption that each input must essentially
be read by the polling task. However, there are applications where this is not
necessarily required. Simulink [115], for instance, defines periodic tasks that
communicate through registers, and data can eventually be overwritten before
it is read. This eliminates causal relations between event arrival and task execu-
tion. We have thoroughly analyzed the importance of register communication
Polling 151
and non-causal task execution in our SPI project (see Section 2.4). This thesis,
however, focuses on causal performance dependencies, and register communi-
cation is not considered further.
The event curves of Figure 6.27 illustrate a polling scenario with bursts on
the data input stream S4,data. The behavior in the case of polling is very similar
to the behavior known from sporadic burst reduction, as introduced in Sec-
tion 6.4.1. Hence, similar calculations can be applied. There is, however, a
key difference. While shapers consume an input event as early as possible, a
polling task must be assumed to read the input as late as possible, because it
is executed independently of the input stream timing. In other words, an input
event unusually has to wait until the next activation of the polling receiver. This
adds a constant amount of time to the overall delay, and also affects buffering.
We can determine the end of the input burst and the corresponding two crit-
ical events using the known Equations 6.41 and 6.44 with some modifications.
In Equations 6.47 and 6.48, we
substitute the time-out value dEAF ,out with the polling period T4,act,
use the more general δ−1 (2) instead of dEAF ,in to allow the application tojittery streams without burst, and
add one activation period T4,act to the delay to account for the possible
“late” consumption of the receiver
We obtain:
backlog+4,in = max
(
1 +
⌊
J1
T1 − δ−1 (2)
⌋
−
⌈⌊
J1
T1 − δ−1 (2)
⌋
δ−1 (2)
T4,act
⌉
,
1 +
⌈
J1
T1 − δ−1 (2)
⌉
−
⎡
⎢⎢⎢⎢
⌈
J1
T1−δ−1 (2)
⌉
T1 − J1
T4,act
⎤
⎥⎥⎥⎥
)
(6.57)
delay+4,in = T4,act +max
( ⌊
J1
T1 − δ−1 (2)
⌋
(T4,act − δ−1 (2)),
⌈
J1
T1 − δ−1 (2)
⌉
(T4,act − T1) + J1
)
(6.58)
6.6.2 Execution Load and Response Time
The activation of the polling task is fully independent of the actual data in-
put. Hence, scheduling analysis only needs to consider the activating event
152 Event Adaptation Functions
stream S4,act. The execution time, which may be data-dependent, can be cap-
tured by an execution time interval. Scheduling analysis will then provide a
corresponding response time interval and the minimum and maximum load.
The details of the actual scheduling analysis are not in the key focus of this
thesis. Rather, this work focuses on the amount of information required to en-
able the analysis. We see that the data input stream S4,data is not essentially
needed.
There are, however, scheduling analysis techniques that can distinguish be-
tween several execution behaviors or contexts [55]. For such techniques, the
input stream S4,data provides important information about the distribution of
the two distinctive behaviors.
6.6.3 Output Event Streams
To determine the output stream, we have to know about the implementation
of the polling task. There are two possible (and equally popular) ways to im-
plement the output communication. One possibility is to always produce an
output event and to code the success of the poll, or other state information,
in the produced data. Such implementations are found in periodic data-flow
implementations as generated by Simulink [115]. In this case, the situation
can be reduced to a periodically activated task that always produces an output
event, and the output calculations from Section 4.1 apply:
S4,out = SP+B
(
T4,out = T4,act,
J4,out = J4,R = R+4 −R−4 ,
d4,out = max
(
T4,act − J4,R, R−4
) ) (6.59)
The second possibility is to only produce an output event after a successful
input poll, i. e. if a data input was available from stream S4,data. In other words,
the task has a conditional output production. According to Section 4.5, such
tasks produce their output sporadically. So we can directly re-use all calcula-
tions from Equation 6.59 but simply have to change the event model class from
periodic into sporadic.
However, this procedure yields an overly conservative bound on the real
output stream behavior. The polling task does not behave randomly but reacts
to the availability of data on stream S4,data, and the actual input-output behavior
is in fact deterministic. In other words, key properties of the input stream will
be propagated to the output, such as an average period:
T4,out = T4,data = T1 (6.60)
We can account for this input-output relationship when we consider the en-
tire path from task T1 to the output of task T4. Figure 6.28 illustrates this. We
Polling 153
T1
T4
S4,data=S1,out=SP+ (T1,J1,d1)
S4,act=SP(T4,act)
S4,out=SP+ (T4,out=T1, J4,out=?, d4,out=?)
R4delay4,data
Rpoll
Figure 6.28. Output Stream of Conditional-Output Polling Tasks
determine the combined response time of the input buffer and the task execu-
tion:
Rpoll = delay4,in + R4
R+poll = delay
+
4,in + R
+
4
R−poll = delay
−
4,in + R
−
4
Jpoll = R+poll −R−poll
Now, we apply this combined response time to the input stream of task T4 and
we obtain as output:
S4,out = SP+B
(
T4,out = T1,
J4,out = J1 + Jpoll,R,
d4,out = max
(
T1 − Jpoll, R−4
) )
(6.61)
We can even incorporate key information about the activation period of task
T4 to further tighten the minimum output distance d4,out by using the maximum
value of both Equations 6.59 and 6.61:
d4,out = max
(
T1 − Jpoll, T4,act − J4,R, R−4
)
(6.62)
This is specifically useful, if the input stream is bursty and the buffering
delay exceeds the original period. This optimization accounts for the fact that
154 Event Adaptation Functions
strictly
periodic
periodic
w/ jitter
periodic
w/ burst
strictly
sporadic
sporadic
w/ jitter
sporadic
w/ burst
burst reduction by
sporadic shaping
sporadic shaping
("sporadic synchronization")
periodic shaping /
re- synchronization
polling
polling
Figure 6.29. Existing Event Adaptation Functions
periodic polling shares key properties with sporadic shaping, as introduced in
Section 6.4. It buffers input and reduces transient frequencies.
Clearly, periodic polling can be applied to sporadic streams as well. The
output stream of T4 is a sporadic stream with the properties provided by Equa-
tions 6.61 and 6.62.
6.7 Summary
We have seen that the timing of events in a stream can be controlled by
means of buffers and timers in order to modify specific properties of a stream
such that new model transformations are enabled, in addition to those of the
previous chapter. Such event adaptation functions improve the usability and
compatibility of standard event models in flow-based scheduling analysis fur-
ther.
Two fundamentally different shaping techniques have been introduced. The
event model transformations that have been enabled by these two shaper types
are illustrated as bold arrows in Figure 6.29. Periodic shaping is used to re-
synchronize periodic streams with jitter and burst to their original period. Spo-
radic shaping reduces transient burst frequencies for all stream types, and al-
lows to virtually re-synchronize sporadic streams. The buffer requirements and
delays that shaping introduces have been thoroughly investigated and formal
frameworks for calculating bounds on delays and backlogs have been devel-
oped.
We have carried out an experiment, which illustrates that the impact of shap-
ing depends heavily on the choice of the shaper. By varying the shaping type,
Summary 155
periodic or sporadic, and the time-out value, designers can deliberately control
and optimize the system behavior. We call such optimizations user-controlled
shaping that we distinguish from automatic shaping, which allows the system-
atic reduction of shaping backlogs and delays, whilst still meeting given input
requirements.
Finally, we have analyzed the situation of input polling. Polling is basi-
cally an implementation choice for a task rather than an operation on an event
stream. The influence of polling on buffers and event timing, however, is
strongly related to shaping. Depending on the specific situation, polling can
be formally seen as either type of shaping, and the derived formal framework
allows calculation of buffer sizes and delays also for systems with polling. We
have shown that, and how, the event stream view helps to optimize the output
stream accuracy in the presence of polling.

Chapter 7
SYSTEM-LEVEL ANALYSIS PROCEDURE
Each of the four preceding chapters provides one important concept that
lets us a) capture component inputs and task activation as a pre-requisite for
scheduling analysis, b) model and provide a relation between inputs and out-
puts of a task or a component, influenced by scheduling and execution, c) pro-
vide appropriate event model interfaces to match the analysis requirements,
and d) apply appropriate event stream adaptation to facilitate the interfacing
step (or to optimize the scheduling).
These concepts cover the key local aspects of scheduling and response time
analysis in a system-level context. This chapter integrates these individual con-
cepts and uses them as hand tools to apply the flow-based analysis approach,
as introduced in Section 2.3, to systems with multiple heterogeneous event
models.
We start with a brief review of the introduced formalisms and define an ap-
propriate system analysis model. In order to extend the iterative flow-based
approaches from Thiele [116] and Gresser [38, 39] to support heterogeneous
event models, we have to insert an appropriate event model interfacing step.
We will see that these interfaces not only enable this new analysis procedure,
but that adaptations also allow control of the streams during the analysis and
integration process, and to globally optimize the system. This is of particu-
lar importance in systems where the mixture of architectural and functional
influences leads to complex and confusing cyclic dependencies and schedul-
ing anomalies. These can turn the iterative analysis into a convergence prob-
lem, and we identify monotonicity properties to formulate termination condi-
tions. We show how bottlenecks and pitfalls can be identified, resolved, and
optimized using this new analysis procedure. We use expressive examples to
demonstrate the individual steps as well as the overall analysis.
158 System-Level Analysis Procedure
T1
T2
(C1,P1)
T3
(C3,P3)(C2,P2)
CPU
1
S1,out
S2,in
S3,in
S1,4
S3,5
R1
R2
R3
TX
SX,out=SX,1=S1,in
T6
BUS
2
T5
(C4,P4)
(C6,P6)(C5,P5)
R4
R5
R6
T4 TY
S4,out=S4,Y=SY,in
T8
BUS
2
T7
CPU
2
T9
T6
(C7,P7)
R7
Figure 7.1. System Model Example
7.1 System Analysis Model
We summarize the required elements, parameters, and the overall structure
using part of an example system as illustrated in Figure 7.1.
7.1.1 Model Elements and Parameters
The system consist of a set of tasks Ti. Each task Ti is mapped to a resource
RSCj and is scheduled there according to the resource’s scheduling strategy.
Each task has two mapping-specific parameters: the core task time Ci and the
scheduling parameters Pi. We do not further distinguish between computation
tasks (processes) and communication tasks (channels, links, etc.). Both require
a net resource access time (Ci). The actual response time Ri defines the time
between the occurrence of the request (activation time) and the time this re-
quest has been successfully served (completion). Both the core task time and
the response time are intervals with upper and lower bounds.
7.1.2 Model Structure and Dependencies
The response time Ri abstracts from the detailed scheduling influences that
task Ti experiences due to e. g. preemptions by other tasks. It represents the
tasks externally observable execution or communication timing behavior. The
interaction with other tasks is captured using event streams: an input event
The System-Level Analysis Procedure 159
stream Si,in and an output event stream Si,out. Through these uni-directional
streams, tasks communicate with each other. The output stream Si,out of task
Ti becomes the input stream Sk,in of task Tk, the stream itself is denoted Si,k.
Each task must have exactly one input stream, while a task’s output can be
connected to several task’s inputs. In the example of Figure 7.1, the output of
T1 is connected to two tasks, T7 and T4, respectively. This allows task trees to
be captured.
7.1.3 Environment Modeling
Tasks TX and TY are environmental tasks that model timing constraints and
assertions of the environment that the system is embedded in. Task TX is an
environmental source task that provides information about the timing of the
primary inputs to the system, such as an actuator connected to CPU1. TY is
an environmental sink task that also has a certain timing behavior represent-
ing a timing constraint, such as a maximum bound on the allowed jitter or a
maximum sporadic period. Using event streams and models, not only within
the system but also between the system and its environment, we can elegantly
model environmental assertions and constraints without requiring additional
concepts.
7.1.4 Local Scheduling
The event streams are the key integrating elements in this proposed analysis
approach. Each resource RSCj has one local analysis method associated that
calculates the response time Ri of the tasks as reviewed in Section 2.1. The
analysis takes as input the following parameters of each task Ti mapped on that
resource: the core task time Ci, the scheduling parameter Pi, and the activating
event stream Si,act.
The analysis requires the activating stream to comply with an analysis-
dependent input event model requirement Rj,in as introduced in Chapter 5. In
order to meet this requirement, the actual input stream Si,in might need to be
appropriately transformed by means of event model interface and/or automatic
shapers as introduced in Chapters 5 and 6.
After analyzing the scheduling, the output event stream Si,out is determined
from the input stream and the response time using a function O(Ri,Si,in). We
thoroughly discussed the dependencies between response times and input and
output streams in Chapter 4.
7.2 The System-Level Analysis Procedure
Figure 7.2 provides an abstract view of the overall system-level analysis
procedure consisting of 7 steps and a set-up step (step 0). The overall idea
of iterative event stream propagation is not fully new, it has been proposed
160 System-Level Analysis Procedure
FAILED!
no
no
derive output event streams
can input be captured?
choose analyzable resource
propagate streams globally
capture primary system inputs
0
1
2
4
5
constraints met ?
6
all resources analyzed ?
7no
yes
SUCCESS!
yes
yes
resource schedulable ?
no
yes
3
Figure 7.2. System-Level Analysis Procedure
by Gresser [38, 39] and Thiele et. al. [116]. The novelty of our approach is
that is allows the use of known local analysis techniques, that possibly require
heterogeneous event models, enabled by event model interfacing and stream
adaptation.
Step 0: Capturing Primary System Inputs
The primary system inputs are represented as environmental source tasks. We
introduced environmental modeling in Section 7.1.3. The environment speci-
fication determines the input event streams of the directly connected tasks:
∀Sa,b, a ∈ {Tenv} : Sb,in = Sa,out (7.1)
Step 1: Choosing an Analyzable Resource
Scheduling analysis requires the activation of all tasks to be known. Hence, we
can only analyze a resource when the activating event streams are known, in
turn requiring that the input streams are known for all tasks on that resource.
In the beginning, these are usually the ones which are connected to the primary
system inputs.
Step 2: Capturing Task Activation
After selecting a resource for analysis, we have to capture the activation of all
tasks in a way suitable for the analysis. This might impose an analysis-specific
The System-Level Analysis Procedure 161
can input be captured?input
requirement
met?
exists
appropriate
EMIF?
insert EMIF
no
exists
appropriate
EAF?
no
no
possibly insert additional shaper for optimization purposes
yes
yes
yes
insert minimum shaper
2
Figure 7.3. Input Event Stream Capturing
input model requirement Ri,in on the task input streams. Depending on the
situation, this step might incorporate several sub-steps illustrated in Figure 7.3.
We have to apply the procedure to each task separately.
We start with testing whether the input stream meets the requirement (see
Section 5.2):
Si,in
?∈ Ri,in (7.2)
If the test is successful, the input stream already represents the activating
stream that can be used for scheduling analysis (in step 3):
Si,act = Si,in (7.3)
If test 7.2 fails, we look for an event model interface that transforms the in-
put stream representation into a representation suitable for analysis. We apply
the requirement coverage test from Definition 5.4:
RC(Si,in,Ri,in) != 1 (true) (7.4)
If the test is successful, we can insert the appropriate EMIFs introduced in
Chapter 5 to transform the input stream into an activating stream that meets the
input requirement:
Si,act = EMIFEMi,in→EMi,req(Si,in) ∈ Ri,in (7.5)
162 System-Level Analysis Procedure
If also test 7.4 fails, we try inserting an automatic shaper (see Definition 6.1),
that reduces too high transient loads or fully eliminates jitters. Then, we check
if the resulting shaped stream meets the input requirement, possibly with an
additional EMIF :
Si,shaped = EAF auto(Si,in,Ri,in)
RC(Si,shaped,Ri,in) != 1(true)
When even automatic shaping does not help, the input stream can simply not
be reasonably transformed into the required representation. In effect, (at least
some of) the tasks on that resource will not be analyzable by the next step, and
we can terminate the iterative analysis procedure. There are two classes of rea-
sons for such failures: First, to prevent inputs that lead to permanent overload,
a task might have a minimum allowed average period, reflecting a maximum
average execution frequency. Input streams that have a smaller average period
are not acceptable. Second, there might be a general mismatch between the in-
tended behavior of the producer task and the consumer task, for instance both
have different periods but were assumed to execute in strong relationship with
each other. Either source of failure represents a well-known system integration
problem. The event stream view implicitly detects such integration problems.
In case of a successful activation modeling, i. e. all input streams can be
transformed to meet the corresponding task input requirements, a user might
consider additional local optimizations using periodic or sporadic shaping. We
have shown the impact of such user-controlled shaping in Section 6.4.3. A spe-
cial case where such local optimizations help to globally increase the schedu-
lability of the system, is discussed in Section 7.7.
Step 3: Local Scheduling Analysis
When all task activation models are known from the previous step, the schedul-
ing on the selected resource can be analyzed. For local scheduling analysis, a
big variety of techniques is available from the real-time systems community.
We reviewed popular techniques and landmark publications in Section 2.1. In
addition to the task activation models, these techniques require the core execu-
tion time Ci as well as the scheduling parameters Pi of each task to be known.
The scheduling analysis returns the response time Ri of each task which deter-
mines the externally observable timing behavior of a task.
This is the second step of the overall procedure that can fail. An example
is a permanent overload situation that clearly makes some, if not all tasks un-
schedulable. Less obvious examples are situations where the system is in fact
schedulable but the analysis has limitations that prevent it from calculating a
bounded response time. The initial proposal for rate-monotonic analysis [73]
Local and Global Constraint Veriﬁcation 163
is such an example. Response times larger than periods are just not considered.
In either case, the local analysis cannot determine a response time for a subset
of tasks. Again, the systematic procedure and the event stream view help in
identifying a potential modeling insufficiency or a performance bottleneck.
Step 4: Determining the Output Streams
We have shown in Chapter 4 that the output stream is a function of the input
stream and the response time:
Si,out = O(Si,in, Ri)
If available, additional information about the implementation of a task, for
instance polling characteristics (see Section 6.6), can further tighten the output
stream calculations.
Step 5: Propagating Event Streams Globally
In this step, the just obtained output streams are propagated to the inputs of the
connected tasks in the application:
Sk,in = Si,out
Step 6: Constraint Veriﬁcation
When all tasks have been successfully analyzed, the system is schedulable,
in general meaning that no permanent overload conditions occurred, and we
can check if the given constraints are met. We have already mentioned that
environmental sink tasks can be used to model constraints on event steams
that enter the environment, and there is a variety of additional possibilities to
verify other system properties such as local deadlines, buffer constraints and
path latencies, which we explain in Section 7.3. If one of these constraints is
violated, the analysis can be aborted.
Step 7: Iteration
Now, the whole process iterates from the beginning. During the iteration, event
streams are propagated through the system of locally analyzable components,
from the primary system inputs to the system outputs, i. e. to the environmental
sink tasks. The iteration is successfully completed when all resources have
been analyzed, and fails if either not all task inputs could be appropriately
transformed to meet requirements, or a bounded response time could not be
determined for all tasks, or another constraint is violated.
164 System-Level Analysis Procedure
7.3 Local and Global Constraint Veriﬁcation
7.3.1 Environmental Constraints
A dedicated period and a maximum allowed jitter at the interface between
the system outputs and the environment is a popular example for an environ-
mental constraint. It can be elegantly modeled using a virtual sink task with an
appropriate input requirement:
Rsink,in = {SP+J ∈ EMP+J|T = Tsink, J ≤ Jsink}
As another example, a maximum allowed frequency can be modeled using a
sporadic input requirement. As they use virtually the same modeling concepts,
the environmental source and sink tasks can be included in the analysis proce-
dure, and the requirements are automatically checked during step 2. Moreover,
stream transformation using EMIFs and EAFs is considered representing an
automatic output adaptation. However, in our examples later, this particular
check is delayed and considered after the system has been fully analyzed.
7.3.2 Internal Event Streams
The event streams capture in detail the interaction between tasks and pro-
vide information about the resource access patterns of individual tasks. The
additional delays and the buffer memory that is required because of shaping
allows the impact of such shaping decisions on the overall system timing and
performance to be determined.
7.3.3 Local Task and Resource Properties
The local response times as a direct result from the individual task schedul-
ing analysis allow the actual execution timing to be checked against the ex-
pected timing and/or local constraints such as a deadline. It furthermore pro-
vides information about each individual task’s performance for a given map-
ping of tasks to resources.
The total load or utilization of each resource in the system allows the iden-
tification of bottlenecks, as well as the remaining performance in the architec-
ture. In practice, this can be of particular importance for selecting components
(resources) to be optimized in terms of speed and performance, e. g. bus band-
width.
7.3.4 Path Constraints
From the mentioned local timing properties we can determine key global
timing and performance properties. Very often, it is not the individual tasks that
are constrained to exhibit a certain timing behavior. Rather, the interactions of
several tasks form a system function that is required to meet a certain deadline.
Local and Global Constraint Veriﬁcation 165
TX
S1,EAF
T2
R2
S2,3
T3
R3
SX,1
T1
R1
TY
S3,Y
SEAF,2
delay
EAF
PL1=R1+delayEAF PC1
PL2=R1+delayEAF+R2+R3 PC2
!
!
P1={T1,EAF}
P2={T1,EAF,T2,T3,}
Figure 7.4. Path Latencies and Constraints
Such system functions usually span a whole path from primary system inputs
to primary system outputs, including several tasks and event streams.
Definition 7.1. (Path)
A path Pi is a connected set of tasks, shapers, and event streams. A path must
have a dedicated starting element, and a termination element, and at most one
output event stream of each task can be included in that path, prohibiting a path
from containing branches.
Definition 7.2. (Path Constraint)
A Path Constraint PCi is a positive real that bounds the allowed maximum
time each event requires to travel along that path Pi.
To check the compliance with such path constraints, we need to determine
the actual path latency or path delay by accumulating the delays of the individ-
ual path elements.
Definition 7.3. (Path Latency)
The accumulated task response times and shaping delays of all elements in a
path Pi yield the Path Latency PLi:
PLi =
∑
Tj∈Pi
RTj +
∑
EAFk∈Pi
delayEAFk (7.6)
The path latency is an interval, and the upper and lower bounds are determined
by accumulating the corresponding upper and lower bounds of the response
times and shaping delays.
Figure 7.4 shows three system tasks, one sink and one source task, and one
shaper, which are connected as a path with five event streams. Two paths
P1 and P2 are shown together with their respective latencies. These paths
166 System-Level Analysis Procedure
represent chains in the application and could possibly be specified by their
start and end node –task or shaper. Other work allows also functional cycles to
be included in a path [140, 52], that are not considered further here.
7.3.5 Buﬀer Constraints
The execution backlog of all tasks on one resource determines (together
with the “size” of the data that the events might carry) the total required in-
put buffers which might be constrained because of limited memory for that
resource. Likewise, the shaping backlog of all elements provides the memory
required for shaping. We mentioned that such shaping can be elegantly done
by operating system functions or hardware drivers that adds to the overall re-
quired memory. The required execution and shaping backlogs along a path
also provide interesting information about the “bottleneck distribution” along
a path.
7.4 Cyclic Event Stream Dependencies
So far, we have assumed that we can always find a resource with all input
streams known in each analysis iteration (step 1). Unfortunately, this is not
necessarily the case. Recall the example system from the introduction. We
highlighted a non-functional dependency cycle in Figure 1.5. The two key
components, the CPU and the bus, are mutually dependent on each other with
respect to the event streams. Each resource requires an output stream of the
other one to be known before it can be analyzed. In such situations the primary
system inputs do not provide a starting point for the analysis procedure of
Section 7.2, since no resource has all input streams known.
It is important to recognize that such dependency cycles can turn the itera-
tive analysis procedure into a convergence problem as illustrated in Figure 7.5,
and we are facing two key challenges: We have to find a reasonable start-
ing point for the iterative procedure and we have to guarantee convergence, or
find a reasonable termination condition. The detailed analysis of the impact
of scheduling and execution on output event streams in Chapter 4 provides us
with a basic approach.
7.4.1 The Starting Point
We know that execution and scheduling adds jitter characteristics to event
streams from task inputs to task outputs, i. e. the jitter grows from input to
output at each local analysis while the original input period is preserved at the
output, regardless whether periodic or sporadic. We can exploit this behavior
and start the actual analysis procedure by propagating all input streams from
the primary system inputs through the system without considering the influence
of scheduling. In other words, we simply “copy” the input stream of a task to
Cyclic Event Stream Dependencies 167
fo
r 
e
a
c
h
 r
e
s
o
u
rc
e
no
generate starting point
FAILED!
no
derive output event streams
can input be captured?
2
4
yes
resource schedulable ?
no
yes
3
no
propagate streams globally
5
constraints met ?
6
yes
SUCCESS!
yes
convergence?
Figure 7.5. System-Level Analysis Turns into a Convergence Problem
its output, and we do this for all tasks. This is the stating point for the cyclic
analysis.
7.4.2 Cyclic Analysis
In the first analysis cycle, we analyze each resource exactly once. More
precisely, we apply the steps 2, 3, and 4 to all resources, on after another (see
Figure 7.5). In that analysis cycle, the response time interval of all tasks are
determined. If the response time interval of each task has identical upper and
lower bounds, i. e. the response time would be constant, then the output jitter
would equal the input jitter, which was already given by the starting point. In
other words, the analysis would have already converged.
If at least one task has a non-constant response time, then the width of the
response time interval determines the new output jitter of that task. This inval-
idates the initial starting-point assumptions. Consequently, we propagate the
output streams of all tasks to the inputs of all connected tasks (step 5), check
if the constraints are met (step 6), and have to perform a second analysis cycle,
that re-analyzes the tasks on all resources whose input jitters have changed.
After the second analysis cycle, we have to check again, whether the output
jitters have increased, and possibly perform another analysis cycle, and so on.
The analysis is completed when the cyclic procedure converges, i. e. no output
jitter values increase anymore. The entire cyclic procedure including the con-
168 System-Level Analysis Procedure
vergence test is illustrated in Figure 7.5. The important question is: Does the
analysis converge, and when?
7.4.3 Convergence and Termination
When we take a closer look on the consequences of increasing input jitter
of a task, we can distinguish two effects. First, the output jitter of that task
will also increase because of the jitter inheritance phenomenon, that we men-
tioned in Section 4.1.3. This inheritance applies to all tasks along paths in
the system. The second effect of increasing input jitters is scheduling distor-
tion. An increasing input jitter distorts the scheduling and potentially increases
the amount of worst-case interference, consequently increasing worst-case re-
sponse times. Conversely, the best-case response times decrease, finally re-
sulting in larger output jitters. This also shows that our initial assumption is
valid, since the initial input streams with smaller jitters are covered by all later
input streams with a possibly larger jitter. In other words, the initially assumed
system behavior is still included in the possible behavior of all later steps.
Convergence criteria and the actual time-complexity of the entire analysis,
however, are extremely complex to determine, even though we know the influ-
ences that let jitters and response times increase. We could at best bound the
number of analysis cycles, but the overall complexity also depends strongly
on the complexity of the local analysis algorithms. These are embedded in
the global cyclic analysis procedure and could possibly pose further questions
to numerical convergence and stability. The holistic analysis approach (see
Section 2.2.2), that seeks an iterative solution of a complex set of recursive
system-level timing equations, is faced with a comparable convergence prob-
lem. This, however, has not even been solved there, although many groups
continuously extend and enhance the related holistic equations and algorithms.
In this thesis, we will not investigate this issue further, since we can formulate
a reasonable termination condition that allows the efficient application of the
cyclic analysis procedure in practice.
We know that, in case of fixed-priority scheduling, the interference of a task
is the sum of integer multiples of the core execution time of other tasks on the
same resource (see Equation 3.22). Likewise, in time-driven scheduling, the
interference is an integer multiple of one or more slot times (see Equation 2.9),
etc.. Consequently, the amount of interference can only increase in discrete
steps; and the minimum increment is bounded by, for instance, the minimum
core execution time, the smallest slot time, or the execution time of some oper-
ating system function. In effect, the response times and the output jitters of at
least some tasks will monotonically grow with a minimum “speed”. This mini-
mum speed prevents the jitters and response times from asymptotic expansion.
Sooner or later, the analysis will either successfully converge, or a constraint
will be violated, and the analysis can be safely terminated. This lets us bound
Example 169
EAF
3
EAF
2
EAF
1
M2DSP
IP2M3IP1
HW
M1CPU
Sens
sporadic
w/ jitter
C1
C3
bus
C2
periodic
w/ burst
periodic
w/ jitter
simple
sporadic
periodic
simple
periodic
T3T1
fmax=1,7kHz, s=8kB
f=140kHz, s=1kB
f=20kHz
s=3kB
8kBo 32u ( 256 + 6 ) byte
1kBo 1u ( 1024 + 6 ) byte
3kBo 24u ( 128 + 6 ) byte
simple
sporadic
periodic
periodic
w/ burst
Figure 7.6. Detailed System Example
the number of analysis cycles from the given deadlines, path constraints, en-
vironmental sink constraints, and task input requirements. As an additional
advantage, the global solution procedure proposed tightly follows the event-
and data-flow in the system. This makes the cyclic analysis, especially with
respect to convergence issues, easily comprehensible.
7.5 Example
Now, we demonstrate the applicability of the approach by fully analyzing
the example from the introduction (see Figure 1.2) where we have integrated
two functionally independent sub-systems using a shared bus. The CPU sub-
system consists of a sensor that eventually sends data that must be processed
by the CPU. In turn, the CPU accesses a hardware accelerator (HW). The DSP
sub-system runs a highly optimized digital signal processing application and
the communication over the bus is critical. We have highlighted the key analy-
sis challenges in Section 1.1 including cyclic dependencies and model incom-
patibilities.
7.5.1 System Set-Up
Figure 7.6 provides a detailed view on the entire system. The individual
components are now specified.
170 System-Level Analysis Procedure
7.5.1.1 The Primary System Inputs
There are three inputs to the system: The sensor sporadically sends data
blocks of 8kb size to task T1, with a maximum sending frequency of 1, 7kHz,
which corresponds to a sporadic event model with a minimum sporadic period
of 11,7kHz = 588µs. Task T3 is periodically activated by an RTOS (real-time
operating system) timer on the CPU with a period of 120kHz = 50µs. The high-
performance DSP application on the IP1 component has a sending frequency
of 140kHz, corresponding to a period of 7, 14µs.
These inputs are modeled as environmental source tasks. The formal event
stream definitions are:
Ssens = SS(Tsens = 588.2)
Stimer = SP(Ttimer = 50)
SIP = SP(TIP = 7.14)
7.5.1.2 The Bus Timing
The communication over the bus is implemented using a non-preemptive
static priority protocol. Instead of sending the complete data blocks as a sin-
gle transmission, the data is fragmented into smaller packets to avoid extended
blocking times (see Section 2.1.2.4). Each 8kB data block from the sensor is
split into 32 packets of 262byte each, 256bytes plus 6bytes protocol overhead–
address, length, and CRC. The 3kB blocks from task T3 are split into 24 pack-
ets of (128+6) = 134bytes. This channel C2 has a higher priority than channel
C1. The highest-priority channel C3 does not split the DSP data packets, but
only adds the 6byte protocol information.
The actual network speed is 300Mbyte/s. Hence, the actual core commu-
nication times are:
CC1 = 32× (256 + 6)byte×
1s
300Mbyte
= 27.95µs
CC2 = 24× (128 + 6)byte×
1s
300Mbyte
= 10.72µs
CC3 = 1× (1024 + 6)byte×
1s
300Mbyte
= 3.43µs
Because the communication of an individual packet cannot be preempted,
the higher-priority channels can experience blocking by lower-priority commu-
nications. The longest packets that can block other communications are sent
by the sensor, hence it determines the blocking times of the other channels:
Example 171
BC2 = BC2 = (256 + 6)byte×
1s
300Mbyte
= 0.87µs
The overall average network usage Unet is:
Unet = Usens + UCPU + UDSP
= 1, 7kHz × 32× 262byte + 20kHz × 24× 134byte
+140kHz × 1× 1030byte
= 14, 2528Mbyte/s + 64, 32Mbyte/s + 144, 2Mbyte/s
= 222, 77Mbyte/s
With respect to the actual bus speed, the utilization is:
Unet = Unet300Mbyte/s = 74, 3% (7.7)
7.5.1.3 The Task Core Execution Timing
For simplicity, the core execution times of the two tasks on the CPU are
assumed constant. This is not a restriction of the local analysis, nor of the
overall global analysis approach, but it simplifies the discussion of the results:
CT1 = 250
CT3 = 10
In addition, we model the operating system influence using blocking times for
both tasks T1 and T3:
BT1 = 15
BT3 = 15
7.5.1.4 Constraints
The hardware block HW as well as the signal processor (DSP) are impos-
ing constraints on their input timing. Due to its limited execution speed, the
frequency of the input to the hardware block is constrained by:
fHW,max = 50kHz =
1
20µs
The DSP requires fully periodic inputs in order to run a set of signal processing
applications with a highly optimized cyclic schedule. The frequency equals the
172 System-Level Analysis Procedure
Figure 7.7. SymTA/S Model of Example System
sending frequency of the IP sub-system, since both components were initially
directly connected (see Figure 1.2):
fDSP,in = 140kHz =
1
7.14µs
These constraints translate into input model requirements (see Section 5.2)
for the two corresponding tasks:
RDSP,in = {SP(TDSP = TIP = 7.14)} ⊂ EMP
RHW,in = {SS(THW)|THW ≥ 20)} ⊂ EMS
7.5.2 Analysis Set-Up
To perform the analysis, we use the SymTA/S tool which we have developed
in our group. Figure 7.7 shows the example system in the editor window of the
tool. Environmental tasks have a gray body, while scheduled tasks that must
be analyzed are yellow (and turn white after successful analysis). The icons in
the task ports abstractly illustrate the general shape of the η(∆t) event curves
and provide a quick visualization about the event model, in which the stream
is represented.
Iterative Analysis 173
The specific properties of the sensor and the IP sub-system are captured
as environmental source tasks, and the HW block as well as the DSP sub-
system as environmental sinks. An output port icon denotes the event model
in which the actual output stream is provided: periodic for the IP component
and the RTOS timer, sporadic for the sensor. An input port icon visualizes
an event stream requirement: periodic for the DSP and sporadic for the HW
component. The character “a” in the input ports of the tasks and channels show
that the analysis can cope with any input event model, i. e. there is no specific
input model requirement. The system has just been initialized, i. e. a starting
point has been generated according to Section 7.4.1 by propagating the event
streams from the task inputs to task outputs.
Local Analysis Technique
For the local scheduling analysis on both the CPU and the bus, we have slightly
modified the analysis technique from Lehoczky [69] and Tindell [121] (see
also Sections 2.1.2.2 and 3.3.2) to support our six-class event model set. For
the best-case response time, we use an approximation algorithm [90].
7.6 Iterative Analysis
We will now apply our novel analysis procedure to the given system. We
will perform several analysis cycles until all event streams –especially the
jitters– converge, and we shall report in detail on the results of each individual
cycle.
7.6.1 Analysis Cycle 0: Starting Point Generation
As introduced in Section 7.4.1, we first propagate all event streams from
environmental sources through the system following the task dependencies in
order to generate a reasonable starting point for the iterative analysis proce-
dure:
ST1,in(0) = SC1,out(0) = SC1,in(0) = Ssens = SS(588.2)
SDSP,in(0) = SC3,out(0) = SC3,in(0) = SIP = SP(7.14)
SHW,in(0) = SC2,out(0) = SC2,in(0) = ST3,out(0) = ST3,in(0) = Stimer = SP(50)
7.6.2 Analysis Cycle 1
We apply these event streams of step 0 as the actual inputs of step 1 and
analyze the CPU and the bus independent from each other.
174 System-Level Analysis Procedure
Figure 7.8. CPU Scheduling Diagram of First Analysis Cycle
7.6.2.1 CPU Analysis
The input streams of the two tasks on the CPU are:
ST1,in(1) = ST1,in(0) = SS(588.2)
ST3,in(1) = ST3,in(0) = SP(50)
The local analysis of Section 7.5.2 does not impose any input event model
requirements, so we can directly use the input streams to capture task activation
(step 2) and perform the local analysis (step 3). This yields the following
response times:
R+T1
(1) = 265 R−T1
(1) = 250
R+T3
(1) = 275 R−T3
(1) = 10
The scheduling diagram in Figure 7.8 shows the critical instant of task T3.
Due to the preemption by T1 and the additional blocking time BT3 the sixth
activating event arrives before the first execution starts. This leads to a bursty
execution behavior of task T3 and an execution backlog that must be appropri-
ately buffered. The execution backlog of task T1 is one:
backlogT1
(1) = 1 backlogT3
(1) = 6
With the functions defined in Chapter 4, we determine the task output event
streams (step 4):
ST1,out(1) = SS+J(TT1,in(1), JT1,R(1)
= SS+J(588.2, 15)
ST3,out(1) = SP+B
(
TT3,in
(1), JT3,R
(1),max(TT3,in
(1) − JT3,R(1), R−T3
(1))
)
= SP+B(50, 265, 10)
Iterative Analysis 175
Figure 7.9. Bus Scheduling Diagram of First Analysis Cycle
Finally, we propagate the output stream of task T3 (step 5) to be considered in
the second analysis cycle:
SC2,in(2) = ST3,out(1) = SP+B(50, 265, 10)
7.6.2.2 Bus Analysis
These updated values from CPU analysis are not yet considered in the first
cycle. Rather, the input streams of the three channels are still determined by
the initial starting point assumptions:
SC1,in(1) = SC1,in(0) = SS(588.2)
SC2,in(1) = SC2,in(0) = SP(50)
SC3,in(1) = SC3,in(0) = SP(7.14)
The response times are:
R+C3
(1) = 4.3 R−C3
(1) = 3.43
R+C2
(1) = 25.31 R−C2
(1) = 17.58
R+C1
(1) = 97.41 R−C1
(1) = 72.97
The scheduling diagram of the critical instance of channel C1 in Figure 7.9
shows that there is no self-interference, and the communication backlog of all
channels is one:
backlogC1
(1) = backlogC2
(1) = backlogC3
(1) = 1
176 System-Level Analysis Procedure
Figure 7.10. CPU Scheduling Diagram of Second Analysis Cycle
We combine steps 4 and 5 and obtain:
SDSP,in(2) = SC3,out(1) = SP+J(TC3,in(1), JC3,R(1)
= SP+J(7.14, 0.87)
SHW,in(2) = SC2,out(1) = SP+J(TC2,in(1), JC2,R(1)
= SP+J(50, 7.73)
ST1,in(2) = SC1,out(1) = SS+J(TC1,in(1), JC1,R(1)
= SS+J(588.2, 24.44)
7.6.3 Analysis Cycle 2
7.6.3.1 CPU Analysis
While task T3 has a constant timer-generated input, we now use the output
stream of channel C1 from the first analysis cycle as the input stream of the
second cycle for task T1:
ST1,in(2) = SC1,out(1) = SS+J(588.2, 24.44)
ST3,in(2) = Stimer = SP(50)
Figure 7.10 shows the CPU scheduling diagram of this second analysis cycle.
Compared to Figure 7.8, we see that the second activation of task T1 arrives
earlier than in the previous analysis cycle. The reason is the input jitter that
has increased: while assumed zero in the first cycle (due to the starting point
generation), it now inherits the scheduling effects of channel C1 on the bus that
are a result of the first analysis cycle (Section 7.6.2.2). This, however, does not
yet affect the critical instant of task T3, and we obtain the same response times
and backlogs as in the first cycle:
R+T1
(2) = 265 R−T1
(2) = 250 backlogT1
(2) = 1
R+T3
(2) = 275 R−T3
(2) = 10 backlogT3
(2) = 6
Iterative Analysis 177
Figure 7.11. Bus Scheduling Diagram of Second Analysis Cycle
While these values remain constant, the output jitter of task T1 increases be-
cause it inherits the increased input jitter:
ST1,out(2) = SS+J(TT1,in(2), JT1,in(2) + JT1,R(2))
= SS+J(588.2, 39.44)
ST3,out(2) = SC2,in(3) = SP+B
⎛
⎜⎝ TT3,in
(2),
JT3,R
(2),
max(TT3,in
(2) − qJT3,R(2), R−T3
(2))
⎞
⎟⎠
= SP+B(50, 265, 10)
7.6.3.2 Bus Analysis
Channels C1 and C3 are connected to environmental source tasks, so only
the input of channel C2 is updated:
SC1,in(2) = SC1,in(0) = SS(588.2)
SC2,in(2) = ST3,out(1) = SP+B(50, 265, 10)
SC3,in(2) = SC3,in(0) = SP(7.14)
The tremendous increase of the input jitter of channel C2 leads to communi-
cation bursts that can be seen in the scheduling diagram of Figure 7.11. We
can see that the seventh event in that burst arrives (at ∆t = 60) even before
the third packet has been completely communicated, leading to long worst-
case response times for both channels C2 and C1 and increasing communica-
tion backlogs. To analyze the burst, we have to use the windowing techniques
mentioned in Section 7.5.2:
R+C3
(2) = 4.3 R−C3
(2) = 3.43 backlogC3
(2) = 1
R+C2
(2) = 87.94 R−C2
(2) = 17.58 backlogC2
(2) = 5
178 System-Level Analysis Procedure
Figure 7.12. CPU Scheduling Diagram of Third Analysis Cycle
R+C1
(2) = 283.07 R−C1
(2) = 51.96 backlogC1
(2) = 1
The propagated output streams are:
SDSP,in(3) = SC3,out(2) = SP+J(TC3,in(2), JC3,R(2))
= SP+J(7.14, 0.87)
SHW,in(3) = SC2,out(2) = SP+B(TC2,in(2), JC2,in(2) + JC2,R(2))
= SP+B(50, 335.36, 17.58)
ST1,in(3) = SC1,out(2) = SS+J(TC1,in(2), JC1,in(2) + JC1,R(2))
= SS+J(588.2, 231.11)
7.6.4 Analysis Cycle 3
7.6.4.1 CPU Analysis
The input jitter of T1 has further increased:
ST1,in(2) = SC1,out(1) = SS+J(588.2, 231.11)
ST3,in(2) = Stimer = SP(50)
However, this has still no critical effect on the worst-case scheduling, illus-
trated in Figure 7.12. Again, we obtain the same response times and backlogs
as in the previous cycles:
R+T1
(3) = 265 R−T1
(3) = 250 backlogT1
(3) = 1
R+T3
(3) = 275 R−T3
(3) = 10 backlogT3
(3) = 6
Iterative Analysis 179
Only the output jitter of task T1 increases:
ST1,out(3) = SS+J(TT1,in(3), JT1,in(3) + JT1,R(3))
= SS+J(588.2, 246.11)
ST3,out(3) = SP+B
(
TT3,in
(3), JT3,R
(3),max(TT3,in
(3) − JT3,R(3), R−T3
(3))
)
= SP+B(50, 265, 10)
7.6.4.2 Bus Analysis
When we look at the bus input streams, we see that these have not changed
compared to the previous analysis cycle:
SC1,in(3) = SC1,in(2) = SS(588.2)
SC2,in(3) = SC2,in(2) = ST3,out(2) = SP+B(50, 265, 10)
SC3,in(3) = SC3,in(2) = SP(7.14)
Hence, the bus does not need to be analyzed in this cycle, nor do the output
streams change:
SC1,out(3) = SC1,out(2) = SS+J(588.2, 231.11)
SC2,out(3) = SC2,out(2) = SP+B(50, 335.36, 17.58)
SC3,out(3) = SC3,out(2) = SP+J(7.14, 0.87)
7.6.5 Analysis Cycle 4: Termination
Because the bus outputs have not changed in the previous cycle, the CPU
inputs have also not changed:
ST1,in(4) = ST1,in(3) = SC1,out(3) = SS+J(588.2, 231.11)
ST3,in(4) = ST3,in(3) = SP(50)
Now, both components no longer change their input-output streams, and the
entire analysis procedure has successfully terminated.
7.6.6 Sink Task Input Requirements
After the analysis of the internal system behavior, we finally check if the
external behavior meets the requirements of the environmental sink tasks (see
Section 7.5.1.4). In Section 7.2/Step 2, we have introduced the sub-steps for in-
put stream capturing that possibly require event model interfacing and/or adap-
tation. The same concepts can be used to match the event model constraints
imposed by environmental sink tasks.
180 System-Level Analysis Procedure
EAF
1
M2DSP
periodic
C2
periodic
w/ burst
periodic
w/ jitter
C3
HW
simple
sporadic
EAF
2
Figure 7.13. Required Event Adaptation Functions EAF
We start with the DSP sub-system and see that the actual output stream from
channel C3 does not meet the input requirement of the DSP:
SC3,out = SP+J(7.14, 0.87) /∈ RDSP,in ⊂ EMP (7.8)
There is no plain event model interface for this model combination, and we
must eliminate the jitter by means of an adaptation function. We apply auto-
matic shaping from Section 6.5, and we obtain a periodic shaper with a buffer
size of 1 and a maximum buffering delay of 8.01 time units. This is inserted as
EAF1 between channel C3 and the DSP, illustrated in Figure 7.13. The actual
input to the DSP is determined by Equation 6.53:
SDSP,in = EAF auto,1(SEAF1,in,RDSP,in)
= EAF auto,1(SC3,out, {SP(TDSP = TIP = 7.14)})
= SP(7.14) ∈ RDSP,in (7.9)
The actual input stream of the HW component does not meet the require-
ment, either:
SC2,out = SP+B(50, 335.36, 17.58) /∈ RHW,in ⊂ EMS (7.10)
For this situation, an event model interface exists, and we derive the trans-
formed HW input stream according to Section 5.7.7. However, the sporadic
period is too little and not supported by the input requirement:
EMIFP+B→S(SC2,out) = SS(T = 17.58) /∈ RHW,in = {SS(THW = 20)}
(7.11)
Iterative Analysis 181
We finally apply automatic shaping and obtain the corresponding event adap-
tation function EAF2, a sporadic shaper with a backlog of 2 and a maximum
delay of 24.2 time units. The actual HW input stream is:
SHW,in = EAF auto,2(SEAF2,in,RHM,in)
= SS(20) ∈ RHW,in (7.12)
7.6.7 Results
We have analyzed the example with our SymTA/S tool suite [114] that im-
plements all concepts presented in this thesis. It is written in Java and does
not require any external analysis packages. All experiments that are presented
in this thesis have been carried out on an Athlon1800+ (@1.15GHz) powered
PC with 512 MByte of RAM, running the WindowsXP Professional operat-
ing system and the Java virtual machine from Sun Microsystem’s Java2SDK,
Standard Edition Version 1.4.1. The analysis run-time for the above example
was below 1 second.
7.6.7.1 Overview
Table 7.1 provides a compact overview about the experiment. For each anal-
ysis cycle, the input and output jitters and the response times are shown. The
analysis assumes zero input jitter for the first cycle. Each cycle yields updated
values for the output jitters. The output jitter of channel C1 turns into the input
jitter of task T1, and the output jitter of task T3 turns into the input jitter of
channel C2. These values are shown in bold numbers. At the second analysis
cycle, updated values need be considered for both elements in the dependency
cycle, namely task T3 and channel C2. For the third cycle, the input jitter of
task T1 has further increased, while the input jitter of channel C2 has not. The
large jitters lead to self-interference, and consequently burst communication on
channel C2. The rightmost column shows the size of the busy window [69, 121]
required to analyze the bursts.
7.6.7.2 Jitter Observations
The monotonicity of jitters and response times play a key role in the defini-
tions of a suitable starting point as well as a reasonable termination condition
for the iterative analysis procedure. The example illustrates these effects. Jit-
ters increase from inputs to outputs, and we have also seen the cyclic dependen-
cies in detail. Figure 7.14 allows comparison of the changes in the worst-case
scheduling scenarios from one analysis cycle to the next. The particular ef-
fect of increasing jitters is highlighted. On the CPU, we see that the task T3 is
blocked for several activations and then runs in burst mode. The rightmost col-
umn of Table 7.1 indicates that the size of the busy window [69, 121] is seven
(7). Even though the increasing input jitter of T1 leads to earlier re-arrivals (see
182 System-Level Analysis Procedure
task input resp. output size of busy
jitter [µs] time [µs] jitter [µs] window
Cycle 1
C1 0 [72.97 ; 97.41] 24.44 1
C2 0 [17.58 ; 25.31] 7.73 1
C3 0 [3.43 ; 4.3] 0.87 1
T1 0 [250 ; 265] 15 1
T3 0 [10 ; 275] 265 7
Cycle 2
C1 0 [51.96 ; 283.07] 231.11 1
C2 265 [17.58 ; 87.94] 335.36 10
C3 0 [3.43 ; 4.3] 0.87 1
T1 24.44 [250 ; 265] 39.44 1
T3 0 [10 ; 275] 265 7
Cycle 3
C1 0 [51.96 ; 283.07] 231.11 1
C2 265 [17.58 ; 87.94] 335.36 10
C3 0 [3.43 ; 4.3] 0.87 1
T1 231.11 [250 ; 265] 246.11 1
T3 0 [10 ; 275] 265 7
Termination after third analysis cycle!!!
Table 7.1. Experiment Results
Figure 7.14), these still do not influence the critical instant of task T3 whose
scheduling remains constant. On the bus, the burst output of task T3 leads
to communication bursts that are only limited by the minimum event distance
δ−C2,in(2) = dT3,out = 10. The size of the corresponding busy window is ten(10).
7.6.7.3 Path Latencies
According to Definition 7.2, we define three paths in the example system.
Path P1 from the output of the IP sub-system to the input of the DSP, P2 from
the RTOS timer to the HW sub-system, and a third path from the sensor to the
output (completion) of task T1:
P1 = {C3, EAF1}
P2 = {T3, C2, EAF2}
P3 = {C1, T1}
Iterative Analysis 183
analysis cycle 1
analysis cycle 2
analysis cycle 3
44,24(1)out,1
(2)
in,1   CT JJ
11,231(2)out,1
(3)
in,1   CT JJ
0out,
(0)
in,1
(0)
out,1
(1)
in,1     SensJJJJ CCT
starting point
10)2(
(1)
out,2
(2)
in,2   

TC
dG
0(0) in,3
(0)
out,3
(1)
in,2     timerJJJJ TTC
(3)
in,1
(3)
out,1
(4)
in,1 TCT JJJ   successfull termination
starting point
CPU BUS
bursts
(1)
out,2
(2)
out,2
(3)
in,2 )2( TTC dd   
G
bursts
Figure 7.14. Scheduling Diagrams of All Analysis Cycles
According to Definition 7.3, the maximum latencies of these paths are:
PL+1 = R+C3 + delay+EAF1
= 4.3 + 8.01 = 12.31 (7.13)
PL+2 = R+T3 + R+C2 + delay+EAF2
= 275 + 87.94 + 24.2 = 387.14 (7.14)
PL+3 = R+C1 + R+T1
= 283.07 + 265 = 548.07 (7.15)
184 System-Level Analysis Procedure
Finally, we calculate the accumulated backlog along each path:
backlog+P1 = backlog
+
C3 + backlog
+
EAF1
= 1 + 2 = 3 (7.16)
backlog+P2 = backlog
+
T3 + backlog
+
C2 + backlog
+
EAF2
= 6 + 5 + 2 = 13 (7.17)
backlog+P3 = backlog
+
C1 + backlog
+
T1
= 1 + 1 = 2 (7.18)
7.7 Optimizations
We have shown in Section 6.4.3 that shaping supports us in reducing tran-
sient load peaks. We have performed a set of experiments with periodic and
sporadic shapers with different time-out values in order to optimize a local
schedule. Shaping also has, however, an important global effect since the peak
load reduction and load balancing is not limited to a single task or resource.
A more deterministic execution or communication usually results in more de-
terministic output streams, in turn improving the scheduling of the next task
or channel. This is of particular importance for systems with cycles and, as
we shall see, it has a large impact on the scheduling dynamics as well as the
analysis results.
7.7.1 Full Re-Synchronization
We insert a shaper EAF3 between task T3 and channel C2 thereby reducing
the communication bursts on the bus. We have already indicated the possibility
of shaping in Figure 7.6. We start with a fully periodic shaper to re-synchronize
the output of task T3 to its original period. In other words, we eliminate the
jitter. The overall analysis procedure does not change, but we have to consider
the influence of shaping during the event stream propagation step (step 5 in
Figure 7.2).
As we use the same analysis starting point, the first analysis cycle is mostly
identical to the situation without shaping (see Section 7.6.2 for details). From
the output stream of task T3, we can then dimension the shaper according to
Section 6.3.4:
backlog+EAF3 = 3 delay
+
EAF3 = 315
Now, because of the shaper, the bus inputs do not change compared to the
initial starting point. That means that the bus does not need to be analyzed a
second time, since the periodic shaper breaks up the dependency cycle. Only
the CPU must be analyzed again to account for the influence of bus schedul-
ing. We can re-use the calculations from Section 7.6.3.1, and we see that the
output stream of task T3 does not change compared to the first cycle, and the
Optimizations 185
Maximum Path Delay Maximum Path Backlog Analysis Run-
Shaper P1 P2 P3 P1 P2 P3 Cycles Time
— 12.31 387.14 548.07 3 13 2 4 <1s
P 12.31 615.31 362.41 3 14 2 2 <1s
S(30) 12.31 424.31 443.02 3 12 2 4 <1s
Table 7.2. Path Properties of All Experiments
analysis terminates. For the local analysis of the CPU and the bus, the results
of Sections 7.6.2.2 and 7.6.3.1 apply. In order to determine the path latencies
and backlogs, we have to consider the shaper EAF3 in the path P2:
P2 = {T3, EAF3, C2, EAF2}
Table 7.2 summarizes the path properties of this example system with differ-
ent shaper set-ups. The first two rows of the table allow the un-shaped version
(“–”) to be compared to the shaped version (“P”). The additional buffering has
lead to a larger backlog and delay for path P2. However, the delay of path P3 is
remarkably less than without the additional shaper, since the interference that
channel C1 experiences has been reduced. Path P1 has not changed because
the channel C3 that contributes to that path has the highest priority on the bus
and is therefore not affected by other communications.
There is another advantageous side effect of shaping. Because of the shaper,
the communication on channel C2 experiences less interference, and its output
jitter is considerably less compared to the un-shaped version:
JC2,out = 7.73 < 335.36 = JC2,out,un-shaped (7.19)
In effect, the minimum output event distance δ−(2) in that stream is increasing
from 17.58 (see Equation 7.11) to
δ−C2,out = max(TC2,out − JC2,out, R−C2) = 50− 7.73 = 42.27
That means, we can find a plain EMIF such that the HW sub-system require-
ment is automatically met without the need for shaper EAF2:
EMIFP+B→S(SC2,out) = SS(T = 42.27) ∈ RHW,in = {SS(THW = 20)}
(7.20)
This demonstrates the large impact of buffering. A shaper is required on either
position but the choice can be subject to further optimization.
7.7.2 Dynamic Bus Load Reduction
We now replace the fully periodic shaper with a sporadic shaper. We choose
a time-out value of 30 which is in the “medium range” between the maximum
allowed value (the period: 50) and the minimum reasonable value (the min-
imum distance: 10). The shaper also reduces the amount of interference on
186 System-Level Analysis Procedure
Figure 7.15. Bus Scheduling Diagram with Sporadic Shaper
the bus. We have to perform the shaper dimensioning of Section 6.4.1 in each
analysis cycle. The analysis terminates in the fourth cycle. The worst-case
communication scheduling scenario is shown in Figure 7.15, the path latency
and backlog is provided in the last row of Table 7.2. We see that this option
yields the optimal path backlog while the path delays are within the range of
the other two experiments. Again, the shaper EAF2 becomes obsolete because
the output distance if channel C2 is
δ−C2,out = max(TC2,out − JC2,out︸ ︷︷ ︸
<0
, δ−C2,in − JRC2︸ ︷︷ ︸
30−7.73=22.73
, R−C2︸︷︷︸
17.58
) = 22.73
which fulfills the HW input requirement.
7.7.3 Reducing the Bus Speed
The examples show that the proposed analysis procedure yields detailed
information about the timing and performance of each individual task or com-
munication, as well as resource utilization information. For instance, the bus
has currently a utilization of 74,3% (see Equation 7.7). In a final set of experi-
ments, we reduce the bus speed to 80% of its original speed, i. e. 240Mbyte/s.
This increases the individual byte and packet communication times, and the
resulting overall network utilization is:
Unet = Unet240Mbyte/s = 92, 8% (7.21)
We perform four experiments with different set-ups for shaper EAF3. Again,
the first analysis cycle of all experiments is identical. We perform the first ex-
periment without an additional shaper. We can observe that the path delays on
paths P2 and P3 –along with the jitters and response times– rapidly increase.
They exceed their absolute deadlines, which are set to 2000 and 2500, after
the sixth analysis cycle, and the analysis terminates without success. The over-
all analysis run-time of this experiment was below two seconds. The rapid
Summary 187
Maximum Path Delay Maximum Path Backlog Analysis Run-
Shaper P1 P2 P3 P1 P2 P3 Cycles Time
— 13.56 > 2000 > 2500 3 > 46 > 8 6! <2s
P 13.56 630.21 560.41 3 14 2 2 <1s
S(50) 13.56 630.21 560.41 3 14 2 2 <1s
S(40) 13.56 950.21 1132.6 3 23 4 5 <1s
Table 7.3. Path Properties of All Experiments with Reduced Bus Speed
increase of the response times demonstrates the usefulness of the termination
condition of Section 7.4.3 in practice.
In the second experiment, we add a periodic shaper, and the analysis suc-
cessfully terminates after two cycles. Next, we apply maximum sporadic shap-
ing with a time-out of 50. Finally, we reduce the time-out value to 40. The re-
sults are presented in Table 7.3. All experiments with shapers terminate within
the first second. We see that both the periodic shaper and the maximum spo-
radic shaper yield identical path delays and backlogs. They differ, however, in
the scheduling of channel C1 on the bus which leads to a higher activation jitter
of task T1. Neither of the effects is illustrated further here.
7.7.4 Concluding Remarks
We have used this example system earlier at the IEEE Real-Time Systems
Symposium, 2003, in Cancun, Mexico. At the time we wrote the paper [98],
we could not use the SymTA/S tool, so we had to do the calculations manually.
Unfortunately, we made a systematic mistake by not appropriately considering
the input jitters, and the results published in [98] have flaws. With this para-
graph, we would like to apologize for this mistake and kindly ask this to be
considered when comparing the results.
7.8 Summary
In this Chapter, we have presented our novel system-level scheduling anal-
ysis procedure for heterogeneous distributed systems. Using an expressive ex-
ample, we have shown in detail how the individual concepts of the preceding
chapters are applied one after another according to a systematically structured
seven-step analysis procedure. In practice, each individual step is comprehen-
sible and can be performed without considering any specialties of the model,
the architecture, or individual parts of it. Event stream incompatibilities are
identified and resolved step-by-step. The same holds for the way the system-
level dependencies are captured and analyzed. We have seen that even critical
design pitfalls, such as dependency cycles, do not increase the complexity of
the overall procedure at all. On the contrary, the structured, cyclic approach
provides meaningful intermediate results that can already give hints for up-
188 System-Level Analysis Procedure
coming bottlenecks. The actual amount of jitter increase, for instance, gives
valuable feedback about the dynamic evolution of the analysis.
From the mathematical perspective, we have shown that known deadlines
and other constraints allow the algorithmic complexity of the analysis to be ef-
ficiently bounded, in case the analysis does not converge successfully. Finally,
we have shown that, and how, traffic shaping can substantially reduce the anal-
ysis complexity, enforce convergence, and optimize the system globally.
The experiments illustrate the main contribution of this thesis. The event
stream representation and the structured standard event models are the key
enablers for both, the novel analysis procedure to determine the timing and the
performance of the system, and the comprehensive view that increases system
understanding and provides efficient and extremely fast optimization support.
Chapter 8
SUMMARY AND CONCLUSION
8.1 Summary
In order to find a reasonable formal basis for our technique, we reviewed
popular scheduling analysis techniques and landmark publications. We dis-
covered that the host of analysis proposals share only few relatively compact
and comprehensible event models for task activation modeling. Looking for a
way to combine these techniques into a system-level analysis, we thoroughly
investigated the specific properties and the characteristic functions of the four
most popular input event models, as well as the influence of scheduling with
respect to output event models that have, interestingly, been scarcely consid-
ered to date. We showed that the existing input models have weaknesses in
output stream modeling. The concept of increasing jitter that leads to event
bursts has not previously been systematically analyzed. The same applies to
the close relationship between periodic and sporadic models.
Based on these observations, we structured input and output models into
two appropriate classes: periodic and sporadic, and we have three models in
each class: strict, jitter, and burst. This systematic arrangement leads to a
self-contained six-class model that represents an efficient compromise between
model simplicity, theoretical completeness, and practical applicability. In order
to allow the heterogeneous use of these six models in one system, we defined
compatibility and coverage tests for event streams and models, and we sub-
sequently developed Event Model Interfaces and Event Adaptation Functions.
These provide the necessary model transformations that enable the integration
of different components, and the composition of their local analysis techniques
within the novel system-level analysis procedure.
The proposed procedure propagates the outputs of one component to the in-
puts of the connected components, thereby analyzing the components locally,
190 Summary and Conclusion
one after another. The structured system model, and the use of simple, estab-
lished event models, allows a comprehensive overview of all components and
their interactions. The analysis provides key information about the local sub-
system timing such as task response times and resource utilization, as well as
global system properties such as end-to-end path latencies and overall buffer-
ing requirements. These are the key system parameters that designers and
system architects require to verify the performance of their systems and com-
ponents, and to evaluate the integration decisions. The approach presented is
both comprehensible and provides this information faster than many previous
attempts, including the best-practice of performance simulation.
We have investigated the impact of event stream dependency cycles that
can turn the iterative analysis procedure into a convergence problem for event
streams. We could show that the standard event models reveal monotonicity
properties, that lead to a bounded number of analysis iterations until the anal-
ysis converges or a path constraint or a deadline is missed, which makes the
analysis procedure applicable in practice; and even in the case of unsuccessful
termination, the analysis provides additional information about which deadline
is missed, and the stream representation provides initial hints to source route
such problems.
8.2 Extensibility
The modularity of the analysis model allows not only to re-use existing ap-
proaches such as RMS [73], it also eases the development of new analysis
modules for specific components. We have already characterized the pop-
ular automotive ERCOSek operating system [32], and we have developed a
SymTA/S library component for that [16, 61]. Even though ERCOSek defines
a sophisticated priority structure that complicates the local analysis, we could
develop and implemented the module into out SymTA/S tool within very short
time. Currently, we are investigating CAN in a project with a major automotive
supplier. This modular extensibility is considered a major advantage over the
holistic analysis approach, that suffers from the complexity to build the holistic
models.
However, the basic SymTA/S approach, as far as introduced in this thesis,
has certain obvious limitations. We have assumed that each task has exactly
one input and one output. The input of one task is connected to exactly one
output of another task, while one output can possibly be connected to several
inputs. Consequently, the supported application topology is restricted to task
trees, although the examples in this thesis consist of task chains, a subclass of
trees. We have further assumed that each task is activated by a single input
event, and the task produces at most one output event per execution. Realistic
applications usually exhibit more complex task input-output behavior, more
Extensibility 191
complex activation conditions, more complex task topologies, and finally more
complex system-level interactions.
The basic SymTA/S approach, however, represents a core technology that
lays the foundation for a set of extensions. In order to deal with data-rate
transitions, which are commonly found in signal processing applications in-
cluding SDF systems, task execution and communication have been recently
separated from task activation and scheduling. Token production and consump-
tion curves have been introduced [54] to be associated with task inputs and
outputs. Input token curves are transformed into activation event streams that
are further used for task scheduling analysis. Likewise, output event streams
are re-transformed into token curves to be propagated during the system level
analysis. These transformations also consider multi-input activation with AND
or OR semantics [58], which allows the scope of system-level event streams,
and the system-level analysis procedure, to be extended to complex token-
flow models and sophisticated application topologies including functional cy-
cles [58].
These extensions are only possible because of the clear separation of local
analysis and global interactions, a key contribution of this thesis. Moreover,
it could be shown that the six-class event model set can efficiently capture
both task activation and completion, as well as token consumption and pro-
duction [54]. Furthermore, multi-input task activation exhibits backlogs and
requires the insertion of appropriate buffers. In order to dimension the buffers
and determine the additional delay, key conceptual contributions of this thesis
can be re-used, that are related to event stream adaptation.
We summarize that the ideas presented in this thesis are not generally lim-
ited to simple applications. On the contrary, the basic approach provides a
vehicle for a variety of extensions that benefit from: a) the clear separation
of local analysis and global interaction modeling using efficient event models
and b) from the idea of model transformations using appropriate interfaces and
adaptations. In other words, SymTA/S is the enabling technology for the analy-
sis of complex embedded applications that are implemented on heterogeneous
hardware/software architectures. The details of the extensions mentioned can
be found in Jersak’s thesis [52].
Another type of extension benefits from the efficiency of the analysis proce-
dure. We have seen in the experiments that the analysis run-time is in the range
of seconds. This enables the analysis of a large number of different system set-
ups in a relatively short period of time. The SymTA/S tool [114] has been
coupled with an automatic exploration and optimization framework [13, 12].
The exploration framework uses evolutionary algorithms [147] to modify shap-
ing and other implementation decisions, such as priorities or time slots, to find
optimized solutions [44, 43]. Such optimizations are only possible with a suf-
ficiently fast analysis procedure which SymTA/S provides.
192 Summary and Conclusion
A related research direction targets sensitivity analysis, where binary search
trees [89] are used to determine the system reserves and describe the system
flexibility during the design phase, whilst guaranteeing that system constraints
can be satisfied. Again, the efficiency of the new approach enables the appli-
cation of such kind of sensitivity analysis.
8.3 Outlook and Future Work
The conservative nature of the analysis that solely considers best-case and
worst-case bounds is often a cause of concern. Clearly, the system-level anal-
ysis cannot be more accurate than the individual local models and techniques.
In order to derive safe, guaranteed bounds, the parameter intervals can become
large. Under certain circumstances, this may lead to conservative results. The
holistic approaches take into account more detailed correlations between in-
dividual parameters and tasks, that are treated independently in our approach
to reasons of modularity and flexibility. There are two distinct and apparently
reasonable approaches to increasing the accuracy of the analysis.
By incorporating additional information about the task execution and com-
munication behavior, we can distinguish between several task modes or con-
texts. Intra-stream contexts [48, 55] can be associated with event streams to
model the correlated execution of tasks including their communication. It was
shown that this considerably tightens analysis bounds for specific applications.
Likewise, inter-stream contexts [48, 55] allow phase and offset information to
be specified for task scheduling, consequently tightening response time analy-
sis.
As the second alternative, one could investigate how much of the key holis-
tic ideas can be incorporated into in the compositional SymTA/S approach to
increase the accuracy without degrading modularity and efficiency. We specif-
ically expect that the influence of bursts on path latencies can be more effi-
ciently handled [35].
8.4 Conclusion
In this thesis we have presented a novel approach to analyzing the timing
and the performance of heterogeneous, distributed real-time systems. One key
contribution of this work is the comprehensible representation of the interac-
tions between the individual components and sub-systems, which are a major
source of complexity and make the timing analysis problem a huge challenge
in practice.
Previous work in this field either –in case of holistic analysis– does not pro-
vide the necessary modularity and flexibility that today’s “cut&paste” design
style requires, or –in the case of the two known compositional approaches–
requires relatively complex interaction models, that must be homogeneously
Conclusion 193
used in the entire system and substantially hinder the integration and re-use of
known, established sub-system techniques.
The new approach is aimed explicitly at supporting the heterogeneous appli-
cation of several different event models in one system. This flexibility allows a
variety of known techniques for individual components and sub-systems to be
used locally, without compromising global analysis, which we consider a key
advantage with respect to the practical application of the approach.

Bibliography
[1] Accelera. http://www.accellera.org.
[2] Heinz Arnold. Thema der woche (topic of the week): Automotive electronics, in Ger-
man. Markt & Technik, (36):16–20, 2004.
[3] N. C. Audsley and A. Burns. Real-time system scheduling. Technical report, Depart-
ment of Computer Science, University of York, England, 1990.
[4] N. C. Audsley, A. Burns, M. F. Richardson, K. Tindell, and A. J. Wellings. Applying
new scheduling theory to static priority preemptive scheduling. Journal of Real-Time
Systems, 8(5):284–292, 1993.
[5] N. C. Audsley, A. Burns, M. F. Richardson, and A. J. Wellings. Hard real-time schedul-
ing: The deadline monotonic approach. In Proceedings of the 8th IEEE Workshop on
Real-Time Operating Systems, pages 133–137, 1991.
[6] N. C. Audsley, K.W. Tindell, and A. Burns. The end of the line for static cyclic schedul-
ing? In In Proc. Euromicro Conference on Real-Time Systems, 1993.
[7] AUTOSAR Development Partnership. AUTomotive Open System Architecture – AU-
TOSAR. http://www.autosar.org/.
[8] AXYS Design. MaxSim Development Suite.
http://www.axysdesign.com/products/products maxsim.asp.
[9] S. Baruah and J. Goossens. Scheduling real-time tasks: Algorithms and complexity. In
J. Y.-T. Leung, editor, Handbook of Scheduling: Algorithms, Models, and Performance
Analysis. Chapman Hall, CRC Press, 2004.
[10] S. Baruah, L.E. Rosier, and R.R. Howell. Algorithms and complexity concerning the
preemptive scheduling of periodic, real-time tasks on one processor. Journal of Real-
Time Systems, 2:301–324, 1990.
[11] J. Blazewicz. Modeling and Performance Evaluation of Computer Systems, chapter
Scheduling Dependent Tasks with Different Arrival Times to Meet Deadlines. North-
Holland, Amsterdam, 1976.
196 Bibliography
[12] S. Bleuler, M. Laumanns, L. Thiele, and E. Zitzler. PISA – A platform and program-
ming language independent interface for search algorithms. In Evolutionary Multi-
Criterion Optimization, pages 494 – 508, 2003.
[13] T. Blickle, J. Teich, and L. Thiele. System-level synthesis using evolutionary algo-
rithms. Journal on Design Automation for Embedded Systems, 3(8):23–58, January
1998.
[14] J. L. Boudec and P. Thiran. Network calculus - a theory of deterministic queuing sys-
tems for the internet. In In Proceedings of International Workshop on Workshop on
Quality in Multiservice IP Networks, volume 2050 of Lecture Notes in Computer Sci-
ence. Springer, 2001.
[15] J.-Y. Le Boudec. Application of network calculus to guaranteed service networks. IEEE
Transactions on Information Theory, 44(3):1087–1096, 1998.
[16] J.-C. Braam. Analyse der Architektureinflu¨sse auf das Ausfu¨hrungszeitverhalten von
Software-Funktionen am Beispiel ERCOSEK. Master’s thesis, Technical University of
Braunschweig, March 2003.
[17] G. Buttazzo. HARD REAL-TIME COMPUTING SYSTEMS: Predictable Scheduling
Algorithms and Applications. Kluwer Academic Publishers, Boston, Massachusetts,
USA, 1997.
[18] G. Buttazzo. Rate monotonic vs. edf: Judgment day. In Proc. 3rd Workshop on Embed-
ded Software (EMSOFT), Philadelphia (PA), USA, October 2003.
[19] Cadence. Cierto VCC Environment. http://www.cadence.com/products/vcc.html.
[20] Beatriz Asensio Calvo. Real-time analysis of time-driven scheduling – a quantitative
comparison of Round Robin and TDMA. Technical report, Technical University of
Braunschweig, September 2001.
[21] S. Chakraborty. System-Level Timing Analysis and Scheuling for Embedded Packet
Processors. PhD thesis, Swiss Federal Institute of Technology Zurich, 2003.
[22] S. Chakraborty, T. Erlenbach, S. Ku¨nzli, and L. Thiele. Schedulability of event-driven
code blocks in real-time embedded systems. In Proceedings Design Automation Con-
ference, pages 616–621, New Orleans, LA, USA, 2002.
[23] S. Chakraborty, S. Ku¨nzli, and L. Thiele. Approximate schedulability analysis. In
Proceedings IEEE Real-Time Systems Symposium, Austin, TX, USA, 2002.
[24] M.-I. Chen and K.-J. Lin. Dynamic priority ceilings: A concurrency control protocol
for real-time systems. Journal of Real-Time Systems, 2(4):325–346, 1990.
[25] CiA – Can in Automation. TTCAN - Time-Triggered Controller Area Network.
http://www.can-cia.de/can/ttcan/.
[26] A. Colin and I. Puaut. Worst-case execution time analysis of the rtems real-time op-
erating system. In Proc. Euromicro Conference of Real-Time Systems, pages 191–198,
Delft, Nederlands, June 2001.
[27] R. Cruz. A calculus for network delay. IEEE Transactions on Information Theory,
37(1):114–131, 1991.
Bibliography 197
[28] A. Dasdan. Timing Analysis of Embedded Real-Time Systems. PhD thesis, University
of Illinois at Urbana-Champaign, 1999.
[29] Petru Eles, Alexa Doboli, Paul Pop, and Zebo Peng. Scheduling with bus access op-
timization for distributed embedded systems. IEEE Transactions on VLSI Systems,
8(5):472–491, 2000.
[30] Petru Eles, Krzysztof Kuchcinski, Zebo Peng, Paul Pop, and Alexa Doboli. Scheduling
of conditional process graphs for the synthesis of embedded systems. In Proc. Design,
Automation and Test in Europe - DATE, 1998.
[31] M. Engels, G. Bilsen, R. Lauwereins, and J. Peperstraete. Cyclo-Static Data Flow:
Model and implementation. In Proc. 28th Asilomar Conf. on Signals, Systems, and
Computers, pages 503–507, Pacific Grove, CA, 1994.
[32] ETAS. ERCOSek, OSEK based Real-Time Operating System.
http://www.etas.de/html/en/products/ec/ercosek/en products ec ercosek index.htm.
[33] ETAS, formerly Livedevices. Real-Time Architect.
http://www.livedevices.co.uk/realtime.shtml.
[34] C. J. Fidge. Real-time schedulability tests for preemptive multitasking. Journal of
Real-Time Systems, 14:61–93, 1998.
[35] M. Fidler. Extending the network calculus pay bursts only once principle to aggre-
gate scheduling. In In Proceedings of International Workshop on Quality of Service in
Multiservice IP Networks, Lecture Notes in Computer Science. Springer, 2003.
[36] FlexRay-Group. FlexRay. http://www.flexray.com.
[37] R. L. Graham. Bounds on multiprocessing timing anomalies. SIAM Journal on Applied
Mathematics, 17(2):416–429, 1969.
[38] K. Gresser. An event model for deadline verification of hard real-time systems. In
Proceedings 5th Euromicro Workshop on Real-Time Systems, pages 118–123, Oulu,
Finland, 1993.
[39] Klaus Gresser. Echtzeitnachweis ereignisgesteuerter Realzeitsysteme. PhD thesis, only
avaliable in German, Technische Universita¨t Mu¨nchen, 1993.
[40] J. J. Gutierrez and M. G. Harbour. Increasing schedulability in distributed hard real-
time systems. In Proceedings 7th Euromicro Workshop on Real-Time Systems, page 71,
Odense, Denmark, June 1995.
[41] J. J. Gutierrez, J. C. Palencia, and M. G. Harbour. On the schedulability analysis for
distributed hard real-time systems. In Proceedings 9th Euromicro Workshop on Real-
Time Systems, pages 136–143, Toledo, Spain, June 1997.
[42] J. J. Gutierrez, J. C. Palencia, and M. G. Harbour. Schedulability analysis of distributed
hard real-time systems with multiple-event synchronization. In Proceedings 12th Eu-
romicro Workshop on Real-Time Systems, page 15, Stockholm, Sweden, June 2000.
[43] A. Hamann and R. Ernst. TDMA time slot and turn optimization with evolutionary
search techniques. In submitted to Design, Automation and Test in Europe Conference
- DATE, Munich, Germany, March 2005.
198 Bibliography
[44] A. Hamann, M. Jersak, K. Richter, and R. Ernst. Design space exploration and system
optimization with SymTA/S - symbolic timing analysis for systems. In Proceedings
25th International Real-Time Systems Symposium, December 2004.
[45] M. G. Harbour, J. L. Medina, J. J. Gutierrez, J. C. Palencia, and J. M. Drake. Mast:
An open environment for modeling, analysis, and design of real-time systems. In 1st
Workshop on Computer Aided Architectural Analysis of Real-Time Systems, Aranjuez,
Spain, October 2002.
[46] C. Haubelt, J. Teich, and K. Richter. System design for flexibility. In Proc. of Design,
Automation and Test in Europe Conference (DATE’02), Paris, France, March 2002.
[47] W. Henderson, D. Kendall, and A. Robson. Improving the accuracy of scheduling
analysis applied to distributed systems. Journal of Time-Critical Computing Systems,
20(1):5–25, 2001.
[48] R. Henia. Analyse von kontextabha¨ngigem Systemverhalten komplexer eingebetteter
Systeme. Master’s thesis, Technical University of Braunschweig, April 2003.
[49] P.-E. Hladik and A.-M. Deplanche. Best-case response time analysis for precedence
relations in hard real-time systems. In Proc. Work-in-Progress Session, IEEE Real-
Time Systems Symposium, Cancun, Mexico, December 2003.
[50] IEEE. The Official IEEE 802.5 Web Site. http://www.ieee802.org/5/www8025org/.
[51] K. Jeffay. The Real-Time Producer/Consumer Paradigm: Towards Verifiable Real-Time
Computations. PhD thesis, University of Washington, Department of Computer Sci-
ence, 1989.
[52] M. Jersak. Performance Analysis for Complex Embedded Applications. PhD thesis,
Technical University of Braunschweig, 2004.
[53] M. Jersak, Y. Cai, D. Ziegenbein, and R. Ernst. A transformational approach to con-
straint relaxation of a time-driven simulation model. In Proceedings 13th International
Symposium on System Synthesis, Madrid, Spain, September 2000.
[54] M. Jersak and R. Ernst. Enabling scheduling analysis of heterogeneous systems with
multi-rate data dependencies and rate intervals. In Proceeding 40th Design Automation
Conference, Annaheim, USA, June 2003.
[55] M. Jersak, R. Henia, and R. Ernst. Context-aware performance analysis for efficient
embedded system design. In Proceeding Design Automation and Test in Europe, Paris,
France, March 2004.
[56] M. Jersak, R. Racu, J. Staschulat, K. Richter, R. Ernst, J.-C. Braam, and F. Wolf. Formal
methods for integration of automotive software. In A.A. Jerraya, S. Yoo, D. Verkest,
and N. Wehn, editors, Embedded Software for SoC, pages 11–24. Kluwer Academic
Publishers, August 2003.
[57] M. Jersak, K. Richter, and R. Ernst. Combining complex event models and timing
constraints. In Proceedings 6th IEEE Workshop on High Level Design Validation and
Test, Monterey, USA, November 2001.
Bibliography 199
[58] M. Jersak, K. Richter, and R. Ernst. Performance analysis for complex embedded ap-
plications. International Journal of Embedded Systems, Special Issue on Codesign for
SoC, 2004.
[59] M. Jersak, K. Richter, R. Henia, R. Ernst, and F. Slomka. Transformation of SDL
specifications for system-level timing analysis. In Tenth International Symposium on
Hardware/Software Codesign (CODES’02), Estes Park, Colorado, USA, May 2002.
[60] M. Joseph and P. Pandya. Finding response times in a real-time system. The Computer
Journal, 29(5):390–395, 1986.
[61] D. Kerk. Implementierung einer Scheduling-Analyse fu¨r das ERCOSEK-Betriebssystem
und Integration in SymTA/S. Master’s thesis, Technical University of Braunschweig,
May 2004.
[62] T. Kim, J. Lee, H. Shin, and N. Chang. Best case response time analysis for improved
schedulability analysis of distributed real-time tasks. In Proceedings ICDCS Workshops
on Distributed Real-Time Systems, pages 14–20, April 2000.
[63] M. Klein. A Practitioner’s Handbook for Real-Time Analysis. Kluwer Academic Pub-
lishers, Boston, Massachusetts, USA, 1993.
[64] H. Kopetz and G. Gruensteidl. TTP - a time-triggered protocol for fault-tolerant com-
puting. In Proceedings 23rd International Symposium on Fault-Tolerant Computing,
pages 524–532, 1993.
[65] Hermann Kopetz. Real-Time Systems – Design Principles for Distributed Embedded
Applications. Kluwer Academic Publishers, Boston, Massachusetts, april 1997.
[66] E. A. Lee. Recurrences, iteration, and conditionals in statically scheduled block dia-
gram languages. In R. W. Brodersen and H. S. Morowitz, editors, VLSI Signal Process-
ing III, pages 330–340, IEEE Press, New York, 1988.
[67] E. A. Lee and D. G. Messerschmitt. Synchronous dataflow. Proceedings of the IEEE,
75(9):1235–1245, 1987.
[68] E. A. Lee and D.G. Messerschmitt. Static scheduling of synchronous data flow pro-
grams for digital signal processing. IEEE Transactions on Computers, 36(1), January
1987.
[69] J. Lehoczky. Fixed priority scheduling of periodic task sets with arbitrary deadlines. In
Proceedings Real-Time Systems Symposiom, pages 201–209, 1990.
[70] J. Lehoczky, L. Sha, and Y. Ding. The rate monotonic scheduling algorithm: Exact char-
acterization and average case behavior. In Proceedings Real-Time Systems Symposiom,
pages 166–171, IEEE Computer Society Press, 1989.
[71] J. Y.-T. Leung and J. Whitehead. On the complexity of fixed-priority scheduling of
peridic, real-time tasks. Journal of Performance Evaluation, 21(7):237–250, 1982.
[72] Lin Consortium. LIN – Local Interconnect Network. http://www.lin-subbus.org/.
[73] C. L. Liu and J. W. Layland. Scheduling algorithms for multiprogramming in a hard-
real-time environment. Journal of the ACM, 20(1):46–61, 1973.
200 Bibliography
[74] J. Liu. Real-Time Systems. Prentice-Hall, Boston, Massachusetts, USA, 2000.
[75] C. D. Locke. Software architecture for hard real-time applications: Cyclic executives
vs. fixed priority executives. Journal of Real-Time Systems, 4(1):37–52, 1992.
[76] A. Mathur, A. Dasdan, and R. K. Gupta. Rate Analysis for Embedded Systems. ACM
Transactions on Design Automation of Electronic Systems, 3(3):408 – 436, July 1998.
[77] Mentor Graphics. Seamless Co-Verification Environment.
http://www.mentorg.com/seamless/.
[78] A.K. Mok and D. Chen. A multiframe model for real-time tasks. IEEE Transactions
on Software Engineering, 23(10):635–645, 1997.
[79] OAR Corporation. RTEMS – Real-Time Executive for Multiprocessor Systems.
http://www.rtems.com.
[80] OSEK Steering Committee. OSEK Open systems and the corresponding interfaces for
automotive electronics. http://www.osek-vdx.org/.
[81] J. C. Palencia, J. J. Gutierrez, and M. G. Harbour. Best-case analysis for improving the
worst-case schedulability test for distributed hard real-time systems. In Proceedings
10th Euromicro Workshop on Real-Time Systems, page 35, Berlin, Germany, June 1998.
[82] J. C. Palencia and M. G. Harbour. Schedulability analysis for tasks with static and
dynamic offsets. In Proceedings of the IEEE Real-Time Systems Symposium, page 26.
IEEE Computer Society, 1998.
[83] J. C. Palencia and M. G. Harbour. Exploiting precedence relations in the schedulabil-
ity analysis of distributed real-time systems. In Proceedings of the IEEE Real-Time
Systems Symposium, pages 328–399. IEEE Computer Society, 1999.
[84] J. C. Palencia and M. G. Harbour. Offset-based response time analysis of distributed
systems scheduled under edf. In Proceedings Euromicro Conference on Real-Time
Systems, July 2003.
[85] Philips Semiconductors. Controller Area Network CAN.
http://www.semiconductors.philips.com/can/.
[86] P. Pop. Analysis and Synthesis of Communication-Intensive Heterogeneous Real-Time
Systems. PhD thesis, Linko¨ping University, 2003.
[87] P. Pop, P. Eles, and Z. Peng. Bus access optimization for distributed embedded sys-
tems based on schedulability analysis. In Proc. Design, Automation and Test in Europe
(DATE 2000), Paris, France, 2000.
[88] T. Pop, P. Eles, and Z. Peng. Holistic scheduling and analysis of mixed time/event-
triggered distributed embedded systems. In Proc. Int. Symposium on Hard-
ware/software codesign CODES’02, Estes Park, USA, 2002.
[89] R. Racu, M. Jersak, and R. Ernst. Applying sensitivity analysis in real-time distributed
systems. In Submitted to 11th IEEE Real-Time and Embedded Technology and Appli-
cations Symposium (RTAS’05), March 2005.
Bibliography 201
[90] R. Racu, K. Richter, and R. Ernst. Calculating task output event models to reduce
distributed system cost. In Proceedings of GI/ITG/GMM-Workshop Methoden und
Beschreibungssprachen zur Modellierung und Verifikation von Schaltungen und Sys-
temen, February 2004.
[91] R. Rajkumar, L. Sha, , and J. P. Lehoczky. Realtime synchronization protocols for
multiprocessors. In Proceedings Real-Time Systems Symposium, pages 259–269, 1988.
[92] O. Redell and M. Sanfridson. Exact best-case response time analysis of fixed priority
scheduled tasks. In Proceedings 14th Euromicro Workshop on Real-Time Systems, page
165, Vienna, Autria, June 2002.
[93] K. Richter. Developing a general model for scheduling of mixed transformative/reactive
systems. Master’s thesis, Technical University of Braunschweig, January 1998.
[94] K. Richter and R. Ernst. Event model interfaces for heterogeneous system analysis. In
Proc. of Design, Automation and Test in Europe Conference (DATE’02), Paris, France,
March 2002.
[95] K. Richter and R. Ernst. A formal approach to performance verification of heteroge-
neous architectures. In Proceedings Embedded World Conference, Nu¨rnberg, Germany,
February 2004.
[96] K. Richter, R. Ernst, and W. Wolf. Hierarchical specification methods for platform-
based design. In Proc. of Tenth Workshop on Synthesis And System Integration of Mixed
Technologies (SASIMI 2001), Nara, Japan, October 2001.
[97] K. Richter, M. Jersak, and R. Ernst. A formal approach to MpSoC performance verifi-
cation. IEEE Computer, 36(4), April 2003.
[98] K. Richter, R. Racu, and R. Ernst. Scheduling analysis integration for heterogeneous
multiprocessor SoC. In Proceedings 24th International Real-Time Systems Symposium
(RTSS’03), Cancun, Mexico, December 2003.
[99] K. Richter, D. Ziegenbein, R. Ernst, L. Thiele, and J. Teich. Representation of function
variants for embedded system optimizetion and systhesis. In Proceeding 36th Design
Automation Conference, pages 517–522, New Orleans, USA, June 1999.
[100] K. Richter, D. Ziegenbein, M. Jersak, and R. Ernst. Bottom-up performance analysis
of HW/SW platforms. In Proceedings Distributed and Parallel Embedded Systems
Conference (DIPES’02), Montreal, Canada, August 2002.
[101] K. Richter, D. Ziegenbein, M. Jersak, and R. Ernst. Model composition for scheduling
analysis in platform design. In Proceeding 39th Design Automation Conference, New
Orleans, USA, June 2002.
[102] F. A. Schreiber. Is time a real time? An overview of time ontology in informatics.
In W. A. Halang and A. D. Stoyenko, editors, Real-Time Computing. Springer Verlag,
1994.
[103] SDL Forum Society. Specification and Description Language. http://www.sdl-
forum.org/SDL/index.htm.
202 Bibliography
[104] Semiconductor Industry Association. 2003 International Technology Roadmap for
Semiconductors. http://public.itrs.net/Files/2003ITRS/Home2003.htm.
[105] L. Sha, R. Rajkumar, and J. Lehoczky. Priority inheritance protocols: An approach to
real-time synchronization. IEEE Transactions on Computers, 39(9):1175–1185, 1990.
[106] L. Sha, R. Rajkumar, and S. S. Sathaye. Generalized rate-monotonic scheduling theory:
A framework for developing real-time systems. Proceedings of the IEEE, 82(1):68–82,
January 1994.
[107] Sonics. SiliconBackplane µNetwork. http://www.sonicsinc.com/Pages/Networks.html.
[108] B. Sprunt, L. Sha, and J. Lehoczky. Aperiodic task scheduling for hard real-time sys-
tems. Journal of Real-Time Systems, 1(1):27–60, 1989.
[109] M. Spuri. Earliest Deadline Scheduled in Real-Time Systems. PhD thesis, INRIA, Le
Chesnay, Cedex, France, 1995.
[110] M. Spuri. Analysis of deadline scheduled real-time tasks. Technical report, INRIA, Le
Chesnay, Cedex, France, 1996.
[111] J. Stankovic, M. Spuri, K. Ramamritham, and G. Buttazzo. DEADLINE SCHEDUL-
ING FOR REAL-TIME SYSTEMS – EDF and Related Algorithms. Kluwer Academic
Publishers, Boston, Massachusetts, USA, 1998.
[112] K. Strehl, L. Thiele, D. Ziegenbein, R. Ernst, and J. Teich. Scheduling hard-
ware/software systems using symbolic techniques. In Proc. CODES’99, the 7th Int.
Workshop on Hardware/Software Co-Design, pages 173–177, Rome, Italy, May 1999.
[113] A.S. Tanenbaum. Operating Systems Design and Implementation. Prentice-Hall, 1987.
[114] Technical University of Braunschweig. SymTA/S – Symbolic Timing Analysis for Sys-
tems. http://www.symta.org.
[115] The MathWorks. Simulink datasheet. http://www.mathworks.com/products/simulink/.
[116] L. Thiele, S. Chakraborty, and M. Naedele. Real-time calculus for scheduling hard
real-time systems. In Proceedings International Symposium on Circuits and Systems
(ISCAS), Geneva, Switzerland, 2000.
[117] L. Thiele, s. Chakraborty, M. Gries, A. Maxiaguine, and J. Greutert. Embedded soft-
ware in network processors - models and algorithms. In Proc. 1st Workshop on Embed-
ded Software (EMSOFT), Lake Tahoe (CA), USA, October 2001.
[118] L. Thiele, K. Strehl, D. Ziegenbein, R. Ernst, and J. Teich. FunState - an internal design
representation for codesign. In ICCAD’99, the IEEE/ACM Int. Conf. on Computer-
Aided Design, pages 558–565, San Jose, U.S.A., November 1999.
[119] L. Thiele, J. Teich, and D. Ziegenbein. FunState - functions driven by state machines.
Technical Report 33, Computer Engineering and Communication Networks Lab (TIK),
Swiss Federal Institute of Technology (ETH) Zu¨rich, January 1998.
[120] K. Tindell. Adding time-offsets to schedulability analysis. Technical Report YCS 221,
Department of Computer Science, University of York, UK, 1994.
Bibliography 203
[121] K. Tindell, A. Burns, and A. Wellings. An extendible approach for analysing fixed pri-
ority hard real-time systems. Journal of Real-Time Systems, 6(2):133–152, Mar 1994.
[122] K. Tindell and J. Clark. Holistic schedulability analysis for distributed real-time sys-
tems. Microprocessing and Microprogramming - Euromicro Journal (Special Issue on
Parallel Embedded Real-Time Systems), 40:117–134, 1994.
[123] K. Tindell, J. Clark, and A. Wellings. Analysing real-time communications: Controller
area network. In Proceedings International Real-Time Systems Symposium, pages 259–
263, 1994.
[124] Tri-Pacific Software, Inc. RAPID RMA. http://www.tripac.com/html/prod-fact-
rrm.html.
[125] TTTech AG. TTP - Time-Triggered Protocol. http://www.tttech.com/.
[126] TTTech AG. TTP Software Development Suite.
http://www.tttech.com/products/software/ttptools/overview.htm.
[127] University of California at Berkeley. Giotto – A Methodology for Embedded Control
Systems Development. http://www-cad.eecs.berkeley.edu/ fresco/giotto/.
[128] University of Cantabria, Spain. MAST – Modeling and Analysis Suite for Real-Time
Applications. http://mast.unican.es/.
[129] VaST Systems Technology Corporation. CoMET – Electronic System-level Design En-
vironment. http://www.vastsystems.com/products comet.html.
[130] Vector Informatic GmbH. CANAlyzer – The Tool for Comprehensive Network Analysis.
http://www.canalyzer.com.
[131] Virtual Socket Interface Alliance. http://www.vsi.org.
[132] Volcano Communications Technologies AB. Volcano Network Architect for CAN.
http://www.volcanoautomotive.com/products/can.htm.
[133] F. Wolf. Behavioral Intervals in Embedded Software – Timing and Power Analysis of
Embedded Real-Time Software Processes. Kluver Academic Publishers, Boston, 2002.
[134] F. Wolf and R. Ernst. Intervals in software execution cost analysis. In Proceedings of
the IEEE/ACM International Symposium on System Synthesis, pages 130–135, Madrid,
Spain, September 2000.
[135] F. Wolf, J. Kruse, and R. Ernst. Segment-wise timing and power measurement in soft-
ware emulation. In Proceedings of the IEEE/ACM Design, Automation and Test in
Europe Conference, Designers’ Forum, Munich, Germany, March 2001.
[136] J. Xu and D. L. Parnas. Priority scheduling versus pre-run-time scheduling. Real-Time
Systems, 18(1):7–24, 2000.
[137] T. Yen and W. Wolf. Performance estimation for real-time distributed embedded sys-
tems. In International Conference on Computer Design, 1995.
[138] T. Yen and W. Wolf. Performance estimation for real-time distributed embedded sys-
tems. IEEE Transactions on Parallel and Distributed Systems, 9(11), November 1998.
204 Bibliography
[139] W. Zhao and J. Stankovic. Performance analysis of fcfs and improved fcfs scheduling
algorithms for dynamic real-time computer systems, 1989.
[140] D. Ziegenbein. A Compositional Approach to Embedded System Design. PhD thesis,
Technical University of Braunschweig, 2003.
[141] D. Ziegenbein, R. Ernst, K. Richter, J. Teich, and L. Thiele. Combining multiple mod-
els of computation for scheduling and allocation. In Proceedings Sixth International
Workshop on Hardware/Software Co-Design (Codes/CASHE ’98), pages 9–13, Seattle,
USA, March 1998.
[142] D. Ziegenbein, M. Jersak, K. Richter, and R. Ernst. Breaking down complexity for reli-
able system-level timing validation. In Ninth IEEE/DATC Electronic Design Processes
Workshop (EDP’02), Monterey, USA, April 2002.
[143] D. Ziegenbein, K. Richter, R. Ernst, J. Teich, and L. Thiele. Representation of pro-
cess mode correlation for scheduling. In Proceedings International Conference on
Computer-Aided Design (ICCAD ’98), San Jose, USA, November 1998.
[144] D. Ziegenbein, K. Richter, R. Ernst, L. Thiele, and J. Teich. SPI – A system model for
heterogeneously specified embedded systems. IEEE Transactions on Very Large Scale
Integration (VLSI) Systems, 10(4), August 2002.
[145] D. Ziegenbein, J. Uerpmann, and R. Ernst. Dynamic Response Time Optimization
for SDF Graphs. In Proceedings International Conference on Computer-Aided Design
(ICCAD ’00), San Jose, November 2000.
[146] D. Ziegenbein, F. Wolf, K. Richter, M. Jersak, and R. Ernst. Interval-based analysis of
software processes. In Proceedings Workshop on Languages, Compilers, and Tools for
Embedded Systems (LCTES ’2001), Snowbird, USA, June 2001.
[147] E. Zitzler, M. Laumanns, and L. Thiele. SPEA2: Improving the Strength Pareto Evolu-
tionary Algorithm. Technical Report 103, Swiss Federal Institute of Technology Zurich,
2001.



Compositional Scheduling Analysis
Using Standard Event Models
The SymTA/S Approach
KAI RICHTER
Dissertation, 2005
Institute of Computer and Communication Network Engineering
Department of Electrical Engineering and Information Technology
Technical University Carolo-Wilhelmina of Braunschweig
Braunschweig, Germany
K
a
i
 
R
i
c
h
t
e
r
 
 
 
 
 
 
 
 
 
C
o
m
p
o
s
i
t
i
o
n
a
l
 
S
c
h
e
d
u
l
i
n
g
 
A
n
a
l
y
s
i
s
 
U
s
i
n
g
 
S
t
a
n
d
a
r
d
 
E
v
e
n
t
 
M
o
d
e
l
s
