#### 13.0 INSTRUCTION SET SUMMARY

Each PIC16F87X instruction is a 14-bit word, divided into an OPCODE which specifies the instruction type and one or more operands which further specify the operation of the instruction. The PIC16F87X instruction set summary in Table 13-2 lists **byte-oriented**, **bit-oriented**, and **literal and control** operations. Table 13-1 shows the opcode field descriptions.

For **byte-oriented** instructions, 'f' represents a file register designator and 'd' represents a destination designator. The file register designator specifies which file register is to be used by the instruction.

The destination designator specifies where the result of the operation is to be placed. If 'd' is zero, the result is placed in the W register. If 'd' is one, the result is placed in the file register specified in the instruction.

For **bit-oriented** instructions, 'b' represents a bit field designator which selects the number of the bit affected by the operation, while 'f' represents the address of the file in which the bit is located.

For **literal and control** operations, 'k' represents an eight or eleven bit constant or literal value.

TABLE 13-1: OPCODE FIELD DESCRIPTIONS

| Field | Description                                                                                                                                                         |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| f     | Register file address (0x00 to 0x7F)                                                                                                                                |
| W     | Working register (accumulator)                                                                                                                                      |
| b     | Bit address within an 8-bit file register                                                                                                                           |
| k     | Literal field, constant data or label                                                                                                                               |
| x     | Don't care location (= 0 or 1). The assembler will generate code with x = 0. It is the recommended form of use for compatibility with all Microchip software tools. |
| d     | Destination select; $d = 0$ : store result in W, $d = 1$ : store result in file register f. Default is $d = 1$ .                                                    |
| PC    | Program Counter                                                                                                                                                     |
| TO    | Time-out bit                                                                                                                                                        |
| PD    | Power-down bit                                                                                                                                                      |

The instruction set is highly orthogonal and is grouped into three basic categories:

- · Byte-oriented operations
- · Bit-oriented operations
- · Literal and control operations

All instructions are executed within one single instruction cycle, unless a conditional test is true or the program counter is changed as a result of an instruction. In this case, the execution takes two instruction cycles with the second cycle executed as a NOP. One instruction cycle consists of four oscillator periods. Thus, for an oscillator frequency of 4 MHz, the normal instruction execution time is 1  $\mu s$ . If a conditional test is true, or the program counter is changed as a result of an instruction, the instruction execution time is 2  $\mu s$ .

Table 13-2 lists the instructions recognized by the MPASM™ assembler.

Figure 13-1 shows the general formats that the instructions can have.

**Note:** To maintain upward compatibility with future PIC16F87X products, <u>do not use</u> the OPTION and TRIS instructions.

All examples use the following format to represent a hexadecimal number:

0xhh

where h signifies a hexadecimal digit.

### FIGURE 13-1: GENERAL FORMAT FOR INSTRUCTIONS



A description of each instruction is available in the PICmicro  $^{\text{TM}}$  Mid-Range Reference Manual, (DS33023).

TABLE 13-2: PIC16F87X INSTRUCTION SET

| Mnemonic,<br>Operands |      | Description                  | Cycles  | 14-Bit Opcode |      | Status | Notes |          |       |
|-----------------------|------|------------------------------|---------|---------------|------|--------|-------|----------|-------|
|                       |      | Description                  |         | 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 OPER | 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          | OPERATI | ONS           |      |        |       |          |       |
| 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  | ₹O,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 Program Counter (PC) is modified, or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP.

### 13.1 Instruction Descriptions

| ADDLW                                                                              | Add Literal and W              | E |
|------------------------------------------------------------------------------------|--------------------------------|---|
| Syntax:                                                                            | [ <i>label</i> ] ADDLW k       | S |
| Operands:                                                                          | $0 \le k \le 255$              | C |
| Operation:                                                                         | $(W) + k \rightarrow (W)$      | _ |
| Status Affected:                                                                   | C, DC, Z                       | C |
| Description:                                                                       | The contents of the W register | S |
| are added to the eight bit literal 'k' and the result is placed in the W register. |                                | C |

| BCF              | Bit Clear f                         |
|------------------|-------------------------------------|
| Syntax:          | [label] BCF f,b                     |
| Operands:        | $0 \le f \le 127$ $0 \le b \le 7$   |
| Operation:       | $0 \rightarrow (f < b >)$           |
| Status Affected: | None                                |
| Description:     | Bit 'b' in register 'f' is cleared. |

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

| BSF              | Bit Set f                         |
|------------------|-----------------------------------|
| Syntax:          | [ <i>label</i> ] BSF f,b          |
| Operands:        | $0 \le f \le 127$ $0 \le b \le 7$ |
| Operation:       | $1 \rightarrow (f < b >)$         |
| Status Affected: | None                              |
| Description:     | Bit 'b' in register 'f' is set.   |
|                  |                                   |

