



# **SONiX 8-Bit Micro-Controller**

SONIX reserves the right to make change without further notice to any products herein to improve reliability, function or design. SONIX does not assume any liability arising out of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights nor the rights of others. SONIX products are not designed, intended, or authorized for us as components in systems intended, for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the SONIX product could create a situation where personal injury or death may occur. Should Buyer purchase or use SONIX products for any such unintended or unauthorized application. Buyer shall indemnify and hold SONIX and its officers, employees, subsidiaries, affiliates and distributors harmless against all claims, cost, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use even if such claim alleges that SONIX was negligent regarding the design or manufacture of the part.



# **AMENDENT HISTORY**

| Version  | Date      | Description                                                                                         |
|----------|-----------|-----------------------------------------------------------------------------------------------------|
| VER 1.90 | Sep. 2002 | V1.90 first issue                                                                                   |
| VER 1.93 | Feb. 2003 | Change the description of ADD M,A instruction from " $M \leftarrow M+A$ " to " $M \leftarrow A+M$ " |
| VER 1.94 | Jul. 2004 | 1. Separate instruction table into two tables.                                                      |
|          |           | 2. Add PUSH/POP instruction description.                                                            |
|          |           | 3. Remove the instruction cycle description in each instruction description.                        |



# **Table of Content**

| 1 OVERVIEW                                                | 5  |
|-----------------------------------------------------------|----|
|                                                           | J  |
| 2                                                         |    |
| INSTRUCTION SET TABLE                                     | 6  |
| TABLE I: FOR SN8P1XXX (FOUR CLOCKS PER INSTRUCTION CYCLE) |    |
| TABLE II: FOR SN8P2XXX (ONE CLOCK PER INSTRUCTION CYCLE)  |    |
| INSTRUCTION DESCRIPTION                                   | 10 |
| DATA TRANSFER INSTRUCTION                                 |    |
| MOV – Memory Read / Write Instruction                     |    |
| BOMOV – BANK 0 Memory Read / Write Instruction            |    |
| XCH – Data Exchange for All Area Memory                   |    |
| B0XCH – Data Exchange for BANK 0 Memory                   |    |
| MOVC – Read Data from ROM                                 |    |
| ARITHMETIC INSTRUCTION                                    |    |
| ADC – Add with Carry                                      |    |
| ADD – Add only                                            |    |
| B0ADD – Add with BANK 0 Memory                            |    |
| SBC – Subtract with Carry                                 |    |
| SUB – Subtract only                                       |    |
| DAA –Decimal-Adjust accumulator                           |    |
| MUL – Multiply Unsigned                                   |    |
| LOGIC INSTRUCTION                                         |    |
| AND – Logical AND                                         |    |
| OR – Logical OR                                           |    |
| XOR – Logical XOR                                         |    |
| PROCESS INSTRUCTION                                       |    |
| SWAP & SWAPM – Memory high/low Nibble Exchange            |    |
| RLC & RLCM – Memory Left Rotation                         |    |
| RRC & RRCM – Memory Right Rotation                        |    |
| CLR – Clear                                               |    |
| BCLR & BOBCLR – Bit Clear                                 |    |
| BSET & BOBSET – Bit Set                                   |    |
| BRANCH INSTRUCTION                                        |    |



| CMPRS – Compare                                                | 31 |
|----------------------------------------------------------------|----|
|                                                                |    |
| INCS & INCMS – Increment and Skip on Zero                      |    |
| DECS & DECMS – Decrement and Skip on Zero                      |    |
| BTSO & BOBTSO – Bit Test 0                                     |    |
| BTS1 & B0BTS1 – Bit Test 1                                     |    |
| JMP – Jump                                                     |    |
| CALL – Call Procedure                                          |    |
| MISCELLANEOUS INSTRUCTION                                      |    |
| RET – Return from Call Procedure                               |    |
| RETI – Return from Interrupt                                   |    |
| NOP – No Operation                                             | 40 |
| PUSH – Save Some System Registers for SN8P1XXX and SN8P270XA   |    |
| PUSH – Save A and PFLAG for SN8P260X                           |    |
| POP – Restore Some System Registers for SN8P1XXX and SN8P270XA |    |
| POP – Restore A and PFLAG for SN8P260X                         | 44 |



# 1 OVERVIEW

This Manual contains detailed information and programming examples for each instruction of SONiX 8-Bit MCU series instruction set. Information is arranged in a consistent format to improve readability and for use as a quick-reference resource for application programmers.

The information elements of the instruction description format are as follows:

- Instruction name (mnemonic)
- Full instruction name
- Operand overview
- Source/destination format of the instruction operand
- Textual description of instructions
- Programming examples to shoe how the instruction is used



# **2** INSTRUCTION SET TABLE

# Table I: For SN8P1XXX (Four clocks per instruction cycle)

| Field | Mnem         | onic | Description                                                                           | С                             | DC | Ζ  | Cycle |
|-------|--------------|------|---------------------------------------------------------------------------------------|-------------------------------|----|----|-------|
|       | MOV          | A,M  | $A \leftarrow M$                                                                      | -                             | -  |    | 1     |
| М     | MOV          | M,A  | $M \leftarrow A$                                                                      | -                             | -  | -  | 1     |
| 0     | B0MOV        | A,M  | $A \leftarrow M (bnak 0)$                                                             | -                             | -  |    | 1     |
| V     | B0MOV        | M,A  | $M (bank 0) \leftarrow A$                                                             | -                             | -  | -  | 1     |
| Е     | MOV          | A,I  | A←I                                                                                   | -                             | -  | -  | 1     |
|       | <b>B0MOV</b> | M,I  | $M \leftarrow I$ , (M = only for Working registers R, Y, Z, RBANK & PFLAG)            | -                             | -  | -  | 1     |
|       | XCH          | A,M  | $A \leftarrow \rightarrow M$                                                          | -                             | -  | -  | 1     |
|       | B0XCH        | A,M  | $A \leftarrow \rightarrow M (bank 0)$                                                 | -                             | -  | -  | 1     |
|       | MOVC         |      | $R, A \leftarrow ROM [Y,Z]$                                                           | -                             | -  | -  | 2     |
|       | ADC          | A,M  | $A \leftarrow A + M + C$ , if occur carry, then C=1, else C=0                         |                               |    |    | 1     |
| А     | ADC          | M,A  | $M \leftarrow A + M + C$ , if occur carry, then C=1, else C=0                         |                               |    |    | 1     |
| R     | ADD          | A,M  | $A \leftarrow A + M$ , if occur carry, then C=1, else C=0                             |                               |    |    | 1     |
| Ι     | ADD          | M,A  | $M \leftarrow A + M$ , if occur carry, then C=1, else C=0                             |                               |    |    | 1     |
| Т     | B0ADD        | M,A  | $M$ (bank 0) $\leftarrow$ A + M (bank 0), if occur carry, then C=1, else C=0          |                               |    |    | 1     |
| Н     | ADD          | A,I  | A $\leftarrow$ A + I, if occur carry, then C=1, else C=0                              |                               |    |    | 1     |
| М     | SBC          | A,M  | $A \leftarrow A - M - /C$ , if occur borrow, then C=0, else C=1                       |                               |    | V  | 1     |
| Е     | SBC          | M,A  | $M \leftarrow A - M - /C$ , if occur borrow, then C=0, else C=1                       |                               |    | √. | 1     |
| Т     | SUB          | A,M  | $A \leftarrow A - M$ , if occur borrow, then C=0, else C=1                            | V                             |    | V  | 1     |
| Ī     | SUB          | M,A  | $M \leftarrow A - M$ , if occur borrow, then C=0, else C=1                            | $\sqrt{\sqrt{\sqrt{\gamma}}}$ |    |    |       |
| C     | SUB          | A,I  | $A \leftarrow A - I$ , if occur borrow, then C=0, else C=1                            |                               |    |    | 1     |
| Ũ     | DAA          | ,.   | To adjust ACC's data format from HEX to DEC.                                          |                               | -  | _  | 1     |
|       |              |      | R, A $\leftarrow$ A * M, The LB of product stored in Acc and HB stored in R register. | ,                             |    | 1  |       |
|       | MUL          | A,M  | ZF affected by Acc.                                                                   | -                             | -  |    | 2     |
|       | AND          | A,M  | $A \leftarrow A \text{ and } M$                                                       | -                             | -  |    | 1     |
| L     | AND          | M,A  | $M \leftarrow A \text{ and } M$                                                       | _                             | -  |    | 1     |
| Ō     | AND          | A,I  | $A \leftarrow A \text{ and } I$                                                       | _                             | _  | V  | 1     |
| G     | OR           | A,M  | $A \leftarrow A \text{ or } M$                                                        | -                             | -  | V  | 1     |
| Ī     | OR           | M,A  | $M \leftarrow A \text{ or } M$                                                        | -                             | -  | √. | 1     |
| C     | OR           | A,I  | $A \leftarrow A \text{ or } I$                                                        | -                             | -  | V  | 1     |
|       | XOR          | A,M  | $A \leftarrow A \text{ xor } M$                                                       | -                             | _  | V  | 1     |
|       | XOR          | M,A  | $M \leftarrow A \text{ xor } M$                                                       | -                             | -  | V  | 1     |
|       | XOR          | A,I  | $A \leftarrow A \text{ xor } I$                                                       | -                             | -  | √. | 1     |
|       | SWAP         | M    | $A (b3 \sim b0, b7 \sim b4) \leftarrow M(b7 \sim b4, b3 \sim b0)$                     | -                             | _  | -  | 1     |
| Р     | SWAPM        |      | $M(b3 \sim b0, b7 \sim b4) \leftarrow M(b7 \sim b4, b3 \sim b0)$                      | -                             | -  | -  | 1     |
| R     | RRC          | M    | $A \leftarrow RRC M$                                                                  |                               | -  | -  | 1     |
| 0     | RRCM         | M    | $M \leftarrow RRC M$                                                                  |                               | -  | -  | 1     |
| C     | RLC          | M    | $A \leftarrow RLC M$                                                                  |                               | -  | -  | 1     |
| E     | RLCM         | M    | $M \leftarrow RLC M$                                                                  |                               | _  | -  | 1     |
| S     | CLR          | M    | $M \leftarrow 0$                                                                      | -                             | -  | -  | 1     |
| S     | BCLR         | M.b  | $M \leftarrow 0$                                                                      | _                             | _  | -  | 1     |
|       | BSET         | M.b  | $M.b \leftarrow 0$                                                                    | -                             | -  | -  | 1     |
|       | 2021         | M.b  | $M.b \leftarrow 1$<br>M(bank 0).b $\leftarrow 0$                                      | -                             | _  | _  | 1     |
|       | B0BCLR       |      |                                                                                       | -                             |    |    | 1     |
|       | BOBSET       | M.b  | $M(bank \ 0).b \leftarrow 1$                                                          | -                             | -  | -  | 1     |



