### EE434

# ASIC and Digital Systems

### Final Exam

# May 5, 2022. (1:30pm - 3:30pm)

# Instructor: Dae Hyun Kim

#### Name:

### WSU ID:

| Problem | Points |  |
|---------|--------|--|
| 1       | 80     |  |
| 2       | 80     |  |
| 3       | 50     |  |
| 4       | 50     |  |
| Total   | 260    |  |

### Problem #1 (Interconnect Optimization, 80 points)

The following figure shows a net optimized by a buffer.



#### Constants

- Output resistance of a cell: R
- Input capacitance of a cell: C
- Internal delay of a buffer: D
- Wire resistance and capacitance per length:  $r (\Omega/\text{um})$ , c (fF/um)
- Length of each subnet:  $L_1, L_2, L_3$  (um)

Independent variable

• Location of the buffer:  $x (0 < x < L_1)$ 

We want to optimize the delay from the driver to Sink 1 or Sink 2. "BP" is a branch point. Answer the following questions.

(1) Replace each segment (seg 1, 2, 3, 4) by a PI model. Then, express the delay from the source to <u>Sink 1</u> using the Elmore delay model. (10 points)

(2) Find the optimal location (x) of the buffer minimizing the delay from the source to Sink 1. (10 points)

(3) Answer the following questions for the problems (1)-(2) (Correct: +4 points, Wrong: -4 points, No answer: 0) for the minimization of the delay from the source to <u>Sink 1</u>.

- If  $L_1$  increases, x increases. (True / False)
- If  $L_2$  increases, x increases. (True / False)
- If  $L_3$  increases, x increases. (True / False)
- If *C* (the input capacitance of a cell) increases, *x* increases. (True / False)
- If *c* (the wire capacitance per length) increases, *x* increases. (True / False)



Now, we are moving the buffer to the branch connected to Sink 1 as follows:

(4) Replace each segment (seg 1, 2, 3, 4) by a PI model. Then, express the delay from the source to <u>Sink 1</u> using the Elmore delay model. (10 points)

(5) Find the optimal location (y) of the buffer minimizing the delay from the source to Sink 1. (10 points)

(6) Answer the following questions for the problems (4)-(5) (Correct: +5 points, Wrong: -5 points, No answer: 0) for the minimization of the delay from the source to <u>Sink 1</u>.

- If  $L_1$  increases, y increases. (True / False)
- If *L*<sub>2</sub> increases, *y* increases. (True / False)

(7) Replace each segment (seg 1, 2, 3, 4) by a PI model. Then, express the delay from the source to <u>Sink 2</u> using the Elmore delay model. (10 points)

#### Problem #2 (Interconnect Optimization, 80 points)

The following figure shows a net optimized by buffer insertion. The driver and the sink are denoted by  $K_D$  and  $K_S$ , respectively, and the inserted buffers are denoted by  $B_i$  ( $1 \le i \le n-1$ ).  $n \ge 2$ , i.e., there is at least one buffer between the driver and the sink.



- Output resistance of a cell ( $K_D$  and  $B_i$ ): R
- Input capacitance of a cell ( $K_s$  and  $B_i$ ): C
- Delay of a buffer: D
- Length of the *i*-th net  $(1 \le i \le n)$ :  $s_i$  (um)
- $\sum_{i=1}^{n} s_i = L$  (um)
- Unit wire resistance and capacitance: r ( $\Omega$ /um), c (fF/um)
- Use the PI model to model each segment.
- Use the following model to model a cell (the driver, the sink, and the buffers). (Notice that there is an output capacitor with capacitance *C<sub>V</sub>*.)



(1) Find the optimal locations of the buffers (i.e., express  $s_i$  as a function for the given parameters for each i = 1, 2, ..., n) minimizing the delay from the driver to the sink. (20 points)

(2) Then, find the optimal # buffers (n) minimizing the delay (express n as a function of the given parameters). (20 points)

(3) Answer the following questions for the problem (1) (Correct: +4 points, Wrong: -4 points, No answer: 0) for the minimization of the delay from the driver to the sink.

- If *L* increases, *n* increases. (True / False)
- If *r* increases, *n* increases. (True / False)
- If *c* increases, *n* increases. (True / False)
- If *R* increases, *n* increases. (True / False)
- If *C* increases, *n* increases. (True / False)
- If  $C_V$  increases, *n* increases. (True / False)
- If *D* increases, *n* increases. (True / False)
- If the output capacitance  $(C_V)$  of  $B_{n-1}$  increases,  $s_n$  increases. (True / False)
- If the output capacitance  $(C_V)$  of  $B_{n-1}$  increases,  $s_{n-1}$  increases. (True / False)
- If the output capacitance  $(C_V)$  of  $B_{n-1}$  increases,  $s_1$  increases. (True / False)

### Problem #3 (Interconnect Optimization, 50 points)

The following shows three nets connecting four gates ( $G_1$ ,  $G_2$ ,  $G_3$ ,  $G_4$ ). To reduce the delay, you insert buffers between  $G_1$  and  $G_2$ , between  $G_2$  and  $G_3$ , and between  $G_3$  and  $G_4$ . The total number of buffers you insert is k (constant). Thus, the total # of buffers you insert between  $G_1$  and  $G_2$  is a, the total # buffers you insert between  $G_2$  and  $G_3$  is b, and total # buffers you insert between  $G_3$  and  $G_4$  is k - a - b.



- All the gates and buffers are of the same type (they have the same output resistance, input capacitance, and internal delay). You can ignore the output capacitance of each gate.
- (1) Find *a* and *b* minimizing the delay from the driver to the sink. (30 points)

Answer:

$$a = \frac{(\ )L_1 - (\ )L_2 - (\ )L_3}{L_1 + L_2 + L_3}, \ b = \frac{(\ )L_1 - (\ )L_2 - (\ )L_3}{L_1 + L_2 + L_3}$$

(2) Answer the following questions for the problem (1) (Correct: +5 points, Wrong: -5 points, No answer: 0) for the minimization of the delay from the driver to the sink.

- If *k* increases, *a* increases. (True / False)
- If *k* increases, *b* increases. (True / False)
- If the input capacitance of the sink increases, *a* increases. (True / False)
- If the input capacitance of the sink increases, *b* increases. (True / False)

### Problem #4 (Interconnects, 50 points)



The figure shows a long wire whose length, unit resistance and capacitance are L, r, and c, respectively. We want to insert a buffer (0 < x < L). The size of the buffer is s and its output resistance, input capacitance, output capacitance, and internal delay are as follows:

- Output resistance:  $\frac{R}{s}$  (where *R* is a constant)
- Input capacitance: sP (where P is a constant)
- Output capacitance: sQ (where Q is a constant)
- Internal delay: *sD* (where *D* is a constant)

 $R_0$  is the output resistance of the driver and  $C_2$  is the input capacitance of the sink. Notice that there are two variables, *x* and *s*. You can model the buffer using the following model.



(1) Express the total delay as a function of the variables and the constants. (10 points)

(2) Find the optimal location of the buffer (you can treat *s* as a constant.) (10 points)

(3) Answer the following questions for the problem (1) (Correct: +5 points, Wrong: -5 points, No answer: 0) for the minimization of the delay from the driver to the sink. Assume that  $R_0 > \frac{R}{s}$  and  $C_2 > sP$ .

- If C<sub>2</sub> increases, x increases. (True / False)
- If *c* increases, *x* increases. (True / False)
- If *R* increases, *x* increases. (True / False)
- If *r* increases, *x* increases. (True / False)
- If  $R_0$  increases, x increases. (True / False)
- If *P* increases, *x* increases. (True / False)