

16/9

## MODULE: 4

### Sequential Logic Storage Devices

Cross coupled inverter pair



- When you give  $Q=0$ , it gives the input of inverter  $I_2$  producing an o/p  $Q_n=1$  which in turn become the input for  $I_1$  resulting in  $Q=0$ . Such a state is called a stable state.

- If you give  $Q=1$ , again it will return a state where  $Q=1$ , making a system stable. Such a system where there are two stable states i.e 0 and 1 is called as a bistable

### Metastability

Sometimes a system will be having a voltage range in b/w 0 and 1. Then the system is said to be in metastable state.

Consider a system in metastable state where

$$Q = \frac{V_{CC}}{2}$$

Examining metastability - moving towards 0.

Let,  $\frac{V_{CC}}{2} = V_n$ . We are going to add a multiplying factor called gain gain represented by  $g$  in order to push the voltage  $V_n$  towards 0.



Here the noise is amplified by the inverter with a -ve gain, pushing it slightly towards a logic '0'.



Here the noise is amplified by the inverter with a +ve -ve gain, pushing it slightly towards '1'.

18/9

### S-R Latch

- Here S stands for set and R stands for reset.

- Set indicates that the o/p is forced to a logic 1 ie,  $Q=1$  and reset indicates that the o/p is forced into a logic 0 ie,  $Q=0$ .

## Modes of SR Latch

1. Store : This mode is enable when  $S=0$  and  $R=0$

NOR

| A | B | out |
|---|---|-----|
| 0 | 0 | 1   |
| 0 | 1 | 0   |
| 1 | 0 | 0   |
| 1 | 1 | 0   |



case 1 :  $Q=0$ , then  $Q_n$  remains 1

case 2:  $Q=1$ , then  $Q_n$  remains 0

Hence, store mode is bistable.

2. Set mode :  $S=1$  and  $R=0$



- If  $S=1$ , it will force an o/p on  $U_2$ ,  $Q_n=0$
- This inturn will be fed as an i/p to  $U_1$  where  $R=0$ , resulting in  $Q=1$

3. Resetting :  $Q=0$ ,  $S=0$ ,  $R=1$



- When  $R=1$ ,  $U_1$  gives an o/p  $Q=0$  which in turn is fed into  $U_2$  along with  $S=0$  forcing  $U_2$  give an o/p  $Q_n=1$  which will again be fed into  $U_1$  along with  $R=1$  forcing  $U_1$  to give o/p  $Q=0$

4. Don't use mode :  $S=1$  and  $R=1$

When  $S=1$  and  $R=1$ , we get both  $Q=0$  and  $Q_n=0$ . This might cause unpredictable outputs when we switch the S-R latch into store mode. Also there is a chance of the latch going into metastable state.

### $S'R'$ Latch



NAND

A    B    Out

0    0    1

0    1    0

1    0    0

1    1    0

In  $S'R'$  latch, the input codes store, ~~for~~ set and reset are complemented and compared to SR latch.

### Modes of operation

1. Store :  $S'=1$ ,  $R'=1$

2. Set mode

a) - For storing  $Q=1$ ,  $S'=0$  and  $R'=1$

- If  $S'=0$ , it will force an o/p ~~when S=0~~

on  $U_1$  of  $Q=1$



b) Reset :  $S'=1$  and  $R'=0$



3. Don't use mode  
when both  $S'$  and  $R'$  are 0, the outputs of both  $U_1$  and  $U_2$  ie,  $Q_n=1$ . This will cause the outputs to go metastable when  $S'$  and  $R'=1$

2019

### SR Latch with Enable

- In SR Latch with Enable, enable is implemented by adding two NAND gates on the i/p stage of an  $S'R'$  Latch



- In this configuration, any time  $C=0$  the o/p of  $U_3$  and  $U_4$  will be 1. This will be fed into  $U_1$  and  $U_2$  respectively. Then the configuration becomes store state.

- When  $C=1$ , it has the effect of inverting the values of  $S$  and  $R$  before they become the inputs of  $U_1$  and  $U_2$ .

