Instruction Set Summary

| Mnemonics | Operands | Description | Operation | Flags | \#Clks |
| :---: | :---: | :---: | :---: | :---: | :---: |
| NOP |  | No Operation |  |  | 1 |
| ADD | Rd, Rs1, Rs2 | Add two Registers | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1+\mathrm{Rs} 2$ | C,O,N,Z | 1 |
| ADDI | Rd, Rs1, \#data | Add Register with Immediate | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1+$ \#data | c,o,n,z | 1 |
| ADC | Rd, Rs1, Rs2 | Add two Registers with Carry | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1+\mathrm{Rs} 2+\mathrm{C}$ | c,o,n,z | 1 |
| ADCI | Rd, Rs1, \#data | Add Register with Immediate with Carry | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1+$ \#data +C | c,o,n,Z | 1 |
| SUB | Rd, Rs1, Rs2 | Subtract two Registers | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1$ - Rs2 | C,o,N,Z | 1 |
| SUBI | Rd, Rs1, \#data | Subtract Immediate from Register | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1$-\#data | C,o,N, Z | 1 |
| SBB | Rd, Rs1, Rs2 | Subtract two Registers with Borrow | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1$ - Rs2 - C | c,o,N, Z | 1 |
| SBBI | Rd, Rs1, \#data | Subtract Immediate from Register with Borrow | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1$ - \#data - C | c,o,n,z | 1 |
| CMP | Rs1, Rs2 | Compare two Registers | Rs1 - Rs2 | C,o,N, Z | 1 |
| CMPI | Rs1, \#data | Compare Register with Immediate | Rs1-\#data | c,o,n, Z | 1 |
| AND | Rd, Rs1, Rs2 | Logical AND Registers | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1 \cdot \mathrm{Rs} 2$ | N,Z | 1 |
| ANDI | Rd, Rs1, \#data | Logical AND Register with Immediate | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1 \cdot \#$ data | N,Z | 1 |
| OR | Rd, Rs1, Rs2 | Logical OR Registers | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1 \mathrm{v} \mathrm{Rs} 2$ | N,Z | 1 |
| ORI | Rd, Rs1, \#data | Logical OR Register with Immediate | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1 \mathrm{v}$ \#data | N,Z | 1 |
| XOR | Rd, Rs1, Rs2 | Logical XOR Registers | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1 \oplus \mathrm{Rs} 2$ | N,Z | 1 |
| XORI | Rd, Rs1, \#data | Logical XOR Register with Immediate | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1 \oplus$ \#data | N,Z | 1 |
| SHR | Rd, Rs1, Rs2 | Logical or Arithmetic Shift Right | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1 \gg \mathrm{Rs} 2[3: 0]$ | c,N,Z | 1 |
| SHRI | Rd, Rs1, \#am | Logical or Arithmetic Shift Right Immediate Amount | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1 \gg$ \#am | c,N,Z | 1 |
| SHL | Rd, Rs1, Rs2 | Logical or Arithmetic Shift Left | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1 \ll \mathrm{Rs} 2[3: 0]$ | c,o,n,z | 1 |
| SHLI | Rd, Rs1, \#am | Logical or Arithmetic Shift Left Immediate Amount | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1 \ll \# \mathrm{~mm}$ | C,o,N, Z | 1 |
| COM | Rd, Rs1 | One's Complement | Rd $\leftarrow$ \#FFFF - Rs 1 | N,Z | 1 |
| NEG | Rd, Rs1 | Two's Complement | $\mathrm{Rd} \leftarrow \# 0000-\mathrm{Rs} 1$ | O,N,Z | 1 |
| ROL | Rd, Rs1 | Rotate Left through Carry | $\mathrm{Rd}[0] \leftarrow \mathrm{C}, \mathrm{Rd}[\mathrm{n}+1] \leftarrow \mathrm{Rs} 1[\mathrm{n}], \mathrm{C} \leftarrow \mathrm{Rs} 1[15]$ | C,N,Z | 1 |
| ROR | Rd, Rs1 | Rotate Right through Carry | $\mathrm{Rd}[15] \leftarrow \mathrm{C}, \mathrm{Rd}[\mathrm{n}] \leftarrow \mathrm{Rs} 1[\mathrm{n}+1], \mathrm{C} \leftarrow \mathrm{Rs} 1[0]$ | C,N,Z | 1 |
| MOV | Rd, Rs1 | Load from Register to Register | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1$ |  | 1 |
| MOVI | Rd, \#data | Load Immediate to Register | $\mathrm{Rd} \leftarrow$ \#data |  | 1 |
| MOVF | Rd, Rs1 | Load from Register to Register with Test | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1$ | N,Z | 1 |
| MULT | Rd, Rs1, Rs2 | Multiply two Registers | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1 \times \mathrm{Rs} 2$ | C,O,N, Z | 10 |
| MULTI | Rd, Rs1, \#data | Multiply Register with Immediate | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1 \mathrm{x}$ \#data | C,O,N,Z | 10 |
| DIV | Rd, Rs1, Rs2 | Divide two Registers | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1 / \mathrm{Rs} 2, \mathrm{Rd}+1 \leftarrow \mathrm{Rs} 1$ \% Rs2 | C,O,N,Z | 19 |
| DIVI | Rd, Rs1, \#data | Divide Register by Immediate | $\mathrm{Rd} \leftarrow \mathrm{Rs} 1 /$ \#data, $\mathrm{Rd}+1 \leftarrow \mathrm{Rs} 1$ \% \#data | c,o,N, Z | 19 |
| SET | \#mask | Set or Clear Flags by Mask | Flags $\leftarrow$ \{Flags •\#maskMsb $\vee$ \#maskLsb |  |  |
|  | \#mask = 0xFF80 | Set Masking Flag | $\mathrm{M} \leftarrow 1$ | M | 1 |
|  | \#mask = 0x7F00 | Clear Masking Flag | $\mathrm{M} \leftarrow 0$ | M | 1 |
|  | \#mask = 0xFF40 | Set Enable Flag | $\mathrm{E} \leftarrow 1$ | E | 1 |
|  | \#mask $=0 \times$ PF00 | Clear Enable Flag | $\mathrm{E} \leftarrow 0$ | E | 1 |
|  | \#mask = 0xFF20 | Set Interrupt Flag | $1 \leftarrow 1$ | 1 | 1 |
|  | \#mask = 0xDF00 | Clear Interrupt Flag | $1 \leftarrow 0$ | 1 | 1 |
|  | \#mask = 0xFF10 | Set Signed Flag | $s \leftarrow 1$ | S | 1 |
|  | \#mask = 0xEF00 | Clear Signed Flag | $\mathrm{S} \leftarrow 0$ | S | 1 |
|  | \#mask = 0xFF08 | Set Carry Flag | $\mathrm{C} \leftarrow 1$ | C | 1 |
|  | \#mask = 0xF700 | Clear Carry Flag | $C \leftarrow 0$ | C | 1 |
|  | \#mask = 0xFF04 | Set Overflow Flag | $0 \leftarrow 1$ | 0 | 1 |
|  | \#mask = 0xFB00 | Clear Overflow Flag | $0 \leftarrow 0$ | 0 | 1 |
|  | \#mask = 0xFF02 | Set Negative Flag | $N \leftarrow 1$ | N | 1 |
|  | \#mask = 0xFD00 | Clear Negative Flag | $N \leftarrow 0$ | N | 1 |
|  | \#mask = 0xFF01 | Set Zero Flag | $\mathrm{Z} \leftarrow 1$ | Z | 1 |
|  | \#mask = 0xFE00 | Clear Zero Flag | $\mathrm{Z} \leftarrow 0$ | Z | 1 |


