### EE434

# **ASIC and Digital Systems**

#### Midterm Exam

Mar. 6, 2024. (2:10pm - 3pm)

# Instructor: Dae Hyun Kim

#### Name:

### WSU ID:

| Problem   | Points |  |
|-----------|--------|--|
| 1         | 10     |  |
| 2         | 20     |  |
| 3         | 10     |  |
| 4         | 10     |  |
| 5         | 10     |  |
| 6         | 10     |  |
| 7 (Bonus) | 10     |  |
| Total     | 80     |  |

## Problem #1 (10 points)

Answer the following questions for a digital system that has multiple pipeline stages. Correct: +2 points. Wrong: -2 points. No answer: 0 points. Minimum: 0 points.

(Notice: Suppose a problem says, "If A happens, then B happens. (True / False)". In this case, if B can happen in some cases and cannot happen in some other cases, the answer is False. In other words, the answer is True only if B always happens when A happens.

For example, "If x > 0 and y > 10, then y > x." This is false because y < x can also happen (e.g., x=20, y=15).

On the other hand, "If  $x^*y > 0$  and y > 0, then x > 0." This is true because if y > 0, then dividing both sides of  $x^*y > 0$  by y leads to x > 0.

(1) Assume WNS < 0 and TNS < 0. If you reduce the delay of a net in the system, WNS goes up. (True / False)

(2) Assume WNS < 0 and TNS < 0. If you reduce the delay of a net in the system, TNS goes up. (True / False)

(3) Assume WNS = 0. If the delay of a gate goes up, then WNS goes down. (True / False)

(4) Suppose all the paths in the pipeline stages have setup time violations. If the delay of a gate goes down, then WNS goes up. (True / False)

(5) Suppose all the paths in the pipeline stages have setup time violations. If the delay of a gate goes down, then TNS goes up. (True / False)

## Problem #2 (20 points)

The following figure shows a pipeline stage. X is the input and Y is the output. Y has two output signals,  $Y_1$  and  $Y_2$ . The system spec is as follows:



- Data is fed into the system every cycle (captured by the FFs on the left).
  - Each data set "Data #" generates two outputs, "Output #" and "Output #".
    - Output # is generated by Logic 1 and Logic 2. This is captured by  $Y_1$ .
    - $\circ$  Output #' is generated by Logic 1 and Logic 3. This is captured by  $Y_2$ .
- $X Y_1$  is a single-cycle path as shown in the waveform above.
- $X Y_2$  is a multi-cycle path (two cycles) as shown in the waveform above.

Parameters:

- $L_{i-k}$ : the logic delay from input  $X_i$  to output  $Y_k$  (e.g.,  $L_{64-2}$  means the logic delay from input  $X_{64}$  to output  $Y_2$ )
- *s*: setup time of a flip-flop
- *h*: hold time of a flip-flop
- *x*: delay from the clock source to the clock pin of a flip-flop

- *c*: clk-to-Q delay of a flip-flop
- $T_{CLK}$ : clock period
- *MIN, MAX*: MIN, MAX operators

(1) Show all the setup time inequalities for the design (4 points). (Use the MIN, MAX operators.)

(2) Show all the hold time inequalities for the design (4 points). (Use the MIN, MAX operators.)

Answer the following questions for the figure above. Correct: +2 points, Wrong: -2 points, No answer: 0. Min: 0 points.

(3) Assume WNS < 0. In this case, if s goes up, WNS goes down. (True / False)

(4) Assume WNS < 0. In this case, if the delay of Logic 1 goes up, WNS goes down. (True / False)

(5) Assume WNS < 0. In this case, if the delay of Logic 3 goes up, WNS goes down. (True / False)

Answer the following questions for the figure above. Correct: +2 points, Wrong: -2 points, No answer: 0. Min: 0 points.

(6) Assume TNS < 0. In this case, if *s* goes up, TNS goes down. (True / False)

(7) Assume TNS < 0. In this case, if the delay of Logic 1 goes up, TNS goes down. (True / False)

(8) Assume TNS < 0. In this case, if the delay of Logic 2 goes up, TNS goes down. (True / False)

### Problem #3 (Static CMOS, 10 points)

Design the following function (draw a transistor-level schematic) using the static CMOS logic design methodology. Available input: A, B, C, D. Try to minimize the # TRs.

$$Y = A \cdot \left\{ \overline{B \oplus (C+D)} \right\}$$

10 points if # TRs  $\leq$  20. 7 points if 20 < # TRs  $\leq$  22. 5 points if # TRs > 22.

### Problem #4 (TR Sizing, 10 points)

 $R_n$  is the resistance of a 1X NFET (whose width is  $w_{min}$ ). " $h \times$ " for a TR means that the width of the TR is  $h \cdot w_{min}$ .

The following figure shows the NFET network of a static CMOS logic gate.



Notice that *L*, *M*, *N* are positive integer constants.

Timing constraint:  $\tau_f \leq R_n C$  ( $\tau_f$  is the worst-case fall delay).

Find the optimal sizes of the TRs that minimize the total transistor width. (Just saying "3X for all the TRs" will get 0 points. You should optimize the total width.)

# Problem #5 (Analysis, 10 points)

Express the output *Y* as a Boolean function of the input signals (A, B, C, D, E, F, G, H).



## Problem #6 (STA, 10 points)

For the setup-time analysis, we use the slack = required time – arrival time. We can define a similar metric for the hold-time analysis as follows:

slack (for hold time) = arrival time – required time.

Notice that a hold-time violation occurs when the delay (arrival time) of a signal is too small. Thus, if we use the definition above, a positive slack means no hold-time violation and a negative slack means a hold-time violation. We can define WNS and TNS in the same way.

Answer the following questions for the <u>hold-time analysis of a pipeline stage (between</u> <u>two flip-flop stages)</u>. Correct: +2 points. Wrong: -2 points. No answer: 0 points. Minimum: 0 points.

(1) Assume WNS < 0 and TNS < 0. If you increase the delay of a net in the critical path, WNS goes up. (True / False)

(2) Assume WNS < 0 and TNS < 0. If you increase the delay of a gate in the critical path, TNS goes up. (True / False)

(3) Assume WNS < 0. In this case, can "WNS = TNS" happen? (i.e., can WNS be equal to TNS?) (Yes / No)

(4) Assume TNS < 0. In this case, can "TNS < WNS" happen? (Yes / No)

(5) Suppose  $T_{CLK} > 2 \cdot (T_S + T_H)$  where  $T_{CLK}$  is the clock period,  $T_S$  is the setup time of a FF, and  $T_H$  is the hold time of a FF. In this case, can a path have both setup-time and hold-time violations? (Yes / No)

#### Problem #7 (TR Sizing, 10 points, Bonus)

 $R_n$  is the resistance of a 1X NFET (whose width is  $w_{min}$ ). " $h \times$ " for a TR means that the width of the TR is  $h \cdot w_{min}$ .

The following figure shows the NFET network of a static CMOS logic gate Y =

 $(x_{1,1} + \dots + x_{1,n_1}) \cdot (x_{2,1} + \dots + x_{2,n_2}) \cdot \dots \cdot (x_{p,1} + \dots + x_{p,n_p}).$ 



Notice that  $p, n_1, n_2, ..., n_p$  are all positive integer constants. For example,  $p = 3, n_1 = L, n_2 = M, n_3 = N$  for Problem #4. This problem is a generalization of Problem #4.

Timing constraint:  $\tau_f \leq R_n C$  ( $\tau_f$  is the worst-case fall delay).

Find the optimal sizes of the TRs that minimize the total transistor width. (Just saying " $n_p \times$  for all the TRs" will get 0 points. You should optimize the total width.)