## VIRTUAL16 Instruction Set

| VIII O NEID III ON |                      |                |                      |                |                      |                |     |  |
|--------------------------------------------------------|----------------------|----------------|----------------------|----------------|----------------------|----------------|-----|--|
|                                                        | 1 <sup>st</sup> Byte |                | 2 <sup>nd</sup> Byte |                | 3 <sup>rd</sup> Byte |                |     |  |
|                                                        | Hi Nb (BIT7:4)       | Lo Nb (BIT3:0) | Hi Nb (BIT7:4)       | Lo Nb (BIT3:0) | Hi Nb (BIT7:4)       | Lo Nb (BIT3:0) | See |  |
| RET                                                    | 0                    | 0              | -                    | -              | -                    | -              | 1   |  |
| MOV Rs, Rd                                             | 0                    | 1              | Rs                   | Rd             | -                    | -              |     |  |
| MOV @Rs, Rd                                            | 0                    | 2              | Rs                   | Rd             | -                    | -              | 8   |  |
| MOV Rs, @Rd                                            | 0                    | 3              | Rs                   | Rd             | -                    | -              | 8   |  |
| MOV +@Rs, Rd                                           | 0                    | 4              | Rs                   | Rd             | -                    | -              | 8   |  |
| MOV Rs, +@Rd                                           | 0                    | 5              | Rs                   | Rd             | -                    | -              | 8   |  |
| MOV Rs.H, Rd.H                                         | 0                    | 6              | Rs                   | Rd             | Rd(MSB) = Rs(MSB)    |                |     |  |
| MOV Rs.H, Rd.L                                         | 0                    | 7              | Rs                   | Rd             | Rd(MSB) = Rs(LSB)    |                |     |  |
| MOV Rs.L, Rd.H                                         | 0                    | 8              | Rs                   | Rd             | Rd(LSB) = Rs(MSB)    |                |     |  |
| MOV Rs.L, Rd.L                                         | 0                    | 9              | Rs                   | Rd             | Rd(LSB) = Rs(LSB)    |                |     |  |
| SWAP Rs, Rd                                            | 2                    | 9              | Rs                   | Rd             | -                    | -              | 2   |  |
| JSR ADDR                                               | 0                    | D              | ADDR[7:4]            | ADDR[3:0]      | ADDR[15:12]          | ADDR[11:8]     | 3   |  |
| NJSR ADDR                                              | 1                    | 8              | ADDR[7:4]            | ADDR[3:0]      | ADDR[15:12]          | ADDR[11:8]     | 7   |  |
| JMPR Rd                                                | 2                    | 3              | Rd                   | X              | -                    | -              |     |  |
| JMP ADDR                                               | 0                    | F              | ADDR[7:4]            | ADDR[3:0]      | ADDR[15:12]          | ADDR[11:8]     | 3   |  |
| RTS                                                    | 0                    | E              | -                    | -              | -                    | -              |     |  |
|                                                        |                      |                |                      |                |                      |                |     |  |

