

# MIPS Reference Data



## CORE INSTRUCTION SET

|                             | NAME, MNEMONIC | FOR-MAT                                             | OPCODE / FUNCT (in Verilog) |
|-----------------------------|----------------|-----------------------------------------------------|-----------------------------|
| Add                         | add            | R [rd] = R[rs] + R[rt]                              | (1) 0 / 20 <sub>hex</sub>   |
| Add Immediate               | addi           | I R[rt] = R[rs] + SignExtImm                        | (1,2) 8 <sub>hex</sub>      |
| Add Imm. Unsigned           | addiu          | I R[rt] = R[rs] + SignExtImm                        | (2) 9 <sub>hex</sub>        |
| Add Unsigned                | addu           | R R[rd] = R[rs] + R[rt]                             | 0 / 21 <sub>hex</sub>       |
| And                         | and            | R R[rd] = R[rs] & R[rt]                             | 0 / 24 <sub>hex</sub>       |
| And Immediate               | andi           | I R[rt] = R[rs] & ZeroExtImm                        | (3) c <sub>hex</sub>        |
| Branch On Equal             | beq            | I if(R[rs]==R[rt]) PC=PC+4+BranchAddr               | (4) 4 <sub>hex</sub>        |
| Branch On Not Equal         | bne            | I if(R[rs]!=R[rt]) PC=PC+4+BranchAddr               | (4) 5 <sub>hex</sub>        |
| Jump                        | j              | J PC=JumpAddr                                       | (5) 2 <sub>hex</sub>        |
| Jump And Link               | jal            | J R[31]=PC+X, PC=JumpAddr                           | (8) (5) 3 <sub>hex</sub>    |
| Jump Register               | jr             | R PC=R[rs]                                          | 0 / 08 <sub>hex</sub>       |
| Load Byte Unsigned          | lbu            | I R[rt]=(24'b0.M[R[rs]+SignExtImm](7:0))            | (2) 24 <sub>hex</sub>       |
| Load Halfword Unsigned      | lhu            | I R[rt]=(16'b0.M[R[rs]+SignExtImm](15:0))           | (2) 25 <sub>hex</sub>       |
| Load Linked                 | ll             | I R[rt]=M[R[rs]+SignExtImm]                         | (2,7) 30 <sub>hex</sub>     |
| Load Upper Imm.             | lui            | I R[rt]={imm, 16'b0}                                | f <sub>hex</sub>            |
| Load Word                   | lw             | I R[rt]=M[R[rs]+SignExtImm]                         | (2) 23 <sub>hex</sub>       |
| Nor                         | nor            | R R[rd]=~(R[rs]   R[rt])                            | 0 / 27 <sub>hex</sub>       |
| Or                          | or             | R R[rd]=R[rs]   R[rt]                               | 0 / 25 <sub>hex</sub>       |
| Or Immediate                | ori            | I R[rt]=R[rs]   ZeroExtImm                          | (3) d <sub>hex</sub>        |
| Set Less Than               | slt            | R R[rd]=(R[rs]<R[rt]) ? 1 : 0                       | 0 / 2a <sub>hex</sub>       |
| Set Less Than Imm.          | slti           | I R[rt]=(R[rs]<SignExtImm)? 1 : 0 (2)               | a <sub>hex</sub>            |
| Set Less Than Imm. Unsigned | sltiu          | I R[rt]=(R[rs]<SignExtImm)? 1 : 0                   | b <sub>hex</sub>            |
| Set Less Than Unsigned      | sltiu          | R R[rd]=(R[rs]<R[rt]) ? 1 : 0                       | (2,6) b <sub>hex</sub>      |
| Shift Left Logical          | sll            | R R[rd]=R[rt]<>shamt                                | 0 / 00 <sub>hex</sub>       |
| Shift Right Logical         | srl            | R R[rd]=R[rt]>>shamt                                | 0 / 02 <sub>hex</sub>       |
| Store Byte                  | sb             | I M[R[rs]+SignExtImm](7:0)=R[rt](7:0)               | (2) 28 <sub>hex</sub>       |
| Store Conditional           | sc             | I M[R[rs]+SignExtImm]=R[rt]; R[rt]=(atomic) ? 1 : 0 | (2,7) 38 <sub>hex</sub>     |
| Store Halfword              | sh             | I M[R[rs]+SignExtImm](15:0)=R[rt](15:0)             | (2) 29 <sub>hex</sub>       |
| Store Word                  | sw             | I M[R[rs]+SignExtImm]=R[rt]                         | (2) 2b <sub>hex</sub>       |
| Subtract                    | sub            | R R[rd]=R[rs] - R[rt]                               | (1) 0 / 22 <sub>hex</sub>   |
| Subtract Unsigned           | subu           | R R[rd]=R[rs] - R[rt]                               | 0 / 23 <sub>hex</sub>       |
| Syscall                     | syscall        | R PC = ExceptionAddr                                | 0 / 0c hex                  |
| Shift Right Arithmetic      | sra            | R R[rd]=R[rt]>>shamt                                | 0 / 03 hex                  |
| Exclusive Or                | xor            | R R[rd]=R[rs] + R[rt]                               | 0 / 2b hex                  |
| Move From C0                | mfco           | R R[rd]=R0[rd]                                      | 10 / 00 hex                 |

(1) May cause overflow exception

(2) SignExtImm = { 16{immediate[15]}, immediate }

(3) ZeroExtImm = { 16{1b'0}, immediate }

(4) BranchAddr = { 14{immediate[15]}, immediate, 2'b0 }

(5) JumpAddr = { PC+4[31:28], address, 2'b0 }

(6) Operands considered unsigned numbers (vs. 2's comp.)

(7) Atomic test&set pair; R[rt]=1 if pair atomic, 0 if not atomic

(8) PC+4: Normal PC+8:Pipeline

## BASIC INSTRUCTION FORMATS

|   |          |       |       |       |         |           |  |
|---|----------|-------|-------|-------|---------|-----------|--|
| R | opcode   | rs    | rt    | rd    | shamt   | funct     |  |
|   | 31 26 25 | 21 20 | 16 15 | 11 10 | 6 5     | 0         |  |
| I | opcode   | rs    | rt    |       |         | immediate |  |
|   | 31 26 25 | 21 20 | 16 15 |       |         | 0         |  |
| J | opcode   |       |       |       | address |           |  |
|   | 31 26 25 |       |       |       |         | 0         |  |

## ARITHMETIC CORE INSTRUCTION SET

| OPCODE              | NAME, MNEMONIC | FOR-MAT                                                        | OPERATION (Hex) |
|---------------------|----------------|----------------------------------------------------------------|-----------------|
| Branch On FP True   | bclt           | FI if(FPcond)PC=PC+4+BranchAddr                                | (4) 11/8/1--    |
| Branch On FP False  | bclf           | FI if(FPcond)PC=PC+4+BranchAddr                                | 11/8/0--        |
| Divide              | div            | R Lo=R[rs]/R[rt]; Hi=R[rs] % R[rt]                             | 0/-/-/1a        |
| Divide Unsigned     | divu           | R Lo=R[rs]/R[rt]; Hi=R[rs] % R[rt]                             | (6) 0/-/-/1b    |
| FP Add Single       | add.s          | FR F[fd]=F[fs]+F[ft]                                           | 11/10/-/0       |
| FP Add              | add.d          | FR {F[fd],F[fd+1]} = {F[fs],F[fs+1]} + {F[ft],F[ft+1]}         | 11/11/-/0       |
| Double              | c.x.s*         | FR FPcond = (F[fs] op F[ft]) ? 1 : 0                           | 11/10/-/y       |
| FP Compare Single   | c.x.d*         | FR FPcond = ({F[fs],F[fs+1]} op {F[ft],F[ft+1]}) ? 1 : 0       | 11/11/-/y       |
| Double              | *              | (x is eq, lt, or le) (op is ==, <, or <=) (y is 32, 3c, or 3e) |                 |
| FP Divide Single    | div.s          | FR F[fd] = F[fs] / F[ft]                                       | 11/10/-/3       |
| FP Divide           | div.d          | FR {F[fd],F[fd+1]} = {F[fs],F[fs+1]} / {F[ft],F[ft+1]}         | 11/11/-/3       |
| FP Multiply Single  | mul.s          | FR F[fd] = F[fs] * F[ft]                                       | 11/10/-/2       |
| FP Multiply         | mul.d          | FR {F[fd],F[fd+1]} = {F[fs],F[fs+1]} * {F[ft],F[ft+1]}         | 11/11/-/2       |
| FP Subtract Single  | sub.s          | FR F[fd]=F[fs]-F[ft]                                           | 11/10/-/1       |
| FP Subtract         | sub.d          | FR {F[fd],F[fd+1]} = {F[fs],F[fs+1]} - {F[ft],F[ft+1]}         | 11/11/-/1       |
| Load FP Single      | lwcl           | I F[rt]=M[R[rs]+SignExtImm]                                    | (2) 31/-/-/-    |
| Load FP             | ldcl           | I F[rt]=M[R[rs]+SignExtImm]; F[rt+1]=M[R[rs]+SignExtImm+4]     | 35/-/-/-        |
| Double              |                | F[rt+1]=M[R[rs]+SignExtImm+4]                                  |                 |
| Move From Hi        | mfhi           | R R[rd]=Hi                                                     | 0/-/-/10        |
| Move From Lo        | mflo           | R R[rd]=Lo                                                     | 0/-/-/12        |
| Move From Control   | mfco           | R R[rd]=CR[Rrs]                                                | 10/0/-/0        |
| Multiply            | mult           | R {Hi,Lo} = R[rs] * R[rt]                                      | 0/-/-/18        |
| Multiply Unsigned   | multu          | R {Hi,Lo} = R[rs] * R[rt]                                      | (6) 0/-/-/19    |
| Shift Right Arith.  | sra            | R R[rd]=R[rt]>>shamt                                           | 0/-/-/3         |
| Store FP Single     | swcl           | I M[R[rs]+SignExtImm] = F[rt]                                  | (2) 39/-/-/-    |
| Store FP            | sdcl           | I M[R[rs]+SignExtImm] = F[rt]; M[R[rs]+SignExtImm+4] = F[rt+1] | 3d/-/-/-        |
| Double              |                | M[R[rs]+SignExtImm+4] = F[rt+1]                                |                 |
| Move Single         | mov.s          | FR F[fd]=F[fs]                                                 | 11/10/0/6       |
| Move Double         | mov.d          | FR F[fd]=F[fs]                                                 | 11/11/0/6       |
| Move To C1          | mtc1           | FI* F[fs]=R[rt]                                                | 11/4/-/0        |
| Move From C1        | mfcl           | FI* R[rt]=F[fs]                                                | 11/0/-/0        |
| Convert from Y to X | cvt.x.y        | FR F[fld]=F[fs]y (x,y)={S,D,W}                                 |                 |
| Square Root         | sqrts          | FR F[fd]=sqrt(F[fs])                                           | 11/10/0/4       |

## FLOATING-POINT INSTRUCTION FORMATS

|     |          |       |       |       |     |           |   |
|-----|----------|-------|-------|-------|-----|-----------|---|
| FR  | opcode   | fmt   | ft    | fs    | fd  | funct     | 0 |
|     | 31 26 25 | 21 20 | 16 15 | 11 10 | 6 5 |           | 0 |
| FI  | opcode   | fmt   | ft    |       |     | immediate | 0 |
|     | 31 26 25 | 21 20 | 16 15 |       |     |           | 0 |
| FI* | opcode   | fmt   | rt    | fs    |     | 0         | 0 |
|     | 31 26 25 | 21 20 | 16 15 | 11 10 |     |           | 0 |

## PSEUDOINSTRUCTION SET

| NAME                         | MNEMONIC | OPERATION                   |
|------------------------------|----------|-----------------------------|
| Branch Less Than             | bit      | if(R[rs]<R[rt]) PC = Label  |
| Branch Greater Than          | bgt      | if(R[rs]>R[rt]) PC = Label  |
| Branch Less Than or Equal    | ble      | if(R[rs]<=R[rt]) PC = Label |
| Branch Greater Than or Equal | bge      | if(R[rs]>=R[rt]) PC = Label |
| Load Immediate               | li       | R[rd] = immediate           |
| Move                         | move     | R[rd] = R[rs]               |
| Load Address                 | la       | R[rd] = 32 bits immediate   |

## REGISTER NAME, NUMBER, USE, CALL CONVENTION

| NAME      | NUMBER | USE                                                   | PRESERVED ACROSS A CALL? |
|-----------|--------|-------------------------------------------------------|--------------------------|
| \$zero    | 0      | The Constant Value 0                                  | N.A.                     |
| \$at      | 1      | Assembler Temporary                                   | No                       |
| \$v0-\$v1 | 2-3    | Values for Function Results and Expression Evaluation | No                       |
| \$a0-\$a3 | 4-7    | Arguments                                             | No                       |
| \$t0-\$t7 | 8-15   | Temporaries                                           | No                       |
| \$s0-\$s7 | 16-23  | Saved Temporaries                                     | Yes                      |
| \$t8-\$t9 | 24-25  | Temporaries                                           | No                       |
| \$k0-\$k1 | 26-27  | Reserved for OS Kernel                                | No                       |
| \$gp      | 28     | Global Pointer                                        | Yes                      |
| \$sp      | 29     | Stack Pointer                                         | Yes                      |
| \$fp      | 30     | Frame Pointer                                         | Yes                      |
| \$ra      | 31     | Return Address                                        | Yes                      |

### OPCODES, BASE CONVERSION, ASCII SYMBOLS

| MIPS    | (1) MIPS | (2) MIPS  | Hexa-<br>Binary | Deci-<br>mal | Hexa-<br>ASCII<br>Char-<br>acter | Deci-<br>mal | Hexa-<br>ASCII<br>Char-<br>acter |
|---------|----------|-----------|-----------------|--------------|----------------------------------|--------------|----------------------------------|
| (31:26) | (5:0)    | (5:0)     |                 |              |                                  |              |                                  |
| (1)     | sll      | add,f     | 00 0000         | 0            | 0 NUL                            | 64           | 40 @                             |
|         |          | sub,f     | 00 0001         | 1            | 1 SOH                            | 65           | 41 A                             |
| j       | srl      | mul,f     | 00 0010         | 2            | 2 STX                            | 66           | 42 B                             |
| jal     | sra      | div,f     | 00 0011         | 3            | 3 ETX                            | 67           | 43 C                             |
| beq     | slv      | sqrt,f    | 00 0100         | 4            | 4 EOT                            | 68           | 44 D                             |
| bne     |          | abs,f     | 00 0101         | 5            | 5 ENQ                            | 69           | 45 E                             |
| blez    | srly     | mov,f     | 00 0110         | 6            | 6 ACK                            | 70           | 46 F                             |
| bgtz    | srav     | neg,f     | 00 0111         | 7            | 7 BEL                            | 71           | 47 G                             |
| addi    | jr       | 00 1000   | 8               | 8 BS         | 72                               | 48 H         |                                  |
| addiu   | jalr     | 00 1001   | 9               | 9 HT         | 73                               | 49 I         |                                  |
| slti    | mvz      | 00 1010   | 10              | 10 LF        | 74                               | 4a J         |                                  |
| sltiu   | mvzn     | 00 1011   | 11              | 11 b VT      | 75                               | 4b K         |                                  |
| andi    | syscall  | round,w,f | 00 1100         | 12           | c FF                             | 76           | 4c L                             |
| ori     | break    | trunc,w,f | 00 1101         | 13           | d CR                             | 77           | 4d M                             |
| xori    |          | ceil,w,f  | 00 1110         | 14           | e SO                             | 78           | 4e N                             |
| lui     | sync     | floor,w,f | 00 1111         | 15           | f SI                             | 79           | 4f O                             |
| (2)     | mfhi     |           | 01 0000         | 16           | 10 DLE                           | 80           | 50 P                             |
| mthi    |          |           | 01 0001         | 17           | 11 DC1                           | 81           | 51 Q                             |
| mflo    | movzf    |           | 01 0010         | 18           | 12 DC2                           | 82           | 52 R                             |
| mtlo    | movnf    |           | 01 0011         | 19           | 13 DC3                           | 83           | 53 S                             |
|         |          |           | 01 0100         | 20           | 14 DC4                           | 84           | 54 T                             |
|         |          |           | 01 0101         | 21           | 15 NAK                           | 85           | 55 U                             |
|         |          |           | 01 0110         | 22           | 16 SYN                           | 86           | 56 V                             |
|         |          |           | 01 0111         | 23           | 17 ETB                           | 87           | 57 W                             |
| mult    |          | 01 1000   | 24              | 18 CAN       | 88                               | 58 X         |                                  |
| multu   |          | 01 1001   | 25              | 19 EM        | 89                               | 59 Y         |                                  |
| div     |          | 01 1010   | 26              | 1a SUB       | 90                               | 5a Z         |                                  |
| divu    |          | 01 1011   | 27              | 1b ESC       | 91                               | 5b [         |                                  |
| lb      | add      | cvt.s,f   | 10 0000         | 32           | 20 Space                         | 96           | 60 =                             |
| lh      | addu     | cvt.d,f   | 10 0001         | 33           | 21 !                             | 97           | 61 a                             |
| lw      | sub      |           | 10 0010         | 34           | 22 "                             | 98           | 62 b                             |
| lw      | subu     |           | 10 0011         | 35           | 23 #                             | 99           | 63 c                             |
| lbu     | and      | cvt.w,f   | 10 0100         | 36           | 24 \$                            | 100          | 64 d                             |
| lhu     | or       |           | 10 0101         | 37           | 25 %                             | 101          | 65 e                             |
| lwr     | xor      |           | 10 0110         | 38           | 26 &                             | 102          | 66 f                             |
|         | nor      |           | 10 0111         | 39           | 27 '                             | 103          | 67 g                             |
| sb      |          |           | 10 1000         | 40           | 28 ,                             | 104          | 68 h                             |
| sh      |          |           | 10 1001         | 41           | 29 .                             | 105          | 69 i                             |
| swl     | slt      |           | 10 1010         | 42           | 2a *                             | 106          | 6a j                             |
| sw      | sltu     |           | 10 1011         | 43           | 2b +                             | 107          | 6b k                             |
|         |          |           | 10 1100         | 44           | 2c ,                             | 108          | 6c l                             |
|         |          |           | 10 1101         | 45           | 2d -                             | 109          | 6d m                             |
| swr     |          |           | 10 1110         | 46           | 2e :                             | 110          | 6e n                             |
| cache   |          |           | 10 1111         | 47           | 2f /                             | 111          | 6f o                             |
| ll      | tge      | c.f,f     | 11 0000         | 48           | 30 0                             | 112          | 70 p                             |
| lwcl    | tgeu     | c.unf     | 11 0001         | 49           | 31 1                             | 113          | 71 q                             |
| lwcl2   | tit      | c.eqf     | 11 0010         | 50           | 32 2                             | 114          | 72 r                             |
| pref    | titu     | c.ueqf    | 11 0011         | 51           | 33 3                             | 115          | 73 s                             |
|         | teq      |           | 11 0100         | 52           | 34 4                             | 116          | 74 t                             |
| ldc1    | c.oltf   |           | 11 0101         | 53           | 35 5                             | 117          | 75 u                             |
| ldc2    | tne      | c.ultf    | 11 0110         | 54           | 36 6                             | 118          | 76 v                             |
| sc      |          | c.colef   | 11 0111         | 55           | 37 7                             | 119          | 77 w                             |
| scw1    |          | c.sff     | 11 1000         | 56           | 38 8                             | 120          | 78 x                             |
| scw2    |          | c.nglef   | 11 1001         | 57           | 39 9                             | 121          | 79 y                             |
|         |          | c.seqf    | 11 1010         | 58           | 3a :                             | 122          | 7a z                             |
|         |          | c.nglf    | 11 1011         | 59           | 3b ;                             | 123          | 7b {                             |
| sdc1    | c.lt,f   |           | 11 1100         | 60           | 3c <                             | 124          | 7c                               |
| sdc2    | c.ngef   |           | 11 1101         | 61           | 3d =                             | 125          | 7d }                             |
|         | c.lef    |           | 11 1110         | 62           | 3e >                             | 126          | 7e ~                             |
|         | c.ngtf   |           | 11 1111         | 63           | 3f ?                             | 127          | 7f DEL                           |

(1) opcode(31:26) == 0  
 (2) opcode(31:26) == 17<sub>10</sub>(11<sub>hex</sub>); if fnt(25:21) == 16<sub>10</sub>(10<sub>hex</sub>) = s (single);  
 if fnt(25:21) == 17<sub>10</sub>(11<sub>hex</sub>) = d (double)

| Service                     | Code in \$v0 | Arguments                                                                     | Result                                    |
|-----------------------------|--------------|-------------------------------------------------------------------------------|-------------------------------------------|
| print integer               | 1            | \$a0 = integer to print                                                       |                                           |
| print float                 | 2            | \$f12 = float to print                                                        |                                           |
| print double                | 3            | \$f12 = double to print                                                       |                                           |
| print string                | 4            | \$a0 = address of null-terminated string to print                             |                                           |
| read integer                | 5            |                                                                               | \$v0 contains integer read                |
| read float                  | 6            |                                                                               | \$v0 contains float read                  |
| read double                 | 7            |                                                                               | \$v0 contains double read                 |
| read string                 | 8            | \$a0 = address of input buffer<br>\$a1 = maximum number of characters to read | See note below table                      |
| strk (allocate heap memory) | 9            | \$a0 = number of bytes to allocate                                            | \$v0 contains address of allocated memory |
| exit (terminate execution)  | 10           |                                                                               |                                           |

### IEEE 754 FLOATING-POINT STANDARD

$$(-1)^S \times (1 + Fraction) \times 2^{(Exponent - Bias)}$$

where Single Precision Bias = 127,  
 Double Precision Bias = 1023.

### IEEE Single Precision and Double Precision Formats:

| S  | Exponent | Fraction |
|----|----------|----------|
| 31 | 30       | 23 22    |
| 63 | 62       | 52 51    |

### MEMORY ALLOCATION



### STACK FRAME



### DATA ALIGNMENT

| Double Word |      |          |      |          |      |          |      |
|-------------|------|----------|------|----------|------|----------|------|
| Word        |      |          |      | Word     |      |          |      |
| Halfword    |      | Halfword |      | Halfword |      | Halfword |      |
| Byte        | Byte | Byte     | Byte | Byte     | Byte | Byte     | Byte |
| 0           | 1    | 2        | 3    | 4        | 5    | 6        | 7    |

Value of three least significant bits of byte address (Big Endian)

### EXCEPTION CONTROL REGISTERS: CAUSE AND STATUS

| B  | D  | Interrupt Mask    | Exception Code |
|----|----|-------------------|----------------|
| 31 | 15 | 8                 | 6              |
|    |    | Pending Interrupt | UM EL          |

BD = Branch Delay, UM = User Mode, EL = Exception Level, IE = Interrupt Enable

### EXCEPTION CODES

| Number | Name | Cause of Exception                                  | Number | Name | Cause of Exception            |
|--------|------|-----------------------------------------------------|--------|------|-------------------------------|
| 0      | Intr | Interrupt (hardware)                                | 9      | Bp   | Breakpoint Exception          |
| 4      | AdEL | Address Error Exception (load or instruction fetch) | 10     | RI   | Reserved Instruction          |
| 5      | AdES | Address Error Exception (store)                     | 11     | CpU  | Coprocessor Unimplemented     |
| 6      | IBE  | Bus Error on Instruction Fetch                      | 12     | Ov   | Arithmetic Overflow Exception |
| 7      | DBE  | Bus Error on Load or Store                          | 13     | Tr   | Trap                          |
| 8      | Sys  | Syscall Exception                                   | 15     | FPE  | Floating Point Exception      |

### SIZE PREFIXES (10<sup>x</sup> for Disk, Communication; 2<sup>x</sup> for Memory)

| PRE-SIZE FIX                       | PRE-SIZE FIX | PRE-SIZE FIX                       | PRE-SIZE FIX |
|------------------------------------|--------------|------------------------------------|--------------|
| 10 <sup>3</sup> , 2 <sup>10</sup>  | Kilo         | 10 <sup>15</sup> , 2 <sup>50</sup> | Peta         |
| 10 <sup>6</sup> , 2 <sup>20</sup>  | Mega         | 10 <sup>18</sup> , 2 <sup>60</sup> | Exa          |
| 10 <sup>9</sup> , 2 <sup>30</sup>  | Giga         | 10 <sup>21</sup> , 2 <sup>70</sup> | Zetta        |
| 10 <sup>12</sup> , 2 <sup>40</sup> | Tera         | 10 <sup>24</sup> , 2 <sup>80</sup> | Yotta        |

The symbol for each prefix is just its first letter, except μ is used for micro.

|                              |    |                                                                                                         |                                                                                                     |
|------------------------------|----|---------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| print character              | 11 | \$a0 = character to print                                                                               | See note below table                                                                                |
| read character               | 12 |                                                                                                         | \$v0 contains character read                                                                        |
| open file                    | 13 | \$a0 = address of null-terminated string containing filename<br>\$a1 = flags<br>\$a2 = mode             | \$v0 contains file descriptor (negative if error). See note below table                             |
| read from file               | 14 | \$a0 = file descriptor<br>\$a1 = address of input buffer<br>\$a2 = maximum number of characters to read | \$v0 contains number of characters read (0 if end-of-file, negative if error). See note below table |
| write to file                | 15 | \$a0 = file descriptor<br>\$a1 = address of output buffer<br>\$a2 = number of characters to write       | \$v0 contains number of characters written (negative if error). See note below table                |
| close file                   | 16 | \$a0 = file descriptor                                                                                  |                                                                                                     |
| exit2 (terminate with value) | 17 | \$a0 = termination result                                                                               | See note below table                                                                                |