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

#### Lecture 20 – Introduction to Synchronous Digital Systems



2004-10-15

#### **Lecturer PSOE Dan Garcia**

www.cs.berkeley.edu/~ddgarcia

Great new PC HW!⇒ OQO model 01 is the

new, lightest, coolest fullyfunctional PC on the block. 1GHz, 20GB drive, 256MB RAM, wireless, color display, thumb keyboard which slides out. Small & light!



Garcia, Fall 2004 © UCB

#### What are "Machine Structures"?



# Coordination of many *levels of abstraction*

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





- 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)



CS 61C L20 Introduction to Synchronous Digital Systems (4)

## **Logic Gates**

- Basic building blocks are logic gates.
  - In the beginning, did ad hoc designs, and then saw patterns repeated, gave names
  - Can build gates with transistors and resistors
- Then found theoretical basis for design
  - Can represent and reason about gates with truth tables and Boolean algebra
  - Assume know truth tables and Boolean algebra from a math or circuits course.
  - Section B.2 in the textbook has a review



### **Physical Hardware**



CS 61C L20 Introduction to Synchronous Digital Systems (6)

Garcia, Fall 2004 © UCB

#### Gate-level view vs. Block diagram



CS 61C L20 Introduction to Synchronous Digital Systems (7)

#### **Signals and Waveforms: Clocks**



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



CS 61C L20 Introduction to Synchronous Digital Systems (9)

Garcia, Fall 2004 © UCB

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





### Signals and Waveforms: Circuit Delay



Cal .

## **Combinational Logic**

- Complex logic blocks are built from basic AND, OR, NOT building blocks we'll see shortly.
- A *combinational* logic block is one in which the output is a function only of its current input.
- Combinational logic cannot have memory (e.g., a register is not a combinational unit).



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



#### **Administrivia**

# • Midterm coming up on Monday @ 7pm in 1 Pimintel. Heard this enough yet?





- A. SW can peek at HW (past ISA abstraction boundary) for optimizations
- B. SW can depend on particular HW implementation of ISA
- C. Timing diagrams serve as a critical debugging tool in the EE toolkit



CS 61C L20 Introduction to Synchronous Digital Systems (15)

- ISA is very important abstraction layer
  - Contract between HW and SW
- Basic building blocks are logic gates
- Clocks control pulse of our circuits
- Voltages are analog, quantized to 0/1
- Circuit delays are fact of life
- Two types
  - Stateless Combinational Logic (&,I,~)



State circuits (e.g., registers)

CS 61C L20 Introduction to Synchronous Digital Systems (16)