# COMSM1302 Overview of Computer Architecture

Lecture 4
Simple devices



#### In this lecture

#### Foundations

Data representation, logic, Boolean algebra.

#### **Building blocks**

 Transistors, transistor based logic, simple devices, storage.

#### Modules

 Memory, simple controllers, FSMs, processors and execution.

#### **Programming**

 Machine code, assembly, high-level languages, compilers.

#### Wrap-up

Operating systems, energy aware computing.



# Today, we learn to add!

- And also...
  - Subtract
  - Select 1 signal from many
  - Distribute 1 signal to many
- The circuits shown hereafter will be drawn in Logisim.
  - You can download it from:

http://sourceforge.net/projects/circuit/

Install Logisim on your own computer and practice.





Photo by Joseph A. Carr, 1975



#### COMSM1302 NAND board kit



- Your task in the NAND labs will involve building some of the circuits that will be introduced today.
- You should always design with Logisim BEFORE you start building with the NAND board kit.

- How to add two, singledigit binary numbers?
  - Each digit is either 0 or 1
  - What are the possible results?

- How to add two, singledigit binary numbers?
  - Each digit is either 0 or 1
  - What are the possible results?

- How to add two, singledigit binary numbers?
  - Each digit is either 0 or 1
  - What are the possible results?

$$0+0=0$$
 $0+1=1$ 
 $1+1=2$ 
 $10$ 

- How to add two, singledigit binary numbers?
  - Each digit is either 0 or 1
  - There are three possible results
    - 0, 1, 2
    - 0b00, 0b01, 0b10
  - Two inputs
    - A, B
  - Output
    - Sum (S)



- How to add two, singledigit binary numbers?
  - Each digit is either 0 or 1
  - There are three possible results
    - 0, 1, 2
    - 0b00, 0b01, 0b10
  - Two inputs
    - A, B
  - Two outputs
    - Sum (S)
    - Carry (C)





- How to add two, singledigit binary numbers?
  - Each digit is either 0 or 1
  - There are three possible results
    - 0, 1, 2
    - 0b00, 0b01, 0b10
  - Two inputs
    - A, B
  - Two outputs
    - Carry (C)
    - Sum (S)

| Α | В | C | S |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 1 | 0 | 1 |
| 1 | 0 | 0 | 1 |
| 1 | 1 | 1 | 0 |
|   |   |   |   |





- How to add two, singledigit binary numbers?
  - Each digit is either 0 or 1
  - There are three possible results
    - 0, 1, 2
    - 0600, 0601, 0610
  - Two inputs
    - A, B
  - Two outputs
    - Carry (C)
    - Sum (S)

|   |   |                  | _ <u>S</u> _          |
|---|---|------------------|-----------------------|
| A | В | 2 <sup>1</sup> 2 | <b>2</b> <sup>0</sup> |
| 0 | 0 | 0                | 0                     |
| 0 | 1 | 0                | 1                     |
| 1 | 0 | 0                | 1                     |
| 1 | 1 | 1                | 0                     |



# With some Boolean algebra

- Remember our truth tables for the connectives in Boolean algebra, e.g. AND, OR, XOR, etc?
- Which operations can be used to help us generate S and C?

| A  | В | С | S |
|----|---|---|---|
| 0  | 0 | 0 | 0 |
| 0  | 1 | 0 | 1 |
| 1  | 0 | 0 | 1 |
| _1 | 1 | 1 | 0 |

# With some Boolean algebra

- Remember our truth tables for the connectives in Boolean algebra, e.g. AND, OR, XOR, etc?
- Which operations can be used to help us generate S and C?

|   |   |   | •   |  |  |
|---|---|---|-----|--|--|
| Α | В | C | S   |  |  |
| 0 | 0 | 0 | 0   |  |  |
| 0 | 1 | 0 | 1   |  |  |
| 1 | 0 | 0 | 1 / |  |  |
| 1 | 1 | 1 | 0   |  |  |
|   |   | ノ |     |  |  |

| Α | В | <u> ¬A</u> | АΛВ | AVB | А⊕В | A <u>→</u> B | A≡B |
|---|---|------------|-----|-----|-----|--------------|-----|
| 0 | 0 | 1          | 0   | 0   | 0   | 1            | 1   |
| 0 | 1 | 1          | 0   | 1   | 1   | 1            | 0   |
| 1 | 0 | 0          | 0   | 1   | 1   | 0            | 0   |
| 1 | 1 | 0          | 1   | 1   | 0   | 1            | 1   |



#### The half-adder

- $S = A \oplus B$
- $C = A \wedge B$
- Now let's build it with logic gates.







# We The half-adder in action





- We can add two bits together.
  - By generating a sum and a carry bit.
- How do we add multiple bits together?





- We can add two bits together.
  - By generating a sum and a carry bit.
- How do we add multiple bits together?



- We can add two bits together.
  - By generating a sum and a carry bit.
- How do we add multiple bits together?



- We can add two bits togeth
  - By generating a sum and a
- How do we add multiple

