

# **Chapter 6**

# **Registers and Register Transfers**

**Dosen: Erdefi Rakun dan Tim Dosen PSD  
Fasilkom UI**



# 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

*Note: These materials are taken from © 2008 by Pearson Education, Inc*

# 6-1 Registers and Load Enable

- Register - a collection 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

# Example: 2-bit Register

- How many states are there?
- How many input combinations?  
Output combinations?
- What is the output function?
- What is the next state function?
- Moore or Mealy?

**State Table:**



| Current State<br>A1 A0 | Next State<br>A1(t+1) A0(t+1)<br>For In1 In0 = | Output<br>(=A1 A0)<br>Y1 Y0 |
|------------------------|------------------------------------------------|-----------------------------|
| 0 0                    | 00 01 10 11                                    | 0 0                         |
| 0 1                    | 00 01 10 11                                    | 0 1                         |
| 1 0                    | 00 01 10 11                                    | 1 0                         |
| 1 1                    | 00 01 10 11                                    | 1 1                         |

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

# Example: 4-bit Register



Load  
Clock  
C inputs (clock inputs  
of flip-flops)

(c) Load control input



# 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

# 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, that for (0,0) applied, store their state
- Load 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 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 = 1, loads input values (load new values)



# 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,  
*Load=0* loads register contents (hold current values)
- Hardware more complex than clock gating, but free of timing problems





# 6-2 Register Transfers

- A digital system is a sequential circuit made up of interconnected flip flops and gates
- Partition of digital system:
  - Datapath, which perform data processing operation
  - Control unit, which determines the sequence of data-processing operations



# 6-3 Register Transfer Operations

- Datapath are defined by their registers and the operations performed on binary data stored in the registers.
- **Register transfer operations:**
  - The movement of data stored in register
  - Processing performed on the data stored in register
- Register transfer operations are specified by three basic components:
  1. The set of registers in the system
  2. The operation that are performed on the data stored in the registers
  3. The control that supervises the sequence of operation in the system
- Elementary Operations -- load, count, shift, add, bitwise "OR", etc.
  - Elementary operations called *microoperations*

# 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), PC(L))
- Arrow ( $\leftarrow$ ) – denotes data transfer (ex.  $R1 \leftarrow R2$ ,  $PC(L) \leftarrow R0$ )
- Comma – separates parallel operations
- Brackets [ ] – Specifies a memory address (ex.  $R0 \leftarrow M[AR]$ ,  $R3 \leftarrow M[PC]$  )

# Conditional Transfer

- If  $(K1 = 1)$  then  $(R2 \leftarrow R1)$  is shortened to  
K1:  $(R2 \leftarrow R1)$  where K1 is a control variable specifying a conditional execution of the microoperation.



# 6-4 Register Transfer in Verilog

□ TABLE 6-2  
Textbook RTL, VHDL, and Verilog Symbols for Register Transfers

| Operation                | Text RTL     | VHDL                      | Verilog                |
|--------------------------|--------------|---------------------------|------------------------|
| Combinational assignment | =            | <= (concurrent)           | assign = (nonblocking) |
| Register transfer        | ←            | <= (concurrent)           | <= (nonblocking)       |
| Addition                 | +            | +                         | +                      |
| Subtraction              | −            | −                         | −                      |
| Bitwise AND              | ∧            | and                       | &                      |
| Bitwise OR               | ∨            | or                        |                        |
| Bitwise XOR              | ⊕            | xor                       | ^                      |
| Bitwise NOT              | – (overline) | not                       | ~                      |
| Shift left (logical)     | Sl           | sll                       | <<                     |
| Shift right (logical)    | Sr           | srl                       | >>                     |
| Vectors/registers        | $A(3:0)$     | $A(3 \text{ down to } 0)$ | $A[3:0]$               |
| Concatenation            |              | &                         | {,}                    |

# 6-5 Microoperations

- Logical Groupings:
  - Transfer - move data from one register 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
- ⊕ Logical Exclusive OR
- ¬ Not

# Example Microoperations

