### **Shimon Even**

June 15, 1935 - May 1, 2004



## Chapter 11: Flip-Flops

Computer Structure

Intro. to Digital Computers

© Dr. Guy Even

Tel-Aviv Univ.

■ introduce clock signal.

- introduce clock signal.
- define edge-triggered flip-flops.

- introduce clock signal.
- define edge-triggered flip-flops.
- discuss parameters of flip-flops: setup time, hold time, contamination delay, propagation delay.

- introduce clock signal.
- define edge-triggered flip-flops.
- discuss parameters of flip-flops: setup time, hold time, contamination delay, propagation delay.
- explain importance of critical segment.

- introduce clock signal.
- define edge-triggered flip-flops.
- discuss parameters of flip-flops: setup time, hold time, contamination delay, propagation delay.
- explain importance of critical segment.
- understand timing of a flip-flop.

- introduce clock signal.
- define edge-triggered flip-flops.
- discuss parameters of flip-flops: setup time, hold time, contamination delay, propagation delay.
- explain importance of critical segment.
- understand timing of a flip-flop.
- other memory devices.





digital signal with periodic oscillations between 0 and 1.



- digital signal with periodic oscillations between 0 and 1.
- oscillations are instantaneous.



- digital signal with periodic oscillations between 0 and 1.
- oscillations are instantaneous.
- **each** clock period starts with a  $0 \rightarrow 1$  transition.



- digital signal with periodic oscillations between 0 and 1.
- oscillations are instantaneous.
- **each** clock period starts with a  $0 \rightarrow 1$  transition.
- $\blacksquare 1 \rightarrow 0$  transition in the interior of the clock period.



- digital signal with periodic oscillations between 0 and 1.
- oscillations are instantaneous.
- each clock period starts with a  $0 \rightarrow 1$  transition.
- $\blacksquare 1 \rightarrow 0$  transition in the interior of the clock period.
- we denote the clock signal by CLK.

















- clock period denoted by  $\varphi(\mathsf{CLK})$ .
- clock pulse interval during which clk(t) = 1.











- ightharpoonup clock period denoted by  $\varphi(\text{CLK})$ .
- clock pulse interval during which clk(t) = 1.
- ightharpoonup duration of clock pulse.







- clock period denoted by  $\varphi(\mathsf{CLK})$ .
- clock pulse interval during which clk(t) = 1.
- $\blacksquare$  CLK $_{pw}$  duration of clock pulse.
- **symmetric clock** if  $\mathrm{CLK}_{pw} = \varphi(\mathrm{CLK})/2$ .







- clock period denoted by  $\varphi(\mathsf{CLK})$ .
- clock pulse interval during which clk(t) = 1.
- $\blacksquare$  CLK $_{pw}$  duration of clock pulse.
- symmetric clock if  $\operatorname{clk}_{pw} = \varphi(\operatorname{clk})/2$ .
- narrow pulses if  $clk_{pw} < \varphi(clk)/2$ .







- clock period denoted by  $\varphi(\mathsf{CLK})$ .
- clock pulse interval during which clk(t) = 1.
- $\blacksquare$  CLK $_{pw}$  duration of clock pulse.
- symmetric clock if  $\operatorname{clk}_{pw} = \varphi(\operatorname{clk})/2$ .
- narrow pulses if  $\mathrm{CLK}_{pw} < \varphi(\mathrm{CLK})/2$ .
- wide pulses if  ${\rm CLK}_{pw}> \varphi({\rm CLK})/2$ .

A clock partitions time into discrete intervals as follows:

A clock partitions time into discrete intervals as follows:

Let  $t_i$  denote the starting time of the *i*th clock period.

A clock partitions time into discrete intervals as follows:

- Let  $t_i$  denote the starting time of the ith clock period.
- We refer to the half-closed interval  $[t_i, t_{i+1})$  as clock cycle i.

■ Setup-time denoted by  $t_{su}$ ,

- Setup-time denoted by  $t_{su}$ ,
- Hold-time denoted by  $t_{hold}$ ,

- Setup-time denoted by  $t_{su}$ ,
- Hold-time denoted by  $t_{hold}$ ,
- $\blacksquare$  Contamination-delay denoted by  $t_{cont}$ ,

- Setup-time denoted by  $t_{su}$ ,
- Hold-time denoted by  $t_{hold}$ ,
- $\blacksquare$  Contamination-delay denoted by  $t_{cont}$ ,
- Propagation-delay denoted by  $t_{pd}$ .

- Setup-time denoted by  $t_{su}$ ,
- Hold-time denoted by  $t_{hold}$ ,
- $\blacksquare$  Contamination-delay denoted by  $t_{cont}$ ,
- Propagation-delay denoted by  $t_{pd}$ .

These parameters satisfy  $-t_{su} < t_{hold} < t_{cont} < t_{pd}$ .

- Setup-time denoted by  $t_{su}$ ,
- Hold-time denoted by  $t_{hold}$ ,
- $\blacksquare$  Contamination-delay denoted by  $t_{cont}$ ,
- Propagation-delay denoted by  $t_{pd}$ .

These parameters satisfy  $-t_{su} < t_{hold} < t_{cont} < t_{pd}$ . Notation:

- $\blacksquare$  critical segment:  $C_i = [t_i t_{su}, t_i + t_{hold}]$ .
- instability segment:  $A_i = [t_i + t_{cont}, t_i + t_{pd}]$ .

- Setup-time denoted by  $t_{su}$ ,
- Hold-time denoted by  $t_{hold}$ ,
- $\blacksquare$  Contamination-delay denoted by  $t_{cont}$ ,
- Propagation-delay denoted by  $t_{pd}$ .