- when  $S=1$ ,  $R=0$  and  $C=1$ , the configuration goes into Set mode.
- when  $S=0$ ,  $R=1$  and  $C=1$ , the system becomes Reset mode

## D Latch

- In D-Latch, the SR Latch with enable is modified in such a way that instead of having two separate i/p lines to control the o/p's of, we are going to use a single i/p for  $U_3$  and  $U_4$  where that i/p is inverted while being fed into  $U_4$ . That i/p is known as D (data).



- This configuration removes the don't use states.

- This new circuit when  $C=1, D=1, Q=1$  ie the set state and when  $C=1, D=0$  then  $Q=0$  ie, the reset state.

- This behaviour of o/p when  $C=1$  is called trapping tracking the o/p.

Q.1 Explain the working of a multiplexer using truth table and gate diagram.

Q.2 Form a truth table for a 7 segment display starting from 0000 and ending at 1111

Q.3 What is bistable and metastable state? How can a circuit reach stability, ie  $Q=0$  and  $Q=1$  from metastable state? Explain with the help of a cross coupled inverted pair.

23/9

## D Flip Flop

Difference b/w a latch and a flip flop.

- Flip flop is edge triggered i.e., a bistable element with clock input
- The state of a flip flop changes only during the transition of the clock pulse from 0 to 1 (rising edge) or 1 to 0 (falling edge).
- Bistable elements without edge triggered clock are known as latches.
- A D flip flop can be built from two back to back D latches controlled by complementary clocks.



- The latch  $L_1$  is called master and latch  $L_2$  is called slave.
- The node b/w two latches is known as  $N_1$ .
- When  $CLK=0$ ,  $L_1$  becomes transparent and  $L_2$  becomes opaque. Therefore whatever value is at  $D$ , propagates through  $N_1$ .
- When  $CLK=1$ ,  $L_2$  becomes transparent and  $L_1$  becomes opaque. The value at  $N_1$  is transferred to  $Q$  at  $L_2$  and  $N_1$  is cut off from  $D$ .
- A D flip flop copies  $D$  to  $Q$  on the rising edge of the clock and remembers its state at all other times.



## Register

- An n bit register is a bank of n flip flop that share a common clock i/p so that all bits of the register are updated at the same time.



## Enabled Flip Flop

An enabled flip flop adds another i/p called  $EN^{EN}$  to determine whether data is loaded on the clock edge



- An i/p multiplexer passes the value of D if EN is 1 (true) or recycles old state from Q

if EN is 0 (false)

### Resettable FLIP FLOP

- A resettable flip flop adds another i/p called RESET.
  - If RESET is false, the flip flop behaves like an ordinary D flip flop
  - If RESET is true, the flip flop ignores D and resets the o/p to 0.
  - When the RESET is false, the AND gate forces a 0 into the flip flop and if RESET is true, AND gate passes a value of D into the flip flop.



23/9

### Sequential Logic Timing Considerations

1. Set up time ( $t_{\text{setup}}/t_s$ )
  - Specifies how long the data i/p needs to be at a steady state before the clock event
2. Hold time ( $t_{\text{hold}}/t_h$ )
  - Specifies how long the data i/p needs to be at a steady state after the clock event.
3. If the specifications  $t_s$  and  $t_h$  are violated (the i/p transitions are too close to the clock transition the storage device will not be able to determine whether the i/p was 0 or 1. This state is known as metastable state and the time for which the device is in metastable state is known as  $t_{\text{meta}}$ .)

4. The delay from the time of the clock event to the point where the data is present on the Q output is known as clock to Q delay ie,  $t_{CQ}$ .



- ① : First transition on data from 0 to 1 meets  $t_s$  or  $t_h$  specification allowing the device to latch successfully to the value.
- ② : The value of D will show up at Q after the delay  $t_{CQ}$
- ③ : The second transition of data from 1 to 0 violates the  $t_s$  or  $t_h$  specification and the device goes metastable for a time period  $t_{meta}$  where the o/p is unknown.
- ④ : From coming out of metastable state, Q can be either 1 or 0 ie, random or unknown

## 25) Toggle Flop Clock Driver

