TABLE 16-2: PIC16F87/88 INSTRUCTION SET

| Mnemor | nic, | Description                  | Cycles  |        | 14-Bit | Opcode | )    | Status   | Notes |
|--------|------|------------------------------|---------|--------|--------|--------|------|----------|-------|
| Operan | ıds  | Description                  | Cycles  | MSb    |        |        | LSb  | Affected | Notes |
|        |      | BYTE-ORIENTED FILE REGIS     | TER OPE | RATIO  | NS     |        |      |          |       |
| ADDWF  | f, d | Add W and f                  | 1       | 00     | 0111   | dfff   | ffff | C,DC,Z   | 1,2   |
| ANDWF  | f, d | AND W with f                 | 1       | 00     | 0101   | dfff   | ffff | Z        | 1,2   |
| CLRF   | f    | Clear f                      | 1       | 00     | 0001   | lfff   | ffff | Z        | 2     |
| CLRW   | -    | Clear W                      | 1       | 00     | 0001   | 0xxx   | xxxx | Z        |       |
| COMF   | f, d | Complement f                 | 1       | 00     | 1001   | dfff   | ffff | Z        | 1,2   |
| DECF   | f, d | Decrement f                  | 1       | 00     | 0011   | dfff   | ffff | Z        | 1,2   |
| DECFSZ | f, d | Decrement f, Skip if 0       | 1(2)    | 00     | 1011   | dfff   | ffff |          | 1,2,3 |
| INCF   | f, d | Increment f                  | 1       | 00     | 1010   | dfff   | ffff | Z        | 1,2   |
| INCFSZ | f, d | Increment f, Skip if 0       | 1(2)    | 00     | 1111   | dfff   | ffff |          | 1,2,3 |
| IORWF  | f, d | Inclusive OR W with f        | 1       | 00     | 0100   | dfff   | ffff | Z        | 1,2   |
| MOVF   | f, d | Move f                       | 1       | 00     | 1000   | dfff   | ffff | Z        | 1,2   |
| MOVWF  | f    | Move W to f                  | 1       | 00     | 0000   | lfff   | ffff |          |       |
| NOP    | -    | No Operation                 | 1       | 00     | 0000   | 0xx0   | 0000 |          |       |
| RLF    | f, d | Rotate Left f through Carry  | 1       | 00     | 1101   | dfff   | ffff | С        | 1,2   |
| RRF    | f, d | Rotate Right f through Carry | 1       | 00     | 1100   | dfff   | ffff | С        | 1,2   |
| SUBWF  | f, d | Subtract W from f            | 1       | 00     | 0010   | dfff   | ffff | C,DC,Z   | 1,2   |
| SWAPF  | f, d | Swap nibbles in f            | 1       | 00     | 1110   | dfff   | ffff |          | 1,2   |
| XORWF  | f, d | Exclusive OR W with f        | 1       | 00     | 0110   | dfff   | ffff | Z        | 1,2   |
|        |      | BIT-ORIENTED FILE REGIST     | ER OPEF | RATION | IS     |        |      |          |       |
| BCF    | f, b | Bit Clear f                  | 1       | 01     | 00bb   | bfff   | ffff |          | 1,2   |
| BSF    | f, b | Bit Set f                    | 1       | 01     | 01bb   | bfff   | ffff |          | 1,2   |
| BTFSC  | f, b | Bit Test f, Skip if Clear    | 1 (2)   | 01     | 10bb   | bfff   | ffff |          | 3     |
| BTFSS  | f, b | Bit Test f, Skip if Set      | 1 (2)   | 01     | 11bb   | bfff   | ffff |          | 3     |
|        |      | LITERAL AND CONTROL          | OPERAT  | IONS   |        |        |      |          |       |
| ADDLW  | k    | Add literal and W            | 1       | 11     | 111x   | kkkk   | kkkk | C,DC,Z   |       |
| ANDLW  | k    | AND literal with W           | 1       | 11     | 1001   | kkkk   | kkkk | Z        |       |
| CALL   | k    | Call subroutine              | 2       | 10     | 0kkk   | kkkk   | kkkk |          |       |
| CLRWDT | -    | Clear Watchdog Timer         | 1       | 00     | 0000   | 0110   | 0100 | TO,PD    |       |
| GOTO   | k    | Go to address                | 2       | 10     | 1kkk   | kkkk   | kkkk |          |       |
| IORLW  | k    | Inclusive OR literal with W  | 1       | 11     | 1000   | kkkk   | kkkk | Z        |       |
| MOVLW  | k    | Move literal to W            | 1       | 11     | 00xx   | kkkk   | kkkk |          |       |
| RETFIE | -    | Return from interrupt        | 2       | 00     | 0000   | 0000   | 1001 |          |       |
| RETLW  | k    | Return with literal in W     | 2       | 11     | 01xx   | kkkk   | kkkk |          |       |
| RETURN | -    | Return from Subroutine       | 2       | 00     | 0000   | 0000   | 1000 |          |       |
| SLEEP  | -    | Go into Standby mode         | 1       | 00     | 0000   | 0110   | 0011 | TO,PD    |       |
| SUBLW  | k    | Subtract W from literal      | 1       | 11     | 110x   | kkkk   | kkkk | C,DC,Z   |       |
| XORLW  | k    | Exclusive OR literal with W  | 1       | 11     | 1010   | kkkk   | kkkk | Z        |       |

