

# **Lab2: Channel and Interface**

Kun-Chih (Jimmy) Chen 陳坤志

kcchen@nycu.edu.tw

Institute of Electronics,
National Yang Ming Chiao Tung University



### **Channel and Interface**



- Channel
  - sc\_signal<T>
  - sc\_signal\_resolved
  - sc\_signal\_rv<W>
  - sc\_buffer<T>
  - sc\_fifo<T>
  - sc\_mutex
  - sc\_semaphore

- Interface
  - sc\_fifo\_in\_if
  - sc\_fifo\_out\_if
  - sc\_mutex\_if
  - sc\_semaphore\_if
  - sc\_signal\_in\_if
  - sc\_signal\_out\_if

### **Example: FIFO Interface**



sc\_port <interface > portname;

```
Example: space

SC_MODULE(stereo_amp) {

sc_port<sc_fifo_in_if<int> > soun

sc_port<sc_fifo_out_if<int> > sou

...
```

#### Lab2: Adder with channel interface

- Three modules
  - ❖ Random number generator (random seed = i+1)
    - ➤ Generate 100 random numbers, and the range is between 0~99
  - Adder
    - Compute the sum of the two inputs
  - Monitor
    - Check the correctness of the addition results



## Lab Requirement

- Due in one week (2023/05/31)
  - Complete the three modules.
  - Practice sc\_fifo, sc\_signal, and sc\_buffer in this Lab
  - Use Platform Architecture and Terminal to simulate output results.
    - Without channels in the PA
    - With channels outside the PA
  - Upload compressed file which include source codes (all of your file, include PA project file, source code....) to E3@NYCU
    - > File name rule: Student ID\_Lab2