## Embedded System Design and Synthesis

#### Robert Dick

http://ziyang.eecs.northwestern.edu/~dickrp/esds-two-week Department of Electrical Engineering and Computer Science Northwestern University

Office at Tsinghua University: 9-310 East Main Building







## Available resources - System-level

- · General-purpose SW processors
- · Digital signal processors (DSPs)
- Application-specific integrated circuits
- Dynamically reconfigurable hardware
  - $\cdot$  E.g., field-programmable gate arrays (FPGAs)
- Busses
- · Wireless communication channels
- Wires

Specification language requirements

- · Describe hardware (HW) and software (SW) requirements
- · Specify constraints on design
- · Indicate system-level building blocks
- · To allow flexibility in synthesis, must be abstract
  - Differentiate HW from SW only when necessary
  - Concentrate on requirements, not implementation
  - · Make few assumptions about platform

ANSI-C

## Advantages

- · Huge code base
- · Many experienced programmers
- · Efficient means of SW implementation
- · Good compilers for many SW processors

#### Disadvantages

- · Little implementation flexibility
  - Strongly SW oriented
  - Makes many assumptions about platform
- · Poor support for fine-scale HW synchronization

Short and fat vs. tall and thin

Specification and modeling languag



Available resources - High-level

- · Simple arithmetic/logic units
- · Multiplexers
- · Registers
- · Wires

Software oriented design representations

- · ANSI-C
- SystemC
- · Other SW language-based

SystemC

## Advantages

- · Support from big players
  - Synopsys, Cadence, ARM, Red Hat, Ericsson, Fujitsu, Infineon Technologies AG, Sony Corp., STMicroelectronics, and Texas Instruments
- · Familiar for SW engineers

## Disadvantages

- · Extension of SW language
  - · Not designed for HW from the start
- · Compiler available for limited number of SW processors
  - · New

#### Hardware oriented design representations

· Numerous competitors

Other SW language-based

- · Numerous languages
  - $\cdot\,$  ANSI-C, C++, and Java are most popular starting points
- · In the end, few can survive
- · SystemC has broad support



#### Advantages

- · Supports abstract data types
- · System-level modeling supported
- · Better support for test harness design

#### Disadvantages

- · Requires extensions to easily operate at the gate-level
- · Difficult to learn
- · Slow to code



- · March 1995, Synopsys Users Group meeting
- · Create a gate netlist for the fastest fully synchronous loadable 9-bit increment-by-3 decrement-by-5 up/down counter that generated even parity, carry and borrow
- · 5 / 9 Verilog users completed
- · 0 / 5 VHDL users competed

Does this mean that Verilog is better?

Maybe, but maybe it only means that Verilog is easier to use for simple designs.



- · Dataflow graph (DFG)
- · Synchronous dataflow graph (SDFG)
- · Control flow graph (CFG)
- · Control dataflow graph (CDFG)
- · Finite state machine (FSM)
- · Petri net
- · Periodic vs. aperiodic
- · Real-time vs. best effort
- · Discrete vs. continuous timing
- · Example from research

- · VHDL
- · Verilog · Esterel
- Verilog

#### Advantages

- · Easy to learn
- · Easy for small designs

#### Disadvantages

- · Not designed to handle large designs
- · Not designed for system-level



- · Easily allows synchronization among parallel tasks
- · Works above RTL
  - · Doesn't require explicit enumeration of all states and transitions
- · Recently extended for specifying datapaths and flexible clocking schemes
- · Amenable to theorem proving
- · Translation to RTL or C possible
- · Commercialized by Esterel Technologies





- · Nodes are tasks
- · Edges are data dependencies
- · Edges have communication quantities
- · Used for digital signal processing (DSP)
- · Often acyclic when real-time
- · Can be cyclic when best-effort

## Synchronous dataflow graph (SDFG)



22

Robert Dick

Embedded System Design and Synthesis

Specification and modeling languages Homework Software oriented design representations Hardware oriented design representation Graph based design representations

## Control dataflow graph (CDFG)



Robert D

Embedded System Design and Synthesis

Specification and modeling languages

Software oriented design representations Hardware oriented design representations Graph based design representations Resource descriptions

