# System-On-Chip Specification Style Guide

Andreas Gerstlauer Kiran Ramineni Rainer Dömer Daniel D. Gajski

Technical Report CECS-03-21 June 25, 2003

Center for Embedded Computer Systems University of California, Irvine Irvine, CA 92697-3425, USA (949) 824-8919

http://www.cecs.uci.edu

# System-On-Chip Specification Style Guide

Andreas Gerstlauer Kiran Ramineni Rainer Dömer Daniel D. Gajski

Technical Report CECS-03-21 June 25, 2003

Center for Embedded Computer Systems University of California, Irvine Irvine, CA 92697-3425, USA (949) 824-8919

> gerstl@cecs.uci.edu kiran@cecs.uci.edu doemer@cecs.uci.edu gajski@cecs.uci.edu http://www.cecs.uci.edu

#### Abstract

Many recently proposed system-level design methodologies share the characteristic that the design flow starts from a golden, executable specification model. The specification model is captured by the designer and describes the desired system behavior in a purely functional way. As the starting point for the system-level design process, it will later be gradually refined through a series of interactive and automated steps down to an actual implementation. Therefore, having a clear and unambigious input model as defined by this manual is crucial for effective design space exploration.

In this report, we will describe and define a system specification style guide using the SpecC language and the design flow in the System-on-Chip Design Environment (SCE) as an example. Following some general guidelines for developing efficient specification models, detailed rules that define the specification modeling style are given. For the example of SCE used in this report, specification models are written in version 2.0 of the SpecC language. On top of the basic SpecC syntax and semantics, the modeling rules impose additional restrictions for a proper and valid specification model. Finally, steps required to convert an existing C description into a specification model are outlined and some conversion examples are given.

# Contents

| 1  | Intro | oduction                                    | 1      |
|----|-------|---------------------------------------------|--------|
|    | 1.1   | System Design Flow                          | 1      |
|    | 1.2   | SpecC Language                              | 2      |
|    | 1.3   | Specification Model                         | 3      |
| 2  | Mod   | alina Cuidalinaa                            | 2      |
| 4  |       | commutation .                               | 3<br>2 |
|    | 2.1   |                                             | 3<br>2 |
|    |       |                                             | 3      |
|    |       | 2.1.2 Hierarchy                             | 3      |
|    |       | 2.1.3 Encapsulation                         | 4      |
|    |       | 2.1.4 Concurrency                           | 4      |
|    |       | 2.1.5 Time                                  | 4      |
|    | 2.2   | Communication                               | 4      |
|    |       | 2.2.1 Semantics                             | 4      |
|    |       | 2.2.2 Dependencies                          | 5      |
| _  |       |                                             | _      |
| 3  | Mod   | eling Style                                 | 5      |
|    | 3.1   | Computation                                 | 5      |
|    |       | 3.1.1 Leaf Behaviors                        | 5      |
|    |       | 3.1.2 Hierarchical Behaviors                | 6      |
|    | 3.2   | Communication                               | 7      |
|    |       | 3.2.1 Behavior Interfaces (Ports)           | 7      |
|    |       | 3.2.2 Connectivity (Variables and Channels) | 7      |
|    | aa    |                                             | _      |
| 4  |       | de Conversion                               | 7      |
|    | 4.1   |                                             | 7      |
|    |       | 4.1.1 Syntactic Refinement                  | /      |
|    |       | 4.1.2 Semantic Refinement                   | 8      |
|    | 4.2   | Basic Constructs                            | 8      |
|    |       | 4.2.1 If (no else) Statement                | 8      |
|    |       | 4.2.2 If Else Statement                     | 8      |
|    |       | 4.2.3 While Statement                       | 9      |
|    |       | 4.2.4 Do While Statement                    | 9      |
|    |       | 4.2.5 For Statement                         | 0      |
|    | 4.3   | Composite Constructs                        | 0      |
|    |       | 4.3.1 Clean While and If Statements         | 0      |
|    |       | 4.3.2 Unclean While and If Else Statements  | 1      |
|    | 4.4   | Example                                     | 1      |
|    |       | 4.4.1 Translation: Step 1                   | 2      |
|    |       | 4.4.2 Translation: Step 2                   | 3      |
|    |       | 4.4.3 Translation: Step 3                   | 3      |
|    |       | 4.4.4 Translation: Step 4                   | 3      |
|    |       | 4.4.5 Translation: Step 5                   | 3      |
|    |       |                                             | _      |
| Re | feren | ces 14                                      | 4      |

# References

# List of Figures

