Communication Scheduling for Time-Triggered Systems by Pop, Paul et al.
  
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  
General rights 
Copyright and moral rights for the publications made accessible in the public portal are retained by the authors and/or other copyright owners 
and it is a condition of accessing publications that users recognise and abide by the legal requirements associated with these rights. 
 
• Users may download and print one copy of any publication from the public portal for the purpose of private study or research. 
• You may not further distribute the material or use it for any profit-making activity or commercial gain 
• You may freely distribute the URL identifying the publication in the public portal  
 
If you believe that this document breaches copyright please contact us providing details, and we will remove access to the work immediately 
and investigate your claim. 
   
 
Downloaded from orbit.dtu.dk on: Dec 17, 2017
Communication Scheduling for Time-Triggered Systems
Pop, Paul; Eles, Petru; Peng, Zebo
Published in:
Euromicro Conference on Real-Time Systems. Proceedings
Publication date:
1999
Document Version
Publisher's PDF, also known as Version of record
Link back to DTU Orbit
Citation (APA):
Pop, P., Eles, P., & Peng, Z. (1999). Communication Scheduling for Time-Triggered Systems. Euromicro
Conference on Real-Time Systems. Proceedings.
Communication Scheduling for Time-Triggered Systems Slide 1
Communication Scheduling for 
Time-Triggered Systems
Paul Pop, Petru Eles and Zebo Peng
Dept. of Computer and Information Science
Linköping University
Sweden
Communication Scheduling for Time-Triggered Systems Slide 2
Conditional Process Graph
P44 P55
P77
P1313
P1515
n First processor
n Second processor
n ASIC
C
C
DD
P0
P18
P11
P22 P33
P66
P88 P99
P1010
P1111
P1212
P1414 P1616
P1717
C
K
K
Subgraph corresponding to 
DÙCÙK
Communication Scheduling for Time-Triggered Systems Slide 3
Hardware Architecture
I/O Interface
TTP Controller
CPU
RAM
ROM
ASIC
S0 S1 S2 S3 S0 S1 S2 S3
TDMA Round
Cycle of two rounds
Slot
Node
• Safety-critical distributed embedded systems.
• Nodes connected by a broadcast
communication channel.
• Nodes consisting of: TTP controller, CPU,
RAM, ROM, I/O interface, (maybe) ASIC.
• Communication between nodes is based on
the time-triggered protocol.
• Buss access scheme: time-division multiple-
access (TDMA).
• Schedule table located in each TTP 
controller: message descriptor list (MEDL).
Communication Scheduling for Time-Triggered Systems Slide 4
Problem Formulation
Input
• Safety-critical application with several operating modes.
• Each operating mode is modelled by a conditional process graph.
• The system architecture and mapping of processes to nodes are given.
• The worst case delay of a process is known:
Output
• Local schedule tables for each node and the MEDL for the TTP controllers.
• Delay on the system execution time for each operating mode,
so that this delay is as small as possible.
)(
21 CCPPAP ii
tT qqd +++=
å
=
=
)(
1
1
i
local
out
i
PN
i
SC dq åå
==
+=
)(
1
)(
1
2
i
remote
in
i
i
remote
out
i
PN
i
KR
PN
i
KSC ddq
Communication Scheduling for Time-Triggered Systems Slide 5
Scheduling Example
P1
P4
P2 P3
m1 m2
m3 m4
S1 S0
Round 1 Round 2 Round 3 Round 4 Round 5
P1 P4
P2
m1 m2 m3 m4
P3
Round 1
P1
Round 2 Round 3 Round 4
S1S0 m1 m2 m3 m4
P2 P3
P4
Round 1 Round 2 Round 3
S1S0
P2 P3
P4P1
m1 m2 m3 m4
24 ms
22 ms
20 ms
Communication Scheduling for Time-Triggered Systems Slide 6
Experimental Results
0
10
20
30
40
50
60
80 160 240 320 400
Naive Designer
Greedy 1
Greedy 2
Average percentage deviations
from the lengths of near-optimal schedules
• The Greedy Approach is producing accurate
results in a very short time (few seconds for
graphs with 400 processes).
• Greedy 1 performs slightly better than
Greedy 2, but it is a bit slower.
• SA finds near-optimal results in a reasonable
time (few minutes for graphs with 80 processes
and 275 minutes for graphs with 400 processes).
• A real-life example implementing a vehicle
cruise controller validated our approach.
%
Number of processes
