

## Unit-3

### Introduction

- In combinational circuits, the o/p is a function of present inputs.
- In sequential circuits, the o/p depends on previous as well as current inputs.
- FSM and Pipelines are two examples of sequential circuits
- Sequential circuits are designed with flipflops or latches, which are sometimes called memory elements that hold data called tokens.
- The purpose of elements is not really memory; instead it is to enforce sequence, to distinguish the current token from the previous or next token. Therefore, we will call them Sequencing elements. Without sequencing elements, the next token might catch up with the previous token, garbling both.
- This chapter considers sequencing both static & dynamic circuits.
- Static circuits refer to gates that have no clock i/p, such as Complementary CMOS, pseudo NMOS, or pass transistor logic.
- Dynamic circuits refer to gates that have a clock input especially domino logic.
- Sequencing elements can be either static or dynamic circuits.

- A sequencing element with static storage employs some sort of feedback to retain its o/p value indefinitely.
- An element with dynamic storage generally maintains its value as charge on a capacitor that will leak away if not refreshed for a long period of time.
- A periodic clock is commonly used to indicate the timing of a sequence.

### Sequencing Static Circuits

- Latches & flip flops are the two most commonly used sequencing elements. Both are 3 terminals: D, CLK, & Q.
- The latch is transparent when the clock is high & opaque when the clock is low; In other words, when clock is high, D flows through to Q as if the latch were just a buffer, but when the clock is low, the latch holds its present Q o/p even if D changes.
- The flop is an edge triggered device that copies D to Q on the rising edge of the clock & ignores D at all other times.





fig(1): Waveforms of latch & flop.

→ The three most widely used methods of sequencing static circuits are

- (a) flip-flops
- (b) 2-phase transparent latches
- (c) Pulsed latches.

### Sequencing Methods

- Fig(2) illustrates three methods of sequencing blocks of combinational logic. In each case, the clock waveforms, sequencing elements, & combinational logic are shown.



fig(2) Flipflops.



fig(2). 2-phase transparent latches.



fig(2) Pulsed Latches.

- In the above fig, the horizontal axis corresponds to the time at which a token reaches a point in the circuit. For ex, the token is captured in the first flip-flop on the first rising edge of the clock. It propagates through the combinational logic & reaches the second flip flop on the rising edge of the clock.
- The clock period is  $T_c$ .
- In a 2-phase system, the phases may be separated by  $t_{nonoverlap}$ .

- In a pulsed system, the pulse width is  $t_{pw}$ . 5

a) Flip-flop based system

This method uses one F/F on each cycle boundary. Tokens advance from one cycle to next on the rising edge. If a token arrives too early, it waits at the F/F until next clock cycle.

b) In 2-phase System

clock & its complement are represented as  $\phi_1$  and  $\phi_2$ . At any given time, at least one clock is low & the corresponding latch is opaque, preventing one token from catching up with another.

c) Pulsed Latch

In this, one of the latch is eliminated from each cycle. A brief pulse is applied to the remaining latch. If the pulse is shorter than the delay through the combinational logic, we can still expect that a token will only advance through one <sup>clk</sup> cycle on each pulse.

Delay & timing Constraints: Combinational logic & Sequencing elements.

1.  $t_{pd}$  - Logic propagation delay
2.  $t_{cd}$  - Logic contamination delay
3.  $t_{pcq}$  - Latch/flop clock-to-Q propagation delay
4.  $t_{ccq}$  - Latch/flop clock-to-Q Contamination delay
5.  $t_{pdq}$  - Latch D-to-Q propagation delay.
6.  $t_{cdq}$  - Latch D-to-Q Contamination delay

7.  $t_{\text{setup}}$  - Latch/flop setup time (6)

8.  $t_{\text{hold}}$  - Latch/flop hold time.

Fig.(3) illustrates these delays in a timing diagram.  
In a timing diagram, the horizontal axis indicates time & the vertical axis indicates logic level.



fig (3) Timing diagrams

$$\begin{aligned} ① - t_{cdq} \\ ② - t_{pdq} \end{aligned}$$

