# Inf2C - Computer Systems Lecture 8-9 Logic Design

Boris Grot

School of Informatics
University of Edinburgh



#### Reminder

- Coursework 1: due Wed @ 4pm
- <u> Do</u>:
  - Have correct code
    - Compiles/builds/runs without warnings or errors
    - MIPS & C syntax & semantics are followed
  - Have well-structured code
    - Use functions; no goto's
  - Have readable code
    - Meaningful comments
    - Meaningful names for functions, labels, C variables, etc.



#### Reminder

- Coursework 1: due Wed @ 4pm
- <u>Don't</u>:
  - Be late!
  - Ask me for extensions
    - UG2 organizer Dr. Sharon Goldwater handles these
  - Plagiarize!





#### Logic design overview

#### Binary digital logic circuits:

- Two voltage levels (ground and supply voltage) for 0 and 1
  - Built from transistors used as on/off switches
  - Analog circuits not very suitable for generic computing
  - Digital logic with more than two states is not practical

Combinational logic: output depends only on the current inputs (no memory of past inputs)



Sequential logic: output depends on the current inputs as well as (some) previous inputs → requires "memory"



Inverter (or NOT gate): 1 input and 1 output "invert the input signal"







Inverter (or NOT gate): 1 input and 1 output "invert the input signal"

input — output 
$$\frac{IN | OUT|}{0 | 1 | 0}$$
 OUT =  $\overline{IN}$ 

• AND gate: 2 inputs and 1 output "output 1 only if both inputs are 1"



OR gate: "output 1 if at least one input is 1"

$$IN_1 \longrightarrow OUT$$

| $IN_1$ | $IN_2$ | OUT |                                                |
|--------|--------|-----|------------------------------------------------|
| 0      | 0      | 0   |                                                |
| 0      | 1      | 1   | $\mathbf{OUT} = \mathbf{IN}_1 + \mathbf{IN}_2$ |
| 1      | 0      | 1   |                                                |
| 1      | 1      | 1   |                                                |





OR gate: "output 1 if at least one input is 1"

$$IN_1$$
 OUT  $IN_2$ 

■ NOR gate: "output 1 if no input is 1" (NOT OR)

$$IN_1$$
 OUT

| $IN_1$ | $IN_2$ | OUT |                                                           |
|--------|--------|-----|-----------------------------------------------------------|
| 0      | 0      | 1   |                                                           |
| 0      | 1      | 0   | $\mathbf{OUT} = \overline{\mathbf{IN}_1 + \mathbf{IN}_2}$ |
| 1      | 0      | 0   |                                                           |
| 1      | 1      | 0   |                                                           |



• AND gate: "output 1 if both inputs are 1"

$$IN_1 \longrightarrow OUT$$

■ NAND gate: "output 1 if both inputs are <u>not</u> 1" (NOT AND)

$$IN_1$$
 OUT  $IN_2$ 

| IN <sub>1</sub> | $IN_2$ | OUT |                         |
|-----------------|--------|-----|-------------------------|
| 0               | 0      | 1   |                         |
| 0               | 1      | 1   | $OUT = IN_1 \cdot IN_1$ |
| 1               | 0      | 1   |                         |
| 1               | 1      | 0   |                         |



• Multiple-input gates:







- Functional completeness:
  - Set of gates that is sufficient to express any boolean function
- Examples:
  - AND + OR + NOT
  - NAND
  - NOR



#### Multiplexer (mux)

Multiplexer: a circuit for selecting one of multiple inputs



$$z = \begin{cases} i_0, & \text{if } c=0 \\ i_1, & \text{if } c=1 \end{cases}$$

| c | $\mathbf{i_0}$ | $\mathbf{i}_1$ | Z |
|---|----------------|----------------|---|
| 0 | 0              | 0              | 0 |
| 0 | 0              | 1              | 0 |
| 0 | 1              | 0              | 1 |
| 0 | 1              | 1              | 1 |
| 1 | 0              | 0              | 0 |
| 1 | 0              | 1              | 1 |
| 1 | 1              | 0              | 0 |
| 1 | 1              | 1              | 1 |

$$z = \overline{c}.i_0.\overline{i}_1 + \overline{c}.i_0.i_1 + \overline{c}.\overline{i}_0.i_1 + \overline{c}.i_0.i_1$$

$$= \overline{c}.i_0.(\overline{i}_1 + i_1) + \overline{c}.(\overline{i}_0 + i_0).i_1$$

$$= \overline{c}.i_0 + \overline{c}.i_1 \quad \text{minimized}$$
"sum of products form"



# A multiplexer implementation

- Sum of products form:  $i_1 \cdot c + i_0 \cdot \overline{c}$ 
  - Can be implemented with 1 inverter, 2 AND gates & 1 OR gate:



- Sum of products is not practical for circuits with large number of inputs (n)
  - The number of possible products can be proportional to 2<sup>n</sup>



#### Arithmetic circuits

32-bit adder



64 inputs → too complex for sum of products

- Idea: modularize!
  - Design a generic 1-bit adder block
  - Replicate it N number of times for an N-bit adder



