### HOMEWORK III

Due day: 2:00pm Nov. 22 (Wednesday), 2023

### Introduction

In this homework, you need to implement CSR instructions, mret, and WFI instructions. Also, there are 4 new IPs that will need to be implemented, the DRAM Wrapper, WDT, ROM Wrapper and Sensor control Wrapper. The WDT is clocked by 2 separate clock domain, so you need to debug CDC issues with Spyglass. You also need to write a simple program to boot your CPU, and write some programs to test your SoC. Finally, complete synthesis of your system.

### General rules for deliverables

- This homework can be completed by INDIVIDUAL student or a TEAM (up to 2 students). Only one submission is needed for a team. You MUST write down you and your teammate's name on the submission cover of the report. Otherwise duplication of other people's work may be considered cheating.
- Compress all files described in the problem statements into one tar file.
- Submit the compressed file to the course website before the due day.
   Warning! AVOID submitting in the last minute. Late submission is not accepted.

# **Grading Notes**

- Important! DO remember to include your SystemVerilog code. NO code, NO grades. Also, if your code can not be recompiled by TA successfully using tools in SoC Lab and commands in Appendix B, you will receive NO credit.
- Write your report seriously and professionally. Incomplete description and information will reduce your chances to get more credits.
- DO read the homework statements and requirements thoroughly. If you fail to comply, you are not able to get full credits.
- Please follow course policy.
- Verilog and SystemVerilog generators aren't allowed in this course.

#### HOMEWORK III

### **Deliverables**

- 1. All SystemVerilog codes including components, testbenches and machine codes for each lab exercise. NOTE: Please DO NOT include source codes in the report!
- 2. Write a homework report in MS word and follow the convention for the file name of your report: N260xxxxx.docx. Please save as docx file format and replace N260xxxxx with your student ID number. (Let the letter be uppercase.) If you are a team, you should name your report, top folder and compressed file with the student ID number of the person uploading the file. The other should be written on the submission cover of your report, or you will receive NO credit.
- 3. Specified percentage of contributions by every team member. For example, contributions by everyone are equally divided, you can specified Axx 50%, and Byy 50%.
- 4. Organize your files as the hierarchy in Appendix A.

# **Report Writing Format**

- a. Use the submission cover which is already in provided N260XXXXX.docx.
- b. A summary in the beginning to state what has been done.
- c. Report requirements from each problem.
- d. Describe the major problems you encountered and your resolutions.
- e. Lessons learned from this homework.

#### HOMEWORK III

### Problem1

### 1.1 Problem Description

A CPU needs interrupts to communicate with other cores or devices. In this problem, you have to implement CSR to support interrupt operations and some new instructions for your RISC-V CPU from HW 2, synthesize the top module. Your CPU should have following new features:

- a. The RISC-V ISA with 8 more specified instructions.
- b. Has CSR and interrupt mechanism.

A more detailed description of this problem can be found in Section 1.4. The WDT is used to detect and recover from CPU malfunctions. When CPU fail to restart WDT, WDT will time out and generate a time-out signal to restart CPU. There are 2 clock domains in your mini system. You have to design CDC circuit to solve CDC metastability issues, then pass Spyglass CDC check.

Also, in this problem, you have to implement a simple DRAM, from which to load your main programs and to which to store your main data. You have to implement ROM wrapper, so as to access ROM to fetch boot code. And you have to implement Sensor Control Wrapper, so as to fetch IO data from sensor.

### HOMEWORK III

# 1.2 Module Specification



Fig. 1-1: System block diagram

Table 1-1: given modules

