## **Instruction Set Summary** 5.3

|   |          |         |                                              | Status Bits |   |   |   |
|---|----------|---------|----------------------------------------------|-------------|---|---|---|
|   |          |         |                                              | V           | N | Z | С |
| * | ADC(.B)  | dst     | $dst + C \rightarrow dst$                    | X           | X | Х | X |
|   | ADD(.B)  | src,dst | $src + dst \rightarrow dst$                  | Χ           | X | Χ | X |
|   | ADDC(.B) | src,dst | $src + dst + C \rightarrow dst$              | Χ           | X | Χ | X |
|   | AND(.B)  | src,dst | $src.and.dst \rightarrow dst$                | 0           | Х | Х | X |
|   | BIC(.B)  | src,dst | .not.src .and. $dst \rightarrow dst$         | -           | - | - | - |
|   | BIS(.B)  | src,dst | $src.or. dst \rightarrow dst$                | -           | - | - | - |
|   | BIT(.B)  | src,dst | src .and. dst                                | 0           | X | Χ | X |
| * | BR       | dst     | Branch to                                    | -           | - | - | - |
|   | CALL     | dst     | $PC+2 \rightarrow stack, dst \rightarrow PC$ | -           | - | - | - |
| * | CLR(.B)  | dst     | Clear destination                            | -           | - | - | - |
| * | CLRC     |         | Clear carry bit                              | -           | - | - | 0 |
| * | CLRN     |         | Clear negative bit                           | -           | 0 | - | - |
| * | CLRZ     |         | Clear zero bit                               | -           | - | 0 | - |
|   | CMP(.B)  | src,dst | dst - src                                    | Χ           | X | Χ | Χ |
| * | DADC(.B) | dst     | $dst + C \rightarrow dst (decimal)$          | Χ           | X | Х | Χ |
|   | DADD(.B) | src,dst | $src + dst + C \rightarrow dst (decimal)$    | Χ           | X | Χ | X |
| * | DEC(.B)  | dst     | dst - 1 → dst                                | Χ           | Χ | Χ | Χ |
| * | DECD(.B) | dst     | $dst - 2 \rightarrow dst$                    | Χ           | Χ | Χ | Χ |
| * | DINT     |         | Disable interrupt                            | -           | - | - | - |
| * | EINT     |         | Enable interrupt                             | -           | - | - | - |
| * | INC(.B)  | dst     | Increment destination, dst +1 → dst          | Χ           | Χ | Χ | Χ |
| * | INCD(.B) | dst     | Double-Increment destination, dst+2→dst      | Χ           | X | Χ | Χ |
| * | INV(.B)  | dst     | Invert destination                           | Χ           | Χ | Χ | Χ |
|   | JC/JHS   | Label   | Jump to Label if Carry-bit is set            | -           | - | - | - |
|   | JEQ/JZ   | Label   | Jump to Label if Zero-bit is set             | -           | - | - | - |
|   | JGE      | Label   | Jump to Label if $(N .XOR. V) = 0$           | -           | - | - | - |
|   | JL       | Label   | Jump to Label if (N .XOR. V) = 1             | -           | - | - | - |
|   | JMP      | Label   | Jump to Label unconditionally                | -           | - | - | - |
|   | JN       | Label   | Jump to Label if Negative-bit is set         | -           | - | - | - |

Legend:

- 0 Status bit always cleared
- Status bit always set 1
- Status bit cleared or set on results Х \*
- Status bit not affected
- **Emulated Instructions**

Table 5.3: MPS430 Family Instruction Set Summary

|   |          |         |                                                 | Status Bits |   |   |   |
|---|----------|---------|-------------------------------------------------|-------------|---|---|---|
|   |          |         |                                                 | V           | N | Z | С |
|   | JNC/JLO  | Label   | Jump to Label if Carry-bit is reset             | -           | - | - | - |
|   | JNE/JNZ  | Label   | Jump to Label if Zero-bit is reset              | -           | - | - | - |
|   | MOV(.B)  | src,dst | $src \rightarrow dst$                           | -           | - | - | - |
| * | NOP      |         | No operation                                    | -           | - | - | - |
| * | POP(.B)  | dst     | Item from stack, SP+2 → SP                      | -           | - | - | - |
|   | PUSH(.B) | src     | SP - 2 $\rightarrow$ SP, src $\rightarrow$ @SP  | -           | - | - | - |
|   | RETI     |         | Return from interrupt                           | Х           | Х | Χ | Χ |
|   |          |         | $TOS \rightarrow SR, SP + 2 \rightarrow SP$     |             |   |   |   |
|   |          |         | $TOS \rightarrow PC$ , $SP + 2 \rightarrow SZP$ |             |   |   |   |
| * | RET      |         | Return from subroutine                          | -           | - | - | - |
|   |          |         | $TOS \rightarrow PC$ , $SP + 2 \rightarrow SP$  |             |   |   |   |
| * | RLA(.B)  | dst     | Rotate left arithmetically                      | Χ           | X | Χ | Χ |
| * | RLC(.B)  | dst     | Rotate left through carry                       | Χ           | X | Χ | Χ |
|   | RRA(.B)  | dst     | $MSB \to MSB \ LSB \to C$                       | 0           | X | Χ | Χ |
|   | RRC(.B)  | dst     | $C \to MSB \LSB \to C$                          | Χ           | Χ | Χ | Χ |
| * | SBC(.B)  | dst     | Subtract carry from destination                 | Χ           | Х | Χ | Χ |
| * | SETC     |         | Set carry bit                                   | -           | - | - | 1 |
| * | SETN     |         | Set negative bit                                | -           | 1 | - | - |
| * | SETZ     |         | Set zero bit                                    | -           | - | 1 | - |
|   | SUB(.B)  | src,dst | $dst + .not.src + 1 \rightarrow dst$            | Х           | X | Χ | Χ |
|   | SUBC(.B) | src,dst | $dst + .not.src + C \rightarrow dst$            | Χ           | X | Χ | Χ |
|   | SWPB     | dst     | swap bytes                                      | -           | - | - | - |
|   | SXT      | dst     | Bit7 → Bit8 Bit15                               | 0           | X | X | X |
| * | TST(.B)  | dst     | Test destination                                | X           | X | X | X |
|   | XOR(.B)  | src,dst | $\text{src .xor. dst} \to \text{dst}$           | Х           | X | X | Χ |

Legend:

- 0 The Status Bit is cleared
- Х \* The Status Bit is affected
- The Status Bit is set
- The Status Bit is not affected
- **Emulated Instructions**

Table 5.3: MPS430 Family Instruction Set Summary (Concluded)

## **Emulated Instructions** Note:

All marked instructions ( \* ) are emulated instructions. The emulated instructions use core instructions combined with the architecture and implementation of the CPU for higher code efficiency and faster execution.