

# HW4

Wednesday, October 12, 2022 4:50 PM



Homework 4

Name:

Collaborators:

# Homework 4

## 1. Reading and Review

- Continue referring back to Ch3, Ch4, and the Verilog Cheatsheet as needed
- Reread Ch1, 1.4.5, 1.4.6
- Chapter 5: 5.1 to 5.2.3
  - Section on Cary-Lookahead/Prefix Adders is optional

*These questions are to make sure you get enough from the reading. Show your work!*

### a) Review: Flip Flops

Sketch the waveforms for the following circuit under different types of set/reset. Note that for this flip flop set and reset are active low (action occurs when the voltage is zero).



iii) Assume reset is active high **and** synchronous. Sketch the waveforms for D and Q below.

## 2. Verilog Skillbuilding

### a) Verilog to Schematic



For each output, draw an equivalent gate level schematic \*and\* write a phrase or sentence



describing what that output does in terms of the inputs.

```
module mystery(a, b, c, out);
    input wire a, b, c;
    output logic out[3:0];
    always_comb begin
        out[0] = b ? a : c;
        out[1] = (~a & b) | (~b & a);
        out[2] = c | ( b & c);
    end
    logic d;
    always_comb d = b ? a : 1'b0;
    always_ff @(posedge c) begin
        out[3] <= d;
    end
endmodule
```

*flip flop*

*c is unk*

*Synchronous assignment*

$\text{out}[0]$ : if  $b$ , then  $\text{out}[0] = a$ . Else,  $\text{out}[0] = c$



$\text{out}[1]$ : not  $a$  and  $b$  or not  $b$  and  $a$



| A | B | y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

} XOR!

$\text{out}[2]$ :  $c$  or  $b$  and  $c$

$c$  —  $\text{out}[2]$

| c | b | $\text{out}[2]$ |
|---|---|-----------------|
| 0 | 0 | 0               |
| 0 | 1 | 0               |
| 1 | 0 | 1               |
| 1 | 1 | 1               |

} just c

$\text{out}[3]$ : if  $b$ ,  $d = a$ . If not  $b$ ,  $d = 1'b0$  (aka 0)



on rising edge c,  
assign  $\text{out}[3]$   
to  $d$

b) Schematic to Verilog *→ in practice.sv*

Create this module as part of your zipped submission. There's a testbench to go with it so you can see what it does (it's not an obviously useful circuit but it has some interesting use cases).



*instability before first rising edge!*

### 3. Combinational Design Challenge - ALU Part One

An arithmetic logic unit is a critical building block for a CPU. It does a variety of mathematical operations on two inputs (addition, subtraction, comparison, etc.). The next few problem sets will have us build up the different units inside it. For this phase we will focus on making a 32-bit adder and a 32:1 32-bit mux. The homework folder is a starting point, but you will need to create/edit the following:

- a mux32.sv file
- an add32.sv file (or an adder\_n.sv file that you can parametrize up to N=32).
- all submodule files that you used to make the above
- testbenches that give you confidence that you implemented them correctly
- a Makefile that runs your tests
- a README.md file with
  - A description of how you implemented the modules (you can include pictures or reference notes in your homework pdf)
  - A description of how you tested the mux32.
  - How to run your tests

You may use any of the basic gates for this task (and, or, xor, nor, nand, not, mux2), and are encouraged to build up any modules you want to reuse. This cannot have any sequential logic. See the examples directory in the git repository for how to approach this!

Bonus: there's enough code in the examples to make a ripple carry adder, but that's the slowest way to do this. Instead, implement a faster adder, like Carry Look Ahead!

*Leattempted*

#### Submission

Put a pdf copy of all of your written responses in the hws/4/ folder, then run make submission to generate a zip you can upload on canvas.

#### Metadata

How long did the reading take you? *~ 1.5 hrs*

How long did the homework take you?

*~ 4 hours  
(didn't do CLA adder)*