## **Archi**

# Opcodes

| Opcode | Opcode(binary) | Instruction Id | Instruction Type | Instruction |
|--------|----------------|----------------|------------------|-------------|
| 0      | 0000           | L              | Memory           | lw          |
| 1      | 0001           | А              | Arithmetic       | add         |
| 2      | 0010           | В              | Arithmetic       | addi        |
| 3      | 0011           | К              | Logic            | nor         |
| 4      | 0100           | 0              | Control          | bneq        |
| 5      | 0101           | D              | Arithmetic       | subi        |
| 6      | 0110           | С              | Arithmetic       | sub         |
| 7      | 0111           | Н              | Logic            | ori         |
| 8      | 1000           | N              | Control          | beq         |
| 9      | 1001           | 1              | Logic            | sll         |
| 10     | 1010           | J              | Logic            | srl         |
| 11     | 1011           | Е              | Logic            | and         |
| 12     | 1100           | Р              | Control          | jump        |
| 13     | 1101           | F              | Logic            | andi        |
| 14     | 1110           | G              | Logic            | or          |
| 15     | 1111           | М              | Memory           | sw          |

### Instructions

| Туре | Field_1<br>bit(12-15) | Field_2<br>bit(8-11) | Field_3<br>bit(4-7) | Field_4 bit(0-3) | operations                |
|------|-----------------------|----------------------|---------------------|------------------|---------------------------|
| R    | Opcode                | Src Reg 1            | Src Reg 2           | Dst reg          | add, nor, sub,<br>and, or |
| S    | Opcode                | Src Reg 1            | Dst Reg             | Shamt            | sll, srl                  |
| I    | Opcode                | Src Reg 1            | Dst Reg             | lmmdt.           | addi, subi, ori,<br>andi  |

| Туре | Field_1<br>bit(12-15) | Field_2<br>bit(8-11) | Field_3<br>bit(4-7) | Field_4<br>bit(0-3) | operations |
|------|-----------------------|----------------------|---------------------|---------------------|------------|
| I    | Opcode                | Src Reg 1            | Src Reg 2           | Addr.               | bneq, beq  |
| I    | Opcode                | Src Reg 1            | Dst Reg             | Immdt               | lw         |
| I    | Opcode                | Src Reg 1            | Src Reg 2           | Immdt               | sw         |
| J    | Opcode                | Jump<br>Address      | Jump<br>Address     | 0                   | jump       |

# Mappings

| Control<br>Bit         | 0                                               | 1                                                       | Opcode for 0              | Opcode for 1 |
|------------------------|-------------------------------------------------|---------------------------------------------------------|---------------------------|--------------|
| RegDst                 | Field_4 as Register for write                   | Field_3 as Register for write                           | R type                    |              |
| Jump                   | Instruction is not Jump                         | Instruction is jump                                     |                           | jump         |
| Branch                 | Instruction is not branch                       | Instruction is branch                                   |                           | beq          |
| Branch<br>not<br>equal | Instruction is not bneq                         | Instruction is bneq                                     |                           | bneq         |
| Mem<br>Read            | Data not read from memory                       | Data read from memory                                   |                           | lw           |
| Mem to reg             | Data for writing to<br>memory comes from<br>ALU | Data for writing to memory comes from memory            |                           | lw           |
| Mem<br>Write           | Data not written to memory                      | Data Written to memory                                  |                           | sw           |
| Alu Src                | ALU input 2 comes from register output          | ALU input 2 comes from sign extension of immdt(Field_4) | R type                    |              |
| Reg<br>Write           | Register writing enabled                        | Register Writing Disabled                               | bneq,<br>beq,<br>jump, sw |              |

## **ALU operands mapping**

| ALU operation | control | control(binary) | operations             |
|---------------|---------|-----------------|------------------------|
| add           | 0       | 000             | lw, add, addi, jmp, sw |
| sub           | 1       | 001             | bneq, subi, sub, beq   |
| and           | 2       | 010             | and, andi              |
| or            | 3       | 011             | ori, or                |
| nor           | 4       | 100             | nor                    |
| sll           | 5       | 101             | sll                    |
| srl           | 6       | 110             | srl                    |

#### **EPROM** codes

### Atmega diagram



#### **PC rom ATMEGA**

| PIN | NO  | ROLE  | Maps To | Bit no | Comment |
|-----|-----|-------|---------|--------|---------|
| РВ  | 0-3 | Input | PC      | 7-4    |         |
| PD  | 3-6 | Input | PC      | 3-0    |         |

| PIN | NO  | ROLE     | Maps To     | Bit no | Comment |
|-----|-----|----------|-------------|--------|---------|
| PA  | 0-7 | Output   | МС          | 15-8   |         |
| РС  | 7-0 | Output   | МС          | 7-0    |         |
| PD  | 2   | Interupt | Clock Pulse |        |         |

### Register File AtMega

| PIN | NO  | ROLE   | Maps To          | Bit no | Comment |
|-----|-----|--------|------------------|--------|---------|
| РВ  | 0-3 | Input  | src reg 1        | 0-3    |         |
| РВ  | 4-7 | Input  | src reg 2        | 0-3    |         |
| PD  | 3-6 | Input  | dest reg 1       | 0-3    |         |
| РС  | 3-0 | Input  | data             | 3-0    |         |
| PD  | 2   | Input  | Clock Pulse      |        |         |
| PD  | 0   | Input  | regWrite         |        |         |
| PA  | 0-3 | Output | register value 1 | 0-3    |         |
| PA  | 4-7 | Output | register value 2 | 0-3    |         |

### ALU

| PIN | NO  | ROLE   | Maps To   | Bit no | Comment |
|-----|-----|--------|-----------|--------|---------|
| РВ  | 0-3 | Input  | operand 1 | 0-3    |         |
| PD  | 3-6 | Input  | operand 2 | 0-3    |         |
| PA  | 0-2 | Input  | control   | 0-3    |         |
| PA  | 3   | Output | zero flag |        |         |
| PA  | 4-7 | Output | Result    | 0-3    |         |

### Memory

| PIN | NO  | ROLE  | Maps To    | Bit no | Comment |
|-----|-----|-------|------------|--------|---------|
| РВ  | 0-3 | Input | Address    | 0-3    |         |
| PD  | 3-6 | Input | write data | 0-3    |         |
| PD  | 0   | Input | MemWrite   |        |         |

| PIN | NO  | ROLE   | Maps To     | Bit no | Comment |
|-----|-----|--------|-------------|--------|---------|
| PD  | 1   | Input  | MemRead     |        |         |
| PD  | 2   | Input  | Clock pulse |        |         |
| PA  | 0-3 | Output | Read Data   | 0-3    |         |

### Control

| PIN | NO  | ROLE   | Maps To | Bit no | Comment |
|-----|-----|--------|---------|--------|---------|
| PD  | 3-6 | Input  | opcode  | 0-3    |         |
| PA  | 0-7 | Output | Flag    |        |         |
| РС  | 7-4 | Output | Flag    |        |         |