#### 4.1 Introduction

The high performance of the PICmicro<sup>™</sup> devices can be attributed to a number of architectural features commonly found in RISC microprocessors. These include:

- · Harvard architecture
- Long Word Instructions
- Single Word Instructions
- Single Cycle Instructions
- Instruction Pipelining
- Reduced Instruction Set
- Register File Architecture
- Orthogonal (Symmetric) Instructions

Figure 4-2 shows a simple core memory bus arrangement for Mid-Range MCU devices.

#### Harvard Architecture:

Harvard architecture has the program memory and data memory as separate memories and are accessed from separate buses. This improves bandwidth over traditional von Neumann architecture in which program and data are fetched from the same memory using the same bus. To execute an instruction, a von Neumann machine must make one or more (generally more) accesses across the 8-bit bus to fetch the instruction. Then data may need to be fetched, operated on, and possibly written. As can be seen from this description, that bus can be extremely conjested. While with a Harvard architecture, the instruction is fetched in a single instruction cycle (all 14-bits). While the program memory is being accessed, the data memory is on an independent bus and can be read and written. These separated buses allow one instruction to execute while the next instruction is fetched. A comparison of Harvard vs. von-Neumann architectures is shown in Figure 4-1.





#### Long Word Instructions:

Long word instructions have a wider (more bits) instruction bus than the 8-bit Data Memory Bus. This is possible because the two buses are separate. This further allows instructions to be sized differently than the 8-bit wide data word which allows a more efficient use of the program memory, since the program memory width is optimized to the architectural requirements.

#### **Single Word Instructions:**

Single Word instruction opcodes are 14-bits wide making it possible to have all single word instructions. A 14-bit wide program memory access bus fetches a 14-bit instruction in a single cycle. With single word instructions, the number of words of program memory locations equals the number of instructions for the device. This means that all locations are valid instructions.

Typically in the von Neumann architecture, most instructions are multi-byte. In general, a device with 4-KBytes of program memory would allow approximately 2K of instructions. This 2:1 ratio is generalized and dependent on the application code. Since each instruction may take multiple bytes, there is no assurance that each location is a valid instruction.

#### **Instruction Pipeline:**

The instruction pipeline is a two-stage pipeline which overlaps the fetch and execution of instructions. The fetch of the instruction takes one TCY, while the execution takes another TCY. However, due to the overlap of the fetch of current instruction and execution of previous instruction, an instruction is fetched and another instruction is executed every single TCY.

#### **Single Cycle Instructions:**

With the Program Memory bus being 14-bits wide, the entire instruction is fetched in a single machine cycle (TCY). The instruction contains all the information required and is executed in a single cycle. There may be a one cycle delay in execution if the result of the instruction modified the contents of the Program Counter. This requires the pipeline to be flushed and a new instruction to be fetched.

#### **Reduced Instruction Set:**

When an instruction set is well designed and highly orthogonal (symmetric), fewer instructions are required to perform all needed tasks. With fewer instructions, the whole set can be more rapidly learned.

#### **Register File Architecture:**

The register files/data memory can be directly or indirectly addressed. All special function registers, including the program counter, are mapped in the data memory.

#### **Orthogonal (Symmetric) Instructions:**

Orthogonal instructions make it possible to carry out any operation on any register using any addressing mode. This symmetrical nature and lack of "special instructions" make programming simple yet efficient. In addition, the learning curve is reduced significantly. The mid-range instruction set uses only two non-register oriented instructions, which are used for two of the cores features. One is the SLEEP instruction which places the device into the lowest power use mode. The other is the CLRWDT instruction which verifies the chip is operating properly by preventing the on-chip Watchdog Timer (WDT) from overflowing and resetting the device.

# PICmicro MID-RANGE MCU FAMILY





#### 4.2 **Clocking Scheme/Instruction Cycle**

The clock input (from OSC1) is internally divided by four to generate four non-overlapping quadrature clocks, namely Q1, Q2, Q3, and Q4. Internally, the program counter (PC) is incremented every Q1, and the instruction is fetched from the program memory and latched into the instruction register in Q4. The instruction is decoded and executed during the following Q1 through Q4. The clocks and instruction execution flow are illustrated in Figure 4-3, and Example 4-1.





4

#### 4.3 Instruction Flow/Pipelining

An "Instruction Cycle" consists of four Q cycles (Q1, Q2, Q3, and Q4). Fetch takes one instruction cycle while decode and execute takes another instruction cycle. However, due to Pipelining, each instruction effectively executes in one cycle. If an instruction causes the program counter to change (e.g. GOTO) then an extra cycle is required to complete the instruction (Example 4-1).

The instruction fetch begins with the program counter incrementing in Q1.

In the **execution** cycle, the fetched instruction is latched into the "Instruction Register (IR)" in cycle Q1. This instruction is then decoded and executed during the Q2, Q3, and Q4 cycles. Data memory is read during Q2 (operand read) and written during Q4 (destination write).

Example 4-1 shows the operation of the two stage pipeline for the instruction sequence shown. At time TcY0, the first instruction is fetched from program memory. During TcY1, the first instruction executes while the second instruction is fetched. During TcY2, the second instruction executes while the third instruction is fetched. During TcY3, the fourth instruction is fetched while the third instruction (CALL SUB\_1) is executed. When the third instruction completes execution, the CPU forces the address of instruction four onto the Stack and then changes the Program Counter (PC) to the address of SUB\_1. This means that the instruction that was fetched during TcY3 needs to be "flushed" from the pipeline. During TcY4, instruction four is flushed (executed as a NOP) and the instruction at address SUB\_1 is fetched. Finally during TcY5, instruction five is executed and the instruction at address SUB\_1 + 1 is fetched.



#### Example 4-1: Instruction Pipeline Flow

All instructions are single cycle, except for any program branches. These take two cycles since the fetch instruction is "flushed" from the pipeline while the new instruction is being fetched and then executed.

| Mnemonic,<br>Operands                  |         |                              |        | 14-Bit Instruction Word |      |       |      | Status           |       |
|----------------------------------------|---------|------------------------------|--------|-------------------------|------|-------|------|------------------|-------|
|                                        |         | Description                  | Cycles | MSb                     |      |       | LSb  | Bits<br>Affected | Notes |
| BYTE-ORIENTED FILE REGISTER OPERATIONS |         |                              |        |                         |      |       |      |                  |       |
| 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   |
| <b>BIT-ORIENT</b>                      | ED FILE | REGISTER OPERATIONS          |        | 1                       |      |       |      |                  |       |
| 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     |
|                                        | ,       | ROL OPERATIONS               |        |                         |      |       |      |                  | -     |
| 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 | 10,10            |       |
| 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,00,2           |       |
| NONLIN                                 | r.      |                              |        | 1 I I                   | TOTO | VVVV  | VVVV | 4                |       |

#### Table 5-1: Mid-Range MCU Instruction Set

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'.

2: 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.

3: 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.

#### 5.2 General Instruction Format

The Mid-Range MCU instructions can be broken down into four general formats as shown in Figure 5-1. As can be seen the opcode for the instruction varies from 3-bits to 6-bits. This variable opcode size is what allows 35 instructions to be implemented.





#### 5.3 Central Processing Unit (CPU)

The CPU can be thought of as the "brains" of the device. It is responsible for fetching the correct instruction for execution, decoding that instruction, and then executing that instruction.

The CPU sometimes works in conjunction with the ALU to complete the execution of the instruction (in arithmetic and logical operations).

The CPU controls the program memory address bus, the data memory address bus, and accesses to the stack.

#### 5.4 Instruction Clock

Each instruction cycle (TCY) is comprised of four Q cycles (Q1-Q4). The Q cycle time is the same as the device oscillator cycle time (Tosc). The Q cycles provide the timing/designation for the Decode, Read, Process Data, Write, etc., of each instruction cycle. The following diagram shows the relationship of the Q cycles to the instruction cycle.

The four Q cycles that make up an instruction cycle (Tcy) can be generalized as:

- Q1: Instruction Decode Cycle or forced No operation
- Q2: Instruction Read Data Cycle or No operation
- Q3: Process the Data
- Q4: Instruction Write Data Cycle or No operation

Each instruction will show a detailed Q cycle operation for the instruction.

#### Figure 5-2: Q Cycle Activity



#### 5.5 **Arithmetic Logical Unit (ALU)**

PICmicro MCUs contain an 8-bit ALU and an 8-bit working register. The ALU is a general purpose arithmetic and logical unit. It performs arithmetic and Boolean functions between the data in the working register and any register file.



Figure 5-3: Operation of the ALU and W Register

The ALU is 8-bits wide and is capable of addition, subtraction, shift and logical operations. Unless otherwise mentioned, arithmetic operations are two's complement in nature. In two-operand instructions, typically one operand is the working register (W register). The other operand is a file register or an immediate constant. In single operand instructions, the operand is either the W register or a file register.

The W register is an 8-bit working register used for ALU operations. It is not an addressable register.

Depending on the instruction executed, the ALU may affect the values of the Carry (C), Digit Carry (DC), and Zero (Z) bits in the STATUS register. The C and DC bits operate as a borrow bit and a digit borrow out bit, respectively, in subtraction. See the SUBLW and SUBWF instructions for examples.

#### 5.6 STATUS Register

The STATUS register, shown in Figure 5-1, contains the arithmetic status of the ALU, the RESET status and the bank select bits for data memory. Since the selection of the Data Memory banks is controlled by this register, it is required to be present in every bank. Also, this register is in the same relative position (offset) in each bank (see Figure 6-5: "Register File Map" in the "Memory Organization" section).

The STATUS register can be the destination for any instruction, as with any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the  $\overline{TO}$  and  $\overline{PD}$  bits are not writable. Therefore, the result of an instruction with the STATUS register as destination may be different than intended.

For example, CLRF STATUS will clear the upper-three bits and set the Z bit. This leaves the STATUS register as  $000u \ uluu$  (where u = unchanged).

It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF instructions are used to alter the STATUS register because these instructions do not affect the Z, C or DC bits from the STATUS register. For other instructions, not affecting any status bits, see Table 5-1.

- Note 1: Some devices do not require the IRP and RP1 (STATUS<7:6>) bits. These bits are not used by the Section 5. CPU and ALU and should be maintained clear. Use of these bits as general purpose R/W bits is NOT recommended, since this may affect upward code compatibility with future products.
- **Note 2:** The C and DC bits operate as a borrow and digit borrow bit, respectively, in subtraction.

Register 5-1: STATUS Register

