# National Cheng Kung University Department of Electrical Engineering

### Introduction to VLSI CAD (Spring 2024)

### **Lab Session 2**

# Design and Simulation of Carry-Lookahead Adder & Parallel-Prefix Adder & Multiplier

| Name                |           | Student | ID    |
|---------------------|-----------|---------|-------|
| 簡笠恩                 | E14102305 |         | 05    |
| Practical Sections: |           | Points  | Marks |
| Prob A              |           | 15      |       |
| Prob B              |           | 30      |       |
| Prob C              |           | 40      |       |
| Report              |           | 15      |       |
| Bonus               |           | 10      |       |
| Notes               |           |         |       |
|                     |           |         |       |

#### Due Date: 14:59, March 13, 2024 @ moodle

#### **Deliverables**

- All Verilog codes including testbenches for each problem should be uploaded.
   NOTE: Please **DO NOT** include source code in the paper report!
- 2) All homework requirements should be uploaded in this file hierarchy or you will not get the full credit.
  - NOTE: Please DO NOT upload waveforms!
- 3) Important! TA will use the command in Appendix A to check your design under SoC Lab environment, if your code can not be recompiled by TA successfully using the commands, you will not get the full credit.
- 4) If you upload a dead body which we can't even compile you will get NO credit!
- 5) All Verilog file should get at least 90% superLint Coverage.
- 6) File hierarchy should not be changed; it may cause your code can not be recompiled by TA successfully using the autograding commands



Fig.1 File hierarchy for Homework submission

#### **Objectives:**

Help students get familiar with the CAD tools (VCS & Verdi) for digital logic design. Introduce different adder architectures and the algorithms behind them. Please go through the hands-on exercise step-by-step.

Prob A: Design Steps & Carry-Lookahead Adder

- 1) An adder is a digital circuit that performs addition of number. Please design a full adder in gate level.
- 2) The truth table of full adder

| Inputs |   | Outputs         |                           |   |
|--------|---|-----------------|---------------------------|---|
| Α      | В | c <sub>in</sub> | $\mathbf{c}_{\text{out}}$ | s |
| 0      | 0 | 0               | 0                         | 0 |
| 0      | 0 | 1               | 0                         | 1 |
| 0      | 1 | 0               | 0                         | 1 |
| 0      | 1 | 1               | 1                         | 0 |
| 1      | 0 | 0               | 0                         | 1 |
| 1      | 0 | 1               | 1                         | 0 |
| 1      | 1 | 0               | 1                         | 0 |
| 1      | 1 | 1               | 1                         | 1 |

3) Draw a full adder in gate level.



- 4) Design a full adder in Structural coding (The module name should be FA. And the file you include should be FA.v)
- 5) Carry-lookahead-adder uses carry generator to alleviate the lengthy carry

propagation procedure in ripple-carry-adder.

6) Derive the 8<sup>th</sup> carry bit  $C_8(ex. C_2 = A_1B_1 + (A_1 + B_1)C_1 = g_1 + p_1C_1 = g_1 + p_1g_0 + p_1p_0C_0)$ 



ex.  $C_2 = A_1B_1 + (A_1 + B_1)C_1 = g_1 + p_1C_1 = g_1 + p_1g_0 + p_1p_0C_0$ ,  $g_1 + p_1g_0 + p_1p_0C_0$  is the final result.

 $C_8 = A_7B_7 + (A_7 + B_7)C_7 = g_7 + p_7C_7 = g_7 + p_7g_6 + p_7p_6C_6 = g_7 + p_7g_6 + p_7p_6g_5 + p_7p_6p_5C_5$ 

 $=g_7+p_7g_6+p_7p_6g_5+p_7p_6p_5g_4+p_7p_6p_5p_4C_4=g_7+p_7g_6+p_7p_6g_5+p_7p_6p_5g_4+p_7p_6p_5p_4g_3+p_7p_6p_5p_4p_3C_3=g_7+p_7g_6+p_7p_6g_5+p_7p_6p_5g_4+p_7p_6p_5p_4g_3+p_7p_6p_5p_4p_3g_2+p_7p_6p_5p_4p_3p_2C_2=g_7+p_7g_6+p_7p_6g_5+p_7p_6p_5g_4+p_7p_6p_5p_4g_3+p_7p_6p_5p_4p_3g_2+p_7p_6p_5p_4p_3p_2g_1+p_7p_6p_5p_4p_3p_2p_1C_1$ 