|                | 1 <sup>st</sup> Byte |                | 2 <sup>nd</sup> Byte |                | 3 <sup>rd</sup> Byte |                |      |
|----------------|----------------------|----------------|----------------------|----------------|----------------------|----------------|------|
|                | Hi Nb (BIT7:4)       | Lo Nb (BIT3:0) | Hi Nb (BIT7:4)       | Lo Nb (BIT3:0) | Hi Nb (BIT7:4)       | Lo Nb (BIT3:0) | See  |
| INC Rd, #COUNT | 1                    | 0              | Rd                   | COUNT          | -                    | -              | 4    |
| DEC Rd, #COUNT | 1                    | 1              | Rd                   | COUNT          | -                    | -              | 4    |
| ADD Rd, Rs     | 1                    | 2              | Rd                   | Rs             | Rd = F               | d + Rs         |      |
| ADC Rd, Rs     | 1                    | 3              | Rd                   | Rs             | Rd = Rd +            | Rs + Carry     |      |
| SUB Rd, Rs     | 1                    | 4              | Rd                   | Rs             | Rd = F               | Rd – Rs        |      |
| SBC Rd, Rs     | 1                    | 5              | Rd                   | Rs             | Rd = Rd -            | Rs - !Carry    |      |
| SMUL Rd, Rs    | 1                    | 6              | Rd                   | Rs             | R12(LSW):R13(        | MSW) = Rs * Rd | 10   |
| UMUL Rd, Rs    | 1                    | 7              | Rd                   | Rs             | R12(LSW):R13(        | MSW) = Rs * Rd | 10   |
| CMP Rd, Rs     | 2                    | 8              | Rd                   | Rs             | R13 = Rd - Rs        |                | 10   |
| ASR Rd, #COUNT | 1                    | 9              | Rd                   | COUNT          | -                    | -              | 4    |
| LSL Rd, #COUNT | 1                    | Α              | Rd                   | COUNT          | -                    | -              | 4    |
| LSR Rd, #COUNT | 1                    | В              | Rd                   | COUNT          | -                    | -              | 4    |
| ROL Rd, #COUNT | 1                    | С              | Rd                   | COUNT          | -                    | -              | 4, 9 |
| RLC Rd, #COUNT | 1                    | D              | Rd                   | COUNT          | -                    | -              | 4, 9 |
| ROR Rd, #COUNT | 1                    | E              | Rd                   | COUNT          | -                    | -              | 4, 9 |
| RRC Rd, #COUNT | 1                    | F              | Rd                   | COUNT          | -                    | -              | 4, 9 |

## VIRTUAL16 Instruction Set (continued)

