## **Computer Architecture Final Project**

Verilog Single Cycle RISC-V

TA: Yan-Lun Wu (<u>r08943016@ntu.edu.tw</u>) Chi-Hung Weng (<u>r08943010@ntu.edu.tw</u>) If you have any problem, contact us by email first.

Due 2021/1/9 13:00 Saturday (CEIBA, no late homework is allowed.)

統一公告網址: https://tinyurl.com/2020-CA-Final

### 1. Introduction

Microprocessor without Interlocked Pipeline Stages (RISCV) is a widely used instruction set architecture. We've already had comprehensive understandings of it in our Computer Architecture course. In this exercise, we're going to implement the single-cycle RISCV architecture using Verilog. This exercise will give you a hardware viewpoint to this architecture.

The RISCV architecture is shown in Fig. 1. In this exercise, the instruction memory and data memory are implemented in the testbench. Except the memories, you need to implement everything else by yourself.



## 2. Specification

The input/output pins are defined in Table. 1. The required instructions you need to support in the baseline are "JAL, JALR, BEQ, BNE, LD, SD, ADDI, SLTI, XORI, ORI, ANDI, SLLI, SRLI, SRAI, ADD, SUB, SLL, SLT, XOR, SRL, SRA, OR, AND". The complete machine codes for the required instructions are not listed in this document. Please refer to your textbook or RISCV Green Sheet for the full machine code, our testbench follows the standard machine code rules.

The input/output pins are defined in Table1:

Tabel. 1:I/O pins specification

| Signal name | 1/0 | Bit width | Description                               |
|-------------|-----|-----------|-------------------------------------------|
| clk         | I   | 1         | Clock signal.                             |
|             |     |           | Positive edge trigger.                    |
| rst_n       | I   | 1         | Active low asynchronous reset signal.     |
| mem_addr_I  | 0   | 30        | Output address of instruction memory.     |
| mem_rdata_I | I   | 32        | Instruction read from instruction memory. |
| mem_wen_D   | 0   | 1         | Write-enable                              |
|             |     |           | Set it high to write data into memory.    |
| mem_addr_D  | 0   | 30        | Output address of data memory.            |
| mem_wdata_D | 0   | 64        | Data store to data memory.                |
| mem_rdata_D | I   | 64        | Data read from data memory.               |

Note the instruction and data memory is stored in little Endian.

## 3. Files

- Your work should be submitted in a compressed file following the naming convention, Final\_Group#.zip (for example, Final\_Group1.zip). There's a 20% penalty for incorrect upload format. No late submission is accepted.
  - Final\_Group#.zip
    - Final\_Group#/
      - RISCV.v (RTL file)
      - RISCV syn.v (synthesized gate-level netlist)
      - RISCV\_syn.ddc (Design database generated by Synopsys Design Compiler)
      - RISCV\_syn.sdf (Pre-layout gate-level sdf)
      - Report\_Group#.pdf (Report, replace with your index)
      - Outcome.txt

# 4. Grading Criteria

We encourage you to generate testing file by RARS.

Make sure to check signed executions for some instructions.

# Plagiarism is prohibited!

| Item                        | Description                                     |  |
|-----------------------------|-------------------------------------------------|--|
| RTL tb1/tb2/tb3 correctness | Your RISCV.v should give correct answer.        |  |
| (30%)                       | (no latch and non-negative slack)               |  |
|                             | No timing violation after reset.                |  |
| RTL (hidden) (10%)          | Additional test case besides the provided files |  |
| Gate-level tb1/tb2/tb3      | Your RISCV_syn.v should give correct answer.    |  |
| correctness (30%)           |                                                 |  |
| Outcome.txt                 | See the reference below                         |  |
| Report (10%)                | 1. no latch                                     |  |
|                             | 2. Timing report → report_timing                |  |
|                             | 3. Area report → report_area                    |  |
|                             | 4. Please describe how you design this single   |  |
|                             | cycle RISCV (Architecture and some analysis for |  |
|                             | your A*T improvement)                           |  |
|                             | 5. Work distribution                            |  |
| Performance (20%)           | Top 5 group: 20, 17, 14, 12, 10                 |  |
|                             | Others: max(0, 15-rank)                         |  |