| Mnemonics | Operands | Description | Operation | Flags | \#CIks |
| :---: | :---: | :---: | :---: | :---: | :---: |
| LOAD | Rd, Rs1 | Load Indirect from RAM | $\mathrm{Rd} \leftarrow(\mathrm{Rs} 1)$ |  | 1 |
| LOADI | Rd, \#addr | Load Direct from RAM | $\mathrm{Rd} \leftarrow$ (\#addr) |  | 1 |
| STORE | Rs1, Rs2 | Store Indirect to RAM | $(\mathrm{Rs} 2) \leftarrow \mathrm{Rs} 1$ |  | 1 |
| STOREI | Rs1, \#addr | Store Direct to RAM | (\#addr) $\leftarrow \mathrm{Rs} 1$ |  | 1 |
| IN | Rd, \#sel | Load from Input Port | $\mathrm{Rd} \leftarrow \mathrm{Pin}[\#$ sel] $]$ |  | 1 |
| OUT | \#sel, \#op, Rs1 | Store Register to Output Port with Operation | Port[\#sel] $\leftarrow$ \#op(Rs1, Port[\#sel]) |  |  |
|  | \#op $=0 \times 0$ | Operation = NOP | Port[\#sel] $\leftarrow$ Rs 1 |  | 1 |
|  | \#op $=0 \times 1$ | Operation = AND | Port[\#sel] $\leftarrow$ Rs1 • Port[\#sel] |  | 1 |
|  | \#op $=0 \times 2$ | Operation = OR | Port[\#sel] $\leftarrow$ Rs1 v Port[\#sel] |  | 1 |
|  | \#op $=0 \times 3$ | Operation = XOR | Port[\#sel] $\leftarrow$ Rs $1 \oplus$ Port[\#sel] |  | 1 |
| OUTI | \#sel, \#op, \#data | Store Immediate to Output Port with Operation | Port[\#sel] ז\#op(\#data, Port[\#sel]) |  |  |
|  | \#op $=0 \times 0$ | Operation = NOP | Port[\#sel] $\leftarrow$ \#data |  | 1 |
|  | \#op $=0 \times 1$ | Operation = AND | Port[\#sel] $\leftarrow$ \#data • Port[\#sel] |  | 1 |
|  | \#op $=0 \times 2$ | Operation $=$ OR | Port[\#sel] $\leftarrow$ \#data v Port[\#sel] |  | 1 |
|  | \#op $=0 \times 3$ | Operation = XOR | Port[\#sel] $\leftarrow$ \#data $\oplus$ Port[\#sel] |  | 1 |
| JMP | \#addr | Direct Jump | PC ¢\#addr |  | 2 |
| JC | \#addr | Jump If Carry | If ( $\mathrm{C}==1$ ) then PC $\leftarrow$ \#addr |  | 2 |
| JNC | \#addr | Jump If Not Carry | If ( $\mathrm{C}==0$ ) then $\mathrm{PC} \leftarrow$ \#addr |  | 2 |
| JO | \#addr | Jump If Overflow | If ( $\mathrm{O}==1$ ) then PC $\leftarrow$ \#addr |  | 2 |
| JNO | \#addr | Jump If Not Overflow | If ( $\mathrm{O}==0$ ) then PC $\leftarrow$ \#addr |  | 2 |
| JN | \#addr | Jump If Negative | If ( $\mathrm{N}==1$ ) then $\mathrm{PC} \leftarrow$ \#addr |  | 2 |
| JP | \#addr | Jump If Positive | If ( $\mathrm{N}==0$ ) then PC $\leftarrow$ \#addr |  | 2 |
| JZ | \#addr | Jump If Zero | If $(Z==1)$ then PC $\leftarrow$ \#addr |  | 2 |
| JNZ | \#addr | Jump If Not Zero | If $(Z==0)$ then PC $\leftarrow$ \#addr |  | 2 |
| JL | \#addr | Jump If Lower | If ( $\mathrm{C} \vee(\mathrm{N} \oplus \mathrm{O}$ ) $==1$ ) then $\mathrm{PC} \leftarrow$ \#addr |  | 2 |
| JLE | \#addr | Jump If Lower or Equal | If $(Z \vee C \vee(N \oplus O)==1)$ then PC ¢ \#addr |  | 2 |
| JG | \#addr | Jump If Greater | If $(\mathrm{Z} v \mathrm{C} v(\mathrm{~N} \oplus \mathrm{O})==0)$ then $\mathrm{PC} \leftarrow$ \#addr |  | 2 |
| JGE | \#addr | Jump If Greaterr or Equal | If $(\mathrm{C} ~ \vee ~(~ N \oplus O)=00)$ then PC ¢ \#addr |  | 2 |
| CALL | \#addr | Subroutine Call | CALL_STACK $\leftarrow \mathrm{PC}+1, \mathrm{PC} \leftarrow$ \#addr |  | 2 |
| RET |  | Subroutine Return | $\mathrm{PC} \leftarrow$ CALL_STACK |  | 2 |
| PUSH | Rs1 | Push Register on Stack | DATA_STACK $\leftarrow$ Rs 1 |  | 1 |
| POP | Rd | Pop Register from Stack | $\mathrm{Rd} \leftarrow$ DATA_STACK |  | 1 |
| PUSHF |  | Push Flags on Stack | DATA_STACK $\leftarrow$ Flags |  | 1 |
| POPF |  | Pop Flags from Stack | Flags $\leftarrow$ DATA_STACK |  | 1 |
| STOP |  | Stop Program Execution |  |  | 1 |

