### Logic and Computer Design Fundamentals

# Chapter 7 – Registers and Register Transfers

# Part 1 – Registers, Microoperations and Implementations

#### **Charles Kime & Thomas Kaminski**

© 2004 Pearson Education, Inc. <u>Terms of Use</u> (Hyperlinks are active in View Show mode)

### Overview

- Part 1 Registers, Microoperations and Implementations
  - Registers and load enable
  - Register transfer operations
  - Microoperations arithmetic, logic, and shift
  - Microoperations on a single register
    - Multiplexer-based transfers
    - Shift registers
- Part 2 Counters, register cells, buses, & serial operations
  - Microoperations on single register (continued)
    - Counters
  - Register cell design
  - · Multiplexer and bus-based transfers for multiple registers
  - Serial transfers and microoperations

Logic and Computer Design Fundamentals PowerPoint<sup>®</sup> Sildes © 2004 Poerson Education, Inc.

### **Registers**

- Register a <u>collection</u> of binary storage elements
- In theory, a register is sequential logic which can be defined by a state table
- More often think of a register as storing a vector of binary values
- Frequently used to perform simple data storage and data movement and processing operations

Logic and Computer Design Fundamentals PowerPoint<sup>®</sup> Sides © 2004 Pearson Education, Inc.

Chapter 7 - Part 1 3

### **Example: 2-bit Register**



• What are the the quantities above for an *n*-bit register?

Logic and Computer Dealgn Fundamentals PowerPoint<sup>®</sup> Slides © 2004 Poerson Education, Inc.

### **Register Design Models**

- Due to the large numbers of states and input combinations as *n* becomes large, the state diagram/state table model is not feasible!
- What are methods we can use to design registers?
  - Add predefined combinational circuits to registers
    - Example: To count up, connect the register flip-flops to an incrementer
  - Design individual cells using the state diagram/state table model and combine them into a register
    - A 1-bit cell has just two states
    - Output is usually the state variable

Logic and Computer Dealgn Fundamentals PowerPoint<sup>®</sup> Stides © 2004 Poersun Education, Inc.

Chapter 7 - Part 1 5

# **Register Storage**

#### Expectations:

- A register can store information for multiple clock cycles
- To "store" or "load" information should be controlled by a signal
- Reality:
  - A D flip-flop register loads information on every clock cycle
- Realizing expectations:
  - Use a signal to block the clock to the register,
  - Use a signal to control feedback of the output of the register back to its inputs, or
  - Use other SR or JK flip-flops which for (0,0) applied store their state
- <u>Load</u> is a frequent name for the signal that controls register storage and loading
  - Load = 1: Load the values on the data inputs
  - Load = 0: Store the values in the register

### **Registers with Clock Gating**

- <u>Load</u> signal is used to enable the clock signal to pass through if 1 and prevent the clock signal from passing through if 0.
- Example: For Positive Edge-Triggered or Negative Pulse Master-Slave Flip-flop:



Logic and Computer Design Fundamentals PowerPoint<sup>®</sup> Stides © 2004 Poorson Education, Inc.

Chapter 7 - Part 1 7

### **Registers with Load-Controlled Feedback**

- A more reliable way to selectively load a register:
  - Run the clock continuously, and
  - Selectively use a load control to change the register contents.
- Example: 2-bit register with Load Control:
- For Load = 0, loads register contents (hold current values)
- For Load = 1, loads input values (load new values)
   Load-In1-
- Hardware more complex than clock gating, but free of timing problems In0



Chapter 7 - Part 1 8

2-to-1 Multiplexers

A1

A0

D

Clock

-Y1

-Y0

### **Register Transfer Operations**

- <u>Register Transfer Operations</u> The movement and processing of data stored in registers
- Three basic components:
  - set of registers
  - operations
  - control of operations
- Elementary Operations -- load, count, shift, add, bitwise "OR", etc.
  - Elementary operations called *microoperations*

Logic and Computer Dealgn Fundamentals PowerPoint<sup>®</sup> Stites © 2004 Poersun Education, Inc.

Chapter 7 - Part 1 9

### **Register Notation**



- Letters and numbers denotes a register (ex. R2, PC, IR)
- Parentheses () denotes a range of register bits (ex. R1(1), PC(7:0), AR(L))
- Arrow (←) denotes data transfer (ex. R1 ← R2, PC(L) ← R0)
- Comma separates parallel operations
- Brackets [] Specifies a memory address (ex. R0 ← M[AR], R3 M[PC] )

