# PROCESSOR DESIGN



## Input and output pins



### Some information about my processor

Data memory: 2 bytes

• Instruction memory: 8 bytes

• Word size: 8 bits

Architecture: Harvard Architecture

#### Instruction Register

| Opcode<br>MSB | Opcode | Operand_1 | Operand_1 | Operand_2 | Operand_2 | Mem_0 | Mem_1<br>LSB |
|---------------|--------|-----------|-----------|-----------|-----------|-------|--------------|
|---------------|--------|-----------|-----------|-----------|-----------|-------|--------------|

#### **Instruction Set**

1. add reg/mem,reg/mem - used for adding the data in a register/memory to the data in another register/memory.



2. mov reg,reg - used for moving the data from one register to another register.

3. mov reg,mem - used for moving the data from the memory to a register.

4. mov mem,reg - used for moving the data from the register to a memory.



#### **Testbench**

- 04 00000100 add a,b
- 08 00001000 add a,c
- 0c 00001100 add a,mem[0]
- 0d 00001101 add a,mem[1]

Instruction mem

| 000 | Add a,b      |
|-----|--------------|
| 001 | Add a,c      |
| 010 | Add a,mem[0] |
| 011 | Add a,mem[1] |
| 100 |              |
| 101 |              |
| 110 |              |
| 111 |              |

Initialization of memories:

Accumulator: 01H Register B: 02H Register C: 03H

RAM: 04H and 05H

Result stored in accumulator after the above four operations: 0FH