| 1  | SCE design flow.                                                    | 2 |
|----|---------------------------------------------------------------------|---|
| 2  | Specification model top-level structure.                            | 5 |
| 3  | Specification model top-level code                                  | 5 |
| 4  | If statement.                                                       | 3 |
| 5  | If Else statement.                                                  | ) |
| 6  | While statement.                                                    | ) |
| 7  | Do While statement.                                                 | ) |
| 8  | For statement                                                       | ) |
| 9  | Combination of clean While and If statements                        | ) |
| 10 | Combination of unclean While and If Else statements                 | 1 |
| 11 | FSM for combination of unclean While and If Else statements         | 1 |
| 12 | Second combination of unclean While and If Else statements          | 1 |
| 13 | FSM for second combination of unclean While and If Else statements. | 2 |
| 14 | Complex example of nesting                                          | 2 |
| 15 | Step 1 - For Block                                                  | 3 |
| 16 | Step 2 - Do While Block 1                                           | 3 |
| 17 | Step 3 - Do While Block 2                                           | 3 |
| 18 | Step 4 - If Else Block                                              | 1 |
| 19 | While Block                                                         | 4 |

# System-On-Chip Specification Style Guide

A. Gerstlauer, K. Ramineni, R. Dömer, D. Gajski

Center for Embedded Computer Systems University of California, Irvine Irvine, CA 92697-3425, USA {gerstl,kiran,doemer,gajski}@cecs.uci.edu http://www.cecs.uci.edu

## Abstract

Many recently proposed system-level design methodologies share the characteristic that the design flow starts from a golden, executable specification model. The specification model is captured by the designer and describes the desired system behavior in a purely functional way. As the starting point for the system-level design process, it will later be gradually refined through a series of interactive and automated steps down to an actual implementation. Therefore, having a clear and unambigious input model as defined by this manual is crucial for effective design space exploration.

In this report, we will describe and define a system specification style guide using the SpecC language and the design flow in the System-on-Chip Design Environment (SCE) as an example. Following some general guidelines for developing efficient specification models, detailed rules that define the specification modeling style are given. For the example of SCE used in this report, specification models are written in version 2.0 of the SpecC language. On top of the basic SpecC syntax and semantics, the modeling rules impose additional restrictions for a proper and valid specification model. Finally, steps required to convert an existing C description into a specification model are outlined and some conversion examples are given.

# **1** Introduction

The System-On-Chip design environment (SCE) is an example of an implementation of a state-of-the-art systemlevel design methodology [1]. SCE is a framework that combines a set of tools under a common graphical user interface (GUI). Using this framework, the designer can take an initial specification down to an actual implementation through a series of interactive and automated steps. Starting from a purely functional description of the desired system behavior, an implementation of the design on a heterogoeneous system architecture with multiple processing elements (PEs) connected through system busses is produced at the end of the design flow.

# 1.1 System Design Flow

The SCE system-level design methodology is shown in Figure 1. The SCE methodology is a set of four models and three transformation steps that take a system specification down to an RTL implementation [1].

The system design flow consists of two main parts: (a) system synthesis, and (b) a backend for hardware and software synthesis. In the SCE methodology, system synthesis is further subdivided into two orthogonal tasks, architecture exploration and communication synthesis. Architecture exploration implements the computation behavior of the specification on a set of processing elements that form the system architecture. Communication synthesis, on the other hand, implements the communication functionality of the specification over the system busses.

Each system synthesis and backend task refines the model of the design at the current stage of the design process into a new model representing the details of the implementation added during the synthesis step. At the output of each task, the model of the design reflects the implementation decisions made in the previous step. At the same time, each model forms the input to the next task.

The system-level design process starts off with a specification of the desired system behavior. This specification model is written by the user and forms the input to the design process.

In the SCE methodology, the first task of system synthesis is architecture exploration. Architecture exploration selects a set of processing elements and maps the computation behavior of the specification onto the PEs. Architecture exploration refines the specification model into the intermediate architecture model. The architecture model describes the PE structure of the system architecture and the mapping of computation behaviors onto the PEs, in-



Figure 1: SCE design flow.

cluding estimated execution times for the behavior of each PE.

Architecture exploration is followed by communication synthesis to complete the system synthesis process. Communication synthesis selects a set of system busses and protocols, and maps the communication functionality of the specification onto the system busses. Communication synthesis creates the communication model which reflects the bus architecture of the system and the mapping of communication onto the busses.

The communication model is the result of the system synthesis process. It describes the structure of the system architecture consisting of PEs and busses, and the implementation of the system functionality on this architecture. It is timed in both computation and communication, i.e. simulation detail is increased by events for estimated execution and communication delays.

The communication model is a structural view at the system level. At the same time, the specification of the functionality of each PE of the system in the form of a behavioral view at the register-transfer level forms the input to the RTL synthesis of those components in the backend. In a hierarchical fashion, each PE is synthesized separately in the backend and the behavioral view of the PE is replaced with a structural view of its RTL or instruction-set (IS) microarchitecture. The result of this backend process is the implementation model.

The implementation model is a cycle-accurate, structural description of the RTL/IS architecture of the whole system. In a hierarchical fashion, the implementation model describes the system structure and the RTL structure of each PE in the system. Simulation detail is increased down to the clock level, i.e. the timing resolution is in terms of clock events for each local PE clock.