- Add the content of R1 to the content of R2 and place the result in R1.

$$R1 \leftarrow R1 + R2$$

- Multiply the content of R1 by the content of R6 and place the result in PC.

$$PC \leftarrow R1 * R6$$

- Exclusive OR the content of R1 with the content of R2 and place the result in R1.

$$R1 \leftarrow R1 \oplus R2$$

# Example Microoperations (Continued)

- Take the 1's Complement of the contents of R2 and place it in the PC.

$$PC \leftarrow \overline{R2}$$

- On condition  $K1 \text{ OR } K2$ , the content of R1 is Logic bitwise Ored with the content of R3 and the result placed in R1.

$$(K1 + K2): R1 \leftarrow R1 \vee R3$$

*NOTE: "+" (as in  $K_1 + K_2$ ) and means "OR."  
In  $R1 \leftarrow R1 + R3$ , + means "plus."*

# Control Expressions

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

- 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  $\overline{X} = 1$  so  $\overline{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).

# Implementation of Add and Subtract microoperations



# Arithmetic Microoperations

- From Table 7-3:

| Symbolic Designation                   | Description                |
|----------------------------------------|----------------------------|
| $R0 \leftarrow R1 + R2$                | Addition                   |
| $R0 \leftarrow \overline{R1}$          | Ones Complement            |
| $R0 \leftarrow \overline{R1} + 1$      | Two's Complement           |
| $R0 \leftarrow R2 + \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 Designation            | Description                     |
|---------------------------------|---------------------------------|
| $R_0 \leftarrow \bar{R}_1$      | Bitwise NOT                     |
| $R_0 \leftarrow R_1 \vee R_2$   | Bitwise OR (sets bits)          |
| $R_0 \leftarrow R_1 \wedge R_2$ | Bitwise AND (clears bits)       |
| $R_0 \leftarrow R_1 \oplus R_2$ | Bitwise EXOR (complements bits) |

# Logical Microoperations (continued)

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

| <b>R0</b>       | <b>Operation</b>                                |
|-----------------|-------------------------------------------------|
| <b>01010101</b> | <b><math>R0 \leftarrow \overline{R1}</math></b> |
| <b>11111010</b> | <b><math>R0 \leftarrow R1 \vee R2</math></b>    |
| <b>10100000</b> | <b><math>R0 \leftarrow R1 \wedge R2</math></b>  |
| <b>01011010</b> | <b><math>R0 \leftarrow R1 \oplus R2</math></b>  |

# Shift Microoperations

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

| Symbolic Designation  | Description |
|-----------------------|-------------|
| $R1 \leftarrow sl R2$ | Shift Left  |
| $R1 \leftarrow sr R2$ | Shift Right |

| R1       | Operation             |
|----------|-----------------------|
| 10010010 | $R1 \leftarrow sl R2$ |
| 01100100 | $R1 \leftarrow 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 10).

# 6-6 Microoperations on a single Register

# Register Transfer Structures

- Multiplexer-Based Transfers - Multiple inputs are selected by a multiplexer dedicated to the register
- Bus-Based Transfers - Multiple inputs are selected by a shared multiplexer driving a bus that feeds inputs to multiple registers
- Three-State Bus - Multiple inputs are selected by 3-state drivers with outputs connected to a bus that feeds multiple registers
- Other Transfer Structures - 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)
- The transfers are:  $K1: R0 \leftarrow R1$   
 $K2 \cdot \bar{K1}: R0 \leftarrow R2$



(a) Block diagram



(b) Detailed logic

# 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*.

# 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



| CP | In | A | B | C | Out |
|----|----|---|---|---|-----|
| T0 | 0  | ? | ? | ? | ?   |
| T1 | 1  | 0 | ? | ? | ?   |
| T2 | 1  | 1 | 0 | ? | ?   |
| T3 | 0  | 1 | 1 | 0 | ?   |
| T4 | 1  |   |   |   |     |
| T5 | 1  |   |   |   |     |
| T6 | 1  |   |   |   |     |

