





Projektiranje programabilnih SoC platformi ID 222683

## SYSTEMC SYSTEM-LEVEL MODELING





### SYSTEMC SYSTEM DESIGN METHODOLOGY



 used for accelerating the software development by modelling a SOC

- Refinement Methodology:
  - The design is not converted from a C level description to an HDL in one large effort.
  - The design is slowly refined in small sections to add the necessary hardware and timing constructs to produce a good design.
    - Using this refinement methodology, the designer can more easily implement design changes and detect bugs during refinement.





## **SYSTEM LEVEL DESIGN FLOW**







### SYSTEMC SYSTEM DESIGN METHODOLOGY





## Z Innin

#### SYSTEM C

- A library of C++ classes
  - Processes (for concurrency)
  - Clocks (for time)
  - Modules, ports, signals (for hierarchy)
  - Waiting, watching (for reactivity)
  - Hardware data types
- A modeling style for modeling systems consisting of multiple design domains, abstraction levels, architectural components, real-life constraints
- A light-weight simulation kernel for high-speed cycle-accurate simulation





## PRINCIPLE OF OPERATIONS





## 2 minus

### **RESULTS**

- executable specification
- testbenches
- written specification
- HW
  - understand specification
  - refine
  - validate re-using testbenches
  - synthesize

Why?

C/C++





#### SYSTEMC EXTENSIONS TO C++

- The SystemC Class Library:
  - provides the necessary constructs to model system architectures, including hardware timing, concurrency, and reactive behaviors that are missing in standard C++.
- The C++ object-oriented programming language:
  - provides the ability to extend the language through classes, without adding new syntactic constructs.
  - SystemC provides these necessary classes and allows designers to continue to use the familiar C++ language and development tools.





### SYSTEMC DEVELOPMENT ENVIRONMENT



- Simulator
- Can be downloaded from www.systemc.org





## **MODULES AND HIERARCHY**

#### Modules

- the basic building block within SystemC to partition a design.
  - Modules allow designers to hide internal data representation and algorithms from other modules.

#### Declaration

