# 250P: Computer Systems Architecture

Lecture 2: Basics of Digital Design

Anton Burtsev October, 2019

#### **Digital Design Basics**

- Two voltage levels high and low (1 and 0, true and false) Hence, the use of binary arithmetic/logic in all computers
- A transistor is a 3-terminal device that acts as a switch



## Logic Blocks

- A logic block has a number of binary inputs and produces a number of binary outputs – the simplest logic block is composed of a few transistors
- A logic block is termed *combinational* if the output is only a function of the inputs
- A logic block is termed *sequential* if the block has some internal memory (state) that also influences the output
- A basic logic block is termed a *gate* (AND, OR, NOT, etc.)

We will only deal with combinational circuits today

#### **Truth Table**

- A truth table defines the outputs of a logic block for each set of inputs
- Consider a block with 3 inputs A, B, C and an output E that is true only if *exactly* 2 inputs are true



#### **Truth Table**

- A truth table defines the outputs of a logic block for each set of inputs
- Consider a block with 3 inputs A, B, C and an output E that is true only if *exactly* 2 inputs are true



#### **Boolean Algebra**

- Equations involving two values and three primary operators:
  - OR : symbol + , X = A + B → X is true if at least one of A or B is true
  - AND : symbol . , X = A . B → X is true if both A and B are true
  - NOT : symbol ,  $X = \overline{A} \rightarrow X$  is the inverted value of A

#### **Boolean Algebra Rules**

- Identity law : A + 0 = A ;  $A \cdot 1 = A$
- Zero and One laws : A + 1 = 1 ; A . 0 = 0
- Inverse laws :  $A \cdot \overline{A} = 0$  ;  $A + \overline{A} = 1$
- Commutative laws : A + B = B + A ; A . B = B . A
- Associative laws : A + (B + C) = (A + B) + C A . (B . C) = (A . B) . C
- Distributive laws : A . (B + C) = (A . B) + (A . C) A + (B . C) = (A + B) . (A + C)

#### DeMorgan's Laws

- $\overline{A + B} = \overline{A} \cdot \overline{B}$
- $\overline{A \cdot B} = \overline{A} + \overline{B}$

Confirm that these are indeed true

#### Logic for common arithmetic operations Simple ALU

#### **Pictorial Representations**



What logic function is this?



Source: H&P textbook

#### **Boolean Equation**

 Consider the logic block that has an output E that is true only if exactly two of the three inputs A, B, C are true

Multiple correct equations:

Two must be true, but all three cannot be true:  $E = ((A \cdot B) + (B \cdot C) + (A \cdot C)) \cdot (A \cdot B \cdot C)$ 

Identify the three cases where it is true:  $E = (A \cdot B \cdot \overline{C}) + (A \cdot C \cdot \overline{B}) + (C \cdot B \cdot \overline{A})$ 

#### Sum of Products

• Can represent any logic block with the AND, OR, NOT operators

- Draw the truth table
- For each true output, represent the corresponding inputs as a product
- The final equation is a sum of these products



- Can also use "product of sums"
- Any equation can be implemented with an array of ANDs, followed by an array of ORs

#### NAND and NOR

- NAND : NOT of AND : A nand  $B = \overline{A \cdot B}$
- NOR : NOT of OR : A nor  $B = \overline{A + B}$
- NAND and NOR are *universal gates*, i.e., they can be used to construct any complex logical function

#### Common Logic Blocks – Decoder

Takes in N inputs and activates one of  $2^{N}$  outputs

