# University of Washington - Computer Science \& Engineering <br> Spring 2024 Instructor: Justin Hsia 2024-05-14 <br> CSE 369 QUIZ 2 <br>  <br> Student ID <br> Number: _1234567 <br> <br> Please do not turn the page until 2:20. 

 <br> <br> Please do not turn the page until 2:20.}

## Instructions

- This quiz contains 4 pages, including this cover page. You may use the backs of the pages for scratch work.
- Please clearly indicate (box, circle) your final answer.
- The quiz is closed book and closed notes.
- Please silence and put away all cell phones and other mobile or noise-making devices.
- Remove all hats, headphones, and watches.
- You have $30(+5)$ minutes to complete this quiz.


## Advice

- Read questions carefully before starting. Read all questions first and start where you feel the most confident to maximize the use of your time.
- There may be partial credit for incomplete answers; please show your work.
- Relax. You are here to learn.

| Question | Points | Score |
| :--- | :---: | :---: |
| (1) SL \& Timing | 6 | 6 |
| (2) FSM Implementation | 10 | 10 |
| (3) FSM Design | 11 | 11 |
| $r$ Total: | $\mathbf{2 7}$ | $\mathbf{2 7}$ |

## Question 1: Sequential Logic \& Timing [6 pts]

Consider the following circuit diagram with $t_{\text {setup }}=11 \mathrm{~ns}, t_{C 2 Q}=9 \mathrm{~ns}, t_{N O T}=3 \mathrm{~ns}, t_{O R}=8 \mathrm{~ns}$, and $t_{X O R}=10 \mathrm{~ns}$. Assume that In changes $\mathbf{7} \mathbf{n s}$ after every clock trigger.

(A) Calculate the minimum clock period that will allow the circuit to function correctly. [3 pts]

The critical path is shown above in red.
We need $t_{\mathrm{C} 2 \mathrm{Q}}+t_{\mathrm{XOR}}+t_{\mathrm{OR}} \leq t_{\text {period }}-t_{\text {setup }}$.
Then $t_{\text {period }} \geq 9+10+8+11=38 \mathrm{~ns}$.
(B) Calculate the maximum hold time $\left(t_{\text {hold }}\right)$ that will allow the circuit to function correctly. [3 pts]

The shortest path to a register input is shown above in blue.
We need $t_{\text {In }}+t_{\text {XoR }} \geq t_{\text {hold }}$.
Then $t_{\text {hold }} \leq 7+10=17 \mathrm{~ns}$.

Question 2: Finite State Machine Implementation [10 pts]
(A) Fill in the provided truth table based on the FSM shown. [2 pts]


| $\mathrm{PS}_{\mathbf{1}}$ | $\mathrm{PS}_{\mathbf{0}}$ | In | $\mathrm{NS}_{\mathbf{1}}$ | $\mathrm{NS}_{\mathbf{0}}$ | Out $_{\mathbf{1}}$ | Out $_{\mathbf{0}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | X | X | X | X |
| 0 | 0 | 1 | X | X | X | X |
| 0 | 1 | 0 | 1 | 0 | 0 | 1 |
| 0 | 1 | 1 | 1 | 1 | 0 | 1 |
| 1 | 0 | 0 | 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 1 | 1 | 1 | 0 |
| 1 | 1 | 0 | 1 | 0 | 1 | 1 |
| 1 | 1 | 1 | 0 | 1 | 1 | 1 |

(B) Complete the circuit diagram below using minimal logic based on the truth table shown below. Use only 2 -input logic gates. [8 pts]

| PS | In $_{1}$ | In | NS | Out |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 0 | 1 |
| 0 | 1 | 0 | X | X |
| 0 | 1 | 1 | 0 | 0 |
| 1 | 0 | 0 | X | X |
| 1 | 0 | 1 | 1 | 0 |
| 1 | 1 | 0 | 1 | 0 |
| 1 | 1 | 1 | 0 | 0 |

Wire connection: $\downarrow$

Wire crossing:


## Question 3: Finite State Machine Design [11 pts]

The following FSM represents a DNA construct known as a promoter, whose output level of $m$ is determined inversely to the number of repressors ( $r$ ) bound to its two binding sites (op1 and op2). The value of the one-bit input In represents a repressor binding (1) or a repressor unbinding (0).

$\overline{\mathrm{op} 1} \overline{\mathrm{op}} 2$

(A) How many total rows are in the truth table for this FSM? How many of the rows are filled with Don't Cares? [2 pts]
2 state +1 input bits $\rightarrow 2^{3}=8$ rows in TT.
One missing state (11) with 2 transitions.
Rows: 8 Don't Care Rows: 2
(B) Complete the test bench initial block to thoroughlytest the FSM by filling in all bolded blanks. You may fill out the comments to track the state, but these won't be graded. Don't worry about situations we don't expect to see during normal operation. [5 pts]

```
initial begin
```



```
    @(posedge clk); In <= 0; // state: 01__
    @(posedge clk); In <= 1; // state: 00__
    @(posedge clk); In <= 1___; // state: 01__
    @(posedge clk); In <= 1; // state: 10___
    @(posedge clk); In <= 0___; // state: 10___
    @(posedge clk); // state: 01__
    $stop();
end
```

(C) Is there any way that the hardware implementation could output 10? Briefly explain. [2 pts]

Yes, if the system ends up in state 11 (e.g., before a reset) and the output don't cares resolved to 10 for one or both input options.
(D) Consider the limitations of FSMs in representing certain systems. Name one unrealistic behavior (compared to a real promoter) that is implied by the operation of this FSM. [2 pts]

## Examples of accepted responses:

- That a repressor binds or unbinds at every clock cycle.
- That only one repressor can bind at a time (i.e., no transition from 00 to 10 ).
- The input meaning "breaks" at the edges (e.g., "binding" from Two stays at Two).
- For 1 repressor bound, no indication of which site it is bound to.

