

**Due Date: 15:10, March 5, 2025 @ moodle**

## **Deliverables**

- 1) 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 Lab2 tutorial 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 structural and hierarchical Verilog modeling and provide related practice problems. Please go through the hands-on exercise step-by-step.

---

### *Lab in class: Design Steps & Ripple-Carry Adder & Multiplier*

---

❖ **8-bit unsigned ripple-carry 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          |   |
|--------|---|-----------------|------------------|---|
| A      | B | C <sub>in</sub> | C <sub>out</sub> | 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) A ripple-carry adder is a basic digital circuit that performs binary addition by propagating carry bits sequentially through a chain of full adders, resulting in a relatively slow operation for large bit-widths.
- 6) Design a 4-bit unsigned ripple-carry adder in **Structural coding** (The module name should be **RCA4**. And the file you include should be **RCA4.v**)



- 7) Design a 8-bit unsigned ripple-carry adder in **hierarchical coding** using previously designed RCA4 module. (The module name should be **RCA8**. And the file should be **RCA8.v**)

| Signal   | IO     | Bits | Description              |
|----------|--------|------|--------------------------|
| a        | Input  | 8    | Addend                   |
| b        | Input  | 8    | Augend                   |
| sum      | Output | 8    | Result after calculating |
| overflow | Output | 1    | Overflow detection       |

- 8) Simulate your design with the following test pattern in sample testbench.
- 9) 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.
- 10) You only need to upload your v-code to moodle, do not paste your code here.

Your simulation result on the terminal.

```

*****
*          *   |__||_
* Congratulations !!    *   /_O.O_|_
*          *   /_____\|_
* Simulation PASS!!    *   /^\^\^\|w|
*          *   |^\^\^\|w|
*****\m__m_|_|

$finish called from file "testbench.v", line 90.
$finish at simulation time      257000
V C S   S i m u l a t i o n   R e p o r t
Time: 2570000 ps
CPU Time:      0.620 seconds;      Data structure size:  0.0Mb
Tue Mar  4 17:29:46 2025
CPU time: .477 seconds to compile + .575 seconds to elab + .417 seconds to link
+ .662 seconds in simulation
vlsicad6:/home/user1/vlsi25/vlsi25137/Lab2_Exxxxxxxx/Labinclass/RCA8 %

```

#### Your waveform :



#### Explanation of your waveform :

Input A = 11, B = ee, 相加得到 ff 且無 overflow ,

Input A = 11, B = ff, 相加產生 overflow, Sum 值為 10 。

#### ✧ 8\*8-bit unsigned multiplier

- 1) Design a half adder in **Structural coding** (The module name should be **HA**. And the file you include should be **HA.v**)
- 2) Design a full adder in **Structural coding** (The module name should be **FA**. And the file you include should be **FA.v**)
- 3) If you want to use **RCA8.v** from the first question to build an 8×8-bit multiplier, that is also possible. You can copy **RCA4.v** and **RCA8.v** from the first question into the folder and use them as a basis to write your program.
- 4) Design a 8\*8-bit unsigned multiplier in **Structural and hierarchical coding** (The module name should be **Multiplier**. And the file should be **Multiplier.v**)

| Signal | IO | Bits | Description |
|--------|----|------|-------------|
|--------|----|------|-------------|

|                |               |           |                                 |
|----------------|---------------|-----------|---------------------------------|
| <b>a</b>       | <b>Input</b>  | <b>8</b>  | <b>Multiplicand</b>             |
| <b>b</b>       | <b>Input</b>  | <b>8</b>  | <b>Multiplier</b>               |
| <b>product</b> | <b>Output</b> | <b>16</b> | <b>Result after calculating</b> |

- 5) Simulate your design with the following test pattern in sample testbench.
  - 6) Verify your design by comparing the simulation results with the results you predicted. If the results are not the same, please go back to 1) 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.
  - 7) You only need to upload your v-code to moodle, do not paste your code here.

## Your simulation result on the terminal.