| I <sub>0</sub> | $I_1$ | <b>I</b> <sub>2</sub> | <b>O</b> <sub>0</sub> | <b>O</b> <sub>1</sub> | <b>O</b> <sub>2</sub> | <b>O</b> <sub>3</sub> | <b>O</b> <sub>4</sub> | <b>O</b> <sub>5</sub> | <b>O</b> <sub>6</sub> | <b>O</b> <sub>7</sub> |  |
|----------------|-------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|--|
| 0              | 0     | 0                     | 1                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     |  |
| 0              | 0     | 1                     | 0                     | 1                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     |  |
| 0              | 1     | 0                     | 0                     | 0                     | 1                     | 0                     | 0                     | 0                     | 0                     | 0                     |  |
| 0              | 1     | 1                     | 0                     | 0                     | 0                     | 1                     | 0                     | 0                     | 0                     | 0                     |  |
| 1              | 0     | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     | 0                     | 0                     | 0                     |  |
| 1              | 0     | 1                     | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     | 0                     | 0                     |  |
| 1              | 1     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     | 0                     |  |
| 1              | 1     | 1                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     |  |
|                |       |                       |                       |                       |                       |                       |                       |                       |                       |                       |  |



#### Common Logic Blocks – Multiplexor

 Multiplexor or selector: one of N inputs is reflected on the output depending on the value of the log<sub>2</sub>N selector bits



#### Adder Algorithm



#### Truth Table for the above operations:

| Α | В | Cin | Sum Cout |
|---|---|-----|----------|
| 0 | 0 | 0   |          |
| 0 | 0 | 1   |          |
| 0 | 1 | 0   |          |
| 0 | 1 | 1   |          |
| 1 | 0 | 0   |          |
| 1 | 0 | 1   |          |
| 1 | 1 | 0   |          |
| 1 | 1 | 1   |          |
|   |   |     |          |

#### Adder Algorithm



Truth Table for the above operations:

| Ą | В                                         | Cin                                                                                                                     | Sum                                                                                                                                                                                                                                                                                     | Cout                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C | 0                                         | 0                                                                                                                       | 0                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                             |
| C | 0                                         | 1                                                                                                                       | 1                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                             |
| C | 1                                         | 0                                                                                                                       | 1                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                             |
| C | 1                                         | 1                                                                                                                       | 0                                                                                                                                                                                                                                                                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1 | 0                                         | 0                                                                                                                       | 1                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1 | 0                                         | 1                                                                                                                       | 0                                                                                                                                                                                                                                                                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1 | 1                                         | 0                                                                                                                       | 0                                                                                                                                                                                                                                                                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1 | 1                                         | 1                                                                                                                       | 1                                                                                                                                                                                                                                                                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                             |
|   | A<br>D<br>D<br>D<br>D<br>1<br>1<br>1<br>1 | A     B       D     0       D     0       D     1       D     1       1     0       1     1       1     1       1     1 | A         B         Cin           0         0         0           0         0         1           0         1         0           0         1         1           1         0         0           1         0         1           1         1         0           1         1         1 | A         B         Cin         Sum           0         0         0         0           0         0         1         1           0         1         0         1           0         1         0         1           0         1         0         1           0         1         0         1           1         0         1         0           1         1         0         0           1         1         1         1 |

```
Equations:

Sum = Cin \overline{A} \cdot \overline{B} +

B \cdot \overline{Cin} \cdot \overline{A} +

A \cdot \overline{Cin} \cdot \overline{B} +

A \cdot B \cdot Cin
```

## Carry Out Logic







## 1-Bit ALU with Add, Or, And

• Multiplexor selects between Add, Or, And operations



19

## 32-bit Ripple Carry Adder

1-bit ALUs are connected "in series" with the carry-out of 1 box going into the carry-in of the next box



20

## **Incorporating Subtraction**

#### Must invert bits of B and add a 1

- Include an inverter
- CarryIn for the first bit is 1
- The CarryIn signal (for the first bit) can be the same as the Binvert signal



Source: H&P textbook

#### Incorporating NOR and NAND



## Incorporating cmp (set bit when less than)

- Perform a b and check the sign
- New signal (Less) that is zero for ALU boxes 1-31
- The 31<sup>st</sup> box has a unit to detect overflow and sign – the sign bit serves as the Less signal for the 0<sup>th</sup> box



## Incorporating cmp (set bit when less than)

- Perform a b and check the sign
- New signal (Less) that is zero for ALU boxes 1-31
- The 31<sup>st</sup> box has a unit to detect overflow and sign – the sign bit serves as the Less signal for the 0<sup>th</sup> box



Source: H&P textbook