| Field | Mnemor   | nic | Description                                                                            | С | DC    | Ζ | Cycle |
|-------|----------|-----|----------------------------------------------------------------------------------------|---|-------|---|-------|
|       | CMPRS A  | A,I | $ZF,C \leftarrow A - I$ , If $A = I$ , then skip next instruction                      |   | -     |   | 1 + S |
| В     | CMPRS A  | A,M | $ZF,C \leftarrow A - M$ , If $A = M$ , then skip next instruction                      |   | -     |   | 1 + S |
| R     | INCS N   | M   | $A \leftarrow M + 1$ , If $A = 0$ , then skip next instruction                         | - | -     | - | 1 + S |
| Α     | INCMS N  | M   | $M \leftarrow M + 1$ , If $M = 0$ , then skip next instruction                         | - | -     | - | 1 + S |
| Ν     | DECS N   | M   | $A \leftarrow M - 1$ , If $A = 0$ , then skip next instruction                         | - | -     | - | 1 + S |
| С     | DECMS N  | M   | $M \leftarrow M - 1$ , If $M = 0$ , then skip next instruction                         | - | -     | - | 1 + S |
| Н     | BTS0 N   | M.b | If $M.b = 0$ , then skip next instruction                                              | - | 1 + S |   |       |
|       | BTS1 N   | M.b | If $M.b = 1$ , then skip next instruction                                              | - | -     | - | 1 + S |
|       | BOBTSO N | M.b | If $M(bank 0).b = 0$ , then skip next instruction                                      | - | -     | - | 1 + S |
|       | BOBTS1 N | M.b | If $M(bank 0).b = 1$ , then skip next instruction                                      | - | -     | - | 1 + S |
|       | JMP      | d   | PC15/14 $\leftarrow$ RomPages1/0, PC13~PC0 $\leftarrow$ d                              | - | -     | - | 2     |
|       | CALL     | d   | Stack $\leftarrow$ PC15~PC0, PC15/14 $\leftarrow$ RomPages1/0, PC13~PC0 $\leftarrow$ d | - | -     | - | 2     |
|       | RET      |     | $PC \leftarrow Stack$                                                                  | - | -     | - | 2     |
| М     | RETI     |     | $PC \leftarrow Stack$ , and to enable global interrupt                                 | - | -     | - | 2     |
| Ι     | RETLW    |     | $PC \leftarrow Stack$ , and to load a value by $PC+A$                                  | - | -     | - | 2     |
| S     | PUSH     |     | To push working registers (080H~087H) into buffers                                     | - | -     | - | 1     |
| С     | POP      |     | To pop working registers (080H~087H) from buffers                                      |   |       |   | 1     |
|       | NOP      |     | No operation                                                                           | - | -     | - | 1     |

#### <u>Remark</u>

- 1. The "M" is memory including system registers and user defined memory.
- 2. If branch condition is true then "S = 0", otherwise "S = 1".
- 3. Any instruction that writes OSCM register will add an extra cycle.
- 4. One instruction cycle = 1/Fcpu



# Table II: For SN8P2XXX (One clock per instruction cycle)

| Field | Mnem                                                   | onic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Description                                                                | С                                                     | DC | Ζ            | Cycle |
|-------|--------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|-------------------------------------------------------|----|--------------|-------|
|       | MOV                                                    | A,M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow M$                                                           | -                                                     | -  |              | 1     |
| М     | MOV                                                    | M,A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $M \leftarrow A$                                                           | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | 1  |              |       |
| 0     | <b>B0MOV</b>                                           | A,M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow M (bnak 0)$                                                  | -                                                     | -  |              | 1     |
| V     | <b>B0MOV</b>                                           | M,A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | M (bank 0) $\leftarrow$ A                                                  | -                                                     | -  | -            | 1     |
| Е     | MOV                                                    | A,I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | A←I                                                                        | -                                                     | -  | -            | 1     |
|       | <b>B0MOV</b>                                           | M,I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $M \leftarrow I$ , (M = Working registers, RBANK & PFLAG)                  | -                                                     | -  | -            | 1     |
|       | XCH                                                    | A,M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow \rightarrow M$                                               | -                                                     | -  | -            | 1+N   |
|       | B0XCH                                                  | A,M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow \rightarrow M (bank 0)$                                      | I                                                     | -  | I            | 1+N   |
|       | MOVC                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | $R, A \leftarrow ROM [Y,Z]$                                                | -                                                     | -  | -            | 2     |
|       | ADC                                                    | A,M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow A + M + C$ , if occur carry, then C=1, else C=0              |                                                       |    |              | 1     |
| А     | ADC                                                    | M,A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $M \leftarrow A + M + C$ , if occur carry, then C=1, else C=0              |                                                       |    |              | 1+N   |
| R     | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1                                                                          |                                                       |    |              |       |
| Ι     | ADD                                                    | A,IA $\leftarrow$ IM,IM $\leftarrow$ I, (M = Working registers, RBANK & PFLAG)A,MA $\leftarrow \rightarrow$ MA,MA $\leftarrow \rightarrow$ M (bank 0)R, A $\leftarrow$ ROM [Y,Z]A,MA $\leftarrow A + M + C$ , if occur carry, then C=1, else C=0M,AM $\leftarrow A + M + C$ , if occur carry, then C=1, else C=0A,MA $\leftarrow A + M$ , if occur carry, then C=1, else C=0M,AM $\leftarrow M + A$ , if occur carry, then C=1, else C=0M,AM $\leftarrow M + A$ , if occur carry, then C=1, else C=0A,AM (bank 0) $\leftarrow$ M (bank 0) + A, if occur carry, then C=1, else C=0A,IA $\leftarrow A + H$ , if occur carry, then C=1, else C=0A,IA $\leftarrow A + H$ , if occur borrow, then C=0, else C=1M,AM $\leftarrow A - M - /C$ , if occur borrow, then C=0, else C=1M,AM $\leftarrow A - M$ , if occur borrow, then C=0, else C=1A,MA $\leftarrow A - M$ , if occur borrow, then C=0, else C=1M,AM $\leftarrow A - M$ , if occur borrow, then C=0, else C=1To adjust ACC's data format from HEX to DEC.A,MR, $A \leftarrow A + M$ , The LB of product stored in Acc and HB stored in R regiZF affected by Acc.A,MA $\leftarrow A$ and MA,AM $\leftarrow A$ or MA,AM $\leftarrow A$ or MA,AA $\leftarrow A$ and MA,AA $\leftarrow A$ or MA, |                                                                            |                                                       |    |              | 1+N   |
| Т     | B0ADD                                                  | M,A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | M (bank 0) $\leftarrow$ M (bank 0) + A, if occur carry, then C=1, else C=0 |                                                       |    |              | 1+N   |
| Н     | ADD                                                    | A,I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow A + I$ , if occur carry, then C=1, else C=0                  |                                                       |    |              | 1     |
| М     | SBC                                                    | A,M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow A - M - /C$ , if occur borrow, then C=0, else C=1            |                                                       |    |              | 1     |
| Е     | SBC                                                    | M,A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $M \leftarrow A - M - /C$ , if occur borrow, then C=0, else C=1            |                                                       |    |              | 1+N   |
| Т     | SUB                                                    | A,M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow A - M$ , if occur borrow, then C=0, else C=1                 |                                                       |    |              | 1     |
| Ι     |                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                            |                                                       |    |              | 1+N   |
| С     | SUB                                                    | A,I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow A - I$ , if occur borrow, then C=0, else C=1                 |                                                       |    |              | 1     |
|       | DAA                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | To adjust ACC's data format from HEX to DEC.                               |                                                       | -  | -            | 1     |
|       | MUL                                                    | A,M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                            | -                                                     | -  | $\checkmark$ | 2     |
|       | AND                                                    | A,M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow A \text{ and } M$                                            | -                                                     | -  |              | 1     |
| L     | AND                                                    | M,A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $M \leftarrow A and M$                                                     | -                                                     | -  |              | 1+N   |
| 0     | AND                                                    | A,I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow A \text{ and } I$                                            | -                                                     | -  |              | 1     |
| G     | OR                                                     | A,M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow A \text{ or } M$                                             | -                                                     | -  |              | 1     |
| Ι     | OR                                                     | M,A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $M \leftarrow A \text{ or } M$                                             | -                                                     | -  |              | 1+N   |
| С     | OR                                                     | A,I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow A \text{ or } I$                                             | -                                                     | -  |              | 1     |
|       | XOR                                                    | A,M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow A \text{ xor } M$                                            | -                                                     | -  |              | 1     |
|       | XOR                                                    | M,A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $M \leftarrow A \operatorname{xor} M$                                      | -                                                     | -  |              | 1+N   |
|       | XOR                                                    | A,I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $A \leftarrow A \text{ xor } I$                                            | -                                                     | -  |              | 1     |
|       | SWAP                                                   | М                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | A (b3~b0, b7~b4) $\leftarrow$ M(b7~b4, b3~b0)                              | -                                                     | -  | -            | 1     |
| Р     | SWAPM                                                  | М                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                            | -                                                     | -  | -            | 1+N   |
| R     | RRC                                                    | М                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                            |                                                       | -  | -            | 1     |
| 0     | RRCM                                                   | М                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | $M \leftarrow RRC M$                                                       |                                                       | -  | -            | 1+N   |
| С     | RLC                                                    | М                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                            |                                                       | -  | -            | 1     |
| Е     | RLCM                                                   | М                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | $M \leftarrow RLC M$                                                       |                                                       | -  | -            | 1+N   |
| S     | CLR                                                    | М                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | $M \leftarrow 0$                                                           | -                                                     | -  | -            | 1     |
| S     | BCLR                                                   | M.b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $M.b \leftarrow 0$                                                         | _                                                     | -  | -            | 1+N   |
|       | BSET                                                   | M.b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $M.b \leftarrow 1$                                                         | -                                                     | -  | -            | 1+N   |
|       | B0BCLR                                                 | M.b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $M(bank 0).b \leftarrow 0$                                                 | -                                                     | -  | -            | 1+N   |
|       | BOBSET                                                 | M.b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $M(bank 0).b \leftarrow 1$                                                 | -                                                     | -  | -            | 1+N   |