1+3=4 out 35=6 01 carry-in 11 carry  $+001 \times +001 \times -100 = 6$  100=4 110=6

For each addition (except for the first) we need to account for two input bits and a carry\_in, and we produce a sum and a carry\_out.





| C_in | _ <u>A</u> | В | C_out | S |
|------|------------|---|-------|---|
| 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 |

#### From the half-adder:

- $S = A \oplus B$
- $C_{out} = A \wedge B$

(Note that the above covers only the top-half of this table!)



| C_in | Α | В | C_out | S |
|------|---|---|-------|---|
| 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 |



For multiple arguments, XOR is defined to be true iff an odd number of its arguments is true, and false otherwise.

| C_in | Α  | В   | C_out | S  |
|------|----|-----|-------|----|
| 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 |

• 
$$S = A \oplus B \oplus C_{in}$$

Also valid:

$$C_{out} = (A \land B) \lor (C_{in} \land (A \oplus B))$$

- Why?



|   | C_in | Α | В | C_out | S |
|---|------|---|---|-------|---|
|   | 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     | 1 |

• 
$$S = A \oplus B \oplus C_{in}$$

Also valid:

$$C_{out} = (A \land B) \lor (C_{in} \land (A \oplus B))$$

- Why?



- 8 different combinations of input
- Try them yourself!



- $S = A \oplus B \oplus C_{in}$
- C\_out =(A  $\wedge$  B)  $\vee$  (C\_in  $\wedge$  (A  $\oplus$  B))



- 8 different combinations of input
- Try them yourself!



- To build this with the NAND kits you need to:
  - use Boolean algebra to obtain a design that is based purely on NAND gates,
  - implement this in Logisim to gain confidence your design is correct, then
  - (and only then) transfer to NAND boards and test.



- We can add two bits together.
  - By generating a sum and a carry bit.
- We can add three bits together
  - By accommodating a carry-in as well as our regular two inputs.
- How do we add multiple bits together?





- We can add two bits together.
  - By generating a sum and a carry bit.
- We can add three bits together
  - By accommodating a carry-in as well as our regular

two inputs.

 How do we add multiple bits together?



= 22

# **Chaining full-adders**







# Chaining full-adders





# 8-bit adder, ripple-carry adder



- Named ripple-carry because a carry signal generated at the LSB (Least Significant Bit... bit 0) of the device can affect the result on any/all more significant bits.
- Does this have any implications?





# Building blocks

- To recap what we've done:
  - Used Boolean algebra to identify our building blocks.
  - Built a unit capable of adding two bits.
    - Half-adder
  - Extended it to handle carry-in.
    - Full-adder
  - Chained them together to make an adder of arbitrary size.
    - Ripple-carry adder
- Now we can add anything!
  - Modern processors typically have adders between 8 and 64 bits.
  - Why?



#### Subtraction

- Subtraction is easy if we think of it as adding one number to a negative number.
- So let's represent this subtraction:

$$1-2 = -1$$
• As:
$$1+(-2) = -1$$

How to negate a number?

#### Subtraction

- Subtraction is easy if we think of it as adding one number to a negative number.
- So let's represent this subtraction:

$$1 - 2 = -1$$

• As:

$$1 + -2 = -1$$

- How to negate a number?
  - We use 2s complement!



# Reminder: 2s complement

$$Y = -x_{N-1} \cdot 2^{N-1} + \sum_{i=0}^{N-2} x_i \cdot 2^i$$

|      |    | _  |    |   |   |   |   |         |
|------|----|----|----|---|---|---|---|---------|
| -128 | 64 | 32 | 16 | 8 | 4 | 2 | 1 | Base 10 |
| 0    | 0  | 0  | 0  | 1 | 0 | 1 | 0 | 10      |
| 0    | 0  | 0  | 0  | 0 | 0 | 0 | 1 | 1       |
| 1    | 1  | 1  | 1  | 1 | 1 | 1 | 1 | -1      |
| 1    | 1  | 1  | 1  | 1 | 1 | 1 | 0 | -2      |
| 1    | 0  | 0  | 0  | 1 | 0 | 1 | 0 | -118    |



# Calculating the 2s complement

#### To calculate the 2's complement of an integer:

