#### COL216 Assignment 2 Stage 2 Aryan Dua – 2020CS50475

The epwaves shown are the result of the testbench that I have submitted along with my code in this zip file. I have tested my design on the two test examples given to us. I would have tested extensively on more examples, but sadly I couldn't get the time to do so, as my minors finished just one day before the deadline. Also, I would request that this assignment uses my credit day of the last assignment.

Technically, I submitted my last assignment on the extended day, but it was done on the due date itself. At 11:30pm when I opened my laptop to submit, I read the mail that the deadline was extended, therefore I went back with my family to continue what I was doing and submitted it when I came back at 12:20am, just 20 minutes later than the original deadline. Then, as we were not informed of the credit day, I made some redundant changes in report.pdf the next day (Totally useless changes, but did it because I had time (or so it seemed)) and submitted it again (you can check that my code is the same). I request you to consider this as a credit day and let me use it on this assignment.

#### **Design Description:**

In my main processor.vhd file, I have 8 components, namely – Program counter, Register File, Data Memory, Program Memory, ALU, Flag updater, Condition checker, Decoder. I have attached their synthesis reports below. All these components have been instantiated under the processor architecture. The data path signals flow through them. The control signals are given to the processor by the decoder. The last control signal Psrc, is given by the condition checker. I have simulated and synthesized on edaplayground.com

The design works up to the expectation and nothing has been hardcoded. I have attached the epwave outputs of as many signals as I could/are relevant. I have given a looped clock input of 25 iterations for this stage. I will add a reset signal in further stages. The PW control signal that I have declared is redundant in this stage.

# **Synthesis Reports:**

#### 0. Processor

```
Device Utilization for 7A100TCSG324
Used Avail Utilization
# Info: Resource
# Info: ------
# Info: IOs
                           1 210 0.48%
                                       0.00%
                                 32
# Info: Global Buffers
                            0
# Info: LUTs
                            0
                                  63400
                                      0.00%
# Info: CLB Slices
                            0
                                  15850
                                       0.00%
# Info: Dffs or Latches
                            0
                                  126800 0.00%
# Info: Block RAMs
                            0
                                  135
                                        0.00%
# Info: DSP48E1s
                                  240
Info: Library: work Cell: processor View: behavior
# Info: Number of ports :
# Info: Number of nets:
                                     0
# Info: Number of instances:
# Info: Number of references to this view :
# Info: Total accumulated area:
# Info: Number of gates :
# Info: Number of accumulated instances :
# Info: ****************
IO Register Mapping Report
# Info: ****************
# Info: Design: work.processor.behavior
# Info: | Port | Direction | INFF | OUTFF | TRIFF |
# Info: +-----+
# Info: Total registers mapped: 0
    Netlist:
//
// Verilog description for cell processor,
// Sun Feb 20 13:05:04 2022
// Precision RTL Synthesis, 64-bit 2021.1.0.4//
(* PSEUDO BBOX = "1" *)
module processor ( clock ) ;
input clock ;
```

#### 1. Condition Checker:

```
Device Utilization for 7A100TCSG324
Used Avail Utilization
# Info: Resource
# Info: ------

      14
      210
      6.67%

      1
      32
      3.12%

      1
      63400
      0.00%

      1
      15850
      0.01%

      1
      126800
      0.00%

      0
      135
      0.00%

      0
      240
      0.00%

# Info: IOs
# Info: Global Buffers
# Info: LUTs
# Info: CLB Slices
# Info: Dffs or Latches
# Info: Block RAMs
# Info: DSP48E1s
# Info: **********************************
# Info: Library: work Cell: condition View: rtl
# Info: **********************************
# Info: Number of ports :
# Info: Number of nets :
                                                    17
# Info: Number of instances :
                                                     11
# Info: Number of references to this view: 0
# Info: Total accumulated area:
# Info: Number of Dffs or Latches :
# Info: Number of LUTs :
                                                     1
# Info: Number of Primitive LUTs :
                                                     1
# Info: Number of accumulated instances: 11
```