Note 1: When an I/O register is modified as a function of itself (e.g., MOVF PORTB, 1), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.

**Note:** Additional information on the mid-range instruction set is available in the "PICmicro® Mid-Range MCU Family Reference Manual" (DS33023).

<sup>2:</sup> If this instruction is executed on the TMR0 register (and where applicable, d = 1), the prescaler will be cleared if assigned to the Timer0 module.

<sup>3:</sup> If the Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP.

### 16.2 Instruction Descriptions

| ADDLW                | Add Literal and W                                                                  | ANDWF            | AND W with f                                                                                                                                     |
|----------------------|------------------------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:              | [label] ADDLW k                                                                    | Syntax:          | [ label ] ANDWF f,d                                                                                                                              |
| Operands: Operation: | $0 \le k \le 255$ $(W) + k \to (W)$                                                | Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                               |
| Status Affected:     | C, DC, Z                                                                           | Operation:       | (W) .AND. (f) $\rightarrow$ (destination)                                                                                                        |
| Description:         | The contents of the W register                                                     | Status Affected: | Z                                                                                                                                                |
| ·                    | are added to the eight-bit literal 'k' and the result is placed in the W register. | Description:     | AND the W register with register 'f'. If 'd' = 0, the result is stored in the W register. If 'd' = 1, the result is stored back in register 'f'. |

| ADDWF            | Add W and f                                                                                                                                                      | BCF              | Bit Clear f                           |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------------|
| Syntax:          | [label] ADDWF f,d                                                                                                                                                | Syntax:          | [ label ] BCF f,b                     |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                               | Operands:        | $0 \le f \le 127$<br>$0 \le b \le 7$  |
| Operation:       | $(W) + (f) \to (destination)$                                                                                                                                    | Operation:       | $0 \rightarrow (f \langle b \rangle)$ |
| Status Affected: | C, DC, Z                                                                                                                                                         | Status Affected: | None                                  |
| Description:     | Add the contents of the W register with register 'f'. If 'd' = 0, the result is stored in the W register. If 'd' = 1, the result is stored back in register 'f'. | Description:     | Bit 'b' in register 'f' is cleared.   |