- Using the macro SC\_MODULE
  - SC\_MODULE(modulename) {
- Using typical C++ struct or class declaration:
  - struct modulename : sc\_module {





## **MODULE, PROCESS, PORTS, CHANNEL, INTERFACE**

```
class my_channel: if_w, if_r, sc_module {
                       void write() {...}
                       void read () {...}
     Producer Module
                                                Consumer Module
                                                sc_port<if_r> p2;
    sc_port<if_w> p1;
      p1->write()
                        P1
                             my_channel
                                            P2
                                                      p2->read()
                                           class if_r: virtual sc_interface {
class if_w: virtual sc_interface {
                                                  virtual void read() = 0;
       virtual void write() = 0;
                                           };
```





### **SYSTEMC DATA TYPES**

All C++ data types

- sc\_logic 0, 1, X, Z
  - sc\_lv<length> array of sc\_logic
- sc\_uint<length>, sc\_biguint<length>, sc\_bv<length>
- sc\_fix





## **DATA TYPE**

Use native C++ data types wherever possible

Use sc\_logic if 4-valued logic is required

Use sc\_uint<length> for less than 64-bits and 2-valued logic

Use sc\_biguint<length> for more than 64-bits and 2-valued logic

Use sc\_fix for fixed point arithmetic





## **SYSTEMC INTERFACE**

- Declares a set of access methods needed for communication between IPs
- Do not provide any implementation of the access methods
- Implementation of interfaces are done within a channel
  - sc\_signal\_in\_if -> T& read() const interface
- You can define your own interfaces but it should inherit from

```
template <typename T>
    class my_interface : public sc_interface {
        int read(int & addr) = 0;
        void write( int& addr, int & data) = 0;
}
```





## **INTERFACE EXAMPLES**

```
// sc_signal_in_if
// this interface provides a 'read' method
                                           // sc_signal_inout_if
                                           // this interface provides 'read' & 'write'
                                           method
template <class T>
class sc_signal_in_if: virtual public sc_ir
                                           template <class T>
     public:
                                           Class sc_signal_inout_if: virtual public
                                           sc_signal_in_if {
     // interface methods
                                                public:
     virtual const T& read() const = 0;
                                                // interface methods
                                                virtual void write( const T& ) = 0;
                                           };
```





## DIFFERENCE INTERFACE TYPE FOR DIFFERENT ABSTRACTION LEVEL

#### **Cycle Accurate Model**

Interfaces in form of signals of request, grant, address, data, etc

# RTL Pin accurate, cycle accurate req(), gnt(), addr(), data() RTL

#### **Transaction Level Model**

Interfaces in the form of read (address) or write (address, data)







## **SYSTEMC CHANNEL?**

- Means for communication between modules
- Provides the functionality of methods declared in interface
  - Derived from interfaces

```
template <typename T>
class my_channel : my_interface, sc_module {
    int read(int& addr) {
      return arr[add];
    void write(int & addr, int & data) {
      arr[addr]= data;
```

```
my_interface
(sc_signal_inout_if)

my_channel
(sc_signal)
```

sc\_interface



#### **CHANNEL EXAMPLE**

```
// sc_signal<T>
template < class T>
class sc_signal: public
sc_signal_inout_if<T> {
     m_value;
    T& read () {
        //immediate return
        return m_value;
```

```
// sc_signal<T>
template < class T>
class sc_signal: public
sc_signal_inout_if<T> {
      m_value;
      T& read () {
          //return after some time
          wait (10, SC_NS);
          return m_value;
```





## **MODULES AND HIERARCHY**

#### Elements:

- ports,
- local signals,
- local data,
- other modules,
- processes, and
- constructors.







#### **PORTS**

```
SC_MODULE(fifo) {
 sc_in<bool> load;
 sc_in<bool> read;
 sc_inout<int> data;
 sc_out<bool> full;
 sc_out<bool> empty;
//rest of module not shown
```







## **SIGNALS**

sc\_signal<type > q, s, c;

- PositionalConnection
- Named Connection







#### NAMED CONNECTION

• Instancename.portname(signalname);

```
SC MODULE(filter) {
   sample *s1;
   coeff *c1;
   mult *m1;
   sc signal<sc uint<32> > q, s,
   SC CTOR(filter) {
     \overline{s1} = \text{new sample ("s1")};
     s1->din(q);
     s1->dout(s);
     c1 = new coeff ("c1");
     c1->out(c);
     m1 = new mult ("m1");
     m1->a(s);
     m1->b(c);
     m1->q(q);
```







## **POSITIONAL CONNECTION**

Instancename (sig1, sig2, ...);

```
SC MODULE(filter) {
   sample *s1;
   coeff *c1;
   mult *m1;
   sc signal<sc uint<32> > q, s, c;
   SC CTOR(filter) {
     \overline{s1} = \text{new sample ("s1")};
     (*s1)(q,s);
     c1 = new coeff ("c1");
     (*c1)(c);
     m1 = new mult ("m1");
     (*m1)(s,c,q);
```







### INSTANTIATION

```
// file ex1.h
SC_MODULE(ex1) {
    sc_port<sc_fifo_in_if<int> > m;
    sc_port<sc_fifo_out_if<int> > n;

    SC_CTOR(ex1) {
        }
// Rest of the module body is not shown
    };
```

```
// file ex2.h
SC_MODULE(ex2) {
    sc_port<sc_fifo_in_if<int> > x;
    sc_port<sc_fifo_out_if<int> > y;

    SC_CTOR(ex2) {
        }
// Rest of the module body is not shown
    };
```

ex1 instance("ex1 instance"):

- passes the instance label to the constructors of the instance.



```
SC MODULE(ex3) {
     sc port<sc fifo in if<int> >a;
    sc port<sc fifo out if<int> > b;
           sc fifo<int> sig1;
     // Instances of ex1 and ex2
           ex1 ex1 instance;
           ex2 ex2 instance;
        // Module Constructor
             SC CTOR(ex3):
    ex1 instance("ex1 instance"),//init'n
    ex2 instance("ex2 instance") //init'n
         // Named connection for ex1
              ex1 instance.m(a);
            ex1 instance.n(sig1);
       // Positional connection for ex2
            ex2 instance(sig1, b);
// Rest of constructor body not shown
                 };
```





## SC\_MAIN()

- The top level is a special function called sc\_main.
  - It is in a file named main.cpp or main.cc (standard practice not a requirement).
- sc\_main() is called by SystemC and is the entry point for your code.
- The execution of sc\_main() until the sc\_start() function is called (described later) is considered to be the elaboration time of SystemC.

```
int sc_main (int argc, char *argv [ ] ) {
// body of function
...
return 0 ;
}
```





## INSTANTIATION STEPS IN SC MAIN()

- Two Steps:
  - Declaration and Initialization.

```
module_name instance_name ("string_name") ;
```

- recommended to keep the string\_name the same as the instance\_name.
- Module Instantialtion Port Binding
  - Named Connection:

```
instance_name.port_name(channel_or_port);
```

Positional Connection:

```
instance_name(channel_or_port, channel_or_port,...);
```



## C. Innum

#### **SYSTEMC**

- A set of modeling constructs in RTL or Behavioral abstraction level
- Structural design using Modules, Ports, and Signals
- Rich set of data types including bit-true types
  - Specially: Fixed-Point data types for DSP apps
- Concurrent Behavior is described using Processes
  - Processes can suspend and resume execution
  - Limited control over awakening events
    - Events and sensitivity list are static (specified at compile-time)
- SC\_THREAD and SC\_CTHREAD processes
  - Can suspend and resume execution
  - Require their own execution stack
  - Memory and Context-switching time overhead
  - SC\_METHOD gives best simulation performance



## The state of the s

## **SYSTEMC**

- Hardware Signals are hard to model in software
  - Initialization to X
    - Used to detect reset problems
    - sc logic, sc lv data types
  - Multiple drivers
    - resolved logic signals (sc\_signal\_rv)
  - Not immediately change their output value
    - Delay is essential
    - Capability to swap two registers on clock edge
- Delayed assignment and delta cycles
  - Same asVHDL and Verilog
  - Essential to model hardware signal assignments
    - Each assignment to a signal isn't seen by other processes until the next delta cycle
    - Delta cycles don't increase user-visible time
    - Multiple delta cycles may occur



## The state of the s

#### SYSTEMC 2.0

- Primary goal: Enable System-Level Modeling
  - Systems include hardware, software, or both
  - Challenges:
    - Wide range of design models of computation
    - Wide range of design abstraction levels
    - Wide range of design methodologies
- SystemC 2.0
  - Introduces a compact general purpose modeling foundation => Core Language
  - Elementary channels
    - library models provided (FIFO, Timers, ...)
    - Includes SystemC 1.0 Signals
  - Support for various models of computation, methodologies, etc.
    - Built on top of the core language, hence are separate from it





## **COMMUNICATION AND SYNCHRONIZATION**

- SystemC 1.0 Modules and Processes are still useful in system design
- NOTE: communication and synchronization mechanisms avaliable in SystemC 1.0 (Signals) are restrictive for system-level modeling
  - Communication using queues
  - Synchronization (access to shared data) using mutexes
- SystemC 2.0 includes general-purpose mechanisms
  - Channel
    - A container for communication and synchronization
    - They implement one or more interfaces
  - Interface
    - Specify a set of access methods to the channel
      - But it does not implement those methods
  - Event
    - Flexible, low-level synchronization primitive
    - Used to construct other forms of synchronization

Builds advanced comm. & sync. models

e.g. HW-signals, queues (FIFO, LIFO, message queues,...) semaphores, memories and busses (RTL and TLM)





## **COMMUNICATION AND SYNCHRONIZATION**







## SYSTEMC 2.0 LANGUAGE ARCHITECTURE

#### Standard Channels for Various MOC's

Kahn Process Networks Static Dataflow, etc.

#### Methodology-Specific Channels

Master/Slave Library, etc.

#### **Elementary Channels**

Signal, Timer, Mutex, Semaphore, Fifo, etc.

#### Core Language

Modules

Ports

Processes

Interfaces

Channels

Events

#### Data Types

Logic Type (01XZ)
Logic Vectors
Bits and Bit Vectors
Arbitrary Precision Integers
Fixed Point Integers Integers

C++ Language Standard

- All built on C++
- Upper layers cleanly built on lower ones
- Core language
  - Structure
  - Concurrency
  - Communication
  - Synchronization
- Data types separate from the core language
- Commonly used communication mechanisms and MOC built on top of core language
- Lower layers can be used without upper ones



#### **FIFO**



Problem definition: FIFO communication channel with blocking read and write operations Source available in SystemC installation, under "examples\systemc" subdirectory





## FIFO EXAMPLE

## Interfaces

```
class write_if : public sc_interface
  public:
        virtual void write(char) = 0;
        virtual void reset() = 0;
};
class read if : public sc interface
   public:
        virtual void read(char&) = 0;
        virtual int num available() =
   0;
};
```







## FIFO CHANNEL



```
class fifo: public sc channel,
  public write if,
  public read if
  private:
       enum e {max elements=10};
       char data[max elements];
       int num elements, first;
       sc event write event,
                read event;
       bool fifo empty() {...};
       bool fifo_full() {...};
  public:
       SC CTOR(fifo) {
          num elements = first=0;
        }
```

```
void write(char c) {
   if (fifo full())
       wait(read event);
   data[ <you say> ]=c;
   ++num elements;
   write event.notify();
void read(char &c) {
   if( fifo empty() )
       wait(write event);
   c = data[first];
   --num elements;
   first = <you say>;
   read event.notify();
```



## FIFO CHANNEL

```
void reset() {
    num_elements = first = 0;
}

int num_available() {
    return num_elements;
}
}; // end of class declarations
```



#### All channels must

- be derived from sc\_channel class
  - SystemC internals
     (kernel\sc\_module.h)

    typedef sc\_module
    sc channel;
- be derived from one (or more)
  classes derived from
  sc\_interface
- provide implementations for all pure virtual functions defined in its parent interfaces





#### FIFO EXAMPLE

#### Note

- wait() call with arguments => dynamic sensitivity
  - wait(sc event)
  - wait(time) // e.g. wait(200, SC\_NS);
  - wait(time out, sc event) //wait(2, SC\_PS, e);

#### Events

- the fundamental synchronisation primitive in SystemC
- different from signals!!
  - have no type and no value
  - always cause sensitive processes to be resumed
  - can be specified to occur:
    - immediately/ one delta-step later/ some specific time later





## WAIT () FUNCTION

```
// wait for 200 ns.
sc time t(200, SC_NS);
wait( t );
// wait on event el, timeout after 200 ns.
wait( t, e1 );
// wait on events e1, e2, or e3, timeout after 200 ns.
wait( t, e1 | e2 | e3 );
// wait on events e1, e2, and e3, timeout after 200 ns.
wait( t, e1 & e2 & e3 );
// wait for 200 clock cycles, SC CTHREAD only (SystemC 1.0).
wait( 200 );
// wait one delta cycle.
wait( 0, SC NS );
// wait one delta cycle.
wait( SC ZERO TIME );
```





## NOTIFY() METHOD OF SC EVENT

## Possible calls to notify():

```
sc event my event;
my event.notify(); // notify immediately
my event.notify( SC ZERO TIME ); // notify next delta cycle
my event.notify( 10, SC NS ); // notify in 10 ns
sc time t(10, SC NS);
my event.notify( t ); // same
```





#### **COMM. MODELING EXAMPLE**

- Producer module
  - sc\_port<write\_if> out;
    - Producer can only call member functions of write\_if interface
- Consumer module
  - sc\_port<read\_if> in;
    - Consumer can only call member functions of read\_if interface

- Producer and consumer are
  - unaware of how the works
  - just aware of their respective interfaces
- Channel implementation is hidden from communicating modules



## **COMM. MODELING EXAMPLE**



```
SC_MODULE(top) {
  public:
       fifo *afifo;
       producer *pproducer;
       consumer *pconsumer;
  SC CTOR(top) {
       afifo = new fifo("Fifo");
       pproducer=new producer("Producer");
       pproducer->out(afifo);
       pconsumer=new consumer("Consumer");
       pconsumer->in(afifo);
   };
```





#### **COMM. MODELING EXAMPLE**

- Advantages of separating communication from functionality
  - Trying different communication modules
  - Refine the FIFO into a software implementation
    - Using queuing mechanisms of the underlying RTOS
  - Refine the FIFO into a hardware implementation
    - Channels can contain other channels and modules
      - Instantiate the hw FIFO module within FIFO channel
      - Implement read and write interface methods to properly work with the hw FIFO
      - Refine read and write interface methods by inlining them into producer and consumer codes





### SYSTEMC MODELS OF COMPUTATION

- Many different models
  - The best choice is not always clear!
- Basic topics in a computation model
  - The model of time, and event ordering constraints
    - Time model (real valued, integervalued, untimed)
    - Event ordering (globally ordered, partially ordered)
  - Supported methods of communication between concurrent processes
  - Rules for process activation

- Generic model of computation
  - The designer can implement desired model
- All discrete-time models are supported
  - Static Multi-rate Data-flow
  - Dynamic Multi-rate Data-flow
  - Kahn Process Networks
  - Communicating Sequential Processes
  - Discrete Event as used for
    - RTL hardware modeling
    - network modeling (e.g. stochastic or "waiting room" models)
    - transaction-based SoC platformmodeling
- not suitable for continuous-time models (e.g. analog modeling)!!

e.g. Signals are realized on top of channels, interfaces, and events





## **FUTURE EVOLUTION OF SYSTEMC**

- IEEE 1666-2011 IEEE Standard for Standard SystemC
   Language Reference Manual
- IEEE 1666.1-2016 IEEE Standard for Standard
   SystemC(R) Analog/Mixed-Signal Extensions Language
   Reference Manual
- download http://www.accellera.org/downloads/standards/systemc
- Ver. 2.3.3
  - Support for RTOS modeling different approaches
    - Fork and join threads + dynamic thread creation
    - Interrupt or abort a thread and its children
    - Specification and checking of timing constraints
    - Abstract RTOS modeling and scheduler modeling
  - New features in the core language
    - Support for analog mixed signal modeling





## Extensions as libraries on top of the core language

- Standardized channels for various MOC (e.g. static dataflow and Kahn process networks)
- Testbench development
  - Libraries to facilitate development of testbenches
    - data structures that aid stimulus generation and response checking
    - functions that help generate randomized stimulus, etc.
- System level modeling guidelines
  - library code that helps users create models following the guidelines
- Interfacing to other simulators
  - Standard APIs for interfacing SystemC with other simulators, emulators, etc.





## Accellera Systems Initiative Policies and Organizational Documents

- UVM 2017-1.1 Reference Implementation
- SystemC AMS 2.3
- IP-XACT Vendor Extensions
- Portable Stimulus 1.0a
- SCE-MI 2.4
- SystemC 2.3.3 (w/TLM), AMS 2.0, CCI 1.0, & Synthesis 1.4.7
- SystemRDL 2.0

All Accellera standards | IEEE standards

## UVM-SystemC is

 standard to develop structured verification environments following the Universal Verification Methodology (UVM)