In T flip-flop circuit, it contains a D flip flop configured in such a way that the  $Q_n$  o/p is wired back to the D i/p



- The <sup>only</sup> i/p to this flip flop is clock i/p

- when  $Q=0$ ,  $Q_n=1$ . The  $Q_n$  is wired to D i/p therefore a value 1 is present in the D i/p before the first clock edge. Upon the rising edge of the clock Q is updated with value of D ie,  $Q=1$ . Therefore  $Q_n=0$ .

This configuration produce the o/p in the form of square waves with exact half the frequency of the incoming clock signals. So T flip flop is also known as 'Clock Divider'.



- Q and  $Q_n$  will always be opposite logic values.
- when rising edge of a clock occurs, Q will be updated with the value in D.
- In this configuration, value of D will always be opposite to the current value of Q. Therefore the o/p will toggle at every rising edge of the clock. Therefore the outputs are created as square waves half the frequency of the clock.
- T stands for toggle.

### Ripple Counter



### 1/10 Finite state Machine (FSM)

- Also known as state machine.
- circuit that contains pre defined finite no. of states. It can only be at one state at a time. Every state transition is based on a triggering event (edge of a clock)



## State diagram

- It is the graphical description of functionality of FSM.

- There are two different kinds of o/p conditions for a state machine:

1. The o/p is only depended on the current state of the machine, known as Moore machine.
2. The o/p condition is depended on both the current state and the system inputs, known as Mealy Machine

Eg:



## State Transition Table

| Current State | Input | Outputs  |            |         |
|---------------|-------|----------|------------|---------|
|               |       | Press    | Next State | Open CW |
| w-closed      | 0     | w-closed | 0          | 0       |
| w-closed      | 1     | w-open   | 1          | 0       |

|        |   |          |   |   |
|--------|---|----------|---|---|
| w-open | 0 | w-open   | 0 | 0 |
| w-open | 1 | w-closed | 0 | 1 |

## Logic Synthesis of FSM

- There are 3 components of a state machine:
- 1. Next state logic : It creates the signal next state based on current state and depending on the type of machine the system inputs.
- 2. State memory : It holds the current state. The current state is updated to next state on the rising edge of the clock (implemented using D flip flop)
- 3. Output logic : It creates system o/p based on current state and system inputs (depending on the type of machine).



## State Memory

State Encoding : Assigning binary values to descriptive names of states.

There are three types of state encoding:

1. Binary Encoding : The state codes are simply a set of binary codes ie, 00, 01, 10, 11
2. Gray code Encoding : In this, the value of the code differs only one with its neighbours ie, 00, 01, 11, 10
3. One hot Encoding : In this, the one hot state

codes will be 001, 010, 100...

|                | Binary | Graycode | One hot  |
|----------------|--------|----------|----------|
| S <sub>0</sub> | 000    | 000      | 00000001 |
| S <sub>1</sub> | 001    | 001      | 00000010 |
| S <sub>2</sub> | 010    | 011      | 00000100 |
| S <sub>3</sub> | 0011   | 010      | 00001000 |
| S <sub>4</sub> | 100    | 110      | 00100000 |
| S <sub>5</sub> | 101    | 111      | 01000000 |
| S <sub>6</sub> | 110    | 101      | 10000000 |
| S <sub>7</sub> | 100    | 100      |          |

IMP  
8/10

| Current state | Input |       | Next state | Outputs |         |           |
|---------------|-------|-------|------------|---------|---------|-----------|
|               | Qcurr | Prens |            | Q-next  | Open-cw | close_ccw |
| w-closed      | 0     | 0     | w-closed   | 0       | 0       | 0         |
| w-closed      | 0     | 1     | w-open     | 1       | 1       | 0         |
| w-open        | 1     | 0     | w-open     | 1       | 0       | 0         |
| w-open        | 1     | 1     | w-closed   | 0       | 0       | 1         |