| ANDLW            | AND Literal with W                                                                                            |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:          | [ <i>label</i> ] ANDLW k                                                                                      |  |  |
| Operands:        | $0 \le k \le 255$                                                                                             |  |  |
| Operation:       | (W) .AND. $(k) \rightarrow (W)$                                                                               |  |  |
| Status Affected: | Z                                                                                                             |  |  |
| Description:     | The contents of W register are AND'ed with the eight bit literal 'k'. The result is placed in the W register. |  |  |

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

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

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

| CALL             | Call Subroutine                                                                                                                                                                                                           | CLRWDT                           | Clear Watchdog Timer                                                                                                                           |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] CALL k                                                                                                                                                                                                            | Syntax:                          | [label] CLRWDT                                                                                                                                 |
| Operands:        | $0 \leq k \leq 2047$                                                                                                                                                                                                      | Operands:                        | None                                                                                                                                           |
| Operation:       | $(PC)+ 1 \rightarrow TOS,$<br>$k \rightarrow PC<10:0>,$<br>$(PCLATH<4:3>) \rightarrow PC<12:11>$                                                                                                                          | Operation:                       | $00h \rightarrow WDT$ $0 \rightarrow WDT \text{ prescaler,}$ $1 \rightarrow \overline{TO}$                                                     |
| Status Affected: | None                                                                                                                                                                                                                      | Q                                | 1 → PD                                                                                                                                         |
| 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. | Status Affected:<br>Description: | TO, PD  CLRWDT instruction resets the Watchdog Timer. It also resets the prescaler of the WDT. Status bits TO and PD are set.                  |
| CLRF             | Clear f                                                                                                                                                                                                                   | COMF                             | Complement f                                                                                                                                   |
| Syntax:          | [ <i>label</i> ] CLRF f                                                                                                                                                                                                   | Syntax:                          | [ label ] COMF f,d                                                                                                                             |
| Operands:        | $0 \le f \le 127$                                                                                                                                                                                                         | Operands:                        | $0 \le f \le 127$                                                                                                                              |
| Operation:       | 00h  (f)                                                                                                                                                                                                                  |                                  | d ∈ [0,1]                                                                                                                                      |
| 0                | $1 \rightarrow Z$                                                                                                                                                                                                         | Operation:                       | $(\bar{f}) \to (destination)$                                                                                                                  |
| Status Affected: | Z                                                                                                                                                                                                                         | Status Affected:                 | Z                                                                                                                                              |
| Description:     | The contents of register 'f' are cleared and the Z bit is set.                                                                                                                                                            | Description:                     | The contents of register 'f' are complemented. If 'd' is 0, the result is stored in W. If 'd' is 1, the result is stored back in register 'f'. |
| CLRW             | Clear W                                                                                                                                                                                                                   | DECF                             | Decrement f                                                                                                                                    |
| Syntax:          | [label] CLRW                                                                                                                                                                                                              | Syntax:                          | [label] DECF f,d                                                                                                                               |
| Operands:        | None                                                                                                                                                                                                                      | Operands:                        | 0 ≤ f ≤ 127                                                                                                                                    |
| Operation:       | $00h \rightarrow (W)$                                                                                                                                                                                                     |                                  | d ∈ [0,1]                                                                                                                                      |
|                  | $1 \rightarrow Z$                                                                                                                                                                                                         | Operation:                       | $(f) - 1 \rightarrow (destination)$                                                                                                            |
| Status Affected: | Z                                                                                                                                                                                                                         | Status Affected:                 | Z                                                                                                                                              |
| Description:     | W register is cleared. Zero bit (Z) is set.                                                                                                                                                                               | Description:                     | Decrement register 'f'. If 'd' is 0, the result is stored in the W register. If 'd' is 1, the result is stored 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' is 0, the result is placed in the W register. If 'd' is 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 2TCY 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' is 0, the result is placed in the W register. If 'd' is 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 2TCY instruction. |

| GOTO             | Unconditional Branch                                                                                                                                                              |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] GOTO k                                                                                                                                                                  |
| Operands:        | $0 \le k \le 2047$                                                                                                                                                                |
| Operation:       | $k \rightarrow PC<10:0>$<br>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. |

| IORLW            | Inclusive OR Literal with W                                                                                      |
|------------------|------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] IORLW k                                                                                                |
| Operands:        | $0 \le k \le 255$                                                                                                |
| Operation:       | (W) .OR. $k \rightarrow (W)$                                                                                     |
| Status Affected: | Z                                                                                                                |
| Description:     | The contents of the W register are OR'ed with the eight bit literal 'k'. The result is placed in the W register. |

| 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' is 0, the result is placed in the W register. If 'd' is 1, the result is placed back in register 'f'. |

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

| 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$ , 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. |

| No Operation  |
|---------------|
| [ label ] NOP |
| None          |
| No operation  |
| None          |
| No operation. |
|               |
|               |
|               |
|               |

| MOVLW            | Move Literal to W                                                                          |
|------------------|--------------------------------------------------------------------------------------------|
| Syntax:          | [label] MOVLW k                                                                            |
| Operands:        | $0 \le k \le 255$                                                                          |
| Operation:       | $k \rightarrow (W)$                                                                        |
| Status Affected: | None                                                                                       |
| Description:     | The eight bit literal 'k' is loaded into W register. The don't cares will assemble as 0's. |