| Catagory   | Name             |             |             |             |  |  |  |  |  |
|------------|------------------|-------------|-------------|-------------|--|--|--|--|--|
| Category   | File             | File Module |             | SDF         |  |  |  |  |  |
| RTL        | top.sv           | top         | TOP         |             |  |  |  |  |  |
| Gate-Level | top_syn.v        | top         | TOP         | top_syn.sdf |  |  |  |  |  |
| RTL        | SRAM wrapper.sv  | SRAM_       | IM1         |             |  |  |  |  |  |
| KIL        | SKAWI_wrapper.sv | wrapper     | 11V11       |             |  |  |  |  |  |
| RTL        | SRAM wrapper.sv  | SRAM_       | DM1         |             |  |  |  |  |  |
| KIL        | SKAWI_wrapper.sv | wrapper     | DIVIT       |             |  |  |  |  |  |
| RTL        | SRAM_rtl.sv      | SRAM        | i_SRAM      |             |  |  |  |  |  |
| RTL        | sensor_ctrl.sv   | sensor_ctrl | sensor_ctrl |             |  |  |  |  |  |
| Behavior   | ROM.v            | ROM         | i_ROM       |             |  |  |  |  |  |
| Behavior   | DRAM.v           | DRAM        | i_DRAM      |             |  |  |  |  |  |

### HOMEWORK III

### Table 1-2: Module signals

| Module |                | Specifications    |          |                                       |  |  |  |  |  |
|--------|----------------|-------------------|----------|---------------------------------------|--|--|--|--|--|
|        | Name           | Signal            | Bits     | Function explanation                  |  |  |  |  |  |
|        | System signals |                   |          |                                       |  |  |  |  |  |
|        | clk            | input             | 1        | System clock                          |  |  |  |  |  |
|        | rst            | input             | 1        | System reset (active high)            |  |  |  |  |  |
|        |                | Сс                | onnect w | ith ROM                               |  |  |  |  |  |
|        | ROM_out        | input             | 32       | Data from ROM                         |  |  |  |  |  |
|        | ROM_read       | output            | 1        | ROM output enable                     |  |  |  |  |  |
|        | ROM_enable     | output            | 1        | Enable ROM                            |  |  |  |  |  |
|        | ROM_address    | output            | 12       | Address to ROM                        |  |  |  |  |  |
|        | Name           | Signal            | Bits     | Function explanation                  |  |  |  |  |  |
| top    |                | Connect with DRAM |          |                                       |  |  |  |  |  |
| юр     | DRAM_Q         | input             | 32       | Data from DRAM                        |  |  |  |  |  |
|        | DRAM_valid     | input             | 1        | DRAM output data valid                |  |  |  |  |  |
|        | DRAM_CSn       | output            | 1        | DRAM Chip Select                      |  |  |  |  |  |
|        |                |                   |          | (active low)                          |  |  |  |  |  |
|        | DRAM_WEn       | output            | 4        | DRAM Write Enable                     |  |  |  |  |  |
|        |                |                   |          | (active low)                          |  |  |  |  |  |
|        | DRAM_RASn      | output            | 1        | DRAM Row Access Strobe                |  |  |  |  |  |
|        |                |                   | -        | (active low)                          |  |  |  |  |  |
|        | DRAM_CASn      | output            | 1        | DRAM Column Access Strobe             |  |  |  |  |  |
|        | DRAM A         | output            | 11       | (active low) Address to DRAM          |  |  |  |  |  |
|        | DRAM D         | -                 | 32       | Data to DRAM                          |  |  |  |  |  |
| ROM    | DRAW_D         | output            |          |                                       |  |  |  |  |  |
| KOM    | CK             | input             | System 1 | System clock                          |  |  |  |  |  |
|        | CK             | Прис              | Memory   | · · · · · · · · · · · · · · · · · · · |  |  |  |  |  |
|        | DO             | output            | 32       | ROM data output                       |  |  |  |  |  |
|        | OE             | input             | 1        | Output enable (active high)           |  |  |  |  |  |
|        | CS             | input             | 1        | Chip select (active high)             |  |  |  |  |  |
|        | A              | input             | 12       | ROM address input                     |  |  |  |  |  |
|        |                |                   | Memory   | Space                                 |  |  |  |  |  |

### HOMEWORK III