## Instruction Set Opcode Fields

| NOP |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- |
| $\# \mathbf{0 x 0 0}$ |  |  |  | - |
| 31 |  | 24 | 23 |  |


| ADD |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0x0C | Rd |  | Rs1 |  | Rs2 |  |  |  |
| 3124 | 23 | 20 | 19 | 16 | 15 | 12 | 11 | 0 |


| ADDI |  |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| \# 0x0E |  | Rd |  | Rs1 |  |  | \#data |  |  |
| 31 | 24 | 23 |  | 20 | 19 |  | 16 | 15 |  |


| ADC |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0x0D |  | Rd |  | Rs1 |  | Rs2 |  | - |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 12 | 11 | 0 |


| ADCI |  |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| \# 0x0F |  | Rd |  | Rs1 |  |  | \#data |  |  |
| 31 | 24 | 23 |  | 20 | 19 |  | 16 | 15 | 0 |


| SUB |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0x1C |  | Rd |  | Rs1 |  | Rs2 |  | - |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 12 | 11 | 0 |


| SUBI |  |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| \# 0x1E |  | Rd |  | Rs1 |  |  | \#data |  |  |
| 31 | 24 | 23 |  | 20 | 19 |  | 16 | 15 | 0 |


| SBB |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0x1D |  | Rd |  | Rs1 |  | Rs2 |  | - |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 12 | 11 | 0 |