= g7 + p7g6 + p7p6g5 +p7p6p5g4 + p7p6p5p4g3 + p7p6p5p4p3g2 + p7p6p5p4p3p2g1 + p7p6p5p4p3p2p1g0 + p7p6p5p4p3p2p1p0

- 7) **Design a 8-bit carry lookahead adder** in **Structural coding** (The module name should be CLA8. And the file you include should be CLA8.v)
- 8) **Design a 32-bit carry lookahead adder in hierarchical coding** using previously designed CLA8 module. (The module name should be CLA32. And the file should be CLA32.v)



| Signal   | 10     | Bits | Description              |
|----------|--------|------|--------------------------|
| а        | Input  | 32   | Addend                   |
| b        | Input  | 32   | Augend                   |
| sum      | Output | 32   | Result after calculating |
| overflow | Output | 1    | Overflow detection       |

- 9) Simulate your design with the following test pattern in sample testbench. (Hint: The command for compiling is % vcs -R tb\_CLA.32v -full64) (Hint: The command for simulation is %vcs -R tb\_CLA32.v -debug\_access+all -full64 +define+FSDB)
- 10) Verify your design by comparing the simulation results with the results you predicted. If the results are not the same, please go back to 2) and revise your code. If the simulation results are correct, please snapshot the simulation result on the terminal and the waveform you dumped and explain your waveform.

  (Hint: The command to open nWave is %nWave &)

  In addition, you should check your coding style, and make sure that there are no error messages and coverage with Superlint must > 90 %. Snapshot the result and calculate Superlint coverage. (Hint: The command to open Superlint is %jg -superlint superlint.tcl)
- **11)** You only need to upload your v-code to moodle, **do not** paste your code here.

#### Your simulation result on the terminal.

#### Your waveform:



#### Explanation of your waveform:

我擷取一部份的程式出來 在左邊對出來的 A 為 606\_0606,B 為 3535\_3535

,我們計算可得知 Sum 應該為 3b3b\_3b3b,而最後我們寫的程式確實為 3b3b\_3b3b

#### Superlint screenshot and coverage ∇ Description (Order by Category) Category, FILEFORMAT (2) Tag: FIL\_MS\_DUNM (1) "Module name 'pg\_generation' differs from file name 'CLA8.v'" Tag: FIL\_NR\_MMOD (1) <u>....</u> Tag: FIL\_NK\_MMOD (L) More than one design-unit definition in file './CLA8.v" Category CODINGSTYLE (4) Tag: WIR\_NO\_READ (1) "More than one design-unit definition in file './CLA8.v" "Wire 'sh' defined in module CLA8 does not drive any object, But is assigned at least once" Ė٠ ġ... "A constant is used in a port expression" Tag: OTP\_UC\_INST (2) <u>.</u> lag: UP\_UC\_INST (2) "Port 'Cout' (which is being used as an output) of entity/module 'FA' is being driven inside the design, but not connect "Port 'Cout' (which is being used as an output) of entity/module 'CLA8' is being driven inside the design, but not conn 1-(6/23+79+14)=94.83% (VERT-SOZO)] .//CENDZ.V(ID): MESSING/OPER POLES ON INSCANCE CLA32 [<embedded>] % [<embedded>] % # Setup clock and reset [<embedded>] % #clock clk; ## modify your clock name ## [<embedded>] % #reset rst; ## modify your reset name ## [<embedded>] % [<embedded>] % # Extract checks [<embedded>] % check superlint -extract INFO (ISL018): Started extraction of structural checks INFO (ISL016): Extracted 2 STRUCTURAL checks. INFO (ISL016): Extracted 4 BASIC LINT checks. [<embedded>] % [<embedded>] % wc -l CLA32.v [<embedded>] % wc -l CLA8.v 79 CLA8.v [<embedded>] % wc -l FA.v 14 FA.v

- 1) Parallel-prefix-adder reduces the complexity of the carry generation circuitry in carry-lookahead-adder.
- 2) Recursive formulation of carry bits:

Q(m, n) = 
$$\sum_{i=n}^{m} (\prod_{r=i+1}^{m} p_r) g_i$$

$$C_{0} = 0$$

$$C_{1} = A_{1}B_{1} + (A_{1} \oplus B_{1})C_{0} = g_{1} + p_{1}C_{0} = g_{1}$$

$$C_{2} = A_{2}B_{2} + (A_{2} \oplus B_{2})C_{1} = g_{2} + p_{2}C_{1} = g_{2} + p_{2}g_{1}$$

$$C_{3} = A_{3}B_{3} + (A_{3} \oplus B_{3})C_{2} = g_{3} + p_{3}C_{2} = g_{3} + p_{3}g_{2} + p_{3}p_{2}g_{1}$$

$$= Q(2, 1) = p_{2}Q(1, 1) + Q(2, 2)$$

$$= Q(3, 1) = p_{3}p_{2}Q(1, 1) + Q(3, 2)$$

$$= p_{3}p_{2}Q(1, 1) + p_{3}Q(2, 2) + Q(3, 3)$$

$$C_{4} = A_{4}B_{4} + (A_{4} \oplus B_{4})C_{3} = g_{4} + p_{4}C_{3} = g_{4} + p_{4}g_{3} + p_{4}p_{3}g_{2} + p_{4}p_{3}p_{2}g_{1}$$

$$= Q(4, 1) = p_{4}p_{3}Q(2, 1) + Q(4, 3)$$



- 3) Design a full adder in Structural coding (The module name should be FA. And the file you include should be FA.v)
- 4) **Design black cell & blue cell in Structural coding** (The module name should be black\_cell & blue\_cell. And the file you include should be black\_cell.v & blue cell.v)
- 5) Design a 8-bit parallel-prefix-adder in hierarchical coding using black cell & blue cell as basic unit (The module name should be PPA8. And the file you include should be PPA8.v)
- 6) **Design a 32-bit parallel-prefix-adder in hierarchical coding** using previously designed PPA8 module. (The module name should be PPA32. And the file should





| Signal   | 10     | Bits | Description              |
|----------|--------|------|--------------------------|
| а        | Input  | 32   | Addend                   |
| b        | Input  | 32   | Augend                   |
| sum      | Output | 32   | Result after calculating |
| overflow | Output | 1    | Overflow detection       |

- 7) Simulate your design with the following test pattern in sample testbench. (Hint: The command for compiling is % vcs -R tb\_PPA32.v -full64) (Hint: The command for simulation is %vcs -R tb\_PPA32.v -debug\_access+all -full64 +define+FSDB)
- 8) Verify your design by comparing the simulation results with the results you predicted. If the results are not the same, please go back to 2) and revise your code. If the simulation results are correct, please snapshot the simulation result on the terminal and the waveform you dumped and explain your waveform. (Hint: The command to open nWave is %nWave &)

  In addition, you should check your coding style, and make sure that there are no error messages and coverage with Superlint must > 90 %. Snapshot the result and calculate Superlint coverage. (Hint: The command to open Superlint is %jg -superlint superlint.tcl)
- 9) You only need to upload your v-code to moodle, **do not** paste your code here.

#### Your simulation result on the terminal.

#### Your waveform:



#### Explanation of your waveform:

我擷取一部份的波形出來 在左邊對出來的 A 為 404\_0404,B 為 2525\_2525

,我們計算可得知 Sum 應該為 2929\_2929,而最後我們寫的程式 確實為

2929 2929

Superlint screenshot and coverage