|                |                 | TIOMIL W | JICIE III |                               |
|----------------|-----------------|----------|-----------|-------------------------------|
|                | Memory_byte0    | reg      | 8         | Size: [0:4095]                |
|                | Memory_byte1    | reg      | 8         | Size: [0:4095]                |
|                | Memory_byte2    | reg      | 8         | Size: [0:4095]                |
|                | Memory_byte3    | reg      | 8         | Size: [0:4095]                |
| DRAM           |                 |          | System    | signals                       |
|                | CK              | input    | 1         | System clock                  |
|                | RST             | input    | 1         | System reset (active high)    |
|                |                 |          | Memory    | ports                         |
|                | CSn             | input    | 1         | DRAM Chip Select              |
|                |                 |          |           | (active low)                  |
|                | WEn             | input    | 4         | DRAM Write Enable             |
|                |                 |          |           | (active low)                  |
|                | RASn            | input    | 1         | DRAM Row Access               |
|                |                 |          |           | Strobe(active low)            |
|                | CASn            | input    | 1         | DRAM Column Access Strobe     |
|                |                 |          |           | (active low)                  |
|                | A               | input    | 11        | DRAM Address input            |
|                | D               | input    | 32        | DRAM data input               |
|                | Q               | output   | 32        | DRAM data output              |
|                | VALID           | output   | 1         | DRAM data output valid        |
|                |                 |          | Memory    | space                         |
|                | Memory_byte0    | reg      | 8         | Size: [0:2097151]             |
|                | Memory_byte1    | reg      | 8         | Size: [0: 2097151]            |
|                | Memory_byte2    | reg      | 8         | Size: [0: 2097151]            |
|                | Memory_byte3    | reg      | 8         | Size: [0: 2097151]            |
| Sensor Control |                 |          | System S  | Signals                       |
|                | clk             | input    | 1         | System clock                  |
|                | rst             | input    | 1         | System reset (active high)    |
|                | sctrl_en        | input    | 1         | Sensor control enable         |
|                |                 |          |           | (active high)                 |
|                | sctrl_clear     | input    | 1         | Sensor controller clear       |
|                |                 |          |           | (active high)                 |
|                | sctrl_addr      | input    | 1         | Sensor controller address     |
|                | sctrl_interrupt | output   | 6         | Sensor controller interrupt   |
|                | sctrl_out       | output   | 32        | Sensor controller data output |
|                | sensor_ready    | input    | 1         | Sensor data ready             |
|                |                 |          |           |                               |

### HOMEWORK III

| sensor_out   | input  | 32 | Data from sensor            |  |  |  |
|--------------|--------|----|-----------------------------|--|--|--|
| sensor_en    | output | 1  | Sensor enable (active high) |  |  |  |
| Memory space |        |    |                             |  |  |  |
| mem          | logic  | 32 | Size: [0:63]                |  |  |  |

### HOMEWORK III

### 1.3 Detailed Description

You should implement the additional instructions in Table 1-3 and the CSRs in Table 1-4. You only need to implement Machine Mode.

20 19 15 14 12 11 opcode Mnemonic Description rd = csr, if #rd != 0001 1110011 **CSRRW** rs1 rd csr csr = rs1rd = csr, if #rd != 0010 1110011 rs1 rd **CSRRS**  $csr = csr \mid rs1$ , if that csr bit is csr writable and #rs1 != 0 rd = csr, if #rd != 0011 1110011 **CSRRC**  $csr = csr \& (\sim rs1)$ , if that csrrs1 rd csr bit is writable and #rs1 != 0 rd = csr, if #rd != 0**CSRRWI** 101 1110011 uimm[4:0] rd csr csr = uimm(zero-extend) rd = csr, if #rd! = 0 $csr = csr \mid uimm(zero-extend),$ uimm[4:0] 110 rd 1110011 **CSRRSI** csr if that csr bit is writable and uimm != 0rd = csr, if #rd != 0 $csr = csr \& (\sim uimm(zero$ csr uimm[4:0] 111 rd 1110011 **CSRRCI** extend)), if that csr bit is writable and uimm != 0