## Performance

When designing a digital system, there are some metrics to verify how well it performs, the common metrics are timing, area and power. We will use timing and area in this final project.

All groups in class will compete their A\*T value(cost).

Grade A: Pass synthesis testbench (tb1+tb2+tb3) → A\*T

Grade B: Pass RTL testbench (tb1+tb2+tb3)

Grade A > Grade B

#### Ref:

### Outcome.txt

A: From area report (Total cell area)

T: Clock cycle you use to synthesis and pass gate-level simulation(tb1&tb2&tb3)

If you use 10 to synthesis but pass simulation at 12, please use 12 to calculate and also write 12 in Outcome.txt . We will run your gate-level simulation on the cycle time you provide.

RTL pass cycle: 10.0 SYN pass cycle: 10.0 Total cell area: 171861.744619

A\*T(Area\*SYN pass cycle): 1718617.44619

### No latch:

```
Inferred memory devices in process
        in routine RISCV line 156 in file
                 '/home/raid7_2/user08/r08016/Test_Final/v5/RISCV.v'.
     Register Name
                                     Width | Bus | MB | AR | AS |
                                                                   SR | SS | ST
                           Type
        PC reg
                       | Flip-flop
<mark>/arning: /home/raid7_2/user08/r08016/Test_Final/v5/RISCV.v:189: signed to unsig</mark>
Inferred memory devices in process
        in routine reg_file line 192 in file
                 '/home/raid7_2/user08/r08016/Test_Final/v5/RISCV.v'.
     Register Name
                           Type
                                     Width | Bus | MB |
                                                        AR | AS | SR | SS | ST
                        Flip-flop |
                                     2048
                                                  N
                                                            N
                                                                   Ν
                                                                        Ν
        mem_reg
```

### Timing report:

#### Area report:

| alu0/out[54] (alu) U615/Y (A022X4) reg0/d[54] (reg_file) reg0/U212/Y (INVX12) reg0/U256/Y (CLKBUFX2) reg0/U255/Y (CLKINVX12) reg0/U255/Y (CLKINVX12) reg0/U4437/Y (MXI2X1) reg0/mem_reg_954_/D (DFFRX1) data arrival time  clock CLK (rise edge) clock network delay (ideal) clock uncertainty reg0/mem_reg_954_/CK (DFFRX1) library setup time data required time | 0.07<br>0.14 | 4.74 r<br>4.81 f<br>4.96 f<br>5.04 r<br>5.11 f<br>5.25 r<br>5.25 r<br>5.25<br>5.00<br>5.50<br>5.40 r |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------------------------------------------------------------------------------------------------|
| data required time data arrival timeslack (MET)                                                                                                                                                                                                                                                                                                                    |              | 5.25<br>-5.25<br>-0.00                                                                               |

```
dc_shell> report_area
Report : area
Design : RISCV
Version: N-2017.09-SP2
Date
        Sun Dec 13 15:26:39 2020
Library(s) Used:
    typical (File: /home/raid7_2/course/cvsd/CE
                                          1495
Number of ports:
Number of nets:
                                          15498
Number of cells:
                                          12141
Number of combinational cells:
                                          10092
Number of sequential cells:
                                           2040
Number of macros/black boxes:
Number of buf/inv:
                                           2006
Number of references:
                                             79
Combinational area:
                                 106724.023813
                                  17958.492030
Buf/Inv area:
                                  65137.722805
Noncombinational area:
Macro/Black Box area:
                                      0.000000
                                1602121.526459
Net Interconnect area:
Total cell area:
                                 171861.746619
Total area:
                                1773983.273077
```