| SBBI |  |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| \# 0x1F |  |  | Rd |  |  | Rs1 |  |  | \#data |
| 31 | 24 | 23 |  | 20 | 19 |  | 16 | 15 |  |


| CMP |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0x14 |  | - |  | Rs1 |  | Rs2 |  | - |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 12 | 11 | 0 |


| CMPI |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0x16 |  | - |  | Rs1 |  | \#data |  |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 |  | 0 |


| AND |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0x2C |  | Rd |  | Rs1 |  | Rs2 |  | - |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 12 | 11 | 0 |



| XOR |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0x4C |  | Rd |  | Rs1 |  | Rs2 |  | - |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 12 | 11 | 0 |


| XORI |  |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| \# 0x4E |  |  | Rd |  |  | Rs1 |  |  | \#data |
| 31 | 24 | 23 |  | 20 | 19 |  | 16 | 15 |  |


| SHR |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0x5C |  | Rd |  | Rs1 |  | Rs2 |  | - |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 12 | 11 | 0 |


| SHRI |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0x5E |  | Rd |  | Rs1 |  | - |  | \#am |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 4 | 3 | 0 |


| SHL |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0x6C |  | Rd |  | Rs1 |  | Rs2 |  | - |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 12 | 11 | 0 |



| ROL |  |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| \# 0x9D |  | Rd |  | Rs1 |  |  | - |  |  |
| 31 | 24 | 23 |  | 20 | 19 |  | 16 | 15 | 0 |