# **1.2 SpecC Language**

The SCE methodology is supported by the SpecC systemlevel design language [2]. The SpecC language as an example of a modern system-level design language (SLDL) was developed to satisfy all the requirements for an efficient formal description of the models in the SCE methodology. It supports behavioral and structural views and contains features for describing a design at all levels of abstraction.

In the SpecC methodology, all four models of the design process starting with the specification model and down to the implementation model are described in the SpecC language. One common language removes the need for tedious translation. Furthermore, all the models in SpecC are executable which allows for validation through simulation, reusing one single testbench throughout the whole design flow. In addition, the formal nature of the models enables application of formal methods, e.g. for verification or equivalence checking.

## **1.3 Specification Model**

As outlined previosuly, the specification model is the input to the SCE design flow. It is captured graphically or textually by the designer in the form of SpecC code to specify the system functionality to implement. All other models of the SCE design flow will be generated automatically from the specification model through a sequence of interactive, GUI-assisted refinement steps. As such, the specification model needs to precisely and unambiously describe the desired system behavior on top of the SpecC language semantics. Furthermore, the specification model defines the possible design space for exploration and quality of implementation results therefore depends to a large extent on the characteristics of the specification model. For example, any premature references to implementation detail will prevent exploration of solutions outside of the scope imposed by such restrictions.

In this manual, we define how to describe a specification of a system that can serve as the input to a modern systemlevel design process using SCE and the SpecC language as an example. First, a set of general guidelines for writing good specification models will be given in Section 2. Then, in Section 3, specific and detailed rules and restrictions imposed on the specification model style are defined. Finally, Section 4 describes how straight-line C code can be efficiently converted into a SpecC specification model.

# 2 Modeling Guidelines

The specification model is the input of the SCE design flow. It is captured by the user to specify the desired system functionality. The specification is a behavioral view of the system, i.e. it describes the desired functionality in an abstract manner. The specification model is a purely functional model, free of any implementation details. For example, objects at the specification level are abstract entities that do not correspond to real physical components.

A key aspect of the specification model is to separate computation from communication. On the one hand, this is a requirement for composability of a system out of components including the reuse of pre-existing IP components. On the other hand, this separation of concerns allows to implement computation and communication in two separate steps of the design flow.

# 2.1 Computation

In terms of computation, the specification is hierarchically composed of SpecC behaviors. Behaviors are arranged sequentially, concurrently, or in a mix of both, i.e. in a pipelined fashion. Behaviors at the leaves of the hierarchy contain basic algorithms in the form of straight-line C code that perform arithmetic and logical operations on data. In addition to temporary data, leaf behaviors will encapsulate any permanent storage required by the algorithm.

#### 2.1.1 Granularity

The basic, indivisible units of granularity for design space exploration are SpecC behaviors. That is, during the design process the specification will be partitioned along behavior boundaries but behaviors at the leaves of the hierarchy form the smallest, indivisible units for exploration. Therefore, leaf behaviors contain basic algorithms in the form of C code, reading from their inputs, processing a data set, and producing outputs.

Algorithms of the specification model are split into leaf behaviors along the boundaries defined between reading and writing of data structures. On the other hand, all the code needed to process a complete, consistent data set should be kept together in one leaf behavior.

Also, the ratio of communication to computation should be minimized yet the size of the leaf behaviors be kept small and manageable with well-defined, sensible interfaces and possible reuse in mind. As a rule of thumb, what would be a traditional C function will become a leaf behavior with typically half a page to maximally two pages of code.

## 2.1.2 Hierarchy

At each level of hierarchy, the system should be composed of self-contained blocks with well-defined interfaces enabling easy composition, rearrangement, and reuse. Closely related functionality is grouped through hierarchy. Higher-level behaviors encapsulate tightly coupled groups of subbehaviors such that the ratio of external to internal communication is minimized. On the other hand, the number of subbehaviors per parent should be kept small and manageable. As a guideline, behaviors typically have 2-5 children on average.

At each level, the behavior hierarchy should be clean. Different behavioral concepts shouldn't be mixed in the same level. A behavior is either a hierarchical composition of subbehaviors or a leaf behavior with sequential code. Similarly, a hierarchical behavior is either a sequential, parallel, pipelined or FSM composition of subbehaviors but does not contain arbitrary C code.

#### 2.1.3 Encapsulation

In general, information should be localized as much as possible. This includes code (functions, methods), storage (variables), and communication (port variables, channels). Each hierarchical unit (behavior) encapsulates and abstracts as many local details as possible, hiding them from the higher levels. Hierarchical behaviors encapsulate dependencies and communication of a group of subbehaviors, providing only an interface to their combined functionality.

At the leaves, behaviors encapsulates all the code and storage needed by the algorithm. As mentioned above, global, static variables become member variables of the leaf behavior. Furthermore, global functions that are called out of leaf behaviors should be avoided. Instead, depending on size and number of callers, consider converting functions into separate leaf behaviors that get instantiated as subbehaviors of the caller, or move global functions into the calling behavior where they become local methods. An exception are small helper functions with a few lines of code that are used ubiquitously and can be considered basic operations (on the same level as additions or multiplications).

