# inst.eecs.berkeley.edu/~cs61c/su06 CS61C : Machine Structures

#### Lecture #14: Combinational Logic, Gates, and State



2006-07-20



**Andy Carle** 

#### What are "Machine Structures"?



## Coordination of many *levels of abstraction*

#### We'll investigate lower abstraction layers! (contract between HW & SW)



CS 61C L14 Combinational Logic (2)



#### Physical Hardware - PowerPC 750





**Digital Design Basics (1/2)** 

- Next 2 weeks: we'll study how a modern processor is built starting with basic logic elements as building blocks.
- Why study logic design?
  - Understand what processors can do fast and what they can't do fast (avoid slow things if you want your code to run fast!)
  - Background for more detailed hardware courses (CS 150, CS 152)



# **Digital Design Basics (2/2)**

- ISA is very important abstraction layer
  - Contract between HW and SW
  - Can you peek across abstraction?
  - Can you depend "across abstraction"?
- Voltages are analog, quantized to 0/1
- Circuit delays are fact of life
- Two types
  - Stateless Combinational Logic (&,|,~)
  - State circuits (e.g., registers)



## Outline

- Truth Tables
- Transistors
- Logic Gates
- Combinational Logic
- Boolean Algebra



#### **Truth Tables (1/6)**

|                  |     | a | b | c | d | У          |
|------------------|-----|---|---|---|---|------------|
|                  |     | 0 | 0 | 0 | 0 | F(0,0,0,0) |
|                  |     | 0 | 0 | 0 | 1 | F(0,0,0,1) |
|                  |     | 0 | 0 | 1 | 0 | F(0,0,1,0) |
|                  |     | 0 | 0 | 1 | 1 | F(0,0,1,1) |
| a                |     | 0 | 1 | 0 | 0 | F(0,1,0,0) |
|                  |     | 0 | 1 | 0 | 1 | F(0,1,0,1) |
|                  |     | 0 | 1 | 1 | 0 | F(0,1,1,0) |
| C                | J J | 0 | 1 | 1 | 1 | F(0,1,1,1) |
|                  |     | 1 | 0 | 0 | 0 | F(1,0,0,0) |
| $d \rightarrow $ |     | 1 | 0 | 0 | 1 | F(1,0,0,1) |
|                  |     | 1 | 0 | 1 | 0 | F(1,0,1,0) |
|                  |     | 1 | 0 | 1 | 1 | F(1,0,1,1) |
|                  |     | 1 | 1 | 0 | 0 | F(1,1,0,0) |
|                  |     | 1 | 1 | 0 | 1 | F(1,1,0,1) |
|                  |     | 1 | 1 | 1 | 0 | F(1,1,1,0) |
| 2                |     | 1 | 1 | 1 | 1 | F(1,1,1,1) |
|                  |     |   |   |   |   |            |

CS 61C L14 Combinational Logic (8)

## TT (2/6) Ex #1: 1 iff one (not both) a,b=1





#### TT (3/6): Example #2: 2-bit adder



| А        | В        | C             |
|----------|----------|---------------|
| $a_1a_0$ | $b_1b_0$ | $c_2 c_1 c_0$ |
| 00       | 00       | 000           |
| 00       | 01       | 001           |
| 00       | 10       | 010           |
| 00       | 11       | 011           |
| 01       | 00       | 001           |
| 01       | 01       | 010           |
| 01       | 10       | 011           |
| 01       | 11       | 100           |
| 10       | 00       | 010           |
| 10       | 01       | 011           |
| 10       | 10       | 100           |
| 10       | 11       | 101           |
| 11       | 00       | 011           |
| 11       | 01       | 100           |
| 11       | 10       | 101           |
| 11       | 11       | 110           |

CS 61C L14 Combinational Logic (10)

# TT (4/6): Ex #3: 32-bit unsigned adder C R Α 000 ... 0 $000 \dots 00$ 000 ... 0 000 ... 0 000 ... 1 000 ... 01 . 111 ... 1 111 ... 1 | 111 ... 10



## TT (5/6): Conversion: 3-input majority

| a | b | C | У |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |







# Transistors (1/3)



#### **CMOSFET Transistors:**

- \* Physically exist!
- \* Voltages are quantized
- \* Only 2 Types:
  - P-channel:
    - 0 on gate -> pull up (1)
- N-channel:
  - 1 on gate -> pull down (0)

#### \* Undriven otherwise.



# **Transistors (2/3)**



**CMOSFET Transistors:** 

\* have delay and require power

\* can be combined to perform logical operations and maintain state.

- logical operations will be our starting point for digital design

- state tomorrow



CS 61C L14 Combinational Logic (15)

#### Transistors (3/3): CMOS -> Nand





Logic Gates (1/4)

- Transistors are too low level
  - Good for measuring performance, power.
  - Bad for logical design / analysis

- Gates are collections of transistors wired in a certain way
  - Can represent and reason about gates with truth tables and Boolean algebra
  - We will mainly review the concepts of truth tables and Boolean algebra in this class. It is assumed that you've seen these before.



Section B.2 in the textbook has a review

CS 61C L14 Combinational Logic (17)

Logic Gates (2/4)





#### **AND Gate**



#### Definition







#### Logic Gates (4/4)



CS 61C L14 Combinational Logic (20)

**Boolean Algebra (1/7)** 

- George Boole, 19<sup>th</sup> Century mathematician
- Developed a mathematical system (algebra) involving logic, later known as "Boolean Algebra"
- Primitive functions: AND, OR and NOT
- The power of BA is there's a one-to-one correspondence between circuits made up of AND, OR and NOT gates and equations in BA



