## **MF16 Instruction Set Architecture User's Guide**

### **General Properties**

| Property                          | Value  |
|-----------------------------------|--------|
| Word size                         | 16 bit |
| Number of registers               | 16     |
| Number of Hardware Instructions   | 16     |
| Number of Pseudo Instructions     | 14     |
| Number of Instruction types       | 2      |
| Number of ALU instructions        | 14     |
| Memory access size                | Word   |
| Memory addressing                 | Byte   |
| Unsigned arithmetic support       | None   |
| Floating point arithmetic support | None   |

#### **Instruction Types**

R-type Instructions

|    | OPCODE | rs   | rt  | rd  |
|----|--------|------|-----|-----|
| 15 | 12     | 11 8 | 7 4 | 3 0 |

I-type Instructions

|    | OPCODE | rs   | immediate |
|----|--------|------|-----------|
| 15 | 12     | 11 8 | 7 0       |

#### **List of Hardware Instructions**

| Name                                 | Mnemonic | OPCODE | Туре | ALU Involved | Hex |
|--------------------------------------|----------|--------|------|--------------|-----|
| Add                                  | add      | 0000   | R    | yes          | 0   |
| And                                  | and      | 0001   | R    | Yes          | 1   |
| Branch on equal                      | beq      | 0010   | R    | Yes          | 2   |
| Jump Register                        | jr       | 0011   | R    | Yes          | 3   |
| Jump register and link               | jrl      | 0100   | R    | Yes          | 4   |
| Load upper immediate                 | lui      | 0101   | I    | Yes          | 5   |
| Load word                            | lw       | 0110   | R    | No           | 6   |
| Barrel Shift Right (Special feature) | bsr      | 0111   | R    | Yes          | 7   |
| Nor                                  | nor      | 1000   | R    | Yes          | 8   |
| Or                                   | or       | 1001   | R    | Yes          | 9   |
| Or immediate                         | ori      | 1010   | I    | Yes          | Α   |
| Shift left logical                   | sll      | 1011   | R    | Yes          | В   |
| Set on less than                     | slt      | 1100   | R    | Yes          | C   |
| Exclusive Or                         | xor      | 1101   | R    | Yes          | D   |
| Shift right logical                  | srl      | 1110   | R    | Yes          | Е   |
| Store word                           | SW       | 1111   | R    | No           | F   |

## **List of Registers**

| Name | Number | Description         | Preserved across a call? |
|------|--------|---------------------|--------------------------|
| \$0  | 0      | Constant value zero | N/A                      |
| \$s0 | 1      | Saved temporary     | Yes                      |
| \$s1 | 2      | Saved temporary     | Yes                      |
| \$s2 | 3      | Saved temporary     | Yes                      |
| \$s3 | 4      | Saved temporary     | Yes                      |
| \$t0 | 5      | Temporary           | No                       |
| \$t1 | 6      | Temporary           | No                       |
| \$t2 | 7      | Temporary           | No                       |
| \$t3 | 8      | Temporary           | No                       |
| \$a0 | 9      | Argument            | No                       |
| \$a1 | 10     | Argument            | No                       |
| \$la | 11     | Label Address       | No                       |
| \$sp | 12     | Stack pointer       | Yes                      |
| \$rv | 13     | Return value        | Yes                      |
| \$at | 14     | Assembler temporary | Yes                      |
| \$ra | 15     | Return address      | Yes                      |

#### Instructions