Table 1-3: CSR instructions, mret, and WFI

| 31      | 20    | 19  | 15 | 14  | 12   | 11 |      | 7 | 6     | 0  |          |                                   |
|---------|-------|-----|----|-----|------|----|------|---|-------|----|----------|-----------------------------------|
| imm[1   | [1:0] | rs  |    | fun | ict3 |    | rd   |   | opcod | le | Mnemonic | Description                       |
| 0011000 | 00010 | 000 | 00 | 00  | 00   | 0  | 0000 |   | 11100 | 11 | MRET     | Return from traps in Machine Mode |

| 31      | 20    | 19    | 15 | 14    | 12 | 11 | 7     | 6 0     |          |                    |
|---------|-------|-------|----|-------|----|----|-------|---------|----------|--------------------|
| imm[1   | 1:0]  | rs1   |    | funct | t3 |    | rd    | opcode  | Mnemonic | Description        |
| 0001000 | 00101 | 00000 |    | 000   | )  | 0  | 00000 | 1110011 | WFI      | Wait for interrupt |

Table 1-4: m mode CSRs

| Address | Privilege | Name    | Description                               |
|---------|-----------|---------|-------------------------------------------|
| 0x300   | М         | mstatus | Machine status register                   |
| 0x304   | М         | mie     | Machine interrupt-enable register         |
| 0x305   | М         | mtvec   | Machine Trap-Vector Base-Address register |
| 0x341   | М         | mepc    | Machine exception program counter         |
| 0x344   | М         | mip     | Machine interrupt pending register        |

#### HOMEWORK III

In Table 1-3, MRET and WFI are listed in The RISC-V Instruction Set Manual Volume II: Privileged Architecture. You can treat "hardwire to 0" in description as WIRI (Reserved Write Ignored, Reads Ignore Values) for simplicity except mtvec. It should be WARL (Write Any Values, Reads Legal Values.)

Slave configuration is listed in Table 1-5, you should follow the specification. The MEIP of mip can connect to sensor\_interrupt of sensor\_ctrl directly, or you can design an interrupt controller to handle it. You should design slave wrappers by yourself. You should only implement read operation in ROM wrapper and implement read and write operations in IM, DM and DRAM wrapper. For sensor controller wrapper, you should only implement read operation between 0x1000\_0000 and 0x1000\_03ff, i.e., read contents between SC[0] and SC[63]. Furthermore, you also need to implement write operation for 0x1000\_0100 and 0x1000\_0200. CPU can enable sctrl\_en signal by writing non-zero data to 0x1000\_0100. Similarly, writing non-zero data to 0x1000\_0200 will enable sctrl\_clear signal.

Table 1-5: Slave Configuration

| NAME        | Number  | Start address | End address | Property |
|-------------|---------|---------------|-------------|----------|
| ROM         | Slave 0 | 0x0000_0000   | 0x0000_1FFF | memory   |
| IM          | Slave 1 | 0x0001_0000   | 0x0001_FFFF | memory   |
| DM          | Slave 2 | 0x0002_0000   | 0x0002_FFFF | memory   |
| sensor_ctrl | Slave 3 | 0x1000_0000   | 0x1000_03FF | 1/0      |
| WDT         | Slave 4 | 0x1001_0000   | 0x1001_03FF | 1/0      |
| DRAM        | Slave 5 | 0x2000_0000   | 0x201F_FFFF | memory   |

### HOMEWORK III

For WDT wrapper, you should implement write operation for  $0x1001\_0100$  and  $0x1001\_0200$ . CPU can enable WDEN signal by writing non-zero data to  $0x1001\_0100$ . Similarly, writing non-zero data to  $0x1001\_0200$  will enable WDLIVE signal. Writing data to  $0x1001\_0300$  will change WTOCNT value.

WDT signal is listed in Table 1-6. During normal operation, CPU regularly restarts the watchdog timer to prevent it from timing out. If, due to a hardware fault or program error, the computer fails to restart the watchdog, the timer will elapse and generate a timeout signal to invoke CPU reboot.