# Parallel Load Shift Registers

- By adding a mux between each shift register stage, data can be shifted or loaded
- If SHIFT is low, A and B are replaced by the data on  $D_A$  and  $D_B$  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.



# Parallel Load Shift Registers



□ **FIGURE 7-10**  
Shift Register with Parallel Load

# Shift Registers with Additional Functions

- By placing a 4-input multiplexer in front of each D flip-flop 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 registers can be designed to shift a variable number of bit positions specified by a variable called a *shift amount*.

# Shift Registers with Additional Functions



□ **FIGURE 7-11**  
Bidirectional Shift Register with Parallel Load

# Counters

- Counters are sequential circuits which "count" through a specific state sequence. They can count up, count down, or count through other fixed sequences. Two distinct types are in common usage:
- Ripple Counters
  - Clock connected to the flip-flop clock input on the LSB bit flip-flop
  - For all other bits, a flip-flop output is connected to the clock input, thus circuit is not truly synchronous!
  - Output change is delayed more for each bit toward the MSB.
  - Resurgent because of low power consumption
- Synchronous Counters
  - Clock is directly connected to the flip-flop clock inputs
  - Logic is used to implement the desired state sequencing

# Ripple Counter

- How does it work?
  - When there is a positive edge on the clock input of A, A complements
  - The clock input for flip-flop B is the complemented output of flip-flop A
  - When flip A changes from 1 to 0, there is a positive edge on the clock input of B causing B to complement



# Ripple Counter (continued)

- The arrows show the cause-effect relationship from the prior slide =>
- The corresponding sequence of states =>  $(B,A) = (0,0), (0,1), (1,0), (1,1), (0,0), (0,1), \dots$
- Each additional bit, C, D, ... behaves like bit B, changing half as frequently as the bit before it.
- For 3 bits:  $(C,B,A) = (0,0,0), (0,0,1), (0,1,0), (0,1,1), (1,0,0), (1,0,1), (1,1,0), (1,1,1), (0,0,0), \dots$



# 4-Bit Ripple Counter



# Ripple Counter (continued)

- These circuits are called *ripple counters* because each edge sensitive transition (positive in the example) causes a change in the next flip-flop's state.
- The changes “ripple” upward through the chain of flip-flops, i. e., each transition occurs after a clock-to-output delay from the stage before.
- To see this effect in detail look at the waveforms on the next slide.

# Ripple Counter (continued)

- Starting with  $C = B = A = 1$ , equivalent to  $(C,B,A) = 7$  base 10, the next clock increments the count to  $(C,B,A) = 0$  base 10. In fine timing detail:
  - The clock to output delay  $t_{PHL}$  causes an increasing delay from clock edge for each stage transition.
  - Thus, the count “ripples” from least to most significant bit.
  - For  $n$  bits, total worst case delay is  $n t_{PHL}$ .



# Synchronous Counters

- To eliminate the "ripple" effects, use a common clock for each flip-flop and a combinational circuit to generate the next state.
- For an up-counter, use an incrementer =>



# Synchronous Counters (continued)

- Internal details => Incrementer
- Internal Logic
  - XOR complements each bit
  - AND chain causes complement of a bit if all bits toward LSB from it equal 1
- Count Enable
  - Forces all outputs of AND chain to 0 to “hold” the state
- Carry Out
  - Added as part of incrementer
  - Connect to Count Enable of additional 4-bit counters to form larger counters



(a) Logic Diagram-Serial Gating

# Synchronous Counters (continued)

- Carry chain
  - series of AND gates through which the carry “ripples”
  - Yields long path delays
  - Called *serial gating*
- Replace AND carry chain with ANDs => in parallel
  - Reduces path delays
  - Called *parallel gating*
  - Like carry lookahead
  - Lookahead can be used on COs and ENs to prevent long paths in large counters
- Symbol for Synchronous Counter →



# Other Counters

- See text for:
  - *Down Counter* - counts downward instead of upward
  - *Up-Down Counter* - counts up or down depending on value a control input such as Up/Down
  - *Parallel Load Counter* - Has parallel load of values available depending on control input such as Load