## 2. Data Memory

| Device Utilization for 7A100TCSG324 # Info: ************************************ | · • • • • • • • • • • • • • • • • • • • | ******      |  |  |  |
|----------------------------------------------------------------------------------|-----------------------------------------|-------------|--|--|--|
| # Info: ************************************                                     |                                         | Utilization |  |  |  |
| # Info:                                                                          |                                         |             |  |  |  |
| # Info: IOs 75                                                                   | 210                                     | 35.71%      |  |  |  |
| # Info: Global Buffers 1                                                         | 32                                      | 3.12%       |  |  |  |
| # Info: LUTs 32                                                                  | 63400                                   | 0.05%       |  |  |  |
| # Info: CLB Slices 8                                                             | 15850                                   | 0.05%       |  |  |  |
| # Info: Dffs or Latches 0                                                        | 126800                                  | 0.00%       |  |  |  |
| # Info: Block RAMs 0                                                             | 135                                     | 0.00%       |  |  |  |
| # Info: Distributed RAMs                                                         |                                         |             |  |  |  |
| # Info: RAM64X1S 32                                                              |                                         |             |  |  |  |
| # Info: DSP48E1s 0                                                               | 240                                     | 0.00%       |  |  |  |
| # Info:                                                                          |                                         |             |  |  |  |
| # Info: **************                                                           |                                         |             |  |  |  |
| # Info: Library: work Cell: DM View: BEV                                         |                                         |             |  |  |  |
| # Info: ************************************                                     |                                         |             |  |  |  |
| # Info: Number of ports :                                                        | 75                                      |             |  |  |  |
| # Info: Number of nets:                                                          | 150                                     |             |  |  |  |
| # Info: Number of instances :                                                    | 76                                      |             |  |  |  |
| # Info: Number of references to this view :                                      | 0                                       |             |  |  |  |
| # Info: Total accumulated area :                                                 |                                         |             |  |  |  |
| # Info: Number of LUTs :                                                         | 32                                      |             |  |  |  |
| # Info: Number of Primitive LUTs :                                               | 32                                      |             |  |  |  |
| # Info: Number of LUTs as Distributed RAM :                                      | 32                                      |             |  |  |  |
| # Info: Number of accumulated instances :                                        | 107                                     |             |  |  |  |

#### 3. ALU

```
Device Utilization for 7A100TCSG324
Used Avail Utilization
# Info: Resource
# Info: ------
# Info: IOs
                               114
                                     210 54.29%
                               0 32
# Info: Global Buffers
                                           0.00%
                              201 63400 0.32%

27 15850 0.17%

0 126800 0.00%

0 135 0.00%

0 240 0.00%
# Info: LUTs
# Info: CLB Slices
# Info: Dffs or Latches
# Info: Block RAMs
# Info: DSP48E1s
# Info: ------
# Info: **************************
# Info: Library: work Cell: alu View: rtl
# Info: ******************************
# Info: Number of ports :
# Info: Number of nets :
                                       493
# Info: Number of instances :
                                       381
# Info: Number of references to this view :
# Info: Total accumulated area:
# Info: Number of LUTs:
                                      201
# Info: Number of Primitive LUTs :
                                      233
# Info: Number of LUTs with LUTNM/HLUTNM :
                                      64
# Info: Number of MUX CARRYs :
                                       64
# Info: Number of accumulated instances: 478
```

#### 4. Program Counter:

```
Device Utilization for 7A100TCSG324
Used Avail Utilization
# Info: Resource
# Info: ------

      58
      210
      27.62%

      1
      32
      3.12%

      90
      63400
      0.14%

      23
      15850
      0.15%

      30
      126800
      0.02%

      0
      135
      0.00%

      0
      240
      0.00%

# Info: IOs
# Info: Global Buffers
# Info: LUTs
# Info: CLB Slices
# Info: Dffs or Latches
# Info: Block RAMs
# Info: DSP48E1s
# Info: ------
# Info: *************************
# Info: Library: work Cell: pc View: rtl
# Info: **************************
# Info: Number of ports :
                                                   58
# Info: Number of nets :
                                                  326
# Info: Number of instances :
                                                 300
# Info: Number of references to this view :
# Info: Total accumulated area:
# Info: Number of Dffs or Latches :
                                                  30
# Info: Number of LUTs :
                                                  90
# Info: Number of Primitive LUTs :
                                                  90
# Info: Number of MUX CARRYs :
                                                  59
# Info: Number of accumulated instances: 300
```