| ANDLW            | AND Literal with W                                                   | BSF              | Bit Set f                       |
|------------------|----------------------------------------------------------------------|------------------|---------------------------------|
| Syntax:          | [label] ANDLW k                                                      | Syntax:          | [ label ] BSF f,b               |
| Operands:        | $0 \le k \le 255$                                                    | Operands:        | $0 \le f \le 127$               |
| Operation:       | (W) .AND. $(k) \rightarrow (W)$                                      |                  | $0 \le b \le 7$                 |
| Status Affected: | Z                                                                    | Operation:       | $1 \rightarrow (f < b >)$       |
| Description:     | The contents of W register are                                       | Status Affected: | None                            |
| į.               | AND'ed with the eight-bit literal 'k'. The result is placed in the W | Description:     | Bit 'b' in register 'f' is set. |
|                  | register.                                                            |                  |                                 |

**BTFSC** 

| BTFSS            | Bit Test f, Skip if Set                                                                                                                                                | CLRF            |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| Syntax:          | [ label ] BTFSS f,b                                                                                                                                                    | Syntax:         |
| Operands:        | $0 \le f \le 127$                                                                                                                                                      | Operands:       |
|                  | $0 \le b < 7$                                                                                                                                                          | Operation:      |
| Operation:       | skip if $(f < b >) = 1$                                                                                                                                                | •               |
| Status Affected: | None                                                                                                                                                                   | Status Affected |
| Description:     | If bit 'b' in register 'f' = 0, the next instruction is executed.  If bit 'b' = 1, then the next instruction is discarded and a NOP is executed instead, making this a | Description:    |

| CLRF             | Clear f                                                                |
|------------------|------------------------------------------------------------------------|
| Syntax:          | [label] CLRF f                                                         |
| Operands:        | $0 \le f \le 127$                                                      |
| Operation:       | $\begin{array}{l} 00h \rightarrow (f), \\ 1 \rightarrow Z \end{array}$ |
| Status Affected: | Z                                                                      |
| Description:     | The contents of register 'f' are cleared and the Z bit is set.         |
|                  |                                                                        |
|                  |                                                                        |

| Syntax:          | [label]BTFSC f,b                                                                                                                                                                                      |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operands:        | $0 \le f \le 127$<br>$0 \le b \le 7$                                                                                                                                                                  |
| Operation:       | skip if $(f < b >) = 0$                                                                                                                                                                               |
| Status Affected: | None                                                                                                                                                                                                  |
| Description:     | If bit 'b' in register 'f' = 1, the next instruction is executed. If bit 'b', in register 'f', = 0, the next instruction is discarded and a NOP is executed instead, making this a 2 Tcy instruction. |

Bit Test, Skip if Clear

2 Tcy instruction.

| CLRW             | Clear W                                                                |
|------------------|------------------------------------------------------------------------|
| Syntax:          | [label] CLRW                                                           |
| Operands:        | None                                                                   |
| Operation:       | $\begin{array}{l} 00h \rightarrow (W), \\ 1 \rightarrow Z \end{array}$ |
| Status Affected: | Z                                                                      |
| Description:     | W register is cleared. Zero bit (Z) is set.                            |
|                  |                                                                        |

| CALL             | Call Subroutine                                                                                                                                                                                                             |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] CALL k                                                                                                                                                                                                              |
| Operands:        | $0 \leq k \leq 2047$                                                                                                                                                                                                        |
| Operation:       | $ \begin{aligned} &(PC) + 1 \rightarrow TOS, \\ &k \rightarrow PC < 10:0>, \\ &(PCLATH < 4:3>) \rightarrow PC < 12:11> \end{aligned} $                                                                                      |
| Status Affected: | None                                                                                                                                                                                                                        |
| Description:     | Call subroutine. First, return address (PC + 1) is pushed onto the stack. The eleven-bit immediate address is loaded into PC bits <10:0>. The upper bits of the PC are loaded from PCLATH. CALL is a two-cycle instruction. |