Table 1-6: WDT signals

|     |                     |        | $\mathcal{C}$ |                             |  |  |
|-----|---------------------|--------|---------------|-----------------------------|--|--|
| WDT | System Signals      |        |               |                             |  |  |
|     | clk                 | input  | 1             | System clock                |  |  |
|     | rst                 | input  | 1             | System reset (active high)  |  |  |
|     | clk2                | input  | 1             | WDT counter clock           |  |  |
|     | rst2                | input  | 1             | WDT counter reset           |  |  |
|     |                     |        |               | (active high)               |  |  |
|     | Connect with system |        |               |                             |  |  |
|     | WDEN                | input  | 1             | Enable watchdog timer       |  |  |
|     | WDLIVE              | input  | 1             | Restart watch dog timer     |  |  |
|     | WTOCNT              | input  | 32            | WDT timeout count           |  |  |
|     | WTO                 | output | 1             | WDT timeout, serve as timer |  |  |
|     |                     |        |               | interrupt                   |  |  |

Table 1-7: Clock domain

| name                   | Frequency | Clock domain |
|------------------------|-----------|--------------|
| CPU, Bus, Wrappers,    | >50MHz    | clk          |
| ROM, RAMs, sensor_ctrl |           |              |
| WDEN, WDLIVE,          | 10MHz     | clk2         |
| WTOCNT, WTO            |           |              |

#### HOMEWORK III

### Problem2

### 2.1 Problem Description

In this problem, you have to support booting operations for your RISC-V CPU, and implement some testing programs.

### 2.2 Verification

You should use the commands in Appendix B to verify your design.

- a. For prog0, to prog5, you should write a boot program defined as boot.c or boot.S to copy data between \_dram\_i\_start and \_dram\_i\_end to \_imem\_start, from \_\_data\_paddr\_start to \_\_data\_start and \_\_data\_end, also from \_\_sdata\_paddr\_start to \_\_sdata\_start and \_\_sdata\_end. The booting program should be stored at ROM.
- b. Use *prog0* to perform verification for the functionality of instructions.
- c. Write a program defined as prog1 to perform a sort algorithm. The number of sorting elements is stored at the address named array\_size in ".rodata" section defined in data.S. The first element is stored at the address named array\_addr in ".rodata" section defined in data.S, others are stored at adjacent addresses. The maximum number of elements is 128. All elements are signed 2-byte half-word and you should sort them in ascending order. Rearranged data should be stored at the address named \_test\_start in "\_test" section defined in link.ld.
- d. Write a program defined as prog2 to turn image into gray scale. Image data is stored byte(8 bits) by byte in order of {blue, green, red} from address named "\_binary\_image\_bmp\_start" to "\_binary\_image\_bmp\_end". The number of bytes is stored at "\_binary\_image\_bmp\_size". Store gray scale result byte by byte from "\_test\_start" to "test\_start"+\_binary\_image\_bmp\_size-1. The gray scale formula is y = 0.11\*blue + 0.59\*green + 0.3\*red
- e. Test your SoC using a program defined as *prog3* to perform interrupt check on sensor\_control. When sensor memory is full, it will interrupt CPU. The trap handler copy() will copy data to DM. Then, reset the counter of sensor controller. When copy() is done, ISR return to main program. After 4 groups of data are copied, the copied data will be sorted.

### HOMEWORK III

- f. Test your SoC using a program defined as *prog4* to perform interrupt check on WDT, without clock delay. CPU will start executing program and enter dead loop. When WDT assert timer interrupt, CPU will be reset. After CPU is reset, it will periodically reset timer.
- g. Test your SoC using a program defined as *prog5* to perform interrupt check on WDT, with clock delay. The testing program is the same as prog4, except that the clock is delayed in testbench.