```
The correct answer is A*B = 255 * 254 = 64770
Correct! Your answer is A*B = 255 * 254 = 64770
-----
The correct answer is A*B = 255 * 255 = 65025
Correct! Your answer is A*B = 255 * 255 = 65025
-----
*****          **      |__||_
**      | / 0.0 |
** Congratulations !!    **      | /_____|_
**      | / ^ ^ \ |
** Simulation PASS!!    **      | ^ ^ ^ ^ |w|
**      | \m__m_ |_
*****          |_||

$finish called from file "testbench.v", line 76.
$finish at simulation time      32769000
                                V C S   S i m u l a t i o n   R e p o r t
Time: 327690000 ps
CPU Time:      5.090 seconds;      Data structure size:   0.0Mb
Tue Mar  4 17:35:26 2025
CPU time: .511 seconds to compile + .593 seconds to elab + .419 seconds to link + 5.129 seconds in simulation
visicad6:/home/user1/vlsicad17/Lab2_Exxxxxxxx/Labinclass/Multiplier %
```

## Your waveform :



## **Explanation of your waveform :**

將數字換成 10 進位易觀察。

Input 1 為  $28 * 180 = 5040$  ,

**Input 2** 為  $28 * 181 = 5068$ ，與波形圖結果符合。

---

### Prob A: 8-bit unsigned ALU

---

- 1) An Arithmetic Logic Unit (ALU) is a digital circuit that performs arithmetic and logical operations as the fundamental processing unit of CPU.
- 2) Using the circuit design `RCA8.v` and `Multiplier.v` from lab-in-class to design a 8-bit unsigned ALU in **Structural coding** (The module name should be **ALU**. And the file you include should be **ALU.v**)
- 3) Using a select signal `sel` to determine whether the ALU should perform addition or multiplication. If `sel` is 1, the ALU performs addition; otherwise, if `sel` is 0, it performs multiplication.



| Signal | IO     | Bits | Description                              |
|--------|--------|------|------------------------------------------|
| src1   | Input  | 8    | Source 1                                 |
| src2   | Input  | 8    | Source 2                                 |
| sel    | Input  | 1    | 1'b1 : addition<br>1'b0 : multiplication |
| result | Output | 16   | ALU result                               |

- 4) Simulate your design with the following test pattern in sample testbench.
- 5) 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**.
- 6) 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**.

7) You only need to upload your v-code to moodle, do not paste your code here.

**Your simulation result on the terminal.**

# PASS

```
$finish called from file "tb_ALU.v", line 169.  
$finish at simulation time 111000  
VCS Simulation Report  
Time: 1110000 ps  
CPU Time: 0.640 seconds; Data structure size: 0.0Mb  
Tue Mar 4 17:37:33 2025  
CPU time: .602 seconds to compile + .620 seconds to elab + .410 seconds to link + .678 seconds in simulation  
vlsicad6:/home/usr1/vlsi25/vlsi25137/Lab2_Exxxxxxx/Homework %
```

## Your waveform :



### **Explanation of your waveform :**

第一個 input sel = 1, 因此做相加( $255+1 = 256$ ),直到第六個 input sel = 0, 因此做相乘( $128*2= 256$ )

## Superlint screenshot and coverage

Violation Messages View

Category CODINGSTYLE (1)

Tag: NS\_NP\_PEX (1)

"A constant is used in a port expression"

```

1  include "Multiplier.v"
2
3  module ALU (
4      input [15:0] src1 ;
5      input [15:0] src2 ;
6      input sel ;
7      output [15:0] result
8  );
9
10 //put your design here
11
12 wire [15:0] temp0, temp1;
13 ROR#(8) r1((src1), .b(src2), .sum(temp1[7:0]), .overflow(temp1[8]));
14 assign temp0[15:8] = r1;
15
16 Multiplier#(8) m1((src1), .B(src2), .product(temp0));
17
18 wire [15:0] temp1, temp2;
19
20
21 not(sel, 0, sel);
22 and(temp0[0], temp0[0], sel[0]);
23 and(temp0[1], temp0[1], sel[1]);
24 and(temp0[2], temp0[2], sel[2]);
25 and(temp0[3], temp0[3], sel[3]);
26 and(temp0[4], temp0[4], sel[4]);
27 and(temp0[5], temp0[5], sel[5]);
28 and(temp0[6], temp0[6], sel[6]);
29 and(temp0[7], temp0[7], sel[7]);
30 and(temp0[8], temp0[8], sel[8]);
31 and(temp0[9], temp0[9], sel[9]);
32 and(temp0[10], temp0[10], sel[10]);
33 and(temp0[11], temp0[11], sel[11]);
34 and(temp0[12], temp0[12], sel[12]);
35 and(temp0[13], temp0[13], sel[13]);
36 and(temp0[14], temp0[14], sel[14]);
37
38 endmodule

```

