

# Week 5 – CPU

## ① Memory



- 16 bit, 16 k RAM chip → RAM
- built in 8k screen chip → Screen
- built in keyboard chip → keyboard

|                            |   | <i>add[14]</i> |   |                         |
|----------------------------|---|----------------|---|-------------------------|
| 0                          | : | 0000           | ⇒ | 000 000 RAM start       |
| 16383                      | : | 3FFF           | ⇒ | 071 FFF RAM end         |
| 16384                      | : | 4000           | ⇒ | 100 000 Screen start    |
| 24575                      | : | 5FFF           | ⇒ | 151 FFF Screen end      |
| 24576                      | : | 6000           | ⇒ | 110 000 <u>Keyboard</u> |
| <i>No I/P for keyboard</i> |   |                |   |                         |

i.e

| address [14] | Output |
|--------------|--------|
| 0            | Load   |
| 1            | Load   |

load →  $\begin{array}{|c|} \hline 1 \times 2 \\ \hline \end{array}$  → RAM → To Screen

add [14]

| address [13..14] | Out       |
|------------------|-----------|
| 00               | Ramout    |
| 01               | Ramout    |
| 10               | Screenout |
| 11               | kbout     |



## ② CPU



(CPU as black box)

- \* The ROM is loaded with a Hack program. When reset button is pushed the program starts running.
- \* At any point of time, there is always a selected register in the instruction memory and there is always a selected memory register in the data memory. So something always comes into the CPU.

# CPU Implementation



## The C-instruction: symbolic and binary syntax

Symbolic syntax: *dest* = *comp* ; *jump*

Binary syntax: 1 1 1 a c1 c2 c3 c4 c5 c6 d1 d2 d3 j1 j2 j3

| <i>comp</i> |     | c1 c2 c3 c4 c5 c6 |
|-------------|-----|-------------------|
| 0           |     | 1 0 1 0 1 0       |
| 1           |     | 1 1 1 1 1 1       |
| -1          |     | 1 1 1 0 1 0       |
| D           |     | 0 0 1 1 0 0       |
| A           | M   | 1 1 0 0 0 0       |
| !D          |     | 0 0 1 1 0 1       |
| !A          | !M  | 1 1 0 0 0 1       |
| -D          |     | 0 0 1 1 1 1       |
| -A          | -M  | 1 1 0 0 1 1       |
| D+1         |     | 0 1 1 1 1 1       |
| A+1         | M+1 | 1 1 0 1 1 1       |
| D-1         |     | 0 0 1 1 1 0       |
| A-1         | M-1 | 1 1 0 0 1 0       |
| D+A         | D+M | 0 0 0 0 1 0       |
| D-A         | D-M | 0 1 0 0 1 1       |
| A-D         | M-D | 0 0 0 1 1 1       |
| D&A         | D&M | 0 0 0 0 0 0       |
| D A         | D M | 0 1 0 1 0 1       |
| a=0         | a=1 |                   |

| <i>dest</i> | d1 d2 d3 | effect: the value is stored in:    |
|-------------|----------|------------------------------------|
| null        | 0 0 0    | The value is not stored            |
| M           | 0 0 1    | RAM[A]                             |
| D           | 0 1 0    | D register                         |
| MD          | 0 1 1    | RAM[A] and D register              |
| A           | 1 0 0    | A register                         |
| AM          | 1 0 1    | A register and RAM[A]              |
| AD          | 1 1 0    | A register and D register          |
| AMD         | 1 1 1    | A register, RAM[A], and D register |

| <i>jump</i> | j1 j2 j3 | effect:            |
|-------------|----------|--------------------|
| null        | 0 0 0    | no jump            |
| JGT         | 0 0 1    | if out > 0 jump    |
| JEQ         | 0 1 0    | if out = 0 jump    |
| JGE         | 0 1 1    | if out ≥ 0 jump    |
| JLT         | 1 0 0    | if out < 0 jump    |
| JNE         | 1 0 1    | if out ≠ 0 jump    |
| JLE         | 1 1 0    | if out ≤ 0 jump    |
| JMP         | 1 1 1    | Unconditional jump |

## Instructions

A instruction  $\Rightarrow$  Instruction [15] = 0 [@ value  
15bit]  
C instruction  $\Rightarrow$  Instruction [15] = 1

111 a cccccc d<sub>1</sub> d<sub>2</sub> d<sub>3</sub> j<sub>1</sub> j<sub>2</sub> j<sub>3</sub>



By this way we select the type of instruction.

## A Register



- \* If A instruction, Store address in A
- \* For C instruction, if destination bit d<sub>1</sub> is 1, store result in A.

is load of A = 1 in these 2 cases.

- \* If not an A instruction, AW op is given to A.



### D Register



load = 1 when Cinst & d2 = 1



Cinst: 111  $\textcircled{a}$  c1 or c3 c4 c5 c6 d1 d2 d3  
j1 j2 j3

## ALU



## Outputs

① Write M



② Address M  $\rightarrow$  Register  $S[14][0 \dots 14]$



③ Out M



④ PC



$z_8 \rightarrow$  Indicates  $\delta/P$  is zero

$ng \rightarrow$  Indicates  $\delta/P$  is -ve



$z_8 \rightarrow$   $j_{eq}$  (Jump if equal to zero)

$j_2 \rightarrow$   $j_{gt}$  (greater than 0)

$j_1 \rightarrow$   $j_{lt}$  (less than 0)

Jump if  $j_{eq}$  or  $j_{gt}$  or  $j_{lt}$  is 1 & it is a c instruction



③

## Computer