These parameters satisfy  $-t_{su} < t_{hold} < t_{cont} < t_{pd}$ . Notation:

- $\blacksquare$  critical segment:  $C_i = [t_i t_{su}, t_i + t_{hold}]$ .
- instability segment:  $A_i = [t_i + t_{cont}, t_i + t_{pd}]$ .



# Definition: Edge-triggered Flip-Flop

## Definition: Edge-triggered Flip-Flop

Inputs: A digital signal D(t) and a clock CLK.

### Definition: Edge-triggered Flip-Flop

Inputs: A digital signal D(t) and a clock CLK.

Output: A digital signal Q(t).

# Definition: Edge-triggered Flip-Flop

Inputs: A digital signal D(t) and a clock CLK.

Output: A digital signal Q(t).

Functionality: If D(t) is stable during the critical segment  $C_i$ , then  $Q(t) = D(t_i)$  during the interval  $(t_i + t_{pd}, t_{i+1} + t_{cont})$ .

# Definition: Edge-triggered Flip-Flop

Inputs: A digital signal D(t) and a clock CLK.

Output: A digital signal Q(t).

Functionality: If D(t) is stable during the critical segment  $C_i$ , then  $Q(t) = D(t_i)$  during the interval  $(t_i + t_{pd}, t_{i+1} + t_{cont})$ .







$$lacksquare$$
  $-t_{ extsf{su}} < t_{ extsf{hold}} < t_{ extsf{cont}} < t_{ extsf{pd}} \implies C_i \cap A_i = \emptyset$  .



- lacksquare  $-t_{ extsf{su}} < t_{ extsf{hold}} < t_{ extsf{cont}} < t_{ extsf{pd}} \implies C_i \cap A_i = \emptyset$  .
- Stability of D(t) during  $C_i \Rightarrow$  digital value of D(t) during the critical segment  $C_i$  is logical and equals  $D(t_i)$ .



- lacksquare  $-t_{ extsf{su}} < t_{ extsf{hold}} < t_{ extsf{cont}} < t_{ extsf{pd}} \implies C_i \cap A_i = \emptyset$  .
- Stability of D(t) during  $C_i \Rightarrow$  digital value of D(t) during the critical segment  $C_i$  is logical and equals  $D(t_i)$ .
- Flip-flop samples D(t) during  $C_i$ . The sampled value  $D(t_i)$  is output during the interval  $[t_i + t_{pd}, t_{i+1} + t_{cont}]$ .



- lacksquare  $-t_{ extsf{su}} < t_{ extsf{hold}} < t_{ extsf{cont}} < t_{ extsf{pd}} \implies C_i \cap A_i = \emptyset$  .
- Stability of D(t) during  $C_i \Rightarrow$  digital value of D(t) during the critical segment  $C_i$  is logical and equals  $D(t_i)$ .
- Flip-flop samples D(t) during  $C_i$ . The sampled value  $D(t_i)$  is output during the interval  $[t_i + t_{pd}, t_{i+1} + t_{cont}]$ .
- Sampling is successful only if D(t) is stable while it is sampled. This is why we refer to  $C_i$  as a critical segment.

### Remarks on definition of flip-flop - cont.



#### Remarks on definition of flip-flop - cont.



If the input D(t) is stable during the critical segments  $\{C_i\}_i$ , then the output Q(t) is stable in between the instability segments  $\{A_i\}_i$ .

#### Remarks on definition of flip-flop - cont.



- If the input D(t) is stable during the critical segments  $\{C_i\}_i$ , then the output Q(t) is stable in between the instability segments  $\{A_i\}_i$ .
- The stability of the input D(t) during the critical segments depends on the clock period. We will later see that slowing down the clock (i.e. increasing the clock period) helps in achieving a stable D(t) during the critical segments.





clock port is marked by an "arrow".



- clock port is marked by an "arrow".
- we abbreviate and refer to an edge-triggered flip-flop simply as a flip-flop.



- clock port is marked by an "arrow".
- we abbreviate and refer to an edge-triggered flip-flop simply as a flip-flop.

Question: Prove that an edge-triggered flip-flop is not a combinational circuit.

### **Arbitration**

Arbitration is the problem of deciding which event occurs first.



### **Arbitration**

Arbitration is the problem of deciding which event occurs first.



Focus on the task of determining which of two signals reaches 1 first.

$$A_0(t)$$
  $A_0(t)$   $A_1(t)$   $A_1(t)$   $A_1(t)$  reaches 1 first  $A_1(t)$  reaches 1 first

### **Definition:** arbiter

Inputs: Non-decreasing analog signals  $A_0(t), A_1(t)$  defined for every  $t \ge 0$ .

Output: An analog signal Z(t).

Functionality: Assume that  $A_0(0) = A_1(0) = 0$ . Define  $T_i$ , for i = 0, 1, as follows:

$$T_i \stackrel{\triangle}{=} \inf\{t \mid \operatorname{dig}(A_i(t)) = 1\}.$$

Let  $t' \triangleq 10 + \max\{T_0, T_1\}$ . The output Z(t) must satisfy, for every  $t \geq t'$ ,

$$extit{dig}(Z(t)) = egin{cases} 0 & ext{if } T_0 < T_1 - 1 \ 1 & ext{if } T_1 < T_0 - 1 \ 0 & ext{or } 1 & ext{otherwise.} \end{cases}$$

$$T_i \stackrel{\triangle}{=} \inf\{t \mid \operatorname{dig}(A_i(t)) = 1\}.$$

If  $T_0$  or  $T_1$  equals infinity, then  $t' = \infty$ , and there is no requirement on the output Z(t).

$$T_i \stackrel{\triangle}{=} \inf\{t \mid \operatorname{dig}(A_i(t)) = 1\}.$$