**Coverage : (280/281)\*100% = 99.6%**

---

### *Prob B: Find First One*

---

- 1) Design a Find First One circuit in **Structural coding** (The module name should be **FFO**. And the file you include should be **FFO.v**)
- 2) The function of FFO (First Find One) is to locate the **first occurrence of '1'** in a binary sequence, starting from the LSB. It outputs the position of the first '1' and indicates **whether the position is valid**. (An invalid position occurs when there are no '1's in the sequence.)



| Signal          | IO            | Bits     | Description                                       |
|-----------------|---------------|----------|---------------------------------------------------|
| <b>data</b>     | <b>Input</b>  | <b>8</b> | <b>Input sequence</b>                             |
| <b>position</b> | <b>Output</b> | <b>3</b> | <b>The position of the first occurrence of 1.</b> |
| <b>valid</b>    | <b>Output</b> | <b>1</b> | <b>The position is valid or not.</b>              |

- 3) Simulate your design with the following test pattern in sample testbench.
- 4) Verify your design by comparing the simulation results with the results you predicted. If the results are not the same, please go back to 1) 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**.
- 5) 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**.
- 6) 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 :**

我將 `data` 用 `binary` 的方式顯示，較容易看出 `position` 位置。第一個 `input` 是 0，因此 `valid = 0`，第二個 `input` 是 1，因此 `valid = 1` 且 `position = 1`。第三個 `input` 是 10，1 出現在 bit 1，所以 `position = 1, valid = 0`。

## Superlint screenshot and coverage

```

Violation Messages View
.... <No violation check extracted>
Analysis Browser
Module for FFO

1 module FFO(
2     input [7:0] data ,
3     output valid ,
4     output [2:0] position
5 );
6 //put your design here
7
8 wire pos0, pos1, pos2, pos3, pos4, pos5, pos6, pos7;
9 and(pos0, data[0], 1'bl);
10 and(pos1, data[1], ~data[0]);
11 and(pos2, data[2], ~data[0], ~data[1]);
12 and(pos3, data[3], ~data[0], ~data[1], ~data[2]);
13 and(pos4, data[4], ~data[0], ~data[1], ~data[2], ~data[3]);
14 and(pos5, data[5], ~data[0], ~data[1], ~data[2], ~data[3], ~data[4]);
15 and(pos6, data[6], ~data[0], ~data[1], ~data[2], ~data[3], ~data[4]);
16 and(pos7, data[7], ~data[0], ~data[1], ~data[2], ~data[3], ~data[4]);
17
18 or(valid, pos0, pos1, pos2, pos3, pos4, pos5, pos6, pos7);
19
20 or(position[0], pos1, pos3, pos5, pos7);
21 or(position[1], pos2, pos3, pos6, pos7);
22 or(position[2], pos4, pos5, pos6, pos7);
23
24
25 endmodule

```

Coverage : 100%

---

### Prob C: Merge Sort

---

- 1) Design a 4-bit\*6 merge sort circuit in **Structural coding** (The module name should be **MergeSort**. And the file you include should be **MergeSort.v**)

| Signal | I/O    | Bits | Description          |
|--------|--------|------|----------------------|
| in0    | Input  | 4    | Input data(unsigned) |
| in1    | Input  | 4    | Input data(unsigned) |
| in2    | Input  | 4    | Input data(unsigned) |
| in3    | Input  | 4    | Input data(unsigned) |
| in4    | Input  | 4    | Input data(unsigned) |
| in5    | Input  | 4    | Input data(unsigned) |
| out0   | Output | 4    | Output data(biggest) |
| out1   | Output | 4    | Output data          |
| out2   | Output | 4    | Output data          |

|             |               |          |                              |
|-------------|---------------|----------|------------------------------|
| <b>out3</b> | <b>Output</b> | <b>4</b> | <b>Output data</b>           |
| <b>out4</b> | <b>Output</b> | <b>4</b> | <b>Output data</b>           |
| <b>out5</b> | <b>Output</b> | <b>4</b> | <b>Output data(smallest)</b> |

