

Mark Ivey

mxi240020

Friday, November 15, 2024

Project 5

## Project 5: D Flip Flop

Times:

$T_{SU\_DD\_ONE}$  : -20ps (20 ps after clock edge)

$T_{SU\_OPT\_ONE}$  : 8ps (8 ps before clock edge)

$T_{HOLD\_ONE}$  : ~ 30ps

$T_{SU\_DD\_ZERO}$  : 39ps

$T_{SU\_OPT\_ZERO}$  : 45ps

$T_{HOLD\_ZERO}$  : 65ps

$T_{SU}$  : 45 ps

$T_{HOLD}$  : 65 ps

$T_D$  : 371ps (D low-to-high to Q)

$T_{CLK \rightarrow Q}$  : 326ps

DFF Dimensions: 7.54 μm (width) x 3.735 μm (height)

## DFF Layout



## Measurements and Contact Spacing



Figure 1: Abstract view

## Methodology and Thought Process of the Layout



Figure 2: Euler Trail and Odd Nodes

In the annotated schematic above, it shows the thought process behind how I came up with two diffusion breaks and what gates I chose to connect. In the actual layout, I placed the clock in the center of the two mux/nor structures. Doing this allowed me to minimize the size of the gate; having the clock on the left or right would increase the width by 760 nm, as the metal 1 traces of CLK and  $\overline{CLK}$  would have to go around the input or output.

To get the  $T_{SU\_OPT}$ ,  $T_{SU\_DD}$ ,  $T_{HOLD}$ ,  $T_D$  and  $T_{CLK \rightarrow Q}$ , I did the following:

- 1) First, for the case of D going high to low, I used hspice to get a rough estimate, to the nearest 100 ps, for  $T_{SU\_DD}$
- 2) Then, using a script, 100-200 points were tested via a script in 1 ps increments.
- 3) The results were graphed and  $T_{SU\_OPT}$ ,  $T_{SU\_DD}$  were determined.
- 4) Using  $T_{SU\_OPT}$ , I then calculated  $T_{HOLD}$
- 5) The process was repeated for D going low to high
- 6) For the final values of  $T_D$  and  $T_{CLK \rightarrow Q}$ , I used the best worst case from  $T_{SU\_OPT}$ , and  $T_{HOLD}$ .  
In my case, this turned out to be  $T_{SU\_OPT\_ZERO}$ .

$T_{SU\_DD\_ONE}$  : -20ps (20 ps after clock edge)

$T_{SU\_OPT\_ONE}$  : 8ps (8 ps before clock edge)

$T_{HOLD\_ONE}$  :~ 30ps

$T_{SU\_DD\_ZERO}$  : 39ps

$T_{SU\_OPT\_ZERO}$  : 45ps

$T_{HOLD\_ZERO}$  : 65ps

$T_{SU}$  : 45 ps

$T_{HOLD}$  : 65 ps

$T_D$  : 371ps (D low-to-high to Q)

$T_{CLK \rightarrow Q}$  : 326ps

These values were selected because the slew rate of Q from zero-to-one was lower than one-to-zero







Figure 3: CLK  $\rightarrow$  Q and delay of Rising and Falling Data