## 5. Decoder:

| Device Utilization for 7A100TCSG324 # Info: ************************************ |        |           |             |  |  |
|----------------------------------------------------------------------------------|--------|-----------|-------------|--|--|
| # Info: Resource                                                                 |        |           | Utilization |  |  |
| # Info:                                                                          |        |           |             |  |  |
| # Info: IOs                                                                      | 146    | 210       | 69.52%      |  |  |
| # Info: Global Buffers                                                           | 1      | 32        | 3.12%       |  |  |
| # Info: LUTs                                                                     | 25     | 63400     | 0.04%       |  |  |
| # Info: CLB Slices                                                               | 3      | 15850     | 0.02%       |  |  |
| # Info: Dffs or Latches                                                          | 17     | 126800    | 0.01%       |  |  |
| # Info: Block RAMs                                                               | 0      | 135       | 0.00%       |  |  |
| # Info: DSP48E1s                                                                 | 0      | 240       | 0.00%       |  |  |
| # Info:                                                                          |        |           |             |  |  |
| # Info: ******************                                                       | *****  | ******    | ******      |  |  |
| # Info: Library: work Cell: Decoder                                              | View:  | Behaviora | ıl          |  |  |
| # Info: ******************                                                       | ****** |           | *****       |  |  |
| # Info: Number of ports :                                                        |        | 146       |             |  |  |
| # Info: Number of nets :                                                         |        | 229       |             |  |  |
| # Info: Number of instances :                                                    |        | 197       |             |  |  |
| # Info: Number of references to this vi                                          | ew :   | 0         |             |  |  |
| # Info: Total accumulated area :                                                 |        |           |             |  |  |
| # Info: Number of Dffs or Latches :                                              |        | 17        |             |  |  |
| # Info: Number of LUTs:                                                          |        | 25        |             |  |  |
| # Info: Number of Primitive LUTs:                                                |        | 31        |             |  |  |
| # Info: Number of LUTs with LUTNM/HLUTN                                          | •      | 12        |             |  |  |
| # Info: Number of accumulated instances                                          | :      | 197       |             |  |  |

# 6. Instruction Memory:

| David Utility 1: Car 74100TCCC224                                                           |          |        |             |  |
|---------------------------------------------------------------------------------------------|----------|--------|-------------|--|
| <pre>Device Utilization for 7A100TCSG324 # Info: ************************************</pre> |          | ****   | ****        |  |
|                                                                                             |          |        |             |  |
| # Info: Resource<br># Info:                                                                 |          |        | Utilization |  |
| " 11110.                                                                                    |          |        |             |  |
| # Info: IOs                                                                                 | 38       | 210    |             |  |
| # Info: Global Buffers                                                                      | 0        | 32     | 0.00%       |  |
| # Info: LUTs                                                                                | 12       | 63400  | 0.02%       |  |
| # Info: CLB Slices                                                                          | 2        | 15850  | 0.01%       |  |
| # Info: Dffs or Latches                                                                     | 0        | 126800 | 0.00%       |  |
| # Info: Block RAMs                                                                          | 0        | 135    | 0.00%       |  |
| # Info: DSP48E1s                                                                            | 0        | 240    | 0.00%       |  |
| # Info:                                                                                     |          |        |             |  |
| # Info: *****************                                                                   | *******  | ****** |             |  |
| # Info: Library: work Cell: IM Vi                                                           | lew: BEV |        |             |  |
| # Info: ************************************                                                |          |        |             |  |
| # Info: Number of ports :                                                                   |          | 38     |             |  |
| # Info: Number of nets:                                                                     |          | 59     |             |  |
| # Info: Number of instances :                                                               |          | 53     |             |  |
| # Info: Number of references to this v                                                      | /iew :   | 0      |             |  |
| # Info: Total accumulated area :                                                            |          |        |             |  |
| # Info: Number of LUTs :                                                                    |          | 12     |             |  |
| <pre># Info: Number of Primitive LUTs :</pre>                                               |          | 14     |             |  |
| # Info: Number of LUTs with LUTNM/HLU7                                                      | ΓNM :    | 4      |             |  |
| # Info: Number of accumulated instance                                                      |          | 53     |             |  |

