**CSCE 230J Computer Organization** 

# Processor Architecture II: Logic Design

Dr. Steve Goddard goddard@cse.unl.edu

http://cse.unl.edu/~goddard/Courses/CSCE230J

# Giving credit where credit is due

- Most of slides for this lecture are based on slides created by Dr. Bryant, Carnegie Mellon University.
- ■I have modified them and added new slides.

# **Overview of Logic Design**

#### **Fundamental Hardware Requirements**

- **■** Communication
  - How to get values from one place to another
- Computation
- Storage

#### **Bits are Our Friends**

- Everything expressed in terms of values 0 and 1
- **■** Communication
  - Low or high voltage on wire
- **■** Computation
  - Compute Boolean functions
- Storage
  - Store bits of information

3

### **Digital Signals**



Time

- Use voltage thresholds to extract discrete values from continuous signal
- Simplest version: 1-bit signal
  - Either high range (1) or low range (0)
  - With guard range between them
- Not strongly affected by noise or low quality circuit elements
  - Can make circuits simple, small, and fast

# **Computing with Logic Gates**



- Outputs are Boolean functions of inputs
- Respond continuously to changes in inputs
  - With some, small delay



5

### **Combinational Circuits**

# Acyclic Network



### **Acyclic Network of Logic Gates**

- Continously responds to changes on primary inputs
- Primary outputs become (after some delay) Boolean functions of primary inputs

# **Bit Equality**



■ Generate 1 if a and b are equal

#### **Hardware Control Language (HCL)**

- Very simple hardware description language
  - Boolean operations have syntax similar to C logical operations
- We'll use it to describe control logic for processors

7



Page 4

# **Bit-Level Multiplexor**



#### **HCL Expression**

bool out = (s&a) | | (!s&b)

- Control signal s
- Data signals a and b
- Output a when s=1, b when s=0

9

#### **Word Multiplexor Word-Level Representation** - Out MUX out<sub>31</sub> $a_{31}$ **HCL** Representation int Out = [ b<sub>30</sub> out<sub>30</sub> s : A; 1 : B; ]; ■ Select input word A or B depending on control signal s ■ HCL representation • Case expression • Series of test : value pairs out<sub>0</sub> • Output value for first successful test 10

# **HCL Word-Level Examples**

#### **Minimum of 3 Words**



- Find minimum of three input words
- HCL case expression
- Final case guarantees match

#### 4-Way Multiplexor



- Select one of 4 inputs based on two control bits
- HCL case expression
- Simplify tests by assuming sequential matching

11

### **Arithmetic Logic Unit**



- Combinational logic
  - Continuously responding to inputs
- Control signal selects function computed
  - Corresponding to 4 arithmetic/logical operations in Y86
- Also computes values for condition codes









### 1-Bit Latch



#### Latching



#### Storing



17

# **Transparent 1-Bit Latch**

#### Latching



#### Changing D



- When in latching mode, combinational propogation from D to Q+ and Q-
- Value latched depends on value of D as C falls





# **Register Operation**



- Stores data bits
- For most of time acts as barrier between input and output
- As clock rises, loads input



### **Random-Access Memory**



- Stores multiple words of memory
  - Address input specifies which word to read or write
- Register file
  - Holds values of program registers
  - %eax, %esp, etc.
  - Register identifier serves as address
    - » ID 8 implies no read or write performed
- Multiple Ports
  - Can read and/or write multiple words in one cycle
    - » Each has separate address and data input/output

23

#### **Register File Timing** Reading 2 X ■ Like combinational logic Register ■ Output data generated based on input address • After some delay Writing ■ Like register ■ Update only as clock rises 2 y Rising Register file clock Register $\Rightarrow$ file Clock Clock 24

### **Hardware Control Language**

- Very simple hardware description language
- Can only express limited aspects of hardware operation
  - Parts we want to explore and modify

### **Data Types**

- bool: Boolean
  - a, b, c, ...
- int: words
  - A, B, C, ...
  - Does not specify word size---bytes, 32-bit words, ...

#### **Statements**

- bool a = bool-expr ;
- int A = int-expr ;

25

### **HCL Operations**

■ Classify by type of value returned

### **Boolean Expressions**

- Logic Operations
  - a && b, a || b, !a
- **■** Word Comparisons
  - A == B, A != B, A < B, A <= B, A >= B, A > B
- Set Membership
  - A in { B, C, D }

    » Same as A == B || A == C || A == D

### **Word Expressions**

- **■** Case expressions
  - [a: A; b: B; c: C]
  - Evaluate test expressions a, b, c, ... in sequence
  - Return word expression A, B, C, ... for first successful test

# **Summary**

### Computation

- Performed by combinational logic
- Computes Boolean functions
- Continuously reacts to input changes

### **Storage**

- Registers
  - Hold single words
  - Loaded as clock rises
- Random-access memories
  - Hold multiple words
  - Possible multiple read or write ports
  - Read word when address input changes
  - Write word as clock rises