# ROHINI COLLEGE OF ENGINEERING AND TECHNOLOGY 24EC302 - DIGITAL LOGIC CIRCUIT AND DESIGN

# 3.6. REGISTERS

A register is simply a group of Flip-Flops that can be used to store a binary number. There must be one Flip-Flop for each bit in the binary number. For instance, a register used to store an 8-bit binary number must have 8 Flip-Flops.

The Flip-Flops must be connected such that the binary number can be entered (shifted) into the register and possibly shifted out. A group of Flip-Flops connected to provide either or both of these functions is called a *shift register*.

The bits in a binary number (data) can be removed from one place to another in either of two ways. The first method involves shifting the data one bit at a time in a serial fashion, beginning with either the most significant bit (MSB) or the least significant bit (LSB). This technique is referred to as *serial shifting*. The second method involves shifting all the data bits simultaneously and is referred to as *parallel shifting*.

There are two ways to shift into a register (serial or parallel) and similarly two ways to shift the data out of the register. This leads to the construction of four basic register types—

- i. Serial in- serial out,
- ii. Serial in- parallel out,
- iii. Parallel in- serial out,

### 24EC302 - DIGITAL LOGIC CIRCUIT AND DESIGN

### iv. Parallel in- parallel out.



#### Serial-In Serial-Out Shift Register:

The serial in/serial out shift register accepts data serially, i.e., one bit at a time on a single line. It produces the stored information on its output also in serial form.



The entry of the four bits 1010 into the register is illustrated below, beginning with the right-most bit. The register is initially clear. The 0 is put onto the data input line, making D=0 for  $FF_0$ . When the first clock pulse is applied,  $FF_0$  is reset, thus storing the 0.

Next the second bit, which is a 1, is applied to the data input, making D=1 for  $FF_0$  and D=0 for  $FF_1$  because the D input of  $FF_1$  is connected to the  $Q_0$  output. When the second clock pulse occurs, the 1 on the data input is shifted into  $FF_0$ , causing  $FF_0$  to set; and the 0 that was in  $FF_0$  is shifted into  $FF_1$ .

#### 24EC302 - DIGITAL LOGIC CIRCUIT AND DESIGN

The third bit, a 0, is now put onto the data-input line, and a clock pulse is applied. The 0 is entered into  $FF_0$ , the 1 stored in  $FF_0$  is shifted into  $FF_1$ , and the 0 stored in  $FF_1$  is shifted into  $FF_2$ .

The last bit, a 1, is now applied to the data input, and a clock pulse is applied. This time the 1 is entered into FF0, the 0 stored in FF0 is shifted into FF1, the 1 stored in FF1 is shifted into FF2, and the 0 stored in FF2 is shifted into FF3. This completes the serial entry of the four bits into the shift register, where they can be stored for any length of time as long as the Flip-Flops have dc power.

To get the data out of the register, the bits must be shifted out serially and taken off the Q3 output. After CLK4, the right-most bit, 0, appears on the Q3 output.

When clock pulse CLK5 is applied, the second bit appears on the Q3 output. Clock pulse CLK6 shifts the third bit to the output, and CLK7 shifts the fourth bit to the output. While the original four bits are being shifted out, more bits can be shifted in. All zeros are shown being shifted out, more bits can be shifted in.

#### Serial-In Parallel-Out Shift Register:

In this shift register, data bits are entered into the register in the same as serial-in serial-out shift register. But the output is taken in parallel. Once the data are stored, each bit appears on its respective output line and all bits are available simultaneously instead of on a bit-by-bit.



Serial-In parallel-Out Shift Register

#### 24EC302 - DIGITAL LOGIC CIRCUIT AND DESIGN

#### Parallel-In Serial-Out Shift Register:

In this type, the bits are entered in parallel i.e., simultaneously into their respective stages on parallel lines.

A 4-bit parallel-in serial-out shift register is illustrated below. There are four data input lines,  $X_0$ ,  $X_1$ ,  $X_2$  and  $X_3$  for entering data in parallel into the register. SHIFT/LOAD input is the control input, which allows four bits of data to **load** in parallel into the register.



Parallel-In Serial-Out Shift Register

When SHIFT/LOAD is LOW, gates  $G_1$ ,  $G_2$ ,  $G_3$  and  $G_4$  are enabled, allowing each data bit to be applied to the D input of its respective Flip-Flop. When a clock pulse is applied, the Flip-Flops with D = 1 will **set** and those with D = 0 will **reset**, thereby storing all four bits simultaneously.

When SHIFT/LOAD is HIGH, gates  $G_1$ ,  $G_2$ ,  $G_3$  and  $G_4$  are disabled and gates  $G_5$ ,  $G_6$  and  $G_7$  are enabled, allowing the data bits to shift right from one stage to the next. The OR gates allow either the normal shifting operation or the parallel dataentry operation, depending on which AND gates are enabled by the level on the SHIFT/LOAD input.

## 24EC302 - DIGITAL LOGIC CIRCUIT AND DESIGN

## Parallel-In Parallel-Out Shift Register:

In this type, there is simultaneous entry of all data bits and the bits appear on parallel outputs simultaneously.



Parallel-In Parallel-Out Shift Register