#### 2.1.4 Concurrency

Any concurrency available between independent behaviors should be exposed through their parallel or pipelined composition. That is, all behaviors that do not have any control or data dependencies (or data dependencies only across iterations) should be arranged to execute in a concurrent fashion. Furthermore, the behavior hierarchy should be constructed in such a way as to maximize the number of independent behaviors and hence the available parallelism.

Dependent behaviors, on the other hand, should generally not be arranged in a concurrent fashion. Instead, their dependencies should be captured explicitly through transitions. An exception are rare (control) dependencies between otherwise highly independent top-level tasks, for example. In those cases, communication and synchronization are modeled using channels between the tasks.

In general, concurrent behaviors in the specification model should reflect the available parallelism in the specification. Therefore, they should be as independent as possible. Data or control dependencies between behaviors at the specification level should be explicitly captured through the behavior hierarchy. Instead of concurrent behaviors that communicate or synchronize through variables or events, the behaviors should be split into independent parts that can run in parallel and dependent parts that have to be executed sequentially.

# 2.1.5 Time

The specification model is untimed and all behaviors execute in zero logical time. Therefore, the only events in the system are events for synchronization in order to specify causality. The ordering of events in the system is based on causal relationships only and there is no notion of time. The system is partially ordered based on causality as determined by the explicit or implicit dependencies between behaviors. As the design flow progresses, timing information that will be added to the system will successively introduced additional order based on delays.

Apart from the untimed behavior, however, the specification model can contain constraints for execution times of parts of the specification. During the design process, it then has to be assured that any time introduced into the model does not violate any of the constraints.

# 2.2 Communication

In terms of communication, exchange of data between behaviors in the specification model is encapusulated into SpecC channels that connect behaviors through ports. Channels describe how data and synchronization messages are transfered between two communication partners in an abstract way.

#### 2.2.1 Semantics

In general, behaviors at the specification level communicate via message-passing channels. Behaviors exchange data by sending and receiving messages over communication channels with appropriate semantics. In the case of a sequential composition, message-passing degenerates to simple variables. Data is exchanged by reading and writing from/to the variable. In the case of a parallel composition with simple synchronization only, the synchronization is implemented via a single event. In the general case of data communication between concurrent behaviors, however, a message-passing channel is instantiated. The specification model instantiates channels out of a SpecC channel library with pre-defined, known semantics. The library contains channels with abstract communication semantics like buffered and unbuffered message-passing, FIFOs, shared-memory semaphores/mutexes, and so on. By using the predefined channels out of the library, commonly needed communication functionality is available for integration into the specification model.

Note that the specification models of channels do not imply any specific implementation of their abstract semantics. The code inside the channel is for simulation of the correct semantics during execution only. It is the task of communication synthesis to refine those abstract channels into an actual implementation of the desired semantics using the available system bus protocols and PE interfaces.

#### 2.2.2 Dependencies

Data dependencies should be reflected explicitly in the behavioral hierarchy as transitions between behaviors, either through a sequential composition or conditionally using the fsm statement. In this case, channels degenerate to simple variables connecting behaviors, and the need for implicit synchronization through message-passing is eliminated.

All dependencies are explicitly captured through the connectivity between behaviors and no hidden side effects exist. Global variables should be avoided completely. Static variables accessed from a single leaf behavior become member variables of that behavior. Global variables used for communication have to be turned into explicit dependencies in the form of connectivity as behaviors are only allowed to exchange data through their ports.

If the relationship of concurrent behaviors in the specification model extends beyond synchronization through pure events and necessitates some actual form of data communication, the specification needs to clearly separate such communication from the normal computation by encapsulating communication functionality in the form of channels.

# **3** Modeling Style

In general, the SCE specification input model is written in SpecC and as such has to adhere to the syntax and semantics of the SpecC language [2]. However, to form a valid specification model that can be input into the SCE design flow, additional rules and restrictions on top of the SpecC base have to be adhered to as defined in this section. Note that, apart from that, unless otherwise noted here, any valid SpecC code is an acceptable specification model.



Figure 2: Specification model top-level structure.

Figure 2 and Figure 3 show an example template for a valid specification model. A specification model has to be an executable SpecC model, i.e. it has to define a Main behavior. Usually, a specification model consists of a testbench that surrounds the actual design to be implemented. Typically, a testbench consists of stimulating (Stimulus) and monitoring (Monitor) behaviors that are executing concurrently to the acutal design (Design) in the topmost Main behavior, and that drive the design under test and check the generated output against known good values.