#### Finite state machine (FSM)

|         | input |    |
|---------|-------|----|
|         | 0     | 1  |
| 00      | 10    | 00 |
| 01      | 01    | 00 |
| 10      | 00    | 01 |
| 11      | 10    | 00 |
| current | next  |    |

- · Normally used at lower levels
- · Difficult to represent independent behavior
  - · State explosion
- · No built-in representation for data flow
  - · Extensions have been proposed
- Extensions represent SW, e.g., co-design finite state machines (CFSMs)



M/D/3/2: Markov arrival, deterministic service delay, From A. Zimmermann's token game demonstration.

Control flow graph (CFG)



Introduction Software oriented design representations Hardware oriented design representations Graph based design representations

## Finite state machine (FSM)



Robert Dic

Embedded System Design and Synthesi

Specification and modeling languages

Introduction
Software oriented design representation
Hardware oriented design representatio
Graph based design representations

## Petri net

- · Graph composed of places, transitions, and arcs
- $\cdot$  Tokens are produced and consumed
- $\cdot$  Useful model for asynchronous and stochastic processes
- · Places can have priorities
- $\cdot$  Not well-suited for representing dataflow systems
- $\cdot$  Timing analysis quite difficult
- $\cdot$  Large flat graphs difficult to understand

27 Robert Dick Embedded System Design and Synthesis

Specification and modeling languages Homework

Periodic graphs

Robert Dick Embedded System Design and Synthesis

Introduction
Software oriented design representations
Hardware oriented design representations
Graph based design representations
Resource descriptions

- · Some system specifications contain periodic graphs
- $\cdot$  Can guarantee scheduling validity by scheduling to the least common multiple of periods
- · Can also meet aperiodic specifications, however, resources will sometimes be idle

#### Periodic graphs



30 Robert Dick Embedded System Design and Synthesis

Specification and modeling languages Homework

Periodic vs. aperiodic

Robert Dick Embedded System Design and Synthesis

Introduction
Software oriented design representations
Graph based design representations
Resource descriptions

#### Periodic applications

- · Power electronics
- · Transportation applications
  - · Engine controllers
  - · Brake controllers
- · Many multimedia applications
  - · Video frame rate
  - Audio sample rate
- · Many digital signal processing (DSP) applications

However, devices which react to unpredictable external stimuli have aperiodic behavior

Many applications contain periodic and aperiodic components

Specification and modeling languages
Homework

Aperiodic to periodic

Robert Dick

Embedded System Design and Synthesis

Introduction
Software oriented design representations
Hardware oriented design representations
Graph based design representations
Resource descriptions

- · Can easily build a periodic representation with a deadline and period of 5 ms
  - Problem, requires a 50 ms execution time when 100 ms should be sufficient
- · Can use overlapping graphs to allow an increase in execution time
  - · Parallelism required

The main problem with representing aperiodic problems with periodic representations is that the tradeoff between deadline and period must be made at the time of synthesis

34 Robert Dick Embedded System Design and Synthesis

Specification and modeling languages Homework

Discrete vs. continuous timing

# System-level: continuous

- $\cdot$  Operations are not small integer multiples of the clock cycle High-level: discrete
- $\dot{}$  Operations are small integer multiples of the clock cycle Implications:
  - $\cdot \ \, \mathsf{System-level} \,\, \mathsf{scheduling} \,\, \mathsf{is} \,\, \mathsf{more} \,\, \mathsf{complicated}. \, \ldots$
  - $\cdot$  ... however, high-level also very difficult.

## Aperiodic graphs

- · No precise periods imposed on task execution
- · Useful for representing reactive systems
- · Difficult to guarantee hard deadlines in such systems
  - · Possible if minimum inter-arrival time known

Specification and modeling languages Homework

Aperiodic to periodic

Robert Dick

Embedded System Design and Synthesis

Introduction
Software oriented design representations
Hardware priented design representations
Resource descriptions
Resource descriptions

Can design periodic specifications that meet requirements posed by aperiodic specifications

· Some resources will be wasted

#### Example:

- · At most one aperiodic task can arrive every 50 ms
- $\cdot$  It must complete execution within 100 ms of its arrival time