- *Divide-by-n (Modulo n) Counter*
  - Count is remainder of division by  $n$ ;  $n$  may not be a power of 2 or
  - Count is arbitrary sequence of  $n$  states specifically designed state-by-state
  - Includes modulo 10 which is the *BCD counter*

# Counter with Parallel Load

- Add path for input data
  - enabled for Load = 1
- Add logic to:
  - disable count logic for Load = 1
  - disable feedback from outputs for Load = 1
  - enable count logic for Load = 0 and Count = 1
- The resulting function table:

| Load | Count | Action                       |
|------|-------|------------------------------|
| 0    | 0     | <b>Hold Stored Value</b>     |
| 0    | 1     | <b>Count Up Stored Value</b> |
| 1    | X     | <b>Load D</b>                |



# Design Example: Synchronous BCD

- Use the sequential logic model to design a synchronous BCD counter with D flip-flops
- State Table =>
- Input combinations 1010 through 1111 are don't cares

| Present State |       |       |       | Next State       |                  |                  | Output           |     |
|---------------|-------|-------|-------|------------------|------------------|------------------|------------------|-----|
| $Q_8$         | $Q_4$ | $Q_2$ | $Q_1$ | $D_8 = Q_8(t+1)$ | $D_4 = Q_4(t+1)$ | $D_2 = Q_2(t+1)$ | $D_1 = Q_1(t+1)$ | $Y$ |
| 0             | 0     | 0     | 0     | 0                | 0                | 0                | 1                | 0   |
| 0             | 0     | 0     | 1     | 0                | 0                | 1                | 0                | 0   |
| 0             | 0     | 1     | 0     | 0                | 0                | 1                | 1                | 0   |
| 0             | 0     | 1     | 1     | 0                | 1                | 0                | 0                | 0   |
| 0             | 1     | 0     | 0     | 0                | 1                | 0                | 1                | 0   |
| 0             | 1     | 0     | 1     | 0                | 1                | 1                | 0                | 0   |
| 0             | 1     | 1     | 0     | 0                | 1                | 1                | 1                | 0   |
| 0             | 1     | 1     | 1     | 1                | 0                | 0                | 0                | 0   |
| 1             | 0     | 0     | 0     | 1                | 0                | 0                | 1                | 0   |
| 1             | 0     | 0     | 1     | 0                | 0                | 0                | 0                | 1   |

# Synchronous BCD (continued)

- Use K-Maps to two-level optimize the next state equations and manipulate into forms containing XOR gates:

$$D_1 = \overline{Q_1}$$

$$D_2 = Q_2 \oplus \overline{Q_1} \overline{Q_8}$$

$$D_4 = Q_4 \oplus Q_1 Q_2$$

$$D_8 = Q_8 \oplus (Q_1 Q_8 + Q_1 Q_2 Q_4)$$

- The logic diagram can be draw from these equations
  - An asynchronous or synchronous reset should be added
- What happens if the counter is perturbed by a power disturbance or other interference and it enters a state other than 0000 through 1001?

# Synchronous BCD (continued)

- Find the actual values of the six next states for the don't care combinations from the equations
- Find the overall state diagram to assess behavior for the don't care states (states in decimal)

| Present State | Next State  |
|---------------|-------------|
| Q8 Q4 Q2 Q1   | Q8 Q4 Q2 Q1 |
| 1 0 1 0       | 1 0 1 1     |
| 1 0 1 1       | 0 1 1 0     |
| 1 1 0 0       | 1 1 0 1     |
| 1 1 0 1       | 0 1 0 0     |
| 1 1 1 0       | 1 1 1 1     |
| 1 1 1 1       | 0 0 1 0     |



# Synchronous BCD (continued)

- For the BCD counter design, if an invalid state is entered, return to a valid state occurs within two clock cycles
- Is this adequate? If not:
  - Is a signal needed that indicates that an invalid state has been entered? What is the equation for such a signal?
  - Does the design need to be modified to return from an invalid state to a valid state in one clock cycle?
  - Does the design need to be modified to return from an invalid state to a specific state (such as 0)?
