



2499-24

#### International Training Workshop on FPGA Design for Scientific Instrumentation and Computing

11 - 22 November 2013

Introduction to SoC Modeling

Julio D. DONDO GAZZANO

Departamento de Tecnologias y Sistemas de la Informacion, Escuela Superior de Informatica, Universidad de Castilla la Mancha Ciudad Real Spain

# Introduction to System on Chip modelling



Source:http://memetician.livejournal.com/201202.htm

International Training Course on FPGA Design for Scientific Instrumentation and Computing



Source: http://historiadelarte-amparosantos.blogspot.com/2010/04/la-sagrada-familia-antonio-gaudi.html

### Model

What a model is?

An abstract view of a design. Providing relevant aspects Hiding non relevant ones

# Design gap



Figure DESN3 Hardware and Software Design Gaps versus Time5

Source: The International Technology Roadmap for Semiconductors: 2009

Traditional design methods, in which systems are designed directly at the low hardware or software levels, are fast becoming infeasible.

One solution for closing the productivity gap is to raise the level of abstraction in the design process.



What the components generated at circuit level are?



Cells, formed by P-type and N-type transistors.



Cells, formed by P-type and N-type transistors.

Library of cells





Logic gates and flip-flops to generate register-transfer components



Logic gates and flip-flops to generate register-transfer components

Library of logic gates to create components at RTL level, such as registers, register files, ALUs, multipliers, and other components for processor micro architecture



On the processor level, standard and custom processors, or special-hardware components (memory controllers, arbiters, bridges, routers, and various interface components) are generated.

PE Processing Elements
CE Communication Elements



At this level it is also performed the floorplanning, placement, and routing of these PEs or CEs using the components from RTL library, and they are stored in a Processor library.



Finally, on the system level, standard or embedded systems formed by processors, buses, memories, and other processor components are designed.

#### Three different views



#### Three different views



Structural view

the black box is represented as a set of components and connections

#### Three different views



Structural view

Specifies the size and the position of each component, as well as each port and its connection.

#### Three different views





Julio Dondo Gazzano ICTP 2013 20



Julio Dondo Gazzano ICTP 2013 21

#### Three different views

Structural view Behavioural view System Processor Each component in the database needs a model Processor Logic representing the different components Circuit view. RTL components Logic components **Transistor** components Physical view Lay-out **ICTP 2013** Julio Dondo Gazzano 22

#### Three different views

Structural view Behavioural view System Processor Each component in the database needs a model **Processor** Logic representing the different components Circuit view. RTL components for the higher three abstraction levels, we only need a Logic components functional model of each component with estimates **Transistor** of the key metrics such as performance, delay, power, size, components reliability, testability, etc. Physical view Lay-out

**ICTP 2013** 

23

Julio Dondo Gazzano

### Processor-level behavioural model

On the processor level we design processing elements (PE) PE can be a custom component or a standard Processor

The behaviour or the functionality of PE can be described using

- **FSM:** Finite state machine can be made clock-accurate if each state takes one clock cycle.
- **FSMD:** Finite state machine with data. Extended version of FSM with integer or floating point variable.
  - FSMD model is usually not clock-accurate since computation in each state may take more than one clock cycle.
  - FSMD model is not adequate to represent the computation expressed by standard programming languages such as C.
- **CDFG: Control-Data Flow Graph**. It represents any programming-language code
- **ISFC: Instruction Set Flow Chart** describing the fetch, decode and execute stage of each instruction of standard PE.

### Processor-level behavioural model



Control-Data Flow Graph

### Processor-level structural model

Processor structural model usually consists of a controller and a datapath

A datapath consists of a set of storage elements (such as registers, register files, and memories), a set of functional units (such asALUs, multipliers, shifters, and other custom functional units), and a set of busses.



# System-level behavioural model

Multiple processes running in parallel in Sw and Hw require a system-level model.

In order to represent a many-processor platform working in parallel or in pipelined mode, we must introduce concurrency and pipelining in the model.

If processes are working concurrently it is necessary a synchronization mechanism for data exchange.

The model must support Hierarchy.



# System-level structural model

It is a netlist of system components used for computation, storage, and communication



A system structural model is generated from the given behavioural model by the process called **system synthesis.** 



Set of sequential and parallel processes communicating through message-passing channels





The platform can be defined through the estimation of performace, power, reconfigurability, etc

Once the platform is

defined, an application must be partitioned and each partition assigned to a processor or IP in the platform



32







After we obtain a satisfactory application code, platform, and mapping, we can synthesize each component

#### System-level synthesis



After synthesis, we need to generate a CAM (Cycle accurate model) model that contains binaries for downloading to processors and RTL descriptions for the HW parts in the platform.

## Modelling

System behaviour and models can be defined using

- Models of computation (MoC)
- Design languages

MoCs are generally based on a decomposition of behavior into pieces and their relationships in the form of well-defined objects and composition rules.

**Process – based**: data oriented, concurrent processes

**State – based**: control-dominated applications

## Modelling

System behaviour and models can be defined using

- Models of computation (MoC)
- Design languages

System Design Languages:

**Netlist and schematic:** structural representations of the design as a set of components and their connectivity. i.e: Electronic Design Interchange Format (EDIF), at gate level. Variant of XML to capture netlist of system platforms.

**HDL:** To represent not only the netlist and structure of designs but also their behaviour (VHDL, VERILOG)

**System-level design language:** to model the hardware side of a design and parts of the system implemented in software. (C, C+HDL – System Verilog, SystemC, SpecC)

Orthogonality between Computation and communication

On the computation side, the basic system component is a processor. The processor executes part of an application.

At the specification level, the application is modelled as a network of communicating processes.

In case of software processor, applications run on top of an OS. Then, a model of OS is needed to introduce accurate representations of the scheduling of parallel processes on the inherently sequential processors.

#### Computation modelling



At the specification level, the application is modelled as a network of communicating processes.

#### Computation modelling



In case of software processor, applications run on top of an OS. Then, a model of OS is needed to introduce accurate representations of the scheduling of parallel processes on the inherently sequential processors.

41

The model of the OS provides dynamic scheduling and multi-tasking services

#### Computation modelling



Application and OS software has to run on top of the actual processor hardware, which realizes physical bus interfaces and interrupts (including processor suspension and interrupt timing) for communication with the external world

#### Computation modelling



Then a hardware abstraction layer (HAL) is introduced providing interfaces, such as bus drivers and interrupt service routines (ISRs) for accessing the processor hardware from the software (i.e., application and OS) side.

HAL is the lowest level of functionality implemented in software

#### Computation modelling



With the final hardware layer, an accurate model of the actual processor hardware is included. The processor hardware model specifically captures details of physical bus interfaces and of interrupt handling behaviour.

bus

#### Communication modelling

Based on ISO/OSI 7 layer model.

| Layer          | Functionality                 | Implementation | OSI |
|----------------|-------------------------------|----------------|-----|
| Application    | Computation                   | Application    | 7   |
| Presentation   | Data formatting               | OS             | 6   |
| Session        | Synchronization, multiplexing | OS             | 5   |
| Transport      | Packeting, flow control       | OS             | 4   |
| Network        | Subnet bridging, routing      | OS             | 3   |
| Link           | Point-to-point logical links  | Driver         | 2b  |
| Stream         | Multiplexing, addressing      | Driver         | 2b  |
| Media access   | Data slicing, arbitration     | HAL            | 2a  |
| Protocol Media | Protocol timing               | Hardware       | 2a  |
| Physical       | Driving, sampling             | Interconnect   | 1   |

## System Model



## System Model



## System Model



For implementation designers

# Thank you and Good luck!