| RETFIE           | Return from Interrupt                      |
|------------------|--------------------------------------------|
| Syntax:          | [label] RETFIE                             |
| Operands:        | None                                       |
| Operation:       | $TOS \rightarrow PC$ , $1 \rightarrow GIE$ |
| Status Affected: | None                                       |

| MOVWF            | Move W to f                                |
|------------------|--------------------------------------------|
| Syntax:          | [ label ] MOVWF f                          |
| Operands:        | $0 \le f \le 127$                          |
| Operation:       | (W) 	o (f)                                 |
| Status Affected: | None                                       |
| Description:     | Move data from W register to register 'f'. |

| REILW            | Return with Literal in W                                                                                                                                                |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] RETLW k                                                                                                                                                         |
| Operands:        | $0 \le k \le 255$                                                                                                                                                       |
| Operation:       | $k \rightarrow (W);$<br>TOS $\rightarrow$ PC                                                                                                                            |
| Status Affected: | None                                                                                                                                                                    |
| 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. |

RLF Rotate Left f through Carry

Syntax: [ label ] RLF f,d Operands:  $0 \le f \le 127$ 

 $d\in \left[ 0,1\right]$ 

Operation: See description below

Status Affected: C

Description: The contents of register 'f' are rotated

one bit to the left through the Carry Flag. If 'd' is 0, the result is placed in the W register. If 'd' is 1, the result is

stored back in register 'f'.



**SLEEP** 

Syntax: [label] SLEEP

Operands: None

Operation:  $00h \rightarrow WDT$ ,

 $0 \rightarrow WDT$  prescaler,

 $1 \to \overline{TO}, \\ 0 \to \overline{PD}$ 

Status Affected: TO, PD

Description: The power-down status bit,  $\overline{PD}$  is

cleared. Time-out status bit,  $\overline{\text{TO}}$  is set. Watchdog Timer and its

prescaler are cleared.

The processor is put into SLEEP mode with the oscillator stopped.

RETURN Return from Subroutine

Syntax: [label] RETURN

Operands: None  $\text{Operation:} \qquad \text{TOS} \rightarrow \text{PC}$ 

Status Affected: None

Description: Return from subroutine. The stack

is POPed and the top of the stack (TOS) is loaded into the program counter. This is a two-cycle

instruction.

SUBLW Subtract W from Literal

Syntax: [label] SUBLW k

 $\label{eq:constraints} \begin{aligned} &\text{Operands:} && 0 \leq k \leq 255 \\ &\text{Operation:} && k \cdot (W) \rightarrow (W) \end{aligned}$ 

Status Affected: C, DC, Z

Description: The W register is subtracted (2's

complement method) from the eight-bit literal 'k'. The result is placed in the W register.

RRF Rotate Right f through Carry

Syntax: [label] RRF f,d

Operands:  $0 \le f \le 127$ 

 $d \in [0,1]$ 

Operation: See description below

Status Affected: C

Description: The contents of register 'f' are

rotated one bit to the right through the Carry Flag. If 'd' is 0, the result is placed in the W register. If 'd' is 1, the result is placed back in

register 'f'.

C Register f

SUBWF Subtract W from f

Syntax: [ label ] SUBWF f,d

Operands:  $0 \le f \le 127$  $d \in [0,1]$ 

Operation: (f) - (W)  $\rightarrow$  (destination)

Status C, DC, Z

Affected:

Description: Subtract (2's complement method)

stored back in register 'f'.

W register from register 'f'. If 'd' is 0, the result is stored in the W register. If 'd' is 1, the result is

| 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>),  (f<7:4>) \rightarrow (destination<3:0>)$                                                                                |
| Status Affected: | None                                                                                                                                                               |
| Description:     | The upper and lower nibbles of register 'f' are exchanged. If 'd' is 0, the result is placed in the W register. If 'd' is 1, the result is placed in register 'f'. |

| XORWF            | Exclusive OR W with f                                                                                                                                                       |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] XORWF f,d                                                                                                                                                  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                          |
| Operation:       | (W) .XOR. (f) $\rightarrow$ (destination)                                                                                                                                   |
| Status Affected: | Z                                                                                                                                                                           |
| Description:     | Exclusive OR the contents of the W register with register 'f'. If 'd' is 0, the result is stored in the W register. If 'd' is 1, the result is stored back in register 'f'. |

| XORLW            | Exclusive OR Literal with W                                                                                       |
|------------------|-------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] XORLW k                                                                                          |
| Operands:        | $0 \leq k \leq 255$                                                                                               |
| Operation:       | (W) .XOR. $k \rightarrow (W)$                                                                                     |
| Status Affected: | Z                                                                                                                 |
| Description:     | The contents of the W register are XOR'ed with the eight-bit literal 'k'. The result is placed in the W register. |