Logic and Computer Design Fundamentals PowerPoint<sup>®</sup> Sides © 2004 Poerson Education, Inc.

### **Conditional Transfer**



Logic and Computer Design Fundamentals PowerPoint® Stides © 2004 Pearson Education, Inc.

Chapter 7 - Part 1 11

### **Microoperations**

- Logical Groupings:
  - Transfer move data from one set of registers to another
  - Arithmetic perform arithmetic on data in registers
  - Logic manipulate data or use bitwise logical operations
  - Shift shift data in registers

#### **Arithmetic operations**

- + Addition
- Subtraction
- \* Multiplication
- / Division

#### Logical operations

- ✓ Logical OR
  - ∧ Logical AND
  - $\oplus$  Logical Exclusive OR
    - Not

Logic and Computer Design Fundamentals PowerPoint<sup>®</sup> Sildes © 2004 Poerson Education, Inc.

### **Example Microoperations**



Logic and Computer Design Fundamentals PowerPoint® Stides © 2004 Peerson Education, Inc.

Chapter 7 - Part 1 13

**Example Microoperations (Continued)** 

- Take the 1's Complement of the contents of R2 and place it in the PC.
- PC  $\leftarrow \overline{\mathbf{R2}}$
- On condition K1 <u>OR</u> K2, the content of R1 is <u>Logic bitwise Ored</u> with the content of R3 and the result placed in R1.
- (K1 + K2):  $R1 \leftarrow R1 \lor R3$
- NOTE: "+" (as in K<sub>1</sub> + K<sub>2</sub>) and means "OR." In R1 ← R1 + R3, + means "plus."

### **Control Expressions**

- The <u>control expression</u> for an operation appears to the left of the operation and is separated from it by a colon
- Control expressions specify the <u>logical condition</u> for the operation to occur
- Control expression values of:
  - Logic "1" -- the operation occurs.
  - Logic "0" -- the operation is does not occur.

Logis and Computer Denign Fundamentals PowerPoint<sup>03</sup> Stides © 2004 Poerson Education, Inc.

- Example:  $\overline{X}$  K1 : R1  $\leftarrow$  R1 + R2
- $X K1: R1 \leftarrow R1 + \overline{R2} + 1$
- Variable K1 enables the add or subtract operation.
- If X =0, then X =1 so
   X K1 = 1, activating the addition of R1 and R2.
- If X = 1, then X K1 = 1, activating the addition of R1 and the two's complement of R2 (subtract).

Chapter 7 - Part 1 15

# **Arithmetic Microoperations**