| Field | Mnem   | onic | Description                                                                                                                                                                                             | С            | DC           | Ζ            | Cycle |
|-------|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|--------------|-------|
|       | CMPRS  | A,I  | $ZF,C \leftarrow A - I$ , If $A = I$ , then skip next instruction                                                                                                                                       |              | -            |              | 1 + S |
| В     | CMPRS  | A,M  | $ZF,C \leftarrow A - M$ , If $A = M$ , then skip next instruction                                                                                                                                       |              | -            |              | 1 + S |
| R     | INCS   | М    | $A \leftarrow M + 1$ , If $A = 0$ , then skip next instruction                                                                                                                                          | -            | -            | I            | 1 + S |
| А     | INCMS  | М    | $M \leftarrow M + 1$ , If $M = 0$ , then skip next instruction                                                                                                                                          | -            | -            | I            | 1+N+S |
| Ν     | DECS   | Μ    | $A \leftarrow M - 1$ , If $A = 0$ , then skip next instruction                                                                                                                                          | -            | -            | -            | 1 + S |
| С     | DECMS  | Μ    | $M \leftarrow M - 1$ , If $M = 0$ , then skip next instruction                                                                                                                                          | -            | -            | -            | 1+N+S |
| Н     | B0BTS0 | M.b  | If $M(bank 0).b = 0$ , then skip next instruction                                                                                                                                                       | -            | -            | -            | 1 + S |
|       | B0BTS1 | M.b  | If $M(bank 0).b = 1$ , then skip next instruction                                                                                                                                                       | -            | -            | -            | 1 + S |
|       | JMP    | D    | PC15/14 $\leftarrow$ RomPages1/0, PC13~PC0 $\leftarrow$ d                                                                                                                                               | -            | -            | -            | 2     |
|       | CALL   | D    | Stack $\leftarrow$ PC15~PC0, PC15/14 $\leftarrow$ RomPages1/0, PC13~PC0 $\leftarrow$ d                                                                                                                  | -            | -            | -            | 2     |
| М     | RET    |      | $PC \leftarrow Stack$                                                                                                                                                                                   | -            | -            | -            | 2     |
| Ι     | RETI   |      | $PC \leftarrow Stack$ , and to enable global interrupt                                                                                                                                                  | -            | -            | -            | 2     |
| S     | PUSH   |      | <ul> <li>a. To push working registers (080H~087H) into buffers</li> <li>b. To push ACC and PFLAG (except NT0, NPD bit) into buffers.</li> <li>Note: Refer to instruction description section</li> </ul> | -            | -            | -            | 1     |
|       | РОР    |      | <ul> <li>a. To pop working registers (080H~087H) from buffers</li> <li>b. To pop ACC and PFLAG (except NT0, NPD bit) into buffers</li> <li>Note: Refer to instruction description section</li> </ul>    | $\checkmark$ | $\checkmark$ | $\checkmark$ | 1     |
|       | NOP    |      | No operation                                                                                                                                                                                            | -            | -            | -            | 1     |
|       | RETLW  | Ι    | $PC \leftarrow Stack, A \leftarrow I$                                                                                                                                                                   | -            | -            | -            | 2     |

#### Remark

- 1. The "M" is memory including system registers and user defined memory.
- 2. If branch condition is true then "S = 0", otherwise "S = 1".
- 3. If "M" is system registers (80h ~ FFh of bank 0) then "N" = 0, otherwise "N" = 1
- 4. Different to SN8P1XXX series, any instruction that writes OSCM register **does not** add an extra cycle.
- 5. One instruction cycle = 1/Fcpu
- 6. Instruction limitations:
  - The ROM address 8 only JMP or NOP instruction is valid in following chips: SN8P2501A, SN8P2602A, SN8P2604, SN8P2606, SN8P2608, SN8P270XA
  - For "B0MOV M,I" instruction, the value of I can't be 0E6h or 0E7h in following chips: SN8P2501A, SN8P2602A, SN8P2604, SN8P270XA
    - E.g. "B0MOV Y, #0E6h" is invalid
      - "B0MOV Y, #00h" is valid
  - For "B0XCH A,M" instruction, the address range of M can't be 80h ~ FFh in following chips: SN8P2501A, SN8P2602A, SN8P2604, SN8P270XA
  - Read, modify then write back memory instruction can't access T0C register in following chips: SN8P2602A, SN8P2604, SN8P2606, SN8P2608, SN8P270XA
    - E.g. "B0ADD T0C, A" is invalid "B0MOV T0C, A" is valid



# **INSTRUCTION DESCRIPTION**

# DATA TRANSFER INSTRUCTION

### **MOV** – Memory Read / Write Instruction

#### Operation:

| Mnemonic |     | Description      | С | DC | Ζ            |
|----------|-----|------------------|---|----|--------------|
| MOV      | A,M | $A \leftarrow M$ | - | -  | $\checkmark$ |
| MOV      | M,A | $M \leftarrow A$ | - | -  | -            |
| MOV      | A,I | A ← I            | - | -  | -            |

#### Remark

- 1. The "I" is immediately value.
- 2. The "M" is memory including system registers and user defined memory.

#### Description:

The instruction is a memory read/write instruction. It transfers data through ACC. There are three operations of MOV instruction.

- > MOV A,M : Read memory data and store into ACC buffer. If the result is zero, the zero flag (Z) will be set as "1". (Support R/W, R register and memory)
- > MOV M,A : Write the data from ACC buffer to memory. The operation doesn't affect PFLAG. (Support R/W, W register and memory)
- > MOV A,I : Write a immediate value to ACC buffer. The operation doesn't affect PFLAG.
- **S** Example:

| MOV | A, #55H | ; Write 55H immediate value to ACC               |
|-----|---------|--------------------------------------------------|
| MOV | WK00, A | ; Write ACC buffer data to WK00 defined by user. |
| MOV | A, WK00 | ; Read WK00 data and store in to ACC buffer.     |



### **B0MOV – BANK 0 Memory Read / Write Instruction**

#### Operation:

| Mnemonic     |     | Description                                               |   |   | Ζ |
|--------------|-----|-----------------------------------------------------------|---|---|---|
| <b>B0MOV</b> | A,M | $A \leftarrow M$ (bnak 0)                                 | - | - |   |
| <b>B0MOV</b> | M,A | M (bank 0) $\leftarrow$ A                                 | - | - | - |
| <b>B0MOV</b> | M,I | $M \leftarrow I$ , (M = Working registers, RBANK & PFLAG) | - | - | - |

#### **Remark**

- 1. The "I" is immediately value.
- 2. The "M" is BANK 0 memory including system registers and user defined memory.

#### Description:

The instruction is a memory read/write instruction. **The memory must be in BANK 0**. It transfers data through ACC. There are three operations of B0MOV instruction.

- BOMOV A,M : Read BANK 0 memory data and store into ACC buffer. If the result is zero, the zero flag (Z) will be set as "1"; otherwise, the zero flag (Z) is cleared. (Support R/W, R register and memory)
- **BOMOV** M,A : Write the data from ACC buffer to BANK 0 memory. The operation doesn't affect PFLAG. (Support R/W, W register and memory)
- BOMOV M,I : Write a immediate value to BANK 0 memory. The memory must be working register (H, L, R, X, Y, Z), RBANK or PFLAG. The operation doesn't affect PFLAG.
- **C** Example:

| BOMOV        | A, WK00 | ; Read WK00 data and store into ACC. The WK00 is defined by user ; and in BANK 0. |
|--------------|---------|-----------------------------------------------------------------------------------|
| BOMOV        | WK00, A | ; Write ACC buffer data to WK00 defined by user.                                  |
| <b>B0MOV</b> | R, #10  | ; Write an immediate data into R register directly.                               |



#### **XCH** – Data Exchange for All Area Memory

#### Operation:

| Mnemonic | Description                  | С | DC | Ζ |
|----------|------------------------------|---|----|---|
| XCH A,M  | $A \leftarrow \rightarrow M$ | - | -  | - |

#### <u>Remark</u>

The "M" is memory including system registers and user defined memory.

#### Description:

The instruction is to exchange the data between ACC and memory. When the XCH is executed, the ACC data is transferred to the memory, and data of memory transferred to ACC buffer.

> XCH M,A : Exchange the data between ACC and the memory. The operation doesn't affect PFLAG. (Support R/W register and memory)

