TABLE 34-3: ENHANCED MID-RANGE INSTRUCTION SET

| Mnemonic,<br>Operands |      | Description                   | Cycles         | 14-Bit Opcode |      |      |      | Status   | Notes |
|-----------------------|------|-------------------------------|----------------|---------------|------|------|------|----------|-------|
|                       |      | Description                   |                | MSb           |      |      | LSb  | Affected | Notes |
|                       |      | BYTE-ORIENTED FILE            | REGISTER OPE   | RATIO         | NS   |      |      |          |       |
| ADDWF                 | f. d | Add W and f                   | 1              | 0.0           | 0111 | dfff | ffff | C, DC, Z | 2     |
| ADDWFC                | f, d | Add with Carry W and f        | 1              | 11            | 1101 | dfff | ffff | C, DC, Z | 2     |
| ANDWF                 | f, d | AND W with f                  | 1              | 0.0           | 0101 | dfff | ffff | Z        | 2     |
| ASRF                  | f, d | Arithmetic Right Shift        | 1              | 11            | 0111 | dfff | ffff | C, Z     | 2     |
| LSLF                  | f, d | Logical Left Shift            | 1              | 11            | 0101 | dfff | ffff | C, Z     | 2     |
| LSRF                  | f, d | Logical Right Shift           | 1              | 11            | 0110 | dfff | ffff | C, Z     | 2     |
| CLRF                  | f    | Clear f                       | 1              | 00            | 0001 | lfff | ffff | Z        | 2     |
| CLRW                  | _    | Clear W                       | 1              | 00            | 0001 | 0000 | 00xx | Z        |       |
| COMF                  | f, d | Complement f                  | 1              | 0.0           | 1001 | dfff | ffff | Z        | 2     |
| DECF                  | f, d | Decrement f                   | 1              | 0.0           | 0011 | dfff | ffff | Z        | 2     |
| INCF                  | f, d | Increment f                   | 1              | 0.0           | 1010 | dfff | ffff | Z        | 2     |
| IORWF                 | f, d | Inclusive OR W with f         | 1              | 0.0           | 0100 | dfff | ffff | Z        | 2     |
| MOVF                  | f, d | Move f                        | 1              | 0.0           | 1000 | dfff | ffff | Z        | 2     |
| MOVWF                 | f    | Move W to f                   | 1              | 0.0           | 0000 | 1fff | ffff |          | 2     |
| RLF                   | f, d | Rotate Left f through Carry   | 1              | 0.0           | 1101 | dfff | ffff | С        | 2     |
| RRF                   | f, d | Rotate Right f through Carry  | 1              | 0.0           | 1100 | dfff | ffff | С        | 2     |
| SUBWF                 | f, d | Subtract W from f             | 1              | 0.0           | 0010 | dfff | ffff | C, DC, Z | 2     |
| SUBWFB                | f, d | Subtract with Borrow W from f | 1              | 11            | 1011 | dfff | ffff | C, DC, Z | 2     |
| SWAPF                 | f, d | Swap nibbles in f             | 1              | 0.0           | 1110 | dfff | ffff | , ,      | 2     |
| XORWF                 | f, d | Exclusive OR W with f         | 1              | 0.0           | 0110 | dfff | ffff | Z        | 2     |
|                       |      | BYTE ORIENTED                 | SKIP OPERATION | ONS           |      |      |      |          | •     |
| DECFSZ                | f, d | Decrement f, Skip if 0        | 1(2)           | 00            | 1011 | dfff | ffff |          | 1, 2  |
| INCFSZ                | f, d | Increment f, Skip if 0        | 1(2)           | 00            | 1111 | dfff | ffff |          | 1, 2  |
|                       |      | BIT-ORIENTED FILE F           | REGISTER OPER  | RATION        | IS   |      |      |          | 1     |
| BCF                   | f, b | Bit Clear f                   | 11             | 01            | 00bb | bfff | ffff |          | 2     |
| BSF                   | f, b | Bit Set f                     | 1              | 01            | 01bb | bfff | ffff |          | 2     |
|                       |      | BIT-ORIENTED S                | SKIP OPERATIO  | NS            |      |      |      |          | 1     |
| BTFSC                 | f, b | Bit Test f, Skip if Clear     | 1 (2)          | 01            | 10bb | bfff | ffff |          | 1, 2  |
| BTFSS                 | f, b | Bit Test f, Skip if Set       | 1 (2)          | 01            | 11bb | bfff | ffff |          | 1, 2  |
|                       |      | LITERAL (                     | PERATIONS      | ı             |      |      |      |          |       |
| ADDLW                 | k    | Add literal and W             | 1              | 11            | 1110 | kkkk | kkkk | C, DC, Z |       |
| ANDLW                 | k    | AND literal with W            | 1              | 11            | 1001 | kkkk | kkkk | Z        |       |
| IORLW                 | k    | Inclusive OR literal with W   | 1              | 11            | 1000 | kkkk | kkkk | Z        |       |
| MOVLB                 | k    | Move literal to BSR           | 1              | 00            | 0000 | 001k | kkkk |          |       |
| MOVLP                 | k    | Move literal to PCLATH        | 1              | 11            | 0001 | 1kkk | kkkk |          |       |
| MOVLW                 | k    | Move literal to W             | 1              | 11            | 0000 | kkkk | kkkk |          |       |
| SUBLW                 | k    | Subtract W from literal       | 1              | 11            | 1100 | kkkk | kkkk | C, DC, Z |       |
|                       |      |                               |                |               |      |      |      |          |       |

Note 1: 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.

<sup>2:</sup> If this instruction addresses an INDF register and the MSb of the corresponding FSR is set, this instruction will require one additional instruction cycle.

TABLE 34-3: ENHANCED MID-RANGE INSTRUCTION SET (CONTINUED)

| Mnemonic,<br>Operands |      | Description                                   | Cycles | 14-Bit Opcode |      |      |       | Status   | Notes |
|-----------------------|------|-----------------------------------------------|--------|---------------|------|------|-------|----------|-------|
|                       |      |                                               |        | MSb           |      |      | LSb   | Affected | notes |
|                       |      | CONTROL OPERA                                 | TIONS  |               |      |      |       |          |       |
| BRA                   | k    | Relative Branch                               | 2      | 11            | 001k | kkkk | kkkk  |          |       |
| BRW                   | _    | Relative Branch with W                        | 2      | 00            | 0000 | 0000 | 1011  |          |       |
| CALL                  | k    | Call Subroutine                               | 2      | 10            | 0kkk | kkkk | kkkk  |          |       |
| CALLW                 | _    | Call Subroutine with W                        | 2      | 00            | 0000 | 0000 | 1010  |          |       |
| GOTO                  | k    | Go to address                                 | 2      | 10            | 1kkk | kkkk | kkkk  |          |       |
| RETFIE                | k    | Return from interrupt                         | 2      | 00            | 0000 | 0000 | 1001  |          |       |
| RETLW                 | k    | Return with literal in W                      | 2      | 11            | 0100 | kkkk | kkkk  |          |       |
| RETURN                | -    | Return from Subroutine                        | 2      | 00            | 0000 | 0000 | 1000  |          |       |
|                       |      | INHERENT OPERA                                | TIONS  |               |      |      |       |          |       |
| CLRWDT                | _    | Clear Watchdog Timer                          | 1      | 00            | 0000 | 0110 | 0100  | TO, PD   |       |
| NOP                   | _    | No Operation                                  | 1      | 00            | 0000 | 0000 | 0000  |          |       |
| OPTION                | -    | Load OPTION_REG register with W               | 1      | 00            | 0000 | 0110 | 0010  |          |       |
| RESET                 | _    | Software device Reset                         | 1      | 00            | 0000 | 0000 | 0001  |          |       |
| SLEEP                 | _    | Go into Standby mode                          | 1      | 00            | 0000 | 0110 | 0011  | TO, PD   |       |
| TRIS                  | f    | Load TRIS register with W                     | 1      | 00            | 0000 | 0110 | Offf  |          |       |
|                       |      | C-COMPILER OPT                                | IMIZED |               |      |      |       |          |       |
| ADDFSR                | n, k | Add Literal k to FSRn                         | 1      | 11            | 0001 | 0nkk | kkkk  |          |       |
| MOVIW                 | n mm | Move Indirect FSRn to W with pre/post inc/dec | 1      | 0.0           | 0000 | 0001 | 0 nmm | Z        | 2, 3  |
|                       |      | modifier, mm                                  |        |               |      |      | kkkk  |          | •     |
|                       | k[n] | Move INDFn to W, Indexed Indirect.            | 1      | 11            | 1111 | 0nkk | 1nmm  | Z        | 2     |
| MOVWI                 | n mm | Move W to Indirect FSRn with pre/post inc/dec | 1      | 0.0           | 0000 | 0001 | kkkk  |          | 2, 3  |
|                       |      | modifier, mm                                  |        |               |      |      |       |          | •     |
|                       | k[n] | Move W to INDFn, Indexed Indirect.            | 1      | 11            | 1111 | 1nkk |       |          | 2     |

Note 1: 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.

<sup>2:</sup> If this instruction addresses an INDF register and the MSb of the corresponding FSR is set, this instruction will require one additional instruction cycle.

<sup>3:</sup> See Table in the MOVIW and MOVWI instruction descriptions.