BA (2/7): e.g., majority circuit



 $y = a \cdot b + a \cdot c + b \cdot c$ 

y = ab + ac + bc



CS 61C L14 Combinational Logic (22)

#### **BA (3/7):Laws of Boolean Algebra**

| $x\cdot \overline{x}=0$                         | $x + \overline{x} = 1$                               |
|-------------------------------------------------|------------------------------------------------------|
| $x \cdot 0 = 0$                                 | x + 1 = 1                                            |
| $x \cdot 1 = x$                                 | x + 0 = x                                            |
| $x \cdot x = x$                                 | x + x = x                                            |
| $x \cdot y = y \cdot x$                         | x + y = y + x                                        |
| (xy)z = x(yz)                                   | (x+y) + z = x + (y+z)                                |
| x(y+z) = xy + xz                                | x + yz = (x + y)(x + z)                              |
| xy + x = x                                      | (x+y)x = x                                           |
| $\overline{x\cdot y}=\overline{x}+\overline{y}$ | $\overline{(x+y)} = \overline{x} \cdot \overline{y}$ |

complementarity laws of 0's and 1's identities idempotent law commutativity associativity distribution uniting theorem DeMorgan's Law



# **BA (4/7): Circuit & Algebraic Simplification**



original circuit

equation derived from original circuit

algebraic simplification

simplified circuit



#### **BA (5/7): Simplification Example**

$$y = ab + a + c$$
  
=  $a(b+1) + c$  distribution, identity  
=  $a(1) + c$  law of 1's  
=  $a + c$  identity



**BA (6/7): Canonical forms (1/2)** 





#### **BA (7/7): Canonical forms (2/2)**

$$y = \overline{a}\overline{b}\overline{c} + \overline{a}\overline{b}c + a\overline{b}\overline{c} + ab\overline{c}$$
  

$$= \overline{a}\overline{b}(\overline{c} + c) + a\overline{c}(\overline{b} + b) \quad distribution$$
  

$$= \overline{a}\overline{b}(1) + a\overline{c}(1) \quad complementarity$$
  

$$= \overline{a}\overline{b} + a\overline{c} \quad identity$$



CS 61C L14 Combinational Logic (27)

**Combinational Logic** 

A *combinational* logic block is one in which the output is a function only of its current input.

- Combinational logic cannot have memory.
- Everything we've seen so far is CL
- CL will have delay ( f(transistors) )



- A. (a+b)• (a+b) = b
- B. N-input gates can be thought of as cascaded 2-input gates. I.e., (a ∆ bc ∆ d ∆ e) = a ∆ (bc ∆ (d ∆ e)) where ∆ is one of AND, OR, XOR, NAND
- C. You can use NOR(s) with clever wiring to simulate AND, OR, & NOT



#### Administrivia

- HW 4 due Friday
- Project 2 due Friday the 28<sup>th</sup>

- If you want to get a little bit ahead (in a moderately fun sort of way), start playing with Logisim:
  - http://ozark.hendrix.edu/~burch/logisim/



**Signals and Waveforms** 

#### • Outputs of CL change over time

- With what? → Change in inputs
- Can graph changes with waveforms ...



#### **Signals and Waveforms: Adders**



×

#### **Signals and Waveforms: Grouping**





#### Signals and Waveforms: Circuit Delay





CS 61C L14 Combinational Logic (34)



#### • With CL, output is always a function of **CURRENT** input

• With some (variable) propagation delay

#### Clearly, we need a way to introduce state into computation



S 61C L14 Combinational Logic (35)

#### **Accumulator Example**



#### Want: S=0; for i from 0 to n-1 $S = S + X_i$



#### First try...Does this work?



#### Nope!

Reason #1... What is there to control the next iteration of the 'for' loop? Reason #2... How do we say: 'S=0'?

Need a way to store partial sums! ...

CS 61C L14 Combinational Logic (37)

## **Circuits with STATE (e.g., register)**



#### Need a Logic Block that will: 1. store output (partial sum) for a while, 2. until we tell it to update with a new value.



# **Register Details...What's in it anyway?**



- n instances of a "Flip-Flop", called that because the output flips and flops betw. 0,1
- D is "data"
- Q is "output"

Also called "d-q Flip-Flop", "d-type Flip-Flop"



CS 61C L14 Combinational Logic (39)



- Edge-triggered D-type flip-flop
  - This one is "positive edge-triggered"
- "On the rising edge of the clock, the input d is sampled and transferred to the output. At all other times, the input d is ignored."

## What's the timing of a Flip-flop? (2/2)



- Edge-triggered D-type flip-flop
  - This one is "positive edge-triggered"

• "On the rising edge of the clock, the input d is sampled and transferred to the output. At all other times, the input d is ignored."

### Bus a bunch of D FFs together ...



- Register of size N:
  - n instances of D Flip-Flop



#### Second try...How about this? Yep!



CS 61C L14 Combinational Logic (43)

## Accumulator Revisited (proper timing 1/2)



Cal

### **Accumulator Revisited (proper timing 2/2)**



#### **Pipelining to improve performance (1/2)**





CS 61C L14 Combinational Logic (46)

### **Pipelining to improve performance (2/2)**



CS 61C L14 Combinational Logic (47)

**Peer Instruction 2** 

Simplify the following Boolean algebra equation:

- Q = !(A\*B) + !(!A \* C)
- Use algebra, individual steps, etc.
  - Don't just look at it and figure it out, or I'll have to start using harder examples. 😳



"And In conclusion..."

• Use this table and techniques we learned to transform from 1 to another





CS 61C L14 Combinational Logic (49)