#### **C** Example:

XCH A, WK00 ; Exchange the data between ACC and WK00 defined ; by user.



#### **B0XCH** – Data Exchange for BANK 0 Memory

#### Operation:

| Mnemoni  | ic | Description                           | С | DC | Ζ |
|----------|----|---------------------------------------|---|----|---|
| B0XCH A, | ,M | $A \leftarrow \rightarrow M$ (bank 0) | - | -  | - |

#### <u>Remark</u>

The "M" is BANK 0 memory including system registers and user defined memory.

#### Description:

The instruction is to exchange the data between ACC and memory. **The memory must be in BANK 0.** When the B0XCH is executed, the ACC data is transferred to the memory, and data of memory transferred to ACC buffer.

**BOXCH** M,A : Exchange the data between ACC and the BANK 0 memory. The operation doesn't affect PFLAG. (Support R/W register and memory)

#### **C** Example:

B0XCH A, WK00

; Exchange the data between ACC and WK00 defined ; by user and in BANK 0.



#### **MOVC** – Read Data from ROM

#### Operation:

| Mnemonic | Description                     | С | DC | z |
|----------|---------------------------------|---|----|---|
| MOVC     | $R, A \leftarrow ROM [X, Y, Z]$ | - | -  | - |

#### Description:

The instruction is to read data of ROM. This is a look-up table application. After defining the X, Y, Z data pointed to the ROM address, to get the ROM data using MOVC instruction. The high byte data is stored in R register and the low byte is stored in ACC buffer.

#### > MOVC : Read ROM data and store in R register and ACC. The operation doesn't affect PFLAG.

#### **Context** Example: To look up the ROM data located "table\_1".

|         | B0MOV<br>B0MOV<br>MOVC | Z, #TABLE1\$L | ; Set look-up table's middle address.<br>; Set look-up table's low address.<br>; Look up data, R = 00H, ACC = 35H |
|---------|------------------------|---------------|-------------------------------------------------------------------------------------------------------------------|
|         | INCMS<br>NOP<br>MOVC   |               | ;<br>; Look up next ROM's data.<br>;<br>; Look up data, R = 51H, ACC = 05H.                                       |
| TABLE1: | DW<br>DW<br>DW         |               | ;<br>; Define a word (16 bits) data.<br>; "<br>; "                                                                |



# **ARITHMETIC INSTRUCTION**

# **ADC** – Add with Carry

#### **Operation:**

| Mn  | Mnemonic Description |                                                               | С | DC           | Ζ            |
|-----|----------------------|---------------------------------------------------------------|---|--------------|--------------|
| ADC | A,M                  | $A \leftarrow A + M + C$ , if occur carry, then C=1, else C=0 |   | $\checkmark$ | $\checkmark$ |
| ADC | M,A                  | $M \leftarrow A + M + C$ , if occur carry, then C=1, else C=0 |   | $\checkmark$ |              |

#### Remark

- 1. The "M" is memory including system registers and user defined memory.
- 2. The "C" is carry flag.

#### Description:

The instruction is to get the sum of ACC, memory and C flag. If the result is zero, the zero flag (Z) will be set as "1"; otherwise the zero flag (Z) is cleared. If the result occurs overflow signal, the carry flag (C) will be set as "1"; otherwise the carry flag (C) is cleared. If there is a carry signal from low nibble of the result, the decimal carry flag (DC) will be set as "1"; otherwise the decimal carry flag (DC) is cleared.

- > ADC A,M : Add ACC, memory and carry flag (C) up, and store the result in ACC buffer. (Support R/W,R register and memory)
- > ADC M,A : Add ACC, memory and carry flag (C) up, and store the result in the memory. (Support R/W register and memory)
- Example: The ADC instruction is a useful instruction to do work data adding. There is a word data separated to DAH and DAL. DAH is high byte and DAL is low byte. Add 0x10ff and 0x0103 up and store the sum to DAH and DAL.

| MOV<br>B0MOV | A,#03H<br>DAL,A  | ; Input the low byte (03H) of 0x0103 into DAL  |
|--------------|------------------|------------------------------------------------|
| MOV<br>B0MOV | A,#01H<br>DAH,A  | ; Input the high byte (01H) of 0x0103 into DAH |
| MOV<br>ADD   | A,#0FFH<br>DAL,A | ; Add low byte data. DAL = 02H                 |
| MOV<br>ADC   | A,#10H<br>DAH,A  | ; Add high byte data. DAH = 12H                |
|              |                  | ; The sum is 0x1202.                           |



## ADD – Add only

#### Operation:

| Mne | emonic | Description                                               | С            | DC           | Ζ            |
|-----|--------|-----------------------------------------------------------|--------------|--------------|--------------|
| ADD | A,M    | $A \leftarrow A + M$ , if occur carry, then C=1, else C=0 | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADD | M,A    | $M \leftarrow A + M$ , if occur carry, then C=1, else C=0 | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| ADD | A,I    | $A \leftarrow A + I$ , if occur carry, then C=1, else C=0 | $\checkmark$ | $\checkmark$ | $\checkmark$ |

#### **Remark**

- 1. The "M" is memory including system registers and user defined memory.
- 2. The "C" is carry flag.

#### Description:

The instruction is the add instruction. If the result is zero, the zero flag (Z) will be set as "1"; otherwise the zero flag (Z) is cleared. If the result occurs overflow signal, the carry flag (C) will be set as "1"; otherwise the carry flag (C) is cleared. If there is a carry signal from low nibble of the result, the decimal carry flag (DC) will be set as "1"; otherwise the decimal carry flag (DC) is cleared.

- > ADD A,M : Add ACC buffer and the memory up, and store the result in ACC buffer. (Support R/W,R register and memory)
- > ADD M,A : Add ACC buffer and the memory up, and store the result in the memory. (Support R/W register and memory)
- > ADD A,I : Add ACC buffer and the immediate value up, and store the result in ACC buffer.
- Example:

| ADD | A,WK00 | ; A = A + WK00    |
|-----|--------|-------------------|
| ADD | WK00,A | ; WK00 = A + WK00 |
| ADD | A,#10  | ; A = A + 10      |



#### **B0ADD** – Add with BANK 0 Memory

#### Operation:

| Mnemonia | ; | Description                                                                | С | DC | Ζ            |
|----------|---|----------------------------------------------------------------------------|---|----|--------------|
| B0ADD M, | A | M (bank 0) $\leftarrow$ A + M (bank 0), if occur carry, then C=1, else C=0 |   |    | $\checkmark$ |

#### <u>Remark</u>

- 1. The "M" is memory including system registers and user defined memory.
- 2. The "C" is carry flag.

#### Description:

The instruction is the add instruction. The memory must be in BANK0 and the target. If the result is zero, the zero flag (Z) will be set as "1"; otherwise the zero flag (Z) is cleared. If the result occurs overflow signal, the carry flag (C) will be set as "1"; otherwise the carry flag (C) is cleared. If there is a carry signal from low nibble of the result, the decimal carry flag (DC) will be set as "1"; otherwise the decimal carry flag (DC) is cleared.

# **BOADD** M,A : Add ACC buffer and the BANK 0 memory up, and store the result in the memory. (Support R/W register and memory)

**C** Example:

B0ADD

WK00,A

; WK00 = A + WK00



### **SBC** – Subtract with Carry

#### Operation:

| Mr  | nemonic | Description                                                     | С            | DC           | Z            |
|-----|---------|-----------------------------------------------------------------|--------------|--------------|--------------|
| SBC | A,M     | $A \leftarrow A - M - /C$ , if occur borrow, then C=0, else C=1 |              | $\checkmark$ | $\checkmark$ |
| SBC | M,A     | $M \leftarrow A - M - /C$ , if occur borrow, then C=0, else C=1 | $\checkmark$ | $\checkmark$ | $\checkmark$ |

#### <u>Remark</u>

- 1. The "M" is memory including system registers and user defined memory.
- 2. The "C" is carry flag.

#### Description:

The instruction is to get the difference of ACC, memory and the inverse of C flag. If the result is zero, the zero flag (Z) will be set as "1"; otherwise the zero flag (Z) is cleared. If the result occurs borrow signal, the carry flag (C) will be cleared; otherwise the carry flag (C) is as "1". If there is a borrow signal from low nibble of the result, the decimal carry flag (DC) will be cleared; otherwise the decimal carry flag (DC) is as "1".

- SBC A,M : Subtract the memory and the inverse of carry flag (C) from ACC buffer, and store the result in ACC buffer. (Support R/W,R register and memory)
- SBC M,A : Subtract the memory and the inverse of carry flag (C) from ACC buffer, and store the result in the memory. (Support R/W register and memory)
- Example: The SBC instruction is a useful instruction to do work data subtract. There is a word data separated to DAH and DAL. DAH is high byte and DAL is low byte. Subtract 0x0103 from 0x10FF and store the result to DAH and DAL.

| MOV<br>B0MOV | A,#03H<br>DAL,A  | ; Input the low byte (03H) of 0x0103 into DAL  |
|--------------|------------------|------------------------------------------------|
| MOV<br>B0MOV | A,#01H<br>DAH,A  | ; Input the high byte (01H) of 0x0103 into DAH |
| MOV<br>SUB   | A,#0FFH<br>DAL,A | ; Add low byte data. DAL = 0FCH                |
| MOV<br>SBC   | A,#10H<br>DAH,A  | ; Add high byte data. DAH = 0FH                |
|              | ,                | ; The sum is 0x0FFC.                           |



# SUB – Subtract only

#### Operation:

| Mne | emonic | Description                                                | С            | DC           | Ζ            |
|-----|--------|------------------------------------------------------------|--------------|--------------|--------------|
| SUB | A,M    | A $\leftarrow$ A - M, if occur borrow, then C=0, else C=1  | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SUB | M,A    | $M \leftarrow A - M$ , if occur borrow, then C=0, else C=1 | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| SUB | A,I    | $A \leftarrow A - I$ , if occur borrow, then C=0, else C=1 | $\checkmark$ | $\checkmark$ | $\checkmark$ |