- The action to be taken depends on:
  - the application of the circuit
  - design group policy
- See pages 244 of the text.

# 6-7 Register Cell Design

- Assume that a register consists of identical cells
- Then register design can be approached as follows:
  - Design representative cell for the register
  - Connect copies of the cell together to form the register
  - Applying appropriate “boundary conditions” to cells that need to be different and contract if appropriate
- Register cell design is the first step of the above process

# Register Cell Specifications

- A register
- Data inputs to the register
- Control input combinations to the register
  - Example 1: Not encoded
    - Control inputs: Load, Shift, Add
    - At most, one of Load, Shift, Add is 1 for any clock cycle  
 $(0,0,0), (1,0,0), (0,1,0), (0,0,1)$
  - Example 2: Encoded
    - Control inputs: S1, S0
    - All possible binary combinations on S1, S0  
 $(0,0), (0,1), (1,0), (1,1)$

# Register Cell Specifications

- A set of register functions (typically specified as register transfers)
  - Example:
    - Load:  $A \leftarrow B$
    - Shift:  $A \leftarrow sr B$
    - Add:  $A \leftarrow A + B$
- A hold state specification
  - Example:
    - Control inputs: Load, Shift, Add
    - If all control inputs are 0, hold the current register state

# Example 1: Register Cell Design

- Register A (m-bits) Specification:
  - Data input: B
  - Control inputs (CX, CY)
  - Control input combinations (0,0), (0,1) (1,0)
  - Register transfers:
    - CX:  $A \leftarrow B \vee A$
    - CY : $A \leftarrow B \oplus A$
    - Hold state: (0,0)

# Example 1: Register Cell Design (continued)

- Load Control  
 $\text{Load} = \text{CX} + \text{CY}$
- Since all control combinations appear as if encoded (0,0), (0,1), (1,0) can use multiplexer without encoder:

$$S1 = CX$$

$$S0 = CY$$

$$D0 = A_i$$

$$D1 = A_i \leftarrow B_i \oplus A_i$$

$$D2 = A_i \leftarrow B_i \vee A_i \quad \begin{array}{l} \text{Hold } A \\ CY = 1 \\ CX = 1 \end{array}$$

- Note that the decoder part of the 3-input multiplexer can be shared between bits if desired

# Sequential Circuit Design Approach

- Find a state diagram or state table
  - Note that there are only two states with the state assignment equal to the register cell output value
- Use the design procedure in Chapter 5 to complete the cell design
- For optimization:
  - Use K-maps for up to 4 to 6 variables
  - Otherwise, use computer-aided or manual optimization

# Example 1 Again

- State Table:

|                      | <b>Hold</b>   | <b>A<sub>i</sub> v B<sub>i</sub></b> |                          | <b>A<sub>i</sub>⊕B<sub>i</sub></b> |                          |
|----------------------|---------------|--------------------------------------|--------------------------|------------------------------------|--------------------------|
| <b>A<sub>i</sub></b> | <b>CX = 0</b> | <b>CX = 1</b>                        | <b>CX = 1</b>            | <b>CY = 1</b>                      | <b>CY = 1</b>            |
|                      | <b>CY = 0</b> | <b>B<sub>i</sub> = 0</b>             | <b>B<sub>i</sub> = 1</b> | <b>B<sub>i</sub> = 0</b>           | <b>B<sub>i</sub> = 1</b> |
| <b>0</b>             | <b>0</b>      | <b>0</b>                             | <b>1</b>                 | <b>0</b>                           | <b>1</b>                 |
| <b>1</b>             | <b>1</b>      | <b>1</b>                             | <b>1</b>                 | <b>1</b>                           | <b>0</b>                 |

- Four variables give a total of 16 state table entries
- By using:
  - Combinations of variable names and values
  - Don't care conditions (for CX = CY = 1)only 8 entries are required to represent the 16 entries

## State Table 1-dimensi