Don't forget to return from main function to finish the simulation in each program. Save your assembly code or C code as main.S or main.c respectively. You should also explain the result of this program in the report. In addition to these verification, TA may use another program to verify your design. Please make sure that your design can execute the listed instructions correctly.

### HOMEWORK III

# Problem3

# 3.1 Problem Description

In this problem, you should use Spyglass to do CDC check on your design

### HOMEWORK III

### **Report Requirements**

- Proper explanation of your design is required for full credits.
- Block diagrams shall be drawn to depict your designs.
- Show your screenshots of the waveforms and the simulation results on the terminal for the different test cases in your report and illustrate the correctness of your results
- Explain your codes of prog1, prog2.
- Explain your codes of boot.c.
- Report your Superlint coverage
- Report and show screenshots of your prog0 to prog5 simulation time after synthesis and total cell area of your design.
- Explain how the interrupt mechanism work
- Show your screenshots of the Spyglass CDC reports and explain why your CDC circuit can work correctly

#### HOMEWORK III

## **Appendix**

### A. File Hierarchy Requirements

All homework SHOULD be uploaded and follow the file hierarchy and the naming rules, especially letter case, specified below. You should create a main folder named your student ID number. It contains your homework report and other files. The names of the files and the folders are labeled in red color, and the specifications are labeled in black color. Filenames with \* suffix in the same folder indicate that you should provide one of them. Before you submit your homework, you can use Makefile macros in Appendix B to check correctness of the file structure.

### Fig. A-1 File hierarchy

□ N260XXXXX.tar (Don't add version text in filename, e.g. N260XXXXX v1.tar) *N260XXXXX* (Main folder of this homework) *N260XXXXX.docx* (Your homework report) StudentID (Specify your student ID number in this file) StudentID2 (Specify your partner's student ID number in this file. Please delete it if you don't have partner) *Makefile* (You shouldn't modify it) src (Your RTL code with sv format) top.sv SRAM wrapper.sv ROM wrapper.sv DRAM wrapper.sv ① Other submodules (\*.sv)  $\nearrow$  AXIAXLsv Submodules of AXI (\*.sv) include (Your RTL definition with svh format) AXI def.svh def.svh Definition files (\*.svh) Syn (Your synthesized code and timing file) top syn.v top syn.sdf script (Any scripts of verification, synthesis or place and route) script files (\*.sdc, \*.tcl or \*.setup)

#### HOMEWORK III