#### **Remark**

- 1. The "M" is memory including system registers and user defined memory.
- 2. The "C" is carry flag.

#### Description:

The instruction is the subtract instruction. If the result is zero, the zero flag (Z) will be set as "1"; otherwise the zero flag (Z) is cleared. If the result occurs borrow signal, the carry flag (C) will be cleared; otherwise the carry flag (C) is as "1". If there is a borrow signal from low nibble of the result, the decimal carry flag (DC) will be cleared; otherwise the decimal carry flag (DC) is as "1".

- SUB A,M : Subtract the memory from ACC buffer, and store the result in ACC buffer. (Support R/W,R register and memory)
- SUB M,A : Subtract the memory from ACC buffer, and store the result in the memory. (Support R/W register and memory)
- **SUB** A,I : Subtract the immediate value from ACC buffer, and store the result in ACC buffer.
- Example:

| SUB | A,WK00 | ; A = A - WK00    |
|-----|--------|-------------------|
| SUB | WK00,A | ; WK00 = A - WK00 |
| SUB | A,#10  | ; A = A - 10      |



# DAA – Decimal-Adjust accumulator

#### Operation:

| Mnemonic | Description                              |  | DC | Ζ |
|----------|------------------------------------------|--|----|---|
| DAA      | Adjust ACC's data format from HEX to DEC |  | -  | - |

The instruction is adjust accumulator's data from Hexadecimal to Decimal. The operand of this instruction divided ACC into high and low nibble. Each nibble is done by adding 6 to the original value if the original value is greater than 9; other wise the original value remains unchanged. The result is stored in the accumulator.

#### For ACC.3~ACC.0 > 9

 $\begin{aligned} &\mathsf{ACC.3}\sim\mathsf{ACC.0}\ \leftarrow\ (\mathsf{ACC.3}\sim\mathsf{ACC.0})\texttt{+}6\\ &\mathsf{IF}\ (\mathsf{ACC.7}\sim\mathsf{ACC.4}\texttt{+}1) > 9\\ &\mathsf{Then}\ \mathsf{ACC.7}\sim\mathsf{ACC.4}\ \leftarrow\ (\mathsf{ACC.7}\sim\mathsf{ACC.4})\texttt{+}1\texttt{+}6\ (\ \mathsf{C}\ \mathsf{flag}\ \mathsf{will}\ \mathsf{set}\ \mathsf{to}\ 1)\\ &\mathsf{Else}\ \mathsf{ACC.7}\sim\mathsf{ACC.4}\ \leftarrow\ (\mathsf{ACC.7}\sim\mathsf{ACC.4})\texttt{+}1\end{aligned}$ 

#### For ACC.3~ACC.0 <=9

ACC.3~ACC.0  $\leftarrow$  ACC.3~ACC.0 IF ACC.7~ACC.4 > 9 Then ACC.7~ACC.4  $\leftarrow$  (ACC.7~ACC.4)+6 ( C flag will set to 1)

 $\mathsf{Else}\;\mathsf{ACC.7}{\sim}\mathsf{ACC.4}\;\leftarrow\;\mathsf{ACC.7}{\sim}\mathsf{ACC.4}$ 

#### Sector Example1:

| MOV | A,#055H | ; A = 55H |
|-----|---------|-----------|
| DAA |         | ; A = 55H |

#### Example2:

| MOV | A,#01FH | ; A = 1FH |
|-----|---------|-----------|
| DAA |         | ; A = 25H |



# **MUL – Multiply Unsigned**

#### Operation:

| Mnemonia | ; | Description                                                                                                |   | DC | Ζ            |
|----------|---|------------------------------------------------------------------------------------------------------------|---|----|--------------|
| MUL A,N  | M | $R, A \leftarrow A * M$ , The LB of product stored in Acc and HB stored in R register. ZF affected by Acc. | - | -  | $\checkmark$ |

#### <u>Remark</u>

#### The "M" is memory including system registers and user defined memory.

#### Description:

The instruction is multiples 2 8-bit unsigned binary value in ACC and memory. The high byte data of multiple results is stored in R register and the low byte is stored in ACC buffer. If the result is zero, the zero flag (Z) will be set as "1"; otherwise the zero flag (Z) is cleared.

#### **C** Example:

1

| MOV<br>B0MOV<br>MOV<br>MUL | A, #03H<br>DATA_1,A<br>A, #0FFH<br>A, DATA_1 | ; Input the data=03H into DATA_1<br>; DATA_1 in bank 0<br>; Input the data=0FFH into ACC<br>; Multiple Data_1 and A<br>; R = 02H, A=0FDH, Z_flag=0 |
|----------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| MOV<br>B0MOV<br>MOV<br>MUL | A, #00H<br>DATA_1,A<br>A, #0FFH<br>A, DATA_1 | ; Input the data=00H into DATA_1<br>; DATA_1 in bank 0<br>; Input the data=0FFH into ACC<br>; Multiple Data_1 and A<br>; R = 00H, A=00H, Z_flag=1  |



# AND – Logical AND

#### Operation:

| Mne | monic | Description              | С | DC | Ζ            |
|-----|-------|--------------------------|---|----|--------------|
| AND | A,M   | $A \leftarrow A$ and M   | - | -  |              |
| AND | M,A   | $M \leftarrow A$ and $M$ | - | -  | $\checkmark$ |
| AND | A,I   | $A \leftarrow A$ and I   | - | -  | $\checkmark$ |

#### **Remark**

- 1. The "M" is memory including system registers and user defined memory.
- 2. The "Z" is zero flag.

#### Description:

The instruction is the logically AND. The logical AND operation results in a "1" bit being stored whenever the corresponding bits in the two operands are both "1". If the result is zero, the zero flag (Z) will be set as "1"; otherwise the zero flag (Z) is cleared.

- > AND A,M : AND the memory and ACC buffer, and store the result in ACC buffer. (Support R/W,R register and memory)
- > AND M,A : AND the memory and ACC buffer, and store the result in the memory. (Support R/W register and memory)
- > AND A,I : AND the immediate value and ACC buffer, and store the result in ACC buffer.

#### **Contemporal Section** Example: Read Port 2 value and only keep the low-nibble data.

; Store the result in ACC buffer

|                  | B0MOV              | A,P2          |                                                                                                                         |
|------------------|--------------------|---------------|-------------------------------------------------------------------------------------------------------------------------|
| · or             | AND                | A,#00001111B  | ; To clear the high-nibble and compare the low-nibble data.<br>; If the P2 = 10101010B.<br>; The result is "00001010B". |
| ; or             | B0MOV              | A, #00001111B |                                                                                                                         |
|                  | AND                | A,P2          | ; To clear the high-nibble and compare the low-nibble data.<br>; If the P2 = 10101010B.<br>; The result is "00001010B". |
| ; Store the resu | ılt in P2 register |               |                                                                                                                         |
|                  | B0MOV              | A, #00001111B |                                                                                                                         |
|                  | AND                | P2,a          | ; To clear the high-nibble and compare the low-nibble data.<br>; If the P2 = 10101010B.<br>; The result is "00001010B". |



# **OR – Logical OR**

#### Operation:

| Mı | nemonic | Description                    | С | DC | Ζ            |
|----|---------|--------------------------------|---|----|--------------|
| OR | A,M     | $A \leftarrow A \text{ or } M$ | - | -  |              |
| OR | M,A     | $M \leftarrow A \text{ or } M$ | - | -  | $\checkmark$ |
| OR | A,I     | A ← A or I                     | - | -  |              |

#### **Remark**

- 1. The "M" is memory including system registers and user defined memory.
- 2. The "Z" is zero flag.

#### Description:

The instruction is the logically OR. The logical OR operation results in a "1" bit being stored whenever one of the corresponding bits in the two operands is "1". If the result is zero, the zero flag (Z) will be set as "1"; otherwise the zero flag (Z) is cleared.

- > OR A,M : OR the memory and ACC buffer, and store the result in ACC buffer. (Support R/W,R register and memory)
- > OR M,A : OR the memory and ACC buffer, and store the result in the memory. (Support R/W register and memory)
- > OR A,I : OR the immediate value and ACC buffer, and store the result in ACC buffer.
- **Contemporal Section** Example: Read Port 2 value and OR with 0FH.

; Store the result in ACC buffer

|                    | B0MOV            | A,P2    |                                                                                                                                       |
|--------------------|------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------|
|                    | OR               | A,#0FH  | ; To keep the high-nibble and set all of the low-nibble data<br>; as "1".<br>; If the P2 = 10101010B.<br>; The result is "10101111B". |
| ; or               | B0MOV            | A, #0FH |                                                                                                                                       |
|                    | OR               | A,P2    | ; To keep the high-nibble and set all of the low-nibble data<br>; as "1".<br>; If the P2 = 10101010B.<br>; The result is "10101111B". |
| ; Store the result | t in P2 register |         |                                                                                                                                       |
|                    | B0MOV            | A, #0FH |                                                                                                                                       |
|                    | OR               | P2,a    | ; To keep the high-nibble and set all of the low-nibble data<br>; as "1".<br>; If the P2 = 10101010B.<br>; The result is "10101111B". |



# **XOR – Logical XOR**

#### Operation:

| Mnei | monic | Description                     | С | DC | Z            |
|------|-------|---------------------------------|---|----|--------------|
| XOR  | A,M   | $A \leftarrow A \text{ xor } M$ | - | -  |              |
| XOR  | M,A   | $M \leftarrow A \text{ xor } M$ | 1 | -  | $\checkmark$ |
| XOR  | A,I   | $A \leftarrow A \text{ xor } I$ | - | -  | $\checkmark$ |