| CLRWDT           | Clear Watchdog Timer                                                                                                                                                                                                                       |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] CLRWDT                                                                                                                                                                                                                             |
| Operands:        | None                                                                                                                                                                                                                                       |
| Operation:       | $\begin{array}{l} \text{00h} \rightarrow \text{WDT,} \\ \text{0} \rightarrow \underline{\text{WDT}} \text{ prescaler,} \\ \text{1} \rightarrow \overline{\underline{\text{TO}}}, \\ \text{1} \rightarrow \overline{\text{PD}} \end{array}$ |
| Status Affected: | TO, PD                                                                                                                                                                                                                                     |
| Description:     | CLRWDT instruction resets the Watchdog Timer. It also resets the prescaler of the WDT. Status bits TO and PD are set.                                                                                                                      |

| COMF             | Complement f                                                                                                                                         |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] COMF f,d                                                                                                                                     |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                   |
| Operation:       | $\text{(f)} \rightarrow \text{(destination)}$                                                                                                        |
| Status Affected: | Z                                                                                                                                                    |
| Description:     | The contents of register 'f' are complemented. If ' $d' = 0$ , the result is stored in W. If ' $d' = 1$ , the result is stored back in register 'f'. |

| GOTO             | Unconditional Branch                                                                                                                                                              |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] GOTO k                                                                                                                                                                    |
| Operands:        | $0 \leq k \leq 2047$                                                                                                                                                              |
| Operation:       | $k \rightarrow PC<10:0>$ , PCLATH<4:3> $\rightarrow$ PC<12:11>                                                                                                                    |
| Status Affected: | None                                                                                                                                                                              |
| Description:     | GOTO is an unconditional branch. The eleven-bit immediate value is loaded into PC bits <10:0>. The upper bits of PC are loaded from PCLATH<4:3>. GOTO is a two-cycle instruction. |

| DECF             | Decrement f                                                                                                                                 |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] DECF f,d                                                                                                                            |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                          |
| Operation:       | $\text{(f)} - 1 \rightarrow \text{(destination)}$                                                                                           |
| Status Affected: | Z                                                                                                                                           |
| Description:     | Decrement register 'f'. If 'd' = 0,<br>the result is stored in the W<br>register. If 'd' = 1, the result is<br>stored back in register 'f'. |

| INCF             | Increment f                                                                                                                                              |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] INCF f,d                                                                                                                                         |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                       |
| Operation:       | (f) + 1 $\rightarrow$ (destination)                                                                                                                      |
| Status Affected: | Z                                                                                                                                                        |
| Description:     | The contents of register 'f' are incremented. If 'd' = 0, the result is placed in the W register. If 'd' = 1, the result is placed back in register 'f'. |

| DECFSZ           | Decrement f, Skip if 0                                                                                                                                                                                                                                                                                 |  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Syntax:          | [label] DECFSZ f,d                                                                                                                                                                                                                                                                                     |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                     |  |
| Operation:       | (f) $-1 \rightarrow$ (destination);<br>skip if result = 0                                                                                                                                                                                                                                              |  |
| Status Affected: | None                                                                                                                                                                                                                                                                                                   |  |
| Description:     | The contents of register 'f' are decremented. If 'd' = 0, the result is placed in the W register. If 'd' = 1, the result is placed back in register 'f'.  If the result is '1', the next instruction is executed. If the result is '0', then a NOP is executed instead, making it a 2 Tcy instruction. |  |

| INCFSZ           | Increment f, Skip if 0                                                                                                                                                                                                                                                                            |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Syntax:          | [ label ] INCFSZ f,d                                                                                                                                                                                                                                                                              |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                |  |
| Operation:       | (f) + 1 $\rightarrow$ (destination),<br>skip if result = 0                                                                                                                                                                                                                                        |  |
| Status Affected: | None                                                                                                                                                                                                                                                                                              |  |
| Description:     | The contents of register 'f' are incremented. If 'd' = 0, the result is placed in the W register. If 'd' = 1, the result is placed back in register 'f'.  If the result is '1', the next instruction is executed. If the result is '0', a NOP is executed instead, making it a 2 TcY instruction. |  |