| ROR |  |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| \# 0xAD |  |  | Rd |  |  | Rs1 |  |  | - |
| 31 | 24 | 23 |  | 20 | 19 |  | 16 | 15 | 0 |


| MOV |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xB8 |  | Rd |  | - |  | Rs1 |  | - |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 12 | 11 | 0 |


| MOVI |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xBA |  | Rd |  | - |  | \#data |  |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 |  | 0 |


| MOVF |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xBC |  | Rd |  | - |  | Rs1 |  | - |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 12 | 11 | 0 |



| DIVI |  |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| \# 0x4B |  | Rd |  | Rs1 |  |  | \#data |  |  |
| 31 | 24 | 23 |  | 20 | 19 |  | 16 | 15 | 0 |


| SET |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | ---: | :--- | :--- |
| \# 0xD7 |  |  |  | - |  | \#mask |
| 31 |  | 24 | 23 |  | 16 | 15 |
| 0 |  |  |  |  |  |  |


| LOAD |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xD9 |  | Rd |  | - |  | Rs1 |  | - |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 12 | 11 | 0 |


| LOADI |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xDB |  | Rd |  | - |  | \#addr |  |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 |  | 0 |


| STORE |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xC8 |  | - |  | Rs1 |  | Rs2 |  | - |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 12 | 11 | 0 |



| IN |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xDE |  | Rd |  | - |  |  | \#sel |  |  |
| 31 | 24 | 23 | 20 | 19 |  | 2 | 1 |  | 0 |



| OUTI |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xC6 |  | \#op |  | \#sel |  | - |  | \#data |  |
| 31 | 24 | 23 | 22 | 21 | 20 | 19 | 16 | 15 | 0 |


| JMP |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xE0 |  | - |  | \#addr |  |
| 31 | 24 | 23 | 16 | 15 | 0 |


| JC |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xC3 |  | \# 0x0 |  | - |  | \#addr |  |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 |  | 0 |


| JNC |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xC3 |  | \# 0x1 |  | - |  | \#addr |  |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 |  | 0 |


| JO |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xC3 |  | \# 0x2 |  | - |  | \#addr |  |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 |  | 0 |



| JZ |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xC3 |  | \# 0x6 |  | - |  | \#addr |  |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 |  | 0 |



| JL |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xC3 |  | \# 0x8 |  | - |  | \#addr |  |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 |  | 0 |


| JLE |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xC3 |  | \# 0xA |  | - |  | \#addr |  |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 |  | 0 |


| JG |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xC3 |  | \# 0xB |  | - |  | \#addr |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 0 |



| PUSH |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# 0xF2 |  | - |  | Rs1 |  | - |  |
| 31 | 24 | 23 | 20 | 19 | 16 | 15 | 0 |


| POP |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\#$ 0xF8 |  | Rd |  |  | - |  |  |
| 31 | 24 | 23 |  | 20 | 19 | 0 |  |


| PUSHF |  |  |  |  |
| :--- | ---: | :--- | :--- | :--- |
| $\#$ 0xF1 |  |  |  | - |
| 31 |  | 24 | 23 | 0 |


| POPF |  |  |  |  |
| :--- | ---: | ---: | :--- | ---: |
| $\#$ 0xF4 |  |  |  | - |
| 31 |  | 24 | 23 |  |


| STOP |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- |
| $\# \mathbf{0 x C 1}$ |  |  |  | - |
| 31 |  | 24 | 23 |  |