| Name        | add   | add Type R                                                  |       |         |                      |        |                         |                          |  |  |  |  |
|-------------|-------|-------------------------------------------------------------|-------|---------|----------------------|--------|-------------------------|--------------------------|--|--|--|--|
| Syntax      | add   | add rs,rt,rd                                                |       |         |                      |        |                         |                          |  |  |  |  |
| Description | Add t | the co                                                      | ntent | s of ge | neral purpose regist | ter rs | to the contents of gene | eral purpose register rt |  |  |  |  |
| Description | and s | and store the 16-bit result in general purpose register rd. |       |         |                      |        |                         |                          |  |  |  |  |
| Operation   | GPR[  | rd] ←                                                       | GPR[i | 's] + G | PR[rt]               |        |                         |                          |  |  |  |  |
| Encoding    | 0     | 0 0 0 0 rs rt rd                                            |       |         |                      |        |                         |                          |  |  |  |  |
|             |       | 4                                                           | 1     |         | 4                    |        | 4                       | 4                        |  |  |  |  |

| Name        | and   | and Type R                                                                                     |      |         |         |   |   |  |  |  |  |  |
|-------------|-------|------------------------------------------------------------------------------------------------|------|---------|---------|---|---|--|--|--|--|--|
| Syntax      | and   | and rs, rt, rd                                                                                 |      |         |         |   |   |  |  |  |  |  |
| Description | Perfo | Perform bit by bit logical and on the contents of general purpose register rs and the contents |      |         |         |   |   |  |  |  |  |  |
| Description | of ge | of general purpose register rt and store the 16-bit result in general purpose register rd.     |      |         |         |   |   |  |  |  |  |  |
| Operation   | GPR[  | rd] ←                                                                                          | GPR[ | rs] & G | iPR[rt] |   |   |  |  |  |  |  |
| Encoding    | 0     | 0 0 0 1 rs rt rd                                                                               |      |         |         |   |   |  |  |  |  |  |
|             |       | 4                                                                                              | 4    |         | 4       | 4 | 4 |  |  |  |  |  |

| Name        | beq                    |                    |        |                     | Туре                | R                        |                                                                                |  |  |  |  |  |  |
|-------------|------------------------|--------------------|--------|---------------------|---------------------|--------------------------|--------------------------------------------------------------------------------|--|--|--|--|--|--|
| Syntax      | beq rs                 | beq rs, rt, rd     |        |                     |                     |                          |                                                                                |  |  |  |  |  |  |
| Description | equal, bi<br>address i | anch to<br>s taken | the to | arget instruction v | vith a degree gener | delay of one instruction | se register rt. If they are . The target instruction The low order bit of this |  |  |  |  |  |  |
| Operation   | T: co                  | ndition            | ← (GP  | R[rs] = GPR[rt])    |                     |                          |                                                                                |  |  |  |  |  |  |
|             | T+1: if c              | onditio            | ı then |                     |                     |                          |                                                                                |  |  |  |  |  |  |
|             | ļ                      | $PC \leftarrow rd$ |        |                     |                     |                          |                                                                                |  |  |  |  |  |  |
| Encoding    | 0 0                    | 0 0 1 0 rs rt rd   |        |                     |                     |                          |                                                                                |  |  |  |  |  |  |
|             |                        | 4                  |        | 4                   |                     | 4                        | 4                                                                              |  |  |  |  |  |  |

| Name        | jr       | jr R                                                                                                                                                                                                                          |  |   |  |   |   |  |  |  |  |  |  |
|-------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|---|--|---|---|--|--|--|--|--|--|
| Syntax      | jr rd    | jr rd                                                                                                                                                                                                                         |  |   |  |   |   |  |  |  |  |  |  |
| Description | of gener | Unconditionally jump to the address contained in the general purpose register rd. The contents of general purpose registers rt and rs must be zero. The low order bit of rd must be zero so that the address is word-aligned. |  |   |  |   |   |  |  |  |  |  |  |
| Operation   |          |                                                                                                                                                                                                                               |  |   |  |   |   |  |  |  |  |  |  |
| Encoding    | 0 1      | 0 1 0 0 SBZ SBZ rd                                                                                                                                                                                                            |  |   |  |   |   |  |  |  |  |  |  |
|             |          | 4                                                                                                                                                                                                                             |  | 4 |  | 4 | 4 |  |  |  |  |  |  |

| Name        | jrl           | jrl Type R                                                                                                                                                                                                                                                                                                                          |   |   |     |   |     |    |  |  |  |  |  |
|-------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|-----|---|-----|----|--|--|--|--|--|
| Syntax      | jrl           | jrl rd                                                                                                                                                                                                                                                                                                                              |   |   |     |   |     |    |  |  |  |  |  |
| Description | of th<br>gene | Unconditionally jump to the address contained in the general purpose register rd. The address of the instruction after the next instruction is placed into the link register \$\\$7a\$. The contents of general purpose registers rt and rs must be zero. The low order bit of rd must be zero so that the address is word-aligned. |   |   |     |   |     |    |  |  |  |  |  |
| Operation   | T:<br>T+1:    |                                                                                                                                                                                                                                                                                                                                     |   |   |     |   |     |    |  |  |  |  |  |
| Encoding    | 0             | 1                                                                                                                                                                                                                                                                                                                                   | 0 | 0 | SBZ |   | SBZ | rd |  |  |  |  |  |
|             |               |                                                                                                                                                                                                                                                                                                                                     | 4 |   | 4   | • | 4   | 4  |  |  |  |  |  |

| Name        | lui   | lui Type I                                                                                  |        |           |                            |   |  |  |  |  |  |
|-------------|-------|---------------------------------------------------------------------------------------------|--------|-----------|----------------------------|---|--|--|--|--|--|
| Syntax      | lui   | lui rs,immediate                                                                            |        |           |                            |   |  |  |  |  |  |
| Description | Place | Place the contents of the 8-bit immediate field into the high order bits of general purpose |        |           |                            |   |  |  |  |  |  |
|             | regis | ter rs                                                                                      | and se | et all th | ne low order bits to zero. |   |  |  |  |  |  |
| Operation   | GPR[  | rs] ←                                                                                       | imme   | diate     | 08                         |   |  |  |  |  |  |
| Encoding    | 0     | 0 1 0 1 rs immediate                                                                        |        |           |                            |   |  |  |  |  |  |
|             |       | 4                                                                                           | 4      |           | 4                          | 8 |  |  |  |  |  |

| Name        | lw    | lw Type R                                                                                 |        |        |                     |          |                          |                          |  |  |  |  |  |
|-------------|-------|-------------------------------------------------------------------------------------------|--------|--------|---------------------|----------|--------------------------|--------------------------|--|--|--|--|--|
| Syntax      | lw ı  | lw rs,rt                                                                                  |        |        |                     |          |                          |                          |  |  |  |  |  |
| Description | Then  | Then load into general purpose register rs, one word from memory at the address stored in |        |        |                     |          |                          |                          |  |  |  |  |  |
|             | gene  | ral pu                                                                                    | rpose  | regist | er rt. The lowest o | rder bit | t of the address must be | zero so that it is word- |  |  |  |  |  |
|             | align | ed.                                                                                       |        |        |                     |          |                          |                          |  |  |  |  |  |
| Operation   | T:    | mer                                                                                       | n ← L  | oadM   | emory(WORD,GPF      | R[rt])   |                          |                          |  |  |  |  |  |
|             | T+1:  | GPR                                                                                       | [rt] ← | mem    |                     |          |                          |                          |  |  |  |  |  |
| Encoding    | 0     | 0 1 1 0 rs rt SBZ                                                                         |        |        |                     |          |                          |                          |  |  |  |  |  |
|             |       |                                                                                           | 1      | •      | 4                   |          | 4                        | 4                        |  |  |  |  |  |

| Name        | bsr   |                                                                                                                                                                                                                                                                                |  |  |  | Туре | R |  |  |  |
|-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|------|---|--|--|--|
| Syntax      | bsr   | bsr rs,rt,rd                                                                                                                                                                                                                                                                   |  |  |  |      |   |  |  |  |
| Description | highe | Right circular shift the contents of general purpose register, inserting lowest order bit into the nighest order bit. The shift amount is specified by the lower 4 bits of the contents of general purpose register rs. The result is placed into general purpose register rd. |  |  |  |      |   |  |  |  |
| Operation   | GPR[  | $GPR[rd] \leftarrow GPR[rt] \circlearrowleft_{shamt}$ (where shamt = $GPR[rs]_{30}$ )                                                                                                                                                                                          |  |  |  |      |   |  |  |  |
| Encoding    | 0     | 0 1 1 1 rs rt rd                                                                                                                                                                                                                                                               |  |  |  |      |   |  |  |  |
|             |       | 4 4 4                                                                                                                                                                                                                                                                          |  |  |  |      |   |  |  |  |

| Name        | nor   | nor Type R                                                                                       |   |  |   |  |   |   |  |  |  |
|-------------|-------|--------------------------------------------------------------------------------------------------|---|--|---|--|---|---|--|--|--|
| Syntax      | nor   | nor rs,rt,rd                                                                                     |   |  |   |  |   |   |  |  |  |
| Description | Perfo | Perform bit by bit logical or on the contents of general purpose register rs and the contents of |   |  |   |  |   |   |  |  |  |
|             | gener | general purpose register rt and place the complement of the result in general purpose register   |   |  |   |  |   |   |  |  |  |
|             | rd.   | rd.                                                                                              |   |  |   |  |   |   |  |  |  |
| Operation   | GPR[r | $GPR[rd] \leftarrow \neg (GPR[rs] \mid GPR[rt])$                                                 |   |  |   |  |   |   |  |  |  |
| Encoding    | 0     | 0 1 1 1 rs rt rd                                                                                 |   |  |   |  |   |   |  |  |  |
|             |       |                                                                                                  | 1 |  | 4 |  | 4 | 4 |  |  |  |

| Name        | or    | or Type R                                                                                       |   |  |   |   |   |  |  |
|-------------|-------|-------------------------------------------------------------------------------------------------|---|--|---|---|---|--|--|
| Syntax      | or :  | or rs,rt,rd                                                                                     |   |  |   |   |   |  |  |
| Description | Perfo | erform bit by bit logical or on the contents of general purpose register rs and the contents of |   |  |   |   |   |  |  |
|             | gene  | general purpose register rt and place the result in general purpose register rd.                |   |  |   |   |   |  |  |
| Operation   | GPR[  | GPR[rd] ← GPR[rs]   GPR[rt]                                                                     |   |  |   |   |   |  |  |
| Encoding    | 1     | 1 0 0 1 rs rt rd                                                                                |   |  |   |   |   |  |  |
|             |       |                                                                                                 | 1 |  | 4 | 4 | 4 |  |  |

| Name        | ori  | ori Type I                                                                                                                                                                                        |  |  |  |  |  |  |  |  |
|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Syntax      | ori  | ori rs,immediate                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Description | exte | erform bit by bit logical or on the contents of general purpose register rs and the zero extended contents of the immediate field and store the result by overwriting general purpose egister rs. |  |  |  |  |  |  |  |  |
| Operation   | GPR[ | $PR[rd] \leftarrow GPR[rs] \mid (0^8 \mid   immediate)$                                                                                                                                           |  |  |  |  |  |  |  |  |
| Encoding    | 1    | 1 0 1 0 rs immediate                                                                                                                                                                              |  |  |  |  |  |  |  |  |
|             |      | 4 4 8                                                                                                                                                                                             |  |  |  |  |  |  |  |  |

| Name        | sll   | sll Type R                                                                                        |   |  |   |  |   |   |  |  |
|-------------|-------|---------------------------------------------------------------------------------------------------|---|--|---|--|---|---|--|--|
| Syntax      | sll   | sll rs,rt,rd                                                                                      |   |  |   |  |   |   |  |  |
| Description | The o | The contents of general purpose register rt is shifted left, inserting zeros into low order bits. |   |  |   |  |   |   |  |  |
|             | The s | The shift amount is specified by the lower 4 bits of the contents of general purpose register rs. |   |  |   |  |   |   |  |  |
|             | The r | The result is placed into general purpose register rd.                                            |   |  |   |  |   |   |  |  |
| Operation   | GPR[  | $GPR[rd] \leftarrow GPR[rt]_{16-shamt0} \mid\mid 0^{shamt} \text{ (where shamt = } GPR[rs]_{30})$ |   |  |   |  |   |   |  |  |
| Encoding    | 1     | 1 0 1 1 rs rt rd                                                                                  |   |  |   |  |   |   |  |  |
|             |       | 4                                                                                                 | 4 |  | 4 |  | 4 | 4 |  |  |

| Name        | slt   | slt Type R                                                                                      |   |  |   |   |   |  |  |
|-------------|-------|-------------------------------------------------------------------------------------------------|---|--|---|---|---|--|--|
| Syntax      | slt   | slt rs,rt,rd                                                                                    |   |  |   |   |   |  |  |
| Description | Com   | ompare the contents of general purpose register rs with the contents of general purpose         |   |  |   |   |   |  |  |
|             | regis | egister rt. If the former is smaller than the latter, set the general purpose register rd to 1. |   |  |   |   |   |  |  |
| Operation   |       |                                                                                                 |   |  |   |   |   |  |  |
| Encoding    | 1     | 1 1 0 0 rs rt rd                                                                                |   |  |   |   |   |  |  |
|             |       |                                                                                                 | 1 |  | 4 | 4 | 4 |  |  |

| Name        | xor   |                                                                                                |  |  | Тур | е | R |  |  |  |
|-------------|-------|------------------------------------------------------------------------------------------------|--|--|-----|---|---|--|--|--|
| Syntax      | xor   | xor rs,rt,rd                                                                                   |  |  |     |   |   |  |  |  |
| Description | Perfo | erform bit by bit exclusive or on the contents of general purpose register rs and the contents |  |  |     |   |   |  |  |  |
|             | of ge | of general purpose register rt and place the result in general purpose register rd.            |  |  |     |   |   |  |  |  |
| Operation   | GPR[  | GPR[rd] ← GPR[rs] ⊕ GPR[rt]                                                                    |  |  |     |   |   |  |  |  |
| Encoding    | 1     | 1 1 0 1 rs rt rd                                                                               |  |  |     |   |   |  |  |  |
|             |       | 4 4 4                                                                                          |  |  |     |   |   |  |  |  |

| Name        | srl Type R |                                                                                                     |   |  |   |  |   |   |  |  |
|-------------|------------|-----------------------------------------------------------------------------------------------------|---|--|---|--|---|---|--|--|
| Syntax      | srl        | srl rs,rt,rd                                                                                        |   |  |   |  |   |   |  |  |
| Description | The o      | The contents of general purpose register rt is shifted right, inserting zeros into high order bits. |   |  |   |  |   |   |  |  |
|             | The s      | The shift amount is specified by the lower 4 bits of the contents of general purpose register rs.   |   |  |   |  |   |   |  |  |
|             | The r      | The result is placed into general purpose register rd.                                              |   |  |   |  |   |   |  |  |
| Operation   | GPR[       | $GPR[rd] \leftarrow 0^{shamt} \mid   GPR[rt]_{shamt0}$ (where shamt = $GPR[rs]_{30}$ )              |   |  |   |  |   |   |  |  |
| Encoding    | 1          | 1 1 1 0 rs rt rd                                                                                    |   |  |   |  |   |   |  |  |
|             |            | 4                                                                                                   | 1 |  | 4 |  | 4 | 4 |  |  |

| Name        | SW Type R                                                                                    |  |  |  |  |  |  |  |
|-------------|----------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Syntax      | sw rs,rt                                                                                     |  |  |  |  |  |  |  |
| Description | Store in memory, the contents of general purpose register rs at the address specified by the |  |  |  |  |  |  |  |
|             | contents of general purpose register rt. The lowest order bit of the address must be zero so |  |  |  |  |  |  |  |
|             | that it is word-aligned.                                                                     |  |  |  |  |  |  |  |
| Operation   | T: temp $\leftarrow$ GPR[rt]                                                                 |  |  |  |  |  |  |  |
|             | T+1: LoadMemory(WORD,temp)                                                                   |  |  |  |  |  |  |  |
| Encoding    | 1 1 1 1 rs rt SBZ                                                                            |  |  |  |  |  |  |  |
|             | 4 4 4 4                                                                                      |  |  |  |  |  |  |  |

#### **List of Pseudo Instructions**

| Name              | Mnemonic |
|-------------------|----------|
| Load immediate    | li       |
| Add immediate     | addi     |
| And immediate     | andi     |
| Subtract          | sub      |
| Load word offset  | lwo      |
| Store word offset | SWO      |

| Name              | Mnemonic |
|-------------------|----------|
| Push onto stack   | push     |
| Pop from stack    | pop      |
| Call a subroutine | call     |
| Jump              | jmp      |
| Jump if equal     | jeq      |
| sll by immediate  | slli     |

| Name             | Mnemonic |
|------------------|----------|
| srl by immediate | srli     |
| bsr by immediate | bsri     |

Note: The greyed-out instructions were never used in demo programs.

#### **Pseudo-instructions**

| Name                     | li Number of hardware instructions: 2                              |
|--------------------------|--------------------------------------------------------------------|
| Syntax                   | li rs,immediate                                                    |
| Description              | Place the 16-bit immediate value into general purpose register rs. |
| Translated Assembly Code | lui rs,immediate <sub>158</sub> ori rs,immediate <sub>70</sub>     |

| Name                           | addi                                                                                                                                      | Number of hardware instructions: 3 |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Syntax                         | addi rs,immediate,rd                                                                                                                      |                                    |
| Description                    | Add the contents of general purpose register rs to the 16-bit immediate value and store the 16-bit result in general purpose register rd. |                                    |
| Translated<br>Assembly<br>Code | li \$at, immediate add rs,\$at,rd                                                                                                         |                                    |

| Name        | andi                                                                                         | Number of hardware instructions: 3 |
|-------------|----------------------------------------------------------------------------------------------|------------------------------------|
| Syntax      | andi rs,immediate,rd                                                                         |                                    |
| Description | Perform bit by bit logical and on the contents of general purpose register rs and the 16-bit |                                    |
|             | immediate value and store the 16-bit result in general purpose register rd.                  |                                    |
| Translated  |                                                                                              |                                    |
| Assembly    | li \$at, immediate and rs,\$at,rd                                                            |                                    |
| Code        | and is, yac, id                                                                              |                                    |

| Name        | sub                                                                                                | Number of hardware instructions: 13 |
|-------------|----------------------------------------------------------------------------------------------------|-------------------------------------|
| Syntax      | sub rs, rt, rd                                                                                     |                                     |
| Description | Subtract the contents of general purpose register rt from the contents of general purpose          |                                     |
|             | register rs and store the 16-bit result in general purpose register rd. Using the same register as |                                     |
|             | rt and rd is not allowed.                                                                          |                                     |
|             | push rt                                                                                            |                                     |
| Translated  | nor rt, \$0, rt                                                                                    |                                     |
| Assembly    | addi rt, 0x1, rt                                                                                   |                                     |
| Code        | add rs, rt, rd                                                                                     |                                     |
|             | pop rt                                                                                             |                                     |

| Name                           | lwo                                                                                                                                                                                                                                                                | Number of hardware instructions: 4 |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Syntax                         | lwo rs, rt, immediate                                                                                                                                                                                                                                              |                                    |
| Description                    | Then load into general purpose register rs, one word from memory. The memory address is specified by adding the immediate value to the address stored in general purpose register rt. The lowest order bit of the address must be zero so that it is word-aligned. |                                    |
| Translated<br>Assembly<br>Code | addi rt, immediate, \$at<br>lw rs, \$at                                                                                                                                                                                                                            |                                    |

| Name                     | swo                                                                                                                                                                                                                                                             | Number of hardware instructions: 4 |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Syntax                   | swo rs, rt, immediate                                                                                                                                                                                                                                           |                                    |
| Description              | Store the contents of general purpose register rs into memory. The memory address is specified by adding the immediate value to the address stored in general purpose register rt. The lowest order bit of the address must be zero so that it is word-aligned. |                                    |
| Translated Assembly Code | addi rt, immediate, \$at sw rs, \$at                                                                                                                                                                                                                            |                                    |

| Name                     | push                                                                              | Number of hardware instructions: 4                    |
|--------------------------|-----------------------------------------------------------------------------------|-------------------------------------------------------|
| Syntax                   | push rs                                                                           |                                                       |
| Description              | Decrement the content of the stack point purpose register rs on top of the stack. | nter by a word size and store the contents of general |
| Translated Assembly Code | addi \$sp, 0xFFFE, \$sp<br>sw rs, \$sp                                            |                                                       |

| Name        | рор                                      | Number of hardware instructions: 4                   |
|-------------|------------------------------------------|------------------------------------------------------|
| Syntax      | pop rs                                   |                                                      |
| Description | Load a word from top of the stack into g | eneral purpose register rs and increment the content |
|             | of the stack pointer by a word size.     |                                                      |
| Translated  | l. ne ćen                                |                                                      |
| Assembly    | lw rs, \$sp<br>addi \$sp, 0x2, \$sp      |                                                      |
| Code        | auur ysp, usz, ysp                       |                                                      |

| Name        | call                                                                                             | Number of hardware instructions: 11 |
|-------------|--------------------------------------------------------------------------------------------------|-------------------------------------|
| Syntax      | call %func                                                                                       |                                     |
| Description | Call a function specified by label %func. The label address is first put into \$la register. The |                                     |
|             | contents of \$ra register are saved onto the stack. A jump and link is then performed on the     |                                     |
|             | address stored in \$la. Finally, the \$ra is restored from the stack after returning from the    |                                     |
|             | function.                                                                                        |                                     |
| Translated  | li \$la, %func                                                                                   |                                     |
| Assembly    | push \$ra                                                                                        |                                     |
| Code        | jrl \$la                                                                                         |                                     |
| Code        | pop \$ra                                                                                         |                                     |

| Name        | jmp Number of hardware instructions: 3                                                        |  |
|-------------|-----------------------------------------------------------------------------------------------|--|
| Syntax      | jmp %label                                                                                    |  |
| Description | Jump to the instruction address specified by label %label. The address of the %label is first |  |
|             | stored in \$la. An unconditional jump is then performed to the address stored in \$la.        |  |
| Translated  | l; čla vlabal                                                                                 |  |
| Assembly    | li \$la, %label<br>jr \$la                                                                    |  |
| Code        | Ji Yia                                                                                        |  |

| Name        | jeq                                                                                              | Number of hardware instructions: 3 |
|-------------|--------------------------------------------------------------------------------------------------|------------------------------------|
| Syntax      | jeq rs,rt,%label                                                                                 |                                    |
| Description | Compare the contents of general purpose register rs and general purpose register rt. If they are |                                    |
|             | equal, branch to the target instruction specified by label %label. The address of the %label is  |                                    |
|             | first stored in \$la. A conditional jump is then performed to the address stored in \$la.        |                                    |
| Translated  | 1                                                                                                |                                    |
| Assembly    | li \$la, %label                                                                                  |                                    |
| Code        | beq rs, rt, \$la                                                                                 |                                    |

| Name                     | slli                                                                                                                                                                                                                     | Number of hardware instructions: 3 |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Syntax                   | slli shamt,rt,rd                                                                                                                                                                                                         |                                    |
| Description              | The contents of general purpose register rt is shifted left, inserting zeros into low order bits. The shift amount is specified by the 4 bits of the shamt field. The result is placed into general purpose register rd. |                                    |
| Translated Assembly Code | li \$at, shamt<br>sll \$at, rt, rd                                                                                                                                                                                       |                                    |

| Name        | srli                                                                                                | Number of hardware instructions: 3 |
|-------------|-----------------------------------------------------------------------------------------------------|------------------------------------|
| Syntax      | srli shamt,rt,rd                                                                                    |                                    |
| Description | The contents of general purpose register rt is shifted right, inserting zeros into high order bits. |                                    |
|             | The shift amount is specified by the 4 bits of the shamt field. The result is placed into general   |                                    |
|             | purpose register rd.                                                                                |                                    |
| Translated  | li ¢at abamt                                                                                        |                                    |
| Assembly    | li \$at, shamt<br>srl \$at, rt, rd                                                                  |                                    |
| Code        | SII Pat, It, It                                                                                     |                                    |

| Name        | bsri                                                                                               | Number of hardware instructions: 3 |  |
|-------------|----------------------------------------------------------------------------------------------------|------------------------------------|--|
| Syntax      | bsri shamt, rt, rd                                                                                 |                                    |  |
| Description | Right circular shift the contents of general purpose register, inserting lowest order bit into the |                                    |  |
|             | highest order bit. The shift amount is specified by the 4 bits of the shamt field. The result is   |                                    |  |
|             | placed into general purpose register rd.                                                           |                                    |  |
| Translated  | li Cat abamt                                                                                       |                                    |  |
| Assembly    | li \$at, shamt<br>bsr \$at, rt, rd                                                                 |                                    |  |
| Code        | DSI Yac, IC, IC                                                                                    |                                    |  |

## **Assembler Syntax Rules**

| Comments         | '#' symbol indicates the beginning of a line comment.                                          |  |  |
|------------------|------------------------------------------------------------------------------------------------|--|--|
|                  | All text after the first occurrence of '#' will be ignored.                                    |  |  |
| Blank lines      | Blank lines are ignored                                                                        |  |  |
| Label definition | Label definitions must be the first token on the line immediately followed by a ':' character. |  |  |
|                  | Labels can contain upper and lower case characters and digits.  Example:                       |  |  |
|                  | Labell: add \$t1, \$0, \$t1                                                                    |  |  |
| Label usage      | Labels can be addressed by using the '%' character immediately followed by the label           |  |  |
|                  | name.                                                                                          |  |  |
|                  | Example:                                                                                       |  |  |
|                  | call %Label1                                                                                   |  |  |
| Directives       | Current directive usage is limited to asciiz and must follow the format below:                 |  |  |
|                  | Labelname: .asciiz your text goes here                                                         |  |  |
|                  | Note that the remainder of the line after the first whitespaces following .asciiz is taken     |  |  |
|                  | as data. The data is appended with \n\0.                                                       |  |  |
|                  | Directives can come anywhere within the assembly code.                                         |  |  |
| Registers        | All register names must start with '\$' character.                                             |  |  |
| Immediate values | s Only hexadecimal immediate values are allowed. Hex values must start with "0x".              |  |  |
|                  |                                                                                                |  |  |

## **Control Signals**

| Signal          | Values                     | Description                                                                                                                                                              |  |
|-----------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| writePC         | 1 0                        | Enable/Disable writing to PC register                                                                                                                                    |  |
| memAddrSrc      | pc<br>regfile              | Source of memory address for memory operations.                                                                                                                          |  |
| writeMem        | 1 0                        | Indicate read/write memory operation                                                                                                                                     |  |
| writeIR         | 1 0                        | Enable/Disable writing to Instruction register                                                                                                                           |  |
| regFileWriteSrc | alu<br>mem<br>ir<br>nextPC | Specifies the source of the data being written to a register in the register file.                                                                                       |  |
| writeReg        | rs<br>rt<br>rd<br>ra<br>no | Specifies if a register is being written to or not. If writing, it specified which register it is. It can be one of the 3 register specified in the instruction or \$ra. |  |
| doBranch        | 1 0                        | Specifies if current instruction involves branching.                                                                                                                     |  |
| aluIn1Src       | regfile<br>ir              | Specifies the source of first argument to the ALU.                                                                                                                       |  |
| aluOpcode       | One of 16 opcodes          | The opcode value passed to the ALU from the control unit.                                                                                                                |  |
| memRequest      | 1 0                        | CPU tells the memory unit if a memory access was requested                                                                                                               |  |
| memDone         | 1 0                        | Memory unit tells the CPU if a memory access was completed                                                                                                               |  |
| init_sig        | 1 0                        | Specifies if all registers and CPU state must be reset                                                                                                                   |  |

# **MF16 CPU Operation**

The table below shows the steps of the CPU operation for all of the 16 instructions.

| CPU FSM State | Clock<br>Cycle | Clock<br>State  | Actions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Memory Unit State | Description                                                                                                                |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------|
|               | Cycle          | Rising          | init_sig = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                   |                                                                                                                            |
| Initial       | 1              | edge<br>Falling | All registers are latched with their initial                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                   | This state is only visited once in the beginning of program execution or upon user intervention for resetting the program. |
|               |                | edge            | values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                   | discrimental resetting the program.                                                                                        |
|               |                |                 | If memory is ready: writePC = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                                                                                                                            |
|               |                | Rising          | doBranch = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | mamBaady/Novt     |                                                                                                                            |
|               | 2              | edge            | writeReg = no<br>memAddrSrc = pc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | memReady4Next     |                                                                                                                            |
|               |                |                 | writeMem = 0<br>memRequest = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                                                                                                                            |
|               |                | Falling         | memmequest – 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                                                                                                                            |
|               |                | edge<br>Rising  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                                                                                                                            |
| Fetch         | 3              | edge            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                                                                                                                            |
|               |                | Falling<br>edge |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                                                                                                                            |
|               |                | Rising          | Memory unit is busy reading next instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | memReady4Ctrl     |                                                                                                                            |
|               | 4              | edge<br>Falling |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                                                                                                                            |
|               |                | edge<br>Rising  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | memReady4Data     |                                                                                                                            |
|               | 5              | edge            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                                                                                                                            |
|               | 3              | Falling<br>edge | Memory unit output is now valid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                                                                                                                            |
|               |                | Rising          | If memory is ready:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                   |                                                                                                                            |
| Decode        | 6              | edge            | memRequest = 0<br>writeIR = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                   |                                                                                                                            |
|               |                | Falling         | Instruction register output becomes valid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                   |                                                                                                                            |
|               |                | edge            | writeIR = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                   |                                                                                                                            |
|               |                |                 | add, and, or, nor, slt, sll, srl, xor, bsr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                   |                                                                                                                            |
|               |                |                 | aluIn1Src = reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                                                                                                                            |
|               |                |                 | ori, lui aluIn1Src = ir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                   |                                                                                                                            |
|               |                |                 | beq, jr, jrl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | memReady4Next     |                                                                                                                            |
|               | 7              | Rising<br>edge  | aluIn1Src = reg<br>doBranch =1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ,                 |                                                                                                                            |
|               |                |                 | lw<br>memAddrSrc = reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                   |                                                                                                                            |
|               |                |                 | writeMem = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                   |                                                                                                                            |
|               |                |                 | memRequest = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                                                                                                                            |
| Execute and   |                |                 | memAddrSrc = reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                   |                                                                                                                            |
| Memory Access |                |                 | writeMem = 1<br>memRequest = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                                                                                                                            |
|               |                | Falling<br>edge |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                                                                                                                            |
|               |                | Rising          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                                                                                                                            |
|               | 8              | edge<br>Falling |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                                                                                                                            |
|               |                | edge            | NA ome om consist in the constant of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | memReady4Ctrl     | This period only exists when memory access instructions are being executed (sw and lw).                                    |
|               |                | Rising<br>edge  | Memory unit is busy working for sw and lw instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                   |                                                                                                                            |
|               | Falling        |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                                                                                                                            |
|               |                | edge<br>Rising  | - r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | memReady4Data     |                                                                                                                            |
|               | 10             | edge<br>Falling | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                   |                                                                                                                            |
|               |                | edge            | If we are a great in the state of the state |                   |                                                                                                                            |
| Write Back    | 11             |                 | If memory is ready: writePC = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                                                                                                                            |
|               |                | Rising<br>edge  | memRequest = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | memReady4Next     |                                                                                                                            |
|               |                |                 | add, and, or, nor, sll, srl, xor, bsr, slt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                   |                                                                                                                            |
|               |                |                 | regFileWriteSrc = alu<br>writeReg = rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                   |                                                                                                                            |
|               |                |                 | ori, lui                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                   |                                                                                                                            |
|               |                |                 | regFileWriteSrc = alu<br>writeReg = rs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                   |                                                                                                                            |
|               |                |                 | jrl regFileWriteSrc = nextPC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                   |                                                                                                                            |
|               |                |                 | writeReg = ra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                   |                                                                                                                            |
|               |                |                 | lw<br>regFileWriteSrc = mem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                   |                                                                                                                            |
|               |                | Falling         | writeReg = rs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                   |                                                                                                                            |
|               |                | edge            | Register file and PC become valid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                   |                                                                                                                            |