Specification and modeling languages
Homework

Real-time vs. best effort

Embedded System Design and Synthesis

Introduction
Software oriented design representations
Graph based design representations
Resource descriptions
Resource descriptions

- · Why make decisions about system implementation statically?
  - · Allows easy timing analysis, hard real-time guarantees
- · If a system doesn't have hard real-time deadlines, resources can be more efficiently used by making late, dynamic decisions
- · Can combine real-time and best-effort portions within the same specification
  - · Reserve time slots
  - Take advantage of slack when tasks complete sooner than their worst-case finish times

Specification and modeling languages Homework

Processing resource description

Resource descriptions

- · Often table-based
- · Price, area
- · For each task
  - · Execution time
  - · Power consumption
  - · Preemption cost
  - · etc.
- · etc

Similar characterization for communication resources  $\mbox{\sc Wise}$  to use process-based

Introduction
Software oriented design representations
Hardware oriented design representations
Graph based design representations

### Communication resource description

- · Can use bus-bridge based models for distributed systems
- · Wireless models
- · etc.
- · However, in the future, it will become increasingly important to base SOC communication model on process parameters

Specification and modeling languages Homework System-level representations summary

Embedded System Design and Synthesis

Introduction
Software oriented design representations Graph based design representations Resource descriptions

System-level representations summary

- · No single representation has been decided upon
- · Software-based representations becoming more popular
- · System-level representations will become more important
- · This is still an active area of research

Specification and modeling languages
Homework

Interesting future direction

Robert Dick

Embedded System Design and Synthesis

Introduction
Software oriented design representations
Hardware oriented design representations
Graph based design representations
Resource descriptions

#### Open problem

- Can specification be so simple for some embedded application domains that application experts who are not computer engineers easily do it?
- $\cdot$  What HCI, compiler, and synthesis support is required?

43 Robert Dick Embedded System Design and Synthesis

Specification and modeling languages Homework

Reading assignment

Robert P. Dick. *Multiobjective Synthesis of Low-Power Real-Time Distributed Embedded Systems*. PhD thesis, Dept. of Electrical Engineering, Princeton University, July 2002: Chapter 4

· Definitions and introduction to stochastic optimization

#### Data-flow graphs

- · Multirate
- · Hard real-time

Example from research

- · Some aperiodic hard real-time tasks
- · May have best-effort tasks

40 Robert Dick Embedded System Design and Synthesis

Specification and modeling languages Homework

Notes on clustering and partitioning

- · Interdependence with architecture
- · Heterogeneity's impact on partitioning
- · Applications to grid computing
- · Dynamic partitioning

42 Robert Dick Embedded System Design and Synthesis

Specification and modeling languages Homework

Clustering and system-level pipelining references

- Steven Edwards, Luciano Lavagno, Edward A. Lee, and Alberto Sangiovanni-Vincentelli. Design of embedded systems: Formal models, validation, and synthesis. *Proc. IEEE*, (3):366–390, March 1997
  - · Recent technical report from embedded systems languages expert
- Wayne Wolf. Embedded computing systems and hardware/software co-design. In Wai-Kai Chen, editor, *The VLSI Handbook*. CRC Press, 2006

Assignment: Write a short paragraph describing the most important points in both of these articles.

Specification and modeling languages Homework

Decide topics and groups for project

## Determine counts for each, add additional topics

- Models and languages
- · Formal methods for designing reliable embedded systems
- Reliability optimization
- Heterogeneous multiprocessor synthesis
- Real-time systems
- Scheduling

Embedded System Design and

Rol

Robert Dick

Embedded System Design and Synthesis

# Decide topics and groups for project

## Determine counts for each, add additional topics

- Compilation techniques for embedded systems
- Embedded operating systems
- Low-power and power-aware design
- Low-power and power-aware design (continued)
- Novel fabrication techniques for compact and low-power embedded systems
- <sup>6</sup> Emerging applications: sensor networks
- Hardware and software data compression for use in embedded

## Next class

- · Overview of optimization techniques
- $\cdot$  Example solution to heterogeneous MPSoC synthesis problem
- $\cdot$  Survey of formal methods for designing reliable embedded systems