sim (Testbenches and memory libraries) top tb.sv (Main testbench. You shouldn't modify it) **CYCLE** (Specify your clock cycle time in this file) MAX (Specify max clock cycle number in this file) SRAM (SRAM libraries and behavior models) Library files (\*.lib, \*.db, \*.lef or \*.gds) **SRAM.ds** (SRAM datasheet) **SRAM** rtl.sv (SRAM RTL model) *SRAM.v* (SRAM behavior model) ROM (ROM behavior models) *ROM.v* (ROM behavior model) DRAM (DRAM behavior models) *DRAM.v* (DRAM behavior model) data array (data array libraries and behavior models) Library files (\*.lib, \*.db, \*.lef or \*.gds) data array.ds (data array datasheet) data array rtl.sv (data array RTL model) data array.v (data array behavior model) tag array (tag array libraries and behavior models) Library files (\*.lib, \*.db, \*.lef or \*.gds) tag array.ds (tag array datasheet) tag array rtl.sv (tag array RTL model) tag array.v (tag array behavior model) prog0 (Subfolder for Program 0) *Makefile* (Compile and generate memory content) *boot.c*\* (C code for verification) *main.S* (Assembly code for verification) *setup.S* (Assembly code for testing environment setup) *link.ld* (Linker script for testing environment) golden.hex (Golden hexadecimal data) *prog1* (Subfolder for Program 1) *Makefile* (Compile and generate memory content) *boot.c*\* (C code for verification) *main.S* \* (Assembly code for verification) *main.c* \* (C code for verification) data. S (Assembly code for testing data) *setup.S* (Assembly code for testing environment setup)

### HOMEWORK III

- link.ld (Linker script for testing environment)
- **golden.hex** (Golden hexadecimal data)
- prog2 (Subfolder for Program 2)
  - Makefile (Compile and generate memory content)
  - $\blacksquare$  **boot.**  $c^*$  (C code for verification)
  - **main.**S \* (Assembly code for verification)
  - **main.** c \* (C code for verification)
  - **setup.** S (Assembly code for testing environment setup)
  - link.ld (Linker script for testing environment)
  - image.bmp (bmp file)
  - **golden.hex** (Golden hexadecimal data)
- prog3 (Subfolder for Program 3)
  - Makefile (Compile and generate memory content)
  - $\blacksquare$  boot.c\* (C code for verification)
  - $\blacksquare$  *main.S* \* (Assembly code for verification)
  - **main.** c \* (C code for verification)
  - data.S (Assembly code for testing data)
  - **setup.** S (Assembly code for testing environment setup)
  - link.ld (Linker script for testing environment)
  - **golden.hex** (Golden hexadecimal data)
  - Sensor data.dat (Input data of sensor)
- prog4 (Subfolder for Program 4)
  - Makefile (Compile and generate memory content)
  - $\blacksquare$  **boot.**  $c^*$  (C code for verification)
  - $\blacksquare$  main.  $S^*$  (Assembly code for verification)
  - main.c \* (C code for verification)
  - **data.** S (Assembly code for testing data)
  - **setup.** S (Assembly code for testing environment setup)
  - link.ld (Linker script for testing environment)
  - **golden.hex** (Golden hexadecimal data)
- prog5 (Subfolder for Program 5)
  - Makefile (Compile and generate memory content)
  - $\blacksquare$  boot.c\* (C code for verification)
  - $\blacksquare$  main.  $S^*$  (Assembly code for verification)
  - **main.c** \* (C code for verification)
  - **data.** (Assembly code for testing data)
  - **setup.** S (Assembly code for testing environment setup)

### HOMEWORK III

link.ld (Linker script for testing environment)

### **B. Simulation Setting Requirements**

You **SHOULD** make sure that your code can be simulated with specified commands in Table B-1. **TA will use the same command to check your design under SoC Lab environment.** If your code can't be recompiled by **TA successfully, you receive NO credit.** 

Table B-1: Simulation commands

| Simulation Level | Command      |  |  |  |
|------------------|--------------|--|--|--|
| Problem2         |              |  |  |  |
| RTL              | make rtl_all |  |  |  |
| Gate-level       | make syn_all |  |  |  |

TA also provide some useful Makefile macros listed in Table B-2. Braces {} means that you can choose one of items in the braces. X stands for 0,1,2,3..., depend on which verification program is selected.

Table B-2: Makefile macros

| Situation                                    | Command                      |  |
|----------------------------------------------|------------------------------|--|
| RTL simulation for progX                     | make rtlX                    |  |
| Post-synthesis simulation for progX          | make synX                    |  |
| Dump waveform (no array)                     | make {rtlX,synX, prX} FSDB=1 |  |
| Dump waveform (with array)                   | make {rtlX,synX, prX} FSDB=2 |  |
| Open nWave without file pollution            | make nWave                   |  |
| Open Superlint without file pollution        | make superlint               |  |
| Run JasperGold VIP on AXI bridge             | maka win h                   |  |
| without file pollution (RTL only)            | make vip_b                   |  |
| Open DesignVision without file pollution     | make dv                      |  |
| Synthesize your RTL code (You need write     | make symthesize              |  |
| synthesis.tcl in script folder by yourself)  | make synthesize              |  |
| Delete built files for simulation, synthesis | make clean                   |  |
| or verification                              | make clean                   |  |
| Check correctness of your file structure     | make check                   |  |
| Compress your homework to tar format         | make tar                     |  |
| Do CDC check with Spyglass                   | make spyglass                |  |

### HOMEWORK III

You can use the following command to get the number of lines:

wc -l src/\* src/AXI/\* include/\*