| Syntax |               | Description                                                                                                        |          |  |  |
|--------|---------------|--------------------------------------------------------------------------------------------------------------------|----------|--|--|
| addlw  | number        | adds a number to the number in the working register.                                                               |          |  |  |
| addwf  | FileReg, dest | adds the working register to the number in a file register and puts the result in dest.                            |          |  |  |
| andlw  | number        | <b>AND</b> s a <b>number</b> with the working register, leaving the result in the working register.                |          |  |  |
| andwf  | FileReg, dest | ANDs the working register with the number in the file register                                                     | Z        |  |  |
| bcf    | FileReg, bit  | clears a bit in a file register                                                                                    | None     |  |  |
| bsf    | FileReg, bit  | sets a bit in file register                                                                                        | None     |  |  |
| btfsc  | FileReg, bit  | <b>t</b> ests a <b>b</b> it in a <b>f</b> ile register and skips the next instruction if the result is clear       | None     |  |  |
| btfss  | FileReg, bit  | <b>t</b> ests a <b>b</b> it in a <b>f</b> ile register and skips the next instruction if the result is set         | None     |  |  |
| call   | Sub           | Call a subroutine.                                                                                                 | None     |  |  |
| clrf   | FileReg       | clears the file register.                                                                                          | Z        |  |  |
| clrw   |               | clears the working register.                                                                                       | Z        |  |  |
| clrwdt |               | clears the watchdog timer.                                                                                         | /TO, /PD |  |  |
| comf   | FileReg, dest | <b>com</b> plements (inverts) the <b>f</b> ile register.                                                           | Z        |  |  |
| decf   | FileReg, dest | decrements a file register.                                                                                        | Z        |  |  |
| decfsz | FileReg, dest | <b>dec</b> rements a file register and <b>s</b> kip next instruction if result is <b>z</b> ero.                    | None     |  |  |
| goto   | label         | Go to the label                                                                                                    | None     |  |  |
| incf   | FileReg, dest | increments a file register.                                                                                        | Z        |  |  |
| incfsz | FileReg, dest | increments a file register and skip next instruction if result is zero.                                            | None     |  |  |
| iorlw  | number        | inclusive <b>OR</b> s a <b>number</b> with the <b>w</b> orking register                                            | Z        |  |  |
| iorwf  | FileReg, dest | inclusive <b>OR</b> s the <b>w</b> orking register with the number in a <b>f</b> ile register.                     | Z<br>Z   |  |  |
| movfw  | FileReg       | moves (copies) the number in a file register into the working register. movf FileReg, w is equivalent.             |          |  |  |
| movlw  |               |                                                                                                                    | None     |  |  |
| movwf  | FileReg       | moves (copies) the number in a working register into the file register.                                            | None     |  |  |
| nop    |               | no operation.                                                                                                      | None     |  |  |
| option |               | moves the number in the working register into the <b>option</b> register.<br>16C5X only                            | None     |  |  |
| retfie |               | returns from subroutine and set the Global Interrupt Enable bit.                                                   | None     |  |  |
| retlw  | number        | returns from a subroutine with a particular number (literal) in the working register                               | None     |  |  |
| return |               | returns from a subroutine                                                                                          | None     |  |  |
| rlf    | FileReg, dest | rotates the bits in a file register to the left                                                                    | С        |  |  |
| rrf    | FileReg, dest |                                                                                                                    |          |  |  |
| sleep  |               | makes the PIC sleep (low-power-mode)                                                                               | /TO, /PD |  |  |
| sublw  | number        | subtracts the working register from a number                                                                       |          |  |  |
| subwf  | FileReg, dest | • •                                                                                                                |          |  |  |
| swapf  | FileReg, dest |                                                                                                                    |          |  |  |
| tris   | PORTX         | uses the number in the working register to specify which bits of a port are inputs (1) and outputs (0). 16C5X only | None     |  |  |
| xorlw  | number        | exclusive <b>OR</b> s a <b>number</b> with the <b>w</b> orking register                                            | Z        |  |  |
| xorwf  | FileReg, dest | exclusive <b>OR</b> s the working register with the file register.                                                 | Z        |  |  |

#### Register File Map - PIC16F84

|     |                                              |                     | _   |
|-----|----------------------------------------------|---------------------|-----|
| 00h | Indirect addr                                | Indirect addr       | 80h |
| 01h | TMR0                                         | OPTION              | 81h |
| 02h | PCL                                          | PCL                 | 82h |
| 03h | STATUS                                       | STATUS              | 83h |
| 04h | FSR                                          | FSR                 | 84h |
| 05h | PORTA                                        | TRISA               | 85h |
| 06h | PORTB                                        | TRISB               | 86h |
| 07h |                                              |                     | 87h |
| 08h | EEDATA                                       | EECON1              | 88h |
| 09h | EEADR                                        | EECON2              | 89h |
| 0Ah | PCLATH                                       | PCLATH              | 8Ah |
| 0Bh | INTCON                                       | INTCON              | 8Bh |
| 0Ch | 68 General<br>Purpose<br>registers<br>(SRAM) | Mapped in<br>Bank 0 | 8Ch |
| 4Fh |                                              |                     | CFh |
| 50h |                                              |                     | D0h |
| 7Fh |                                              |                     | FFh |
|     | Bank 0                                       | Bank1               |     |