| Q-curr  | Prens | Q-next | k-map for next-state                                                                                                                                                        |         |       |   |   |   |   |
|---------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|---|---|---|---|
| 0       | 0     | 0      |                                                                                                                                                                             |         |       |   |   |   |   |
| 0       | 1     | 1      |                                                                                                                                                                             |         |       |   |   |   |   |
| 1       | 0     | 1      |                                                                                                                                                                             |         |       |   |   |   |   |
| 1       | 1     | 0      | <p>Q-current<br/>Q-curr' Prens</p> <table border="1"> <tr> <td>Q-curr'</td> <td>Prens</td> </tr> <tr> <td>0</td> <td>1</td> </tr> <tr> <td>1</td> <td>0</td> </tr> </table> | Q-curr' | Prens | 0 | 1 | 1 | 0 |
| Q-curr' | Prens |        |                                                                                                                                                                             |         |       |   |   |   |   |
| 0       | 1     |        |                                                                                                                                                                             |         |       |   |   |   |   |
| 1       | 0     |        |                                                                                                                                                                             |         |       |   |   |   |   |

∴ Boolean expression for next state logic will be  
 $= (\bar{Q}\text{-curr}' \cdot \text{Prens}) + (\bar{Q}\text{-curr} \cdot \text{Prens}')$

[or  $(\bar{Q}\text{-curr} \oplus \text{Prens})$ ]

| Output | Q-curr | Prens | Open-cw | Qcurr' · Prens |
|--------|--------|-------|---------|----------------|
|        | 0      | 0     | 0       | 0 0 0          |
|        | 0      | 1     | 1       | 1 1 0          |
|        | 1      | 0     | 0       | 1 0 0          |
|        | 1      | 1     | 0       | 0 1 0          |

| <u>Q-curr</u> | <u>Press</u> | <u>close-cw</u> |
|---------------|--------------|-----------------|
| 0             | 0            | 0               |
| 0             | 1            | 0               |
| 1             | 0            | 0               |
| 1             | 1            | 1               |

|   |   |
|---|---|
| 0 | 1 |
| 1 | 0 |

(Q-curr . Press)



## q10 Finite State Machine Design Flow

1. word description
2. State diagram
3. State transition table
4. state memory synthesis
5. Next state logic
6. Output logic
7. Final logic diagram

Eg: serial bit sequence detector

1. word description : Design a circuit that will monitor an incoming serial bit stream. The stream consists of data in groups of 3 bits  $D_0, D_1, D_2$ . If the sequence occurs in the form of 111 an error is detected, ie  $ERR=1$  else for all other representation,  $ERR=0$ .

2. state diagram



| $D_0$ | $D_1$ | $D_2$ |
|-------|-------|-------|
| 0     | x     | x     |
| 1     | 0     | x     |



### 3. State transition table

| Current state       | Input              |                    |                    | Next state |                     | Output            |                   |     |
|---------------------|--------------------|--------------------|--------------------|------------|---------------------|-------------------|-------------------|-----|
|                     | Q <sub>2curr</sub> | Q <sub>1curr</sub> | Q <sub>0curr</sub> | Din        | Q <sub>2nxt</sub>   | Q <sub>1nxt</sub> | Q <sub>0nxt</sub> | ERR |
| Start               | 0                  | 0                  | 0                  | 0          | D <sub>0</sub> not1 | 0                 | 1                 | 0   |
| Start               | 0                  | 0                  | 0                  | 1          | D <sub>0</sub> not1 | 0                 | 0                 | 1   |
| D <sub>0</sub> is1  | 0                  | 0                  | 1                  | 0          | D <sub>1</sub> not1 | 1                 | 0                 | 0   |
| D <sub>0</sub> is1  | 0                  | 0                  | 1                  | 1          | D <sub>1</sub> is1  | 0                 | 1                 | 0   |
| D <sub>1</sub> is1  | 0                  | 1                  | 0                  | 0          | Start               | 0                 | 0                 | 0   |
| D <sub>1</sub> is1  | 0                  | 1                  | 0                  | 1          | Start               | 0                 | 0                 | 1   |
| D <sub>0</sub> not1 | 0                  | 1                  | 1                  | 0          | D <sub>1</sub> not1 | 1                 | 0                 | 0   |
| D <sub>0</sub> not1 | 0                  | 1                  | 1                  | 1          | D <sub>1</sub> not1 | 1                 | 0                 | 0   |
| D <sub>1</sub> not1 | 1                  | 0                  | 0                  | 0          | Start               | 0                 | 0                 | 0   |
| D <sub>1</sub> not1 | 1                  | 0                  | 0                  | 1          | Start               | 0                 | 0                 | 0   |