| IORLW            | Inclusive OR Literal with W                                                                                      | MOVLW            | Move Literal to W                                                                           |
|------------------|------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------|
| Syntax:          | [label] IORLW k                                                                                                  | Syntax:          | [label] MOVLW k                                                                             |
| Operands:        | $0 \le k \le 255$                                                                                                | Operands:        | $0 \leq k \leq 255$                                                                         |
| Operation:       | (W) .OR. $k \rightarrow$ (W)                                                                                     | Operation:       | $k \rightarrow (W)$                                                                         |
| Status Affected: | Z                                                                                                                | Status Affected: | None                                                                                        |
| Description:     | The contents of the W register are OR'ed with the eight-bit literal 'k'. The result is placed in the W register. | Description:     | The eight-bit literal 'k' is loaded into W register. The don't cares will assemble as '0's. |

| IORWF            | Inclusive OR W with f                                                                                                                                     | MOVWF       |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| Syntax:          | [label] IORWF f,d                                                                                                                                         | Syntax:     |
| Operands:        | $0 \le f \le 127$                                                                                                                                         | Operands:   |
|                  | $d \in [0,1]$                                                                                                                                             | Operation:  |
| Operation:       | (W) .OR. (f) $\rightarrow$ (destination)                                                                                                                  | Status Affe |
| Status Affected: | Z                                                                                                                                                         | Description |
| Description:     | Inclusive OR the W register with register 'f'. If 'd' = 0, the result is placed in the W register. If 'd' = 1, the result is placed back in register 'f'. | ·           |

| Move W to f                                |
|--------------------------------------------|
| [label] MOVWF f                            |
| $0 \le f \le 127$                          |
| $(W) \rightarrow (f)$                      |
| None                                       |
| Move data from W register to register 'f'. |
| register i.                                |
|                                            |
|                                            |

| MOVF             | Move f                                                                                                                                                                                                                                                                    |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Syntax:          | [label] MOVF f,d                                                                                                                                                                                                                                                          |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                        |  |
| Operation:       | $(f) \rightarrow (destination)$                                                                                                                                                                                                                                           |  |
| Status Affected: | Z                                                                                                                                                                                                                                                                         |  |
| Description:     | The contents of register 'f' are moved to a destination dependant upon the status of 'd'. If 'd' = 0, the destination is W register. If 'd' = 1, the destination is file register 'f' itself. 'd' = 1 is useful to test a file register, since status flag Z is affected. |  |

| NOP              | No Operation  |
|------------------|---------------|
| Syntax:          | [label] NOP   |
| Operands:        | None          |
| Operation:       | No operation  |
| Status Affected: | None          |
| Description:     | No operation. |
|                  |               |
|                  |               |
|                  |               |

| RETFIE           | Return from Interrupt  | RLF              | Rotate Left f through Carry                                                                                                                                                                     |
|------------------|------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] RETFIE         | Syntax:          | [label] RLF f,d                                                                                                                                                                                 |
| Operands:        | None                   | Operands:        | $0 \le f \le 127$                                                                                                                                                                               |
| Operation:       | $TOS \rightarrow PC$ , |                  | d ∈ [0,1]                                                                                                                                                                                       |
| •                | 1 → GIE                | Operation:       | See description below                                                                                                                                                                           |
| Status Affected: | None                   | Status Affected: | С                                                                                                                                                                                               |
|                  |                        | Description:     | The contents of register 'f' are rotated one bit to the left through the Carry flag. If 'd' = 0, the result is placed in the W register. If 'd' = 1, the result is stored back in register 'f'. |

| RETLW            | Return with Literal in W                                                                                                                                                | RRF              | Rotate Right f through Carry                                                                                                                                                                     |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] RETLW k                                                                                                                                                         | Syntax:          | [label] RRF f,d                                                                                                                                                                                  |
| Operands:        | 0 ≤ k ≤ 255                                                                                                                                                             | Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                               |
| Operation:       | $k \rightarrow (W);$<br>TOS $\rightarrow$ PC                                                                                                                            | Operation:       | See description below                                                                                                                                                                            |
| Status Affected: | None                                                                                                                                                                    | Status Affected: | С                                                                                                                                                                                                |
| Description:     | The W register is loaded with the eight-bit literal 'k'. The program counter is loaded from the top of the stack (the return address). This is a two-cycle instruction. | Description:     | The contents of register 'f' are rotated one bit to the right through the Carry flag. If 'd' = 0, the result is placed in the W register. If 'd' = 1, the result is placed back in register 'f'. |