The design to be implemented is defined by a single SpecC behavior (Design) which in turn can be hierarchically composed out of a tree of subbehaviors. For a valid specification model, all the behaviors that are part of this tree have to comply with the rules and restrictions for describing computation and communication that will be defined in the following sections. Note, however, that these restrictions do not apply to the testbench part. Therefore, the testbench can be freely described using any valid SpecC code.

# 3.1 Computation

The computational part of the specification is described through the execution semantics of the hierarchy of SpecC behaviors that form the design to be implemented. For a valid specification model, this behavior hierarchy has to be clean. A clean hierarchy is defined as a tree of behaviors in which every behavior is either a leaf behavior or a hierarchical composition of subbehaviors as defined in the following sections.

#### 3.1.1 Leaf Behaviors

In each leaf behavior, the behavior main() method contains a piece of straight-line, plain ANSI-C code. Specifically, the following rules define the restrictions that apply to leaf behaviors.

```
import "c_double_handshake";
   behavior Stimulus(i_sender input) {
                                                            // Stimuli creator
     void main(void) {
       // while(...) {
                        ...; input.send(...); ... }
5
     }
   };
                                                            // Output monitor
   behavior Monitor(i_receiver output) {
    void main(void) {
10
                        ...; output.receive (...); ... }
       // while (...) {
     }
   };
15 behavior Design(i_receiver input, i_sender output) { // System design
     // ...
     void main(void) {
       // fsm { ... }
20
   };
   behavior Main() {
                                                            // Top level
     c_double_handshake input, output;
25
     Stimulus stimulus (input);
     Design
              design (input, output);
     Monitor
              monitor(output);
30
     int main(void) {
       par {
         stimulus .main();
         design.main();
         monitor.main();
35
       ł
     }
   };
```

Figure 3: Specification model top-level code.

**Rule 1** A leaf behavior must not contain any channel or behavior instances. It can, however, contain instances of variables.

**Rule 2** A leaf behavior has exactly one method, the main() method. Generally, the main() method contains any plain, valid ANSI-C code. Of the SpecC-specific types, expressions and statements, only the following are permitted:

- (a) calls to channel methods through behavior ports of interface type (see also Section 3.2.1),
- (b) notify and wait statements on behavior ports of event or signal type,
- (c) declarations of and operations on variables or ports of bit, long long, long double, or bool basic type, and
- (d) do-timing constructs to specify constraints.

**Rule 3** For leaf behaviors that should be implementable in hardware, depending on the capabilities of the backend

tool used for hardware synthesis, additional restrictions might apply (e.g. most tools can not synthesize pointers). If any of these restrictions are violated, the corresponding leaf behavior will be limited to a software implementation. In order to allow the greatest possible flexibility for exploration, these restrictions should be followed as much as possible for all leaf behaviors.

**Rule 4** Generally, leaf behaviors can make calls to global functions. However, leaf behaviors that call global functions can only be mapped to PEs that provide a native implementation of each global function in the processor library (i.e. as a link-level library in software or a dedicated functional unit in hardware). Therefore, global functions should be avoided completely as much as possible.

#### 3.1.2 Hierarchical Behaviors

A hierarchical behavior is a composition of several subbehavior instances in a sequential, parallel, pipelined or FSM fashion. More specifically, the following rules must be followed when composing hierarchical behaviors. **Rule 5** A hierarchical behavior has exactly one method, the main() method, and the main() method contains exactly one statement that is either

- a seq,
- *a par*,
- a pipe, or
- a fsm statement.

**Rule 6** A hierarchical behavior generally contains instances of subbehaviors that execute inside the hierarchical behavior's composition statement (by calling subbehavior main() methods). However, each subbehavior instance can be called at most once inside the composition. Subbehavior instances communicate through ports, variables and channel instances of the hierarchical behavior mapped to subbehavior ports (see Section 3.2.2).

**Rule 7** For the expressions in the arguments of a pipe() statement and in the if() statements of fsm transitions the same rules and restrictions as for the C code in leaf behaviors (Section 3.1.1) apply.

# 3.2 Communication

All communication in the specification model, both inside the design to be implemented and between the testbench and the actual design, is described through variables and channels that connect ports of behaviors.

# 3.2.1 Behavior Interfaces (Ports)

The list of ports of a behavior defines the interface between the behavior and its environment, i.e. behaviors are only allowed to communicate with other behaviors through their ports.

**Rule 8** Behaviors can have ports of standard (variable) type with direction or of interface type. In case of standard ports, ports that are of pointer type are not allowed. For ports of interface type, only interfaces that are part of the standard SpecC channel library are allowed.

**Rule 9** *Behaviors are not allowed to export any methods, i.e. they cannot implement any interfaces.* 

**Rule 10** Behaviors are not allowed to (directly or indirectly, e.g. through a call to a global function) access variables and channels that are outside of their local scope. Therefore, code inside behaviors can only reference variables or call methods of interfaces that are defined inside the behavior as ports or local instances. Hence, accesses of global variables or channels are forbidden.

# 3.2.2 Connectivity (Variables and Channels)