| <u>State</u>        | <u>Code</u> |
|---------------------|-------------|
| Start               | 000         |
| D <sub>0</sub> is1  | 001         |
| D <sub>1</sub> is1  | 010         |
| D <sub>0</sub> not1 | 011         |
| D <sub>1</sub> not1 | 100         |

## 5. Next state logic

| $Q_2\text{curr}$ | $Q_1\text{curr}$ | $Q_0\text{curr}$ | $D_{in}$ | $Q_2\text{nxt}$ | $Q_2\text{curr}$ | $Q_1\text{curr}$ | $Q_0\text{curr}$ | $D_{in}$ |
|------------------|------------------|------------------|----------|-----------------|------------------|------------------|------------------|----------|
| 0                | 0                | 1                | 0        | 1               | 00               | 01               | 11               | 10       |
| 0                | 1                | 1                | 0        | 1               | 00               | 00               | 0                | 0        |
| 0                | 1                | 1                | 1        | 1               | 01               | 00               | 0                | 0        |

ie,  $(Q_1\text{curr} \cdot Q_0\text{curr}) + (Q_0\text{curr} \cdot D_{in}')$

[Find Boolean expression wrt  $Q_1\text{nxt}$ ,  $Q_0\text{nxt}$  and  $D_{in}$ ]

## 6. Output logic synthesis

[Find boolean expression wrt ERR]

## 7. Final logic diagram



## Structural Design

- In verilog structural design refers to including lower level subsystems within a higher level module to produce desired functionality. This is called hierarchy and enables desired partitioning.
- A subsystem in verilog is simply another module called by a higher level module

## Lower level module instantiation

- Instantiation means using or including a lower module in a system.

Syntax:

module-name, <instance identifier>(port mapping)

name of module      optional identifier      to map i/p and  
being called                                          to instantiate multi- o/p codes of  
                                                                ple instances of the lower level module.  
                                                                same sub module.

- There are two techniques to connect signals to the ports of the lower level module

### 1. Explicit port mapping

System 3.V



Syntax:

module-name <inst id> (  
    • portname1(signal1),  
    • portname n(signln));

module sub1 (output wire F1, F2,  
               input wire A, B)

// behaviour

end module

module sub2 (output wire W,  
               input wires A, B)

// behaviour

end module.

module systems (output wire Z,  
               input wire X, Y)

```

wire n1, n2;
Sub1 Uo(·F1(n1), ·F2(n2), ·A(X), ·B(Y));
Sub2 U1(·W(Z), ·A(n1), ·B(n2));
end module

```

## 2. Positional port mapping

Eg: // same module sub1 and sub2

module systems (output wire Z,  
input wire X, Y)

```

wire n1, n2;
Sub1 Uo(n1, n2, X, Y);
Sub2 U1(Z, n1, n2);

```

- Signals given the correct order of how it is defined in the sub modules.

## gate level primitives

A B C F

0 0 0 1

0 1 0 1

1 1 0 1

$$F = \sum_{(0,2,6)} A'B'C' + A'BC' + ABC'$$

A  $\rightarrow$  An

B  $\rightarrow$  Bn

C  $\rightarrow$  Cn



module SystemX (output wire F,  
input wire A, B, C)

wire An, Bn, Cn;

wire m0, m2, M6;

not U<sub>o</sub>(An, A);

not  $U_1(B_n, B)$ ;

not  $U_2(C_n, C)$ ;

and  $U_3(m_0, A_n, B_n, C_n)$ ;

and  $U_4(m_2, A_n, B, C_n)$ ;

and  $U_5(m_6, A, B, C_n)$ ;

or  $U_6(F, m_0, m_2, m_6)$ ;