Title: PerformanceAnalysisof EmbeddedSystems
1Performance Analysis of Embedded Systems
2Overview
- Review of General Aspects
- Modular Performance Analysis
- Real-Time Calculus
- Modeling
- Application Scenarios
3System Composition
4Role of Performance Estimation
- Design validation
- equivalence of specification and implementation
- validation of non-functional aspects (power
consumption, throughput, delay) - Prerequisite for design space exploration
- part of feedback cycle in design
- Performance estimation methods
- use of simulation, trace-based estimation and
analytic methods
5Design Space Exploration
Takes place on several levels of abstraction
6Why Is Estimation Difficult ?
- Non-determinism
- Uncertain system environment (different load
scenarios, unknown (worst case) input patterns). - Data dependent functional behavior.
- Analyzability
- Complex hardware and software interactions in
processing nodes, communication components,
scheduling and arbitration policies. - Use of abstractions in analysis -gt
non-determinism. - Interference
- Internal data streams interact on computing and
communication resources. - This interference determines stream
characteristics (cyclic dependency).
7Why is Estimation Difficult ?
applicationstructure
EPU
EPU
hardwareplatform
EPU
EPU
8 Bounds, Guarantees and Predictability
9Overview
- Review of General Aspects
- Composable Performance Analysis
- Real-Time Calculus
- Modeling
- Application Scenarios
10A Four-Step Approach
- Abstraction Build abstract models for first
class citizensevent streams -gt abstract
event streamsarchitecture elements -gt resource
modulesapplication processes -gt performance
modules - Performance Components Combine performance
modules using resource sharing information - Performance Network Combine all models to a
network that represents the performance aspects - Analysis
11The Big Picture
Application Specification
T1
T2
T3
loadscenarios
Abstract Application
mapping relations
performancecomponents
Performance Network
resourcemodules
Abstract Architecture
architectureelements
ARM9
DSP
Architecture Specification
12Step 1 Abstract Application Model
event stream
applicationprocess (e.g. StateCharts )
13Step 1 Abstract Functional Units
- to an abstract application model
How do we calculate with abstract event streams
and resources units?
abstractresource stream
performancemodule
abstractevent stream
We use Real-Time Calculus! (min-max algebra)
14Step 2 Build Performance Components
How do we do scheduling?
15Step 2 Scheduling I
Fixed Priority (FP)
16Step 2 Scheduling II
Performance component of a combined HW/SW/OS
module exposes performance properties but hides
implementation
share
Generalized Processor Sharing (GPS)
S
17Step 3 and 4 Compose and Analyze
How can we compose performance modules ?
How can we add a new application?
How can we estimate the load on resources?
How can we estimate delay and memory?
ARM9
DSP2
Bus
DSP1
18Dynamic Analytic Models
formalspecification
datasheets
programanalysis
model ofcomponents
inputtraces
model of environment
systemmodel
formalspecific.
analysis
estimationresults
19Overview
- Review of General Aspects
- Modular Performance Analysis
- Real-Time Calculus
- Modeling
- Application Scenarios
20Scheduling Abstraction
- Idea
- unified view of task scheduling, arbitration and
output scheduling in networks - methods
- queueing theory (statistical bounds, Markov
chains) - real-time calculus (worst case bounds, min-max
algebra)
21Foundations of Real-Time-Calculus
- Linear System Theory Baccelli, Cohen, Olsder,
Quadrat 1992 - Calculus for Networks Le Boudec 1998, 2001,
Cruz 1991 - Adversarial Queuing Theory Andrews, Borodin,
Kleinberg, Leighton, 1996 - End-to-end deadlines Parekh, Gallager 1994
22Event and Resource Models
How do we describe uncertain event streams and
resources?
23Arrival and Service Curves
24Event Resource Models
- Use arrival curves to capture packet streams
of packets
max 2 packets min 0 packets
max 3 packets min 1 packet
max 1 packet min 0 packets
3
2
1
D
time t
0
1
2
25Arrival Curves
- Use the concept of arrival curves !
How do we describe uncertain input streams ?
maximum/minimum number of packets in any interval
of length 4
number of packets in time interval 0,4
26Service Curves
- Use the concept of service curves !
How do we describe uncertain resources ?
maximum/minimum computing power in any interval
of length 2
computing power in time interval 0,2
27Arrival and Service Curves
- What else
- sub- and super-additivity
- relation to max- algebra
- operations correspond to convolution
28Transformation of Curves by Modules
29Performance Modules
30Compose and Analyze
I/O
mP
bus
DSP
prop.share
fixedprio.
fixedprio.
fixedprio.
31Compose and Analyze
32Everything Together
application structure
performancememory delay
App. Model
inputstreammodel
AllocationBindingScheduling
PerformanceNetwork
resourcemodel
Architecture Model
TDMA
WFQ
fixedpriority
33Overview
- Review of General Aspects
- Modular Performance Analysis
- Real-Time Calculus
- Modeling
- Application Scenarios
34Open Questions
- How do we model different event types and
correlation in event streams ? - How do we model type-dependent processing
(different modes of operation, example MPEG
coding and decoding) ? - How do we model caches ?
Use more involved abstractions, for example
finite state automata
35Refined Abstractions using FSMs
36Event Stream Model
events vs. time interval
order of events
37Functional Unit Model
input_event/resource_demand/output_event
- FSM can model
- architecture details
- program flow
- scheduling policies
- type-dependent behavior
- Improvement in estimation quality in several
application studies.
38Additional Analysis Methods
- Analyze timed FSMs with respect to their timing
properties. - For example
- Applicable methods minimum cycle mean Karp,
periodic graphs Cohen, Dubois, Quadrat
minimal and maximal accumulated
delay/demand/eventsfor n consecutive
transitions (and its inverse) in a
compact representation
39Missing Link(s)
- Link to lower layer analysis methods (like
abstract interpretation)
model of computer architecture
assembler program
analysis
d,e,f,g
a,b,c
40Overview
- Review of General Aspects
- Modular Performance Analysis
- Real-Time Calculus
- Modeling
- Application Scenarios
41Experiences
- Network processor modeling (IBM)
- Detailed study of a network processor
- Good match between simulation and analytic
methods (delay, memory) - Use of methodology in other projects and case
studies - BridgeCo
- Siemens
- Netmodule
- Implementation and integration into design space
exploration
42Application Model
- Example of a simple stream processing task
structure
43Architecture Model
- In general, we assume an arbitrary heterogeneous
architecture consisting of computing resources,
memory and communication resources.
44Design Space Exploration Strategy
45EXPO Tool architecture
MOSES
EXPO
SPEA 2
Exploration Cycle
46EXPO - Tool
Tool available online http//www.tik.ee.ethz.ch/e
xpo/expo.html
47Results
Performance for encryption/decryption
Performance for RT voice processing
48Acknowledgement
- The presentation contains contributions by
- Samarjit Chakraborty
- Matthias Dyer
- Simon Künzli
- Matthias Gries
- Alexander Maxiaguine