#### ELEX 2117 : Digital Techniques 2 2023 Fall Term

# Solutions to Midterm 1

*There were two versions of each question. The values and the answers for both versions are given below. Version 2 - reversed the first two transition conditions for the binary encoding version of Question 4. Version 3 - reversed the labelling of the two solutions for Question 1.* 

## **Question 1**

Fill the table below with the value of each expression as a Verilog numeric literal including the correct width and the correct value in hexadecimal base. Assume the following declarations:

logic [7:0] x ; logic [3:0] y ;

and that x has the value 8'h3b (or 8'hb3) and that y has the value 4'b0110. The first row has been filled in as an example.

| expression         | value             |
|--------------------|-------------------|
| x[3:0]             | 4'hb<br>(or 4'h3) |
| !x[4]   x[3]       |                   |
| { ~y, x[7:4] }     |                   |
| x << y[3:2]        |                   |
| x[7] ? 3'b1 : 4'd2 |                   |
| x + 1              |                   |

### Answers

For x=8 ' hb3:

| x[3:0]             | 4'h3     |
|--------------------|----------|
| !x[4] x[3]         | 1 ' h0   |
| { ~y, x[7:4] }     | 8'h9b    |
| x << y[3:2]        | 8'h66    |
| x[7] ? 3'b1 : 4'd2 | 4'h1     |
| x + 1              | 32 ' hb4 |

and for x=8 'h3b:

| x[3:0]             | 4 ' hb   |  |  |  |  |
|--------------------|----------|--|--|--|--|
| !x[4] x[3]         | 1 ' h1   |  |  |  |  |
| { ~y, x[7:4] }     | 8'h93    |  |  |  |  |
| x << y[3:2]        | 8'h76    |  |  |  |  |
| x[7] ? 3'b1 : 4'd2 | 4 ' h2   |  |  |  |  |
| x + 1              | 32 ' h3c |  |  |  |  |

### **Question 2**

Write a System Verilog module named pwm with three inputs (clock, enable, and w) and one output (out) that implements the schematic below. Follow the course coding conventions.



or



### Answers

The question makes more sense if **w** is an 8-bit value, but the schematic shows it as a single bit. Solutions that assume **w** is a 1-bit signal were also marked correct.

The two solutions below correspond to the two schematics.

#### endmodule

The schematics generated by Quartus are:



### **Question 3**

A state machine has **reset** and **clock** inputs, and a **pulse** output. Whenever **reset** is asserted, the output is set to **0**. When **reset** is de-asserted, **pulse** is set to **1** for three clock cycles and then it is set to **0** and it stays at **0** until **reset** is asserted again. Write the next-state truth table and the output truth table for this state machine. Use a one-hot (or binary) state encoding.

### Answers

The state transition diagrams for the one-hot and binary encodings are shown below:



A correct solution using only four states (one with an output of zero and three with an output of one) is not possible because there are two states where the output is 0: one state when reset is asserted and one state when reset is not asserted. The question requires that the output stay at 0 indefinitely in both of these states.

Many students gave a solution where the single-bit **pulse** output was used as the state. This is clearly not possible as the state machine needs to output a **1** for three clock cycles. In this respect the state machine is similar to the first state machine described in the lectures and the state machine in the next question.

No marks were awarded for solutions with an insufficient number of states since the state transition table and the output table are necessarily incorrect.

The simplified state transition and output truth tables corresponding to the state transition diagrams above are:

|       |       | novt   |       |        |  |  |
|-------|-------|--------|-------|--------|--|--|
| state | reset | пел    | state | output |  |  |
|       |       | state  | 00001 | 1      |  |  |
| VVVVV | 1     | 00001  | 00001 | 0      |  |  |
| ~~~~  | 1     | 00001  | 10000 | 0      |  |  |
| 10000 | x     | 10000  | 10000 | U      |  |  |
|       |       |        | XXXXX | 1      |  |  |
| n     | X     | n << 1 | L     | 1      |  |  |

and

| state | rocot | next         |       |        |
|-------|-------|--------------|-------|--------|
|       | Teset | state        | state | output |
| ххх   | 1     | 000          | x00   | 0      |
| 100   | х     | 100          | ххх   | 1      |
| n     | х     | <i>n</i> + 1 |       |        |

### **Question 4**

Write a System Verilog module named **esc** that implements the state machine described by the following state transition diagram. The module has four one-bit inputs: **clear**, **even**, **odd**, and **clock** (a clock). It has a one-bit output named **done**. You may use any name(s) for signal(s) internal to the module.

|                 | l1   | us 21 | is 3 | is 41 | is 51 | is 61 | is 71 | s 81 | is 91 | is 10 u | ls 11 | us 12 u | s 13 u | s 141 | ls 15 | us 16u | s 17. | is 18 us |
|-----------------|------|-------|------|-------|-------|-------|-------|------|-------|---------|-------|---------|--------|-------|-------|--------|-------|----------|
| clear=1         |      |       |      |       |       |       |       |      |       |         |       |         |        |       |       |        |       |          |
| clock=0         |      |       |      |       |       |       |       |      |       |         |       |         |        |       |       |        |       |          |
| done=x          |      |       |      |       |       |       |       |      |       |         |       |         |        |       |       |        |       |          |
| even=0          |      |       |      |       |       |       |       |      |       |         |       |         |        |       |       |        |       |          |
| odd=0           |      |       |      |       |       |       |       |      |       |         |       |         |        |       |       |        |       |          |
| state[3:0]=xxxx | хххх | 0001  |      |       |       |       |       |      |       | 0010    |       | 0100    |        |       |       | (1000  |       |          |
|                 |      |       |      |       |       |       |       |      |       |         |       |         |        |       |       |        |       |          |
| clear=1         |      |       | 1    |       |       |       |       |      |       |         |       |         |        |       |       |        |       |          |
| clock=0         |      |       |      |       |       |       |       |      |       |         |       |         |        |       |       |        |       |          |
| done=x          |      |       |      |       |       |       |       |      |       |         |       |         |        |       |       |        |       |          |
| even=0          |      |       |      |       |       |       |       |      |       |         |       |         |        |       |       |        |       |          |
| odd=0           |      |       |      |       |       |       |       |      | 1     |         |       |         |        |       |       |        |       |          |
| state[1:0]=xx   | хх   | 00    |      |       |       |       |       | 01   |       | (10     |       | 11      |        |       |       |        |       |          |

Figure 1: Simulation results for Question 4 solution.

Follow the course coding conventions.





endmodule

The simulation results for the two modules are shown in Figure 1.

or



# Answers