If  $T_0$  or  $T_1$  equals infinity, then  $t' = \infty$ , and there is no requirement on the output Z(t).

Arbiter circuit is given 10 time units starting from  $\max\{T_0, T_1\}$  to determine if  $T_0 < T_1$  or  $T_1 < T_0$ .

$$T_i \stackrel{\triangle}{=} \inf\{t \mid \operatorname{dig}(A_i(t)) = 1\}.$$

If  $T_0$  or  $T_1$  equals infinity, then  $t' = \infty$ , and there is no requirement on the output Z(t).

- Arbiter circuit is given 10 time units starting from  $\max\{T_0, T_1\}$  to determine if  $T_0 < T_1$  or  $T_1 < T_0$ .
- tie: the case that  $|T_0 T_1| \leq 1$ .

$$T_i \stackrel{\triangle}{=} \inf\{t \mid \operatorname{dig}(A_i(t)) = 1\}.$$

If  $T_0$  or  $T_1$  equals infinity, then  $t' = \infty$ , and there is no requirement on the output Z(t).

- Arbiter circuit is given 10 time units starting from  $\max\{T_0, T_1\}$  to determine if  $T_0 < T_1$  or  $T_1 < T_0$ .
- tie: the case that  $|T_0 T_1| \le 1$ .
- In the case of a tie, the arbiter is free to decide, but must decide. Z(t) is stable in the interval  $[t, \infty)$ .

Claim: There does not exist a circuit *C* that implements an arbiter.

Claim: There does not exist a circuit C that implements an arbiter.

Inherent limitation - not just a weakness of the digital abstraction.

Claim: There does not exist a circuit C that implements an arbiter.

- Inherent limitation not just a weakness of the digital abstraction.
- Use the claim to show that flip-flops must have critical segments.

■ Define  $A_0(t)$  so that  $T_0 = 100$  as follows:

$$A_0(t) riangleq egin{cases} rac{t}{100} \cdot V_{m{high,in}} & ext{if } t \in [0,100] \ V_{m{high,in}} & ext{if } t > 100. \end{cases}$$

■ Define  $A_0(t)$  so that  $T_0 = 100$  as follows:

$$A_0(t) riangleq egin{cases} rac{t}{100} \cdot V_{\mbox{\it high,in}} & ext{if } t \in [0, 100] \ V_{\mbox{\it high,in}} & ext{if } t > 100. \end{cases}$$

Fix a parameter  $x \in [-2, 2]$  and define  $A_1(t)$  so that  $T_1 = 100 + x$  as follows:

$$A_1(t) riangleq egin{cases} rac{t}{100+x} \cdot V_{\mbox{\it high,in}} & ext{if } t \in [0,100+x] \ V_{\mbox{\it high,in}} & ext{if } t > 100+x. \end{cases}$$

■ Define  $A_0(t)$  so that  $T_0 = 100$  as follows:

$$A_0(t) riangleq egin{cases} rac{t}{100} \cdot V_{\mbox{\it high,in}} & \mbox{if } t \in [0, 100] \\ V_{\mbox{\it high,in}} & \mbox{if } t > 100. \end{cases}$$

Fix a parameter  $x \in [-2, 2]$  and define  $A_1(t)$  so that  $T_1 = 100 + x$  as follows:

$$A_1(t) riangleq egin{cases} rac{t}{100+x} \cdot V_{\mbox{\it high,in}} & ext{if } t \in [0,100+x] \ V_{\mbox{\it high,in}} & ext{if } t > 100+x. \end{cases}$$

■ Define the function f(x) by  $f(x) \triangleq Z(200)$ .

■ Define  $A_0(t)$  so that  $T_0 = 100$  as follows:

$$A_0(t) riangleq egin{cases} rac{t}{100} \cdot V_{\mbox{\it high,in}} & \mbox{if } t \in [0, 100] \\ V_{\mbox{\it high,in}} & \mbox{if } t > 100. \end{cases}$$

Fix a parameter  $x \in [-2, 2]$  and define  $A_1(t)$  so that  $T_1 = 100 + x$  as follows:

$$A_1(t) riangleq egin{cases} rac{t}{100+x} \cdot V_{\mbox{\it high,in}} & ext{if } t \in [0,100+x] \ V_{\mbox{\it high,in}} & ext{if } t > 100+x. \end{cases}$$

- Define the function f(x) by  $f(x) \triangleq Z(200)$ .
- We study the function f(x) in the interval  $x \in [-2, 2]$ .

 $x = -2 \Rightarrow T_1 = 100 + x = 98$ . It follows that  $A_1(t)$  "wins", and dig(Z(200)) = 1. Hence  $f(-2) \ge V_{high,out}$ .

- $x = -2 \Rightarrow T_1 = 100 + x = 98$ . It follows that  $A_1(t)$  "wins", and dig(Z(200)) = 1. Hence  $f(-2) \ge V_{high,out}$ .
- $x = 2 \Rightarrow T_1 = 100 + x = 102$ . It follows that  $A_0(t)$  "wins", and dig(Z(200)) = 0. Hence  $f(2) \leq V_{low,out}$ .

- $x = -2 \Rightarrow T_1 = 100 + x = 98$ . It follows that  $A_1(t)$  "wins", and dig(Z(200)) = 1. Hence  $f(-2) \ge V_{high,out}$ .
- $x = 2 \Rightarrow T_1 = 100 + x = 102$ . It follows that  $A_0(t)$  "wins", and dig(Z(200)) = 0. Hence  $f(2) \leq V_{low,out}$ .
- $\blacksquare$  claim: f(x) is continuous (will prove this later).