|                 |                      |                      | ALIO IIISII UCIIOII C |                      |                      |                      |      |
|-----------------|----------------------|----------------------|-----------------------|----------------------|----------------------|----------------------|------|
|                 | 1 <sup>st</sup> Byte |                      | 2 <sup>nd</sup> Byte  |                      | 3 <sup>rd</sup> Byte |                      |      |
|                 | Hi Nb (BIT7:4)       | Lo Nb (BIT3:0)       | Hi Nb (BIT7:4)        | Lo Nb (BIT3:0)       | Hi Nb (BIT7:4)       | Lo Nb (BIT3:0)       | See  |
| BCC OFFSET      | 2                    | 0                    | OFFSET[7:4]           | OFFSET[3:0]          | -                    | -                    | 5, 6 |
| BCS OFFSET      | 2                    | 1                    | OFFSET[7:4]           | OFFSET[3:0]          | -                    | -                    | 5, 6 |
| BRA OFFSET      | 2                    | 2                    | OFFSET[7:4]           | OFFSET[3:0]          | -                    | -                    | 5, 6 |
| AND Rd, Rs      | 0                    | Α                    | Rd                    | Rs                   | Rd = Rd & Rs         |                      |      |
| OR Rd, Rs       | 0                    | В                    | Rd                    | Rs                   | Rd = Rd   Rs         |                      |      |
| XOR Rd, Rs      | 0                    | С                    | Rd                    | Rs                   | Rd = Rd ^ Rs         |                      |      |
| CLC             | 2                    | 4                    | -                     | -                    | -                    | -                    |      |
| SEC             | 2                    | 5                    | -                     | -                    | -                    | -                    |      |
| PUSH Rd         | 2                    | 6                    | Rd                    | Х                    | -                    | -                    | 6    |
| POP Rd          | 2                    | 7                    | Rd                    | X                    | -                    | -                    | 6    |
| NOP             | 2                    | Α                    | -                     | -                    | -                    | -                    |      |
| NOP             | 2                    | В                    | -                     | -                    | -                    | -                    |      |
| NOP             | 2                    | С                    | -                     | -                    | -                    | -                    |      |
| NOP             | 2                    | D                    | -                     | -                    | -                    | -                    |      |
| NOP             | 2                    | E                    | -                     | -                    | -                    | -                    |      |
| NOP             | 2                    | F                    | -                     | -                    | -                    | -                    |      |
|                 | 451 -                |                      | and D                 |                      | ord = .              |                      |      |
|                 |                      | 1 <sup>st</sup> Byte |                       | 2 <sup>nd</sup> Byte |                      | 3 <sup>rd</sup> Byte |      |
|                 | Hi Nb (BIT7:4)       | Lo Nb (BIT3:0)       | Hi Nb (BIT7:4)        | Lo Nb (BIT3:0)       | Hi Nb (BIT7:4)       | Lo Nb (BIT3:0)       | See  |
| NOP             | 3                    | X                    | -                     | -                    | -                    | -                    |      |
| NOP             | 4                    | X                    |                       |                      | -                    | -                    |      |
| MOV #VAL, Rd.L  | 5                    | Rd                   | VAL[7:4]              | VAL[3:0]             | -                    | -                    |      |
| MOV #VAL, Rd.H  | 6                    | Rd                   | VAL[7:4]              | VAL[3:0]             | -                    | <u>-</u>             |      |
| MOV #VAL, Rd    | 7                    | Rd                   | VAL[7:4]              | VAL[3:0]             | VAL[15:12]           | VAL[11:8]            |      |
| MOV ADDR, Rd    | 8                    | Rd                   | ADDR[7:4]             | ADDR[3:0]            | ADDR[15:12]          | ADDR[11:8]           |      |
| MOV Rs, ADDR    | 9                    | Rs                   | ADDR[7:4]             | ADDR[3:0]            | ADDR[15:12]          | ADDR[11:8]           |      |
| BNM1 Rs, OFFSET |                      | Rs                   | OFFSET[7:4]           | OFFSET[3:0]          | -                    | -                    | 5    |
| BM1 Rs, OFFSET  | В                    | Rs                   | OFFSET[7:4]           | OFFSET[3:0]          | -                    | -                    | 5    |
| BMI Rs, OFFSET  | С                    | Rs                   | OFFSET[7:4]           | OFFSET[3:0]          | -                    | -                    | 5    |
| BPL Rs, OFFSET  | D                    | Rs                   | OFFSET[7:4]           | OFFSET[3:0]          | -                    | -                    | 5    |
| BNE Rs, OFFSET  | E                    | Rs                   | OFFSET[7:4]           | OFFSET[3:0]          | -                    | -                    | 5    |
| BEQ Rs, OFFSET  | F                    | Rs                   | OFFSET[7:4]           | OFFSET[3:0]          | -                    | -                    | 5    |
|                 |                      |                      |                       |                      |                      |                      |      |

## VIRTUAL16 Instruction Set (continued)

- 1: Last instruction must be RET
- 2: SWAP instruction have 2 modes. If source and destination register is different it swaps register contents. If source and destination register is same it swaps LSB and MSB of register
- 3: JSR and JMP calculates destination address automatically. Assemble your VIRTUAL16 code starting from 0x0000 address for proper calculation
- 4: #COUNT must be "real count -1". If #COUNT == 0 VIRTUAL16 calculates it as 1, if #COUNT == 15 VIRTUAL16 calculates it as 16 etc. If #COUNT not given to customasm assembler it will increment or decrement by 1
- 5: OFFSET formula is = New Address Current Address 2. Same as 6502. Except BRA, BCS and BCC instructions, you must give register to test. If no register given to customasm assembler it will test Compare Register (R13)
- 6: x means don't matter. You can give any value to this nibbles
- 7: With this instruction you can execute native 6502 subroutine without returning from VIRTUAL16 mode. Just give it 6502 subroutine address and magic will happen. Your subroutine must end with RTS instruction
- 8: @ means register holds pointer. +@ means register holds pointer and after execution pointer will incremented by 2. These instructions destroy BITO of pointer. It means you cannot access odd locations in memory
- 9: Difference between ROL and RLC is ROL ignores carry for first rotate but RLC don't. Same for ROR and RRC.