



## Chapter 7: Digital Components

Prof. Ben Lee  
Oregon State University  
School of Electrical Engineering and Computer Science

## Chapter Goals

- Review basic digital design concepts:
  - Designing basic digital components using logic gates and memory elements:
    - Decoders/encoders, multiplexers, counters, registers, memories, and Arithmetic and Logic Units (ALUs).
- Understand that these digital components represent fundamental building blocks for any digital system, especially processor (microarchitecture) design:
  - Modular design.

## Contents

- 7.1 Introduction
- 7.2 Multiplexers
- 7.3 Decoders
- 7.4 Memory Elements
- 7.5 Registers
- 7.6 Register File

### 7.1 Introduction

# Basic Digital Components

- Multiplexors
- Decoders/encoders
- Registers
- Memories
- ...later we will see Arithmetic and Logic Units (ALUs)

AVR Microarchitecture



Chapter 7: Digital Components

5

## 7.2 Multiplexer

Chapter 7: Digital Components

6

## Multiplexors

Use to choose among multiple input sources.



Chapter 7: Digital Components

7

## Multiplexors

- $2^n$  data inputs,  $n$  control inputs, one output.
- Control signal pattern forms binary index of input connected to output.



Chapter 7: Digital Components

8

## Multiplexors (cont.)

- 2:1 MUX:  $O = S' I_0 + S I_1$
- 4:1 MUX:  $O = S_1' S_0' I_0 + S_1' S_0 I_1 + S_1 S_0' I_2 + S_1 S_0 I_3$
- 8:1 MUX:  $O = S_2' S_1' S_0' I_0 + S_2' S_1' S_0 I_1 + S_2' S_1 S_0' I_2 + S_2' S_1 S_0 I_3 + S_2 S_1' S_0' I_4 + S_2 S_1' S_0 I_5 + S_2 S_1 S_0' I_6 + S_2 S_1 S_0 I_7$



Chapter 7: Digital Components

9

## Cascading Multiplexors

- Large multiplexers implemented by cascading smaller ones.



Chapter 7: Digital Components

10

## 7.3 Decoder

Chapter 7: Digital Components

11

## Decoders

- Single data input,  $k$  control inputs,  $2^k$  outputs.
- Used to select one of  $2^k$  components:
  - RAM cells in memory
  - Registers in register file



Chapter 7: Digital Components

12

## 2-to-4 Decoder

- Implementing a 2-to-4 decoder

Truth Table

| E | S <sub>1</sub> | S <sub>0</sub> | O <sub>3</sub> | O <sub>2</sub> | O <sub>1</sub> | O <sub>0</sub> |
|---|----------------|----------------|----------------|----------------|----------------|----------------|
| 1 | 0              | 0              | 0              | 0              | 0              | 1              |
| 1 | 0              | 1              | 0              | 0              | 1              | 0              |
| 1 | 1              | 0              | 0              | 1              | 0              | 0              |
| 1 | 1              | 1              | 1              | 0              | 0              | 0              |

$$O_0 = E \cdot S_1' \cdot S_0'$$

$$O_1 = E \cdot S_1' \cdot S_0$$

$$O_2 = E \cdot S_1 \cdot S_0'$$

$$O_3 = E \cdot S_1 \cdot S_0$$



We can also implement active low enable

## 7.4 Memory Elements

# Memory Elements

- Bi-stable elements used in
    - Program and Data memories
    - Registers
    - Register File



Chapter 7: Digital Components

# Memory Element: S-R Latch



| S | R | Q           |
|---|---|-------------|
| 0 | 0 | hold        |
| 0 | 1 | 0           |
| 1 | 0 | 1           |
| 1 | 1 | not allowed |



| $\overline{S}$ | $\overline{R}$ | Q           |
|----------------|----------------|-------------|
| 0              | 0              | not allowed |
| 0              | 1              | 1           |
| 1              | 0              | 0           |
| 1              | 1              | hold        |

## Chapter 7: Digital Components

## S-R Latch Operation

$S=0, R=0$  (hold), initially  $Q=1$



$S=0, R=1$  (reset), initially  $Q=1$



$S=1, R=0$  (set), initially  $Q=0$



$S=1, R=1$  (not allowed), initially  $Q=1$



Chapter 7: Digital Components

17

## S-R Latch with Enable

Circuit



Function Table

| C | S | R | Q           |
|---|---|---|-------------|
| 0 | X | X | No Change   |
| 1 | 0 | 0 | No Change   |
| 1 | 0 | 1 | 0           |
| 1 | 1 | 0 | 1           |
| 1 | 1 | 1 | Not allowed |

Logic Symbol



Chapter 7: Digital Components

18

## D Latch



Chapter 7: Digital Components

19

## Negative Edge-Triggered D-FF



Chapter 7: Digital Components

20

## Negative Edge-Triggered D-FF Operation



Chapter 7: Digital Components

21

## Positive Edge-Triggered D-FF



Chapter 7: Digital Components

22

## Edge-Triggered D-FF /w Enable



Chapter 7: Digital Components

23

## 7.4 Registers

Chapter 7: Digital Components

24

# Registers

- Used to temporary hold and separate information among various parts of the datapath.



Chapter 7: Digital Components

25

## ***n*-bit Register /w Load Enable**

A set of  
commonly  
clocked  
D flip-flops



Chapter 7: Digital Components

26

## Shift Registers



Shift Left (down)



Shift Right (up)

Chapter 7: Digital Components

27

## Bi-Directional Shift Register /w Parallel Load



| Function    | Control Input  |                | Next State     |                |                |                |  |
|-------------|----------------|----------------|----------------|----------------|----------------|----------------|--|
|             | S <sub>1</sub> | S <sub>0</sub> | Q <sub>3</sub> | Q <sub>2</sub> | Q <sub>1</sub> | Q <sub>0</sub> |  |
| Hold        | 0              | 0              | Q <sub>3</sub> | Q <sub>2</sub> | Q <sub>1</sub> | Q <sub>0</sub> |  |
| Shift right | 0              | 1              | R_IN           | Q <sub>3</sub> | Q <sub>2</sub> | Q <sub>1</sub> |  |
| Shift left  | 1              | 0              | Q <sub>2</sub> | Q <sub>1</sub> | Q <sub>0</sub> | L_IN           |  |
| Load        | 1              | 1              | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |  |

Chapter 7: Digital Components

28

## 7.5 Memory

Chapter 7: Digital Components

29

## Memory

### Program and Data memories



Chapter 7: Digital Components

30

## Memory Cell

- Static RAM (SRAM)
  - Fast
  - Practically a D-FF.
  - Used in Registers and Instruction and Data Caches.
- Dynamic RAM (DRAM)
  - Need to be refreshed periodically.
  - Used in Main Memory



Chapter 7: Digital Components

31

## SRAM Structure



Chapter 7: Digital Components

32

## SRAM Operation: Read



Chapter 7: Digital Components

33

## SRAM Operation: Write



Chapter 7: Digital Components

34

## Building Larger Memory

256K x 8 RAM  
Using four 64K x 8 RAMs



Chapter 7: Digital Components

35

## Building Wider Memory

256K x 16 RAM  
Using two 256K x 8 RAMs



Chapter 7: Digital Components

36

## 7.6 Register File

Chapter 7: Digital Components

37

## Register File

Storage buffer between  
ALU and Memory



Chapter 7: Digital Components

38

## Register File

2 Read-port,  
2 Write-port  
X, Y, & Z-registers



Chapter 7: Digital Components

39

## Questions?



Chapter 7: Digital Components

40