- 1. invert the binary equivalent of the number by changing all of the ones to zeroes and all of the zeroes to ones (also called 1's complement), then
- 2. add one.

\_\_\_

How do we represent -6?



# Calculating the 2s complement

#### To calculate the 2's complement of an integer:

- 1. invert the binary equivalent of the number by changing all of the ones to zeroes and all of the zeroes to ones (also called 1's complement), then
- 2. add one.
- How do we represent -6?



#### To calculate the 2's complement of an integer:

- 1. invert the binary equivalent of the number by changing all of the ones to zeroes and all of the zeroes to ones (also called 1's complement), then
- 2. add one.

\_\_\_

0110 = 6

How do we represent -6?

#### To calculate the 2's complement of an integer:

- 1. invert the binary equivalent of the number by changing all of the ones to zeroes and all of the zeroes to ones (also called 1's complement), then
- 2. add one.
- \_\_\_
- How do we represent -6?





#### To calculate the 2's complement of an integer:

- 1. invert the binary equivalent of the number by changing all of the ones to zeroes and all of the zeroes to ones (also called 1's complement), then
- 2. add one.

---

How do we represent -6?





#### To calculate the 2's complement of an integer:

- 1. invert the binary equivalent of the number by changing all of the ones to zeroes and all of the zeroes to ones (also called 1's complement), then
- 2. add one.

---

How do we represent -6?

$$+\frac{1001}{1010} = -6$$
 $+ 421$ 

# Subtraction with 2s complement

- A B = A + (-B) = A + (Not(B) + 1)
- We already have all the building blocks we need to implement this!
  - NOT gates to flip bits
  - An unused C\_in at the beginning of our adder's carry chain to provide the extra 1.





# Subtraction with 2s complement

- A B = A + (-B) = A + (Not(B) + 1)
- We already have all the building blocks we need to implement this!
  - NOT gates to flip bits
  - An unused C\_in at the beginning of our adder's carry chain to provide the extra 1.





#### From full-adder to subtractor





#### The adder-subtractor?

- We can build an adder or a subtractor.
- They are very similar.
- Can we build one unit that does both?

Almost...





### Adder-subtractor







# Selecting a signal



| <b>S</b> (Select) |  | Α |  | В |  | Q |  |
|-------------------|--|---|--|---|--|---|--|
| 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 |  |



## Selecting a signal

- $Q = (A \land \underline{-S}) \lor (B \land \underline{S})$
- Consider S = 0

Consider S = 1

| S | Α | В | Q |
|---|---|---|---|
| 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 |





### Selecting a signal

- $Q = (A \wedge \underline{S}) \vee (B \wedge \underline{S})$
- Consider S = 0

$$- Q = (A \wedge 1) \vee (B \wedge 0)$$

$$-Q = A \lor 0$$

$$-Q=A$$

• Consider S = 1

$$-\underline{Q} = (A \wedge 0) \vee (B \wedge 1)$$

$$-Q=0VB$$

$$-Q = B$$

| S | Α | В | Q |
|---|---|---|---|
| 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 |





# The multiplexer

- S selects which input to propagate to the output.
- 2-to-1 multiplexer
  - 1 select bit
- N-to-1 multiplexers are also possible
  - log<sub>2</sub>(N) select bitsneeded
    - Why?





### Adder-subtractor





# Ripple-carry adder-subtractor







- 1-to-2 demultiplexer
  - Choose which of <u>2 wires</u> to propagate the input signal onto.

$$-$$
 Q0 = A  $\wedge$   $-$ S

$$-Q1 = A \wedge S$$



The demultiplexer acts like a switch.

- 1-to-2 demultiplexer
  - Choose which of 2 wires to propagate the input signal onto.

$$- Q0 = A \wedge \neg S$$

$$-Q1 = A \wedge S$$





The demultiplexer acts like a switch.

- 1-to-2 demultiplexer
  - Choose which of 2 wires to propagate the input signal onto.

$$-Q0 = A \wedge \neg S$$

$$-Q1 = A \wedge S$$



| S | Α | Q0 | Q1 |  |
|---|---|----|----|--|
| 0 | 0 | 0  | 0  |  |
| 0 | 1 | 1  | 0  |  |
| 1 | 0 | 0  | 0  |  |
| 1 | 1 | 0  | 1  |  |

- 1-to-2 demultiplexer
  - Choose which of 2 wires to propagate the input signal onto.

$$-Q0 = A \wedge \neg S$$

$$-Q1 = A \wedge S$$



| S | Α | Q0 | Q1 |
|---|---|----|----|
| 0 | 0 | 0  | 0  |
| 0 | 1 | 1  | 0  |
| 1 | 0 | 0  | 0  |
| 1 | 1 | 0  | 1  |

- 1-to-2 demultiplexer
  - Choose which of 2 wires to propagate the input signal onto.

$$-Q0 = A \wedge \neg S$$

$$-Q1 = A \wedge S$$



### **K** Summary

- Used Boolean algebra to build four simple devices:
  - Demux, Mux, Adder, <u>Subtractor</u>.
- Combined Mux, NOT gate and adder to build adder-subtractor.
- We can do basic arithmetic with a bunch of NAND gates!

Imagine if we could **store** the results of that arithmetic, somehow...



#### In this lecture

#### Foundations

Data representation, logic, Boolean algebra.

#### **Building blocks**

 Transistors, transistor based logic, simple devices, storage.

#### Modules

 Memory, simple controllers, FSMs, processors and execution.

#### **Programming**

 Machine code, assembly, high-level languages, compilers.

#### Wrap-up

Operating systems, energy aware computing.



#### **K** In the next lecture

#### Foundations

Data representation, logic, Boolean algebra.

#### **Building blocks**

 Transistors, transistor based logic, simple devices, storage.

#### Modules

 Memory, simple controllers, FSMs, processors and execution.

#### **Programming**

 Machine code, assembly, high-level languages, compilers.

#### Wrap-up

Operating systems, energy aware computing.