## STATUS Register (03h, 83h)

| IRP | RP1 | RP0 | /TO | /PD | Z | DC | С |
|-----|-----|-----|-----|-----|---|----|---|
|     |     |     |     |     |   |    |   |

bit 7: IRP: Register select bank.

0 = Bank 0, 1 (00h - FFh)

1 = Bank 2, 3 (100h,1FFh)

RP1:RP0: Register Bank Select bits. bit 6-5:

00 = Bank 0 (00h - 7Fh)

01 = Bank 1 (80h - FFh)

10 = Bank 2 (100h - 17Fh)

11 = Bank 3 (180h - 1FFh) Only RP0 used by PIC16F84

bit 4: /TO: Time-out bit.

1 = After power-up, CLRWDT or SLEEP instruction

0 = A WDT time-out occurred

bit 3: /PD: Power-down bit.

1 = After power-up or by the CLRWDT instruction.

0 = By execution of the SLEEP instruction.

bit 2:

bit 1: DC: Digit carry/borrow bit (for ADDWF and ADDLW instructions)

1 = A carry-out from the 4<sup>th</sup> low order bit of the result occurred

0 = No carry-out from the 4<sup>th</sup> low order bit of the result

bit 0: C: Carry/borrow bit.

#### **OPTION Register (81h)**

bit 5

# /RBPU INTEDG TOCS TOSE PSA PS2 PS1 PS0

/RBPU: PORTB Pull-up Enable bit bit 7

1 = PORTB pull-ups are disabled

0 = PORTB pull-ups are enabled

INTEDG: Interrupt Edge Select bit bit 6:

1 = Interrupt on rising edge of RB0/INT pin 0 = Interrupt on falling edge of RB0/INT pin

TOCS: TMR0 Clock Source Select bit 1 = Transition on RA4/TOCKI pin

0 = Internal instruction cycle clock (CLKOUT)

TOSE: TMR0 Source Edge Select bit bit 4:

1 = Increment on high-to-low transition on RA4/TOCKI pin

0 = Increment on low-to-high transition on RA4/TOCKI pin

bit 3: PSA: Prescaler Assignment bit

1 = Prescaler assigned to the WDT

0 = Prescaler assigned to TMR0

PS2:PS0: Prescaler Rate Select bits hit 2-0.

| Bit Value | TMR0 Rate | WDT Rate |  |  |
|-----------|-----------|----------|--|--|
| 000       | 1:2       | 1:1      |  |  |
| 001       | 1:4       | 1:2      |  |  |
| 010       | 1:8       | 1:4      |  |  |
| 011       | 1 : 16    | 1:8      |  |  |
| 100       | 1:32      | 1 : 16   |  |  |
| 101       | 1:64      | 1:32     |  |  |
| 110       | 1 : 128   | 1:64     |  |  |
| 111       | 1 · 256   | 1 · 128  |  |  |

# INTCON Register (0Bh, 8Bh)

| G | iΕ | EEIE | T0IE | INTE | RBIE | T0IF | INTF | RBIF |
|---|----|------|------|------|------|------|------|------|
|---|----|------|------|------|------|------|------|------|

bit 7: GIE: Global Interrupt Enable bit.

1 = Enables all un-masked interrupts

0 = Disables all interrupts

bit 6: **EEIE**: EE Write Complete Interrupt Enable bit.

1 = Enables the EE write complete interrupt

0 = Disables the EE write complete interrupt

T0IE: TMR0 Overflow Interrupt Enable bit bit 5:

1 = Enables the TMR0 interrupt 0 = Disables the TMR0 interrupt

bit 4.

INTE: RB0/INT Interrupt Enable bit 1 = Enables the RB0/INT interrupt

0 = Disables the RB0/INT interrupt

RBIE: RB Port Change Interrupt Enable bit bit 3:

1 = Enables the RB port change interrupt

0 = Disables the RB port change interrupt

bit 2: T0IF: TMR0 overflow interrupt flag bit

1 = TMR0 has overflowed

0 = TMR0 did not overflow

INTF: RB0/INT Interrupt Flag bit bit 1:

1 = The RB0/INT interrupt occurred

0 = The RB0/INT interrupt did not occur

RBIF: RB Port Change Interrupt Flag bit bit 0:

1 = When at least one of the RB7:RB4 pins changed state

0 = None of the RB7:RB4 bits have changed state

NB: Bits 0 to 2 must be cleared in software before re-enabling interrupts!