## Miniature Processor

Design and contribution by:

- > Mohsen Dehbashi
- > Mohammad Hashemi

```
1 lw 1,0,five
2 lw 2,1,2
3 start add 1,1,2
4 beq 0,1,done
5 j start
6
7 #done halt
8 done halt # redundant
9 five .fill 5
10 neg1 .fill -1
11 stAddr .fill start
```

python assemble.py program.as program.mc

#### Miniature Assembler



# Program Counter 32-bit Register



32-bit Instruction Field



16 Registers

immediate 16 bit /offset field

Sign Extend Unit

32 bit ALU source 2

immediate /offset field 16 bit

Load Upper Unit

32 bit

Write



# Arithmetic Logical Unit



Data Memory



Miniature Datapath

MemToReg



Control the Datapath

| ALU control | Function         |  |  |  |  |  |
|-------------|------------------|--|--|--|--|--|
| 0000        | AND              |  |  |  |  |  |
| 0001        | OR               |  |  |  |  |  |
| 0010        | add              |  |  |  |  |  |
| 0110        | subtract         |  |  |  |  |  |
| 0111        | set-on-less-than |  |  |  |  |  |
| 1100        | NOR              |  |  |  |  |  |
| 1100        | NOR              |  |  |  |  |  |
|             |                  |  |  |  |  |  |

### ALU Control Unit

|      | op<br>code | jump | branch | Mem<br>Read | Mem<br>Write | MemTo<br>Reg | ALU<br>Src | Reg<br>Dst | Reg<br>Write | jalr | lui | ALUControl |
|------|------------|------|--------|-------------|--------------|--------------|------------|------------|--------------|------|-----|------------|
| add  | 0000       | 0    | 0      | 0           | 0            | 0            | 0          | 1          | 1            | 0    | 0   | 0010       |
| sub  | 0001       | 0    | 0      | 0           | 0            | 0            | 0          | 1          | 1            | 0    | 0   | 0110       |
| slt  | 0010       | 0    | 0      | 0           | 0            | 0            | 0          | 1          | 1            | 0    | 0   | 0111       |
| or   | 0011       | 0    | 0      | 0           | 0            | 0            | 0          | 1          | 1            | 0    | 0   | 0001       |
| and  | 0100       | 0    | 0      | 0           | 0            | 0            | 0          | 1          | 1            | 0    | 0   | 0000       |
| addi | 0101       | 0    | 0      | 0           | 0            | 0            | 1          | 0          | 1            | 0    | 0   | 0010       |
| slti | 0110       | 0    | 0      | 0           | 0            | 0            | 1          | 0          | 1            | 0    | 0   | 0111       |
| ori  | 0111       | 0    | 0      | 0           | 0            | 0            | 1          | 0          | 1            | 0    | 0   | 0001       |
| lui  | 1000       | 0    | 0      | 0           | 0            | X            | X          | 0          | 1            | 0    | 1   | XXXX       |
| lw   | 1001       | 0    | 0      | 1           | 0            | 1            | 1          | 0          | 1            | 0    | 0   | 0010       |
| SW   | 1010       | 0    | 0      | 0           | 1            | X            | 1          | X          | 0            | 0    | 0   | 0010       |
| beq  | 1011       | 0    | 1      | 0           | 0            | X            | 0          | X          | 0            | 0    | 0   | 0110       |
| jalr | 1100       | 0    | 0      | 0           | 0            | X            | X          | 0          | 1            | 1    | 0   | XXXX       |
| j    | 1101       | 1    | X      | 0           | 0            | X            | X          | Χ          | 0            | X    | X   | XXXX       |



python simulate.py program.mc

#### Miniature Simulator

## Thanks!

Computer Organisations and Design Lesson **Dr. Mehran Rezaee** 

University of Isfahan, Fourth Grade

Spring 1397