## Opcodes

| Oncode                                                     | Name                             | Action                                                                                             | Oncodo | hitfiald |              |            |          |         |
|------------------------------------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------|--------|----------|--------------|------------|----------|---------|
| Opcode Name Action Opcode bitfields  Arithmetic Logic Unit |                                  |                                                                                                    |        |          |              |            |          |         |
|                                                            | Add                              | ud_uc.lub                                                                                          | 000000 | luo I    | net-         | ud         | 00000    | 100000  |
| · ·                                                        | Add Immediate                    | rd=rs+rt                                                                                           | 001000 |          |              |            |          | 100000  |
|                                                            | Add Immediate Unsigned           | rt=rs+imm<br>rt=rs+imm                                                                             | 001000 |          |              | imr<br>imr |          |         |
| ADDU rd,rs,rt                                              | Add Unsigned                     | rd=rs+rt                                                                                           | 000000 |          | rt           | _          | 00000    | 100001  |
|                                                            | And                              | rd=rs&rt                                                                                           | 000000 |          | rt           |            | 00000    | 100100  |
|                                                            | And Immediate                    | rt=rs&imm                                                                                          | 001100 |          | rt           |            |          | 100100  |
| ANDI rt,rs,imm<br>LUI rt,imm                               | Load Upper Immediate             | rt=imm<<16                                                                                         | 001100 |          |              | imr        |          |         |
| <u> </u>                                                   | Nor                              |                                                                                                    | 000000 |          | rt           | imr        | 00000    | 100111  |
| NOR rd,rs,rt OR rd,rs,rt                                   | Or                               | rd=~(rs rt)<br>rd=rs rt                                                                            | 000000 |          | rt           |            | 00000    | 100111  |
| ORI rt,rs,imm                                              | Or Immediate                     | rt=rs imm                                                                                          | 001101 |          |              |            |          | 100101  |
| SLT rd,rs,rt                                               | Set On Less Than                 | rd=rs <rt< td=""><td>000000</td><td></td><td>rt</td><td>imr</td><td></td><td>101010</td></rt<>     | 000000 |          | rt           | imr        |          | 101010  |
| SLTI rt,rs,imm                                             |                                  | rt=rs <imm< td=""><td>001010</td><td></td><td>rt</td><td></td><td></td><td>101010</td></imm<>      | 001010 |          | rt           |            |          | 101010  |
|                                                            | Set On < Immediate Unsigned      |                                                                                                    | 001010 |          |              | imm<br>imm |          |         |
| SLTU rd,rs,rt                                              | Set On Less Than Unsigned        | rd=rs <rt< td=""><td>000000</td><td></td><td>rt</td><td></td><td>00000</td><td>101011</td></rt<>   | 000000 |          | rt           |            | 00000    | 101011  |
| SUB rd,rs,rt                                               | Subtract                         | rd=rs-rt                                                                                           | 000000 |          |              |            | 00000    | 100010  |
| SUBU rd,rs,rt                                              | Subtract Unsigned                | rd=rs-rt                                                                                           | 000000 |          | rt           |            | 00000    | 100010  |
| XOR rd,rs,rt                                               | Exclusive Or                     | rd=rs^rt                                                                                           | 000000 |          | rt           |            | 00000    | 100011  |
| XORI rt,rs,imm                                             | Exclusive Or Immediate           | rt=rs^imm                                                                                          | 000000 |          |              | imr        |          | 1100110 |
| Shifter                                                    | LAGIOSIVE OF THIRIEGIALE         | rc-13 mmH                                                                                          | 001110 | 13       | 1 C          | 11111      | 11       |         |
| SLL rd,rt,sa                                               | Shift Left Logical               | rd=rt< <sa< td=""><td>000000</td><td>rs</td><td>rt</td><td>rd</td><td>sa</td><td>000000</td></sa<> | 000000 | rs       | rt           | rd         | sa       | 000000  |
| SLLV rd,rt,rs                                              | Shift Left Logical Variable      | rd=rt< <rs< td=""><td>000000</td><td></td><td></td><td></td><td></td><td>000100</td></rs<>         | 000000 |          |              |            |          | 000100  |
| SRA rd,rt,sa                                               | Shift Right Arithmetic           | rd=rt>>sa                                                                                          | 000000 |          |              | rd         |          | 000011  |
| SRAV rd,rt,rs                                              | Shift Right Arithmetic Variable  |                                                                                                    | 000000 |          |              | rd         |          | 000111  |
| SRL rd,rt,sa                                               | Shift Right Logical              | rd=rt>>sa                                                                                          | 000000 |          | rt           |            |          | 000010  |
| SRLV rd,rt,rs                                              |                                  | rd=rt>>rs                                                                                          | 000000 |          | rt           |            |          | 000110  |
| Multiply                                                   |                                  |                                                                                                    |        |          |              |            |          |         |
| DIV rs,rt                                                  | Divide                           | HI=rs%rt; LO=rs/rt                                                                                 | 000000 | rs       | rt           | 000        | 0000000  | 011010  |
| DIVU rs,rt                                                 |                                  | HI=rs%rt; LO=rs/rt                                                                                 | 000000 |          |              |            | 0000000  |         |
| MFHI rd                                                    | Move From HI                     | rd=HI                                                                                              | 000000 |          |              |            |          | 010000  |
| MFLO rd                                                    | Move From LO                     | rd=LO                                                                                              | 000000 |          |              |            |          | 010010  |
| MTHI rs                                                    | Move To HI                       | HI=rs                                                                                              | 000000 |          |              |            |          | 010001  |
| MTLO rs                                                    | Move To LO                       | LO=rs                                                                                              | 000000 |          |              |            |          | 010011  |
| MULT rs,rt                                                 | Multiply                         | HI,LO=rs*rt                                                                                        | 000000 |          |              |            | 0000000  |         |
| MULTU rs,rt                                                | Multiply Unsigned                | HI,LO=rs*rt                                                                                        | 000000 |          |              |            | 0000000  |         |
| Branch                                                     |                                  |                                                                                                    |        |          |              |            |          |         |
|                                                            | Branch On Equal                  | if(rs==rt) pc+=offset*4                                                                            | 000100 | rs       | rt           | offs       | et       |         |
|                                                            | Branch On >= 0                   | if(rs>=0) pc+=offset*4                                                                             | 000001 |          | 00001 offset |            |          |         |
|                                                            | Branch On >= 0 And Link          | r31=pc; if( $rs>=0$ ) $pc+=offset*4$                                                               |        |          | 10001 offset |            |          |         |
|                                                            | Branch On > 0                    | if(rs>0) pc+=offset*4                                                                              | 000111 |          | 00000 offset |            |          |         |
| BLEZ rs,offset                                             | Branch On                        | if(rs<=0) pc+=offset*4                                                                             | 000110 |          | 00000 offset |            |          |         |
|                                                            | Branch On < 0                    | if(rs<0) pc+=offset*4                                                                              | 000001 |          | 00000        |            |          |         |
|                                                            | Branch On < 0 And Link           | r31=pc; if( $rs<0$ ) $pc+=offset*4$                                                                | 000001 |          | 10000        |            |          |         |
|                                                            | Branch On Not Equal              | if(rs!=rt) pc+=offset*4                                                                            | 000101 |          |              | offs       |          |         |
| BREAK                                                      | Breakpoint                       | epc=pc; pc=0x3c                                                                                    | 000000 |          |              |            |          | 001101  |
| J target                                                   | Jump                             | pc=pc_upper (target<<2)                                                                            | 000010 |          |              |            |          |         |
| JAL target                                                 | Jump And Link                    | r31=pc; pc=target<<2                                                                               | 000011 |          |              |            |          |         |
| JALR rs                                                    | Jump And Link Register           | rd=pc; pc=rs                                                                                       | 000000 |          | 00000        | rd         | 00000    | 001001  |
| JR rs                                                      | Jump Register                    | pc=rs                                                                                              | 000000 |          |              |            |          | 001000  |
| MFC0 rt,rd                                                 | Move From Coprocessor            | rt=CPR[0,rd]                                                                                       | 010000 |          |              |            | 00000000 |         |
| MTC0 rt,rd                                                 | Move To Coprocessor              | CPR[0,rd]=rt                                                                                       | 010000 |          |              |            | 00000000 |         |
| SYSCALL                                                    | System Call                      | epc=pc; pc=0x3c                                                                                    |        |          |              |            |          | 001100  |
| Memory Access                                              |                                  |                                                                                                    |        |          |              |            |          |         |
| LB rt,offset(rs)                                           | Load Byte                        | rt=*(char*)(offset+rs)                                                                             | 100000 | rs       | rt           | offs       | set      |         |
|                                                            | Load Byte Unsigned               | rt=*(Uchar*)(offset+rs)                                                                            | 100100 |          | rt           | offset     |          |         |
| LH rt,offset(rs)                                           | Load Halfword                    | rt=*(short*)(offset+rs)                                                                            | 100001 |          | rt           | offset     |          |         |
|                                                            |                                  | rt=*(Ushort*)(offset+rs)                                                                           | 100101 |          | rt           | offset     |          |         |
| LW rt,offset(rs)                                           | Load Word                        | rt=*(int*)(offset+rs)                                                                              | 100011 |          | rt           | offset     |          |         |
|                                                            | Store Byte                       | *(char*)(offset+rs)=rt                                                                             | 101000 |          |              | offset     |          |         |
|                                                            | Store Halfword                   | *(short*)(offset+rs)=rt                                                                            | 101001 |          | rt           | offset     |          |         |
|                                                            | Store Word                       | *(int*)(offset+rs)=rt                                                                              | 101011 |          |              | offset     |          |         |
|                                                            | diate values are normally sign e | , ,,                                                                                               |        | -        | -            |            |          |         |

Notes: The immediate values are normally sign extended.
The opcodes ADD and ADDU are equivalent in the Plasma CPU since ALU operations don't cause exceptions.
The program counter (pc) points to eight bytes past the currently executing instruction.