- In fig.(3), Criss-crossed line indicate that the signal might change at that time.
- A pair of lines with cross-hatching indicates that the signal may change once or more over an interval of time.
- fig 3(a) shows the response of Combinational logic to the input A changing from one arbitrary value to another. The o/p Y cannot change instantaneously. After the  $t_{cd}$ , Y may begin to change or glitch. After the  $t_{pd}$ , Y must have settled to a final value.
- The  $t_{cd}$  and  $t_{pd}$  may be very different because of multiple paths through the Combinational logic.
- fig. 3(b) shows the response of a flipflop. The data i/p must be stable for some window around the rising edge of the flop if it is to be reliably sampled.
- Specifically, the i/p D must have settled by some setup time  $t_{setup}$  before the rising edge of the clk & should not change again until a hold time  $t_{hold}$  after the clock edge.
- The o/p begins to change after a clock-to-Q contamination delay  $t_{cq}$  & completely settles after a clock-to-Q-propagation delay  $t_{pq}$ .

- Fig. 3(c) shows the response of a latch.

Now the i/p D must set up & hold around the falling edge that defines the end of the sampling period. The o/p initially changes  $t_{ccq}$  after the latch becomes transparent on the rising edge of the clock & settles by  $t_{pcq}$ . While the latch is transparent, the o/p will continue to track the i/p after some ~~time~~ D-to-Q delay  $t_{cdq}$  and  $t_{pdq}$ .

### Max-Delay Constraints



fig. 4. Flip-flop - max - delay constraint

- fig (4) shows the max - delay timing constraints on a path from one F/F to the next, assuming ideal clocks with no skew.

(9)

- The Path begins with the rising edge of the clock triggering F1. The data must propagate to the o/p of the F/F Q<sub>1</sub> and thro the Combinational logic to D<sub>2</sub>, setting up at F2 before the next rising-clk edge . This implies that the clock period must be atleast

$$T_c \geq t_{pcq} + t_{pd} + t_{setup} \quad \text{---(1)}$$

Alternatively, [rearranging (1)]

$$t_{pd} \leq T_c - \underbrace{(t_{setup} + t_{pcq})}_{\text{Sequencing overhead}} \quad \text{---(2)}$$

### 2-phase latch max-delay constraint



$$T_c \geq t_{pdq_1} + t_{pd_1} + t_{pd_2} + t_{pdq_2} \quad \textcircled{A}$$

Rearranging  $\textcircled{A}$ ,

$$t_{pd} = t_{pd_1} + t_{pd_2} \leq T_c - (2t_{pdq_2}) \quad \textcircled{B}$$

Sequencing overhead

### Pulsed latch max-delay constraint



fig. Pulsed Latch max-delay constraint.

$$T_c \geq \max(t_{pdq} + t_{pd}, t_{pcq} + t_{pd} + t_{setup} - t_{pw})$$

$$t_{pd} \leq T_c - \max(t_{pdq}, t_{pcq} + t_{setup} - t_{pw})$$

## Min-Delay constraints

(11)

Ideally, sequencing elements can be placed back-to-back without intervening combinational logic & still function correctly.

For ex, a pipeline can use back-to-back registers to sequence along an instruction opcode without modifying it. However, if the hold time is large & the contamination delay is ~~large~~ small, data can incorrectly propagate through two successive elements on one clock edge, corrupting the state of the system.

This is called a race condition, hold-time failure or min-delay failure. It can only be fixed by redesigning the logic, not by slowing the clock.



fig. F/F latch min-delay constraint.

$$t_{cd} \geq t_{hold} - t_{ccq}$$

(2) 2-phase Latch min-delay constraint



$$t_{cd1}, t_{cd2} \geq t_{hold} - t_{ccg} - t_{nonoverlap}$$

(3) Pulsed-latch min delay constraint



$$t_{cd} \geq t_{hold} - t_{ccg} + t_{pw}$$

## CMOS Latches



This shows a simple latch built from a single transistor. It is compact & fast but suffers 4 limitations.

(a) O/p does not swing from rail-to-rail; it never rises above  $V_{DD} - V_t$ .

(b) The o/p is dynamic; o/p floats when latch is opaque.

(c) If it floats long enough, it can be disturbed by leakage.

(d) 'D' drives the diffusion p/p of a pass transistor directly, leading to potential noise issues & making the delay harder to model with static timing analyzers.