|  |  | Input |       | Next State |       |            |
|--|--|-------|-------|------------|-------|------------|
|  |  | $C_x$ | $C_y$ | $A_i$      | $B_i$ | $A_i(t+1)$ |
|  |  | 0     | 0     | 0          | 0     | 0          |
|  |  | 0     | 0     | 0          | 1     | 0          |
|  |  | 0     | 0     | 1          | 0     | 1          |
|  |  | 0     | 0     | 1          | 1     | 1          |
|  |  | 0     | 1     | 0          | 0     | 0          |
|  |  | 0     | 1     | 0          | 1     | 1          |
|  |  | 0     | 1     | 1          | 0     | 1          |
|  |  | 0     | 1     | 1          | 1     | 0          |
|  |  | 1     | 0     | 0          | 0     | 0          |
|  |  | 1     | 0     | 0          | 1     | 1          |
|  |  | 1     | 0     | 1          | 0     | 1          |
|  |  | 1     | 0     | 1          | 1     | 1          |
|  |  | 1     | 1     | 0          | 0     | X          |
|  |  | 1     | 1     | 0          | 1     | X          |
|  |  | 1     | 1     | 1          | 0     | X          |
|  |  | 1     | 1     | 1          | 1     | X          |

## State Table 2-dimensi

|                         | <b>Hold</b>                | <b><math>A_i \vee B_i</math></b> |                             | <b><math>A_i + B_i</math></b> |                             |
|-------------------------|----------------------------|----------------------------------|-----------------------------|-------------------------------|-----------------------------|
|                         |                            | <b><math>CX = 0</math></b>       | <b><math>CX = 1</math></b>  | <b><math>CY = 1</math></b>    | <b><math>CY = 1</math></b>  |
| <b><math>A_i</math></b> | <b><math>CY = 0</math></b> | <b><math>B_i = 0</math></b>      | <b><math>B_i = 1</math></b> | <b><math>B_i = 0</math></b>   | <b><math>B_i = 1</math></b> |
| <b>0</b>                | <b>0</b>                   | <b>0</b>                         | <b>1</b>                    | <b>0</b>                      | <b>1</b>                    |
| <b>1</b>                | <b>1</b>                   | <b>1</b>                         | <b>1</b>                    | <b>1</b>                      | <b>0</b>                    |

# Example 1 Again (continued)

- K-map - Use variable ordering CX, CY, Ai, Bi and assume a D flip-flop



# Example 1 Again (continued)

- The resulting SOP equation:

$$D_i = CX B_i + CY \overline{A}_i B_i + A_i \overline{B}_i + \overline{CY} A_i$$

- Using factoring and DeMorgan's law:

$$\begin{aligned} D_i &= CX B_i + \overline{A}_i (CY B_i) + A_i (\overline{CY} B_i) \\ D_i &= CX B_i + A_i \oplus (CY B_i) \end{aligned}$$

The gate input cost per cell =  $2 + 8 + 2 + 2 = 14$

- The gate input cost per cell for the previous version is:

Per cell: 19

Shared decoder logic: 8

- Cost gain by sequential design > 5 per cell
- Also, no Enable on the flip-flop makes it cost less



Total Gate cost = 14

Gate cost shared  
Decoder = 8



Gate cost dgn mux = 19

4-to-1 Mux

## 6-8 Multiplexer and Bus-Based Transfers for Multiple Registers

- Multiplexer dedicated to each register
- Shared transfer paths for registers
  - A shared transfer object is called a *bus*  
(Plural: *buses*)
- Bus implementation using:
  - multiplexers
  - three-state nodes and drivers
- In most cases, the number of bits is the length of the receiving register

# Dedicated MUX-Based Transfers

- Multiplexer connected to each register input produces a very flexible transfer structure =>
- Characterize the simultaneous transfers possible with this structure.



# Multiplexer Bus

- A single bus driven by a multiplexer lowers cost, but limits the available transfers =>
- Characterize the simultaneous transfers possible with this structure.
- Characterize the cost savings compared to dedicated multiplexers