```
    □ Description (Order by Category)

                  Category: CODINGSTYLE (6)
Tag: OTP_UC_INST (2)
     <u> </u>
                         "Port 'p' (which is being used as an output) of entity/module 'pg_generation' is being driven inside the desi
Port 'Cout' (which is being used as an output) of entity/module 'PPA8' is being driven inside the design, but
                    Tag: WIR_NO_READ (3)
     ag: win, No_REAU (3)

"Wire 'p[0]' defined in module 'PPA8' does not drive any object, but is assigned at least once"

"Wire 'sh' defined in module 'PPA8' does not drive any object, but is assigned at least once"

"Wire 'carry_wire[3]' defined in module 'PPA32' does not drive any object, but is assigned at least once"

be IMC NO BUTEY (1)
     ġ..
                    Tag: INS_NR_PTEX (1)
                 "A constant is used in a port expression"
Category: FILEFORMAT (2)
 Ė
                    "Module name 'pg_generation' differs from file name 'PPA8.v'"
Tag: FIL_NR_MMOD (1)
     <u> </u>
     <u>.</u>
                           ore than one design-unit definition in file './PPA8.v'"
[<embedded>] %
[<embedded>] % # Setup clock and reset
 [<embedded>] % #clock clk; ## modify your clock name ##
[<embedded>] % #reset rst; ## modify your reset name ##
[<embedded>] %
[<embedded>] % # Extract checks
 [<embedded>] % check_superlint -extract
INFO (ISL018): Started extraction of structural checks
INFO (ISL016): Extracted 5 STRUCTURAL checks.
INFO (ISL016): Extracted 6 BASIC LINT checks.
11
[<embedded>] %
[<embedded>] % wc -l black cell.v
11 black_cell.v
 [<embedded>] % wc -l blue cell.v
10 blue cell.v
[<embedded>] % wc -l FA.v
[<embedded>] % wc -l PPA8.v
 89 PPA8.v
[<embedded>] % wc -l PPA32.v
25 PPA32.v
1-11/(11+10+14+89+25)=92.62%
```

#### Prob C: Application

#### 1) Design a 8\*8-bit multiplier

- a. Using CLAs of Prob A
- b. Using PPAs of Prob B
- c. Design in gate level rather than behavioural modelling. (The module name should be Multiplier\_CLA & Multiplier\_PPA. And the file you include should be Multiplier\_CLA.v & Multiplier\_PPA.v)
- 2) Draw your hieratical structure.
- 3) You only need to upload your v-code to moodle, do not paste your code here.
- 4) Simulate your design with the testbench which includes all case of input. (Hint: The command for compiling is % vcs -R tb Multiplier.v -full64)

(Hint: The command for simulation is % vcs -R tb\_Multiplier.v

-debug\_access+all -full64 +define+FSDB)

10) Verify your design by comparing the simulation results with the results you predicted. If the results are not the same, please go back to 2) and revise your code. If the simulation results are correct, please snapshot the simulation result on the terminal and the waveform you dumped and explain your waveform. (Hint: The command to open nWave is %nWave &)
In addition, you should check your coding style, there are no error messages and over 90% coverage with Superlint. Snapshot the result and calculate Superlint coverage. (Hint: The command to open Superlint is %jg -superlint superlint.tcl)

Draw your hieratical structure.





Your simulation result on the terminal.

#### CLA





```
Multiplier_PPA
[<embedded>] %
[<embedded>] % # Setup clock and reset
[<embedded>] % #clock clk; ## modify your clock name ##
[<embedded>] % #reset rst; ## modify your reset name ##
[<embedded>] %
[<embedded>] % # Extract checks
[<embedded>] % check superlint -extract
INFO (ISL018): Started extraction of structural checks
INFO (ISL016): Extracted 7 STRUCTURAL checks.
INFO (ISL016): Extracted 15 BASIC LINT checks.
[<embedded>] %
[<embedded>] % wc -l black_cell.v
10 black_cell.v
[<embedded>] % wc -l blue cell.v
10 blue_cell.v
[<embedded>] % wc -l PPA8.v
97 PPA8.v
[<embedded>] % wc -l Multiplier PPA.v
116 Multiplier_PPA.v
[<embedded>] % wc -l FA.v
14 FA.v
```

1-22/97+116+10+10+14=91.09%

Appendix A: Commands we will use to check your homework

| Problem |          | Commands                                                   |
|---------|----------|------------------------------------------------------------|
| ProbA   | Compile  | % vcs -R tb_CLA32.v -full64                                |
|         | Simulate | % vcs -R tb_CLA32.v -debug_access+all -full64 +define+FSDB |
| ProbB   | Compile  | % vcs -R tb_PPA32.v -full64                                |
|         | Simulate | % vcs -R tb_PPA32.v -debug_access+all -full64 +define+FSDB |
| ProbC   | Compile  | % vcs -R tb_Multiplier.v -full64                           |