Inside hierarchical behaviors, the connectivity of subbehaviors instances is defined by mapping ports of the hierarchical behavior or or instances of variables and channels onto the ports of the subbehaviors.

**Rule 11** Ports of subbehavior instances inside a behavior can only be connected to the behavior's ports or to variables or channels instantiated inside the behavior. Hence, it is not allowed to map other subbehavior instances onto a subbehavior port.

**Rule 12** Given the restrictions on standard port types (see Section 3.2.1), variables used for connections (i.e. mapped to ports) must not be of pointer type.

**Rule 13** Variables with storage class piped are only allowed inside hierarchical behaviors with a pipe composition (see Section 3.1.2) to connect subbehaviors that act as pipeline stages.

**Rule 14** Only channels out of the standard SpecC channel library are allowed to be instantiated and mapped to ports.

# 4 C Code Conversion

In many cases, system design projects can leverage existing C code that describes all or part of the desired system functionality. In order to feed into the SCE design flow, such C models need to be converted into corresponding SpecC system models following the guidelines and rules described in Section 2 and Section 3, respectively.

The rest of this chapter will outline this process by showing how a straight-line C model can be converted into a valid SpecC specification model. For more information and details, please refer to [4].

# 4.1 Code Refinement

The code refinement process can be divided into two steps, namely, *syntactic refinement* and *semantic refinement*.

# 4.1.1 Syntactic Refinement

As a first step of C code conversion, syntactic refinement converts a C program into a semantically equivalent SpecC program through purely syntactical conversions.

Basically, syntactic refinement converts the C functional call hierarchy into an equivalent SpecC behavioral hierarchy. In general, each C function is converted into a SpecC behavior and behaviors are composed hierarchically according to the hierarchy of function calls in the C program.

If necessary, adjustments to the behavior granularity can be made during this step.

An important aspect of this refinement process is to make data dependencies in the C code explicit by exposing and converting them into corresponding behavior dependencies through ports and connections. On the one hand, function parameters and arguments can be directly converted into behavior ports. On the other hand, however, global variables need to be localized and any accesses to formely global variables have to be routed through ports of the hierarchy.

#### 4.1.2 Semantic Refinement

On top of syntactic refinement, semantic refinement is concerned with removing artifical restrictions imposed on the description by the limitations of the semantics of the C language. Based on the extended semantics of the systemlevel design language, the specification is refined to model the desired system behavior in a more natural way.

The main aspect of semantic refinement is to expose all available parallelism in the specification using parallel and pipelined compositions of the SpecC language wherever possible. Neither the concept of pipelining nor parallelism exists within the C language. However, to efficiently perform exploration, a system level design model must provide these two concepts.

- **Parallel** Two behaviors are combined in a parallel composition if the execution sequence of the two behaviors does not influence the simulation result. Otherwise, the two behaviors are defined as behavior-sequential.
- **Pipelined** If, within a sequential programming model, a number of behaviors are executed one after another in a loop body, and one behavior communicates only with the next behavior, then the behaviors should be composed in a pipelined fashion.

# 4.2 Basic Constructs

In this section, we specify guidelines for C to SpecC translation for different control statements by recognizing some basic patterns in a typical input C program.

## 4.2.1 If (no else) Statement

An If statement (Figure 4(a)) is clean, if the code inside the braces of if condition (*If Clean Code Segment*) is a sequence of data statements only and if there are no calls to other behaviors. For this type of statement, we can get valid SpecC code just by wrapping the whole block of the If statement as is into a leaf behavior.



Figure 4: If statement.

An If statement (Figure 4(b)) is unclean, if the code inside the braces of the if condition (*If Unclean Code Segment*) is a composite of data statements as well as calls to other behaviors. *Start* and *End* states are fictitious dummy states which correspond to entrance and exit, respectively inside *If\_fsm\_block*. First task for converting this type of code is transforming *If Unclean Code Segment* into a composite behavior which is clean in SpecC. *If condition check* can be transformed to a *Yes/No FSM* (Finite State Machine) as it resembles decision making as it resembles decision making. If the condition is satisfied then the behavior representing *If Unclean Code Segment* will be called.

#### 4.2.2 If Else Statement

An If Else statement (Figure 5) differs from an If statement (Figure 4) on including an *Else* part. An If statement is a subset of an If Else statement since an If statement does not have an Else part. An If Else statement (Figure 5(a)) is clean if the code inside the braces of if condition (*If Clean Code Segment*) and else condition (*Else Clean Code Segment*) are sequences of just data statements and there are no calls to other behaviors. For this type of statement, we can get valid SpecC code just by wrapping the whole blocks of *If Clean Code Segment* and *Else Clean Code Segment* with the condition check into a leaf behavior.

An If Else statement (Figure 5(b)) is unclean if it satisfies one of the conditions below:

- (a) If part Code Segment is Unclean
- (b) Else part Code Segment is Unclean



Figure 5: If Else statement.