#### Arithmetic circuits

32-bit adder



64 inputs → too complex for sum of products

Full adder:



$$sum = \overline{a.b.c} + \overline{a.b.c} + a.b.c + a.b.c$$
$$carry = b.c + a.c + a.b$$

| a | b | c | carry | sum |
|---|---|---|-------|-----|
| 0 | 0 | 0 | 0     | 0   |
| 0 | 0 | 1 | 0     | 1   |
| 0 | 1 | 0 | 0     | 1   |
| 0 | 1 | 1 | 1     | 0   |
| 1 | 0 | 0 | 0     | 1   |
| 1 | 0 | 1 | 1     | 0   |
| 1 | 1 | 0 | 1     | 0   |
| 1 | 1 | 1 | 1     | 1   |

## Ripple carry adder

32-bit adder: chain of 32 full adders



- Carry bits  $c_i$  are computed in sequence  $c_1, c_2, \ldots, c_{32}$  (where  $c_{32} = s_{32}$ ), as  $c_i$  depends on  $c_{i-1}$
- Since sum bits s<sub>i</sub> also depend on c<sub>i</sub>, they too are computed in sequence



#### Propagation delays

- Propagation delay = time delay between input signal change and output signal change at the other end
- Delay depends on:
  - 1. technology (transistor parameters, wire capacitance, etc.)
  - 2. delay through each gate (function of gate type)
  - 3. number of gates driven by a gate's output (fan out)
- e.g.: 2-input mux: NOT  $\rightarrow$  AND  $\rightarrow$  OR  $\rightarrow$  3 gate delays. Fast!
- What's the delay of a 32-bit ripple carry adder?
  - 65 gate delays → slow
  - AND2 + OR3 for each of 31 carries to propagate;
     followed by NOT + AND3 + OR4 for S<sub>31</sub>



#### Practice problem:

Design a circuit that, given a 4-bit unsigned input, outputs:

1 - if the input value is  $\geq 7$ 

0 - otherwise

What is the propagation delay of the circuit?

What is the delay if only 1- and 2-input gates are allowed?



## Sequential logic circuits



- Output depends on current AND past inputs
  - The circuit has memory
- Sequences of inputs generate sequences of outputs ⇒ sequential logic
- EDINBUTE ASSET

– With *n* feedback signals  $\rightarrow$  up to  $2^n$  stable states

## SR Latch: the basic sequential circuit

#### SR latch

- Inputs: R, S
- Feedback: q, q
- Output: Q





#### SR Latch





#### SR Latch



- Usage: 1-bit memory
  - Keep the value in memory by maintaining S=0 and R=0
  - Set the value in memory to 0 (or 1) by setting R=1 (or S=1) for a short time



## Timing of events

- Asynchronous sequential logic
  - State (and possibly output) of circuit changes whenever inputs change



- Synchronous sequential logic
  - State (and possibly output) can only change at times synchronized to an external signal → the clock





# Using clock to build a memory element



Level-triggered D latch: whenever clock is 1, D is propagated to Q



# Using clock to build a memory element



- Level-triggered D latch: whenever clock is 1, D is propagated to Q
- Edge-triggered D flip-flop: on a positive clock edge, D is propagated to Q





#### Register

- Tie multiple D flip-flops together using a common clock
- E.g., 4-bit register:







Famell







MEMORY ... £1.15 reichelt.com

M74HC160B1R £0.31 Rapid Electro..



# General sequential logic circuit



#### Operation:

- At every rising clock edge next state signals are propagated to current state signals
- Current state signals plus inputs work through combinational logic and generate output and next state signals



#### Hardware FSM

- A sequential circuit is a (deterministic) Finite State
   Machine FSM
- Example: Vending machine
  - Accepts 10p, 20p coins, sells one product costing 30p, no change given
  - Coin reader has 2 signals: a, b for 10p, 20p coins respectively. These are the inputs to our FSM 00
  - Output z asserted when 30p
     or more has been paid in





## FSM implementation

#### Methodology:

- Choose encoding for states, e.g S0=00, ..., S3=11
- Build truth table for the next state  $s_1'$ ,  $s_0'$  and output z
- Generate logic equations for s<sub>1</sub>', s<sub>0</sub>', z
- Design comb logic from logic equations and add stateholding register



| $\mathbf{s}_1$ | $  s_0  $ | a | b     | $\mathbf{s_1}'$ | $\mathbf{s_0}'$ | Z |
|----------------|-----------|---|-------|-----------------|-----------------|---|
| 0              | 0         | 0 | 0     | 0               | 0               |   |
| 0              | 0         | 0 | 1     | 1               | 0               | 0 |
| 0              | 0         | 1 | 0     | 0               | 1               |   |
| 0              | 1         | 0 | 0     | 0               | 1               |   |
| 0              | 1         | 0 | 1     | 1               | 1               | 0 |
| 0              | 1         | 1 | 0     | 1               | 0               |   |
| • • • • • •    |           |   | • • • | • • • •         | •               |   |