## Incorporating jeq (jump when equal)

 Perform a – b and confirm that the result is all zero's



## **Control Lines**

What are the values of the control lines and what operations do they correspond to?



#### **Control Lines**

What are the values of the control lines and what operations do they correspond to?

|     | Ai | Bn | Ор |
|-----|----|----|----|
| AND | 0  | 0  | 00 |
| OR  | 0  | 0  | 01 |
| Add | 0  | 0  | 10 |
| Sub | 0  | 1  | 10 |
| SLT | 0  | 1  | 11 |
| NOR | 1  | 1  | 00 |



CarryOut

## Speed of Ripple Carry

- The carry propagates thru every 1-bit box: each 1-bit box sequentially implements AND and OR total delay is the time to go through 64 gates!
- We've already seen that any logic equation can be expressed as the sum of products – so it should be possible to compute the result by going through only 2 gates!
- Caveat: need many parallel gates and each gate may have a very large number of inputs – it is difficult to efficiently build such large gates, so we'll find a compromise:
  - moderate number of gates
  - moderate number of inputs to each gate
  - moderate number of sequential gates traversed

#### Clocks

- A microprocessor is composed of many different circuits that are operating simultaneously – if each circuit X takes ininputs at time TI<sub>x</sub>, takes time TE<sub>x</sub> to execute the logic, and produces outputs at time TO<sub>x</sub>, imagine the complications in coordinating the tasks of every circuit
- A major school of thought (used in most processors built today): all circuits on the chip share a clock signal (a square wave) that tells every circuit when to accept inputs, how much time they have to execute the logic, and when they must produce outputs



## **Clock Terminology**



# **Sequential Circuits**

 Until now, circuits were combinational – when inputs change, the outputs change after a while (time = logic delay thru circuit)

• We want the clock to act like a start and stop signal – a "latch" is a storage device that separates these circuits – it ensures that the inputs to the circuit do not change during a clock cycle



## **Sequential Circuits**

- Sequential circuit: consists of combinational circuit and a storage element
- At the start of the clock cycle, the rising edge causes the "state" storage to store some input values



- This state will not change for an entire cycle (until next rising edge)
- The combinational circuit has some time to accept the value of "state" and "inputs" and produce "outputs"
- Some of the outputs (for example, the value of next "state") may feed back (but through the latch so they're only seen in the next cycle)

Sequential circuits

#### **Designing a Latch**

An S-R latch: set-reset latch

- When Set is high, a 1 is stored
- When Reset is high, a 0 is stored
- When both are low, the previous state is preserved (hence, known as a storage or memory element)
- Both are high this set of inputs is not allowed

Verify the above behavior!



#### **D** Latch

Incorporates a clock

 The value of the input D signal (data) is stored only when the clock is high – the previous state is preserved when the clock is low



# D Flip Flop

• Terminology:

Latch: outputs can change any time the clock is high (asserted) Flip flop: outputs can change only on a clock edge

 Two D latches in series – ensures that a value is stored only on the falling edge of the clock



# **Sequential Circuits**

 Until now, circuits were combinational – when inputs change, the outputs change after a while (time = logic delay thru circuit)

• We want the clock to act like a start and stop signal – a "latch" is a storage device that separates these circuits – it ensures that the inputs to the circuit do not change during a clock cycle



#### Finite State Machines

#### **Finite State Machine**

- A sequential circuit is described by a variation of a truth table – a finite state diagram (hence, the circuit is also called a finite state machine)
- Note that state is updated only on a clock edge



#### State Diagrams

- Each state is shown with a circle, labeled with the state value – the contents of the circle are the outputs
- An arc represents a transition to a different state, with the inputs indicated on the label



This is a state diagram for \_\_\_\_?

### **3-Bit Counter**

• Consider a circuit that stores a number and increments the value on every clock edge – on reaching the largest value, it starts again from 0

Draw the state diagram:

- How many states?
- How many inputs?

#### **3-Bit Counter**

 Consider a circuit that stores a number and increments the value on every clock edge – on reaching the largest value, it starts again from 0

Draw the state diagram:

- How many states?
- How many inputs?