- $x = -2 \Rightarrow T_1 = 100 + x = 98$ . It follows that  $A_1(t)$  "wins", and dig(Z(200)) = 1. Hence  $f(-2) \ge V_{high,out}$ .
- $x = 2 \Rightarrow T_1 = 100 + x = 102$ . It follows that  $A_0(t)$  "wins", and dig(Z(200)) = 0. Hence  $f(2) \leq V_{low,out}$ .
- $\blacksquare$  claim: f(x) is continuous (will prove this later).
- Mean Value theorem ⇒

$$\forall y \in [V_{low,out}, V_{high,out}] \exists x \in [-2, 2] : f(x) = y.$$

- $x = -2 \Rightarrow T_1 = 100 + x = 98$ . It follows that  $A_1(t)$  "wins", and dig(Z(200)) = 1. Hence  $f(-2) \ge V_{high,out}$ .
- $x = 2 \Rightarrow T_1 = 100 + x = 102$ . It follows that  $A_0(t)$  "wins", and dig(Z(200)) = 0. Hence  $f(2) \leq V_{low,out}$ .
- $\blacksquare$  claim: f(x) is continuous (will prove this later).
- Mean Value theorem ⇒

$$\forall y \in [V_{low,out}, V_{high,out}] \exists x \in [-2, 2] : f(x) = y.$$

■ Pick y such that dig(y) = non-logical.

### **Proof:** every circuit C is not an arbiter - cont.

- $x = -2 \Rightarrow T_1 = 100 + x = 98$ . It follows that  $A_1(t)$  "wins", and dig(Z(200)) = 1. Hence  $f(-2) \ge V_{high,out}$ .
- $x = 2 \Rightarrow T_1 = 100 + x = 102$ . It follows that  $A_0(t)$  "wins", and dig(Z(200)) = 0. Hence  $f(2) \leq V_{low,out}$ .
- $\blacksquare$  claim: f(x) is continuous (will prove this later).
- Mean Value theorem ⇒

$$\forall y \in [V_{low,out}, V_{high,out}] \exists x \in [-2, 2] : f(x) = y.$$

- Pick y such that dig(y) = non-logical.
- There exist valid inputs  $A_0(t), A_1(t)$  with  $t' \le 112$ , such that dig(Z(200)) =non-logical.

### **Proof:** every circuit C is not an arbiter - cont.

- $x = -2 \Rightarrow T_1 = 100 + x = 98$ . It follows that  $A_1(t)$  "wins", and dig(Z(200)) = 1. Hence  $f(-2) \ge V_{high,out}$ .
- $x = 2 \Rightarrow T_1 = 100 + x = 102$ . It follows that  $A_0(t)$  "wins", and dig(Z(200)) = 0. Hence  $f(2) \leq V_{low,out}$ .
- $\blacksquare$  claim: f(x) is continuous (will prove this later).
- Mean Value theorem ⇒

$$\forall y \in [V_{low,out}, V_{high,out}] \exists x \in [-2, 2] : f(x) = y.$$

- Pick y such that dig(y) = non-logical.
- There exist valid inputs  $A_0(t), A_1(t)$  with  $t' \le 112$ , such that dig(Z(200)) =non-logical.
- ightharpoonup 
  ightharpoonup C is not an arbiter. QED.

Rely on the assumption that an infinitesimal change in the energy of input signals causes an infinitesimal change in the energy of the output. Otherwise, noise would cause uncontrollable changes in Z(t) and the circuit C would not be useful anyhow.

Rely on the assumption that an infinitesimal change in the energy of input signals causes an infinitesimal change in the energy of the output. Otherwise, noise would cause uncontrollable changes in Z(t) and the circuit C would not be useful anyhow.

The output Z(200) depends on the following:

Rely on the assumption that an infinitesimal change in the energy of input signals causes an infinitesimal change in the energy of the output. Otherwise, noise would cause uncontrollable changes in Z(t) and the circuit C would not be useful anyhow.

The output Z(200) depends on the following:

1. The initial state of the device C at time t=0. We assume that the device C is in a stable state and that the charge is known everywhere.

Rely on the assumption that an infinitesimal change in the energy of input signals causes an infinitesimal change in the energy of the output. Otherwise, noise would cause uncontrollable changes in Z(t) and the circuit C would not be useful anyhow.

The output Z(200) depends on the following:

- 1. The initial state of the device C at time t=0. We assume that the device C is in a stable state and that the charge is known everywhere.
- 2. The signal  $A_i(t)$  in the interval [0, 200], for i = 0, 1.

Consider an infinitesimal change in x. This change affects  $A_1(t)$  but does not affect  $A_0(t)$  and the initial state.

- Consider an infinitesimal change in x. This change affects  $A_1(t)$  but does not affect  $A_0(t)$  and the initial state.
- infinitesimal change of  $x \Rightarrow$  infinitesimal difference in energy of  $A_1(t)$ .

- Consider an infinitesimal change in x. This change affects  $A_1(t)$  but does not affect  $A_0(t)$  and the initial state.
- infinitesimal change of  $x \Rightarrow$  infinitesimal difference in energy of  $A_1(t)$ .
- infinitesimal difference in energy of  $A_1(t)$  ⇒ infinitesimal difference in Z(200).

- Consider an infinitesimal change in x. This change affects  $A_1(t)$  but does not affect  $A_0(t)$  and the initial state.
- infinitesimal change of  $x \Rightarrow$  infinitesimal difference in energy of  $A_1(t)$ .
- infinitesimal difference in energy of  $A_1(t) \Rightarrow$  infinitesimal difference in Z(200).
- $\blacksquare \Rightarrow f(x)$  is continuous.

■ Claim is counter-intuitive.

