# Hardware Design

# Lab 1 Report

# Gate-Level Verilog

# Team 01

112062144 謝佳晉 112062144 范升維

# **Table of Contents:**

| Q1. 1X4_4BIT DMUX               | 1 |
|---------------------------------|---|
| А. 1x2_4віт DMUX                | 1 |
| В. 1x4_4віт DMUX                | 1 |
| Q2. 2X2_4BIT CROSSBAR SWITCH    | 2 |
| Q3. 4X4_4BIT CROSSBAR SWITCH    | 3 |
| Q4. TOGGLE FLIP-FLOP            | 4 |
| TESTBENCHES                     | 5 |
| A. 1x4_4BIT DMUX                | 5 |
| B. 2x2_4bit Crossbar Switch     | 5 |
| C. 4x4_4bit Crossbar Switch     | 6 |
| D. TOGGLE FLIP FLOP             | 7 |
| WHAT WE HAVE LEARNED FROM LAB1? | 7 |
| CONTRIBUTIONS                   | 8 |
|                                 |   |

# Q1. 1x4\_4bit DMUX

#### A. 1x2\_4bit DMUX



▲ Figure 1.1

- 1 input: *in[3:0]* 

- 1 control signal: sel

- 2 outputs: *a[3:0]*, *b[3:0]* 

First, we construct module 1x2 DMUX. This module can **route the input**, in[3:0], to either a or b **depending** on the **control signal**, sel. When sel is 0, the upper four AND gates have one of the input 1, so their outputs will be the same as input. Since, the lower four have one of the input 0, their outputs will all be 0. Vice versa.

### B. 1x4\_4bit DMUX



▲ Figure 1.2

- 1 input: *in[3:0]* 

- 1 control signal: sel[1:0]

4 outputs: *a[3:0]*, *b[3:0]*, *c[3:0]*, *d[3:0]* 

Now we have 1x2 DMUX, so we can construct module 1x4 DMUX by **combining three** 1x2 DMUX. We can use the left 1x2 DMUX with sel[1] as its control signal to preliminarily route the input to a/b or c/d. Next, we use the right two 1x2 DMUX with sel[0] as its control signal to route the input to a or b, and c or d. Therefore, we get one of a/b/c/d to be the same as input, and other three outputs be 4'b0000.

## Q2. 2x2\_4bit Crossbar Switch



▲ Figure 2

2 inputs: in1[3:0], in2[3:0]1 control signal: control

- 2 outputs: *out1[3:0]*, *out2[3:0]* 

We use two 1x2 DMUX and two 2x1 MUX to construct a 2x2 Crossbar Switch.

When *control* is 0,  $in1 \rightarrow con1 \rightarrow out1$ , and  $in2 \rightarrow con4 \rightarrow out2$ , like parallel.

When control is 1,  $in1 \rightarrow con2 \rightarrow out2$ , and  $in2 \rightarrow con3 \rightarrow out1$ , like cross.

## Q3. 4x4\_4bit Crossbar Switch



▲ Figure 3

- 4 inputs: in1/3:0], in2/3:0], in3/3:0], in4/3:0]
- 1 control signal: control[4:0]
- 4 outputs: out1[3:0], out2[3:0], out3[3:0], out4[3:0]

The 4x4 Crossbar Switch consists of five 2x2 Crossbar Switch. It acts like an enhanced version of 2x2 Crossbar Switch, but there has a limit. Some of the inputs are impossible to route to some specific outputs. The following are the routes that **cannot be implemented** by this 4x4 Crossbar Switch:

The above limits exist because **only one** of the in1/in2 **can be routed** to out3/out4, and at the same time, only one of the in3/in4 can be routed to out1/out2. To handle the problem, we can **add an additional 2x2 Crossbar** which takes con1 and con4 as input.

# Q4. Toggle Flip-Flop



XOR Gate

Con1

rst\_n

Con2

D Flip Flop

Clk

clk

▲ Figure 4.1: XOR Gate

▲ Figure 4.2: Toggle Flip-Flop

- 3 inputs: *clk*, *t*, *rst\_n* 

1 output: q

Given that we cannot utilize built-in XOR gate, Figure 4.1 shows how we construct the XOR gate ourselves. After we have the XOR gate and DFF, from Lab1 basic question 2, we can further get a Toggle Flip Flop as shown in Figure 4.2.

When  $rst_n$  is 0, and on the **positive edge**, q will be reset to 0.

When rst n is 1, and on the positive edge:

When *t* is **stably 1** at that time, *q* will be toggled into  $\sim q$ .

If t is 0 or t isn't **stable** at its **setup time** and **hold time**, q will not be changed.

#### **Testbenches**

#### A. 1x4\_4bit DMUX





We can test the module by adding up *sel's* value and inspect whether the outputs change correspondingly, with ever-changing input value to demonstrate its flexibility.

#### B. 2x2 4bit Crossbar Switch





We can test this module by repeatedly changing the value of control to see if the inputs are routed to the correct output ports. Similarly, we keep changing the input values to demonstrate its flexibility.

#### C. 4x4 4bit Crossbar Switch



We can test this module by changing control's value to see if the inputs have been routed to the correct output ports, just like 2x2\_4bit Crossbar Switch, along with changing input value to demonstrate its flexibility. **To find the impossible routes easily**, we can set input values to be a, b, c, d and use **\$monitor** command.

#### O Difference between \$display and \$monitor:

\$display: It's like printf in C. It output the message once the statement is executed.

**\$monitor**: Once being set, every time the signal changed, it will output the message.

#### D. Toggle Flip Flop

```
module Toggle_Flip_Flop_t;
    reg clk = 1'b0;
    reg rst_n = 1'b0;
    reg t = 1'b0;
    wire q;

Toggle_Flip_Flop TFF1(clk, q, t, rst_n);

initial begin
    repeat (185) #4 clk = ~clk;
    $finish;
end
    always #37 rst_n = ~rst_n;
    always #10 t = ~t;
endmodule
```



We can test this module by setting the proper staggered interval(4, 37, 10) so that we can simulate more cases that it may meet.

#### What we have learned from Lab1?

We began writing Verilog for the first time, as last semester's logic design course only involved "looking" at it, without hands-on writing experience. In this lab, we reviewed some previous concepts such as latches and flip-flops, and learned how to implement them using Verilog. We also discovered that using gate-level descriptions to write buses requires manually typing many lines of code. Additionally, we learned how to write testbenches and use Vivado simulation to verify if our modules were functioning correctly. Moreover, we used draw.io for the first time, which took some time to become familiar with in order to create neat, concise, and visually appealing circuit diagrams. Lastly, we spent considerable time learning how to create a more formal report with a table of contents. In conclusion, we learned a great deal of content through this lab experience.

#### **Contributions**

#### 謝佳晉:

wrote Q1~Q4 Verilog
wrote testbench Q1~Q4
performed Q1~Q4 simulation on Vivado
drew diagram Q3, Q4
constructed report foundation with images and descriptions
made FPGA demonstration

#### 范升維:

wrote Q1~Q4 Verilog
wrote testbench Q1~Q4
performed Q1~Q4 simulation on Vivado
drew diagram Q1, Q2
revised diagram Q3, Q4
organized, beautified report, added more descriptions and revised images
implemented FPGA demonstration