| University | of Washingto | n – Comput     | er Science | & Engin    | eering |
|------------|--------------|----------------|------------|------------|--------|
| Autumn 2   | 2016 Instr   | ructor: Justin | Hsia 2     | 2016-11-22 |        |
| CS         | <b>E</b> 3   | 69             | QU         | ĮZ         | 2      |
| Name: _    |              |                |            |            |        |
| UWNetID: _ |              |                |            |            |        |

# Please do not turn the page until 10:30.

### 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 20 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        | 8      |       |
| (2) FSM Implementation | 10     |       |
| (3) FSM Design         | 9      |       |
| Total:                 | 27     |       |

### Question 1: Sequential Logic & Timing [8 pts]

Consider the following circuit diagram with a clock period of 500 ps  $(10^{-12} \text{ s})$ , setup time of 80 ps, hold time of 50 ps, and clock-to-q delay of 100 ps. Fill in your answers in the boxes below.



(A) If the input In changes exactly on clock triggers, what are the limits on the XOR gate delay that ensure proper behavior? Write "n/a" if no such limit exists.
 Include units! [4 pts]

| $\mathrm{Max}\; t_{XOR} = \qquad \qquad \mathrm{Min}\; t_{XOR} =$ |  |
|-------------------------------------------------------------------|--|
|-------------------------------------------------------------------|--|

(B) We choose a gate with  $t_{XOR} = 100$  ps and complicate the input logic so that the input In changes  $t_{in}$  after each clock trigger. Within each clock cycle (between 0 and 500 ps) for what ranges of  $t_{in}$  will we get proper behavior? Answer using interval notation:  $[t_{start}, t_{end}]$ . [4 pts]



**Question 2:** Finite State Machine Implementation [10 pts]

(A) Fill in the provided truth table based on the FSM shown. [2 pts]



| $\mathbf{PS}_1$ | $\mathbf{PS}_{0}$ | In | $NS_1$ | $\mathbf{NS}_{0}$ | $\mathbf{Out}_1$ | $\mathbf{Out}_0$ |
|-----------------|-------------------|----|--------|-------------------|------------------|------------------|
| 0               | 0                 | 0  | 0      |                   |                  | 1                |
| 0               | 0                 | 1  | 0      |                   |                  | 1                |
| 0               | 1                 | 0  | 0      |                   |                  | 1                |
| 0               | 1                 | 1  | 1      |                   |                  | 0                |
| 1               | 0                 | 0  | 0      | 1                 | 0                | 1                |
| 1               | 0                 | 1  | 1      | 0                 | 0                | 0                |
| 1               | 1                 | 0  | Х      | Х                 | Х                | Х                |
| 1               | 1                 | 1  | Х      | Х                 | Х                | Х                |

(B) Complete the circuit diagram below using *minimal logic* based on the truth table shown below. You are welcome to use 2- and 3-input logic gates. [8 pts]

| $\mathbf{PS}_1$ | $\mathbf{PS}_{0}$ | In | $NS_1$ | $\mathbf{NS}_{0}$ | Out |
|-----------------|-------------------|----|--------|-------------------|-----|
| 0               | 0                 | 0  | 0      | 1                 | 0   |
| 0               | 0                 | 1  | 0      | 0                 | 0   |
| 0               | 1                 | 0  | 0      | 0                 | 0   |
| 0               | 1                 | 1  | 1      | 0                 | 1   |
| 1               | 0                 | 0  | 1      | 0                 | 1   |
| 1               | 0                 | 1  | 0      | 0                 | 0   |
| 1               | 1                 | 0  | Х      | Х                 | Х   |
| 1               | 1                 | 1  | Х      | Х                 | Х   |







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

Recall the 10¢ gumball-dispensing, no-change-giving vending machine FSM from lecture:



(A) Complete the testbench initial block to *thoroughly* test the FSM. Even though they may be unnecessary, please fill in all blanks. Don't worry about situations we don't expect to see during normal operation. [4 pts]

```
initial begin
                      N <= 0;
                                  D <= 0;
     @(posedge clk);
                      N <= 1;
                                       0;
                                  D <=
     @(posedge clk);
                      N <= 1;
                                  D <= 0;
     @(posedge clk);
                     N <= ___;
                                  D <= ___;
     @(posedge clk);
                     N <= ___;
                                  D <= ;
                     N <= ___; D <= ___;
     @(posedge clk);
     @(posedge clk);
                      N <= ____; D <= ____;
     @(posedge clk);
     $stop();
end
```

(B) Due to inflation, we decided to make the gumballs 25¢, how many states and state bits would we need? [2 pts]

| States: | State bits: |
|---------|-------------|
|---------|-------------|

(C) If we kept the cost of gumballs at 10¢ but got greedy and also accepted quarters (25¢), draw the new state diagram below. Use as few arrows as possible. [3 pts]