To derive a valid SpecC code, first we need to make one composite behavior for each of If and Else Unclean code segments. Then, we can introduce *Yes/No FSM* for the condition check. If the condition is satisfied, we make a call to the If composite behavior. Otherwise, we call the Else composite behavior.

#### 4.2.3 While Statement

A While statement (Figure 6(a)) is clean if *While Clean Code Segment* is a sequence of just data statements and there are no calls to other behaviors. For this type of statement, we can get valid SpecC code just by wrapping the whole block of the While statement as is into a leaf behavior.

A While statement (Figure 6(b)) is unclean if While Unclean Code Segment is a composite of data statements as well as calls to other behaviors. First step in converting this type of code is transforming While Unclean Code Segment into a composite behavior which is clean in SpecC. If condition check can be transformed to a Yes/No FSM as it resembles decision making. If the condition is satisfied then the behavior representing While Unclean Code Segment will be called and then the control loops back to the condition checking. This will repeat until the condition becomes false. Then, Exit state (End) will be called which signifies end of the while statement.



Figure 6: While statement.

#### 4.2.4 Do While Statement

A Do While statement (Figure 7) is just a small modification to the While statement (Figure 6). In the While statement, the condition is checked first before executing *While* (*Un*)clean Code Segment. On the contrary, in the Do While statement, first the Do While (*Un*)clean Code Segment is executed and then the condition is checked.

A Do While statement (Figure 7(a)) is clean if *Do While Clean Code Segment* is a sequence of just data statements and there are no calls to other behaviors. For this type of statement, we can get valid SpecC code just by wrapping the whole block of the Do While statement as is into a leaf behavior.

A Do While statement (Figure 7(b)) is unclean if *Do While Unclean Code Segment* is a composite of data statements as well as calls to other behaviors. First step in converting this type of code is transforming *Do While Unclean Code Segment* into a composite behavior which is clean in SpecC. *If condition check* can be transformed to a *Yes/No FSM* as it resembles decision making. When executed, first the behavior representing *Do While Unclean Code Segment* is called then the If condition checked with *Yes/No FSM*. If the condition satisfies, then the behavior representing *Do While Unclean Code Segment* will be called and then the control loops back to *Yes/No FSM*. This will repeat until the condition becomes false. Then, Exit state (End) will be called which signifies end of the do while statement.



Figure 7: Do While statement.





Figure 8: For statement.

A For statement (Figure 8) is just a small modification to the While statement (Figure 6). In the While statement, there is only one block of code (*While* (*Un*)clean *Code Segment*) where as in the For statement, along with *For* (*Un*)clean Code Segment there are two more blocks of code. One block is *init* statements and the other is *post* statements. *Init* statements are executed once at the start of the For statement block. Post statements are executed everytime the For (*Un*)clean Code Segment is executed.

A For statement (Figure 8(a)) is clean if For Clean Code

*Segment* is a sequence of just data statements and there are no calls to other behaviors. For this type of statement, we can get valid SpecC code just by wrapping the whole block of the For statement as is into a leaf behavior.

A For statement (Figure 8(b)) is unclean if *For Unclean Code Segment* is a composite of data statements as well as calls to other behaviors. First step in converting this type of code is transforming *For Unclean Code Segment* into a composite behavior which is clean in SpecC. Then transform init and post statements to appropriate clean SpecC behaviors. Generally, init and post statements contain some variable initialization, increment and decrement operations. So, they can be easily translated to leaf behaviors if they contain just the data statements and no calls to other behaviors. Otherwise, they are transformed to composite behaviors. *Condition check* can be transformed to a *Yes/No FSM* as it resembles decision making.

When executed, first the behavior representing *Init* statement is called once and then the *Yes/No FSM* is called. If the condition is satisfied then the behavior representing *For Unclean Code Segment* will be called followed by *Post* behavior and then the control loops back to *Yes/No FSM*. This loop will repeat until the condition becomes false. Then, Exit state (End) will be called which signifies end of the for statement.

# 4.3 Composite Constructs

This section deals with translating C code with various combinations of basic constructs into SpecC code.

#### 4.3.1 Clean While and If Statements



Figure 9: Combination of clean While and If statements.

A While statement is combined with an If statement as Figure 9 depicts. But both statements are clean. So, the translation is simple as we wrap both these statements into a simple leaf behavior.

#### SpecC



# C Code

# (b) UnClean Code