#### Remark

- 1. The "M" is memory including system registers and user defined memory.
- 2. The "Z" is zero flag.

#### Description:

The instruction is the logically XOR. The logical XOR operation results in a "1" bit being stored whenever the corresponding bits in the two operands are the same. If the result is zero, the zero flag (Z) will be set as "1"; otherwise the zero flag (Z) is cleared.

- > XOR A,M : OR the memory and ACC buffer, and store the result in ACC buffer. (Support R/W,R register and memory)
- > XOR M,A : OR the memory and ACC buffer, and store the result in the memory. (Support R/W register and memory)
- **XOR** A,I : OR the immediate value and ACC buffer, and store the result in ACC buffer.

#### **C** Example: Read Port 2 value and invert it.

; Store the result in ACC buffer

|                                   | B0MOV | A,P2     |                                                                                      |  |
|-----------------------------------|-------|----------|--------------------------------------------------------------------------------------|--|
| . or                              | OR    | A,#0FFH  | ; To invert P2 register.<br>; If the P2 = 10101010B.<br>; The result is "01010101B". |  |
| ; or                              | B0MOV | A, #0FFH |                                                                                      |  |
|                                   | OR    | A,P2     | ; To invert P2 register.<br>; If the P2 = 10101010B.<br>; The result is "01010101B". |  |
| ; Store the result in P2 register |       |          |                                                                                      |  |

| B0MOV | A, #0FFH |                                                                                      |
|-------|----------|--------------------------------------------------------------------------------------|
| OR    | P2,a     | ; To invert P2 register.<br>; If the P2 = 10101010B.<br>; The result is "01010101B". |

# **PROCESS INSTRUCTION**



# **SWAP & SWAPM – Memory high/low Nibble Exchange**

#### Operation:

| Mnem  | Mnemonic Description |                                   | С | DC | Ζ |
|-------|----------------------|-----------------------------------|---|----|---|
| SWAP  | М                    | A (b3~b0, b7~b4) ←M(b7~b4, b3~b0) | - | -  | - |
| SWAPM | М                    | M(b3~b0, b7~b4) ← M(b7~b4, b3~b0) | - | -  | - |

#### <u>Remark</u>

The "M" is memory including system registers and user defined memory.

#### Description:

The instruction's operation is to exchange the high/low byte data of a memory. The operation doesn't affect PFLAG.

- SWAP M : Exchange the high/low nibble data and store the result in ACC buffer. (Support R/W,R register and memory)
- SWAPM M : Exchange the high/low nibble data and store the result in the memory. (Support R/W register and memory)
- **Content** Example: Read P2 value, exchange the high/low nibble data and store in the WK00.

| SWAP  | P2     | ; SWAP P2 register and the result stored in ACC buffer. |
|-------|--------|---------------------------------------------------------|
| B0MOV | WK00,A | ; Save the result in ACC buffer.                        |

#### **C** Example: Read P2 value, exchange the high/low nibble data and reload the new value into P2 register.

SWAPM P2 ; SWAP P2 register and the result stored in P2 register.



# **RLC & RLCM – Memory Left Rotation**

#### Operation:

| Mne  | monic | Description          | С            | DC | Ζ |
|------|-------|----------------------|--------------|----|---|
| RLC  | М     | $A \leftarrow RLC M$ |              | -  | - |
| RLCM | М     | $M \leftarrow RLC M$ | $\checkmark$ | _  | - |

#### **Remark**

- 1. The "M" is memory including system registers and user defined memory.
- 2. The "C" is carry flag.

#### Description:

The instruction rotates the memory from right to left one bit. After RLC /RLCM executed, 8-bit rotate one bit. The LSB is replaced by C flag and the MSB value is moved to C flag position.



- RLC M : Rotate the memory to left and store the result in ACC buffer. (Support R/W,R register and memory)
- RLCM M : Rotate the memory to left and store the result in the memory. (Support R/W register and memory)
- **C** Example: WK00 = 10101010B, change WK00 to 01010101B and store the result in ACC buffer.

| BOBSET | FC   | ; Set the C flag.                                               |
|--------|------|-----------------------------------------------------------------|
| RLC    | WK00 | ; The ACC buffer = 01010101B<br>; The C flag = 1 (MSB of WK00). |

#### Example: WK00 = 11110011B, change WK00 to 11001100B and store the result in WK00.

| B0BCLR<br>RLCM | FC<br>WK00 | ; Clear C flag.<br>; RLCM one time<br>; The WK00 = 11100110B<br>; The C flag = 1 (MSB of WK00). |
|----------------|------------|-------------------------------------------------------------------------------------------------|
| B0BCLR<br>RLCM | FC<br>WK00 | ; Clear C flag.<br>; RLCM two time<br>; The WK00 = 11001100B<br>; The C flag = 1 (MSB of WK00). |



# **RRC & RRCM – Memory Right Rotation**

#### Operation:

| Mnen | nonic | Description          | С            | DC | Ζ |
|------|-------|----------------------|--------------|----|---|
| RRC  | М     | $A \leftarrow RRC M$ | $\checkmark$ | -  | - |
| RRCM | М     | $M \leftarrow RRC M$ | $\checkmark$ | -  | - |

#### **Remark**

- 1. The "M" is memory including system registers and user defined memory.
- 2. The "C" is carry flag.

#### Description:

The instruction rotates the memory from left to right one bit. After RRC /RRCM executed, 8-bit rotate one bit. The MSB is replaced by C flag and the LSB value is moved to C flag position.



- RRC M : Rotate the memory to right and store the result in ACC buffer. (Support R/W,R register and memory)
- RRCM M : Rotate the memory to right and store the result in the memory. (Support R/W register and memory)
- **C** Example: WK00 = 10101010B, change WK00 to 01010101B and store the result in ACC buffer.

| B0BCLR | FC   | ; Clear C flag.                                                 |
|--------|------|-----------------------------------------------------------------|
| RRC    | WK00 | ; The ACC buffer = 01010101B<br>; The C flag = 0 (LSB of WK00). |

#### **C** Example: WK00 = 11110011B, change WK00 to 00111100B and store the result in WK00.

| B0BCLR<br>RRCM | FC<br>WK00 | ; Clear C flag.<br>; RRCM one time<br>; The WK00 = 01111001B<br>; The C flag = 1 (LSB of WK00). |
|----------------|------------|-------------------------------------------------------------------------------------------------|
| B0BCLR<br>RRCM | FC<br>WK00 | ; Clear C flag.<br>; RRCM two time<br>; The WK00 = 00111100B<br>; The C flag = 1 (LSB of WK00). |



# CLR – Clear

#### Operation:

| Mne | Mnemonic Description |                  | С | DC | Ζ |
|-----|----------------------|------------------|---|----|---|
| CLR | М                    | $M \leftarrow 0$ | - | -  | - |

#### <u>Remark</u>

The "M" is memory including system registers and user defined memory.

#### Description:

The instruction is to clear memory data. The operation is read the memory data, clear and writer back. The operation doesn't affect PFLAG.

> CLR M : Clear memory value. (Support R/W register and memory)

#### **Clear system registers.**

| CLR | Y  | ; Clear Y register                                 |
|-----|----|----------------------------------------------------|
| CLR | P0 | ; Error. "CLR" doesn't support read only register. |



# BCLR & B0BCLR – Bit Clear

#### Operation:

| Mnem          | Mnemonic Description |                    | С | DC | Ζ |
|---------------|----------------------|--------------------|---|----|---|
| BCLR          | M.b                  | $M.b \leftarrow 0$ | - | -  | - |
| <b>B0BCLR</b> | M.b                  | M(bank 0).b ← 0    | - | -  | - |

#### **Remark**

The "M" is memory including system registers and user defined memory.

#### Description:

The instruction is to clear a bit of memory. The operation doesn't affect PFLAG.

- > BCLR M.b: Clear the bit called "b" of the memory. (Support R/W register and memory)
- B0BCLR M.b: Clear the bit called "b" of the memory. The memory must be in BANK 0. (Support R/W register and memory)
- **C** Example: Clear carry flag (C).

B0BCLR FC

**Clear the bit 6 of WK00. WK00 is user defined.** 

BCLR WK00.6 ; Clear the bit 6 of WK00.



# **BSET & B0BSET – Bit Set**

#### Operation:

| Mnem   | Inemonic Description |                 | С | DC | Z |
|--------|----------------------|-----------------|---|----|---|
| BSET   | M.b                  | M.b ← 1         | - | -  | - |
| BOBSET | M.b                  | M(bank 0).b ← 1 | - | -  | - |

#### <u>Remark</u>

The "M" is memory including system registers and user defined memory.

#### Description:

The instruction is to set a bit of memory. The operation doesn't affect PFLAG.

- > BSET M.b: Set the bit called "b" of the memory. (Support R/W register and memory)
- BOBSET M.b: Set the bit called "b" of the memory. The memory must be in BANK 0. (Support R/W register and memory)
- **C** Example: Set carry flag (C).

B0BSET FC

**C** Example: Set the bit 6 of WK00. WK00 is user defined.

BSET WK00.6 ; Set the bit 6 of WK00.



# **BRANCH INSTRUCTION**

# **CMPRS – Compare**

#### **Operation:**

| Mnen  | nonic | Description                                                    |  | DC | Ζ            |
|-------|-------|----------------------------------------------------------------|--|----|--------------|
| CMPRS | A,I   | $ZF,C \leftarrow A - I$ , If A = I, then skip next instruction |  | -  | $\checkmark$ |
| CMPRS | A,M   | $ZF,C \leftarrow A - M$ , If A = M, then skip next instruction |  | -  |              |

#### **Remark**

- 1. The "M" is memory including system registers and user defined memory.
- 2. The "C" is carry flag.
- 3. The "Z" is zero flag.

#### Description:

The instruction compares ACC buffer with the memory or an immediate value. If the result is equal, the program counter will skip next instruction. "CMPRS" is to subtract the memory or an immediate value from ACC buffer. The zero flag and carry flag will be changed by the result. If the result is zero, the zero flag (Z) will be set as "1"; otherwise the zero flag (Z) is cleared. If the result occurs borrow signal, the carry flag (C) will be cleared; otherwise the carry flag (C) is as "1". The decimal carry flag (DC) won't be affect and keeps zero.

> CMPRS A,I: Compare the ACC buffer with an immediate value.

- **CMPRS** A,M: Compare the ACC buffer with the memory. (Support R/W,R register and memory)
- **Compare ACC buffer with 55H. If ACC is equal to 55H, jump to SUB1, or jump to SUB2.**

| CMPRS | A,#055H |                   |
|-------|---------|-------------------|
| JMP   | SUB2    | ; ACC is not 55H. |
| JMP   | SUB1    | ; ACC = 55H       |

Example: Compare the memory called WK00 with 55H. If the memory is equal to 55H, jump to SUB1, or jump to SUB2.

| B0MOV               | A,#055H                |                                    |
|---------------------|------------------------|------------------------------------|
| CMPRS<br>JMP<br>JMP | A,WK00<br>SUB2<br>SUB1 | ; WK00 is not 55H.<br>; WK00 = 55H |

~



# **INCS & INCMS – Increment and Skip on Zero**

#### Operation:

| Mnemonic |   | Description                                                    | С | DC | Ζ |
|----------|---|----------------------------------------------------------------|---|----|---|
| INCS     | М | $A \leftarrow M + 1$ , If $A = 0$ , then skip next instruction | - | -  | - |
| INCMS    | М | $M \leftarrow M + 1$ , If M = 0, then skip next instruction    | - | _  | - |

#### **Remark**

#### The "M" is memory including system registers and user defined memory.

#### Description:

The instruction increases the ACC buffer or the memory by one. If the result is zero, the program counter will skip the next instruction. The operation doesn't affect PFLAG.

- > INCS M: Increase the memory value by one and store the result in ACC buffer. (Support R/W register and memory)
- > INCMS M: Increase the memory value by one and store the result in the memory. (Support R/W register and memory)
- **Content** Example: Increase WK00 until the overflow occurring.

|           | MOV   | A, #0xFD |                     |
|-----------|-------|----------|---------------------|
|           | MOV   | WK00, A  |                     |
| INCSTEST: |       |          |                     |
|           | INCS  | WK00     |                     |
|           | NOP   |          |                     |
|           | MOV   | WK00, A  |                     |
|           | CMPRS | A, #0x00 |                     |
|           | JMP   | INCSTEST | ; WK00 is not zero. |
|           |       |          |                     |

Example: Increase Y and Z flags. The Y is high byte and the Z is low byte. Y will increase by one when the Z is overflow.

| INCMS<br>JMP EXIT | Z | ; Z is not zero. |
|-------------------|---|------------------|
| INCMS<br>NOP      | Y | ; Z = 0, Y = Y+1 |

EXIT:



# **DECS & DECMS – Decrement and Skip on Zero**

#### Operation:

| Mnemonic |   | Description                                                    | С | DC | Ζ |
|----------|---|----------------------------------------------------------------|---|----|---|
| DECS     | М | – M - 1, If A = 0, then skip next instruction                  |   | -  | - |
| DECMS    | М | $M \leftarrow M - 1$ , If $M = 0$ , then skip next instruction | - | _  | - |

#### <u>Remark</u>

#### The "M" is memory including system registers and user defined memory.

#### Description:

The instruction decreases the ACC buffer or the memory by one. If the result is zero, the program counter will skip the next instruction. The operation doesn't affect PFLAG.

- > DECS M: Decrease the memory value by one and store the result in ACC buffer. (Support R/W register and memory)
- > DECMS M: Decrease the memory value by one and store the result in the memory. (Support R/W register and memory)
- **Content** Example: Decrease WK00 until equal to zero.
- DECSTEST:

| DECMS | WK00     |             |
|-------|----------|-------------|
| JMP   | DECSTEST | ; Not zero. |
|       |          | ; WK00 = 0. |



# BTS0 & B0BTS0 – Bit Test 0

#### Operation:

| Mnemonic Description |     | С                                              | DC | Ζ |   |
|----------------------|-----|------------------------------------------------|----|---|---|
| BTS0                 | M.b | If M.b = 0, then skip next instruction         | -  | - | - |
| B0BTS0               | M.b | If M(bank 0).b = 0, then skip next instruction | -  | - | - |

#### **Remark**

#### The "M" is memory including system registers and user defined memory.

#### Description:

The instruction compares the bit of memory with 0. If the result is 0, the program counter will skip the next instruction. The operation doesn't affect PFLAG.

- **BTS0** M.b: Compare the bit of memory with 0. (Support R/W register and memory)
- B0BTS0 M.b: Compare the bit of memory with 0. The memory must be in Bank 0. (Support R/W register and memory)
- **C** Example: Check the carry flag. If C = 0, jump to SUB1, or jump to SUB2.

| B0BTS0 | FC   |         |
|--------|------|---------|
| JMP    | SUB2 | ; C = 1 |
| JMP    | SUB1 | ; C = 0 |

#### **C** Example: Check the bit 3 of WK00. If WK00.3 = 0, increase WK00 by one, or exit.

| B0BTS0 | WK00.3 | ; Check bit 3 of WK00 |
|--------|--------|-----------------------|
| JMP    | EXIT   | ; WK00.3=1            |
| INCMS  | WK00   | ; WK00.3=0            |
| NOP    |        | ;                     |

EXIT:



# BTS1 & B0BTS1 – Bit Test 1

#### Operation:

| Mnemonic |     | Description                                    | С | DC | Z |
|----------|-----|------------------------------------------------|---|----|---|
| BTS1     | M.b | If M.b = 1, then skip next instruction         | - | -  | - |
| B0BTS1   | M.b | If M(bank 0).b = 1, then skip next instruction | - | -  | - |

#### **Remark**

#### The "M" is memory including system registers and user defined memory.

#### Description:

The instruction compares the bit of memory with 1. If the result is 1, the program counter will skip the next instruction. The operation doesn't affect PFLAG.

- **BTS1** M.b: Compare the bit of memory with 1. (Support R/W register and memory)
- **BOBTS1** M.b: Compare the bit of memory with 1. The memory must be in Bank 0. (Support R/W register and memory)
- **C** Example: Check the carry flag. If C = 1, jump to SUB1, or jump to SUB2.

| B0BTS1 | FC   |         |
|--------|------|---------|
| JMP    | SUB2 | ; C = 0 |
| JMP    | SUB1 | ; C = 1 |

#### **C** Example: Check the bit 3 of WK00. If WK00.3 = 1, increase WK00 by one, or exit.

| B0BTS1 | WK00.3 | ; Check bit 3 of WK00 |
|--------|--------|-----------------------|
| JMP    | EXIT   | ; WK00.3=0            |
| INCMS  | WK00   | ; WK00.3=1            |
| NOP    |        |                       |

EXIT:



## JMP – Jump

#### **Operation:**

JM

| Mr | nemonic | Description                         | С | DC | Ζ |
|----|---------|-------------------------------------|---|----|---|
| ΛP | d       | PC15/14 ← RomPages1/0, PC13~PC0 ← d | - | -  | - |

#### <u>Remark</u>

The "d" is the label name of the destination address.

#### Description:

"JMP" is a unconditional branch to indicate address by replacing the contents of the program counter (PC) with the destination address. The destination address can be anywhere in the program memory (ROM). The operation doesn't affect PFLAG.

> JMP d: Program jumps to "d" address.

#### **C** Example: Jump to SUB1.

| JMP | SUB1 |
|-----|------|
|     |      |

SUB1:

Example: Using program counter and JMP instruction can be a jump table function. Program can execute different subroutines by the program counter.

| MOV<br>AND<br>MOV                                             | A,#00000111B<br>WK00,A                                                |                                                                                              |
|---------------------------------------------------------------|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| BOADD<br>JMP<br>JMP<br>JMP<br>JMP<br>JMP<br>JMP<br>JMP<br>JMP | PCL,A<br>SUB0<br>SUB1<br>SUB2<br>SUB3<br>SUB4<br>SUB5<br>SUB6<br>SUB7 | ; WK00=0<br>; WK00=1<br>; WK00=2<br>; WK00=3<br>; WK00=4<br>; WK00=5<br>; WK00=6<br>; WK00=7 |



# **CALL – Call Procedure**

#### Operation:

| Mnemonia | ; | Description                                           | С | DC | Ζ |
|----------|---|-------------------------------------------------------|---|----|---|
| CALL d   |   | Stack ← PC15~PC0, PC15/14 ← RomPages1/0, PC13~PC0 ← d | - | -  | - |

#### <u>Remark</u>

SUB1:

The "d" is the label name of the destination address.

#### Description:

"CALL" calls a subroutine in the program memory (ROM). When the instruction is executing, the program counter is stored in stack buffer and the stack point decrease by one. The new address of the subroutine label is loaded in program counter and executed. The subroutine can begin anywhere in all program memory (ROM). The operation doesn't affect PFLAG.

- > CALL d: Program jumps to "d" address.
- Example: The SUB1 address is 0x0213. The CALL command address is 0x0030. The stack point is 0FH. After executing CALL, the stack buffer is 0x0031,stack point is 0EH (decrease by one) and the program counter is 0x0213.

| ORG<br>CALL | 0X0030<br>SUB1 | ; Address = 0x0030<br>; Address = 0x0031. Program return address. |
|-------------|----------------|-------------------------------------------------------------------|
| ORG         | 0X0213         | ; Address = 0x0213                                                |
| RET         |                |                                                                   |