- 2) Design a 1-bit comparator in gate level, and draw the 1-bit comparator in gate level. (The module name should be **Comp1**. And the file you include should be **Comp1.v**)

| Input |   | Output |     |     |
|-------|---|--------|-----|-----|
| a     | b | a<b    | a=b | a>b |
| 0     | 0 | 0      | 1   | 0   |
| 0     | 1 | 1      | 0   | 0   |
| 1     | 0 | 0      | 0   | 1   |
| 1     | 1 | 0      | 1   | 0   |

Draw your 1-bit comparator structure.



- 3) Design a 2-bit comparator using a 1-bit comparator. (The module name should be **Comp2**. And the file you include should be **Comp2.v**)
- 4) Design a 4-bit comparator using a 2-bit comparator. (The module name should be **Comp4**. And the file you include should be **Comp4.v**)

- 5) Design a 4-bit comparator unit using a 4-bit comparator, and draw the Find\_Large\_Small block in gate level. (The module name should be **CompUnit**. And the file you include should be **CompUnit.v**)



Draw your Find\_Large\_Small block in gate level.



a, b, LargeA, LargeAB, LargeB, SmallA, SmallB, SmallAB 皆為 8bit, 因此每個都需要 8 個邏輯閘，因空間關係沒有畫出來。

6) Design a **4-bit\*6 merge sort** using a 4-bit comparator.

7) Draw the block diagram of the merge sort.

Draw your merge sort block diagram.



- 8) You only need to upload your v-code to moodle, do not paste your code here.
- 9) 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**.
- 10) 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**.

## Your simulation result on the terminal.

## Your waveform :



### **Explanation of your waveform :**

第一個 input (0, 2, 3, 4, 6, 2) 時，output 為 (6, 4, 3, 2, 2, 0)，符合預期排序。

第二個 input (0, 2, 3, 4, 6, 3) 時，output 為 (6, 4, 3, 3, 2, 0)，符合預期排序。

## Superlint screenshot and coverage

**Violation Messages View**

Description (Order by Category)

Category: FILEFORMAT (2)  
 Tag: IDN\_NR\_VKYW (2)

\*Verilog reserved word 'Large' used as an identifier  
 \*Verilog reserved word 'Small' used as an identifier

```

3 module MergeSort(
4   input [3:0] in1,
5   input [3:0] in2,
6   input [3:0] in3,
7   input [3:0] in4,
8   input [3:0] in5,
9   input [3:0] in6,
10  output [3:0] out1,
11  output [3:0] out2,
12  output [3:0] out3,
13  output [3:0] out4,
14  output [3:0] out5,
15  output [3:0] out6
16 );
17 //put your design here
18 //left
19 wire [3:0] level1_left1, level1_left2, level1_left3, level2_left1,
20 CompUnit unit1(.a(in1), .b(in2), .Large(level1_left1), .Small(level1_left2),
21 CompUnit unit2(.a(level1_left1), .b(in3), .Large(level2_left1), .Small(level2_left2),
22 CompUnit unit3(.a(level1_left2), .b(level1_left3), .Large(level2_left2),
23
24 //right
25 wire [3:0] level1_right1, level1_right2, level1_right3, level2_right1,
26 CompUnit unit4(.a(in4), .b(in5), .Large(level1_right1), .Small(level1_right2),
27 CompUnit unit5(.a(level1_right1), .b(in6), .Large(level2_right1), .Small(level2_right2),
28 CompUnit unit6(.a(level1_right2), .b(level1_right3), .Large(level2_right2),
29
30 wire [3:0] L0, M0, M1, S0, F0, F1;

```

**Coverage : 100 %**

*Appendix A : Commands we will use to check your homework*

|                     | <b>Problem</b>    | <b>Commands</b>                                             |
|---------------------|-------------------|-------------------------------------------------------------|
| <b>Lab in class</b> | <b>RCA</b>        | % vcs -R testbench.v -debug_access+all -full64 +define+FSDB |
|                     | <b>Multiplier</b> | % vcs -R testbench.v -debug_access+all -full64 +define+FSDB |
| <b>Homework</b>     | <b>ProbA</b>      | % make probA                                                |
|                     | <b>ProbB</b>      | % make probB                                                |
|                     | <b>ProbC</b>      | % make probC                                                |