#### 7. Register File

```
Device Utilization for 7A100TCSG324
Used Avail Utilization
# Info: Resource
# Info: ------
# Info: IOs
                                110 210 52.38%
                               1 32 3.12%

48 63400 0.08%

12 15850 0.08%

0 126800 0.00%

0 135 0.00%
# Info: Global Buffers
# Info: LUTs
# Info: CLB Slices
# Info: Dffs or Latches
# Info: Block RAMs
# Info: Distributed RAMs
# Info: RAM32M
                                10
# Info:
        RAM64M
                                2
# Info: DSP48E1s
                                      240 0.00%
# Info: ------
# Info: *************
# Info: Library: work Cell: RF View: BEV
# Info: ****************************
# Info: Number of ports :
                                        110
# Info: Number of nets :
                                       220
# Info: Number of instances :
                                       111
# Info: Number of references to this view :
                                         0
# Info: Total accumulated area :
# Info: Number of LUTs :
                                         48
# Info: Number of Primitive LUTs :
                                        48
# Info: Number of LUTs as Distributed RAM :
# Info: Number of accumulated instances :
                                        48
                                       123
```

#### 8. Flag Updater

```
Device Utilization for 7A100TCSG324
Used Avail Utilization
# Info: Resource
# Info: ------

      119
      210
      56.67%

      1
      32
      3.12%

      11
      63400
      0.02%

      2
      15850
      0.01%

      4
      126800
      0.00%

      0
      135
      0.00%

      0
      240
      0.00%

# Info: IOs
# Info: Global Buffers
# Info: LUTs
# Info: CLB Slices
# Info: Dffs or Latches
# Info: Block RAMs
# Info: DSP48E1s
# Info: ------
# Info: *****************************
# Info: Library: work Cell: flags View: rtl
# Info: Number of ports :
                                              119
# Info: Number of nets :
                                              127
# Info: Number of instances :
                                               74
# Info: Number of references to this view: 0
# Info: Total accumulated area:
# Info: Number of Dffs or Latches :
# Info: Number of LUTs :
                                               11
# Info: Number of Primitive LUTs :
                                              12
# Info: Number of accumulated instances: 74
```

### **Test Cases and Output:**

1. Here is the epwave output of the first example program:



Description: If we take a look at the datain[31:0] port, it shows the values that are being fed to the Register File. The port just above it, shows the address of the register to which the data is going to be written. To show that the program has been executed correctly, it is enough to see that at the end of the instructions, datain[31:0] = 2 and add\_out[31:0] = 4. This means that r4 = 2 at the end which is actually true, since r3 = 7 and r2 = 5, r3-r2 = 2. The names of the other ports are self-explanatory and can be verified.

(The program should have r0 = 8 initially instead of 10)

2. The epwave output of the second test program:



In this, the program will run 5 times until r1 reaches 0. (r1 = -4, -3, -2, -1, 0). To see the incremented values of r1 in each iteration, we can take a look at the datain[31:0] ports each time the program\_counter is at "c". In the port above it, '1' represents that r1 = datain. The program branches back to instruction 8 4 times before exiting. To do this, the condition checker component has been used, which uses the signed branch offset to decide the instruction to go to. All the flag updations can be verified in this epwave.