This topology uses a TG. TG offers a rail-to-rail o/p swing. It requires an additional clk( $\bar{\phi}$ ) input.



(14)

In fig.(c) adds an o/p inverter so that the state node  $X$  is isolated from noise on the o/p. Of course, this creates an inverting latch.

(d)



fig(d) behaves as an inverting latch with a buffered i/p but unbuffered o/p. The inverter followed by a TG is essentially equivalent to a tristate inverter..

(e)



Referring fig.(e), when  $\text{clk}(\phi)=1$ , i/p TG is ON, the feedback Tristate is off, & the latch is transparent.

When  $\text{clk}(\phi)=0$ , i/p TG is OFF, however the f/b tristate turns ON, holding  $X$  at the correct level.



fig(f) adds an i/p inverter so the i/p is a transistor gate rather than unbuffered diffusion.  
(e) & (f) are o/p noise sensitive circuits.

(g)



(h)



fig(g) is a robust latch that addresses all of the deficiencies discussed so far. The latch is static & all nodes swing rail-to-rail, the state noise is isolated from o/p noise.

## CMOS Flipflops



→ Fig(a) shows a dynamic inverting F/F built from a pair of back-to-back dynamic latches. Either the first or the last inverter can be removed to reduce the delay at the expense of noise sensitivity on the unbuffered i/p or o/p.

→ Fig(b) adds f/b & another inverter to produce a non-inverting static flip flop. Most Std. cell libraries employ this design because it is simple, robust, compact, & energy-efficient.

→ F/F usually take a single clock ( $\phi$ ) & locally generate its complement ( $\bar{\phi}$ ).

D Latch using TG.



(a) when  $C=0$  ( $\bar{C}=1$ ),  $TG_1$  acts as open switch  
The circuit holds the values of  $Q$  &  $\bar{Q}$  at the o/p.

(b) when  $C=1$  ( $\bar{C}=0$ ),  $TG_1$  is 'ON', allowing the i/p bit 'D' to be transferred to the latching circuit.

During this time,  $X=D$

$$Q = D$$

$$\bar{Q} = \bar{D}$$

# Master-Slave D flip flop

(18)



fig. Master-Slave D- flip flop.



- $\phi \rightarrow$  Synchronization & controls the operation.
- $\phi = 0$  ( $\bar{\phi} = 1$ )  
 $M_1 \rightarrow$  ON (closed switch),  $M_2 \& M_3 \rightarrow$  Open circuits.  
Master Latch allows the  $s/p'D'$
- $\phi = 1$ ,  $M_2 \& M_3 \rightarrow$  closed switch  
transfer the bit to the slave.
- MS D F/F → +ve edge triggered DFF

## Clock distribution

- clock tree
- clock Mesh



fig. Clock tree



Clock Mesh

CT → Single path from Source to Sink.

CM → Mesh is a horizontal & vertical connections of wire segments.

For the sinks, clk can reach thru any of the paths.

In CT → there is a unique path from Source to Sink whereas in CM there is no unique path.

There are sub topologies in clock tree

→ Unconstrained tree

→ H-tree (Balanced tree)

## Clock generation & distribution

- Crystal oscillators are used to generate accurate, low-jitter clocks with a freq. range from 10's of MHz to 200 MHz.
- Crystal oscillator will have tank circuit which is responsible for oscillations.
- In order to generate higher frequencies ( $> 200\text{MHz}$ ) then Phase-locked loop is used.



fig. PLL

Phase detector  $\rightarrow$  2 i/p Ex-OR gate

LPF  $\rightarrow$  removes the noise

Provides Pulse to the VCO.

Quartz crystal are naturally available.

→ In unconstrained tree, there is no structural matching,

clk is taken from the source & the delays are balanced



fig. UnConstrained tree

Balanced tree (H-tree)



→ B.t is a tree with Structural Symmetry & exhibits identical delay, buffer & interconnect Segments from the root of the distribution to all branches.

- Length of the wire is same
- No. of buffers is also same.

### clock tree / Binary tree)

Binary tree is a tree intended to deliver the clock in a balanced manner in either the vertical or horizontal dimension.

This is different from a balanced tree which is designed to span the entire die in both the horizontal & vertical dimensions.

- Common structures of clock distribution networks including a trunk, tree, mesh and H-tree