- Claim is counter-intuitive.
- For every judge in a 100-meter dash, there exist two runners whose running times are such that the judge still hangs after an hour.

- Claim is counter-intuitive.
- For every judge in a 100-meter dash, there exist two runners whose running times are such that the judge still hangs after an hour.
- Implies that there does not exist a perfect judge who can determine the winner in a 100-meters dash even if:

- Claim is counter-intuitive.
- For every judge in a 100-meter dash, there exist two runners whose running times are such that the judge still hangs after an hour.
- Implies that there does not exist a perfect judge who can determine the winner in a 100-meters dash even if:
  - 1. high speed cameras located at the finish line and runners run very slowly.

- Claim is counter-intuitive.
- For every judge in a 100-meter dash, there exist two runners whose running times are such that the judge still hangs after an hour.
- Implies that there does not exist a perfect judge who can determine the winner in a 100-meters dash even if:
  - 1. high speed cameras located at the finish line and runners run very slowly.
  - 2. we allow the judge several hours to decide.

- Claim is counter-intuitive.
- For every judge in a 100-meter dash, there exist two runners whose running times are such that the judge still hangs after an hour.
- Implies that there does not exist a perfect judge who can determine the winner in a 100-meters dash even if:
  - 1. high speed cameras located at the finish line and runners run very slowly.
  - 2. we allow the judge several hours to decide.
  - 3. we allow the judge to decide arbitrarily if the running times of the winner and runner-up are within a second.





Player - rolls a ball. Judge - announces decision if ball passes point P one day after.



- Player rolls a ball. Judge announces decision if ball passes point P one day after.
- If speed of ball is above v', then ball passes the obstacle and then rolls past point P.



- Player rolls a ball. Judge announces decision if ball passes point P one day after.
- If speed of ball is above v', then ball passes the obstacle and then rolls past point P.
- If speed of ball is below v', then ball does not pass the obstacle.



- Player rolls a ball. Judge announces decision if ball passes point P one day after.
- If speed of ball is above v', then ball passes the obstacle and then rolls past point P.
- If speed of ball is below v', then ball does not pass the obstacle.

#### Judge is in trouble:

■ If speed= v', then the ball reaches the tip of the obstacle and may remain there indefinitely long!



- Player rolls a ball. Judge announces decision if ball passes point P one day after.
- If speed of ball is above v', then ball passes the obstacle and then rolls past point P.
- If speed of ball is below v', then ball does not pass the obstacle.

#### Judge is in trouble:

- If speed= v', then the ball reaches the tip of the obstacle and may remain there indefinitely long!
- If the ball remains on the obstacle's tip 24 hours past the throw, then the judge cannot announce her decision.

# **Meta-stability**



# **Meta-stability**



Meta-stability - a state of equilibrium (i.e. zero force) which is not a local minimum of energy (i.e. a slight force causes a movement away from the state).

# **Meta-stability**



- Meta-stability a state of equilibrium (i.e. zero force) which is not a local minimum of energy (i.e. a slight force causes a movement away from the state).
- Inclined to say that the "probability of meta-stability occurring is very small". This requires a probability distribution over the rolling speed v where