| From  | Symbolic Designation                                              | Description            |
|-------|-------------------------------------------------------------------|------------------------|
| Table | $R0 \leftarrow R1 + R2$                                           | Addition               |
| 7-3:  | $R0 \leftarrow \overline{R1}$                                     | <b>Ones Complement</b> |
|       | $R0 \leftarrow \overline{R1} + 1$                                 | Two's Complement       |
|       | $\mathbf{R0} \leftarrow \mathbf{R2} + \mathbf{\overline{R1}} + 1$ | R2 minus R1 (2's Comp) |
|       | $R1 \leftarrow R1 + 1$                                            | Increment (count up)   |
|       | $R1 \leftarrow R1 - 1$                                            | Decrement (count down) |

- Note that any register may be specified for source 1, source 2, or destination.
- These simple microoperations operate on the whole word

# **Logical Microoperations**

### From Table 7-4:

| Symbolic<br>Designation                               | Description                     |
|-------------------------------------------------------|---------------------------------|
| $R0 \leftarrow \overline{R1}$                         | Bitwise NOT                     |
| $\mathbf{R0} \leftarrow \mathbf{R1} \lor \mathbf{R2}$ | Bitwise OR (sets bits)          |
| $R0 \leftarrow R1 \land R2$                           | Bitwise AND (clears bits)       |
| $R0 \leftarrow R1 \oplus R2$                          | Bitwise EXOR (complements bits) |

Logic and Computer Denign Fundamentals PowerPoint<sup>01</sup> Stides © 2004 Poerson Education, Inc.

Chapter 7 - Part 1 17

### Logical Microoperations (continued)

- Let R1 = 10101010, and R2 = 11110000
- Then after the operation, R0 becomes:

| R0       | Operation                     |
|----------|-------------------------------|
| 01010101 | $R0 \leftarrow \overline{R1}$ |
| 11111010 | $R0 \leftarrow R1 \lor R2$    |
| 10100000 | $R0 \leftarrow R1 \land R2$   |
| 01011010 | $R0 \leftarrow R1 \oplus R2$  |

### **Shift Microoperations**

- From Table 7-5:
- Let R2 = 11001001
- Then after the operation, R1 becomes:

| Symbolic<br>Designation | Description           |
|-------------------------|-----------------------|
| $R1 \leftarrow sl R2$   | Shift Left            |
| R1 ← sr R2              | Shift Right           |
| R1                      | Operation             |
| 10010010                | $R1 \leftarrow sl R2$ |
| 01100100                | R1 ← sr R2            |

- Note: These shifts "zero fill". Sometimes a separate flip-flop is used to provide the data shifted in, or to "catch" the data shifted out.
- Other shifts are possible (rotates, arithmetic) (see Chapter 11).

Logic and Computer Design Fundamentals PowerPoint® Stides © 2004 Pearson Education, Inc.

Chapter 7 - Part 1 19

# **Register Transfer Structures**

- <u>Multiplexer-Based Transfers</u> Multiple inputs are selected by a multiplexer dedicated to the register
- <u>Bus-Based Transfers</u> Multiple inputs are selected by a shared multiplexer driving a bus that feeds inputs to multiple registers
- <u>Three-State Bus</u> Multiple inputs are selected by 3-state drivers with outputs connected to a bus that feeds multiple registers
- <u>Other Transfer Structures</u> Use multiple multiplexers, multiple buses, and combinations of all the above

### **Multiplexer-Based Transfers**

 Multiplexers connected to register inputs produce flexible transfer structures (Note: Clocks are omitted for clarity)



Chapter 7 - Part 1 21

### **Shift Registers**

- Shift Registers move data laterally within the register toward its MSB or LSB position
- In the simplest case, the shift register is simply a set of D flip-flops connected in a row like this:



- Data input, In, is called a *serial input* or the *shift right input*.
- Data output, Out, is often called the *serial output*.
- The vector (A, B, C, Out) is called the *parallel output*.

Logic and Computer Dealgn Fundamentals PowerPoint<sup>®</sup> Stides © 2004 Poerson Education, Inc.

### Shift Registers (continued)

- The behavior of the serial shift register is given in the listing on the lower right
- T0 is the register state just before the first clock pulse occurs
- T1 is after the first pulse and before the second.
- Initially unknown states are denoted by "?"
- Complete the last three rows of the table

Logic and Computer Design Fundamentals PowerPoint® Sildss © 2004 Poerson Education, Inc.



1

0

1

Chapter 7 - Part 1 23

?

### **Parallel Load Shift Registers**

**T3** 

**T4** 

**T5** 

**T6** 

0

1

1 1

- By adding a mux between each shift register stage, data can be shifted or loaded
   If SUMPT is laws
- If SHIFT is low, SHIFT A and B are CP replaced by the data on D<sub>A</sub> and D<sub>B</sub> lines, else data shifts right on each clock.
- By adding more bits, we can make *n*-bit parallel load shift registers.
- A parallel load shift register with an added "hold" operation that stores data unchanged is given in Figure 7-10 of the text.

Logic and Computer Design Fundamentals PowerPoint<sup>®</sup> Slides © 2004 Pearson Education, Inc.

### **Shift Registers with Additional Functions**

- By placing a 4-input multiplexer in front of each D flipflop in a shift register, we can implement a circuit with shifts right, shifts left, parallel load, hold.
- Shift registers can also be designed to shift more than a single bit position right or left
- Shift register can be designed to shift a variable number of bit positions specified by a variable called a *shift amount*.

Logic and Computer Design Fundamentals PowerPoint<sup>®</sup> Stides © 2004 Pearson Education, Inc.

Chapter 7 - Part 1 25

# **Terms of Use**

- © 2004 by Pearson Education, Inc. All rights reserved.
- The following terms of use apply in addition to the standard Pearson Education <u>Legal Notice</u>.
- Permission is given to incorporate these materials into classroom presentations and handouts only to instructors adopting Logic and Computer Design Fundamentals as the course text.
- Permission is granted to the instructors adopting the book to post these
  materials on a protected website or protected ftp site in original or
  modified form. All other website or ftp postings, including those
  offering the materials for a fee, are prohibited.
- You may not remove or in any way alter this Terms of Use notice or any trademark, copyright, or other proprietary notice, including the copyright watermark on each slide.
- Return to Title Page