### CSE 4207 CT 4 Assignment Roll No: 1603014

**Assignment Problem:** 

Category: A

Word Size = 7 bits

ALU Operations = OR XOR AND ((A or B), SHR

### Solution:

#### Video:

| Have you uploaded the video?                                                                                                                                                                              | YES/NO |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--|
| Check List 1: Have you explained the design using testbenches to prove that your circuit is working correctly and giving correct results?                                                                 | YES    |  |
| Check List 2: Have you shown full synthesis results showing all the required info including RTL Synthesis, RTL Floorplan, RTL Power Analysis, GDS and Heatmap (for details, see assignment template doc)? | YES    |  |
| NB: Failing to upload video will cause heavy point penalty (5-6 Marks)                                                                                                                                    |        |  |
| NB: Failing to add any required info will cause point penalty (1-2 Marks)                                                                                                                                 |        |  |

### **HDL Code:**

| NB: Failing to add any required info will cause point penalty (1-2 Mar                                                                                              | 'ks) |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| Check List: Have you added all the modules written in verilog including ALU, ALU_OP1, ALU_OP2, CONTROLLER, TOP, TOP_TESTBENCH, ALU TESTBENCH, CONTROLLER TESTBENCH? | YES  |

### top.v

```
module TOP #(parameter WIDTH = 8)(
   input [WIDTH-1:0] A,
   input [WIDTH-1:0] B,
   input [4:0] opcode,
   output [WIDTH-1:0] result
);

  wire [4:0] alu_op;

  Controller ctrl (
        .opcode(opcode),
        .alu_op(alu_op)
);
```

```
ALU #(WIDTH) alu_unit (
          .A(A),
          .B(B),
          .opcode(alu_op),
          .Y(result)
);
endmodule
```

#### controller.v

### **RTL Timing Diagram:**

Check List: Have you added all the timing diagrams of ALU\_TESTBENCH, CONTROLLER\_TESTBENCH, TOP\_TESTBENCH?

YES

NB: Failing to add any required info will cause point penalty (1-2 Marks)

top tb.v



## RTL Synthesis (130nm Skywater PDK with OpenLane toolchain):

| Check List: Have you added RTL synthesis summary, RTL synthesized design figure and Standard cell usage in synthesized design? | YES |  |
|--------------------------------------------------------------------------------------------------------------------------------|-----|--|
| NB: Failing to add any required info will cause point penalty (1-2 Marks)                                                      |     |  |

## RTL synthesis summary

| Metric                     | Count |
|----------------------------|-------|
| Number of wires            | 1367  |
| Number of wire bits        | 1400  |
| Number of public wires     | 3     |
| Number of public wire bits | 36    |
| Number of ports            | 3     |
| Number of port bits        | 36    |
| Number of memories         | 0     |
| Number of memory bits      | 0     |
| Number of processes        | 0     |
| Number of cells            | 1376  |



# Standard cell usage in synthesized design

| Cell Name                 | Count | Cell Name                | Count |
|---------------------------|-------|--------------------------|-------|
| sky130_fd_sc_hd_a2111o_2  | 9     | sky130_fd_sc_hda2111oi_2 | 4     |
| sky130_fd_sc_hd_a2111oi_4 | 1     | sky130_fd_sc_hd_a211o_2  | 50    |
| sky130_fd_sc_hd_a211oi_2  | 10    | sky130_fd_sc_hd_a21bo_2  | 6     |
| sky130_fd_sc_hd_a21boi_2  | 1     | sky130_fd_sc_hda21o_2    | 59    |
| sky130_fd_sc_hd_a21oi_2   | 69    | sky130_fd_sc_hd_a21oi_4  | 2     |
| sky130_fd_sc_hd_a221o_2   | 8     | sky130_fd_sc_hd_a221oi_2 | 5     |
| sky130_fd_sc_hd_a22o_2    | 20    | sky130_fd_sc_hda22oi_2   | 2     |
| sky130_fd_sc_hd_a22oi_4   | 1     | sky130_fd_sc_hd_a2bb2o_2 | 4     |
| sky130_fd_sc_hda311o_2    | 14    | sky130_fd_sc_hda311oi_2  | 1     |
| sky130_fd_sc_hda311oi_4   | 1     | sky130_fd_sc_hda31o_2    | 43    |
| sky130_fd_sc_hd_a31oi_2   | 7     | sky130_fd_sc_hda31oi_4   | 2     |
| sky130_fd_sc_hda32o_2     | 8     | sky130_fd_sc_hda32oi_2   | 1     |
| sky130_fd_sc_hda41o_2     | 2     | sky130_fd_sc_hd_and2_2   | 27    |
| sky130_fd_sc_hd_and2_4    | 1     | sky130_fd_sc_hd_and2b_2  | 6     |
| sky130_fd_sc_hd_and3_2    | 38    | sky130_fd_sc_hdand3_4    | 4     |
| sky130_fd_sc_hd_and3b_2   | 6     | sky130_fd_sc_hdand4_2    | 11    |
| sky130_fd_sc_hd_and4b_2   | 3     | sky130_fd_sc_hd_and4bb_2 | 1     |
| sky130_fd_sc_hdbuf_1      | 59    | sky130_fd_sc_hdbuf_2     | 51    |
| sky130_fd_sc_hdbuf_4      | 6     | sky130_fd_sc_hdbuf_6     | 4     |
| sky130_fd_sc_hdconb_1     | 5     | sky130_fd_sc_hdinv_2     | 22    |
| sky130_fd_sc_hdmux2_2     | 31    | sky130_fd_sc_hdmux2_4    | 2     |
| sky130_fd_sc_hdmux4_2     | 1     | sky130_fd_sc_hdnand2_2   | 132   |
| sky130_fd_sc_hdnand3_2    | 8     | sky130_fd_sc_hdnand3b_2  | 1     |
| sky130_fd_sc_hdnand4_2    | 2     | sky130_fd_sc_hdnor2_2    | 134   |
| sky130_fd_sc_hdnor3_2     | 1     | sky130_fd_sc_hdnor4_2    | 1     |
| sky130_fd_sc_hdo2111a_2   | 9     | sky130_fd_sc_hdo2111ai_2 | 6     |
| sky130_fd_sc_hdo211a_2    | 53    | sky130_fd_sc_hdo211a_4   | 1     |
| sky130_fd_sc_hdo211ai_2   | 14    | sky130_fd_sc_hdo211ai_4  | 3     |
| sky130_fd_sc_hdo21a_2     | 40    | sky130_fd_sc_hdo21ai_2   | 46    |
| sky130_fd_sc_hdo21ba_2    | 9     | sky130_fd_sc_hdo21bai_2  | 2     |
| sky130_fd_sc_hdo221a_2    | 18    | sky130_fd_sc_hdo221ai_2  | 3     |
| sky130_fd_sc_hdo22a_2     | 24    | sky130_fd_sc_hdo22ai_2   | 1     |
| sky130_fd_sc_hdo2bb2a_2   | 3     | sky130_fd_sc_hdo311a_2   | 21    |
| sky130_fd_sc_hdo311a_4    | 1     | sky130_fd_sc_hdo311ai_2  | 2     |
| sky130_fd_sc_hdo311ai_4   | 1     | sky130_fd_sc_hdo31a_2    | 19    |
| sky130_fd_sc_hdo31ai_2    | 5     | sky130_fd_sc_hdo32a_2    | 9     |
| sky130_fd_sc_hdo32ai_2    | 4     | sky130_fd_sc_hdo41a_2    | 6     |
| sky130_fd_sc_hd_or2_2     | 47    | sky130_fd_sc_hd_or2_4    | 5     |
| sky130_fd_sc_hdor3_2      | 38    | sky130_fd_sc_hdor3_4     | 6     |
| sky130_fd_sc_hd_or3b_2    | 14    | sky130_fd_sc_hdor3b_4    | 2     |
| sky130_fd_sc_hd_or4_2     | 16    | sky130_fd_sc_hdor4_4     | 8     |
| sky130_fd_sc_hd_or4b_2    | 6     | sky130_fd_sc_hdor4b_4    | 3     |
| sky130_fd_sc_hdor4bb_4    | 1     | sky130_fd_sc_hdxnor2_2   | 34    |
| sky130_fd_sc_hd_xnor2_4   | 2     | sky130_fd_sc_hdxor2_2    | 7     |

# RTL Floorplan (130nm Skywater PDK with OpenLane toolchain)

| Check List: Have you added RTL Floorplan info? | YES |
|------------------------------------------------|-----|
|------------------------------------------------|-----|

## NB: Failing to add any required info will cause point penalty (1-2 Marks)

| General RTL Floorplan Information |                                        |                   |  |
|-----------------------------------|----------------------------------------|-------------------|--|
| Parameter                         | Value                                  | Unit              |  |
| Database Units (DBU)              | 1000                                   | _                 |  |
| Site Size                         | (0.460, 2.720)                         | μm                |  |
| Die Area (BBox)                   | (0.000, 0.000) to (400.000, 400.000)   | μm                |  |
| Core Area (BBox)                  | (10.120, 10.880) to (299.920, 299.200) | μm                |  |
| Core Area                         | 83555.136                              | $\mu\mathrm{m}^2$ |  |
| Placement Utilization             | 14.925                                 | %                 |  |

## RTL Power Analysis (130nm Skywater PDK with OpenLane toolchain)

| Check List: Have you added RTL Power Analysis info?                       | YES |  |
|---------------------------------------------------------------------------|-----|--|
| NB: Failing to add any required info will cause point penalty (1-2 Marks) |     |  |

| Group         | Internal<br>Power (mW) | Switching<br>Power (mW) | Leakage<br>Power (mW) | Total<br>Power (mW) | Contribution (%) |
|---------------|------------------------|-------------------------|-----------------------|---------------------|------------------|
| Sequential    | 0.0000                 | 0.0000                  | 0.0000                | 0.0000              | 0.0%             |
| Combinational | 0.9396                 | 1.6073                  | 0.000005              | 2.5468              | 100.0%           |
| Clock         | -0.00005               | 0.0000                  | 0.000006              | 0.000006            | 0.0%             |
| Macro         | 0.0000                 | 0.0000                  | 0.0000                | 0.0000              | 0.0%             |
| Pad           | 0.0000                 | 0.0000                  | 0.0000                | 0.0000              | 0.0%             |
| Total         | 0.9396                 | 1.6073                  | 0.000011              | 2.5468              | 100.0%           |

## GDS Layout (130nm Skywater PDK with OpenLane toolchain)

| Check List: Have you added the GDS Layout figure?                         | YES |  |
|---------------------------------------------------------------------------|-----|--|
| NB: Failing to add any required info will cause point penalty (1-2 Marks) |     |  |



## Heatmap (130nm Skywater PDK with OpenLane toolchain)

| Check List: Have you added the heatmap?                                   | YES |  |
|---------------------------------------------------------------------------|-----|--|
| NB: Failing to add any required info will cause point penalty (1-2 Marks) |     |  |