While(cond



Figure 10: Combination of unclean While and If Else statements.

In Figure 10, a While statement which is unclean is combined with an If Else statement. The unclean While statement translation is done according to Figure 6 and the If Else statement translation is done according to Figure 5. Since the If Else statement is a sequence to *While Unclean Code Segment*, a new finite state (if\_fsm\_block) is introduced just after the behavior representing *While Unclean Code Segment*. So, the final translation is nothing but plugging the right FSMs which represent the basic building blocks at the right places (Figure 11).

Figure 12 shows another example that differs from the previous combination (Figure 10) in the sequence of execution of *If Else* and *While Unclean Code Segment*. As the Figure 13 illustrates, the *While Unclean Code Segment* is the sequence to the If Else statement. Appropriate changes (flipping the basic blocks) are made to the sequence of execution in Figure 13 which differs from Figure 11.

# 4.4 Example

Figure 14 depicts a complex nesting of one for loop, two Do while loops, one If Else statement and one While loop. Here, only While block has calls to other behaviors. While block is a Composite behavior having two sequential leaf behaviors named *leaf\_behavior\_l* and *leaf\_behavior\_2*. The code segments in all other blocks are clean as they only have data statements. But, since While block is the



FSM representing while if statement

Figure 11: FSM for combination of unclean While and If Else statements.

# C Code

# (b) UnClean Code

# While(cond){



Figure 12: Second combination of unclean While and If Else statements.



FSM representing while if statement

Figure 13: FSM for second combination of unclean While and If Else statements.



Figure 14: Complex example of nesting.

inner most block inside the nesting, it is propagating unclean behavior to the If Else block. The If Else block, in turn makes the Do While block 2 unclean. The Do While block 2 makes the Do While block 1 unclean which in turn makes the For block unclean. So, this is like a *ripple effect* where unclean behavior in the deepest child behavior makes the top most parent unclean.

We can adopt two approaches to get a valid SpecC code out of this huge complex nesting of different basic blocks: a top-down or a bottom-up approach.

When we apply a top-down flow on Figure 14, ordering follows this pattern:

- 1. For Block
- 2. Do While Block 1
- 3. Do While Block 2
- 4. If Else Block
- 5. While Block

If we follow a bottom-up approach, the order is reversed. First we work on the inner most block, make it clean, then work on the its immediate parent block and so on, till we reach the top most block.

For this example, we will show a top-down approach in making this complex example clean.

## 4.4.1 Translation: Step 1

While working on the top most block, we abstract the next level block and we include it as a child behavior. The For block (Figure 15) has a small modification from Figure 8. Figure 8 contains a behavior encapsulating a for unclean code segment but Figure 15 has a composite behavior with two sequential behaviors. One of the two sequential behaviors is the leaf behavior encapsulating *clean\_code\_segment\_1* and the other one is *abstracted Do\_While\_behavior\_1*.

SpecC epee



Figure 15: Step 1 - For Block.

## 4.4.2 Translation: Step 2

*Do\_while\_Block\_1* (Figure 16) is a parent to Do\_while\_Block\_2. We can abstract the latter as a simple behavior following the execution of *clean\_code\_segment\_2*. So, the simplest translation possible is embedding *clean\_code\_segment\_2* into a leaf behavior and abstracting Do\_while\_Block\_2 as a simple behavior. Finally, by modifying Figure 7 so that the hierarchial behavior reflects two sequential behaviors (clean\_code\_segment\_2 and Do\_While\_block\_2) in substitution of the *unclean\_code\_segment*, we get a valid SpecC translation.

## 4.4.3 Translation: Step 3

Step 3 (Figure 17) is similar to step 2 (Figure 16) except that *Do\_while\_Block\_2* has *If\_Else\_block* as the child block.

#### 4.4.4 Translation: Step 4

*If\_Else\_block* (Figure 18) has *While\_block* as the child block and Figure 18 depicts the difference from Figure 5 in that *else block* is a composite sequential behavior consisting of a clean leaf behavior for *clean\_code\_segment\_3* and an *abstracted while* (child) behavior.

### 4.4.5 Translation: Step 5

Step 5 (Figure 19) depicts the inner most while block. This while block has a sequence of two behaviors named *leaf\_behavior\_1* and *leaf\_behavior\_2*. Figure 19 depicts

#### SpecC epee



FSM representing do while blocks

Figure 16: Step 2 - Do While Block 1.

## Specc transformation



FSM representing do while blocks

Figure 17: Step 3 - Do While Block 2.

#### Specc transformation



FSM representing if else and while blocks

Figure 18: Step 4 - If Else Block.

#### Specc transformation



FSM representing while blocks

Figure 19: While Block.

the difference from Figure 6 in that there is a composite sequential behavior containing *leaf\_behavior\_l* and *leaf\_behavior\_2*.

# References

- [1] A. Gerstlauer, R. Dömer, J. Peng, D. Gajski. *System Design: A Practical Guide with SpecC*. Kluwer Academic Publishers, 2001.
- [2] R. Dömer, A. Gerstlauer, D. Gajski. SpecC Language Reference Manual, Version 2.0. SpecC Technology Open Consortium (STOC), Japan, December 2002.
- [3] A. Gerstlauer. SpecC Modeling Guidelines. CECS Technical Report 02-16, Center for Embedded Computer Systems, Irvine, April 2002.
- [4] K. Ramineni, D. Gajski. C To SpecC Conversion Style. CECS Technical Report 03-13, Center for Embedded Computer Systems, Irvine, April 2003.