# Hi-Impedance Outputs

- Logic gates introduced thus far
  - have 1 and 0 output values,
  - cannot have their outputs connected together, and
  - transmit signals on connections in only one direction.
- Three-state logic adds a third logic value, Hi-Impedance (Hi-Z), giving three states: 0, 1, and Hi-Z on the outputs.
- The presence of a Hi-Z state makes a gate output as described above behave quite differently:
  - “1 and 0” become “1, 0, and Hi-Z”
  - “cannot” becomes “can,” and
  - “only one” becomes “two”

# Hi-Impedance Outputs (continued)

- What is a Hi-Z value?
  - The Hi-Z value behaves as an open circuit
  - This means that, looking back into the circuit, the output appears to be disconnected.
  - It is as if a switch between the internal circuitry and the output has been opened.
- Hi-Z may appear on the output of any gate, but we restrict gates to:
  - a 3-state buffer, or
  - Optional: a transmission gate (See Reading Supplement: More on CMOS Circuit-Level Design), each of which has one data input and one control input.

# The 3-State Buffer

- For the symbol and truth table, IN is the data input, and EN, the control input.
  - For  $\text{EN} = 0$ , regardless of the value on IN (denoted by X), the output value is Hi-Z.
  - For  $\text{EN} = 1$ , the output value follows the input value.
  - Variations:
    - Data input, IN, can be inverted
    - Control input, EN, can be invertedby addition of “bubbles” to signals.



## Truth Table

| <b>EN</b> | <b>IN</b> | <b>OUT</b> |
|-----------|-----------|------------|
| 0         | X         | Hi-Z       |
| 1         | 0         | 0          |
| 1         | 1         | 1          |

# Resolving 3-State Values on a Connection

- Connection of two 3-state buffer outputs, B1 and B0, to a wire, OUT
- Assumption: Buffer data inputs can take on any combination of values 0 and 1
- Resulting Rule: At least one buffer output value must be Hi-Z. Why?
- How many valid buffer output combinations exist?
- What is the rule for  $n$  3-state buffers connected to wire, OUT?
- How many valid buffer output combinations exist?

| Resolution Table |      |      |
|------------------|------|------|
| B1               | B0   | OUT  |
| 0                | Hi-Z | 0    |
| 1                | Hi-Z | 1    |
| Hi-Z             | 0    | 0    |
| Hi-Z             | 1    | 1    |
| Hi-Z             | Hi-Z | Hi-Z |

# 3-State Logic Circuit

- Data Selection Function: If  $s = 0$ ,  $OL = IN0$ , else  $OL = IN1$
- Performing data selection with 3-state buffers:

| EN0 | IN0 | EN1 | IN1 | OL |
|-----|-----|-----|-----|----|
| 0   | X   | 1   | 0   | 0  |
| 0   | X   | 1   | 1   | 1  |
| 1   | 0   | 0   | X   | 0  |
| 1   | 1   | 0   | X   | 1  |
| 0   | X   | 0   | X   | X  |



- Since  $EN0 = \bar{S}$  and  $EN1 = S$ , one of the two buffer outputs is always Hi-Z plus the last row of the table never occurs.

# Three-State Bus

- The 3-input MUX can be replaced by a 3-state node (bus) and 3-state buffers.
- Cost is further reduced, but transfers are limited
- Characterize the simultaneous transfers possible with this structure.
- Characterize the cost savings and compare
- Other advantages?



# Three-State Bus vs Mux Bus



(a) Register with bidirectional  
input–output lines and symbol

(b) Multiplexer bus

(c) Three-state bus using  
registers with bidirectional  
lines

# 6-9 Serial Transfers and Microoperations

- Serial Transfers
  - Used for “narrow” transfer paths
  - Example 1: Telephone or cable line
    - Parallel-to-Serial conversion at source
    - Serial-to-Parallel conversion at destination
  - Example 2: Initialization and Capture of the contents of many flip-flops for test purposes
    - Add shift function to all flip-flops and form large shift register
    - Use shifting for simultaneous Initialization and Capture operations