# **MISCELLANEOUS INSTRUCTION**

## **RET – Return from Call Procedure**

#### Operation:

| Mnemonic | Description           | С | DC | Ζ |
|----------|-----------------------|---|----|---|
| RET      | $PC \leftarrow Stack$ | - | -  | - |

#### Description:

"RET" returns to the last ROM address after finishing the call subroutine. When the instruction is executing, the program counter is re-loaded from stack buffer and the stack point increase by one. The program returns to last stack and continues to execute. The subroutine can end anywhere in all program memory (ROM). The operation doesn't affect PFLAG.

- > RET: Return to the last stack level.
- Example: The SUB1 address is 0x0213. The CALL command address is 0x0030. The stack point is 0FH. After executing RET, the stack buffer is load to program counter, stack point is 0FH (increase by one) and the program continues running from 0x0031.

|       | ORG<br>CALL | 0X0030<br>SUB1 | ; Address = 0x0030.<br>; Address = 0x0031. Program return address. |
|-------|-------------|----------------|--------------------------------------------------------------------|
| SUB1: | ORG         | 0X0213         | ; Address = 0x0213                                                 |
|       | RET         |                | ; Return to 0x0031                                                 |



# **RETI – Return from Interrupt**

#### Operation:

| Mnemonic | Description                                            | С | DC | Ζ |
|----------|--------------------------------------------------------|---|----|---|
| RETI     | $PC \leftarrow Stack$ , and to enable global interrupt | - | -  | - |

#### Description:

When any interrupt occurs, the program counter content is stored into stack buffer and the stack point increases by one. The global interrupt flag disables, the program jumps to interrupt vector (ORG 8) and executes the interrupt service routine. The RETI is the end of interrupt service routine. It loads stack buffer content to program counter and enable the global interrupt flag. And program exit the interrupt service routine. The operation doesn't affect PFLAG.

#### > RETI: Return from interrupt and enable global interrupt flag.

#### **C** Example:

| ORG<br>B0XCH<br>B0MOV<br>B0MOV  | 8<br>A,ACCBUF<br>A,PFLAG<br>PFLAGBUF,A | ; Interrupt vector.               |
|---------------------------------|----------------------------------------|-----------------------------------|
| •<br>•                          |                                        |                                   |
| BOMOV<br>BOMOV<br>BOXCH<br>RETI | A,PFLAGBUF<br>PFLAG,A<br>A,ACCBUF      | ; Exit interrupt service routine. |

#### MAIN:

| ; An interrupt occurs. Program jumps to interrupt vector. |
|-----------------------------------------------------------|
| ; Return from interrupt vector.                           |
|                                                           |



# **NOP – No Operation**

#### Operation:

| Mnemonic | Description  | С | DC | Ζ |
|----------|--------------|---|----|---|
| NOP      | No operation | - | -  | - |

#### Description:

"NOP" is no operation. It is typically used from timing delay. One "NOP" instruction is one instruction cycle (Fcpu). The operation doesn't affect PFLAG.

#### > NOP : No operation.

#### **C** Example: A 1024 instruction cycles delay time. If the oscillator is 4MHz, the delay is 1024u seconds.

| DLY1024U:    | MOV                  | A,#0                        | ; Clear ACC buffer                                                                                                       |
|--------------|----------------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------|
| DLY1024U_10: | ADD<br>B0BTS1<br>JMP | A,#01H<br>FZ<br>DLY1024U_10 | ; Increase ACC by one<br>; Check ACC overflow.<br>; No overflow, continues to increase ACC.<br>; Exit the delay routine. |
|              |                      |                             |                                                                                                                          |



# PUSH – Save Some System Registers for SN8P1XXX and SN8P270XA

#### Operation:

| Mnemonic | Description                                        | С | DC | Ζ |
|----------|----------------------------------------------------|---|----|---|
| PUSH     | To push working registers (080H~087H) into buffers | - | -  | - |

#### Description:

There are two kinds of PUSH instruction. In SN8P1XXX series and SN8P270XA (SN8P2704A, SN8P2705A, SN8P2706A, SN8P2707A and SN8P2708A), the push instruction save some system registers (80H ~ 87H) into buffers. Please refer to datasheet for detailed information.

#### > PUSH: Save some system registers (80H ~ 87H) into buffers (doesn't occupy stack buffer).

#### **C** Example: Save 80H ~ 87H system registers after enter interrupt service routine

INT\_SERVICE:

|           | B0XCH<br>PUSH | A, ACCBUF | ; B0XCH doesn't change C, Z flag<br>; Save 80H ~ 87H system register |
|-----------|---------------|-----------|----------------------------------------------------------------------|
|           |               |           |                                                                      |
| EXIT_INT: | POP<br>B0XCH  | A, ACCBUF | ; Pop 80H ~ 87H system register<br>; Restore ACC value.              |
|           | RETI          |           | ; Exit interrupt vector                                              |



# PUSH – Save A and PFLAG for SN8P260X

#### Operation:

| Mnemonic | Description                                               | С | DC | Ζ |
|----------|-----------------------------------------------------------|---|----|---|
| PUSH     | To push ACC and PFLAG (except NT0, NPD bit) into buffers. | - | -  | - |

#### Description:

There are two kinds of PUSH instruction. In SN8P260X series (SN8P2602A, SN8P2604, SN8P2606 and SN8P2608), the push instruction save Accumulator and PFLAG register (except NT0, NPD bits) into buffers. Please refer to datasheet for detailed information.

#### > PUSH: Save Accumulator and PFLAG (except NT0, NPD bits) into buffers (doesn't occupy stack buffer).

#### **C** Example: Save A and PFLAH after enter interrupt service routine

| INT_SERVICE: | ORG<br>JMP | 8<br>INT_SERVICE | ; Interrupt vector                 |
|--------------|------------|------------------|------------------------------------|
|              | PUSH       |                  | ; Save ACC and PFLAG to buffers.   |
|              |            |                  |                                    |
| EXIT_INT:    | POP        |                  | ; Load ACC and PFLAG from buffers. |
|              | RETI       |                  | ; Exit interrupt vector            |



# POP – Restore Some System Registers for SN8P1XXX and SN8P270XA

#### Operation:

| Mnemonic | Description                                       | С            | DC           | Ζ            |
|----------|---------------------------------------------------|--------------|--------------|--------------|
| POP      | To pop working registers (080H~087H) from buffers | $\checkmark$ | $\checkmark$ | $\checkmark$ |

#### Description:

There are two kinds of POP instruction. In SN8P1XXX series and SN8P270XA (SN8P2704A, SN8P2705A, SN8P2706A, SN8P2707A and SN8P2708A), the pop instruction restores some system registers ( $80H \sim 87H$ ) from buffers. Please refer to datasheet for detailed information.

#### > POP: Restore some system registers (80H ~ 87H) from buffers (not from stack buffer).

#### **C** Example: Restore 80H ~ 87H system registers before exit interrupt service routine

INT\_SERVICE:

|           | B0XCH<br>PUSH | A, ACCBUF | ; B0XCH doesn't change C, Z flag<br>; Save 80H ~ 87H system registers |
|-----------|---------------|-----------|-----------------------------------------------------------------------|
|           | •             | •         |                                                                       |
| EXIT_INT: | POP<br>B0XCH  | A, ACCBUF | ; Restore 80H ~ 87H system registers<br>; Restore ACC value.          |
|           | RETI          |           | ; Exit interrupt vector                                               |



# **POP – Restore A and PFLAG for SN8P260X**

#### Operation:

| Mnemonic | Description                                              | С            | DC           | Ζ            |
|----------|----------------------------------------------------------|--------------|--------------|--------------|
| POP      | To pop ACC and PFLAG (except NT0, NPD bit) from buffers. | $\checkmark$ | $\checkmark$ | $\checkmark$ |

#### Description:

There are two kinds of POP instruction. In SN8P260X series (SN8P2602A, SN8P2604, SN8P2606 and SN8P2608), the pop instruction restores Accumulator and PFLAG register (except NT0, NPD bits) from buffers. Please refer to datasheet for detailed information.

#### > POP: Restore Accumulator and PFLAG (except NT0, NPD bits) from buffers (not from stack buffer).

#### **Content** Example: Restore A and PFLAH before exit interrupt service routine

| INT_SERVICE: | ORG<br>JMP | 8<br>INT_SERVICE | ; Interrupt vector                 |
|--------------|------------|------------------|------------------------------------|
|              | PUSH       |                  | ; Save ACC and PFLAG to buffers.   |
|              |            |                  |                                    |
| EXIT_INT:    | POP        |                  | ; Load ACC and PFLAG from buffers. |
|              | RETI       |                  | ; Exit interrupt vector            |



SONIX reserves the right to make change without further notice to any products herein to improve reliability, function or design. SONIX does not assume any liability arising out of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights nor the rights of others. SONIX products are not designed, intended, or authorized for us as components in systems intended, for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the SONIX products for any such unintended or unauthorized application. Buyer shall indemnify and hold SONIX and its officers , employees, subsidiaries, affiliates and distributors harmless against all claims, cost, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use even if such claim alleges that SONIX was negligent regarding the design or manufacture of the part.

#### Main Office:

Address: 9F, NO. 8, Hsien Cheng 5th St, Chupei City, Hsinchu, Taiwan R.O.C. Tel: 886-3-551 0520 Fax: 886-3-551 0523 **Taipei Office:** Address: 15F-2, NO. 171, Song Ted Road, Taipei, Taiwan R.O.C.

Tel: 886-2-2759 1980 Fax: 886-2-2759 8180

#### Hong Kong Office:

Address: Flat 3 9/F Energy Plaza 92 Granville Road, Tsimshatsui East Kowloon. Tel: 852-2723 8086 Fax: 852-2723 9179

Technical Support by Email:

Sn8fae@sonix.com.tw