| RETURN           | Return from Subroutine                                             | SLEEP            | Sleep                                                                                                                                                                                       |
|------------------|--------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] RETURN                                                     | Syntax:          | [label] SLEEP                                                                                                                                                                               |
| Operands:        | None                                                               | Operands:        | None                                                                                                                                                                                        |
| Operation:       | $TOS \to PC$                                                       | Operation:       | $00h \rightarrow WDT$ ,                                                                                                                                                                     |
| Status Affected: | None                                                               |                  | $0 \to \underline{WDT} \text{ prescaler,} \\ 1 \to \overline{TO},$                                                                                                                          |
| Description:     | Return from subroutine. The stack                                  |                  | $0 \rightarrow \overline{PD}$                                                                                                                                                               |
|                  | is POPed and the top of the stack (TOS) is loaded into the program | Status Affected: | TO, PD                                                                                                                                                                                      |
|                  | counter. This is a two-cycle instruction.                          | Description:     | The Power-Down status bit, PD, is cleared. Time-out status bit, TO, is set. Watchdog Timer and its prescaler are cleared. The processor is put into Sleep mode with the oscillator stopped. |

| SUBLW            | Subtract W from Literal                                                                                                        | XORLW            | Exclusive OR Literal with W                                                                                       |
|------------------|--------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] SUBLW k                                                                                                                | Syntax:          | [label] XORLW k                                                                                                   |
| Operands:        | $0 \le k \le 255$                                                                                                              | Operands:        | $0 \le k \le 255$                                                                                                 |
| Operation:       | $k-(W)\to (W)$                                                                                                                 | Operation:       | (W) .XOR. $k \rightarrow (W)$                                                                                     |
| Status Affected: | C, DC, Z                                                                                                                       | Status Affected: | Z                                                                                                                 |
| Description:     | The W register is subtracted (two's complement method) from the eight-bit literal 'k'. The result is placed in the W register. | Description:     | The contents of the W register are XOR'ed with the eight-bit literal 'k'. The result is placed in the W register. |

| SUBWF            | Subtract W from f                                                                                                                                                           | XORWF            | Exclusive OR W with f                                                                                                                                                     |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Syntax:          | [label] SUBWF f,d                                                                                                                                                           | Syntax:          | [label] XORWF f,d                                                                                                                                                         |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                          | Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                        |  |
| Operation:       | $(f)-(W)\to (destination)$                                                                                                                                                  | Operation:       | (W) .XOR. (f) $\rightarrow$ (destination)                                                                                                                                 |  |
| Status Affected: | C, DC, Z                                                                                                                                                                    | Status Affected: | Z                                                                                                                                                                         |  |
| Description:     | Subtract (two's complement method) W register from register 'f'. If 'd' = 0, the result is stored in the W register. If 'd' = 1, the result is stored back in register 'f'. | Description:     | Exclusive OR the contents of the W register with register 'f'. If 'd' = 0, the result is stored in the W register. If 'd' = 1, the result is stored back in register 'f'. |  |

| SWAPF            | Swap Nibbles in f                                                                                                                                            |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] SWAPF f,d                                                                                                                                            |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                           |
| Operation:       | $(f<3:0>) \rightarrow (destination<7:4>),$<br>$(f<7:4>) \rightarrow (destination<3:0>)$                                                                      |
| Status Affected: | None                                                                                                                                                         |
| Description:     | The upper and lower nibbles of register 'f' are exchanged. If 'd' = 0, the result is placed in W register. If 'd' = 1, the result is placed in register 'f'. |