|     | R/W-0                               | R/W-0                                                                             | R/W-0                              | R-1              | R-1           | R/W-x        | R/W-x        | R/W-x         |
|-----|-------------------------------------|-----------------------------------------------------------------------------------|------------------------------------|------------------|---------------|--------------|--------------|---------------|
|     | IRP                                 | RP1                                                                               | RP0                                | TO               | PD            | Z            | DC           | С             |
|     | bit 7                               |                                                                                   |                                    |                  |               |              |              | bit 0         |
| 7   | 1 = Bank 2                          | ter Bank Sele<br>2, 3 (100h - 1F<br>0, 1 (00h - FFt                               | Fh)                                | or indirect a    | ddressing)    |              |              |               |
|     | For device                          | s with only Ba                                                                    | ink0 and Bar                       | hk1 the IRP      | oit is reserv | ed, always   | maintain th  | is bit clear. |
| 6:5 | 11 = Bank<br>10 = Bank<br>01 = Bank | Register Banl<br>3 (180h - 1FF<br>2 (100h - 17F<br>1 (80h - FFh)<br>0 (00h - 7Fh) | <sup>-</sup> h)<br><sup>-</sup> h) | (used for dir    | ect address   | sing)        |              |               |
|     |                                     | is 128 bytes.                                                                     |                                    | with only Ba     | nk0 and Ba    | ank1 the IRI | Dit is rese  | rved,         |
| 4   | <b>TO</b> : Time-c<br>1 = After p   |                                                                                   | NDT instructio                     | ON, OF SLEEP     | instruction   |              |              |               |
| 3   |                                     | -down bit<br>ower-up or by<br>cution of the s                                     |                                    |                  |               |              |              |               |
| 2   |                                     | sult of an arith<br>sult of an arith                                              | 0                                  |                  |               |              |              |               |
| 1   | is reversed<br>1 = A carry          | arry/borrow b<br>l)<br>/-out from the<br>ry-out from th                           | 4th low orde                       | er bit of the re | esult occurr  | ,            | (for borrow  | the polarity  |
| 0   | <b>C</b> : Carry/bo<br>1 = A carry  | orrow bit (ADD<br>-out from the<br>ry-out from th                                 | WF, ADDLW , S<br>most signific     | UBLW, SUBWF      | instructior   | urred        |              |               |
|     | Note:                               | For borrow the                                                                    |                                    | nd operand.      | For rotate    | (RRF, RLF)   | instructions | 0             |

| U = Unimplemented bit | , read as '0'    | - n = Value at POR reset |  |
|-----------------------|------------------|--------------------------|--|
| R = Readable bit      | W = Writable bit |                          |  |
| Legend                |                  |                          |  |

#### 5.7 OPTION\_REG Register

The OPTION\_REG register is a readable and writable register which contains various control bits to configure the TMR0/WDT prescaler, the external INT Interrupt, TMR0, and the weak pull-ups on PORTB.

#### Register 5-2: OPTION\_REG Register

| R/W   | ·1 | R/W-1  | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 |
|-------|----|--------|-------|-------|-------|-------|-------|-------|
| RBP   | Ū  | INTEDG | TOCS  | T0SE  | PSA   | PS2   | PS1   | PS0   |
| bit 7 |    |        |       |       |       |       |       | bit 0 |

bit 7 **RBPU:** PORTB Pull-up Enable bit 1 = PORTB pull-ups are disabled 0 = PORTB pull-ups are enabled by individual port latch values INTEDG: Interrupt Edge Select bit bit 6 1 = Interrupt on rising edge of INT pin 0 = Interrupt on falling edge of INT pin bit 5 TOCS: TMR0 Clock Source Select bit 1 = Transition on T0CKI pin 0 = Internal instruction cycle clock (CLKOUT) TOSE: TMR0 Source Edge Select bit bit 4 1 = Increment on high-to-low transition on T0CKI pin 0 = Increment on low-to-high transition on T0CKI pin bit 3 PSA: Prescaler Assignment bit 1 = Prescaler is assigned to the WDT 0 = Prescaler is assigned to the Timer0 module bit 2-0 PS2:PS0: Prescaler Rate Select bits WOT D Bi

| it 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  |
|          |           |          |

| Legend                 |                  |                          |
|------------------------|------------------|--------------------------|
| R = Readable bit       | W = Writable bit |                          |
| U = Unimplemented bit, | read as '0'      | - n = Value at POR reset |

**Note:** To achieve a 1:1 prescaler assignment for the TMR0 register, assign the prescaler to the Watchdog Timer.

#### 5.8 PCON Register

The Power Control (PCON) register contains flag bit(s), that together with the TO and PD bits, allows the user to differentiate between the device resets.

| Note 1: | $\overline{\text{BOR}}$ is unknown on Power-on Reset. It must then be set by the user and checked on subsequent resets to see if $\overline{\text{BOR}}$ is clear, indicating a brown-out has occurred. The $\overline{\text{BOR}}$ status bit is a don't care and is not necessarily predictable if the brown-out circuit is disabled (by clearing the BODEN bit in the Configuration word). |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Note 2: | It is recommended that the $\overrightarrow{POR}$ bit be cleared after a power-on reset has been detected, so that subsequent power-on resets may be detected.                                                                                                                                                                                                                                |

#### Register 5-3: PCON Register

| R-u   | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 |
|-------|-----|-----|-----|-----|-------|-------|-------|
| MPEEN | —   | _   | _   | _   | PER   | POR   | BOR   |
| bit 7 |     |     |     |     |       |       | bit 0 |

#### bit 7 **MPEEN**: Memory Parity Error Circuitry Status bit This bit reflects the value of the MPEEN configuration bit.

#### bit 6:3 Unimplemented: Read as '0'

- bit 2 **PER**: Memory Parity Error Reset Status bit
  - 1 = No error occurred
  - 0 = A program memory fetch parity error occurred (must be set in software after a Power-on Reset occurs)
- bit 1 **POR**: Power-on Reset Status bit
  - 1 = No Power-on Reset occurred0 = A Power-on Reset occurred (must be set in software after a Power-on Reset occurs)

#### bit 0 **BOR**: Brown-out Reset Status bit

- 1 = No Brown-out Reset occurred
  - 0 = A Brown-out Reset occurred (must be set in software after a Brown-out Reset occurs)

| Legend |
|--------|
|        |

- R = Readable bit W = Writable bit
- U = Unimplemented bit, read as '0' n = Va

n = Value at POR reset

© 1997 Microchip Technology Inc.

### Section 6. Memory Organization





6

#### 6.2.1 Reset Vector

On any device, a reset forces the Program Counter (PC) to address 0h. We call this address the "Reset Vector Address" since this is the address that program execution will branch to when a device reset occurs.

Any reset will also clear the contents of the PCLATH register. This means that any branch at the Reset Vector Address (0h) will jump to that location in PAGE0 of the program memory.

#### 6.2.2 Interrupt Vector

When an interrupt is acknowledged the PC is forced to address 0004h. We call this the "Interrupt Vector Address". When the PC is forced to the interrupt vector, the PCLATH register is not modified. Once in the service interrupt routine (ISR), this means that before any write to the PC, the PCLATH register should be written with the value that will specify the desired location in program memory. Before the PCLATH register is modified by the Interrupt Service Routine (ISR) the contents of the PCLATH may need to be saved, so it can be restored before returning from the ISR.

#### 6.2.3 Calibration Information

Some devices have calibration information stored in their program memory. This information is programmed by Microchip when the device is under final test. The use of these values allows the application to achieve better results. The calibration information is typically at the end of program memory, and is implemented as a RETLW instruction with the literal value being the specified calibration information.

**Note:** For windowed devices, write down all calibration values **BEFORE** erasing. This allows the device's calibration values to be restored when the device is re-programmed. When possible writing the values on the package is recommended.

### 6.2.4 Program Counter (PC)

The program counter (PC) specifies the address of the instruction to fetch for execution. The PC is 13-bits wide. The low byte is called the PCL register. This register is readable and writable. The high byte is called the PCH register. This register contains the PC<12:8> bits and is not directly readable or writable. All updates to the PCH register go through the PCLATH register.

Figure 6-2 shows the four situations for the loading of the PC. Situation 1 shows how the PC is loaded on a write to PCL (PCLATH<4:0>  $\rightarrow$  PCH). Situation 2 shows how the PC is loaded during a GOTO instruction (PCLATH<4:3>  $\rightarrow$  PCH). Situation 3 shows how the PC is loaded during a CALL instruction (PCLATH<4:3>  $\rightarrow$  PCH), with the PC loaded (PUSHed) onto the Top of Stack. Situation 4 shows how the PC is loaded during one of the return instructions where the PC loaded (POPed) from the Top of Stack.





0

#### 6.2.4.1 Computed GOTO

A computed GOTO is accomplished by adding an offset to the program counter (ADDWF PCL). When doing a table read using a computed GOTO method, care should be exercised if the table location crosses a PCL memory boundary (each 256 byte block).

```
Note: Any write to the Program Counter (PCL), will cause the lower five bits of the PCLATH to be loaded into PCH.
```

#### 6.2.5 Stack

The stack allows a combination of up to 8 program calls and interrupts to occur. The stack contains the return address from this branch in program execution.

Mid-Range MCU devices have an 8-level deep x 13-bit wide hardware stack. The stack space is not part of either program or data space and the stack pointer is not readable or writable. The PC is PUSHed onto the stack when a CALL instruction is executed or an interrupt causes a branch. The stack is POPed in the event of a RETURN, RETLW or a RETFIE instruction execution. PCLATH is not modified when the stack is PUSHed or POPed.

After the stack has been PUSHed eight times, the ninth push overwrites the value that was stored from the first push. The tenth push overwrites the second push (and so on). An example of the overwriting of the stack is shown in Figure 6-3.



Figure 6-3: Stack Modification

Note 1: There are no status bits to indicate stack overflow or stack underflow conditions.

Note 2: There are no instructions/mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL, RETURN, RETLW, and RETFIE instructions, or the vectoring to an interrupt address.

### 6.2.6 Program Memory Paging

Some devices have program memory sizes greater then 2K words, but the CALL and GOTO instructions only have a 11-bit address range. This 11-bit address range allows a branch within a 2K program memory page size. To allow CALL and GOTO instructions to address the entire 1K program memory address range, there must be another two bits to specify the program memory page. These paging bits come from the PCLATH<4:3> bits (Figure 6-2). When doing a CALL or GOTO instruction, the user must ensure that page bits (PCLATH<4:3>) are programmed so that the desired program memory page is addressed (Figure 6-2). When one of the return instructions is executed, the entire 13-bit PC is POPed from the stack. Therefore, manipulation of the PCLATH<4:3> is not required for the return instructions.

Devices with program memory sizes between 2K words and 4K words, ignore the paging bit (PCLATH<4>), which is used to access program memory pages 2 and 3 (1000h - 1FFFh). The use of PCLATH<4> as a general purpose read/write bit (for these devices) is not recommended since this may affect upward compatibility with future products.

Example 6-1 shows the calling of a subroutine in page 1 of the program memory. This example assumes that PCLATH is saved and restored by the interrupt service routine (if interrupts are used).

#### Example 6-1: Call of a Subroutine in Page1 from Page0

| ORG 0x500     |                                                  |
|---------------|--------------------------------------------------|
| BSF PCLATH, 3 | ; Select Pagel (800h-FFFh)                       |
| CALL SUB1_P1  | ; Call subroutine in Page1 (800h-FFFh)           |
| :             | ;                                                |
| :             | i                                                |
| ORG 0x900     | i                                                |
| SUB1_P1:      | ; called subroutine Page1 (800h-FFFh)            |
| :             | i                                                |
| RETURN        | ; return to Call subroutine in Page0 (000h-7FFh) |
|               | i                                                |
|               |                                                  |

#### 6.3 Data Memory Organization

Data memory is made up of the Special Function Registers (SFR) area, and the General Purpose Registers (GPR) area. The SFRs control the operation of the device, while GPRs are the general area for data storage and scratch pad operations.

The data memory is banked for both the GPR and SFR areas. The GPR area is banked to allow greater than 96 bytes of general purpose RAM to be addressed. SFRs are for the registers that control the peripheral and core functions. Banking requires the use of control bits for bank selection. These control bits are located in the STATUS Register (STATUS<7:5>). Figure 6-5 shows one of the data memory map organizations, this organization is device dependent.

To move values from one register to another register, the value must pass through the W register. This means that for all register-to-register moves, two instruction cycles are required.

The entire data memory can be accessed either directly or indirectly. Direct addressing may require the use of the RP1:RP0 bits. Indirect addressing requires the use of the File Select Register (FSR). Indirect addressing uses the Indirect Register Pointer (IRP) bit of the STATUS register for accesses into the Bank0 / Bank1 or the Bank2 / Bank3 areas of data memory.

#### 6.3.1 General Purpose Registers (GPR)

Some Mid-Range MCU devices have banked memory in the GPR area. GPRs are not initialized by a Power-on Reset and are unchanged on all other resets.

The register file can be accessed either directly, or using the File Select Register FSR, indirectly. Some devices have areas that are shared across the data memory banks, so a read / write to that area will appear as the same location (value) regardless of the current bank. We refer to this area as the Common RAM.

#### 6.3.2 Special Function Registers (SFR)

The SFRs are used by the CPU and Peripheral Modules for controlling the desired operation of the device. These registers are implemented as static RAM.

The SFRs can be classified into two sets, those associated with the "core" function and those related to the peripheral functions. Those registers related to the "core" are described in this section, while those related to the operation of the peripheral features are described in the section of that peripheral feature.

All Mid-Range MCU devices have banked memory in the SFR area. Switching between these banks requires the RP0 and RP1 bits in the STATUS register to be configured for the desired bank. Some SFRs are initialized by a Power-on Reset and other resets, while other SFRs are unaffected.

**Note:** The Special Function Register (SFR) Area may have General Purpose Registers (GPRs) mapped in these locations.

The register file can be accessed either directly, or using the File Select Register FSR, indirectly.

#### 6.3.3 Banking

The data memory is partitioned into four banks. Each bank contains General Purpose Registers and Special Function Registers. Switching between these banks requires the RP0 and RP1 bits in the STATUS register to be configured for the desired bank when using direct addressing. The IRP bit in the STATUS register is used for indirect addressing.

| Table 6-1: | Direct and Indirect | Addressing of Banks |
|------------|---------------------|---------------------|
|------------|---------------------|---------------------|

| Accessed<br>Bank | Direct<br>(RP1:RP0) | Indirect<br>(IRP) |
|------------------|---------------------|-------------------|
| 0                | 0 0                 | 0                 |
| 1                | 0 1                 | U                 |
| 2                | 1 0                 | 1                 |
| 3                | 1 1                 | L                 |

Each Bank extends up to 7Fh (128 bytes). The lower locations of each bank are reserved for the Special Function Registers. Above the Special Function Registers are General Purpose Registers. All data memory is implemented as static RAM. All Banks may contain special function registers. Some "high use" special function registers from Bank0 are mirrored in the other banks for code reduction and quicker access.

Through the evolution of the products, there are a few variations in the layout of the Data Memory. The data memory organization that will be the standard for all new devices is shown in Figure 6-5. This Memory map has the last 16-bytes mapped across all memory banks. This is to reduce the software overhead for context switching. The registers in **bold** will be in every device. The other registers are peripheral dependent. Not every peripheral's registers are shown, because some file addresses have a different registers from those shown. As with all the figures, tables, and specifications presented in this reference guide, verify the details with the device specific data sheet.



Figure 6-4: Direct Addressing

6

# PICmicro MID-RANGE MCU FAMILY

|                          | Address |                          | Address |                          | Address |                          | Ad<br>10 |
|--------------------------|---------|--------------------------|---------|--------------------------|---------|--------------------------|----------|
|                          | 00h     |                          | 80h     | INDF                     | 100h    |                          | 18       |
| TMR0                     | 01h     | OPTION_REG               | 81h     | TMR0                     | 101h    | OPTION_REG               | 18       |
| PCL                      | 02h     | PCL                      | 82h     | PCL                      | 102h    | PCL                      | 18       |
| STATUS                   | 03h     | STATUS                   | 83h     | STATUS                   | 103h    | STATUS                   | 18       |
| FSR                      | 04h     | FSR                      | 84h     | FSR                      | 104h    | FSR                      | 18       |
| PORTA                    | 05h     | TRISA                    | 85h     |                          | 105h    |                          | 18       |
| PORTB                    | 06h     | TRISB                    | 86h     | PORTB                    | 106h    | TRISB                    | 18       |
| PORTC                    | 07h     | TRISC                    | 87h     | PORTF                    | 107h    | TRISF                    | 18       |
| PORTD                    | 08h     | TRISD                    | 88h     | PORTG                    | 108h    | TRISG                    | 18       |
| PORTE                    | 09h     | TRISE                    | 89h     |                          | 109h    |                          | 18       |
| PCLATH                   | 0Ah     | PCLATH                   | 8Ah     | PCLATH                   | 10Ah    | PCLATH                   | 18       |
| INTCON                   | 0Bh     | INTCON                   | 8Bh     | INTCON                   | 10Bh    | INTCON                   | 18       |
| PIR1                     | 0Ch     | PIE1                     | 8Ch     |                          | 10Ch    |                          | 18       |
| PIR2                     | 0Dh     | PIE2                     | 8Dh     |                          | 10Dh    |                          | 18       |
| TMR1L                    | 0Eh     | PCON                     | 8Eh     |                          | 10Eh    |                          | 18       |
| TMR1H                    | 0Fh     | OSCCAL                   | 8Fh     |                          | 10Fh    |                          | 18       |
| T1CON                    | 10h     |                          | 90h     |                          | 110h    |                          | 19       |
| TMR2                     | 11h     |                          | 91h     |                          | 111h    |                          | 19       |
| T2CON                    | 12h     | PR2                      | 92h     |                          | 112h    |                          | 19       |
| SSPBUF                   | 13h     | SSPADD                   | 93h     |                          | 113h    |                          | 19       |
| SSPCON                   | 14h     | SSPATAT                  | 94h     |                          | 114h    |                          | 19       |
| CCPR1L                   | 15h     |                          | 95h     |                          | 115h    |                          | 19       |
| CCPR1H                   | 16h     |                          | 96h     |                          | 116h    |                          | 19       |
| CCP1CON                  | 17h     |                          | 97h     |                          | 117h    |                          | 19       |
| RCSTA                    | 18h     | TXSTA                    | 98h     |                          | 118h    |                          | 19       |
| TXREG                    | 19h     | SPBRG                    | 99h     |                          | 119h    |                          | 19       |
| RCREG                    | 1Ah     |                          | 9Ah     |                          | 11Ah    |                          | 19       |
| CCPR2L                   | 1Bh     |                          | 9Bh     |                          | 11Bh    |                          | 19       |
| CCPR2H                   | 1Ch     |                          | 9Ch     |                          | 11Ch    |                          | 19       |
| CCP2CON                  | 1Dh     |                          | 9Dh     |                          | 11Dh    |                          | 19       |
| ADRES                    | 1Eh     |                          | 9Eh     |                          | 11Eh    |                          | 19       |
| ADCON0                   | 1Fh     | ADCON1                   | 9Fh     |                          | 11Fh    |                          | 19       |
|                          | 20h     |                          | A0h     |                          | 120h    |                          | 1A       |
|                          |         | General                  |         | General                  |         | General                  |          |
| General                  |         | Purpose                  |         | Purpose                  |         | Purpose                  |          |
| Purpose                  |         | Registers (3)            | EFh     | Registers (3)            | 16Fh    | Registers <sup>(3)</sup> | 1E       |
| Registers <sup>(2)</sup> |         | Mapped in<br>Bank0       | F0h     | Mapped in<br>Bank0       | 170h    | Mapped in<br>Bank0       | 1F       |
|                          | 7Fh     | 70h - 7Fh <sup>(4)</sup> | FFh     | 70h - 7Fh <sup>(4)</sup> | 17Fh    | 70h - 7Fh <sup>(4)</sup> | 1F       |
| Bank0                    |         | Bank1                    |         | Bank2 <sup>(5)</sup>     | _       | Bank3 <sup>(5)</sup>     | -        |

2: Not all locations may be implemented. Unimplemented locations will read as '0'.

3: These locations may not be implemented. Depending on the device, accesses to the unimplemented locations operate differently. Please refer to the specific device data sheet for details.

4: Some device do not map these registers into Bank0. In devices where these registers are mapped into Bank0, these registers are referred to as common RAM

5: Some devices may not implement these banks. Locations in unimplemented banks will read as '0'.

6: General Purpose Registers (GPRs) may be located in the Special Function Register (SFR) area.

### **Section 6. Memory Organization**

The map in Figure 6-6 shows the register file memory map of some 18-pin devices. Unimplemented registers will read as '0'.

| Figure 6-6: | Register | File Map |
|-------------|----------|----------|
|-------------|----------|----------|

|                               | File         |                                                | File    |
|-------------------------------|--------------|------------------------------------------------|---------|
|                               | Address      |                                                | Address |
| INDF                          | 00h          | INDF                                           | 80h     |
| TMR0                          | 01h          | OPTION_REG                                     | 81h     |
| PCL                           | 02h          | PCL                                            | 82h     |
| STATU                         | <b>S</b> 03h | STATUS                                         | 83h     |
| FSR                           | 04h          | FSR                                            | 84h     |
| PORTA                         | <b>A</b> 05h | TRISA                                          | 85h     |
| PORTE                         | <b>3</b> 06h | TRISB                                          | 86h     |
|                               | 07h          | PCON                                           | 87h     |
| ADCON<br>EEDATA               |              | ADCON1 /<br>EECON1 <sup>(2)</sup>              | 88h     |
| ADRES<br>EEADR                |              | ADRES /<br>EECON2 <sup>(2)</sup>               | 89h     |
| PCLAT                         | H 0Ah        | PCLATH                                         | 8Ah     |
| INTCO                         | N 0Bh        | INTCON                                         | 8Bh     |
| Genera<br>Purpos<br>Registers | e            | General<br>Purpose<br>Registers <sup>(4)</sup> | 8Ch     |
| Bank0                         |              | Bank1                                          | ]       |

Note 1: Registers in **BOLD** will be present in every device.

- 2: These registers may not be implemented, or are implemented as other registers in some devices.
- 3: Not all locations may be implemented. Unimplemented locations will read as '0'.
- 4: These locations are unimplemented in Bank1. Access to these unimplemented locations will access the corresponding Bank0 register.

6

#### 6.3.4 Indirect Addressing, INDF, and FSR Registers

Indirect addressing is a mode of addressing data memory where the data memory address in the instruction is not fixed. An SFR register is used as a pointer to the data memory location that is to be read or written. Since this pointer is in RAM, the contents can be modified by the program. This can be useful for data tables in the data memory. Figure 6-7 shows the operation of indirect addressing. This shows the moving of the value to the data memory address specified by the value of the FSR register.

Indirect addressing is possible by using the INDF register. Any instruction using the INDF register actually accesses the register pointed to by the File Select Register, FSR. Reading the INDF register itself indirectly (FSR = '0') will read 00h. Writing to the INDF register indirectly results in a no-operation (although status bits may be affected). An effective 9-bit address is generated by the concatenation of the IRP bit (STATUS<7>) with the 8-bit FSR register, as shown in Figure 6-8.



Figure 6-7: Indirect Addressing

## Section 6. Memory Organization



Figure 6-8: Indirect Addressing

Example 6-2 shows a simple use of indirect addressing to clear RAM (locations 20h-2Fh) in a minimum number of instructions. A similar concept could be used to move a defined number of bytes (block) of data to the USART transmit register (TXREG). The starting address of the block of data to be transmitted could easily be modified by the program.

#### Example 6-2: Indirect Addressing

|          | BCF<br>MOVLW | STATUS, IRP<br>0x20 | ; Indirect addressing Bank0/1<br>; Initialize pointer to RAM |
|----------|--------------|---------------------|--------------------------------------------------------------|
|          | MOVWF        | FSR                 | ;                                                            |
| NEXT     | CLRF         | INDF                | ; Clear INDF register                                        |
|          | INCF         | FSR,F               | ; Inc pointer                                                |
|          | BTFSS        | FSR,4               | ; All done?                                                  |
|          | GOTO         | NEXT                | ; NO, clear next                                             |
| CONTINUE |              |                     | i                                                            |
|          | :            |                     | ; YES, continue                                              |
|          |              |                     |                                                              |

6

© 1997 Microchip Technology Inc.

#### 6.4 Initialization

Example 6-3 shows how the bank switching occurs for Direct addressing, while Example 6-4 shows some code to do initialization (clearing) of General Purpose RAM.

Example 6-3: Bank Switching

| CLRF  | STATUS  |     | ; | Clear STATUS register (Bank0)             |
|-------|---------|-----|---|-------------------------------------------|
| :     |         |     | ; |                                           |
| BSF   | STATUS, | RP0 | ; | Bank1                                     |
| :     |         |     | ; |                                           |
| BCF   | STATUS, | RP0 | ; | Bank0                                     |
| :     |         |     | ; |                                           |
| MOVLW | 0x60    |     | ; | Set RPO and RP1 in STATUS register, other |
| XORWF | STATUS, | F   | ; | bits unchanged (Bank3)                    |
| :     |         |     | ; |                                           |
| BCF   | STATUS, | RP0 | ; | Bank2                                     |
| :     |         |     | ; |                                           |
| BCF   | STATUS, | RP1 | ; | Bank0                                     |
|       |         |     |   |                                           |

#### 6.5 Design Tips

#### Question 1: Program execution seems to get lost.

#### Answer 1:

When a device with more then 2K words of program memory is used, the calling of subroutines may require that the PCLATH register be loaded prior to the CALL (or GOTO) instruction to specify the correct program memory page that the routine is located on. The following instructions will correctly load PCLATH register, regardless of the program memory location of the label SUB\_1.

|       | MOVLW<br>MOVWF | HIGH (SUB_1)<br>PCLATH | ; Select Program Memory Page of<br>; Routine. |
|-------|----------------|------------------------|-----------------------------------------------|
|       | CALL           | SUB_1                  | ; Call the desired routine                    |
|       | :              |                        |                                               |
|       | :              |                        |                                               |
| SUB_1 | :              |                        | ; Start of routine                            |
|       | :              |                        |                                               |
|       | RETURN         |                        | ; Return from routine                         |

### Question 2: I need to initialize RAM to '0's. What is an easy way to do that?

#### Answer 2:

Example 6-4 shows this. If the device you are using does not use all 4 data memory banks, some of the code may be removed.

| Operands         Iso         MSb         LSb         Affected           BYTE-ORIENTED FILE REGISTER OPERATIONS           ADDWF         f, d         AdW and f         1         00         0111         dfff         ffff         Z         2           ADDWF         f, d         AdW and f         1         00         0101         dfff         ffff         Z         1,2           CLRF         f         Clear M         1         00         0001         dfff         ffff         Z         2           COMF         f, d         Complement f         1         00         0101         dfff         ffff         Z         1,2           DECFS         f, d         Increment f, Skip if 0         1(2)         00         1111         dfff         ffff         Z         1,2           INCFS         f, d         Increment f, Skip if 0         1(2)         00         1111         dfff         ffff         Z         1,2           MOVF         f, d         Move f         1         00         1000         dfff         fff         Z         1,2           MOVF         f, d         Nove f         1         00         1000         dfff                                                                                                                                                                                                   | Mnemonic,                              |        | Decorintian                 | Qualas | 14-Bit Instruction Wo |      |      | Vord | Status   | Notas |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|--------|-----------------------------|--------|-----------------------|------|------|------|----------|-------|
| ADDWF         f, d         Add W and f         1         00         0111         dfff         fffff         C,DC,Z         1,2           ANDWF         f, d         AND W with f         1         00         0101         dfff         ffff         Z         2           CLRF         f         Clear W         1         00         0001         1fff         ffff         Z         2           COMF         f, d         Complement f         1         00         0011         dfff         ffff         Z         1,2           DECF         f, d         Decrement f, Skip if 0         1(2)         00         1011         dfff         ffff         1,2,3           INCFS         f, d         Increment f, Skip if 0         1(2)         00         1111         dfff         ffff         1,2,3           IORVF         f, d         Inclusive OR W with f         1         00         1000         dfff         ffff         1,2,3           IORVF         f, d         Nove f         1         00         1000         dfff         ffff         1,2         1,2           MOVF         f, d         Rotate Left through Carry         1         00         1100                                                                                                                                                                                   | Operand                                | ls     | Description                 | Cycles | MSb                   |      |      | LSb  | Affected | Notes |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | BYTE-ORIENTED FILE REGISTER OPERATIONS |        |                             |        |                       |      |      |      |          |       |
| CLRF         f         Clear M         1         00         0001         lfff         ffff         Z         2           COMF         -         Clear W         1         00         0001         lfff         fffff         Z         1,2           DECF         f, d         Decrement f         1         00         0011         dfff         fffff         Z         1,2           DECFSZ         f, d         Decrement f         1         00         1010         dfff         fffff         Z         1,2           INCF         f, d         Increment f, Skip if 0         1(2)         00         1111         dffff         fffff         Z         1,2           INCFSZ         f, d         Increment f         1         00         1000         dfff         fffff         Z         1,2           MOVF         f, d         Move f         1         00         1000         dfff         fffff         Z         1,2           MOVF         f, d         Rotate Cleft through Carry         1         00         1100         dfff         fffff         C         1,2           SUBWF         f, d         Subtract W from f         1         00                                                                                                                                                                                                | ADDWF                                  | f, d   | Add W and f                 | 1      | 00                    | 0111 | dfff | ffff | C,DC,Z   | 1,2   |
| CLRW         -         Clear W         1         00         0001         0xxx         xxxxx         Z           COMF         f, d         Complement f         1         00         1001         dfff         ffff         Z         1,2           DECF         f, d         Decrement f, Skip if 0         1(2)         00         1011         dfff         ffff         Z         1,2           INCF         f, d         Increment f, Skip if 0         1(2)         00         1011         dfff         fffff         Z         1,2           INCFSZ         f, d         Increment f, Skip if 0         1(2)         00         1111         dfff         fffff         Z         1,2           INCFSZ         f, d         Move RW with f         1         00         1000         dfff         fffff         Z         1,2           MOVF         f, d         Move W to f         1         00         1000         dfff         fffff         Z         1,2           SUBWF         f, d         Rotate Left fthrough Carry         1         00         1010         dfff         fffff         C,DC,Z         1,2           SUBWF         f, d         Subtract W from f <t< td=""><td>ANDWF</td><td>f, d</td><td>AND W with f</td><td>1</td><td>00</td><td>0101</td><td>dfff</td><td>ffff</td><td></td><td>1,2</td></t<>                              | ANDWF                                  | f, d   | AND W with f                | 1      | 00                    | 0101 | dfff | ffff |          | 1,2   |
| COMF         f, d         Complement f         1         00         1001         dfff         ffff         Z         1,2           DECF         f, d         Decrement f, Skip if 0         1(2)         00         1011         dfff         ffff         Z         1,2           INCF         f, d         Increment f, Skip if 0         1(2)         00         1010         dfff         ffff         Z         1,2           INCFSZ         f, d         Increment f, Skip if 0         1(2)         00         1111         dfff         ffff         Z         1,2           INCF         f, d         Incusive OR W with f         1         00         0100         dfff         ffff         Z         1,2           MOVF         f, d         Move f         1         00         0000         000         000           RLF         f, d         Rotate Left through Carry         1         00         1100         dfff         ffff         C         1,2           SUMAPF         f, d         Subtract W from f         1         00         1100         dfff         ffff         C,DC,Z         1,2           SUMPF         f, d         Subtract W from f         1                                                                                                                                                                            | CLRF                                   | f      | Clear f                     | 1      | 00                    | 0001 | lfff | ffff |          | 2     |
| DECF         f, d         Decrement f, Skip if 0         1         00         0011         dfff         ffff         Z         1,2           DECFSZ         f, d         Increment f, Skip if 0         1(2)         00         1010         dfff         ffff         Z         1,2           INCF         f, d         Increment f, Skip if 0         1(2)         00         1111         dfff         ffff         Z         1,2           INCFSZ         f, d         Increment f, Skip if 0         1(2)         00         1111         dfff         ffff         Z         1,2           INCFSZ         f, d         Inclusive OR W with f         1         00         0100         dfff         ffff         Z         1,2           MOVF         f, d         Move f         1         00         0000         0xx0         0000           RLF         f, d         Rotate Left fhrough Carry         1         00         1100         dfff         ffff         C         1,2           SUBWF         f, d         Subtract W from f         1         00         1110         dfff         ffff         C         1,2           SUBWF         f, d         Subtract W from f         1 </td <td>CLRW</td> <td>-</td> <td>Clear W</td> <td>1</td> <td>00</td> <td>0001</td> <td>0xxx</td> <td>xxxx</td> <td>z</td> <td></td>                            | CLRW                                   | -      | Clear W                     | 1      | 00                    | 0001 | 0xxx | xxxx | z        |       |
| 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         1,2,3           INCFSZ         f, d         Inclusive OR W with f         1         00         1010         dfff         ffff         Z         1,2           MOVF         f, d         Move f         1         00         1000         dfff         ffff         Z         1,2           MOVF         f, d         Move f         1         00         1000         dfff         ffff         Z         1,2           MOVF         f, d         Move f         1         00         1000         dfff         ffff         Z         1,2           MOVF         f, d         Rotate Left fthrough Carry         1         00         1100         dfff         ffff         C         1,2           SUBWF         f, d         Subar nibbles in f         1         00         0110         dfff         ffff         1,2           SUBWF         f, d         Bit Set f         1         01         01bb         bfff                                                                                                                                                                                        | COMF                                   | f, d   | Complement f                | 1      | 00                    | 1001 | dfff | ffff | z        | 1,2   |
| INCF         f, d         Increment f, Skip if 0         1 (2)         00         1010         dfff         ffff         Z         1,2           INCFSZ         f, d         Increment f, Skip if 0         1(2)         00         1111         dfff         ffff         Z         1,2           IORWF         f, d         Inclusive OR W with f         1         00         0100         dfff         ffff         Z         1,2           MOVF         f, d         Move V to f         1         00         1000         dfff         ffff         Z         1,2           MOVF         f         Move W to f         1         00         0000         0xxx0         0000           RLF         f, d         Rotate Left fthrough Carry         1         00         1100         dfff         ffff         C         1,2           SUBWF         f, d         Subract W from f         1         00         0110         dfff         ffff         Z         1,2           SUBWF         f, d         Subract W from f         1         00         0110         dfff         ffff         Z         1,2           SUBLY         f, d         Suprobibes in f         1         01 </td <td>DECF</td> <td>f, d</td> <td>Decrement f</td> <td>1</td> <td>00</td> <td>0011</td> <td>dfff</td> <td>ffff</td> <td>Z</td> <td></td>                              | DECF                                   | f, d   | Decrement f                 | 1      | 00                    | 0011 | dfff | ffff | Z        |       |
| INCF         f, d         Increment f, Skip if 0         1 (2)         00         1010         dfff         ffff         Z         1,2           INCFSZ         f, d         Increment f, Skip if 0         1(2)         00         1111         dfff         ffff         Z         1,2           IORWF         f, d         Inclusive OR W with f         1         00         0100         dfff         ffff         Z         1,2           MOVF         f, d         Move V to f         1         00         1000         dfff         ffff         Z         1,2           MOVF         f         Move W to f         1         00         0000         0xxx0         0000           RLF         f, d         Rotate Left fthrough Carry         1         00         1100         dfff         ffff         C         1,2           SUBWF         f, d         Subract W from f         1         00         0110         dfff         ffff         Z         1,2           SUBWF         f, d         Subract W from f         1         00         0110         dfff         ffff         Z         1,2           SUBLY         f, d         Suprobibes in f         1         01 </td <td>DECFSZ</td> <td>f, d</td> <td>Decrement f, Skip if 0</td> <td>1(2)</td> <td>00</td> <td>1011</td> <td>dfff</td> <td>ffff</td> <td></td> <td>1,2,3</td>          | DECFSZ                                 | f, d   | Decrement f, Skip if 0      | 1(2)   | 00                    | 1011 | 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         0xx0         0000           RLF         f, d         Rotate Left f through Carry         1         00         1010         dfff         ffff         C         1,2           SUBWF         f, d         Rotate Right f through Carry         1         00         1010         dfff         ffff         C         1,2           SUBWF         f, d         Swap nibbles in f         1         00         1100         dfff         ffff         1,2           XORWF         f, d         Exclusive OR W with f         1         01         00bb         bfff         ffff         1,2           XORWF         f, d         Exclusive OR W with f         1         01         00bb         bfff         ffff         1,2           BTSC         f, b         Bit Test f, Skip if Clear         1 (2)         01         10bb         bfff </td <td>INCF</td> <td></td> <td>· · ·</td> <td></td> <td>00</td> <td>1010</td> <td>dfff</td> <td>ffff</td> <td>Z</td> <td></td>                                | INCF                                   |        | · · ·                       |        | 00                    | 1010 | dfff | ffff | Z        |       |
| 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         0xx0         0000           RLF         f, d         Rotate Left f through Carry         1         00         1010         dfff         ffff         C         1,2           SUBWF         f, d         Rotate Right f through Carry         1         00         1010         dfff         ffff         C         1,2           SUBWF         f, d         Swap nibbles in f         1         00         1100         dfff         ffff         1,2           XORWF         f, d         Exclusive OR W with f         1         01         00bb         bfff         ffff         1,2           XORWF         f, d         Exclusive OR W with f         1         01         00bb         bfff         ffff         1,2           BTSC         f, b         Bit Test f, Skip if Clear         1 (2)         01         10bb         bfff </td <td>INCFSZ</td> <td>f, d</td> <td>Increment f, Skip if 0</td> <td>1(2)</td> <td>00</td> <td>1111</td> <td>dfff</td> <td>ffff</td> <td></td> <td>1,2,3</td> | INCFSZ                                 | f, d   | Increment f, Skip if 0      | 1(2)   | 00                    | 1111 | dfff | ffff |          | 1,2,3 |
| MOVF         f, d         Move f         1         00         1000         dfff         fffff         Z         1,2           MOVWF         f         Move W to f         1         00         0000         1fff         fffff         Z         1,2           NOP         -         No Operation         1         00         0000         0xx0         0000         1100         dfff         fffff         C         1,2           RRF         f, d         Rotate Right f through Carry         1         00         1100         dfff         ffff         C         1,2           SUBWF         f, d         Subtract W from f         1         00         1100         dfff         ffff         C,DC,Z         1,2           SWAPF         f, d         Swap nibbles in f         1         00         0110         dfff         ffff         1,2           XORWF         f, d         Exclusive OR W with f         1         00         010bb         bfff         ffff         1,2           SUBTORIENTED FILE         REGSTER OPERATIONS         1         1         01         01bb         bfff         ffff         3           DTFSS         f, b         Bit Test f, Skip i                                                                                                                                                                        | IORWF                                  | f, d   |                             |        | 00                    | 0100 | dfff | ffff | Z        |       |
| 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         C         1,2           RRF         f, d         Subtract W from f         1         00         0100         dfff         ffff         C         1,2           SWAPF         f, d         Swap nibbles in f         1         00         0101         dfff         ffff         Z         1,2           XORWF         f, d         Exclusive OR W with f         1         00         0110         dfff         ffff         Z         1,2           BTFORIENTED FILE         REGISTER OPERATIONS         Bit Clear f         1         01         00bb         bfff         ffff         1,2         3           BTFSC         f, b         Bit Test f, Skip if Clear         1 (2)         01         10bb         bfff         ffff         3           LITERAL AND CONT         Add literal and W         1         11         111         100 <td< td=""><td>MOVF</td><td>f, d</td><td>Move f</td><td>1</td><td>00</td><td>1000</td><td>dfff</td><td>ffff</td><td>z</td><td></td></td<>                             | MOVF                                   | f, d   | Move f                      | 1      | 00                    | 1000 | dfff | ffff | z        |       |
| RLF         f, d         Rotate Left f through Carry         1         00         1101         dfff         ffff         C         1,2           RRF         f, d         Rotate Right f through Carry         1         00         1100         dfff         ffff         C         1,2           SUBWF         f, d         Subtract W from f         1         00         0100         dfff         ffff         C,DC,Z         1,2           SWAPF         f, d         Swap nibbles in f         1         00         0110         dfff         ffff         C,DC,Z         1,2           XORWF         f, d         Exclusive OR W with f         1         00         0110         dfff         ffff         Z         1,2           BTFORIENTED FILE         REGISTER OPERATIONS         Bit Clear f         1         01         01bb         bfff         ffff         1,2           BSF         f, b         Bit Set f         1         01         01bb         bfff         ffff         1,2           BTFSS         f, b         Bit Test f, Skip if Clear         1 (2)         01         11bb         bfff         ffff         3           LITERAL AND CONTROL OPERATIONS         Add literal and W                                                                                                                                                | MOVWF                                  |        | Move W to f                 | 1      | 00                    | 0000 | lfff | ffff |          |       |
| RLF         f, d         Rotate Left f through Carry         1         00         1101         dfff         ffff         C         1,2           RRF         f, d         Rotate Right f through Carry         1         00         1100         dfff         ffff         C         1,2           SUBWF         f, d         Subtract W from f         1         00         0100         dfff         ffff         C,DC,Z         1,2           SWAPF         f, d         Swap nibbles in f         1         00         0110         dfff         ffff         C,DC,Z         1,2           XORWF         f, d         Exclusive OR W with f         1         00         0110         dfff         ffff         Z         1,2           BTFORIENTED FILE         REGISTER OPERATIONS         Bit Clear f         1         01         01bb         bfff         ffff         1,2           BSF         f, b         Bit Set f         1         01         01bb         bfff         ffff         1,2           BTFSS         f, b         Bit Test f, Skip if Clear         1 (2)         01         11bb         bfff         ffff         3           LITERAL AND CONTROL OPERATIONS         Add literal and W                                                                                                                                                | NOP                                    | -      | No Operation                | 1      | 00                    | 0000 | 0xx0 | 0000 |          |       |
| RRF         f, d         Rotate Right f through Carry         1         00         1100         dfff         ffff         C         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         Z,DC,Z         1,2           XORWF         f, d         Exclusive OR W with f         1         00         0110         dfff         ffff         Z         1,2           BIT-ORIENTED FILE         ECGISTER OPERATIONS          00         0110         dfff         ffff         Z         1,2           BSF         f, b         Bit Clear f         1         01         01bb         bfff         fffff         1,2           BTFSS         f, b         Bit Test f, Skip if Clear         1 (2)         01         10bb         bfff         fffff         3           LITERAL AND CONTROL OPERATIONS         Interst f, Skip if Set         1 (2)         01         11bb         bfff         fffff         3           LITERAL AND Control         Calla with W         1         11                                                                                                                                                       |                                        | f. d   |                             | 1      |                       |      |      |      | С        | 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         0110         dfff         ffff         1,2           XORWF         f, d         Exclusive OR W with f         1         00         0110         dfff         ffff         1,2           BT-ORIENTED FILE         REGISTER OPERATIONS          00         0110         dfff         ffff         Z         1,2           BSF         f, b         Bit Clear f         1         01         00bb         bfff         fffff         1,2           BTFSC         f, b         Bit Test f, Skip if Clear         1 (2)         01         10bb         bfff         fffff         3           ILTERAL AND CONTROL OPERATIONS         I         11         111         111         kkkk         kkkk         Z           ADDLW         k         Add literal and W         1         11         111         100         kkkk         Kkkk         Z           CALL         k         Call subroutine         2         10         0kkkk         kkkk         Z         C <td></td>                                                                      |                                        |        |                             |        |                       |      |      |      |          |       |
| SWAPFf, dSwap nibbles in f1001110dfffffff1,2XORWFf, dExclusive OR W with f1000110dfffffff1,2BIT-ORIENTED FILE REGISTER OPERATIONSBCFf, bBit Clear f10100bbbfffffff1,2BSFf, bBit Set f10101bbbfffffff1,2BTFSCf, bBit Test f, Skip if Clear1 (2)0110bbbfffffff3BTFSSf, bBit Test f, Skip if Set1 (2)0111bbbfffffff3LITERAL AND CONTROL OPERATIONSADDLWkAdd literal and W111111111kkkkkkkkZADDLWkAdd literal and W11111001kkkkkkkkZCALLkCall subroutine2100kkkkkkkZTO,PDGOTOkGo to address2101kkkkkkkZVIORLWkInclusive OR literal with W1111000kkkkZVMOVLWkInclusive OR literal with W1110000000001001RETURN-Return from interrupt200000000001001RETURN-Return from subroutine20000001000TO,PDSUBLWkKeturn with literal in W21101xx <td>SUBWF</td> <td>,</td> <td></td> <td></td> <td>00</td> <td>0010</td> <td>dfff</td> <td>ffff</td> <td>C,DC,Z</td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | SUBWF                                  | ,      |                             |        | 00                    | 0010 | dfff | ffff | C,DC,Z   |       |
| XORWFf, dExclusive OR W with f1000110dfffffffZ1,2BIT-ORIENTED FILE REGISTER OPERATIONSBCFf, bBit Clear f10100bbbfffffff1,2BSFf, bBit Set f10101bbbfffffff1,2BTFSCf, bBit Test f, Skip if Clear1 (2)0110bbbfffffff3BTFSSf, bBit Test f, Skip if Set1 (2)0111bbbfffffff3LITERAL AND CONTROL OPERATIONSADDLWkAdd literal and W111111111.kkkkkkkkADDLWkAdd literal with W1111001kkkkkkkkZCALLkCall subroutine2100kkkkkkkkkkkFO.PDGOTOkGo to address2101kkkkkkkkkkkZIORLWkInclusive OR literal with W1111000kkkkkkkkZMOVLWkMove literal to W11100000001001TO.PDRETURN-Return from interrupt200000000001001TO.PDSUBLWkSubtract W from literal111101xkkkkkkkkKkkk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | SWAPF                                  | f. d   | Swap nibbles in f           | 1      | 00                    | 1110 | dfff | ffff |          |       |
| BCFf, bBit Clear f10100bbbfffffff1,2BSFf, bBit Set f10101bbbfffffff1,2BTFSCf, bBit Test f, Skip if Clear1 (2)0110bbbfffffff3BTFSSf, bBit Test f, Skip if Set1 (2)0111bbbfffffff3LITERAL AND CONTROL OPERATIONSADDLWkAdd literal and W111111xkkkkkkkkZANDLWkAND literal with W1111001kkkkkkkkZCALLkCall subroutine2100kkkkkkkKkkkZCALLkCall subroutine2101kkkkkkkZGOTOkGo to address2101kkkkkkkZIORLWkInclusive OR literal with W111000xkkkkZMOVLWkInclusive OR literal with W111000xkkkkZMOVLWkReturn from interrupt20000001001RETFIE-Return from interrupt200000000001000RETURN-Return from Subroutine20000001000SLEEP-Go into standby mode10000000111TO,PDSUBLWkSubtract W from literal111110xkkkkk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                        | f, d   |                             | 1      | 00                    | 0110 | dfff | ffff | z        |       |
| BSFf, bBit Set f10101bbbfffffff1,2BTFSCf, bBit Test f, Skip if Clear1 (2)0110bbbfffffff3BTFSSf, bBit Test f, Skip if Set1 (2)0111bbbfffffff3LITERAL AND CONTROL OPERATIONSADDLWkAdd literal and W111111kkkkkkkZANDLWkAdd literal with W1111001kkkkkkkkZCALLkCall subroutine2100kkkkkkkkkkkTO,PDGOTOkGo to address2101kkkkkkkZIO,PDGOTOkInclusive OR literal with W1111000kkkkZMOVLWkInclusive OR literal with W11100000001001TO,PDRETLWkReturn from interrupt200000000001001RETLWFETURNRETURN-Return from Subroutine200000000001000SLEEPGo into standby mode100000001100101TO,PDSUBLWkSubtract W from literal111110xkkkkkkkkC,DC,ZI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <b>BIT-ORIENTE</b>                     | D FILE | REGISTER OPERATIONS         | I      |                       |      |      |      |          |       |
| BSFf, bBit Set f10101bbbfffffff1,2BTFSCf, bBit Test f, Skip if Clear1 (2)0110bbbfffffff3BTFSSf, bBit Test f, Skip if Set1 (2)0111bbbfffffff3LITERAL AND CONTROL OPERATIONSADDLWkAdd literal and W111111xkkkkkkkkZANDLWkAdd literal with W1111001kkkkkkkkZCALLkCall subroutine2100kkkkkkkkkkkTO,PDGOTOkGo to address2101kkkkkkkZIIORLWkInclusive OR literal with W1111000kkkkZMOVLWkReturn from interrupt200000000001001RETFIE-Return with literal in W21101xxkkkkkkkkIRETURN-Return from Subroutine200000000001000TO,PDSUBLWkSubtract W from literal111110xkkkkkkkkKkkkI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | BCF                                    | f, b   | Bit Clear f                 | 1      | 01                    | 00bb | bfff | ffff |          | 1,2   |
| BTFSCf, bBit Test f, Skip if Clear1 (2)0110bbbfffffff3BTFSSf, bBit Test f, Skip if Set1 (2)0111bbbfffffff3LITERAL AND CONTROL OPERATIONSADDLWkAdd literal and W111111xkkkkkkkkC,DC,ZANDLWkAdd literal with W111111xkkkkkkkkZCALLkCall subroutine2100kkkkkkkkkkkZCLRWDT-Clear Watchdog Timer100000001100100TO,PDGOTOkGo to address210lkkkkkkkkkkkZIORLWkInclusive OR literal with W1111000kkkkkkkkZMOVLWkMove literal to W11100xxkkkkkkkkZRETFIE-Return from interrupt200000000001001RETLWkReturn with literal in W21101xxkkkkkkkkkkkkRETURN-Return from Subroutine200000000001000SLEEP-Go into standby mode100000001100111TO,PDSUBLWkSubtract W from literal111110xkkkkkkkkKkkk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | BSF                                    |        | Bit Set f                   | 1      | 01                    | 01bb | bfff | ffff |          |       |
| BTFSSf, bBit Test f, Skip if Set1 (2)0111bbbfffffff3LITERAL AND CONTROL OPERATIONSADDLWkAdd literal and W111111 xkkkkkkkkC,DC,ZANDLWkAND literal with W1111001kkkkkkkkZCALLkCall subroutine2100kkkkkkkkkkkZCLRWDT-Clear Watchdog Timer100000001100100TO,PDGOTOkGo to address2101kkkkkkkkkkkZIORLWkInclusive OR literal with W1111000kkkkkkkkZMOVLWkMove literal to W11100xxkkkkkkkkZRETFIE-Return from interrupt200000000011001RETLWkReturn with literal in W21101xxkkkkkkkkKkkkRETURN-Return from Subroutine200000000011001SLEEP-Go into standby mode100000001100111TO,PDSUBLWkSubtract W from literal111110xkkkkkkkkC,DC,Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                        |        |                             |        |                       |      |      |      |          |       |
| LITERAL AND CONTROL OPERATIONSADDLWkAdd literal and W111111.111.kkkkkkkkC,DC,ZANDLWkAND literal with W1111001kkkkkkkkZCALLkCall subroutine2100kkkkkkkkkkkZCLRWDT-Clear Watchdog Timer100000001100100TO,PDGOTOkGo to address2101kkkkkkkkkkkZIORLWkInclusive OR literal with W1111000kkkkkkkkZMOVLWkMove literal to W11100xxkkkkkkkkZRETFIE-Return from interrupt200000000001001RETLWkReturn with literal in W21101xxkkkkkkkkRETURN-Return from Subroutine20000001000SLEEP-Go into standby mode100000001100111SUBLWkSubtract W from literal111110xkkkkkkkkC,DC,Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                        |        | •                           |        |                       |      |      |      |          |       |
| ADDLWkAdd literal and W111111111xkkkkkkkkC,DC,ZANDLWkAND literal with W1111001kkkkkkkkC,DC,ZCALLkCall subroutine2100kkkkkkkkkkkZCLRWDT-Clear Watchdog Timer100000001100100TO,PDGOTOkGo to address2101kkkkkkkkkkkZIORLWkInclusive OR literal with W1111000kkkkkkkkZMOVLWkMove literal to W11100xxkkkkkkkkZRETFIE-Return from interrupt200000000011001RETLWkReturn with literal in W21101xxkkkkkkkkKkkkRETURN-Return from Subroutine200000000001000SLEEP-Go into standby mode100000001100111SUBLWkSubtract W from literal111110xxkkkkkkkkkkkk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                        |        |                             |        |                       |      |      |      |          | -     |
| ANDLWkAND literal with W1111001kkkkkkkkZCALLkCall subroutine2100kkkkkkkkkkkZCLRWDT-Clear Watchdog Timer100000001100100TO,PDGOTOkGo to address2101kkkkkkkkkkkZIORLWkInclusive OR literal with W1111000kkkkkkkkZMOVLWkMove literal to W11100xxkkkkkkkkZRETFIE-Return from interrupt200000000001001RETLWkReturn with literal in W21101xxkkkkkkkkRETURN-Return from Subroutine200000000001000SLEEP-Go into standby mode100000001100111TO,PDSUBLWkSubtract W from literal111110xxkkkkkkkkKkkk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                        |        |                             | 1      | 11                    | 111x | kkkk | kkkk | C.DC.Z   |       |
| CALLkCall subroutine2100kkkkkkkkkkkkkkkCLRWDT-Clear Watchdog Timer100000001100100TO,PDGOTOkGo to address2101kkkkkkkkkkkZIORLWkInclusive OR literal with W1111000kkkkkkkkZMOVLWkMove literal to W11100xxkkkkkkkkZRETFIE-Return from interrupt200000000001001RETLWkReturn with literal in W21101xxkkkkkkkkRETURN-Return from Subroutine200000000001000SLEEP-Go into standby mode100000001100111TO,PDSUBLWkSubtract W from literal111110xxkkkkkkkkC,DC,Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ANDLW                                  | k      | AND literal with W          | 1      | 11                    | 1001 | kkkk | kkkk |          |       |
| CLRWDT-Clear Watchdog Timer100000001100100TO,PDGOTOkGo to address2101kkkkkkkkkkkkkkkIORLWkInclusive OR literal with W1111000kkkkkkkkZMOVLWkMove literal to W11100xxkkkkkkkkZRETFIE-Return from interrupt200000000001001RETLWkReturn with literal in W21101xxkkkkkkkkRETURN-Return from Subroutine200000000001000SLEEP-Go into standby mode100000001100111TO,PDSUBLWkSubtract W from literal111110xxkkkkkkkkkkkk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | CALL                                   | k      | Call subroutine             |        | 10                    | 0kkk | kkkk | kkkk |          |       |
| GOTOkGo to address2101kkkkkkkkkkkkkkkIORLWkInclusive OR literal with W1111000kkkkkkkkZMOVLWkMove literal to W111100xxkkkkkkkkZRETFIE-Return from interrupt200000000001001RETLWkReturn with literal in W21101xxkkkkkkkkRETURN-Return from Subroutine200000000001000SLEEP-Go into standby mode100000001100011SUBLWkSubtract W from literal111110xkkkkkkkk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | CLRWDT                                 | -      | Clear Watchdog Timer        |        | 00                    | 0000 | 0110 | 0100 | TO.PD    |       |
| IORLW         k         Inclusive OR literal with W         1         11         1000         kkkk         kkkk         Z           MOVLW         k         Move literal to W         1         11         00xx         kkkk         kkkk         Z           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         1000           SLEEP         -         Go into standby mode         1         00         0000         011         TO,PD           SUBLW         k         Subtract W from literal         1         11         110x         kkkk         kkkk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | GOTO                                   | k      |                             |        | 10                    |      | kkkk | kkkk | - ,      |       |
| MOVLW         k         Move literal to W         1         11         00xx         kkkk         kkkkk         kkkk         kkkkk         kkkkk         kkkkk                                                                                                                        |                                        | k      | Inclusive OR literal with W |        | 11                    | 1000 | kkkk | kkkk | z        |       |
| RETFIE         -         Return from interrupt         2         00         0000         0001         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         011         TO,PD           SUBLW         k         Subtract W from literal         1         11         110x         kkkk         kkkk         C,DC,Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | -                                      |        |                             |        |                       |      |      |      |          |       |
| 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         0111         TO,PD           SUBLW         k         Subtract W from literal         1         11         110x         kkkk         kkkk         C,DC,Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | -                                      |        |                             |        |                       |      |      |      |          |       |
| 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                        | k      |                             |        |                       |      |      |      |          |       |
| 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                        |        |                             |        |                       |      |      |      |          |       |
| SUBLW         k         Subtract W from literal         1         11         110x         kkkk         kkkk         C,DC,Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | -                                      | -      |                             |        |                       |      |      |      | TO.PD    |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | -                                      |        |                             |        |                       |      |      |      | · ·      |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 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'.

2: 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.

3: 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. 29

#### 29.2 Instruction Formats

Figure 29-1 shows the three general formats that the instructions can have. As can be seen from the general format of the instructions, the opcode portion of the instruction word varies from 3-bits to 6-bits of information. This is what allows the midrange instruction set to have 35 instructions.

**Note 1:** Any unused opcode is Reserved. Use of any reserved opcode may cause unexpected operation.

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

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

0xhh

where h signifies a hexadecimal digit.

To represent a binary number:

00000100b

where b is a binary string identifier.

#### Figure 29-1: General Format for Instructions



| Field         | Description                                                                                                                                                   |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| f             | Register file address (0x00 to 0x7F)                                                                                                                          |
| W             | Working register (accumulator)                                                                                                                                |
| b             | Bit address within an 8-bit file register (0 to 7)                                                                                                            |
| k             | Literal field, constant data or label (may be either an 8-bit or an 11-bit value)                                                                             |
| x             | Don't care (0 or 1)<br>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;<br>d = 0: store result in W,<br>d = 1: store result in file register f.                                                                   |
| dest          | Destination either the W register or the specified register file location                                                                                     |
| label         | Label name                                                                                                                                                    |
| TOS           | Top of Stack                                                                                                                                                  |
| PC            | Program Counter                                                                                                                                               |
| PCLATH        | Program Counter High Latch                                                                                                                                    |
| GIE           | Global Interrupt Enable bit                                                                                                                                   |
| WDT           | Watchdog Timer                                                                                                                                                |
| TO            | Time-out bit                                                                                                                                                  |
| PD            | Power-down bit                                                                                                                                                |
| []            | Optional                                                                                                                                                      |
| ()            | Contents                                                                                                                                                      |
| $\rightarrow$ | Assigned to                                                                                                                                                   |
| <>            | Register bit field                                                                                                                                            |
| E             | In the set of                                                                                                                                                 |
| italics       | User defined term (font is courier)                                                                                                                           |

#### Table 29-2: Instruction Description Conventions

29

Instruction Set

#### 29.3 Special Function Registers as Source/Destination

The Section 29. Instruction Set's orthogonal instruction set allows read and write of all file registers, including special function registers. Some special situations the user should be aware of are explained in the following subsections:

#### 29.3.1 STATUS Register as Destination

If an instruction writes to the STATUS register, the Z, C, DC and OV bits may be set or cleared as a result of the instruction and overwrite the original data bits written. For example, executing CLRF STATUS will clear register STATUS, and then set the Z bit leaving 0000 0100b in the register.

#### 29.3.2 PCL as Source or Destination

Read, write or read-modify-write on PCL may have the following results:

| Read PC:           | $\text{PCL} \rightarrow \text{dest};$                                                                              | PCLATH does not change;          |
|--------------------|--------------------------------------------------------------------------------------------------------------------|----------------------------------|
| Write PCL:         | PCLATH $\rightarrow$ PC                                                                                            | CH;<br>on value $ ightarrow$ PCL |
| Read-Modify-Write: | $\begin{array}{l} PCL \rightarrow ALU \text{ op} \\ PCLATH \rightarrow PC \\ 8-bit result \rightarrow \end{array}$ | CH;                              |

Where PCH = program counter high byte (not an addressable register), PCLATH = Program counter high holding latch, dest = destination, W register or register file f.

#### 29.3.3 Bit Manipulation

All bit manipulation instructions will first read the entire register, operate on the selected bit and then write the result back (read-modify-write (R-M-W)) the specified register. The user should keep this in mind when operating on some special function registers, such as ports.

**Note:** Status bits that are manipulated by the device (including the interrupt flag bits) are set or cleared in the Q1 cycle. So there is no issue with executing R-M-W instructions on registers which contain these bits.

### 29.4 Q Cycle Activity

Each instruction cycle (Tcy) is comprised of four Q cycles (Q1-Q4). The Q cycle is the same as the device oscillator cycle (Tosc). The Q cycles provide the timing/designation for the Decode, Read, Process Data, Write etc., of each instruction cycle. The following diagram shows the relationship of the Q cycles to the instruction cycle.

The four Q cycles that make up an instruction cycle (Tcy) can be generalized as:

- Q1: Instruction Decode Cycle or forced No Operation
- Q2: Instruction Read Cycle or No Operation
- Q3: Process the Data
- Q4: Instruction Write Cycle or No Operation

Each instruction will show the detailed Q cycle operation for the instruction.



#### Figure 29-2: Q Cycle Activity

## PICmicro MID-RANGE MCU FAMILY

#### 29.5 Instruction Descriptions

| ADDLW             | Add Literal and W                                                                                                 |
|-------------------|-------------------------------------------------------------------------------------------------------------------|
| Syntax:           | [ <i>label</i> ] ADDLW k                                                                                          |
| Operands:         | $0 \le k \le 255$                                                                                                 |
| Operation:        | $(W) + k \to W$                                                                                                   |
| Status Affected:  | C, DC, Z                                                                                                          |
| Encoding:         | 11 111x kkkk kkkk                                                                                                 |
| Description:      | The contents of the W register are added to the eight bit literal 'k' and the result is placed in the W register. |
| Words:            | 1                                                                                                                 |
| Cycles:           | 1                                                                                                                 |
| Q Cycle Activity: |                                                                                                                   |
| Q1                | Q2 Q3 Q4                                                                                                          |
| Decode            | Read     Process     Write to W       literal 'k'     data     register                                           |
|                   |                                                                                                                   |
| Example1          | ADDLW 0x15                                                                                                        |
|                   | Before Instruction                                                                                                |
|                   | W = 0x10<br>After Instruction                                                                                     |
|                   | W = 0x25                                                                                                          |
|                   |                                                                                                                   |
| Example 2         | ADDLW MYREG                                                                                                       |
|                   | Before Instruction                                                                                                |
|                   | W = 0x10<br>Address of MYREG <sup>†</sup> = 0x37                                                                  |
|                   | † MYREG is a symbol for a data memory location                                                                    |
|                   | After Instruction                                                                                                 |
|                   | W = 0x47                                                                                                          |
| Example 3         | ADDLW HIGH (LU_TABLE)                                                                                             |
| ·                 | Before Instruction                                                                                                |
|                   | W = 0x10                                                                                                          |
|                   | Address of LU_TABLE <sup>†</sup> = 0x9375<br>† LU_TABLE is a label for an address in program memory               |
|                   | After Instruction                                                                                                 |
|                   | W = 0xA3                                                                                                          |
| Example 4         | ADDLW MYREG                                                                                                       |
|                   | Before Instruction                                                                                                |
|                   | W = 0x10                                                                                                          |
|                   | Address of PCL $^{\dagger}$ = 0x02                                                                                |
|                   | † PCL is the symbol for the Program Counter low byte location<br>After Instruction                                |
|                   | W = 0x12                                                                                                          |
|                   |                                                                                                                   |

### **Section 29. Instruction Set**

| Syntax:          | [ label ] AD            | DWF f,d                              |                      |                                                                                   |
|------------------|-------------------------|--------------------------------------|----------------------|-----------------------------------------------------------------------------------|
| Operands:        | <br>0 ≤ f ≤ 127         | ·                                    |                      |                                                                                   |
| •                | $d \in [0,1]$           |                                      |                      |                                                                                   |
| Operation:       | (W) + (f) $\rightarrow$ | destination                          | า                    |                                                                                   |
| Status Affected  | : C, DC, Z              |                                      |                      |                                                                                   |
| Encoding:        | 00                      | 0111 df                              | ff ffff              |                                                                                   |
| Description:     |                         |                                      |                      | h register 'f'. If 'd' is 0 the result is stored in th<br>d back in register 'f'. |
| Words:           | 1                       |                                      |                      |                                                                                   |
| Cycles:          | 1                       |                                      |                      |                                                                                   |
| Q Cycle Activity | /:                      |                                      |                      |                                                                                   |
| Q1               | Q2                      | Q3                                   | Q4                   |                                                                                   |
| Decode           | Read<br>register 'f'    | Process<br>data                      | Write to destination |                                                                                   |
|                  | register i              | uala                                 | uestination          | 1                                                                                 |
|                  | FS<br>After Instru<br>W | = 0x17<br>SR = 0xC2<br>ction         |                      |                                                                                   |
| Example 2        | ADDWF                   | INDF, 1                              |                      |                                                                                   |
| -                | Before Inst             | ruction                              |                      |                                                                                   |
|                  | FS                      | = 0x17<br>SR = 0xC2<br>ontents of Ad | Idroop (ESD)         | 0.20                                                                              |
|                  | After Instru            |                                      |                      | = 0x20                                                                            |
|                  | W                       |                                      |                      |                                                                                   |
|                  |                         | SR = 0xC2<br>ontents of Ad           | ldress (FSR)         | = 0x37                                                                            |
| Example 3        | ADDWF 1                 | PCL                                  |                      |                                                                                   |
| Case 1:          |                         |                                      |                      |                                                                                   |
|                  | W                       | = 0x10                               |                      |                                                                                   |
|                  |                         | L = 0x37<br>= x                      |                      |                                                                                   |
|                  | After Instru            |                                      |                      |                                                                                   |
|                  |                         | L = 0x47                             |                      |                                                                                   |
| 0                |                         | = 0                                  |                      |                                                                                   |
| Case 2:          | Before Insti<br>W       | ruction $= 0x10$                     |                      |                                                                                   |
|                  | PC                      | L = 0xF7                             |                      |                                                                                   |
|                  |                         | H = 0x08<br>= x                      |                      |                                                                                   |
|                  | After Instru            |                                      |                      |                                                                                   |
|                  |                         | L = 0x07                             |                      |                                                                                   |
|                  |                         | $^{2}H = 0x08$<br>= 1                |                      |                                                                                   |
|                  | c                       | •                                    |                      |                                                                                   |

Set

29

## **PICmicro MID-RANGE MCU FAMILY**

| 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:  | Ζ                                                                                                                                                                                                          |
| Encoding:         | 11 1001 kkkk kkkk                                                                                                                                                                                          |
| Description:      | The contents of W register are AND'ed with the eight bit literal 'k'. The result is placed in the W register.                                                                                              |
| Words:            | 1                                                                                                                                                                                                          |
| Cycles:           | 1                                                                                                                                                                                                          |
| Q Cycle Activity: |                                                                                                                                                                                                            |
| Q1                | Q2 Q3 Q4                                                                                                                                                                                                   |
| Decode            | Read literal     Process     Write to W       'k'     data     register                                                                                                                                    |
|                   | W = 0xA3       ; 1010 0011 (0xA3)         After Instruction       ;         W = 0x03       ; 0000 0011 (0x03)                                                                                              |
| Example 2         | ANDLW MYREG                                                                                                                                                                                                |
|                   | Before Instruction<br>W = 0xA3<br>Address of MYREG <sup>†</sup> = 0x37<br><sup>†</sup> MYREG is a symbol for a data memory location<br>After Instruction<br>W = 0x23                                       |
| Example 3         | ANDLW HIGH (LU_TABLE)<br>Before Instruction<br>W = 0xA3<br>Address of LU_TABLE <sup>†</sup> = 0x9375<br><sup>†</sup> LU_TABLE is a label for an address in program memory<br>After Instruction<br>W = 0x83 |

## **Section 29. Instruction Set**

| ANDWF            | · •                              | AND W with                                               | f                    |                                                |                              |
|------------------|----------------------------------|----------------------------------------------------------|----------------------|------------------------------------------------|------------------------------|
| Syntax:          | [ label ] Al                     | NDWF f,d                                                 |                      |                                                |                              |
| Operands:        | $0 \le f \le 127$                | 7                                                        |                      |                                                |                              |
| 0 "              | $d \in [0,1]$                    |                                                          |                      |                                                |                              |
| Operation:       |                                  | (f) $\rightarrow$ destina                                | ation                |                                                |                              |
| Status Affected: | Z                                |                                                          |                      | 7                                              |                              |
| Encoding:        | 00                               | 0101 df:                                                 |                      |                                                |                              |
| Description:     |                                  | register with r<br>esult is stored                       |                      |                                                | stored in the W register. If |
| Words:           | 1                                |                                                          |                      |                                                |                              |
| Cycles:          | 1                                |                                                          |                      |                                                |                              |
| Q Cycle Activity |                                  |                                                          |                      |                                                |                              |
| Q1               | Q2                               | Q3                                                       | Q4                   | Г                                              |                              |
| Decode           | Read<br>register 'f'             | Process<br>data                                          | Write to destination |                                                |                              |
|                  | F<br>After Instru<br>V           | N = 0x17<br>SR = 0xC2<br>uction<br>V = 0x17<br>SR = 0x02 |                      | ; 1100 0010<br>;<br>; 0000 0010                |                              |
| Example 2        | F<br>After Instru<br>V           | W = 0x17<br>SR = 0xC2                                    |                      | ; 0001 0111<br>; 1100 0010<br>;<br>; 0000 0010 | (0xC2)                       |
| Example 3        | F<br>C<br>After Instri<br>V<br>F | V = 0x17<br>SR = 0xC2<br>Contents of Ad                  |                      |                                                |                              |

# **PICmicro MID-RANGE MCU FAMILY**

| B     | CF             | E                                 | Bit Clear f                             |               |     |                |      |  |  |
|-------|----------------|-----------------------------------|-----------------------------------------|---------------|-----|----------------|------|--|--|
| Synt  | tax:           | [ <i>label</i> ] B0               | CF f,b                                  |               |     |                |      |  |  |
| Ope   | rands:         | $0 \le f \le 127$ $0 \le b \le 7$ | 7                                       |               |     |                |      |  |  |
| Ope   | ration:        | $0 \rightarrow f < b >$           |                                         |               |     |                |      |  |  |
| State | us Affected:   | None                              |                                         |               |     |                |      |  |  |
| Enco  | oding:         | 01                                | 00bb bf                                 | ff f          | fff |                |      |  |  |
| Des   | cription:      | Bit 'b' in reg                    | gister 'f' is clea                      | red.          |     | 1              |      |  |  |
| Wor   | ds:            | 1                                 |                                         |               |     |                |      |  |  |
| Cycl  | es:            | 1                                 |                                         |               |     |                |      |  |  |
| QC    | ycle Activity: |                                   |                                         |               |     |                |      |  |  |
|       | Q1             | Q2                                | Q3                                      | Q4            |     |                |      |  |  |
|       | Decode         | Read<br>register 'f'              | Process<br>data                         | Wri<br>regist |     |                |      |  |  |
| Exar  | mple 1         | BCF                               | FLAG_REG,                               | 7             |     |                |      |  |  |
|       |                | Before Ins<br>F                   | struction<br>LAG_REG = (                | )xC7          |     | ; <b>1</b> 100 | 0111 |  |  |
|       |                | After Instruction                 |                                         |               |     |                |      |  |  |
|       |                | F                                 | LAG_REG = (                             | )x47          |     | ; <b>0</b> 100 | 0111 |  |  |
| Exar  | mple 2         | BCF                               | INDF, 3                                 |               |     |                |      |  |  |
|       |                | F<br>C<br>After Instr<br>V<br>F   | V = 0x17<br>SR = 0xC2<br>Contents of Ad | dress (F      |     |                |      |  |  |

## Section 29. Instruction Set

### **BSF**

|                  |                                   | JIL DEL I                                                                        |   |    |  |  |  |      |  |  |  |
|------------------|-----------------------------------|----------------------------------------------------------------------------------|---|----|--|--|--|------|--|--|--|
| Syntax:          | [ <i>label</i> ] B                | SF f,b                                                                           |   |    |  |  |  |      |  |  |  |
| Operands:        | $0 \le f \le 127$ $0 \le b \le 7$ | 7                                                                                |   |    |  |  |  |      |  |  |  |
| Operation:       | $1 \rightarrow \text{f}$          | $1 \rightarrow f < b >$                                                          |   |    |  |  |  |      |  |  |  |
| Status Affected: | None                              | None                                                                             |   |    |  |  |  |      |  |  |  |
| Encoding:        | 01                                | 01 01bb bfff ffff                                                                |   |    |  |  |  |      |  |  |  |
| Description:     | Bit 'b' in re                     | Bit 'b' in register 'f' is set.                                                  |   |    |  |  |  |      |  |  |  |
| Words:           | 1                                 |                                                                                  |   |    |  |  |  |      |  |  |  |
| Cycles:          | 1                                 |                                                                                  |   |    |  |  |  |      |  |  |  |
| Q Cycle Activity | :                                 |                                                                                  |   |    |  |  |  |      |  |  |  |
| Q1               | Q2                                | Q3                                                                               |   | Q4 |  |  |  |      |  |  |  |
| Decode           | Read<br>register 'f'              |                                                                                  |   |    |  |  |  |      |  |  |  |
|                  |                                   |                                                                                  |   |    |  |  |  |      |  |  |  |
| Example 1        | BSF                               | BSF FLAG_REG, 7                                                                  |   |    |  |  |  |      |  |  |  |
|                  |                                   | Before Instruction<br>FLAG_REG =0x0A ; 0000 10                                   |   |    |  |  |  |      |  |  |  |
|                  | After Instruction                 |                                                                                  |   |    |  |  |  |      |  |  |  |
|                  | F                                 | FLAG_REG =0x8A                                                                   |   |    |  |  |  | 1010 |  |  |  |
| Example 2        | BSF                               | INDF,                                                                            | 3 |    |  |  |  |      |  |  |  |
|                  | V<br>F                            | Before Instruction<br>W = 0x17<br>FSR = 0xC2<br>Contents of Address (FSR) = 0x20 |   |    |  |  |  |      |  |  |  |

 $\begin{array}{rcl} W &=& 0x17\\ FSR =& 0xC2\\ Contents of Address (FSR) = 0x20\\ After Instruction\\ W &=& 0x17\\ FSR =& 0xC2\\ Contents of Address (FSR) = 0x28 \end{array}$ 

| BTFSC               | В                                                              | it Test, Skip                     | if Clear         |                                                                                                               |
|---------------------|----------------------------------------------------------------|-----------------------------------|------------------|---------------------------------------------------------------------------------------------------------------|
| Syntax:             | [ label ] BT                                                   | FSC f,b                           |                  |                                                                                                               |
| Operands:           | $0 \le f \le 127$                                              |                                   |                  |                                                                                                               |
|                     | $0 \le b \le 7$                                                |                                   |                  |                                                                                                               |
| Operation:          | skip if (f <b< td=""><td>&gt;) = 0</td><td></td><td></td></b<> | >) = 0                            |                  |                                                                                                               |
| Status Affected:    | None                                                           |                                   |                  | _                                                                                                             |
| Encoding:           | 01                                                             | 10bb bf                           | ff ffff          |                                                                                                               |
| Description:        | If bit 'b' is '0'                                              | then the next i                   | nstruction (fetc | xt instruction is skipped.<br>hed during the current instruction ex-<br>instead, making this a 2 cycle instru |
| Words:              | 1                                                              |                                   |                  |                                                                                                               |
| Cycles:             | 1(2)                                                           |                                   |                  |                                                                                                               |
| Q Cycle Activity:   |                                                                |                                   |                  |                                                                                                               |
| Q1                  | Q2                                                             | Q3                                | Q4               | 1                                                                                                             |
| Decode              | Read                                                           | Process<br>data                   | No               |                                                                                                               |
| If skip (2nd cycle) | register 'f'                                                   | uala                              | operation        |                                                                                                               |
| Q1                  | Q2                                                             | Q3                                | Q4               |                                                                                                               |
| No<br>operation     | No<br>operation                                                | No<br>operation                   | No<br>operation  |                                                                                                               |
| Example 1           |                                                                | BTFSC FLAG<br>GOTO PROC<br>•<br>• | :, 4<br>ESS_CODE |                                                                                                               |
| Case 1:             |                                                                |                                   | SHERE<br>XXXX    |                                                                                                               |
|                     |                                                                | nce FLAG<4>=                      | = 0,<br>STRUE    |                                                                                                               |
| Case 2:             | FL                                                             | C = addres<br>AG= xxx1            | SHERE<br>XXXX    |                                                                                                               |
|                     |                                                                | nce FLAG<4>=                      | =1,<br>SFALSE    |                                                                                                               |

| BTFSS                     | В                        | it Test f, Skip                   | o if Set        |                                                                                                       |
|---------------------------|--------------------------|-----------------------------------|-----------------|-------------------------------------------------------------------------------------------------------|
| Syntax:                   | [ label ] BT             | FSS f,b                           |                 |                                                                                                       |
| Operands:                 | 0 ≤ f ≤ 127<br>0 ≤ b < 7 |                                   |                 |                                                                                                       |
| Operation:                | skip if (f <b></b>       | >) = 1                            |                 |                                                                                                       |
| Status Affected:          | None                     |                                   |                 |                                                                                                       |
| Encoding:                 | 01                       | 11bb bf                           | ff ffff         |                                                                                                       |
| Description:              | If bit 'b' is '1         | I', then the ne                   | ext instruction | kt instruction is skipped.<br>(fetched during the current instru<br>P is executed instead, making thi |
| Words:                    | 1                        |                                   |                 |                                                                                                       |
| Cycles:                   | 1(2)                     |                                   |                 |                                                                                                       |
| Q Cycle Activity:         |                          |                                   |                 |                                                                                                       |
| Q1                        | Q2                       | Q3                                | Q4              |                                                                                                       |
| Decode                    | Read<br>register 'f'     | Process<br>data                   | No<br>operation |                                                                                                       |
| If skip (2nd cycle)<br>Q1 | ):<br>Q2                 | Q3                                | Q4              |                                                                                                       |
| No<br>operation           | No<br>operation          | No<br>operation                   | No<br>operation |                                                                                                       |
| Example 1                 | FALSE                    | BTFSS FLAG<br>GOTO PROC<br>•<br>• | , 4<br>ESS_CODE |                                                                                                       |
| Case 1:                   |                          | C = addres<br>AG= xxx0            | SHERE<br>XXXX   |                                                                                                       |
|                           |                          | nce FLAG<4>=<br>C = addres        | = 0,<br>SFALSE  |                                                                                                       |
| Case 2:                   |                          | C = addres                        | SHERE           |                                                                                                       |
|                           | FL                       | AG= xxx1                          | XXXX            |                                                                                                       |

Instruction Set

| CALL              | (                                                    | Call Subrout              | tine            |                                                                                                                         |
|-------------------|------------------------------------------------------|---------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------|
| Syntax:           | [label] (                                            | CALL k                    |                 |                                                                                                                         |
| Operands:         | $0 \le k \le 20$                                     | 47                        |                 |                                                                                                                         |
| Operation:        | $(PC)+1 \rightarrow k \rightarrow PC < 1$<br>(PCLATH |                           | <12:11>         |                                                                                                                         |
| Status Affected:  | None                                                 |                           |                 |                                                                                                                         |
| Encoding:         | 10                                                   | 0kkk kk                   | kk kkkk         |                                                                                                                         |
| Description:      | stack. The                                           | eleven bit in of the PC a | nmediate add    | urn address (PC+1) is pushed onto the<br>dress is loaded into PC bits <10:0>. The<br>m PCLATH<4:3>. CALL is a two cycle |
| Words:            | 1                                                    |                           |                 |                                                                                                                         |
| Cycles:           | 2                                                    |                           |                 |                                                                                                                         |
| Q Cycle Activity: |                                                      |                           |                 |                                                                                                                         |
| 1st cycle:        |                                                      |                           |                 |                                                                                                                         |
| Q1                | Q2                                                   | Q3                        | Q4              | _                                                                                                                       |
| Decode            | Read literal<br>'k'                                  | Process<br>data           | No<br>operation |                                                                                                                         |
| 2nd cycle:        |                                                      |                           |                 |                                                                                                                         |
| Q1                | Q2                                                   | Q3                        | Q4              | _                                                                                                                       |
| No<br>operation   | No<br>operation                                      | No<br>operation           | No<br>operation |                                                                                                                         |
| Example 1         | HERE                                                 | CALL THE                  | RE              |                                                                                                                         |
|                   | Before Ins                                           |                           |                 |                                                                                                                         |
|                   | F<br>After Instr                                     | PC = Addres               | SSHERE          |                                                                                                                         |

fter Instruction TOS = Address HERE+1 PC = Address THERE

| CLRF              | (                                                                   | Clear f                             |                           |                          |                                    |
|-------------------|---------------------------------------------------------------------|-------------------------------------|---------------------------|--------------------------|------------------------------------|
| Syntax:           | [ label ] C                                                         | LRF f                               |                           |                          |                                    |
| Operands:         | $0 \le f \le 12^{-1}$                                               | 7                                   |                           |                          |                                    |
| Operation:        | $\begin{array}{c} 00h \rightarrow f \\ 1 \rightarrow Z \end{array}$ |                                     |                           |                          |                                    |
| Status Affected:  | Z                                                                   |                                     |                           |                          |                                    |
| Encoding:         | 00                                                                  | 0001                                | lfff                      | ffff                     | ]                                  |
| Description:      | The conte                                                           | ents of re                          | egister 'f                | are clear                | $\vec{r}$ ed and the Z bit is set. |
| Words:            | 1                                                                   |                                     |                           |                          |                                    |
| Cycles:           | 1                                                                   |                                     |                           |                          |                                    |
| Q Cycle Activity: |                                                                     |                                     |                           |                          |                                    |
| Q1                | Q2                                                                  | Q3                                  | Q                         | 4                        | _                                  |
| Decode            | Read<br>register 'f'                                                | Proce<br>data                       |                           | Write<br>egister 'f'     |                                    |
| Example 1         | After Instr<br>F                                                    | FLAG_RE                             | EG=0x5A<br>EG=0x00        |                          |                                    |
| Example 2         | C<br>After Instr<br>F<br>C                                          | SR =<br>Contents<br>fuction<br>SR = | 0xC2<br>of Addres<br>0xC2 | ss (FSR)=(<br>ss (FSR)=( |                                    |

Instruction Set

| CLRW              |                                                                     | Clear W      | ,       |     |                    |
|-------------------|---------------------------------------------------------------------|--------------|---------|-----|--------------------|
| Syntax:           | [ label ]                                                           | CLRW         |         |     |                    |
| Operands:         | None                                                                |              |         |     |                    |
| Operation:        | $\begin{array}{c} 00h \rightarrow W \\ 1 \rightarrow Z \end{array}$ |              |         |     |                    |
| Status Affected:  | Z                                                                   |              |         |     |                    |
| Encoding:         | 00                                                                  | 0001         | 0xx     | x   | xxxx               |
| Description:      | W registe                                                           | r is clea    | red. Ze | ero | bit (Z) is         |
| Words:            | 1                                                                   |              |         |     |                    |
| Cycles:           | 1                                                                   |              |         |     |                    |
| Q Cycle Activity: |                                                                     |              |         |     |                    |
| Q1                | Q2                                                                  | Q3           |         | Q4  |                    |
| Decode            | Read<br>register 'f'                                                | Proce<br>dat |         |     | Write<br>ister 'W' |
|                   |                                                                     |              |         |     |                    |
| Example 1         | CLRW                                                                |              |         |     |                    |

| •==       |       |       |      |
|-----------|-------|-------|------|
| Before I  | nstru | uctio | n    |
|           | W     | =     | 0x5A |
| After Ins | struc | tion  |      |
|           | W     | =     | 0x00 |
|           | Ζ     | =     | 1    |
|           |       |       |      |

| CLRWD             |                                                                                                                                  | Clear Wat                     | chdog Time              | r                                                                                                    |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------------|-------------------------|------------------------------------------------------------------------------------------------------|
| Syntax:           | [ label ]                                                                                                                        | CLRWDT                        |                         |                                                                                                      |
| Operands:         | None                                                                                                                             |                               |                         |                                                                                                      |
| Operation:        | $\begin{array}{l} 00h \rightarrow \\ 0 \rightarrow WI \\ 1 \rightarrow \overline{TC} \\ 1 \rightarrow \overline{PL} \end{array}$ | DT prescale                   | r count,                |                                                                                                      |
| Status Affected:  | TO, PD                                                                                                                           |                               |                         |                                                                                                      |
| Encoding:         | 00                                                                                                                               | 0000                          | 0110 0100               |                                                                                                      |
| Description:      |                                                                                                                                  |                               |                         | atchdog Timer. It also clears the presits $\overline{\text{TO}}$ and $\overline{\text{PD}}$ are set. |
| Words:            | 1                                                                                                                                |                               |                         |                                                                                                      |
| Cycles:           | 1                                                                                                                                |                               |                         |                                                                                                      |
| Q Cycle Activity: |                                                                                                                                  |                               |                         |                                                                                                      |
| Q1                | Q2                                                                                                                               | Q3                            | Q4                      |                                                                                                      |
| Decode            | No<br>operation                                                                                                                  | Process<br>data               | Clear<br>WDT<br>Counter |                                                                                                      |
| Example 1         | CLRWDT                                                                                                                           |                               |                         |                                                                                                      |
|                   | W<br>After Instru<br>W<br>W                                                                                                      | /DT counter=<br>/DT prescaler | r=1:128<br>0x00         |                                                                                                      |
|                   | P                                                                                                                                | D = 1<br>/DT prescaler        | =1:128                  |                                                                                                      |

Instruction Set

|                   | Complement f                                                                                                                                     |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:           | [ <i>label</i> ] COMF f,d                                                                                                                        |
| Operands:         | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                               |
| Operation:        | $(\overline{f}) \rightarrow destination$                                                                                                         |
| Status Affected:  | Z                                                                                                                                                |
| Encoding:         | 00 1001 dfff ffff                                                                                                                                |
| Description:      | The contents of register 'f' are 1's complemented. If 'd' is 0 the result is stored in W. If 'd' is 1 the result is stored back in register 'f'. |
| Words:            | 1                                                                                                                                                |
| Cycles:           | 1                                                                                                                                                |
| Q Cycle Activity: |                                                                                                                                                  |
| Q1                | Q2 Q3 Q4                                                                                                                                         |
| Decode            | ReadProcessWrite toregister 'f'datadestination                                                                                                   |
| Example 1         | COMF REG1, 0                                                                                                                                     |
|                   | Before Instruction                                                                                                                               |
|                   | REG1= 0x13                                                                                                                                       |
|                   | After Instruction<br>REG1= 0x13                                                                                                                  |
|                   | W = 0xEC                                                                                                                                         |
| Example 2         | COMF INDF, 1                                                                                                                                     |
|                   | Before Instruction                                                                                                                               |
|                   | FSR = 0xC2<br>Contents of Address (FSR)=0xAA                                                                                                     |
|                   | After Instruction                                                                                                                                |
|                   | FSR = 0xC2                                                                                                                                       |
|                   | Contents of Address (FSR)=0x55                                                                                                                   |
| Example 3         | COMF REG1, 1                                                                                                                                     |
|                   | Before Instruction                                                                                                                               |
|                   | REG1= 0xFF                                                                                                                                       |
|                   | After Instruction<br>REG1= 0x00                                                                                                                  |
|                   |                                                                                                                                                  |

| DECF              | Decrement f                                                                                                                        |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:           | [ <i>label</i> ] DECF f,d                                                                                                          |
| Operands:         | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \ [0,1] \end{array}$                                                                  |
| Operation:        | (f) - 1 $\rightarrow$ destination                                                                                                  |
| Status Affected:  | Z                                                                                                                                  |
| Encoding:         | 00 0011 dfff ffff                                                                                                                  |
| 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'. |
| Words:            | 1                                                                                                                                  |
| Cycles:           | 1                                                                                                                                  |
| Q Cycle Activity: |                                                                                                                                    |
| Q1                | Q2 Q3 Q4                                                                                                                           |
| Decode            | ReadProcessWrite toregister 'f'datadestination                                                                                     |
| Example 1         | DECF CNT, 1                                                                                                                        |
|                   | Before Instruction<br>CNT = 0x01                                                                                                   |
|                   | Z = 0                                                                                                                              |
|                   | After Instruction<br>CNT = 0x00                                                                                                    |
|                   | Z = 1                                                                                                                              |
| Example 2         | DECF INDF, 1                                                                                                                       |
|                   | Before Instruction<br>FSR = 0xC2<br>Contents of Address (FSR) = 0x01<br>Z = 0                                                      |
|                   | After Instruction                                                                                                                  |
|                   | FSR = 0xC2<br>Contents of Address (FSR) = 0x00<br>Z = 1                                                                            |
| Example 3         | decf cnt, 0                                                                                                                        |
|                   | Before Instruction<br>CNT = 0x10<br>W = x                                                                                          |
|                   |                                                                                                                                    |
|                   | Z = 0                                                                                                                              |
|                   |                                                                                                                                    |

Instruction Set

| DECFSZ             | ,<br>a                             | Decremen                                            | nt f, Skip if 0                                     |                                                                                                                                                              |
|--------------------|------------------------------------|-----------------------------------------------------|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:            | [ label ]                          | DECFSZ                                              | f,d                                                 |                                                                                                                                                              |
| Operands:          | $0 \le f \le 1$                    |                                                     |                                                     |                                                                                                                                                              |
|                    | d ∈ [0,1                           | -                                                   |                                                     |                                                                                                                                                              |
| Operation:         | (f) - 1 →                          | destination                                         | ; skip if result                                    | = 0                                                                                                                                                          |
| Status Affected:   | None                               |                                                     |                                                     | _                                                                                                                                                            |
| Encoding:          | 0 0                                |                                                     | dfff ffff                                           |                                                                                                                                                              |
| Description:       | in the W<br>If the re<br>instructi | / register. If 's sult is 0, the                    | d' is 1 the res<br>n the next ins<br>n) is discarde | cremented. If 'd' is 0 the result is pla<br>sult is placed back in register 'f'.<br>struction (fetched during the currer<br>d and a NOP is executed instead, |
| Words:             | 1                                  |                                                     |                                                     |                                                                                                                                                              |
| Cycles:            | 1(2)                               |                                                     |                                                     |                                                                                                                                                              |
| Q Cycle Activity:  |                                    |                                                     |                                                     |                                                                                                                                                              |
| Q1                 | Q2                                 | Q3                                                  | Q4                                                  | 1                                                                                                                                                            |
| Decode             | Read<br>register 'f'               | Process<br>data                                     | Write to destination                                |                                                                                                                                                              |
| If skip (2nd cycle | Ŧ                                  | data                                                | decimation                                          |                                                                                                                                                              |
| Q1                 | Q2                                 | Q3                                                  | Q4                                                  |                                                                                                                                                              |
| No                 | No                                 | No                                                  | No                                                  |                                                                                                                                                              |
| operation          | operation                          | operation                                           | operation                                           |                                                                                                                                                              |
| Example            | HERE                               | DECFSZ                                              | CNT, 1                                              |                                                                                                                                                              |
| Example            | TIBICE                             | GOTO                                                | LOOP                                                |                                                                                                                                                              |
|                    | CONTINU                            |                                                     |                                                     |                                                                                                                                                              |
|                    |                                    | E •                                                 |                                                     |                                                                                                                                                              |
|                    |                                    | <u>r</u> .•<br>•                                    |                                                     |                                                                                                                                                              |
| Case 1:            | After Instr<br>CNT                 | truction<br>= address<br>= 0x01<br>uction<br>= 0x00 | HERE<br>CONTINUE                                    |                                                                                                                                                              |

| GOTO              | ι                               | Jncondition        | al Branch       |                                                                            |
|-------------------|---------------------------------|--------------------|-----------------|----------------------------------------------------------------------------|
| Syntax:           | [ label ]                       | GOTO k             |                 |                                                                            |
| Operands:         | $0 \le k \le 20$                | 47                 |                 |                                                                            |
| Operation:        | $k \rightarrow PC < 1$ PCLATH < | 0:0><br>4:3> → PC< | 12:11>          |                                                                            |
| Status Affected:  | None                            |                    |                 |                                                                            |
| Encoding:         | 10                              | 1kkk kk            | kk kkkk         |                                                                            |
| Description:      | into PC bi                      |                    | ne upper bits   | e eleven bit immediate value is loade<br>of PC are loaded from PCLATH<4:3> |
| Words:            | 1                               |                    |                 |                                                                            |
| Cycles:           | 2                               |                    |                 |                                                                            |
| Q Cycle Activity: |                                 |                    |                 |                                                                            |
| 1st cycle:        |                                 |                    |                 |                                                                            |
| Q1                | Q2                              | Q3                 | Q4              |                                                                            |
| Decode            | Read literal<br>'k'<7:0>        | Process<br>data    | No<br>operation |                                                                            |
| 2nd cycle:        |                                 |                    |                 | -                                                                          |
| Q1                | Q2                              | Q3                 | Q4              |                                                                            |
|                   | No                              | No                 | No              |                                                                            |
| No                |                                 | operation          | operation       |                                                                            |

After Instruction PC =AddressTHERE

Instruction Set

| INCF              | Increment f                                                                                                                                                                                                                                                            |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:           | [ <i>label</i> ] INCF f,d                                                                                                                                                                                                                                              |
| Operands:         | $0 \le f \le 127$                                                                                                                                                                                                                                                      |
|                   | $d \in [0,1]$                                                                                                                                                                                                                                                          |
| Operation:        | (f) + 1 $\rightarrow$ destination                                                                                                                                                                                                                                      |
| Status Affected:  |                                                                                                                                                                                                                                                                        |
| Encoding:         | 00 1010 dfff ffff                                                                                                                                                                                                                                                      |
| 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'.                                                                                                               |
| Words:            | 1                                                                                                                                                                                                                                                                      |
| Cycles:           | 1                                                                                                                                                                                                                                                                      |
| Q Cycle Activity: |                                                                                                                                                                                                                                                                        |
| Q1                | Q2 Q3 Q4                                                                                                                                                                                                                                                               |
| Decode            | Read Process Write to<br>register 'f' data destination                                                                                                                                                                                                                 |
| Example 2         | Before Instruction<br>CNT = 0xFF<br>Z = 0<br>After Instruction<br>CNT = 0x00<br>Z = 1<br>INCF INDF, 1<br>Before Instruction<br>FSR = 0xC2<br>Contents of Address (FSR) = 0xFF<br>Z = 0<br>After Instruction<br>FSR = 0xC2<br>Contents of Address (FSR) = 0x00<br>Z = 1 |
| Example 3         | INCF CNT, 0<br>Before Instruction<br>CNT = 0x10<br>W = x<br>Z = 0<br>After Instruction<br>CNT = 0x10<br>W = 0x11<br>Z = 0                                                                                                                                              |

| INCFSZ             | I                                       | ncrement f,                             | Skip if 0                                                |                                                                                                                                                           |
|--------------------|-----------------------------------------|-----------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:            | [ label ]                               | INCFSZ f,d                              |                                                          |                                                                                                                                                           |
| Operands:          | $0 \le f \le 122$ $d \in [0,1]$         | 7                                       |                                                          |                                                                                                                                                           |
| Operation:         | (f) + 1 $\rightarrow$ (                 | destination, s                          | skip if result =                                         | = 0                                                                                                                                                       |
| Status Affected:   | None                                    |                                         |                                                          |                                                                                                                                                           |
| Encoding:          | 00                                      | 1111 df                                 | ff ffff                                                  |                                                                                                                                                           |
| Description:       | the W reg<br>If the resu<br>instructior | ister. If 'd' is<br>It is 0, then t     | 1 the result is<br>the next instruits<br>the discarded a | mented. If 'd' is 0 the result is placed is<br>placed back in register 'f'.<br>uction (fetched during the current<br>and a NOP is executed instead, makin |
| Words:             | 1                                       |                                         |                                                          |                                                                                                                                                           |
| Cycles:            | 1(2)                                    |                                         |                                                          |                                                                                                                                                           |
| Q Cycle Activity:  |                                         |                                         |                                                          |                                                                                                                                                           |
| Q1                 | Q2                                      | Q3                                      | Q4                                                       | 7                                                                                                                                                         |
| Decode             | Read<br>register 'f'                    | Process<br>data                         | Write to destination                                     |                                                                                                                                                           |
| If skip (2nd cycle | ):                                      |                                         |                                                          |                                                                                                                                                           |
| Q1                 | Q2                                      | Q3                                      | Q4                                                       | 1                                                                                                                                                         |
| No<br>operation    | No<br>operation                         | No<br>operation                         | No<br>operation                                          |                                                                                                                                                           |
| Example            | HERE<br>CONTINU                         | INCFSZ<br>GOTO<br>E •                   | CNT, 1<br>LOOP                                           |                                                                                                                                                           |
| Case 1:            | After Instr<br>CNT                      | = address<br>= 0xFF<br>uction<br>= 0x00 | HERE                                                     |                                                                                                                                                           |
| Case 2:            | After Instr                             | = address<br>= 0x00                     |                                                          |                                                                                                                                                           |

| IORLW             | Inclusive OR Literal with W                                                                                     |
|-------------------|-----------------------------------------------------------------------------------------------------------------|
| Syntax:           | [ <i>label</i> ] IORLW k                                                                                        |
| Operands:         | $0 \le k \le 255$                                                                                               |
| Operation:        | (W).OR. $k \rightarrow W$                                                                                       |
| Status Affected:  | Z                                                                                                               |
| Encoding:         | 11 1000 kkkk kkkk                                                                                               |
| Description:      | The contents of the W register is OR'ed with the eight bit literal 'k'. The result is placed in the W register. |
| Words:            | 1                                                                                                               |
| Cycles:           | 1                                                                                                               |
| Q Cycle Activity: |                                                                                                                 |
| Q1                | Q2 Q3 Q4                                                                                                        |
| Decode            | ReadProcessWrite to Wliteral 'k'dataregister                                                                    |
| Example 1         | IORLW 0x35                                                                                                      |
|                   | Before Instruction                                                                                              |
|                   | W = 0x9A<br>After Instruction                                                                                   |
|                   | W = 0xBF                                                                                                        |
|                   | Z = 0                                                                                                           |
| Example 2         | IORLW MYREG                                                                                                     |
|                   | Before Instruction                                                                                              |
|                   | W = 0x9A<br>Address of MYREG $^{\dagger}$ = 0x37                                                                |
|                   | † MYREG is a symbol for a data memory location                                                                  |
|                   | After Instruction                                                                                               |
|                   | W = 0x9F<br>Z = 0                                                                                               |
| Example 3         | IORLW HIGH (LU_TABLE)                                                                                           |
|                   | Before Instruction                                                                                              |
|                   | W = 0x9A                                                                                                        |
|                   | Address of LU_TABLE <sup>†</sup> = 0x9375<br>† LU_TABLE is a label for an address in program memory             |
|                   | After Instruction                                                                                               |
|                   | W = 0x9B $Z = 0$                                                                                                |
| Example 4         | IORLW 0x00                                                                                                      |
| <b>-</b>          | Before Instruction                                                                                              |
|                   | W = 0x00                                                                                                        |
|                   | After Instruction                                                                                               |
|                   | W = 0x00                                                                                                        |

| Syntax:           | [ <i>label</i> ] IORWF f,d                                                                                                                                                                    |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operands:         | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                            |
| Operation:        | (W).OR. (f) $\rightarrow$ destination                                                                                                                                                         |
| Status Affected:  | Z                                                                                                                                                                                             |
| Encoding:         | 00 0100 dfff ffff                                                                                                                                                                             |
| 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'.                                     |
| Words:            | 1                                                                                                                                                                                             |
| Cycles:           | 1                                                                                                                                                                                             |
| Q Cycle Activity: |                                                                                                                                                                                               |
| Q1                | Q2 Q3 Q4                                                                                                                                                                                      |
| Decode            | Read Process Write to<br>register 'f' data destination                                                                                                                                        |
|                   |                                                                                                                                                                                               |
| 5                 | Before Instruction<br>RESULT=0x13<br>W = 0x91<br>After Instruction<br>RESULT=0x13<br>W = 0x93<br>Z = 0                                                                                        |
| Example 2         | IORWF INDF, 1<br>Before Instruction<br>W = 0x17<br>FSR = 0xC2<br>Contents of Address (FSR) = 0x30<br>After Instruction<br>W = 0x17<br>FSR = 0xC2<br>Contents of Address (FSR) = 0x37<br>Z = 0 |
| Example 3         | IORWF RESULT, 1                                                                                                                                                                               |
| Case 1:           | Before Instruction<br>RESULT=0x13<br>W = 0x91<br>After Instruction<br>RESULT=0x93<br>W = 0x91<br>Z = 0                                                                                        |
| Case 2:           | Before Instruction<br>RESULT=0x00<br>W = 0x00<br>After Instruction<br>RESULT=0x00<br>W = 0x00                                                                                                 |

Instruction Set

| MOVLW             | Move Literal to W                                                                                                                                                                                          |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:           | [label] MOVLW k                                                                                                                                                                                            |
| Operands:         | $0 \le k \le 255$                                                                                                                                                                                          |
| Operation:        | $k \rightarrow W$                                                                                                                                                                                          |
| Status Affected:  | None                                                                                                                                                                                                       |
| Encoding:         | 11 00xx kkkk kkkk                                                                                                                                                                                          |
| Description:      | The eight bit literal 'k' is loaded into W register. The don't cares will assemble as 0's                                                                                                                  |
| Words:            | 1                                                                                                                                                                                                          |
| Cycles:           | 1                                                                                                                                                                                                          |
| Q Cycle Activity: |                                                                                                                                                                                                            |
| Q1                | Q2 Q3 Q4                                                                                                                                                                                                   |
| Decode            | Read     Process     Write to W       literal 'k'     data     register                                                                                                                                    |
| Example 2         | MOVLW MYREG                                                                                                                                                                                                |
|                   | Before Instruction<br>W = 0x10<br>Address of MYREG <sup>†</sup> = 0x37<br><sup>†</sup> MYREG is a symbol for a data memory location<br>After Instruction<br>W = 0x37                                       |
| Example 3         | MOVLW HIGH (LU_TABLE)<br>Before Instruction<br>W = 0x10<br>Address of LU_TABLE <sup>†</sup> = 0x9375<br><sup>†</sup> LU_TABLE is a label for an address in program memory<br>After Instruction<br>W = 0x93 |

| MOVF              |                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Syntax:           | [ <i>label</i> ] MOVF f,d                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| Operands:         | $0 \le f \le 127$<br>d \equiv [0,1]                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| Operation:        | $(f) \rightarrow destination$                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| Status Affected:  | Z                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| Encoding:         | 00 1000 dfff ffff                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| Description:      | The contents of register 'f' is moved to a destination dependent 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. |  |  |  |  |  |  |
| Words:            | 1                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| Cycles:           | 1                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| Q Cycle Activity: |                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| Q1                | Q2 Q3 Q4                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| Decode            | Read     Process     Write to       register 'f'     data     destination                                                                                                                                                                                           |  |  |  |  |  |  |
| Example 2         | After Instruction<br>W = 0xC2 $Z = 0$ MOVF INDF, 0<br>Before Instruction<br>W = 0x17 $FSR = 0xC2$ $Contents of Address (FSR) = 0x00$ After Instruction<br>W = 0x17 $FSR = 0xC2$ $Contents of Address (FSR) = 0x00$ $Z = 1$                                          |  |  |  |  |  |  |
| Example 3         | MOVF FSR, 1                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| Case 1:           | Before Instruction<br>FSR = 0x43<br>After Instruction<br>FSR = 0x43<br>Z = 0                                                                                                                                                                                        |  |  |  |  |  |  |
| Case 2:           | Before Instruction<br>FSR = 0x00<br>After Instruction<br>FSR = 0x00                                                                                                                                                                                                 |  |  |  |  |  |  |

29

| MOVW            | ۲ F                  | Move W            | to f            |                     |
|-----------------|----------------------|-------------------|-----------------|---------------------|
| Syntax:         | [ label ]            | MOVWF             | f               |                     |
| Operands:       | $0 \le f \le 12$     | 7                 |                 |                     |
| Operation:      | $(W) \to f$          |                   |                 |                     |
| Status Affected | I: None              |                   |                 |                     |
| Encoding:       | 00                   | 0000              | lfff            | ffff                |
| Description:    | Move data            | from W re         | egister to      | register 'f'        |
| Words:          | 1                    |                   |                 |                     |
| Cycles:         | 1                    |                   |                 |                     |
| Q Cycle Activit | y:                   |                   |                 |                     |
| Q1              | Q2                   | Q3                | Q4              |                     |
| Decode          | Read<br>register 'f' | Proce:<br>data    |                 | Write<br>gister 'f' |
|                 | - regiotor i         |                   |                 | 9.0101              |
| Example 1       | MOVWF                | OPTION            | _REG            |                     |
|                 | Before Ins           | struction         |                 | · <b>c</b>          |
|                 |                      | _                 | 0x4F            | F                   |
|                 | After Instr          |                   |                 | _                   |
|                 |                      | OPTION_I          | REG=0x4<br>0x4F | F                   |
|                 |                      |                   |                 |                     |
| Example 2       | MOVWF                | INDF              |                 |                     |
|                 | Before Ins           | struction         |                 |                     |
|                 | -                    | V = 0x<br>SR = 0x |                 |                     |
|                 | -                    | Contents $c$      |                 | s (FSR) =           |
|                 | After Instr          |                   | 47              |                     |
|                 |                      | V = 0><br>SR = 0> |                 |                     |
|                 |                      | Contents of       |                 | s (FSR) =           |

| N     | OP             |                               | No Ope      | ration        |                 |
|-------|----------------|-------------------------------|-------------|---------------|-----------------|
| Synt  | tax:           | [ label ]                     | NOP         |               |                 |
| Ope   | rands:         | None                          |             |               |                 |
| Ope   | ration:        | No opera                      | tion        |               |                 |
| State | us Affected:   | None                          |             |               |                 |
| Enco  | oding:         | 00                            | 0000        | 0xx0          | 0000            |
| Des   | cription:      | No opera                      | tion.       |               | 1               |
| Wor   | ds:            | 1                             |             |               |                 |
| Cycl  | les:           | 1                             |             |               |                 |
| QC    | ycle Activity: |                               |             |               |                 |
|       | Q1             | Q2                            | Q3          | C             | Q4              |
|       | Decode         | No<br>operation               | No<br>opera |               | No<br>operation |
|       |                |                               |             |               |                 |
| Exa   | mple           | HERE                          | NOP         |               |                 |
| :     |                | Before In<br>PC<br>After Inst | = add       | )<br>dress he | RE              |

PC = address HERE + 1

Instruction Set

29

| OPTION           | Load Option Register                                                                                                                                                                                                           |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] OPTION                                                                                                                                                                                                               |
| Operands:        | None                                                                                                                                                                                                                           |
| Operation:       | $(W) \rightarrow OPTION$                                                                                                                                                                                                       |
| Status Affected: | None                                                                                                                                                                                                                           |
| Encoding:        | 00 0000 0110 0010                                                                                                                                                                                                              |
| Description:     | The contents of the W register are loaded in the OPTION register. This instruction is supported for code compatibility with PIC16C5X products. Since OPTION is a readable/writable register, the user can directly address it. |
| Words:           | 1                                                                                                                                                                                                                              |
| Cycles:          | 1                                                                                                                                                                                                                              |
|                  |                                                                                                                                                                                                                                |

To maintain upward compatibility with future PIC16CXX products, do not use this instruction.

| RETFIE            | I                                                     | Return from     | Interrupt       |                                                                                                                    |
|-------------------|-------------------------------------------------------|-----------------|-----------------|--------------------------------------------------------------------------------------------------------------------|
| Syntax:           | [ label ]                                             | RETFIE          |                 |                                                                                                                    |
| Operands:         | None                                                  |                 |                 |                                                                                                                    |
| Operation:        | $\begin{array}{l} TOS \to P \\ 1 \to GIE \end{array}$ | C,              |                 |                                                                                                                    |
| Status Affected:  | None                                                  |                 |                 |                                                                                                                    |
| Encoding:         | 00                                                    | 0000 00         | 00 1001         |                                                                                                                    |
| Description:      | loaded in                                             | the PC. The     | Global Interru  | Idress at the Top of Stack (TOS) is<br>upt Enable bit, GIE (INTCON<7>), is<br>ts. This is a two cycle instruction. |
| Words:            | 1                                                     |                 |                 |                                                                                                                    |
| Cycles:           | 2                                                     |                 |                 |                                                                                                                    |
| Q Cycle Activity: |                                                       |                 |                 |                                                                                                                    |
| 1st cycle:        |                                                       |                 |                 |                                                                                                                    |
| Q1                | Q2                                                    | Q3              | Q4              | _                                                                                                                  |
| Decode            | No<br>operation                                       | Process<br>data | No<br>operation |                                                                                                                    |
| 2nd cycle:        |                                                       |                 |                 | -                                                                                                                  |
| Q1                | Q2                                                    | Q3              | Q4              |                                                                                                                    |
| No<br>operation   | No<br>operation                                       | No<br>operation | No<br>operation |                                                                                                                    |
|                   |                                                       |                 |                 |                                                                                                                    |
| Example           | RETFIE                                                |                 |                 |                                                                                                                    |
|                   | After Instr                                           | uction          |                 |                                                                                                                    |

After Instruction PC = TOS GIE = 1

29

Instruction Set

| RETLW             | F                                          | Return with           | Literal in W                     |             |     |
|-------------------|--------------------------------------------|-----------------------|----------------------------------|-------------|-----|
| Syntax:           | [ label ]                                  | RETLW k               |                                  |             |     |
| Operands:         | $0 \le k \le 25$                           | 5                     |                                  |             |     |
| Operation:        | $k \rightarrow W;$<br>TOS $\rightarrow P0$ | С                     |                                  |             |     |
| Status Affected:  | None                                       |                       |                                  |             |     |
| Encoding:         | 11                                         | 01xx kk               | kk kkkk                          |             |     |
| Description:      | loaded 13                                  |                       | ed with the eig<br>at the Top of |             |     |
| Words:            | 1                                          |                       |                                  |             |     |
| Cycles:           | 2                                          |                       |                                  |             |     |
| Q Cycle Activity: |                                            |                       |                                  |             |     |
| 1st cycle:<br>Q1  | Q2                                         | Q3                    | Q4                               |             |     |
| Decode            | Read                                       | Process               | Write to W                       | 1           |     |
|                   | literal 'k'                                | data                  | register                         |             |     |
| 2nd cycle:        |                                            |                       |                                  |             |     |
| Q1                | Q2                                         | Q3                    | Q4                               | 1           |     |
| No<br>operation   | No<br>operation                            | No<br>operation       | No<br>operation                  |             |     |
|                   |                                            |                       |                                  | 1           |     |
| Example           | HERE C                                     | CALL TABLE            | ; W conta                        | ains table  |     |
| -                 |                                            |                       | ; offset                         |             |     |
|                   | •                                          | •                     | ; w now h                        | nas table v | va. |
|                   |                                            | •                     |                                  |             |     |
|                   |                                            | ADDWF PC<br>RETLW k1  | ;W = offs<br>;Begin ta           |             |     |
|                   |                                            | REILW KI<br>RETLW k2  | ; Begin ta                       | IDIE        |     |
|                   | •                                          | •                     |                                  |             |     |
|                   | •                                          | •                     |                                  |             |     |
|                   | F                                          | RETLW kn              | ; End of                         | table       |     |
|                   | Before Ins                                 | struction<br>V = 0x07 |                                  |             |     |
|                   | v<br>After Instr                           |                       |                                  |             |     |
|                   | V                                          | V = value             |                                  |             |     |
|                   | F                                          | PC = TOS              | = Address H                      | ere + 1     |     |

| RETURN            |                 | Return fr       | om Subrouti     | ne                                                                            |
|-------------------|-----------------|-----------------|-----------------|-------------------------------------------------------------------------------|
| Syntax:           | [ label         | ] RETURN        |                 |                                                                               |
| Operands:         | None            |                 |                 |                                                                               |
| Operation:        | TOS -           | → PC            |                 |                                                                               |
| Status Affected:  | None            |                 |                 |                                                                               |
| Encoding:         | 0.0             | 0000            | 0000 1000       | )                                                                             |
| Description:      |                 |                 |                 | ck is POPed and the top of the stac<br>n counter. This is a two cycle instruc |
| Words:            | 1               |                 |                 |                                                                               |
| Cycles:           | 2               |                 |                 |                                                                               |
| Q Cycle Activity: |                 |                 |                 |                                                                               |
| 1st cycle:        |                 |                 |                 |                                                                               |
| Q1                | Q2              | Q3              | Q4              | _                                                                             |
| Decode            | No<br>operation | Process<br>data | No<br>operation |                                                                               |
| 2nd cycle:        |                 |                 |                 | -                                                                             |
| Q1                | Q2              | Q3              | Q4              |                                                                               |
| No<br>operation   | No<br>operation | No<br>operation | No<br>operation |                                                                               |

Example

HERE RETURN

After Instruction PC = TOS

29

© 1997 Microchip Technology Inc.

| RLF               | Rotate Left f through Carry                                                                                                                                                                          |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:           | [ <i>label</i> ] RLF f,d                                                                                                                                                                             |
| Operands:         | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                                                      |
| Operation:        | See description below                                                                                                                                                                                |
| Status Affected:  | C                                                                                                                                                                                                    |
| Encoding:         | 00 1101 dfff ffff                                                                                                                                                                                    |
| Description:      | The contents of register 'f' are rotated one bit to the left through the Carr<br>Flag. If 'd' is 0 the result is placed in the W register. If 'd' is 1 the result is<br>stored back in register 'f'. |
|                   | C Register f                                                                                                                                                                                         |
| Words:            | 1                                                                                                                                                                                                    |
| Cycles:           | 1                                                                                                                                                                                                    |
| Q Cycle Activity: |                                                                                                                                                                                                      |
| Q1                | Q2 Q3 Q4                                                                                                                                                                                             |
| Decode            | ReadProcessWrite toregister 'f'datadestination                                                                                                                                                       |
| Example 1         | RLF REG1, 0<br>Before Instruction<br>REG1= 1110 0110<br>C = 0<br>After Instruction                                                                                                                   |
|                   | REG1=1110 0110<br>W =1100 1100<br>C =1                                                                                                                                                               |
| Example 2         | RLF INDF, 1                                                                                                                                                                                          |
| Case 1:           | Before Instruction<br>W = xxxx xxxx<br>FSR = 0xC2<br>Contents of Address (FSR) = 0011 1010<br>C = 1<br>After Instruction                                                                             |
|                   | W = 0x17<br>FSR = 0xC2<br>Contents of Address (FSR) = 0111 0101<br>C = 0                                                                                                                             |
| Case 2:           | Before Instruction<br>W = xxxx xxxx<br>FSR = 0xC2<br>Contents of Address (FSR) = 1011 1001<br>C = 0                                                                                                  |
|                   | After Instruction<br>W = 0x17<br>FSR = 0xC2<br>Contents of Address (FSR) = 0111 0010<br>C = 1                                                                                                        |

| RRF              | Rotate Right f through Carry                                                                                                                                                                     |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] RRF f,d                                                                                                                                                                         |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                                                  |
| Operation:       | See description below                                                                                                                                                                            |
| Status Affected: | C                                                                                                                                                                                                |
| Encoding:        | 00 1100 dfff ffff                                                                                                                                                                                |
| 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                                                                                                                                                                                     |
| Words:           | 1                                                                                                                                                                                                |
| Cycles:          | 1                                                                                                                                                                                                |
| Q Cycle Activity |                                                                                                                                                                                                  |
| Q1               | Q2 Q3 Q4                                                                                                                                                                                         |
| Decode           | Read         Process         Write to           register 'f'         data         destination                                                                                                    |
|                  | $\begin{array}{rcl} REG1 = & 1110 & 0110 \\ W & = & xxxx & xxxx \\ C & = & 0 \\ \mbox{After Instruction} \\ REG1 = & 1110 & 0110 \\ W & = & 0111 & 0011 \\ C & = & 0 \end{array}$                |
| Example 2        | RRF INDF, 1                                                                                                                                                                                      |
| Case 1:          | Before Instruction                                                                                                                                                                               |
|                  | W = xxxx xxxx<br>FSR = 0xC2<br>Contents of Address (FSR) = 0011 1010<br>C = 1                                                                                                                    |
|                  | After Instruction<br>W = 0x17<br>FSR = 0xC2<br>Contents of Address (FSR) = 1001 1101<br>C = 0                                                                                                    |
| Case 2:          | Before Instruction<br>W = xxxx xxxx<br>FSR = 0xC2<br>Contents of Address (FSR) = 0011 1001<br>C = 0                                                                                              |
|                  | After Instruction<br>W = 0x17<br>FSR = 0xC2<br>Contents of Address (FSR) = 0001 1100<br>C = 1                                                                                                    |

29

#### **SLEEP**

| Syntax:           | [ label ]                                                                                                                            | SLEEP                |                                                |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------|------------------------------------------------|
| Operands:         | None                                                                                                                                 |                      |                                                |
| Operation:        | $\begin{array}{l} 00h \rightarrow W \\ 0 \rightarrow WDT \\ 1 \rightarrow \overline{TO}, \\ 0 \rightarrow \overline{PD} \end{array}$ | ΌΤ,<br>Γ prescaler c | ount,                                          |
| Status Affected:  | TO, PD                                                                                                                               |                      |                                                |
| Encoding:         | 00                                                                                                                                   | 0000 01              | .10 0011                                       |
| Description:      | Watchdog                                                                                                                             | g Timer and          | us bit, PD is<br>its prescaler<br>into SLEEP r |
| Words:            | 1                                                                                                                                    |                      |                                                |
| Cycles:           | 1                                                                                                                                    |                      |                                                |
| Q Cycle Activity: |                                                                                                                                      |                      |                                                |
| Q1                | Q2                                                                                                                                   | Q3                   | Q4                                             |
| Decode            | No<br>operation                                                                                                                      | No<br>operation      | Go to sleep                                    |
| Example:          |                                                                                                                                      | SLEEP                |                                                |

Note: The SLEEP instruction does not affect the assignment of the WDT prescaler

| SUBLW            |                     | Subtract                   |      |                 |                 |               |        |
|------------------|---------------------|----------------------------|------|-----------------|-----------------|---------------|--------|
| Syntax:          | [ label ]           | SUBLW                      | К    |                 |                 |               |        |
| Operands:        | $0 \le k \le 2\xi$  |                            |      |                 |                 |               |        |
| Operation:       | k - (W) —           |                            |      |                 |                 |               |        |
| Status Affected: | C, DC, Z            |                            |      | 1               | 1               |               |        |
| Encoding:        | 11                  | 110x                       | kkkk | kkkk            |                 |               |        |
| Description:     |                     | gister is so<br>The result |      |                 |                 | ethod) from t | he eig |
| Nords:           | 1                   |                            |      |                 |                 |               |        |
| Cycles:          | 1                   |                            |      |                 |                 |               |        |
| Q Cycle Activity | :                   |                            |      |                 |                 |               |        |
| Q1               | Q2                  | Q3                         | Q4   |                 |                 |               |        |
| Decode           | Read<br>literal 'k' | Process<br>data            |      | e to W<br>ister |                 |               |        |
| Example 1:       | SUBLW 0:            | x02                        |      |                 |                 |               |        |
| Case 1:          | Before Instru       | uction                     |      |                 |                 |               |        |
|                  | W<br>C<br>Z         | = X                        |      |                 |                 |               |        |
|                  | After Instruc       | tion                       |      |                 |                 |               |        |
|                  | W<br>C<br>7         |                            |      | sult is posit   | ive             |               |        |
| Case 2:          | _                   | °,                         |      |                 |                 |               |        |
| 0030 2.          | W<br>C              | = 0x02<br>= x              | :    |                 |                 |               |        |
|                  | Z                   | ~                          |      |                 |                 |               |        |
|                  | After Instruc       |                            |      |                 |                 |               |        |
|                  | W<br>C<br>Z         | = 1                        |      | sult is zero    |                 |               |        |
| Case 3:          | Before Instru       | uction                     |      |                 |                 |               |        |
|                  |                     | = 0x03<br>= x<br>= x       | i    |                 |                 |               |        |
|                  | After Instruc       | tion                       |      |                 |                 |               |        |
|                  | С                   | = 0xFF<br>= 0<br>= 0       |      | sult is nega    | itive           |               |        |
| Example 2        | SUBLW               | MYREG                      |      |                 |                 |               |        |
|                  | Before Ins          |                            |      |                 |                 |               |        |
|                  |                     | V = 0x1                    |      | 0.05            |                 |               |        |
|                  |                     | ddress of M                |      |                 | nemory location | on            |        |
|                  | After Instr         | uction                     |      |                 | inter y locali  |               |        |
|                  |                     | V = 0x2                    |      |                 |                 |               |        |

29

| SUBWF             | Subtract W from f                                                                                                                                                            |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:           | [ <i>label</i> ] SUBWF f,d                                                                                                                                                   |
| Operands:         | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \left[0,1\right] \end{array}$                                                                                                   |
| Operation:        | (f) - (W) $\rightarrow$ destination                                                                                                                                          |
| Status Affected:  | C, DC, Z                                                                                                                                                                     |
| Encoding:         | 00 0010 dfff ffff                                                                                                                                                            |
| Description:      | Subtract (2's complement method) W register from 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'.    |
| Words:            | 1                                                                                                                                                                            |
| Cycles:           | 1                                                                                                                                                                            |
| Q Cycle Activity: |                                                                                                                                                                              |
| Q1                | Q2 Q3 Q4                                                                                                                                                                     |
| Decode            | Read         Process         Write to           register 'f'         data         destination                                                                                |
| Case 2:           | After Instruction<br>$\begin{array}{rcl} REG1=&1\\ W&=&2\\ C&=&1\\ Z&=&0\\ \end{array}$ ; result is positive<br>$\begin{array}{rcl} Z=&0\\ Before Instruction\\ \end{array}$ |
|                   | REG1= 2 $W = 2$ $C = x$ $Z = x$ After Instruction                                                                                                                            |
|                   | REG1= 0 $W = 2$ $C = 1$ ; result is zero $Z = 1$                                                                                                                             |
| Case 3:           | Before Instruction                                                                                                                                                           |
|                   | REG1= 1 $W = 2$ $C = x$ $Z = x$                                                                                                                                              |
|                   | After Instruction                                                                                                                                                            |
|                   | $\begin{array}{rcl} REG1= & 0xFF \\ W &=& 2 \\ C &=& 0 \\ Z &=& 0 \end{array}; \text{ result is negative} \\ \end{array}$                                                    |

| SWAPF             | Swap Nibbles in f                                                                                                                                            |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:           | [ <i>label</i> ] SWAPF f,d                                                                                                                                   |
| Operands:         | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \left[0,1\right] \end{array}$                                                                                   |
| Operation:        | $(f<3:0>) \rightarrow destination<7:4>,$<br>$(f<7:4>) \rightarrow destination<3:0>$                                                                          |
| Status Affected:  | None                                                                                                                                                         |
| Encoding:         | 00 1110 dfff ffff                                                                                                                                            |
| Description:      | The upper and lower nibbles of register 'f' are exchanged. If 'd' is 0 the result is placed in W register. If 'd' is 1 the result is placed in register 'f'. |
| Words:            | 1                                                                                                                                                            |
| Cycles:           | 1                                                                                                                                                            |
| Q Cycle Activity: |                                                                                                                                                              |
| Q1                | Q2 Q3 Q4                                                                                                                                                     |
| Decode            | ReadProcessWrite toregister 'f'datadestination                                                                                                               |
| Example 1         | SWAPF REG, 0                                                                                                                                                 |
|                   | Before Instruction                                                                                                                                           |
|                   | REG1= 0xA5                                                                                                                                                   |
|                   | After Instruction                                                                                                                                            |
|                   | REG1= 0xA5<br>W = 0x5A                                                                                                                                       |
| Example 2         | SWAPF INDF, 1                                                                                                                                                |
|                   | Before Instruction<br>W = 0x17<br>FSR = 0xC2<br>Contents of Address (FSR) = 0x20                                                                             |
|                   | After Instruction<br>W = 0x17<br>FSR = 0xC2<br>Contents of Address (FSR) = 0x02                                                                              |
| Example 3         | SWAPF REG, 1                                                                                                                                                 |
|                   | Before Instruction                                                                                                                                           |
|                   | REG1= 0xA5                                                                                                                                                   |
|                   | After Instruction                                                                                                                                            |
|                   | REG1= 0x5A                                                                                                                                                   |

| TRIS             |                      | Load TF   | RIS Regis | ter  |                                                                                     |
|------------------|----------------------|-----------|-----------|------|-------------------------------------------------------------------------------------|
| Syntax:          | [ label ]            | TRIS      | f         |      |                                                                                     |
| Operands:        | $5 \le f \le 7$      |           |           |      |                                                                                     |
| Operation:       | $(W) \rightarrow TF$ | RIS regis | ster f;   |      |                                                                                     |
| Status Affected: | None                 |           |           |      |                                                                                     |
| Encoding:        | 00                   | 0000      | 0110      | Offf |                                                                                     |
| Description:     |                      | e TRIS    | ••        |      | e compatibility with the PIC16C5X prod-<br>able and writable, the user can directly |
| Words:           | 1                    |           |           |      |                                                                                     |
| Cycles:          | 1                    |           |           |      |                                                                                     |
|                  |                      |           |           |      |                                                                                     |

#### Example

To maintain upward compatibility with future PIC16CXX products, do not use this instruction.

| XORLW             | Exclusive OR Litera                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | al with W                                                |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|
| Syntax:           | [ <i>label</i> ] XORLW k                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                          |
| Operands:         | $0 \le k \le 255$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                          |
| Operation:        | (W).XOR. $k \rightarrow W$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                          |
| Status Affected:  | Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                          |
| Encoding:         | 11 1010 kkkk kł                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <u>kk</u>                                                |
| Description:      | The contents of the W registe result is placed in the W registered | r are XOR'ed with the eight bit literal 'k'. The ster.   |
| Words:            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                          |
| Cycles:           | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                          |
| Q Cycle Activity: |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                          |
| Q1                | Q2 Q3 Q4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                          |
| Decode            | ReadProcessWrite tliteral 'k'dataregis                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                          |
| Example 1         | XORLW 0xAF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ; 1010 1111 (0xAF)                                       |
|                   | Before Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ; 1011 0101 (0xB5)                                       |
|                   | W = 0xB5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ;                                                        |
|                   | After Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ; 0001 1010 (0x1A)                                       |
|                   | W = 0x1A $Z = 0$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                          |
| Example 2         | XORLW MYREG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                          |
|                   | Before Instruction<br>W = 0xAF<br>Address of MYREG <sup>†</sup> = 0<br>† MYREG is a symbol for<br>After Instruction<br>W = 0x18<br>Z = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x37<br>a data memory location                           |
| Example 3         | XORLW HIGH (LU_TABLE)<br>Before Instruction<br>W = 0xAF<br>Address of LU_TABLE<br>$\dagger LU_TABLE$ is a label for<br>After Instruction<br>W = 0x3C<br>Z = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <sup>†</sup> = 0x9375<br>or an address in program memory |

| XORWF             |                                                                | Exclusive OF                                                  | -                    |                  |                                                           |
|-------------------|----------------------------------------------------------------|---------------------------------------------------------------|----------------------|------------------|-----------------------------------------------------------|
| Syntax:           | [label]                                                        | XORWF f,d                                                     |                      |                  |                                                           |
| Operands:         | $\begin{array}{l} 0 \leq f \leq 12 \\ d \in [0,1] \end{array}$ | 7                                                             |                      |                  |                                                           |
| Operation:        | (W).XOR.                                                       | (f) $\rightarrow$ destina                                     | ation                |                  |                                                           |
| Status Affected:  | Z                                                              |                                                               |                      |                  |                                                           |
| Encoding:         | 00                                                             | 0110 dfi                                                      | f ffff               |                  |                                                           |
| Description:      |                                                                |                                                               |                      |                  | egister 'f'. If 'd' is 0 the<br>t is stored back in regis |
| Words:            | 1                                                              |                                                               |                      |                  |                                                           |
| Cycles:           | 1                                                              |                                                               |                      |                  |                                                           |
| Q Cycle Activity: |                                                                |                                                               |                      |                  |                                                           |
| Q1                | Q2                                                             | Q3                                                            | Q4                   | 7                |                                                           |
| Decode            | Read<br>register 'f'                                           | Process<br>data                                               | Write to destination |                  |                                                           |
| Example 1         | XORWF                                                          | REG, 1                                                        |                      | ; 1010 1111      | (OxAF)                                                    |
|                   | Before Ins                                                     | struction                                                     |                      | ; 1011 0101      | (0xB5)                                                    |
|                   |                                                                | REG= 0xAF                                                     |                      | ;                |                                                           |
|                   |                                                                | W = 0xB5                                                      |                      | ; 0001 1010      | (0x1A)                                                    |
|                   | After Instr                                                    | uction                                                        |                      |                  |                                                           |
|                   |                                                                | $\begin{array}{rcl} REG = & 0x1A \\ W & = & 0xB5 \end{array}$ |                      |                  |                                                           |
| Example 2         | XORWF                                                          | REG, 0                                                        |                      | ; 1010 1111      | (0xAF)                                                    |
|                   | Before Ins                                                     | struction                                                     |                      | ; 1011 0101      | (0xB5)                                                    |
|                   |                                                                | REG= 0xAF<br>W = 0xB5                                         |                      | ;<br>; 0001 1010 | (0x1A)                                                    |
|                   | After Instr                                                    | uction                                                        |                      |                  |                                                           |
|                   |                                                                | REG= 0xAF<br>W = 0x1A                                         |                      |                  |                                                           |
| Example 3         | XORWF                                                          | INDF, 1                                                       |                      |                  |                                                           |
|                   | F                                                              | struction<br>N = 0xB5<br>FSR = 0xC2<br>Contents of Ade        | dress (FSR) =        | = 0xAF           |                                                           |
|                   | After Instr                                                    |                                                               | · - /                |                  |                                                           |
|                   |                                                                | W = 0xB5<br>=SR = 0xC2                                        |                      |                  |                                                           |





#### 8.2 Control Registers

Generally devices have a minimum of three registers associated with interrupts. The INTCON register which contains Global Interrupt Enable bit, GIE, as well as the Peripheral Interrupt Enable bit, PEIE, and the PIE / PIR register pair which enable the peripheral interrupts and display the interrupt flag status.

#### 8.2.1 INTCON Register

The INTCON Register is a readable and writable register which contains various enable and flag bits.

**Note:** Interrupt flag bits get set when an interrupt condition occurs regardless of the state of its corresponding enable bit or the global enable bit, GIE (INTCON<7>).This feature allows for software polling.

#### Register 8-1: INTCON Register

| R/W-0 | R/W-0               | R/W-0 | R/W-0               | R/W-0                     | R/W-0 | R/W-0               | R/W-0                  |
|-------|---------------------|-------|---------------------|---------------------------|-------|---------------------|------------------------|
| GIE   | PEIE <sup>(3)</sup> | TOIE  | INTE <sup>(2)</sup> | RBIE <sup>(1,</sup><br>2) | T0IF  | INTF <sup>(2)</sup> | RBIF <sup>(1, 2)</sup> |
| bit 7 |                     |       | <u> </u>            | <u> </u>                  |       | 1                   | bit 0                  |

| bit 7 | <b>GIE:</b> Global Interrupt Enable bit<br>1 = Enables all un-masked interrupts<br>0 = Disables all interrupts                                                                                        |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 6 | <b>PEIE:</b> Peripheral Interrupt Enable bit<br>1 = Enables all un-masked peripheral interrupts<br>0 = Disables all peripheral interrupts                                                             |
| bit 5 | <b>T0IE:</b> TMR0 Overflow Interrupt Enable bit<br>1 = Enables the TMR0 overflow interrupt<br>0 = Disables the TMR0 overflow interrupt                                                                |
| bit 4 | INTE: INT External Interrupt Enable bit<br>1 = Enables the INT external interrupt<br>0 = Disables the INT external interrupt                                                                          |
| bit 3 | <b>RBIE</b> <sup>(1)</sup> : RB Port Change Interrupt Enable bit<br>1 = Enables the RB port change interrupt<br>0 = Disables the RB port change interrupt                                             |
| bit 2 | <b>T0IF:</b> TMR0 Overflow Interrupt Flag bit<br>1 = TMR0 register has overflowed (must be cleared in software)<br>0 = TMR0 register did not overflow                                                 |
| bit 1 | INTF: INT External Interrupt Flag bit<br>1 = The INT external interrupt occurred (must be cleared in software)<br>0 = The INT external interrupt did not occur                                        |
| bit 0 | <b>RBIF</b> <sup>(1)</sup> : RB Port Change Interrupt Flag bit<br>1 = At least one of the RB7:RB4 pins changed state (must be cleared in software)<br>0 = None of the RB7:RB4 pins have changed state |
|       | Legend                                                                                                                                                                                                |
|       | R = Readable bit W = Writable bit                                                                                                                                                                     |
|       | U = Unimplemented bit, read as '0' - n = Value at POR reset                                                                                                                                           |
|       |                                                                                                                                                                                                       |
|       | Note 1: In some devices, the RBIE bit may also be known as GPIE and the RBIF bit may be know as GPIF.                                                                                                 |
|       | Note 2: Some devices may not have this feature. For those devices this bit is reserved.                                                                                                               |
|       | Note 3: In devices with only one peripheral interrupt, this bit may be EEIE or ADIE.                                                                                                                  |

nterrupts

#### 8.2.2 PIE Register(s)

Depending on the number of peripheral interrupt sources, there may be multiple Peripheral Interrupt Enable registers (PIE1, PIE2). These registers contain the individual enable bits for the Peripheral interrupts. These registers will be generically referred to as PIE. If the device has a PIE register, The PEIE bit must be set to enable any of these peripheral interrupts.

Note: Bit PEIE (INTCON<6>) must be set to enable any of the peripheral interrupts.

Although, the PIE register bits have a general bit location with each register, future devices may not have consistent placement. Bit location inconsistencies will not be a problem if you use the supplied Microchip Include files for the symbolic use of these bits. This will allow the Assembler/Compiler to automatically take care of the placement of these bits by specifying the correct register and bit name.

Register 8-2: PIE Register

|   | R/W-0<br>(Note 1)                                                                                          |       |
|---|------------------------------------------------------------------------------------------------------------|-------|
|   | bit 7                                                                                                      | bit ( |
|   |                                                                                                            |       |
|   | TMR1IE: TMR1 Overflow Interrupt Enable bit                                                                 |       |
|   | <ul><li>1 = Enables the TMR1 overflow interrupt</li><li>0 = Disables the TMR1 overflow interrupt</li></ul> |       |
|   | TMR2IE: TMR2 to PR2 Match Interrupt Enable bit                                                             |       |
|   | 1 = Enables the TMR2 to PR2 match interrupt                                                                |       |
|   | 0 = Disables the TMR2 to PR2 match interrupt                                                               |       |
|   | CCP1IE: CCP1 Interrupt Enable bit                                                                          |       |
|   | 1 = Enables the CCP1 interrupt                                                                             |       |
|   | 0 = Disables the CCP1 interrupt                                                                            |       |
|   | CCP2IE: CCP2 Interrupt Enable bit                                                                          |       |
|   | 1 = Enables the CCP2 interrupt<br>0 = Disables the CCP2 interrupt                                          |       |
|   | SSPIE: Synchronous Serial Port Interrupt Enable bit                                                        |       |
|   | 1 = Enables the SSP interrupt                                                                              |       |
|   | 0 = Disables the SSP interrupt                                                                             |       |
|   | RCIE: USART Receive Interrupt Enable bit                                                                   |       |
|   | 1 = Enables the USART receive interrupt                                                                    |       |
|   | 0 = Disables the USART receive interrupt                                                                   |       |
|   | <b>TXIE</b> : USART Transmit Interrupt Enable bit<br>1 = Enables the USART transmit interrupt              |       |
|   | 0 = Disables the USART transmit interrupt                                                                  |       |
|   | ADIE: A/D Converter Interrupt Enable bit                                                                   |       |
|   | 1 = Enables the A/D interrupt                                                                              |       |
|   | 0 = Disables the A/D interrupt                                                                             |       |
|   | ADCIE: Slope A/D Converter comparator Trip Interrupt Enable bit                                            |       |
|   | <ul><li>1 = Enables the Slope A/D interrupt</li><li>0 = Disables the Slope A/D interrupt</li></ul>         |       |
|   | OVFIE: Slope A/D TMR Overflow Interrupt Enable bit                                                         |       |
|   | 1 = Enables the Slope A/D TMR overflow interrupt                                                           |       |
|   | 0 = Disables the Slope A/D TMR overflow interrupt                                                          |       |
|   | PSPIE: Parallel Slave Port Read/Write Interrupt Enable bit                                                 |       |
|   | 1 = Enables the PSP read/write interrupt                                                                   |       |
|   | 0 = Disables the PSP read/write interrupt                                                                  |       |
|   | <b>EEIE</b> : EE Write Complete Interrupt Enable bit<br>1 = Enables the EE write complete interrupt        |       |
|   | 0 = Disables the EE write complete interrupt                                                               |       |
|   | LCDIE: LCD Interrupt Enable bit                                                                            |       |
|   | 1 = Enables the LCD interrupt                                                                              |       |
|   | 0 = Disables the LCD interrupt                                                                             |       |
|   | CMIE: Comparator Interrupt Enable bit                                                                      |       |
|   | <ul><li>1 = Enables the Comparator interrupt</li><li>0 = Disables the Comparator interrupt</li></ul>       |       |
|   |                                                                                                            |       |
|   | Legend                                                                                                     |       |
|   | R = Readable bit W = Writable bit                                                                          |       |
| ļ | U = Unimplemented bit, read as '0' - n = Value at POR reset                                                |       |

8

#### 8.2.3 PIR Register(s)

Depending on the number of peripheral interrupt sources, there may be multiple Peripheral Interrupt Flag registers (PIR1, PIR2). These registers contain the individual flag bits for the peripheral interrupts. These registers will be generically referred to as PIR.

**Note 1:** Interrupt flag bits get set when an interrupt condition occurs regardless of the state of its corresponding enable bit or the global enable bit, GIE (INTCON<7>).

**Note 2:** User software should ensure the appropriate interrupt flag bits are cleared (by software) prior to enabling an interrupt, and after servicing that interrupt.

Although, the PIR bits have a general bit location within each register, future devices may not be able to be consistent with that. It is recommended that you use the supplied Microchip Include files for the symbolic use of these bits. This will allow the Assembler/Compiler to automatically take care of the placement of these bits within the specified register.

| _        | R/W-0                                                                                                               |     |
|----------|---------------------------------------------------------------------------------------------------------------------|-----|
|          | (Note 1)                                                                                                            |     |
| b        | it 7                                                                                                                | bit |
| т        | MR1IF: TMR1 Overflow Interrupt Flag bit                                                                             |     |
|          | = TMR1 register overflowed (must be cleared in software)                                                            |     |
|          | ) = TMR1 register did not overflow                                                                                  |     |
|          | <b>MR2IF</b> : TMR2 to PR2 Match Interrupt Flag bit                                                                 |     |
|          | = TMR2 to PR2 match occurred (must be cleared in software)                                                          |     |
|          | = No TMR2 to PR2 match occurred                                                                                     |     |
| C        | CCP1IF: CCP1 Interrupt Flag bit                                                                                     |     |
| С        | Capture Mode                                                                                                        |     |
|          | = A TMR1 register capture occurred (must be cleared in software)                                                    |     |
| 0        | ) = No TMR1 register capture occurred                                                                               |     |
| <u>C</u> | Compare Mode                                                                                                        |     |
|          | = A TMR1 register compare match occurred (must be cleared in software)                                              |     |
| 0        | ) = No TMR1 register compare match occurred                                                                         |     |
| _        | PWM Mode                                                                                                            |     |
|          | Jnused in this mode                                                                                                 |     |
| C        | CCP2IF: CCP2 Interrupt Flag bit                                                                                     |     |
| _        | Capture Mode                                                                                                        |     |
|          | = A TMR1 register capture occurred (must be cleared in software)                                                    |     |
|          | = No TMR1 register capture occurred                                                                                 |     |
|          | Compare Mode                                                                                                        |     |
|          | = A TMR1 register compare match occurred (must be cleared in software)<br>= No TMR1 register compare match occurred |     |
|          |                                                                                                                     |     |
| _        | <u>2WM Mode</u><br>Jnused in this mode                                                                              |     |
| -        | SPIF: Synchronous Serial Port Interrupt Flag bit                                                                    |     |
|          | = The transmission/reception is complete                                                                            |     |
|          | ) = Waiting to transmit/receive                                                                                     |     |
|          | RCIF: USART Receive Interrupt Flag bit                                                                              |     |
|          | = The USART receive buffer, RCREG, is full (cleared when RCREG is read)                                             |     |
|          | ) = The USART receive buffer is empty                                                                               |     |
|          | <b>XIF</b> : USART Transmit Interrupt Flag bit                                                                      |     |
|          | = The USART transmit buffer, TXREG, is empty (cleared when TXREG is written                                         | )   |
| -        | ) = The USART transmit buffer is full                                                                               |     |
|          | ADIF: A/D Converter Interrupt Flag bit                                                                              |     |
|          | = An A/D conversion completed (must be cleared in software)                                                         |     |
| U        | ) = The A/D conversion is not complete                                                                              |     |
|          |                                                                                                                     |     |

### Register 8-3: PIR Register (Cont'd)

- bit **ADCIF**: Slope A/D Converter Comparator Trip Interrupt Flag bit 1 = An A/D conversion completed (must be cleared in software) 0 = The A/D conversion is not complete
- bit **OVFIF**: Slope A/D TMR Overflow Interrupt Flag bit 1 = Slope A/D TMR overflowed (must be cleared in software)
  - 0 = Slope A/D TMR did not overflow
- bit **PSPIF:** Parallel Slave Port Read/Write Interrupt Flag bit
   1 = A read or a write operation has taken place (must be cleared in software)
   0 = No read or write has occurred
- bit **EEIF**: EE Write Complete Interrupt Flag bit 1 = The data EEPROM write operation is complete (must be cleared in software) 0 = The data EEPROM write operation is not complete
- bit LCDIF: LCD Interrupt Flag bit
  - 1 = LCD interrupt has occurred (must be cleared in software) 0 = LCD interrupt has not occurred
- bit **CMIF**: Comparator Interrupt Flag bit
  - 1 = Comparator input has changed (must be cleared in software)
  - 0 = Comparator input has not changed

| Legend                             |                          |
|------------------------------------|--------------------------|
| R = Readable bit W = Writable bit  |                          |
| U = Unimplemented bit, read as '0' | - n = Value at POR reset |

**Note 1:** The bit position of the flag bits is device dependent. Please refer to the device data sheet for bit placement.

### 8.3 Interrupt Latency

Interrupt latency is defined as the time from the interrupt event (the interrupt flag bit gets set) to the time that the instruction at address 0004h starts execution (when that interrupt is enabled).

For synchronous interrupts (typically internal), the latency is 3Tcy.

For asynchronous interrupts (typically external), such as the INT or Port RB Change Interrupt, the interrupt latency will be 3 - 3.75TcY (instruction cycles). The exact latency depends upon when the interrupt event occurs (Figure 8-2) in relation to the instruction cycle.

The latency is the same for both one and two cycle instructions.

### 8.4 INT and External Interrupts

The external interrupt on the INT pin is edge triggered: either rising if the INTEDG bit (OPTION<6>) is set, or falling, if the INTEDG bit is clear. When a valid edge appears on the INT pin, the INTF flag bit (INTCON<1>) is set. This interrupt can be enabled/disabled by setting/clearing the INTE enable bit (INTCON<4>). The INTF bit must be cleared in software in the interrupt service routine before re-enabling this interrupt. The INT interrupt can wake-up the processor from SLEEP, if the INTE bit was set prior to going into SLEEP. The status of the GIE bit decides whether or not the processor branches to the interrupt vector following wake-up. See the "Watchdog Timer and Sleep Mode" section for details on SLEEP and for timing of wake-up from SLEEP through INT interrupt.

|                                                  | Q1   Q2   Q3   Q4                                                                                                                                     | Q1   Q2   Q3   Q4                                                                                | Q1   Q2   Q3   Q4        | Q1   Q2   Q3   Q4 | 4 Q1   Q2   Q3   Q4                     |
|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|--------------------------|-------------------|-----------------------------------------|
| OSC1 /                                           |                                                                                                                                                       |                                                                                                  |                          |                   |                                         |
| CLKOUT 3                                         | (4)                                                                                                                                                   |                                                                                                  | <u> </u> /               | `/<br>'           | _\                                      |
| INT pin                                          |                                                                                                                                                       | (1)                                                                                              | 1<br>1<br>1              | 1<br>1<br>1       |                                         |
| INTF flag<br>(INTCON<1>)                         |                                                                                                                                                       |                                                                                                  | Interrupt Latency 2      | 1<br>1<br>1       | • · · · · · · · · · · · · · · · · · · · |
| GIE bit<br>(INTCON<7>)                           |                                                                                                                                                       |                                                                                                  |                          |                   |                                         |
| INSTRUCTION I                                    | LOW                                                                                                                                                   |                                                                                                  | -<br>-<br>               | 1.<br>1.          |                                         |
| PC 🤇                                             | PC                                                                                                                                                    | PC+1                                                                                             | X PC+1                   | × 0004h           | X 0005h                                 |
| Instruction {                                    | Inst (PC)                                                                                                                                             | Inst (PC+1)                                                                                      | —                        | Inst (0004h)      | Inst (0005h)                            |
| Instruction {                                    | Inst (PC-1)                                                                                                                                           | Inst (PC)                                                                                        | Dummy Cycle              | Dummy Cycle       | Inst (0004h)                            |
| 2: Interrup<br>Latency<br>3: CLKOU<br>4: For min | ag is sampled here (ev<br>t latency = 3-4 TcY w<br>/ is the same whether<br>T is available only in f<br>imum width of INT pu<br>enabled to be set any | here TCY = instructior<br>Instruction (PC) is a<br>RC oscillator mode.<br>Ise, refer to AC specs | single cycle or a 2-cycl | e instruction.    |                                         |

Figure 8-2: INT Pin and Other External Interrupt Timing

**Note:** Any interrupts caused by external signals (such as timers, capture, change on port) will have similar timing.

### 8.5 Context Saving During Interrupts

During an interrupt, only the return PC value is saved on the stack. Typically, users may wish to save key registers during an interrupt e.g. W register and STATUS register. This has to be implemented in software.

The action of saving information is commonly referred to as "PUSHing," while the action of restoring the information before the return is commonly referred to as "POPing." These (PUSH, POP) are not instruction mnemonics, but are conceptual actions. This action can be implemented by a sequence of instructions. For ease of code transportability, these code segments can be made into MACROs (see MPASM Assembler User's Guide for details on creating macros).

Example 8-1 stores and restores the STATUS and W registers for devices with common RAM (such as the PIC16C77). The user register, W\_TEMP, must be defined across all banks and must be defined at the same offset from the bank base address (i.e., W\_TEMP is defined at 0x70 - 0x7F in Bank0). The user register, STATUS\_TEMP, must be defined in Bank0, in this example STATUS\_TEMP is also in Bank0.

The steps of Example 8-1:

- 1. Stores the W register regardless of current bank.
- 2. Stores the STATUS register in Bank0.
- 3. Executes the Interrupt Service Routine (ISR) code.
- 4. Restores the STATUS (and bank select bit register).
- 5. Restores the W register.

If additional locations need to be saved before executing the Interrupt Service Routine (ISR) code, they should be saved after the STATUS register is saved (step 2), and restored before the STATUS register is restored (step 4).

Example 8-1: Saving the STATUS and W Registers in RAM (for Devices with Common RAM)

| MOVWF    | W_TEMP          | ;  | Copy W to a Temporary Register       |
|----------|-----------------|----|--------------------------------------|
|          |                 | ;  | regardless of current bank           |
| SWAPF    | STATUS,W        | ;  | Swap STATUS nibbles and place        |
|          |                 | ;  | into W register                      |
| MOVWF    | STATUS_TEMP     | ;  | Save STATUS to a Temporary register  |
|          |                 | ;  | in BankO                             |
| :        |                 |    |                                      |
| : (Inter | rupt Service Ro | ut | tine (ISR) )                         |
| :        |                 |    |                                      |
| SWAPF    | STATUS_TEMP,W   | ;  | Swap original STATUS register value  |
|          |                 | ;  | into W (restores original bank)      |
| MOVWF    | STATUS          | ;  | Restore STATUS register from         |
|          |                 | ;  | W register                           |
| SWAPF    | W_TEMP,F        | ;  | Swap W_Temp nibbles and return       |
|          |                 | ;  | value to W_Temp                      |
| SWAPF    | W_TEMP,W        | ;  | Swap W_Temp to W to restore original |
|          |                 | ;  | W value without affecting STATUS     |
|          |                 |    |                                      |

8

```
Example 8-6: Source File Template
```

```
LIST p = p16C77
                       ; List Directive,
;
    Revision History
;
    #INCLUDE <P16C77.INC> ; Microchip Device Header File
;
    #INCLUDE <MY_STD.MAC> ; Include my standard macros
    #INCLUDE <APP.MAC>
                             ; File which includes macros specific
                             ; to this application
; Specify Device Configuration Bits
    __CONFIG __XT_OSC & _PWRTE_ON & _BODEN_OFF & _CP_OFF & _WDT_ON
;
    org 0x00
                      ; Start of Program Memory
RESET_ADDR :
                      ; First instruction to execute after a reset
    end
```

Example 8-7: Typical Interrupt Service Routine (ISR)

| org ISR_ADDR                   | ;                                                                         |
|--------------------------------|---------------------------------------------------------------------------|
| PUSH_MACRO                     | ; MACRO that saves required context registers,                            |
|                                | ; or in-line code                                                         |
| CLRF STATUS                    | ; Bank0                                                                   |
| BTFSC PIR1, TMR1IF             | ; Timer1 overflow interrupt?                                              |
| GOTO T1_INT                    | ; YES                                                                     |
| BTFSC PIR1, ADIF               | ; NO, A/D interrupt?                                                      |
| GOTO AD_INT                    | ; YES, do A/D thing                                                       |
| :                              | ; NO, do this for all sources                                             |
| :                              | i                                                                         |
|                                | ; NO, LCD interrupt                                                       |
| _                              | ; YES, do LCD thing                                                       |
|                                | ; NO, Change on PORTB interrupt?                                          |
| GOTO PORTB_INT                 | ; YES, Do PortB Change thing                                              |
| INT_ERROR_LP1                  | ; NO, do error recovery                                                   |
| GOTO INT_ERROR_LP1             | ; This is the trap if you enter the ISR                                   |
|                                | ; but there were no expected                                              |
|                                | ; interrupts                                                              |
| T1_INT                         | ; Routine when the Timer1 overflows                                       |
| :                              |                                                                           |
|                                | ; Clear the Timer1 overflow interrupt flag                                |
| _                              | ; Ready to leave ISR (for this request)                                   |
| AD_INT<br>:                    | ; Routine when the A/D completes                                          |
|                                | ;<br>. Clean the A/D interrupt flag                                       |
| BCF PIR1, ADIF<br>GOTO END ISR | ; Clear the A/D interrupt flag<br>; Ready to leave ISR (for this request) |
| LCD_INT                        | ; Routine when the LCD Frame begins                                       |
| :                              | ;                                                                         |
|                                | ,<br>; Clear the LCD interrupt flag                                       |
| GOTO END ISR                   |                                                                           |
| PORTB INT                      | ; Routine when PortB has a change                                         |
| :                              | ;                                                                         |
| END ISR                        | ;                                                                         |
| POP MACRO                      | ; MACRO that restores required registers,                                 |
|                                | ; or in-line code                                                         |
| RETFIE                         | Return and enable interrupts                                              |
|                                | -                                                                         |

### 9.1 Introduction

General purpose I/O pins can be considered the simplest of peripherals. They allow the PICmicro<sup>™</sup> to monitor and control other devices. To add flexibility and functionality to a device, some pins are multiplexed with an alternate function(s). These functions depend on which peripheral features are on the device. In general, when a peripheral is functioning, that pin may not be used as a general purpose I/O pin.

For most ports, the I/O pin's direction (input or output) is controlled by the data direction register, called the TRIS register. TRIS<x> controls the direction of PORT<x>. A '1' in the TRIS bit corresponds to that pin being an input, while a '0' corresponds to that pin being an output. An easy way to remember is that a '1' looks like an I (input) and a '0' looks like an O (output).

The PORT register is the latch for the data to be output. When the PORT is read, the device reads the levels present on the I/O pins (not the latch). This means that care should be taken with read-modify-write commands on the ports and changing the direction of a pin from an input to an output.

Figure 9-1 shows a typical I/O port. This does not take into account peripheral functions that may be multiplexed onto the I/O pin. Reading the PORT register reads the status of the pins whereas writing to it will write to the port latch. All write operations (such as BSF and BCF instructions) are read-modify-write operations. Therefore a write to a port implies that the port pins are read, this value is modified, and then written to the port data latch.



Figure 9-1: Typical I/O Port

### 18.1 Introduction

The Universal Synchronous Asynchronous Receiver Transmitter (USART) module is one of the two serial I/O modules (other is the SSP module). The USART is also known as a Serial Communications Interface or SCI. The USART can be configured as a full duplex asynchronous system that can communicate with peripheral devices such as CRT terminals and personal computers, or it can be configured as a half duplex synchronous system that can communicate with peripheral devices such as A/D or D/A integrated circuits, Serial EEPROMs etc.

The USART can be configured in the following modes:

- Asynchronous (full duplex)
- Synchronous Master (half duplex)
- Synchronous Slave (half duplex)

The SPEN bit (RCSTA<7>), and the TRIS bits, have to be set in order to configure the TX/CK and RX/DT pins for the USART.

### 18.2 Control Registers

| R/W-0                                                  | R/W-0                                        | R/W-0          | R/W-0      | U-0     | R/W-0 | R-1  | R/W-0 |
|--------------------------------------------------------|----------------------------------------------|----------------|------------|---------|-------|------|-------|
| CSRC                                                   | TX9                                          | TXEN           | SYNC       | —       | BRGH  | TRMT | TX9D  |
| bit 7                                                  |                                              |                |            |         |       |      | bit 0 |
| <b>CSRC:</b> Cloc<br><u>Asynchronc</u><br>Don't care   | ck Source Se<br>ous mode                     | elect bit      |            |         |       |      |       |
|                                                        | mode (Clock                                  | generated ir   |            | ו BRG)  |       |      |       |
| 1 = Selects                                            | ransmit Enal<br>9-bit transm<br>8-bit transm | ission         |            |         |       |      |       |
| <b>TXEN</b> : Trans<br>1 = Transmi<br>0 = Transmi      |                                              | bit            |            |         |       |      |       |
| Note:                                                  | SREN/CREM                                    | l overrides T  | XEN in SYN | C mode. |       |      |       |
| 1 = Synchro                                            | ART Mode Se<br>onous mode<br>ronous mode     |                |            |         |       |      |       |
| Unimpleme                                              | ented: Read                                  | as '0'         |            |         |       |      |       |
| BRGH: High<br>Asynchrono<br>1 = High sp<br>0 = Low spe | eed                                          | Select bit     |            |         |       |      |       |
| <u>Synchronou</u><br>Unused in t                       |                                              |                |            |         |       |      |       |
| <b>TRMT</b> : Tran<br>1 = TSR em<br>0 = TSR full       | pty                                          | egister Status | s bit      |         |       |      |       |
| <b>TX9D:</b> 9th b                                     |                                              |                |            |         |       |      |       |

- n = Value at POR reset

W = Writable bit

### Register 18-1: TXSTA: Transmit Status and Control Register

18

R = Readable bit

U = Unimplemented bit, read as '0'

|   | R/W-0                                  | R/W-0                                                              | R/W-0     | R/W-0          | U-0         | R-0          | R-0          | R-0        |
|---|----------------------------------------|--------------------------------------------------------------------|-----------|----------------|-------------|--------------|--------------|------------|
|   | SPEN                                   | RX9                                                                | SREN      | CREN           | —           | FERR         | OERR         | RX9        |
|   | bit 7                                  |                                                                    |           |                |             |              |              | bit 0      |
| 7 | 1 = Serial p                           | al Port Enabl<br>ort enabled (<br>ort disabled                     |           | RX/DT and T    | X/CK pins a | as serial po | rt pins)     |            |
| 6 | 1 = Selects                            | Receive Enab<br>9-bit receptio<br>8-bit receptio                   | on        |                |             |              |              |            |
| 5 | SREN: Sing<br>Asynchrond<br>Don't care | gle Receive E<br>ous mode                                          | nable bit |                |             |              |              |            |
|   | 1 = Enables<br>0 = Disable             | us mode - ma<br>s single receir<br>s single rece<br>is cleared aft | ve<br>ive | is complete.   |             |              |              |            |
|   | <u>Synchronou</u><br>Unused in t       | <u>us mode - sla</u><br>his mode                                   | ve        |                |             |              |              |            |
| 4 | Asynchrono<br>1 = Enables              | ntinuous Rece<br>ous mode<br>s continuous<br>s continuous          | receive   | Dit            |             |              |              |            |
|   |                                        | <u>us mode</u><br>s continuous<br>s continuous                     |           | enable bit C   | REN is clea | ared (CREN   | loverrides   | SREN)      |
| 3 | Unimpleme                              | ented: Read                                                        | as '0'    |                |             |              |              |            |
| 2 |                                        | ning Error bit<br>g error (Can b<br>ning error                     |           | y reading R0   | CREG regis  | ter and rec  | eive next va | alid byte) |
| 1 | 1 = Overrur                            | errun Error bit<br>n error (Can b                                  |           | / clearing bit | CREN)       |              |              |            |
|   | 0 = 100 0001                           | rrun error                                                         |           |                |             |              |              |            |

| Register 18-2: | <b>RCSTA: Receive</b> | Status and Control Register |  |
|----------------|-----------------------|-----------------------------|--|
|----------------|-----------------------|-----------------------------|--|

| Legend                 |                  |                          |
|------------------------|------------------|--------------------------|
| R = Readable bit       | W = Writable bit |                          |
| U = Unimplemented bit, | read as '0'      | - n = Value at POR reset |

### 18.3 USART Baud Rate Generator (BRG)

The BRG supports both the Asynchronous and Synchronous modes of the USART. It is a dedicated 8-bit baud rate generator. The SPBRG register controls the period of a free running 8-bit timer. In asynchronous mode bit BRGH (TXSTA<2>) also controls the baud rate. In synchronous mode bit BRGH is ignored. Table 18-1 shows the formula for computation of the baud rate for different USART modes which only apply in master mode (internal clock).

Given the desired baud rate and Fosc, the nearest integer value for the SPBRG register can be calculated using the formula in Table 18-1, where X equals the value in the SPBRG register (0 to 255). From this, the error in baud rate can be determined.

### Table 18-1: Baud Rate Formula

| SYNC | BRGH = 0 (Low Speed)                      | BRGH = 1 (High Speed)     |
|------|-------------------------------------------|---------------------------|
| 0    | (Asynchronous) Baud Rate = Fosc/(64(X+1)) | Baud Rate= Fosc/(16(X+1)) |
| 1    | (Synchronous) Baud Rate = Fosc/(4(X+1))   | NA                        |

X = value in SPBRG (0 to 255)

Example 18-1 shows the calculation of the baud rate error for the following conditions:

Fosc = 16 MHz Desired Baud Rate = 9600 BRGH = 0 SYNC = 0

#### Example 18-1: Calculating Baud Rate Error

| Desired Baud rate<br>9600<br>X | =      | Fosc / (64 (X + 1))<br>16000000 / (64 (X + 1))<br>[25.042] = 25                                  |
|--------------------------------|--------|--------------------------------------------------------------------------------------------------|
| Calculated Baud Rate           | =<br>= | 16000000 / (64 (25 + 1))<br>9615                                                                 |
| Error                          | =      | (Calculated Baud Rate - Desired Baud Rate)<br>Desired Baud Rate<br>(9615 - 9600) / 9600<br>0.16% |

It may be advantageous to use the high baud rate (BRGH = 1) even for slower baud clocks. This is because the Fosc / (16(X + 1)) equation can reduce the baud rate error in some cases.

Writing a new value to the SPBRG register causes the BRG timer to be reset (or cleared). This ensures the BRG does not wait for a timer overflow before outputting the new baud rate.

Table 18-2: Registers Associated with Baud Rate Generator

| Name  | Bit 7   | Bit 6     | Bit 5      | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR,<br>BOR | Value on all other resets |
|-------|---------|-----------|------------|-------|-------|-------|-------|-------|--------------------------|---------------------------|
| TXSTA | CSRC    | TX9       | TXEN       | SYNC  |       | BRGH  | TRMT  | TX9D  | 0000 -010                | 0000 -010                 |
| RCSTA | SPEN    | RX9       | SREN       | CREN  | _     | FERR  | OERR  | RX9D  | 0000 -00x                | 0000 -00x                 |
| SPBRG | Baud Ra | te Genera | ator Regis | ster  |       |       |       |       | 0000 0000                | 0000 0000                 |

Legend: x = unknown, - = unimplemented read as '0'. Shaded cells are not used by the BRG.

## **PICmicro MID-RANGE MCU FAMILY**

| BAUD                                           | Fos                                                    | c = 20 M                 | <sup>Hz</sup> s                 | PBRG                                          | 10                                | 6 MHz                               | SPE                                          | BRG                                                | 10 N                                 | IHz                                                   | SPBR                                      | G                           | 7.         | 7.15909 MHz                                  |                   | SPBRG                  |
|------------------------------------------------|--------------------------------------------------------|--------------------------|---------------------------------|-----------------------------------------------|-----------------------------------|-------------------------------------|----------------------------------------------|----------------------------------------------------|--------------------------------------|-------------------------------------------------------|-------------------------------------------|-----------------------------|------------|----------------------------------------------|-------------------|------------------------|
| RATE<br>(Kbps)                                 | KBAU                                                   |                          | <b>V</b> a                      | value<br>ecimal)                              | KBAUD                             | %<br>ERRO                           | val<br>R <sup>(deci</sup>                    |                                                    | KBAUD                                | %<br>ERROR                                            | value<br>(decim                           | - 1                         | KBA        | UD EF                                        | %<br>RROR         | value<br>(decimal)     |
| 0.3                                            | NA                                                     | -                        | -                               |                                               | NA                                | -                                   | -                                            |                                                    | NA                                   | -                                                     | -                                         |                             | NA         | -                                            |                   | -                      |
| 1.2                                            | NA                                                     | -                        | -                               |                                               | NA                                | -                                   | -                                            |                                                    | NA                                   | -                                                     | -                                         |                             | NA         | -                                            |                   | -                      |
| 2.4                                            | NA                                                     | -                        | -                               |                                               | NA                                | -                                   | -                                            |                                                    | NA                                   | -                                                     | -                                         |                             | NA         | -                                            |                   | -                      |
| 9.6                                            | NA                                                     | -                        | -                               |                                               | NA                                | -                                   | -                                            |                                                    | 9.766                                | +1.73                                                 | 255                                       |                             | 9.622      | +0.                                          | .23               | 185                    |
| 19.2                                           | 19.53                                                  | +1.7                     | 3 25                            | 5                                             | 19.23                             | +0.16                               | 207                                          |                                                    | 19.23                                | +0.16                                                 | 129                                       |                             | 19.24      | +0.                                          | .23               | 92                     |
| 76.8                                           | 76.92                                                  | +0.1                     | 6 64                            |                                               | 76.92                             | +0.16                               | 51                                           |                                                    | 75.76                                | -1.36                                                 | 32                                        |                             | 77.82      | +1.                                          | .32               | 22                     |
| 96                                             | 96.15                                                  | +0.1                     | 6 51                            |                                               | 95.24                             | -0.79                               | 41                                           |                                                    | 96.15                                | +0.16                                                 | 25                                        |                             | 94.20      | -1.8                                         | 88                | 18                     |
| 300                                            | 294.1                                                  | -1.9                     | 6 16                            |                                               | 307.69                            | +2.56                               | 12                                           |                                                    | 312.5                                | +4.17                                                 | 7                                         |                             | 298.3      | -0.                                          | 57                | 5                      |
| 500                                            | 500                                                    | 0                        | 9                               |                                               | 500                               | 0                                   | 7                                            |                                                    | 500                                  | 0                                                     | 4                                         |                             | NA         | -                                            |                   | -                      |
| HIGH                                           | 5000                                                   | -                        | 0                               |                                               | 4000                              | -                                   | 0                                            |                                                    | 2500                                 | -                                                     | 0                                         |                             | 1789.      | 8 -                                          |                   | 0                      |
| LOW                                            | 19.53                                                  | -                        | 25                              | 5                                             | 15.625                            | -                                   | 255                                          |                                                    | 9.766                                | -                                                     | 255                                       |                             | 6.991      | -                                            |                   | 255                    |
|                                                | Fosc                                                   | = 5.0688                 | 8 MHz                           | 4 M                                           | ЛНz                               |                                     | 3.57954                                      | 45 MHz                                             | z                                    | 1 M                                                   | ۸Hz                                       |                             |            | 32.76                                        | 8 kHz             |                        |
| BAUD<br>RATE<br>(Kbps)                         | KBAUD I                                                | %<br>ERROR               | SPBRG<br>value                  | KBAUD                                         | %                                 | SPBRG<br>value                      |                                              | %                                                  | SPBRG<br>value                       |                                                       | %                                         | va                          | 3RG<br>lue | KRAUR                                        | %                 | SPBRG<br>value         |
|                                                |                                                        |                          | (decimal)                       |                                               | ERROR                             | (decimal)                           | KBAUD                                        | ERRO                                               | R (decima                            | ) KBAUD                                               | ERROR                                     | (dec                        | imal)      | KBAUD                                        | ERRO              | R <sup>(decimal)</sup> |
| 0.3                                            | NA -                                                   |                          | (decimal)<br>-                  | NA                                            | ERROR                             |                                     | KBAUD<br>NA                                  | ERRO                                               | R (decimal                           | NA                                                    | ERROR                                     | (dec                        |            | 0.303                                        | <b>ERRO</b> +1.14 | R (decimal)            |
|                                                | NA -<br>NA -                                           | · ·                      | (decimai)<br>-<br>-             |                                               | ERROR<br>-<br>-                   | -                                   |                                              | ERRO                                               | R (decima<br>-<br>-                  |                                                       | ERROR                                     | (dec<br>-<br>207            |            |                                              |                   |                        |
| 1.2                                            |                                                        |                          | (decimai)<br>-<br>-             | NA                                            | ERROR<br>-<br>-                   | -                                   | NA                                           | ERRO<br>-<br>-<br>-                                | R (decima<br>-<br>-<br>-             | NA                                                    | ERROR<br>-<br>+0.16                       | -                           |            | 0.303                                        | +1.14             | 26                     |
| 1.2<br>2.4                                     | NA -<br>NA -                                           | <br>                     | (decimai)<br>-<br>-<br>-<br>131 | NA<br>NA                                      | ERROR<br>-<br>-<br>+0.16          | -                                   | NA<br>NA<br>NA                               | ERRO<br>-<br>-<br>+0.23                            | • (decimal<br>-<br>-<br>-<br>-<br>92 | NA<br>1.202                                           | <b>ERROR</b><br>-<br>+0.16<br>+0.16       | -<br>207                    |            | 0.303<br>1.170                               | +1.14             | 26                     |
| 1.2<br>2.4<br>9.6                              | NA -<br>NA -<br>9.6 (                                  | <br>)                    | -<br>-<br>-                     | NA<br>NA<br>NA                                | -                                 | -                                   | NA<br>NA<br>NA<br>9.622                      | ERRO<br>-<br>-                                     | -                                    | NA<br>1.202<br>2.404                                  | <b>ERROR</b><br>- +0.16<br>+0.16<br>+0.16 | -<br>207<br>103             |            | 0.303<br>1.170<br>NA                         | +1.14             | 26                     |
| 1.2<br>2.4<br>9.6<br>19.2                      | NA -<br>NA -<br>9.6 (<br>19.2 (                        | <br><br>                 | -<br>-<br>-<br>131              | NA<br>NA<br>NA<br>9.615                       | -<br>-<br>-<br>+0.16              | -<br>-<br>103<br>51                 | NA<br>NA<br>NA<br>9.622<br>19.04             | ERRO<br>-<br>-<br>-<br>+0.23                       | -<br>-<br>-<br>92                    | NA<br>1.202<br>2.404<br>9.615                         | ERROR<br>+0.16<br>+0.16<br>+0.16<br>+0.16 | -<br>207<br>103<br>25       |            | 0.303<br>1.170<br>NA<br>NA                   | +1.14             | 26                     |
| 1.2<br>2.4<br>9.6<br>19.2<br>76.8              | NA -<br>NA -<br>9.6 (<br>19.2 (<br>79.2 -              | )<br>)<br>+3.13          | -<br>-<br>131<br>65             | NA<br>NA<br>9.615<br>19.231                   | -<br>-<br>+0.16<br>+0.16          | -<br>-<br>103<br>51<br>12           | NA<br>NA<br>9.622<br>19.04<br>74.57          | ERRO<br>-<br>-<br>+0.23<br>-0.83                   | -<br>-<br>92<br>46                   | NA<br>1.202<br>2.404<br>9.615<br>19.24                | ERROR<br>+0.16<br>+0.16<br>+0.16<br>+0.16 | -<br>207<br>103<br>25<br>12 |            | 0.303<br>1.170<br>NA<br>NA<br>NA             | +1.14             | 26                     |
| 1.2<br>2.4<br>9.6<br>19.2<br>76.8<br>96        | NA -<br>NA -<br>9.6 ()<br>19.2 ()<br>79.2 -<br>97.48 - | -<br>)<br>+3.13<br>+1.54 | -<br>-<br>131<br>65<br>15       | NA<br>NA<br>9.615<br>19.231<br>76.923         | -<br>-<br>+0.16<br>+0.16<br>+0.16 | -<br>-<br>103<br>51<br>12<br>9      | NA<br>NA<br>9.622<br>19.04<br>74.57<br>99.43 | ERRO<br>-<br>-<br>+0.23<br>-0.83<br>-2.90          | -<br>-<br>92<br>46<br>11             | NA<br>1.202<br>2.404<br>9.615<br>19.24<br>83.34       | ERROR<br>+0.16<br>+0.16<br>+0.16<br>+0.16 | -<br>207<br>103<br>25<br>12 |            | 0.303<br>1.170<br>NA<br>NA<br>NA<br>NA       | +1.14             | 26                     |
| 1.2<br>2.4<br>9.6<br>19.2<br>76.8<br>96<br>300 | NA -<br>NA -<br>9.6 ()<br>19.2 ()<br>79.2 -<br>97.48 - | )<br>)<br>+3.13<br>+1.54 | -<br>-<br>131<br>65<br>15<br>12 | NA<br>NA<br>9.615<br>19.231<br>76.923<br>1000 | -<br>-<br>+0.16<br>+0.16<br>+0.16 | -<br>-<br>103<br>51<br>12<br>9<br>- | NA<br>NA<br>9.622<br>19.04<br>74.57<br>99.43 | ERRO<br>-<br>-<br>+0.23<br>-0.83<br>-2.90<br>+3.57 | -<br>-<br>92<br>46<br>11<br>8        | NA<br>1.202<br>2.404<br>9.615<br>19.24<br>83.34<br>NA | ERROR<br>+0.16<br>+0.16<br>+0.16<br>+0.16 | -<br>207<br>103<br>25<br>12 |            | 0.303<br>1.170<br>NA<br>NA<br>NA<br>NA<br>NA | +1.14             | 26                     |

0.9766 -

255

0.032

255

255

### Table 18-3: Baud Rates for Synchronous Mode

LOW

4.950

255

3.906 -

255

3.496



# PIC16F87XA

### 28/40/44-Pin Enhanced Flash Microcontrollers

### **Devices Included in this Data Sheet:**

- PIC16F873A
- PIC16F876A
- PIC16F874A PIC16F877A

### **High-Performance RISC CPU:**

- Only 35 single-word instructions to learn
- All single-cycle instructions except for program branches, which are two-cycle
- Operating speed: DC 20 MHz clock input DC – 200 ns instruction cycle
- Up to 8K x 14 words of Flash Program Memory, Up to 368 x 8 bytes of Data Memory (RAM), Up to 256 x 8 bytes of EEPROM Data Memory
- Pinout compatible to other 28-pin or 40/44-pin PIC16CXXX and PIC16FXXX microcontrollers

### **Peripheral Features:**

- Timer0: 8-bit timer/counter with 8-bit prescaler
- Timer1: 16-bit timer/counter with prescaler, can be incremented during Sleep via external crystal/clock
- Timer2: 8-bit timer/counter with 8-bit period register, prescaler and postscaler
- Two Capture, Compare, PWM modules
  - Capture is 16-bit, max. resolution is 12.5 ns
  - Compare is 16-bit, max. resolution is 200 ns
  - PWM max. resolution is 10-bit
- Synchronous Serial Port (SSP) with SPI™ (Master mode) and I<sup>2</sup>C<sup>™</sup> (Master/Slave)
- Universal Synchronous Asynchronous Receiver Transmitter (USART/SCI) with 9-bit address detection
- Parallel Slave Port (PSP) 8 bits wide with external RD, WR and CS controls (40/44-pin only)
- Brown-out detection circuitry for Brown-out Reset (BOR)

### **Analog Features:**

- 10-bit, up to 8-channel Analog-to-Digital Converter (A/D)
- Brown-out Reset (BOR)
- Analog Comparator module with:
  - Two analog comparators
  - Programmable on-chip voltage reference (VREF) module
  - Programmable input multiplexing from device inputs and internal voltage reference
  - Comparator outputs are externally accessible

### **Special Microcontroller Features:**

- 100,000 erase/write cycle Enhanced Flash
   program memory typical
- 1,000,000 erase/write cycle Data EEPROM memory typical
- Data EEPROM Retention > 40 years
- Self-reprogrammable under software control
- In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) via two pins
- Single-supply 5V In-Circuit Serial Programming
- Watchdog Timer (WDT) with its own on-chip RC oscillator for reliable operation
- Programmable code protection
- Power saving Sleep mode
- · Selectable oscillator options
- · In-Circuit Debug (ICD) via two pins

### **CMOS Technology:**

- Low-power, high-speed Flash/EEPROM technology
- Fully static design
- Wide operating voltage range (2.0V to 5.5V)
- Commercial and Industrial temperature ranges
- Low-power consumption

| Device     | Program Memory |                               | Data            | FERROM            |     | 10-bit             | ССР | MSSP |                            |       | Timoro             |             |
|------------|----------------|-------------------------------|-----------------|-------------------|-----|--------------------|-----|------|----------------------------|-------|--------------------|-------------|
|            | Bytes          | # Single Word<br>Instructions | SRAM<br>(Bytes) | EEPROM<br>(Bytes) | I/O | 10-bit<br>A/D (ch) |     | SPI  | Master<br>I <sup>2</sup> C | USART | Timers<br>8/16-bit | Comparators |
| PIC16F873A | 7.2K           | 4096                          | 192             | 128               | 22  | 5                  | 2   | Yes  | Yes                        | Yes   | 2/1                | 2           |
| PIC16F874A | 7.2K           | 4096                          | 192             | 128               | 33  | 8                  | 2   | Yes  | Yes                        | Yes   | 2/1                | 2           |
| PIC16F876A | 14.3K          | 8192                          | 368             | 256               | 22  | 5                  | 2   | Yes  | Yes                        | Yes   | 2/1                | 2           |
| PIC16F877A | 14.3K          | 8192                          | 368             | 256               | 33  | 8                  | 2   | Yes  | Yes                        | Yes   | 2/1                | 2           |

| • * * * * * * *                                                                                                                                                                      | ****                                                  | ****                                                                               | wire_16.asm                                                                                                                        |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| ,                                                                                                                                                                                    | PVK40 Example : Wire                                  |                                                                                    |                                                                                                                                    |  |  |  |  |
| ,<br>Processor : PIC16F877A<br>, Clock : XT 3.2768 MHz                                                                                                                               |                                                       |                                                                                    |                                                                                                                                    |  |  |  |  |
| ;<br>On your PVK40 board set DIP switches according to following way:<br>; 1) Switch off all DIP switches except:<br>; 2) Switch on OSC 3.276M on S9<br>; 3) Switch on B3 LED on S11 |                                                       |                                                                                    |                                                                                                                                    |  |  |  |  |
| , Assem                                                                                                                                                                              | list                                                  | ectives :<br>p = PIC16F877A<br>g 0x3F71                                            | ; processor type<br>; configuration setting                                                                                        |  |  |  |  |
| status<br>portb<br>trisb<br>portd                                                                                                                                                    | equ<br>equ                                            | tion :<br>0x03<br>0x06<br>0x06<br>0x08<br>0x08<br>0x08                             | ;status is on the 0x03 address<br>;direct addressing<br>;direct addressing                                                         |  |  |  |  |
| ;<br>#define<br>#define<br>#define                                                                                                                                                   | LED                                                   | portd,0<br>portb,3<br>status,5                                                     | ;pushbutton O is on the RDO pin<br>;LED is on the RB3 pin<br>;RPO is bit 5 in status register                                      |  |  |  |  |
| ;                                                                                                                                                                                    | org<br>bsf<br>movlw<br>movwf<br>movlw<br>movwf<br>bcf | 0<br>RPO<br>B'11110111'<br>trisb<br>B'11111111'<br>trisd<br>RPO                    | ;program starts at address 0x000<br>;bank 1 in RAM memory<br>;pin RB3 is output<br>;portd pins are inputs<br>;bank 0 in RAM memory |  |  |  |  |
| ,                                                                                                                                                                                    | goto<br>*******                                       | PB<br>Main_A<br>LED<br>Main<br>LED<br>Main<br>************************************ | ;is PB 0 or 1?<br>;if PB=0, jump to main_A<br>;PB=1, LED off<br>;closes the loop<br>;LED on<br>;closes the loop                    |  |  |  |  |

| *****                                                                                                            | ****                                                | blink_16.asm                                                                                                                                                           |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| ,<br>PVK40 Example : Blink                                                                                       |                                                     |                                                                                                                                                                        |  |  |  |  |
| Processor : PIC16F877A<br>Clock : XT 3.2768 MHz                                                                  |                                                     |                                                                                                                                                                        |  |  |  |  |
| ; 1) Switch off<br>; 2) Switch on O<br>; 3) Switch on B                                                          | all DIP switches<br>SC 3.276M on S9<br>3 LED on S11 | vitches according to following way:<br>except:                                                                                                                         |  |  |  |  |
| ,<br>; Assembler dire<br>list                                                                                    | ectives :<br>p = PIC16F877A                         | ; processor type<br>; configuration setting                                                                                                                            |  |  |  |  |
| status equ<br>portb equ<br>trisb equ<br>; General Purpos<br>cnt1 equ<br>cnt2 equ<br>cnt3 equ<br>; Destination de | 0x20<br>0x21<br>0x22<br>finition :                  | ;status is on the 0x03 address<br>:direct addressing                                                                                                                   |  |  |  |  |
| w equ<br>f equ<br>; Bits definitio<br>#define LED<br>#define RPO<br>;                                            | 0x01                                                | ;LED is on the RB3 pin<br>;RPO is bit 5 in status register                                                                                                             |  |  |  |  |
| bs∱<br>movlw<br>movwf                                                                                            | 0<br>RPO<br>B'11110111'<br>trisb<br>RPO             | ;program starts at address 0x000<br>;bank 1 in RAM memory<br>;pin RB3 is output<br>;bank 0 in RAM memory                                                               |  |  |  |  |
| call<br>bcf<br>call                                                                                              | LED<br>Wait<br>LED<br>Wait<br>Main                  | ;LED on<br>;wait 0.5 second<br>;LED off<br>;wait 0.5 second<br>;closes the loop                                                                                        |  |  |  |  |
| movwf<br>Wait_A: movlw<br>movwf<br>Wait_B: movlw<br>movwf<br>Wait_C: decfsz                                      | Wait_C<br>cnt2,f<br>Wait_B<br>cnt3,f<br>Wait_A      | <pre>;this subroutine wait 0.5 second<br/>;1 cycle = 1/(Fosc/4) second =&gt;<br/>;=&gt; we need 409600 cycles<br/>;0x05*0x6B*0xFF*3 = 409275<br/>;decrement cnt1</pre> |  |  |  |  |
| decfsz<br>goto<br>decfsz<br>goto<br>return<br>;********                                                          |                                                     | ;and if cnt1=0 then decrement cnt2<br>;and if cnt2=0 then decrement cnt3<br>;if cnt3=0 then return                                                                     |  |  |  |  |