- Serial microoperations
  - Example 1: Addition
  - Example 2: Error-Correction for CDs

## Serial Transfer

1. The system is transferred or manipulated one bit at a time
2. The serial output of register A is connected to the serial input of register B
3. The serial input of register A receives 0s while its data is transferred to register B
4. The initial content of register B is shifted out through its serial output and is lost
5. The shift control input *Shift* determines when and how many times the registers are shifted.



# Serial Microoperations

- By using two shift registers for operands, a full adder, and a flip flop (for the carry), we can add two numbers serially, starting at the least significant bit.
- Serial addition is a low cost way to add large numbers of operands, since a “tree” of full adder cells can be made to any depth, and each new level doubles the number of operands.
- Other operations can be performed serially as well, such as parity generation/checking or more complex error-check codes.
- Shifting a binary number left is equivalent to multiplying by 2.
- Shifting a binary number right is equivalent to dividing by 2.

# Serial Adder

- The circuit shown uses two shift registers for operands A(3:0) and B(3:0).
- A full adder, and one more flip flop (for the carry) is used to compute the sum.
- The result is stored in the A register and the final carry in the flip-flop
- With the operands and the result in shift registers, a tree of full adders can be used to add a large number of operands. Used as a common digital signal processing technique.



# Serial Adder - Exercise



Use the serial input port to add  $A = 1\ 0\ 0\ 1$

$B = 0\ 1\ 0\ 1$

Input string: ?

| Clock | Register A | Register B | A | B | Cin | Sum | Cout |
|-------|------------|------------|---|---|-----|-----|------|
|       | 0 0 0 0    | 0 0 0 0    | 0 | 0 | 0   | 0   | 0    |
| 1     | 0 0 0 0    | 1 0 0 0    | 0 | 0 | 0   | 0   | 0    |
| 2     |            |            |   |   |     |     |      |
| 3     |            |            |   |   |     |     |      |
| 4     |            |            |   |   |     |     |      |
| 5     |            |            |   |   |     |     |      |
| 6     |            |            |   |   |     |     |      |
| 7     |            |            |   |   |     |     |      |
| 8     |            |            |   |   |     |     |      |
| 9     |            |            |   |   |     |     |      |
| 10    |            |            |   |   |     |     |      |
| 11    |            |            |   |   |     |     |      |
| 12    |            |            |   |   |     |     |      |

| Clock | Register A | Register B | A | B | Cin | Sum | Cout |
|-------|------------|------------|---|---|-----|-----|------|
|       | 0 0 0 0    | 0 0 0 0    | 0 | 0 | 0   | 0   | 0    |
| 1     | 0 0 0 0    | 1 0 0 0    | 0 | 0 | 0   | 0   | 0    |
| 2     | 0 0 0 0    | 0 1 0 0    | 0 | 0 | 0   | 0   | 0    |
| 3     | 0 0 0 0    | 0 0 1 0    | 0 | 0 | 0   | 0   | 0    |
| 4     | 0 0 0 0    | 1 0 0 1    | 0 | 1 | 0   | 1   | 0    |
| 5     | 1 0 0 0    | 1 1 0 0    | 0 | 0 | 0   | 0   | 0    |
| 6     | 0 1 0 0    | 0 1 1 0    | 0 | 0 | 0   | 0   | 0    |
| 7     | 0 0 1 0    | 1 0 1 1    | 0 | 1 | 0   | 1   | 0    |
| 8     | 1 0 0 1    | 0 1 0 1    | 1 | 1 | 0   | 0   | 1    |
| 9     | 0 1 0 0    | 0 0 1 0    | 0 | 0 | 1   | 1   | 0    |
| 10    | 1 0 1 0    | 0 0 0 1    | 0 | 1 | 0   | 1   | 0    |
| 11    | 1 1 0 1    | 0 0 0 0    | 1 | 0 | 0   | 1   | 0    |
| 12    | 1 1 1 0    | 0 0 0 0    | 0 | 0 | 0   | 0   | 0    |