$$\lim_{\varepsilon \to 0} \Pr(|v - v'| < \varepsilon) = 0.$$

## **Lessons learned**

Certain tasks are not achievable with probability 1.

## **Lessons learned**

- Certain tasks are not achievable with probability 1.
  - coin toss might end up with the coin standing on its perimeter.

## **Lessons learned**

- Certain tasks are not achievable with probability 1.
  - coin toss might end up with the coin standing on its perimeter.
  - noise could be big enough to cause the digital value of a signal to flip from zero to one. (increase noise margin to reduce the probability of such an event.)

### Reducing the probability of meta-stability

Increase length of segment of instability. Increasing the delay of the arbiter (significantly) decreases the chances of meta-stability. E.g., ball resting on the tip of the obstacle is likely to fall to one of the sides.

### Reducing the probability of meta-stability

- Increase length of segment of instability. Increasing the delay of the arbiter (significantly) decreases the chances of meta-stability. E.g., ball resting on the tip of the obstacle is likely to fall to one of the sides.
- Increase the slope of the transfer function in the range of non-logical values. Similar to sharpening the tip of the obstacle.

### Reducing the probability of meta-stability

- Increase length of segment of instability. Increasing the delay of the arbiter (significantly) decreases the chances of meta-stability. E.g., ball resting on the tip of the obstacle is likely to fall to one of the sides.
- Increase the slope of the transfer function in the range of non-logical values. Similar to sharpening the tip of the obstacle.
- However, increasing the clock rate means that "decisions" must be made faster (i.e. within a clock period) and the chance of meta-stability increases.

# Question

Does the proof of the Claim hold only if the signals  $A_i(t)$  rise gradually?

Question: Prove the claim with respect to "fast" non-decreasing signals  $A_i(t)$ . Namely, the length of the interval during which  $dig(A_i(t))$  is non-logical equals  $\varepsilon$ .

### Flip-flops: necessity of critical segments

DEF: A flip-flop without a critical segment is a flip-flop in which the setup-time and hold-time satisfy  $t_{su} = t_{hold} = 0$ . The functionality is defined as follows:

- For every i, Q(t) is logical (either zero or one) during the interval  $t \in (t_i + t_{pd}, t_{i+1} + t_{cont})$  regardless of whether  $D(t_i)$  is logical.
- If  $D(t_i)$  is logical, then  $Q(t) = D(t_i)$  during the interval  $t \in (t_i + t_{pd}, t_{i+1} + t_{cont})$ .

### Flip-flops: necessity of critical segments

DEF: A flip-flop without a critical segment is a flip-flop in which the setup-time and hold-time satisfy  $t_{su} = t_{hold} = 0$ . The functionality is defined as follows:

- For every i, Q(t) is logical (either zero or one) during the interval  $t \in (t_i + t_{pd}, t_{i+1} + t_{cont})$  regardless of whether  $D(t_i)$  is logical.
- If  $D(t_i)$  is logical, then  $Q(t) = D(t_i)$  during the interval  $t \in (t_i + t_{pd}, t_{i+1} + t_{cont})$ .

Just as the arbiter's decision is free if a tie occurs, the flip-flop is allowed to output either zero or one if  $D(t_i)$  is not logical. However, the output of the flip-flip must be logical once the instability segment ends.

### An arbiter based on a flip-flop without a critical segment





Assumptions:



### Assumptions:

flip-flop is without a critical segment.



### Assumptions:

- flip-flop is without a critical segment.
- $\blacksquare t_{\it cont}, t_{\it pd} \approx 10^{-9} \ {\rm time\ unit.}$



### Assumptions:

- flip-flop is without a critical segment.
- $\blacksquare t_{cont}, t_{pd} \approx 10^{-9}$  time unit.
- intervals during which the inputs  $A_0(t)$  and  $A_1(t)$  are non-logical are also very short (e.g.  $10^{-9}$  time unit).



### Assumptions:

- flip-flop is without a critical segment.
- $-t_{cont}, t_{pd} \approx 10^{-9}$  time unit.
- intervals during which the inputs  $A_0(t)$  and  $A_1(t)$  are non-logical are also very short (e.g.  $10^{-9}$  time unit).

Claim: The circuit above is an arbiter.



#### **Assumptions:**

- flip-flop is without a critical segment.
- $\blacksquare t_{cont}, t_{pd} \approx 10^{-9}$  time unit.
- intervals during which the inputs  $A_0(t)$  and  $A_1(t)$  are non-logical are also very short (e.g.  $10^{-9}$  time unit).

Claim: The circuit above is an arbiter.

CORO: There does not exist a flip-flop without a critical section.





■ the signal  $A_0(t)$  is input as a clock to the flip-flop, but  $A_0(t)$  is not a clock.



- the signal  $A_0(t)$  is input as a clock to the flip-flop, but  $A_0(t)$  is not a clock.
- requirements from  $A_0(t)$  are weaker than the requirements from a clock. Instead of periodic instantaneous transitions from zero to one and back,  $A_0(t)$  is non-decreasing.



- the signal  $A_0(t)$  is input as a clock to the flip-flop, but  $A_0(t)$  is not a clock.
- requirements from  $A_0(t)$  are weaker than the requirements from a clock. Instead of periodic instantaneous transitions from zero to one and back,  $A_0(t)$  is non-decreasing.
- the claim assumes only one "tick of the clock", so we may regard  $A_0(t)$  as a clock with a very long period.



- the signal  $A_0(t)$  is input as a clock to the flip-flop, but  $A_0(t)$  is not a clock.
- requirements from  $A_0(t)$  are weaker than the requirements from a clock. Instead of periodic instantaneous transitions from zero to one and back,  $A_0(t)$  is non-decreasing.
- the claim assumes only one "tick of the clock", so we may regard  $A_0(t)$  as a clock with a very long period.
- proof of claim does not rely on  $A_0(t)$  rising slowly; the claim holds regardless of the rate of change of  $A_0(t)$ .

We consider three cases:

We consider three cases:

 $|T_1 - T_0| \le 1$ : flip-flop's output Z(t) is always logical at time  $T_0 + t_{pd}$ , so circuit functions properly.

#### We consider three cases:

- $|T_1 T_0| \le 1$ : flip-flop's output Z(t) is always logical at time  $T_0 + t_{pd}$ , so circuit functions properly.
- $T_1 < T_0 1$ : if  $T_1 < T_0 1$ , then  $dig(A_1(T_0)) = 1$ . Hence sampled value equals 1, and hence, dig(Z(t)) = 1, for every  $t \ge T_0 + t_{pd}$ .

#### We consider three cases:

- $|T_1 T_0| \le 1$ : flip-flop's output Z(t) is always logical at time  $T_0 + t_{pd}$ , so circuit functions properly.
- $T_1 < T_0 1$ : if  $T_1 < T_0 1$ , then  $dig(A_1(T_0)) = 1$ . Hence sampled value equals 1, and hence, dig(Z(t)) = 1, for every  $t \ge T_0 + t_{pd}$ .
- $T_0 < T_1 1$ : we claim that  $dig(A_1(T_0)) = 0$ , and hence, dig(Z(t)) = 0, for every  $t \ge T_0 + t_{pd}$ .

We need to show that  $T_0 < T_1 - 1 \Rightarrow dig(A_1(T_0)) = 0$ .

We need to show that  $T_0 < T_1 - 1 \Rightarrow dig(A_1(T_0)) = 0$ .

 $\blacksquare T_0 < T_1 \Rightarrow dig(A_1(T_0)) \in \{0, \text{non-logical}\}.$ 

We need to show that  $T_0 < T_1 - 1 \Rightarrow dig(A_1(T_0)) = 0$ .

- $\blacksquare T_0 < T_1 \Rightarrow dig(A_1(T_0)) \in \{0, \text{non-logical}\}.$
- **a** assumption on the fast transition of  $dig(A_1(t))$  implies:

$$dig(A_1(T_0)) = \text{non-logical} \implies dig(A_1(T_0 + 10^{-9})) = 1.$$

Hence,  $T_1 \leq T_0 + 10^{-9}$  contradicting  $T_1 > T_0 + 1$ .

We need to show that  $T_0 < T_1 - 1 \Rightarrow dig(A_1(T_0)) = 0$ .

- $\blacksquare T_0 < T_1 \Rightarrow dig(A_1(T_0)) \in \{0, \text{non-logical}\}.$
- **a** assumption on the fast transition of  $dig(A_1(t))$  implies:

$$dig(A_1(T_0)) = \text{non-logical} \implies dig(A_1(T_0 + 10^{-9})) = 1.$$

Hence,  $T_1 \leq T_0 + 10^{-9}$  contradicting  $T_1 > T_0 + 1$ .

It follows that if  $T_0 < T_1 - 1$ , then  $dig(A_1(T_0)) = 0$ . QED

# Corollary: conclusion

Critical segment is required to avoid meta-stability of the flip-flop.

Without critical segment, flip-flop's output can be non-logical even after  $t_i + t_{\it pd}$ .

# An example: timing



# An example: functionality



## Non-disjoint segments: $A_i \cap C_i \neq \emptyset$



## Non-disjoint segments: $A_i \cap C_i \neq \emptyset$



Stability interval of  $D_1(t)$  is:

$$[t_i + t_{pd} + d(C), t_{i+1} + t_{cont}].$$

Stability interval of  $D_1(t)$  is:

$$[t_i + t_{pd} + d(C), t_{i+1} + t_{cont}].$$

If  $t_{cont} < t_{hold}$ , then  $D_1(t)$  is not stable during

$$C_{i+1} = [t_{i+1} - t_{su}, t_{i+1} + t_{hold}].$$

Stability interval of  $D_1(t)$  is:

$$[t_i + t_{pd} + d(C), t_{i+1} + t_{cont}].$$

If  $t_{cont} < t_{hold}$ , then  $D_1(t)$  is not stable during

$$C_{i+1} = [t_{i+1} - t_{su}, t_{i+1} + t_{hold}].$$

In this case, we need to rely on the contamination delay cont(C) of the combinational circuit C.

Stability interval of  $D_1(t)$  is:

$$[t_i + t_{pd} + d(C), t_{i+1} + t_{cont}].$$

If  $t_{cont} < t_{hold}$ , then  $D_1(t)$  is not stable during

$$C_{i+1} = [t_{i+1} - t_{su}, t_{i+1} + t_{hold}].$$

In this case, we need to rely on the contamination delay cont(C) of the combinational circuit C.

Now  $D_1(t)$  is stable during the interval

$$[t_i + t_{pd} + d(C), t_{i+1} + t_{cont} + cont(C)].$$

Stability interval of  $D_1(t)$  is:

$$[t_i + t_{pd} + d(C), t_{i+1} + t_{cont}].$$

If  $t_{cont} < t_{hold}$ , then  $D_1(t)$  is not stable during

$$C_{i+1} = [t_{i+1} - t_{su}, t_{i+1} + t_{hold}].$$

In this case, we need to rely on the contamination delay cont(C) of the combinational circuit C.

Now  $D_1(t)$  is stable during the interval

$$[t_i + t_{pd} + d(C), t_{i+1} + t_{cont} + cont(C)].$$

If  $t_{cont} + cont(C) > t_{hold}$ , then the signal  $D_1(t)$  is stable during the critical segment  $C_{i+1}$ , and correct functionality is obtained.

Can help in obtaining stability during the critical segment.

- Can help in obtaining stability during the critical segment.
- Many combinational gates have a positive contamination delay. But some don't.

- Can help in obtaining stability during the critical segment.
- Many combinational gates have a positive contamination delay. But some don't.
- Relying on the contamination delay of combinational circuits complicates timing analysis.

- Can help in obtaining stability during the critical segment.
- Many combinational gates have a positive contamination delay. But some don't.
- Relying on the contamination delay of combinational circuits complicates timing analysis.
- We use a strict assumption that cont(C) = 0, for every combinational circuit C. This does not cause incorrect circuits even if cont(C) > 0.

# Fixing $A_i \cap C_i \neq \emptyset$

Question: Assume that we have an edge-triggered flip-flop FF in which  $t_{hold} > t_{cont}$ . Suppose that we have an inverter with a contamination delay cont(INV) > 0.

- Suggest how to design an edge-triggered flip-flop FF' that satisfies  $t_{hold}(FF') < t_{cont}(FF')$ .
- What are the parameters of FF'?

# **D-Latch:** parameters

 $\blacksquare$  characterized by two parameters  $t_{su}$ ,  $t_{hold}$ 

- $\blacksquare$  characterized by two parameters  $t_{su}$ ,  $t_{hold}$
- the critical segment is defined with respect to the falling edge of the clock.

- $\blacksquare$  characterized by two parameters  $t_{su}, t_{hold}$
- the critical segment is defined with respect to the falling edge of the clock.
- $\mathbf{t}_{i}'$  time of the falling edge of the clock during the *i*th clock cycle.

- $\blacksquare$  characterized by two parameters  $t_{su}$ ,  $t_{hold}$
- the critical segment is defined with respect to the falling edge of the clock.
- $\mathbf{t}_{i}'$  time of the falling edge of the clock during the *i*th clock cycle.
- critical segment of a D-latch is

$$[t_i' - t_{su}, t_i' + t_{hold}].$$

- $\blacksquare$  characterized by two parameters  $t_{su}$ ,  $t_{hold}$
- the critical segment is defined with respect to the falling edge of the clock.
- $\mathbf{t}_{i}'$  time of the falling edge of the clock during the *i*th clock cycle.
- critical segment of a D-latch is

$$[t_i' - t_{su}, t_i' + t_{hold}].$$

 $\blacksquare d$  - combinational delay of the *D*-latch.

### **D-Latch: definition**

■ During the interval  $[t_i + d, t'_i)$ , the output Q(t) satisfies: Q(t) = D(t), provided that D(t) is stable during the interval [t - d, t]. We say that the D-latch is transparent during the interval  $[t_i + d, t'_i)$ .

### **D-Latch: definition**

- During the interval  $[t_i + d, t'_i)$ , the output Q(t) satisfies: Q(t) = D(t), provided that D(t) is stable during the interval [t d, t]. We say that the D-latch is transparent during the interval  $[t_i + d, t'_i)$ .
- During the interval  $(t'_i + t_{hold}, t_{i+1})$ , if D(t) is stable during the critical segment  $[t'_i t_{su}, t'_i + t_{hold}]$ , then  $Q(t) = D(t'_i)$ . We say that the D-latch is opaque during the interval  $(t'_i + t_{hold}, t_{i+1})$ .

■ *D*-latches are very important devices.

- *D*-latches are very important devices.
- D-latches are cheaper than flip-flops, and in fact, D-latches are the building blocks of flip-flops (e.g. master/slave designs).

- D-latches are very important devices.
- *D*-latches are cheaper than flip-flops, and in fact, *D*-latches are the building blocks of flip-flops (e.g. master/slave designs).
- using *D*-latches wisely leads to faster designs.

- *D*-latches are very important devices.
- D-latches are cheaper than flip-flops, and in fact, D-latches are the building blocks of flip-flops (e.g. master/slave designs).
- using *D*-latches wisely leads to faster designs.
- designs based on D-latches require multiple clock phases (or at least a clock CLK and its negation  $\overline{\text{CLK}}$ ).

- D-latches are very important devices.
- D-latches are cheaper than flip-flops, and in fact, D-latches are the building blocks of flip-flops (e.g. master/slave designs).
- using *D*-latches wisely leads to faster designs.
- designs based on D-latches require multiple clock phases (or at least a clock CLK and its negation  $\overline{CLK}$ ).
- Although timing with multiple clock phases is an important and interesting topic, we do not deal with it in this course.

Inputs: Digital signals D(t), ce(t) and a clock clk.

Output: A digital signal Q(t).

Functionality: If D(t) and ce(t) are stable during the critical segment  $C_i$ , then for every  $t \in (t_i + t_{pd}, t_{i+1} + t_{cont})$ 

$$Q(t) = \begin{cases} D(t_i) & \text{if } \mathrm{CE}(t_i) = 1\\ Q(t_i) & \text{if } \mathrm{CE}(t_i) = 0. \end{cases}$$

Inputs: Digital signals D(t), ce(t) and a clock clk.

Output: A digital signal Q(t).

Functionality: If D(t) and ce(t) are stable during the critical segment  $C_i$ , then for every  $t \in (t_i + t_{pd}, t_{i+1} + t_{cont})$ 

$$Q(t) = \begin{cases} D(t_i) & \text{if } \mathsf{CE}(t_i) = 1\\ Q(t_i) & \text{if } \mathsf{CE}(t_i) = 0. \end{cases}$$

 $\blacksquare$  ce(t) - clock-enable signal.

Inputs: Digital signals D(t), ce(t) and a clock clk.

Output: A digital signal Q(t).

Functionality: If D(t) and ce(t) are stable during the critical segment  $C_i$ , then for every  $t \in (t_i + t_{pd}, t_{i+1} + t_{cont})$ 

$$Q(t) = \begin{cases} D(t_i) & \text{if } \mathsf{CE}(t_i) = 1\\ Q(t_i) & \text{if } \mathsf{CE}(t_i) = 0. \end{cases}$$

- $\blacksquare$  ce(t) clock-enable signal.
- Arr ce(t) indicates whether the flip-flop samples the input D(t) or maintains its previous value.







Question: Which design is correct?



Design (B) is wrong because:



Design (B) is wrong because:

output of the AND-gate is not a clock signal (glitches).



Design (B) is wrong because:

- output of the AND-gate is not a clock signal (glitches).
- slow transitions of the output of the AND-gate (increase hold time)



#### Design (B) is wrong because:

- output of the AND-gate is not a clock signal (glitches).
- slow transitions of the output of the AND-gate (increase hold time)
- in some technologies, the flip-flop does not retain the stored bit forever.  $\Rightarrow$  if ce(t) = 0 for a long period, then the flip-flop's output may become non-logical.



Question: Compute the parameters of the clock-enabled flip-flop depicted in part (A) in terms of the parameters of the edge-triggered flip-flop and the MUX.

clock signal - definition, terminology

- clock signal definition, terminology
- define edge-triggered flip-flops

- clock signal definition, terminology
- define edge-triggered flip-flops
- prove that critical segments are crucial:

- clock signal definition, terminology
- define edge-triggered flip-flops
- prove that critical segments are crucial:
  - arbitration the problem of deciding "whose first"

- clock signal definition, terminology
- define edge-triggered flip-flops
- prove that critical segments are crucial:
  - arbitration the problem of deciding "whose first"
  - prove that arbiters do not exist

- clock signal definition, terminology
- define edge-triggered flip-flops
- prove that critical segments are crucial:
  - arbitration the problem of deciding "whose first"
  - prove that arbiters do not exist
  - use this proof to show that critical segments are crucial

- clock signal definition, terminology
- define edge-triggered flip-flops
- prove that critical segments are crucial:
  - arbitration the problem of deciding "whose first"
  - prove that arbiters do not exist
  - use this proof to show that critical segments are crucial
- a timing example

- clock signal definition, terminology
- define edge-triggered flip-flops
- prove that critical segments are crucial:
  - arbitration the problem of deciding "whose first"
  - prove that arbiters do not exist
  - use this proof to show that critical segments are crucial
- a timing example
- other memory devices: D-latch & clock-enabled flip-flop