



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

### Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Active                                                                     |
|----------------------------|----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 40MHz                                                                      |
| Connectivity               | I²C, SPI, UART/USART                                                       |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 50                                                                         |
| Program Memory Size        | 96KB (48K x 16)                                                            |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 3.8K x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 3.6V                                                                  |
| Data Converters            | A/D 11x10b                                                                 |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 64-TQFP                                                                    |
| Supplier Device Package    | 64-TQFP (10x10)                                                            |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18f66j15-i-pt |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

## 1.0 DEVICE OVERVIEW

This document contains device specific information for the following devices:

- PIC18F65J10 PIC18F85J10
- PIC18F65J15 PIC18F85J15
- PIC18F66J10 PIC18F86J10
- PIC18F66J15 PIC18F86J15
- PIC18F67J10 PIC18F87J10

This family introduces a new line of low-voltage devices with the main traditional advantage of all PIC18 microcontrollers – namely, high computational performance and a rich feature set – at an extremely competitive price point. These features make the PIC18F87J10 family a logical choice for many high-performance applications where cost is a primary consideration.

### 1.1 Core Features

### 1.1.1 nanoWatt TECHNOLOGY

All of the devices in the PIC18F87J10 family incorporate a range of features that can significantly reduce power consumption during operation. Key items include:

- Alternate Run Modes: By clocking the controller from the Timer1 source or the internal RC oscillator, power consumption during code execution can be reduced by as much as 90%.
- **Multiple Idle Modes:** The controller can also run with its CPU core disabled but the peripherals still active. In these states, power consumption can be reduced even further, to as little as 4% of normal operation requirements.
- **On-the-Fly Mode Switching:** The power-managed modes are invoked by user code during operation, allowing the user to incorporate power-saving ideas into their application's software design.

## 1.1.2 OSCILLATOR OPTIONS AND FEATURES

All of the devices in the PIC18F87J10 family offer five different oscillator options, allowing users a range of choices in developing application hardware. These include:

- Two Crystal modes, using crystals or ceramic resonators.
- Two External Clock modes, offering the option of a divide-by-4 clock output.
- A Phase Lock Loop (PLL) frequency multiplier, available to the external oscillator modes which allows clock speeds of up to 40 MHz.
- An internal RC oscillator with a fixed 31-kHz output which provides an extremely low-power option for timing-insensitive applications.

The internal oscillator block provides a stable reference source that gives the family additional features for robust operation:

- Fail-Safe Clock Monitor: This option constantly monitors the main clock source against a reference signal provided by the internal oscillator. If a clock failure occurs, the controller is switched to the internal oscillator, allowing for continued low-speed operation or a safe application shutdown.
- **Two-Speed Start-up:** This option allows the internal oscillator to serve as the clock source from Power-on Reset, or wake-up from Sleep mode, until the primary clock source is available.

### 1.1.3 EXPANDED MEMORY

The PIC18F87J10 family provides ample room for application code, from 32 Kbytes to 128 Kbytes of code space. The Flash cells for program memory are rated to last up to 100 erase/write cycles. The PIC18F87J10 family also provides plenty of room for dynamic application data, with up to 3936 bytes of data RAM.

### 1.1.4 EXTERNAL MEMORY BUS

In the unlikely event that 128 Kbytes of memory are inadequate for an application, the 80-pin members of the PIC18F87J10 family also implement an external memory bus. This allows the controller's internal program counter to address a memory space of up to 2 Mbytes, permitting a level of data access that few 8-bit devices can claim. This allows additional memory options, including:

- Using combinations of on-chip and external memory up to the 2-Mbyte limit
- Using external Flash memory for reprogrammable application code or large data tables
- Using external RAM devices for storing large amounts of variable data

### 1.1.5 EXTENDED INSTRUCTION SET

The PIC18F87J10 family implements the optional extension to the PIC18 instruction set, adding 8 new instructions and an Indexed Addressing mode. Enabled as a device configuration option, the extension has been specifically designed to optimize re-entrant application code originally developed in high-level languages, such as 'C'.

### TABLE 1-3: PIC18F6XJ10/6XJ15 PINOUT I/O DESCRIPTIONS

| Dis Norse                                                              | Pin Number                                                           | Pin                             | Buffer                  | Description                                                                                                                                                                                                                                                                  |  |  |
|------------------------------------------------------------------------|----------------------------------------------------------------------|---------------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Pin Name                                                               | TQFP                                                                 | Туре                            | Туре                    | Description                                                                                                                                                                                                                                                                  |  |  |
| MCLR                                                                   | 7                                                                    | I                               | ST                      | Master Clear (Reset) input. This pin is an active-low Reset to the device.                                                                                                                                                                                                   |  |  |
| OSC1/CLKI<br>OSC1<br>CLKI                                              | 39                                                                   | I                               | ST<br>CMOS              | Oscillator crystal or external clock input.<br>Oscillator crystal input or external clock source inpu<br>ST buffer when configured in RC mode; CMOS<br>otherwise.<br>External clock source input. Always associated<br>with pin function OSC1. (See related OSC1/CLKI,       |  |  |
| OSC2/CLKO<br>OSC2<br>CLKO                                              | 40                                                                   | 0                               |                         | OSC2/CLKO pins.)<br>Oscillator crystal or clock output.<br>Oscillator crystal output. Connects to crystal or<br>resonator in Crystal Oscillator mode.<br>In RC mode, OSC2 pin outputs CLKO which has<br>1/4 the frequency of OSC1 and denotes the<br>instruction cycle rate. |  |  |
| RA0/AN0<br>RA0<br>AN0                                                  | 24                                                                   | I/O<br>I                        | TTL<br>Analog           | PORTA is a bidirectional I/O port.<br>Digital I/O.<br>Analog input 0.                                                                                                                                                                                                        |  |  |
| RA1/AN1<br>RA1<br>AN1                                                  | 23                                                                   | I/O<br>I                        | TTL<br>Analog           | Digital I/O.<br>Analog input 1.                                                                                                                                                                                                                                              |  |  |
| RA2/AN2/VREF-<br>RA2<br>AN2<br>VREF-                                   | 22                                                                   | I/O<br>I<br>I                   | TTL<br>Analog<br>Analog | Digital I/O.<br>Analog input 2.<br>A/D reference voltage (low) input.                                                                                                                                                                                                        |  |  |
| RA3/AN3/VREF+<br>RA3<br>AN3<br>VREF+                                   | 21                                                                   | I/O<br>I<br>I                   | TTL<br>Analog<br>Analog | Digital I/O.<br>Analog input 3.<br>A/D reference voltage (high) input.                                                                                                                                                                                                       |  |  |
| RA4/T0CKI<br>RA4<br>T0CKI                                              | 28                                                                   | I/O<br>I                        | ST<br>ST                | Digital I/O.<br>Timer0 external clock input.                                                                                                                                                                                                                                 |  |  |
| RA5/AN4<br>RA5<br>AN4                                                  | 27                                                                   | I/O<br>I                        | TTL<br>Analog           | Digital I/O.<br>Analog input 4.                                                                                                                                                                                                                                              |  |  |
| Legend: TTL = TT<br>ST = So<br>I = In<br>P = Po<br>$I^2C/SMB$ = $I^2C$ | L compatible in<br>chmitt Trigger in<br>out<br>ower<br>C™/SMBus inpt | nput<br>put with (<br>ut buffer | CMOS leve               | CMOS = CMOS compatible input or output<br>Analog = Analog input<br>O = Output<br>OD = Open-Drain (no P diode to VDD)                                                                                                                                                         |  |  |

Note 1: Default assignment for ECCP2/P2A when Configuration bit, CCP2MX, is set.

2: Alternate assignment for ECCP2/P2A when Configuration bit, CCP2MX, is cleared.

### 3.7 Effects of Power-Managed Modes on the Various Clock Sources

When PRI\_IDLE mode is selected, the designated primary oscillator continues to run without interruption. For all other power-managed modes, the oscillator using the OSC1 pin is disabled. The OSC1 pin (and OSC2 pin if used by the oscillator) will stop oscillating.

In secondary clock modes (SEC\_RUN and SEC\_IDLE), the Timer1 oscillator is operating and providing the device clock. The Timer1 oscillator may also run in all power-managed modes if required to clock Timer1 or Timer3.

In RC\_RUN and RC\_IDLE modes, the internal oscillator provides the device clock source. The 31 kHz INTRC output can be used directly to provide the clock and may be enabled to support various special features, regardless of the power-managed mode (see **Section 24.2 "Watchdog Timer (WDT)"** through **Section 24.5 "Fail-Safe Clock Monitor**" for more information on WDT, Fail-Safe Clock Monitor and Two-Speed Start-up).

If the Sleep mode is selected, all clock sources are stopped. Since all the transistor switching currents have been stopped, Sleep mode achieves the lowest current consumption of the device (only leakage currents).

Enabling any on-chip feature that will operate during Sleep will increase the current consumed during Sleep. The INTRC is required to support WDT operation. The Timer1 oscillator may be operating to support a Real-Time Clock. Other features may be operating that do not require a device clock source (i.e., MSSP slave, PSP, INTx pins and others). Peripherals that may add significant current consumption are listed in Section 27.2 "DC Characteristics: Power-Down and Supply Current".

## 3.8 Power-up Delays

Power-up delays are controlled by two timers, so that no external Reset circuitry is required for most applications. The delays ensure that the device is kept in Reset until the device power supply is stable under normal circumstances and the primary clock is operating and stable. For additional information on power-up delays, see **Section 5.5 "Power-up Timer (PWRT)**".

The first timer is the Power-up Timer (PWRT), which provides a fixed delay on power-up (parameter 33, Table 27-12). It is always enabled.

The second timer is the Oscillator Start-up Timer (OST), intended to keep the chip in Reset until the crystal oscillator is stable (HS modes). The OST does this by counting 1024 oscillator cycles before allowing the oscillator to clock the device.

There is a delay of interval, TCSD (parameter 38, Table 27-12), following POR, while the controller becomes ready to execute instructions.

 TABLE 3-3:
 OSC1 AND OSC2 PIN STATES IN SLEEP MODE

| Oscillator Mode | OSC1 Pin                                              | OSC2 Pin                                              |
|-----------------|-------------------------------------------------------|-------------------------------------------------------|
| EC, ECPLL       | Floating, pulled by external clock                    | At logic low (clock/4 output)                         |
| HS, HSPLL       | Feedback inverter disabled at quiescent voltage level | Feedback inverter disabled at quiescent voltage level |

Note: See Table 5-2 in Section 5.0 "Reset" for time-outs due to Sleep and MCLR Reset.

| Register | Applicable Devices      | Power-on Reset,<br>Brown-out Reset | MCLR Resets<br>WDT Reset<br>RESET Instruction<br>Stack Resets | Wake-up via WDT<br>or Interrupt |
|----------|-------------------------|------------------------------------|---------------------------------------------------------------|---------------------------------|
| CCPR1H   | PIC18F6XJ1X PIC18F8XJ1X | XXXX XXXX                          | սսսս սսսս                                                     | սսսս սսսս                       |
| CCPR1L   | PIC18F6XJ1X PIC18F8XJ1X | XXXX XXXX                          | սսսս սսսս                                                     | uuuu uuuu                       |
| CCP1CON  | PIC18F6XJ1X PIC18F8XJ1X | 0000 0000                          | 0000 0000                                                     | uuuu uuuu                       |
| CCPR2H   | PIC18F6XJ1X PIC18F8XJ1X | XXXX XXXX                          | սսսս սսսս                                                     | սսսս սսսս                       |
| CCPR2L   | PIC18F6XJ1X PIC18F8XJ1X | XXXX XXXX                          | սսսս սսսս                                                     | uuuu uuuu                       |
| CCP2CON  | PIC18F6XJ1X PIC18F8XJ1X | 0000 0000                          | 0000 0000                                                     | uuuu uuuu                       |
| CCPR3H   | PIC18F6XJ1X PIC18F8XJ1X | XXXX XXXX                          | սսսս սսսս                                                     | սսսս սսսս                       |
| CCPR3L   | PIC18F6XJ1X PIC18F8XJ1X | XXXX XXXX                          | սսսս սսսս                                                     | uuuu uuuu                       |
| CCP3CON  | PIC18F6XJ1X PIC18F8XJ1X | 0000 0000                          | 0000 0000                                                     | uuuu uuuu                       |
| ECCP1AS  | PIC18F6XJ1X PIC18F8XJ1X | 0000 0000                          | 0000 0000                                                     | սսսս սսսս                       |
| CVRCON   | PIC18F6XJ1X PIC18F8XJ1X | 0000 0000                          | 0000 0000                                                     | uuuu uuuu                       |
| CMCON    | PIC18F6XJ1X PIC18F8XJ1X | 0000 0111                          | 0000 0111                                                     | uuuu uuuu                       |
| TMR3H    | PIC18F6XJ1X PIC18F8XJ1X | XXXX XXXX                          | սսսս սսսս                                                     | սսսս սսսս                       |
| TMR3L    | PIC18F6XJ1X PIC18F8XJ1X | XXXX XXXX                          | սսսս սսսս                                                     | uuuu uuuu                       |
| T3CON    | PIC18F6XJ1X PIC18F8XJ1X | 0000 0000                          | սսսս սսսս                                                     | սսսս սսսս                       |
| PSPCON   | PIC18F6XJ1X PIC18F8XJ1X | 0000                               | 0000                                                          | uuuu                            |
| SPBRG1   | PIC18F6XJ1X PIC18F8XJ1X | 0000 0000                          | 0000 0000                                                     | uuuu uuuu                       |
| RCREG1   | PIC18F6XJ1X PIC18F8XJ1X | 0000 0000                          | 0000 0000                                                     | սսսս սսսս                       |
| TXREG1   | PIC18F6XJ1X PIC18F8XJ1X | XXXX XXXX                          | սսսս սսսս                                                     | uuuu uuuu                       |
| TXSTA1   | PIC18F6XJ1X PIC18F8XJ1X | 0000 0010                          | 0000 0010                                                     | uuuu uuuu                       |
| RCSTA1   | PIC18F6XJ1X PIC18F8XJ1X | 0000 000x                          | 0000 000x                                                     | սսսս սսսս                       |
| EECON2   | PIC18F6XJ1X PIC18F8XJ1X |                                    |                                                               |                                 |
| EECON1   | PIC18F6XJ1X PIC18F8XJ1X | 0 x00-                             | 0 u00-                                                        | 0 u00-                          |
| IPR3     | PIC18F6XJ1X PIC18F8XJ1X | 1111 1111                          | 1111 1111                                                     | uuuu uuuu                       |
| PIR3     | PIC18F6XJ1X PIC18F8XJ1X | 0000 0000                          | 0000 0000                                                     | uuuu uuuu <sup>(3)</sup>        |
| PIE3     | PIC18F6XJ1X PIC18F8XJ1X | 0000 0000                          | 0000 0000                                                     | սսսս սսսս                       |
| IPR2     | PIC18F6XJ1X PIC18F8XJ1X | 11 1-11                            | 11 1-11                                                       | uu u-uu                         |
| PIR2     | PIC18F6XJ1X PIC18F8XJ1X | 00 0-00                            | 00 0-00                                                       | uu u-uu <sup>(3)</sup>          |
| PIE2     | PIC18F6XJ1X PIC18F8XJ1X | 00 0-00                            | 00 0-00                                                       | uu u-uu                         |
| IPR1     | PIC18F6XJ1X PIC18F8XJ1X | 1111 1111                          | 1111 1111                                                     | uuuu uuuu                       |
| PIR1     | PIC18F6XJ1X PIC18F8XJ1X | 0000 0000                          | 0000 0000                                                     | uuuu uuuu <sup>(3)</sup>        |
| PIE1     | PIC18F6XJ1X PIC18F8XJ1X | 0000 0000                          | 0000 0000                                                     | սսսս սսսս                       |
| MEMCON   | PIC18F6XJ1X PIC18F8XJ1X | 0-0000                             | 0-0000                                                        | u-uuuu                          |
| OSCTUNE  | PIC18F6XJ1X PIC18F8XJ1X | -0                                 | -0                                                            | -u                              |

### TABLE 5-2: INITIALIZATION CONDITIONS FOR ALL REGISTERS (CONTINUED)

**Legend:** u = unchanged, x = unknown, - = unimplemented bit, read as '0', q = value depends on condition. Shaded cells indicate conditions do not apply for the designated device.

**Note 1:** When the wake-up is due to an interrupt and the GIEL or GIEH bit is set, the TOSU, TOSH and TOSL are updated with the current value of the PC. The STKPTR is modified to point to the next location in the hardware stack.

- 2: When the wake-up is due to an interrupt and the GIEL or GIEH bit is set, the PC is loaded with the interrupt vector (0008h or 0018h).
- 3: One or more bits in the INTCONx or PIRx registers will be affected (to cause wake-up).
- **4:** See Table 5-1 for Reset value for specific condition.

### 6.3.5 STATUS REGISTER

The STATUS register, shown in Register 6.4, contains the arithmetic status of the ALU. The STATUS register can be the operand for any instruction, as with any other register. If the STATUS register is the destination for an instruction that affects the Z, DC, C, OV or N bits, then the write to these five bits is disabled.

These bits are set or cleared according to the device logic. Therefore, the result of an instruction with the STATUS register as destination may be different than intended. For example, CLRF STATUS will set the Z bit but leave the other bits unchanged. The STATUS

register then reads back as '000u u1uu'. It is recommended, therefore, that only BCF, BSF, SWAPF, MOVFF and MOVWF instructions are used to alter the STATUS register because these instructions do not affect the Z, C, DC, OV or N bits in the STATUS register.

For other instructions not affecting any Status bits, see the instruction set summaries in Table 25-2 and Table 25-3.

Note: The C and DC bits operate as a Borrow and Digit Borrow bit respectively, in subtraction.

### REGISTER 6-3: STATUS REGISTER

| U-0           | U-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | U-0                                  | R/W-x                              | R/W-x                                | R/W-x            | R/W-x             | R/W-x            |  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------------------|--------------------------------------|------------------|-------------------|------------------|--|
|               | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | —                                    | N                                  | OV                                   | Z                | DC <sup>(1)</sup> | C <sup>(2)</sup> |  |
| bit 7         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                      |                                    |                                      |                  |                   | bit 0            |  |
|               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                      |                                    |                                      |                  |                   |                  |  |
| Legend:       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                      |                                    |                                      |                  |                   |                  |  |
| R = Read      | able bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | VV = VVritable                       | bit                                |                                      | mented bit, read |                   |                  |  |
| -n = value    | e at POR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | "1" = Bit is set                     |                                    | $0^{\circ} = Bit is cle$             | ared             | x = Bit is unkr   | nown             |  |
| bit 7-5       | Unimplemer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | nted: Read as '                      | 0'                                 |                                      |                  |                   |                  |  |
| bit 4         | bit 4 N: Negative bit<br>This bit is used for signed arithmetic (2's complement). It indicates whether the result was negative<br>(ALU MSB = 1).<br>1 = Result was negative<br>0 = Result was nositive                                                                                                                                                                                                                                                                                              |                                      |                                    |                                      |                  |                   |                  |  |
| bit 3         | bit 3 <b>OV:</b> Overflow bit<br>This bit is used for signed arithmetic (2's complement). It indicates an overflow of the 7-bit magnitude<br>which causes the sign bit (bit 7 of the result) to change state.<br>1 = Overflow occurred for signed arithmetic (in this arithmetic operation)                                                                                                                                                                                                         |                                      |                                    |                                      |                  |                   |                  |  |
| bit 2         | <b>Z:</b> Zero bit<br>1 = The resu<br>0 = The resu                                                                                                                                                                                                                                                                                                                                                                                                                                                  | It of an arithme<br>It of an arithme | tic or logic op<br>tic or logic op | eration is zero<br>eration is not ze | ero              |                   |                  |  |
| bit 1         | t 1 DC: Digit Carry/Borrow bit <sup>(1)</sup><br>For ADDWF, ADDLW, SUBLW and SUBWF instructions:<br>1 = A carry-out from the 4th low-order bit of the result occurred<br>0 = No carry-out from the 4th low-order bit of the result                                                                                                                                                                                                                                                                  |                                      |                                    |                                      |                  |                   |                  |  |
| bit 0         | <ul> <li>C: Carry/Borrow bit<sup>(2)</sup></li> <li>For ADDWF, ADDLW, SUBLW and SUBWF instructions:</li> <li>1 = A carry-out from the Most Significant bit of the result occurred</li> <li>0 = No carry-out from the Most Significant bit of the result occurred</li> </ul>                                                                                                                                                                                                                         |                                      |                                    |                                      |                  |                   |                  |  |
| Note 1:<br>2: | <ol> <li>For Borrow, the polarity is reversed. A subtraction is executed by adding the 2's complement of the second operand. For rotate (RRF, RLF) instructions, this bit is loaded with either bit 4 or bit 3 of the source register.</li> <li>For Borrow, the polarity is reversed. A subtraction is executed by adding the 2's complement of the second operand. For rotate (RRF, RLF) instructions, this bit is loaded with either the high or low-order bit of the source register.</li> </ol> |                                      |                                    |                                      |                  |                   |                  |  |

## FIGURE 7-2: TABLE WRITE OPERATION



## 7.2 Control Registers

Several control registers are used in conjunction with the  ${\tt TBLRD}$  and  ${\tt TBLWT}$  instructions. These include the:

- EECON1 register
- EECON2 register
- TABLAT register
- TBLPTR registers

### 7.2.1 EECON1 AND EECON2 REGISTERS

The EECON1 register (Register 7.2.2) is the control register for memory accesses. The EECON2 register is not a physical register; it is used exclusively in the memory write and erase sequences. Reading EECON2 will read all '0's.

The FREE bit, when set, will allow a program memory erase operation. When FREE is set, the erase operation is initiated on the next WR command. When FREE is clear, only writes are enabled. The WREN bit, when set, will allow a write operation. On power-up, the WREN bit is clear. The WRERR bit is set in hardware when the WR bit is set and cleared when the internal programming timer expires and the write operation is complete.

| Note: | During normal operation, the WRERR is       |  |  |  |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|--|--|--|
|       | read as '1'. This can indicate that a write |  |  |  |  |  |  |  |
|       | operation was prematurely terminated by     |  |  |  |  |  |  |  |
|       | a Reset, or a write operation was           |  |  |  |  |  |  |  |
|       | attempted improperly.                       |  |  |  |  |  |  |  |

The WR control bit initiates write operations. The bit cannot be cleared, only set, in software. It is cleared in hardware at the completion of the write operation.

## 8.3 Wait States

While it may be assumed that external memory devices will operate at the microcontroller clock rate, this is often not the case. In fact, many devices require longer times to write or retrieve data than the time allowed by the execution of table read or table write operations.

To compensate for this, the external memory bus can be configured to add a fixed delay to each table operation using the bus. Wait states are enabled by setting the WAIT Configuration bit. When enabled, the amount of delay is set by the WAIT<1:0> bits (MEMCON<5:4>). The delay is based on multiples of microcontroller instruction cycle time and are added following the instruction cycle when the table operation is executed. The range is from no delay to 3 TCY (default value).

### 8.4 Port Pin Weak Pull-ups

With the exception of the upper address lines, A<19:16>, the pins associated with the external memory bus are equipped with weak pull-ups. The pull-ups are controlled by the upper three bits of the PORTG register. They are named RDPU, REPU and RJPU and control pull-ups on PORTD, PORTE and PORTJ, respectively. Clearing one of these bits enables the corresponding pull-ups for that port. All pull-ups are disabled by default on all device Resets.

### 8.5 Program Memory Modes and the External Memory Bus

The PIC18F87J10 family of devices is capable of operating in one of two program memory modes, using combinations of on-chip and external program memory. The functions of the multiplexed port pins depend on the program memory mode selected, as well as the setting of the EBDIS bit.

In **Microcontroller Mode**, the bus is not active and the pins have their port functions only. Writes to the MEMCOM register are not permitted. The Reset value of EBDIS ('0') is ignored and EMB pins behave as I/O ports.

In **Extended Microcontroller Mode**, the external program memory bus shares I/O port functions on the pins. When the device is fetching or doing table read/table write operations on the external program memory space, the pins will have the external bus function.

If the device is fetching and accessing internal program memory locations only, the EBDIS control bit will change the pins from external memory to I/O port functions. When EBDIS = 0, the pins function as the external bus. When EBDIS = 1, the pins function as I/O ports.

If the device fetches or accesses external memory while EBDIS = 1, the pins will switch to external bus. If the EBDIS bit is set by a program executing from external memory, the action of setting the bit will be delayed until the program branches into the internal memory. At that time, the pins will change from external bus to I/O ports.

If the device is executing out of internal memory when EBDIS = 0, the memory bus address/data and control pins will not be active. They will go to a state where the active address/data pins are tri-state; the  $\overline{CE}$ ,  $\overline{OE}$ ,  $\overline{WRH}$ ,  $\overline{WRL}$ ,  $\overline{UB}$  and  $\overline{LB}$  signals are '1' and ALE and BA0 are '0'. Note that only those pins associated with the current address width are forced to tri-state; the other pins continue to function as I/O. In the case of 16-bit address width, for example, only AD<15:0> (PORTD and PORTE) are affected; A<19:16> (PORTH<3:0>) continue to function as I/O.

In all external memory modes, the bus takes priority over any other peripherals that may share pins with it. This includes the Parallel Slave Port and serial communications modules which would otherwise take priority over the I/O port.

### 8.6 16-Bit Data Width Modes

In 16-Bit Data Width mode, the external memory interface can be connected to external memories in three different configurations:

- 16-Bit Byte Write
- 16-Bit Word Write
- 16-Bit Byte Select

The configuration to be used is determined by the WM<1:0> bits in the MEMCON register (MEMCON<1:0>). These three different configurations allow the designer maximum flexibility in using both 8-bit and 16-bit devices with 16-bit data.

For all 16-bit modes, the Address Latch Enable (ALE) pin indicates that the address bits, AD<15:0>, are available on the external memory interface bus. Following the address latch, the Output Enable signal ( $\overline{OE}$ ) will enable both bytes of program memory at once to form a 16-bit instruction word. The Chip Enable signal ( $\overline{CE}$ ) is active at any time that the microcontroller accesses external memory, whether reading or writing; it is inactive (asserted high) whenever the device is in Sleep mode.

In Byte Select mode, JEDEC standard Flash memories will require BA0 for the byte address line and one I/O line to select between Byte and Word mode. The other 16-bit modes do not need BA0. JEDEC standard static RAM memories will use the UB or LB signals for byte selection.

# 11.4 PORTC, TRISC and LATC Registers

PORTC is an 8-bit wide, bidirectional port. The corresponding Data Direction register is TRISC. Setting a TRISC bit (= 1) will make the corresponding PORTC pin an input (i.e., put the corresponding output driver in a high-impedance mode). Clearing a TRISC bit (= 0) will make the corresponding PORTC pin an output (i.e., put the contents of the output latch on the selected pin). Only PORTC pins, RC2 through RC7, are digital only pins and can tolerate input voltages up to 5.5V.

The Output Latch register (LATC) is also memory mapped. Read-modify-write operations on the LATC register read and write the latched output value for PORTC.

PORTC is multiplexed with several peripheral functions (Table 11-7). The pins have Schmitt Trigger input buffers. RC1 is normally configured by Configuration bit, CCP2MX, as the default peripheral pin for the ECCP2 module and enhanced PWM output, P2A (default state, CCP2MX = 1).

When enabling peripheral functions, care should be taken in defining TRIS bits for each PORTC pin. Some peripherals override the TRIS bit to make a pin an output, while other peripherals override the TRIS bit to make a pin an input. The user should refer to the corresponding peripheral section for the correct TRIS bit settings.

## **Note:** These pins are configured as digital inputs on any device Reset.

The contents of the TRISC register are affected by peripheral overrides. Reading TRISC always returns the current contents, even though a peripheral device may be overriding one or more of the pins.

### EXAMPLE 11-3: INITIALIZING PORTC

| CLRF      | PORTC | ; Initialize PORTC by ; clearing output |
|-----------|-------|-----------------------------------------|
| CLRF      | LATC  | ; data latches<br>; Alternate method    |
| -         |       | ; to clear output                       |
| MOVIW     | OCFh  | ; data latches<br>: Value used to       |
| 110 1 211 | 00111 | ; initialize data                       |
|           |       | ; direction                             |
| MOVWF     | TRISC | ; Set RC<3:0> as inputs                 |
|           |       | ; RC<5:4> as outputs                    |
|           |       | ; RC<7:6> as inputs                     |

### 19.3.2 OPERATION

When initializing the SPI, several options need to be specified. This is done by programming the appropriate control bits (SSPxCON1<5:0> and SSPxSTAT<7:6>). These control bits allow the following to be specified:

- Master mode (SCKx is the clock output)
- Slave mode (SCKx is the clock input)
- Clock Polarity (Idle state of SCKx)
- Data Input Sample Phase (middle or end of data output time)
- Clock Edge (output data on rising/falling edge of SCKx)
- Clock Rate (Master mode only)
- Slave Select mode (Slave mode only)

Each MSSP module consists of a transmit/receive shift register (SSPxSR) and a buffer register (SSPxBUF). The SSPxSR shifts the data in and out of the device, MSb first. The SSPxBUF holds the data that was written to the SSPxSR until the received data is ready. Once the 8 bits of data have been received, that byte is moved to the SSPxBUF register. Then, the Buffer Full detect bit, BF (SSPxSTAT<0>), and the interrupt flag bit, SSPxIF, are set. This double-buffering of the received data (SSPxBUF) allows the next byte to start reception before reading the data that was just received. Any write to the SSPxBUF register during transmission/reception of data will be ignored and the Write Collision Detect bit, WCOL (SSPxCON1<7>), will be set. User software must clear the WCOL bit so that it can be determined if the following write(s) to the SSPxBUF register completed successfully.

When the application software is expecting to receive valid data, the SSPxBUF should be read before the next byte of data to transfer is written to the SSPxBUF. The Buffer Full bit, BF (SSPxSTAT<0>), indicates when SSPxBUF has been loaded with the received data (transmission is complete). When the SSPxBUF is read, the BF bit is cleared. This data may be irrelevant if the SPI is only a transmitter. Generally, the MSSP interrupt is used to determine when the transmission/reception has completed. If the interrupt method is not going to be used, then software polling can be done to ensure that a write collision does not occur. Example 19-1 shows the loading of the SSPxBUF (SSPxSR) for data transmission.

The SSPxSR is not directly readable or writable and can only be accessed by addressing the SSPxBUF register. Additionally, the SSPxSTAT register indicates the various status conditions.

| EXAMPLE 19-1: | LOADING THE SSP1BUF | (SSP1SR) REGISTER |
|---------------|---------------------|-------------------|
|               |                     |                   |

| LOOP | BTFSS | SSP1STAT, BF | ;Has data been received (transmit complete)? |
|------|-------|--------------|----------------------------------------------|
|      | BRA   | LOOP         | ;No                                          |
|      | MOVF  | SSP1BUF, W   | ;WREG reg = contents of SSP1BUF              |
|      | MOVWF | RXDATA       | ;Save in user RAM, if data is meaningful     |
|      | MOVF  | TXDATA, W    | ;W reg = contents of TXDATA                  |
|      | MOVWF | SSP1BUF      | ;New data to xmit                            |

| Name     | Bit 7                                                                                                                   | Bit 6                        | Bit 5                                   | Bit 4                                     | Bit 3           | Bit 2          | Bit 1           | Bit 0  | Reset<br>Values<br>on Page |
|----------|-------------------------------------------------------------------------------------------------------------------------|------------------------------|-----------------------------------------|-------------------------------------------|-----------------|----------------|-----------------|--------|----------------------------|
| INTCON   | GIE/GIEH                                                                                                                | PEIE/GIEL                    | TMR0IE                                  | INT0IE                                    | RBIE            | TMR0IF         | INT0IF          | RBIF   | 53                         |
| PIR1     | PSPIF                                                                                                                   | ADIF                         | RC1IF                                   | TX1IF                                     | SSP1IF          | CCP1IF         | TMR2IF          | TMR1IF | 55                         |
| PIE1     | PSPIE                                                                                                                   | ADIE                         | RC1IE                                   | TX1IE                                     | SSP1IE          | CCP1IE         | TMR2IE          | TMR1IE | 55                         |
| IPR1     | PSPIP                                                                                                                   | ADIP                         | RC1IP                                   | TX1IP                                     | SSP1IP          | CCP1IP         | TMR2IP          | TMR1IP | 55                         |
| PIR2     | OSCFIF                                                                                                                  | CMIF                         | _                                       | —                                         | BCL1IF          | —              | TMR3IF          | CCP2IF | 55                         |
| PIE2     | OSCFIE                                                                                                                  | CMIE                         | _                                       | —                                         | BCL1IE          | —              | TMR3IE          | CCP2IE | 55                         |
| IPR2     | OSCFIP                                                                                                                  | CMIP                         | _                                       | —                                         | BCL1IP          | —              | TMR3IP          | CCP2IP | 55                         |
| PIR3     | SSP2IF                                                                                                                  | BCL2IF                       | RC2IF                                   | TX2IF                                     | TMR4IF          | CCP5IF         | CCP4IF          | CCP3IF | 55                         |
| PIE3     | SSP2IE                                                                                                                  | BCL2IE                       | RC2IE                                   | TX2IE                                     | TMR4IE          | CCP5IE         | CCP4IE          | CCP3IE | 55                         |
| IPR3     | SSP2IP                                                                                                                  | BCL2IP                       | RC2IP                                   | TX2IP                                     | TMR4IP          | CCP5IP         | CCP4IP          | CCP3IP | 55                         |
| TRISC    | TRISC7                                                                                                                  | TRISC6                       | TRISC5                                  | TRISC4                                    | TRISC3          | TRISC2         | TRISC1          | TRISC0 | 56                         |
| TRISD    | TRISD7                                                                                                                  | TRISD6                       | TRISD5                                  | TRISD4                                    | TRISD3          | TRISD2         | TRISD1          | TRISD0 | 56                         |
| SSP1BUF  | MSSP1 Re                                                                                                                | ceive Buffer                 | /Transmit R                             | egister                                   |                 |                |                 |        | 54                         |
| SSP1ADD  | MSSP1 Ad<br>MSSP1 Ba                                                                                                    | ldress Regis<br>iud Rate Rel | ter (I <sup>2</sup> C™ S<br>oad Registe | lave mode),<br>er (I <sup>2</sup> C Maste | er mode)        |                |                 |        | 57                         |
| SSPxCON1 | WCOL                                                                                                                    | SSPOV                        | SSPEN                                   | CKP                                       | SSPM3           | SSPM2          | SSPM1           | SSPM0  | 54, 57                     |
| SSPxCON2 | GCEN                                                                                                                    | ACKSTAT                      | ACKDT/<br>ADMSK5                        | ACKEN/<br>ADMSK4                          | RCEN/<br>ADMSK3 | PEN/<br>ADMSK2 | RSEN/<br>ADMSK1 | SEN    | 54, 57                     |
| SSPxSTAT | SMP                                                                                                                     | CKE                          | D/A                                     | Р                                         | S               | R/W            | UA              | BF     | 54, 57                     |
| SSP2BUF  | MSSP2 Re                                                                                                                | ceive Buffer                 | /Transmit R                             | egister                                   |                 |                |                 |        | 54                         |
| SSP2ADD  | MSSP2 Address Register (I <sup>2</sup> C Slave mode),<br>MSSP2 Baud Rate Reload Register (I <sup>2</sup> C Master mode) |                              |                                         |                                           |                 |                |                 |        | 57                         |

## TABLE 19-4: REGISTERS ASSOCIATED WITH I<sup>2</sup>C<sup>™</sup> OPERATION

**Legend:** — = unimplemented, read as '0'. Shaded cells are not used by the MSSP module in  $I^2C^{TM}$  mode.

NOTES:





### 23.2 Voltage Reference Accuracy/Error

The full range of voltage reference cannot be realized due to the construction of the module. The transistors on the top and bottom of the resistor ladder network (Figure 23-1) keep CVREF from approaching the reference source rails. The voltage reference is derived from the reference source; therefore, the CVREF output changes with fluctuations in that source. The tested absolute accuracy of the voltage reference can be found in **Section 27.0 "Electrical Characteristics"**.

### 23.3 Operation During Sleep

When the device wakes up from Sleep through an interrupt or a Watchdog Timer time-out, the contents of the CVRCON register are not affected. To minimize current consumption in Sleep mode, the voltage reference should be disabled.

### 23.4 Effects of a Reset

A device Reset disables the voltage reference by clearing bit, CVREN (CVRCON<7>). This Reset also disconnects the reference from the RA2 pin by clearing bit, CVROE (CVRCON<6>), and selects the high-voltage range by clearing bit, CVRR (CVRCON<5>). The CVR value select bits are also cleared.

### 23.5 Connection Considerations

The voltage reference module operates independently of the comparator module. The output of the reference generator may be connected to the RF5 pin if the CVROE bit is set. Enabling the voltage reference output onto RA2 when it is configured as a digital input will increase current consumption. Connecting RF5 as a digital output with CVRSS enabled will also increase current consumption.

The RF5 pin can be used as a simple D/A output with limited drive capability. Due to the limited current drive capability, a buffer must be used on the voltage reference output for external connections to VREF. Figure 23-2 shows an example buffering technique.

### 24.5 Fail-Safe Clock Monitor

The Fail-Safe Clock Monitor (FSCM) allows the microcontroller to continue operation in the event of an external oscillator failure by automatically switching the device clock to the internal oscillator block. The FSCM function is enabled by setting the FCMEN Configuration bit.

When FSCM is enabled, the INTRC oscillator runs at all times to monitor clocks to peripherals and provide a backup clock in the event of a clock failure. Clock monitoring (shown in Figure 24-4) is accomplished by creating a sample clock signal which is the INTRC output divided by 64. This allows ample time between FSCM sample clocks for a peripheral clock edge to occur. The peripheral device clock and the sample clock are presented as inputs to the Clock Monitor latch (CM). The CM is set on the falling edge of the device clock source but cleared on the rising edge of the sample clock.





Clock failure is tested for on the falling edge of the sample clock. If a sample clock falling edge occurs while CM is still set, a clock failure has been detected (Figure 24-5). This causes the following:

- the FSCM generates an oscillator fail interrupt by setting bit, OSCFIF (PIR2<7>);
- the device clock source is switched to the internal oscillator block (OSCCON is not updated to show the current clock source – this is the fail-safe condition); and
- the WDT is reset.

During switchover, the postscaler frequency from the internal oscillator block may not be sufficiently stable for timing sensitive applications. In these cases, it may be desirable to select another clock configuration and enter an alternate power-managed mode. This can be done to attempt a partial recovery or execute a controlled shutdown. See Section 4.1.4 "Multiple Sleep Commands" and Section 24.4.1 "Special Considerations for Using Two-Speed Start-up" for more details.

The FSCM will detect failures of the primary or secondary clock sources only. If the internal oscillator block fails, no failure would be detected, nor would any action be possible.

### 24.5.1 FSCM AND THE WATCHDOG TIMER

Both the FSCM and the WDT are clocked by the INTRC oscillator. Since the WDT operates with a separate divider and counter, disabling the WDT has no effect on the operation of the INTRC oscillator when the FSCM is enabled.

As already noted, the clock source is switched to the INTRC clock when a clock failure is detected; this may mean a substantial change in the speed of code execution. If the WDT is enabled with a small prescale value, a decrease in clock speed allows a WDT time-out to occur and a subsequent device Reset. For this reason, fail-safe clock events also reset the WDT and postscaler, allowing it to start timing from when execution speed was changed and decreasing the likelihood of an erroneous time-out.

### 24.5.2 EXITING FAIL-SAFE OPERATION

The fail-safe condition is terminated by either a device Reset or by entering a power-managed mode. On Reset, the controller starts the primary clock source specified in Configuration Register 2H (with any required start-up delays that are required for the oscillator mode, such as OST or PLL timer). The INTRC oscillator provides the device clock until the primary clock source becomes ready (similar to a Two-Speed Start-up). The clock source is then switched to the primary clock (indicated by the OSTS bit in the OSCCON register becoming set). The Fail-Safe Clock Monitor then resumes monitoring the peripheral clock.

The primary clock source may never become ready during start-up. In this case, operation is clocked by the INTRC oscillator. The OSCCON register will remain in its Reset state until a power-managed mode is entered.

| FIGURE 25-1: | GENERAL FORMAT FOR INSTRUCTIONS                                                                                                                                                                                                                       |                      |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
|              | Byte-oriented file register operations                                                                                                                                                                                                                | Example Instruction  |
|              | <u>15 10 9 8 7 0</u>                                                                                                                                                                                                                                  |                      |
|              | OPCODE d a f (FILE #)                                                                                                                                                                                                                                 | ADDWF MYREG, W, B    |
|              | <ul> <li>d = 0 for result destination to be WREG register</li> <li>d = 1 for result destination to be file register (f)</li> <li>a = 0 to force Access Bank</li> <li>a = 1 for BSR to select bank</li> <li>f = 8-bit file register address</li> </ul> |                      |
|              | Byte to Byte move operations (2-word)                                                                                                                                                                                                                 |                      |
|              | <u>15 12 11 0</u>                                                                                                                                                                                                                                     |                      |
|              | OPCODE f (Source FILE #)                                                                                                                                                                                                                              | MOVFF MYREG1, MYREG2 |
|              |                                                                                                                                                                                                                                                       |                      |
|              | 1111 f (Destination FILE #)                                                                                                                                                                                                                           |                      |
|              | f = 12-bit file register address                                                                                                                                                                                                                      |                      |
|              | Bit-oriented file register operations                                                                                                                                                                                                                 |                      |
|              | <u>15 12 11 9 8 7 0</u>                                                                                                                                                                                                                               |                      |
|              | OPCODE b (BIT #) a f (FILE #)                                                                                                                                                                                                                         | BSF MYREG, bit, B    |
|              | b = 3-bit position of bit in file register (f)                                                                                                                                                                                                        |                      |
|              | a = 0 to force Access Bank<br>a = 1 for BSR to select bank                                                                                                                                                                                            |                      |
|              | f = 8-bit file register address                                                                                                                                                                                                                       |                      |
|              | Literal operations                                                                                                                                                                                                                                    |                      |
|              | 15 8 7 0                                                                                                                                                                                                                                              |                      |
|              | OPCODE k (literal)                                                                                                                                                                                                                                    | MOVLW 7Fh            |
|              | k = 8-bit immediate value                                                                                                                                                                                                                             |                      |
|              | Control operations                                                                                                                                                                                                                                    |                      |
|              | CALL GOTO and Branch operations                                                                                                                                                                                                                       |                      |
|              | 15 8 7 0                                                                                                                                                                                                                                              |                      |
|              | OPCODE n<7:0> (literal)                                                                                                                                                                                                                               | GOTO Label           |
|              | 15 12 11 0                                                                                                                                                                                                                                            |                      |
|              | 1111 n<19:8> (literal)                                                                                                                                                                                                                                |                      |
|              | n = 20-bit immediate value                                                                                                                                                                                                                            |                      |
|              | 15 8 7 0                                                                                                                                                                                                                                              |                      |
|              | OPCODE S n<7:0> (literal)                                                                                                                                                                                                                             | CALL MYFUNC          |
|              | 15 12 11 0                                                                                                                                                                                                                                            |                      |
|              | 1111 n<19:8> (literal)                                                                                                                                                                                                                                |                      |
|              | S = Fast bit                                                                                                                                                                                                                                          |                      |
|              | 15 11 10 0                                                                                                                                                                                                                                            |                      |
|              | $OPCODE \qquad n<10:0> (literal)$                                                                                                                                                                                                                     | BRA MYFUNC           |
|              |                                                                                                                                                                                                                                                       |                      |
|              | 15 8 7 0                                                                                                                                                                                                                                              |                      |
|              | OPCODE n<7:0> (literal)                                                                                                                                                                                                                               | BC MYFUNC            |
|              |                                                                                                                                                                                                                                                       |                      |

Branch if Carry

BC n -128 ≤ n ≤ 127

| ANDWF AND W with f                             |                                                                                                                      |                                                                              |                                                                       |                                                               | вс         |                                          |
|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------------------|------------|------------------------------------------|
| Syntax:                                        | ANDWF                                                                                                                | f {,d {,a}                                                                   | }                                                                     |                                                               | Syn        | tax:                                     |
| Operands:                                      | $0 \le f \le 255$                                                                                                    |                                                                              |                                                                       |                                                               | Ope        | erands:                                  |
|                                                | d ∈ [0,1]<br>a ∈ [0,1]                                                                                               |                                                                              |                                                                       |                                                               | Ope        | eration:                                 |
| Operation:                                     | (W) .AND.                                                                                                            | $(f) \rightarrow des$                                                        | t                                                                     |                                                               | Stat       | us Affected                              |
| Status Affected:                               | N, Z                                                                                                                 |                                                                              |                                                                       |                                                               | Enc        | odina:                                   |
| Encoding: 0001 01da ffff fff                   |                                                                                                                      |                                                                              |                                                                       |                                                               |            | cription:                                |
| Description:                                   | The conter<br>register 'f'.<br>in W. If 'd' ia<br>in register '<br>If 'a' is '0', 1<br>If 'a' is '1', 1<br>GPR bank. | Its of W a<br>If 'd' is '0'<br>s '1', the r<br>f'.<br>the Acces<br>the BSR i | re ANDed<br>, the result<br>result is sto<br>s Bank is<br>s used to s | l with<br>t is stored<br>bred back<br>selected.<br>select the |            |                                          |
|                                                | lf 'a' is '0' a                                                                                                      | ind the ex                                                                   | Wor                                                                   | ds:                                                           |            |                                          |
|                                                | set is enab                                                                                                          | led, this i                                                                  | Сус                                                                   | les:                                                          |            |                                          |
|                                                | mode when<br>Section 25<br>Bit-Oriente<br>Literal Off                                                                | never f ≤ 5<br>5.2.3 "By<br>ad Instru<br>set Mode                            | Q (<br>If J                                                           | Cycle Activity:<br>ump:<br>Q1<br>Decode                       |            |                                          |
| Words:                                         | 1                                                                                                                    |                                                                              |                                                                       |                                                               |            |                                          |
| Cycles:                                        | 1                                                                                                                    |                                                                              |                                                                       |                                                               |            | No                                       |
| Q Cycle Activity:                              |                                                                                                                      |                                                                              |                                                                       |                                                               | If N       |                                          |
| Q1                                             | Q2                                                                                                                   | Q3                                                                           |                                                                       | Q4                                                            |            | Q1                                       |
| Decode                                         | Read<br>register 'f'                                                                                                 | Proce<br>Data                                                                | ss V<br>a des                                                         | /rite to<br>stination                                         |            | Decode                                   |
| Example:                                       | ANDWF                                                                                                                | REG,                                                                         | 0, 0                                                                  |                                                               | <u>Exa</u> | mple:                                    |
| Before Instruc<br>W<br>REG<br>After Instructio | tion<br>= 17h<br>= C2h<br>on                                                                                         |                                                                              |                                                                       |                                                               |            | Before Instruc<br>PC<br>After Instructio |
| w<br>REG                                       | = 02h<br>= C2h                                                                                                       |                                                                              |                                                                       |                                                               |            | PC<br>If Carry<br>PC                     |

| ation:                  | if Carry bit is '1',<br>(PC) + 2 + 2n $\rightarrow$ PC                                    |                                                                                                    |                                                                          |  |  |  |
|-------------------------|-------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|--|--|--|
| is Affected:            | None                                                                                      |                                                                                                    |                                                                          |  |  |  |
| oding:                  | 1110                                                                                      | 0010 nn                                                                                            | nn nnnn                                                                  |  |  |  |
| cription:               | If the Carry will branch.                                                                 | bit is '1', then                                                                                   | the program                                                              |  |  |  |
|                         | The 2's con<br>added to the<br>incrementer<br>instruction,<br>PC + 2 + 2r<br>two-cycle in | nplement num<br>e PC. Since th<br>d to fetch the<br>the new addr<br>n. This instruc<br>istruction. | nber '2n' is<br>ne PC will have<br>next<br>ess will be<br>tion is then a |  |  |  |
| ls:                     | 1                                                                                         |                                                                                                    |                                                                          |  |  |  |
| es:                     | 1(2)                                                                                      |                                                                                                    |                                                                          |  |  |  |
| ycle Activity:<br>Imp:  |                                                                                           |                                                                                                    |                                                                          |  |  |  |
| Q1                      | Q2                                                                                        | Q3                                                                                                 | Q4                                                                       |  |  |  |
| Decode                  | Read literal<br>'n'                                                                       | Process<br>Data                                                                                    | Write to<br>PC                                                           |  |  |  |
| No<br>operation         | No<br>operation                                                                           | No<br>operation                                                                                    | No<br>operation                                                          |  |  |  |
| o Jump:                 |                                                                                           |                                                                                                    |                                                                          |  |  |  |
| Q1                      | Q2                                                                                        | Q3                                                                                                 | Q4                                                                       |  |  |  |
| Decode                  | Read literal<br>'n'                                                                       | Process<br>Data                                                                                    | No<br>operation                                                          |  |  |  |
| nple:                   | HERE                                                                                      | BC 5                                                                                               |                                                                          |  |  |  |
| Before Instruc          | tion                                                                                      |                                                                                                    |                                                                          |  |  |  |
| PC<br>After Instruction | = ad                                                                                      | dress (HERE                                                                                        | )                                                                        |  |  |  |
| If Carry<br>PC          | = 1;<br>= ad                                                                              | dress (HERE                                                                                        | + 12)                                                                    |  |  |  |

=

0; address (HERE + 2)

RLCF f {,d {,a}}

 $0 \leq f \leq 255$  $\mathsf{d} \in [0,1]$ **a** ∈ [0,1]

Rotate Left f through Carry

RLCF

Syntax:

Operands:

| RETI  | JRN                                                                                                                                                                                                                                                                                                                                      | Return from Subroutine                                                                                                                                        |               |               |                    |  |  |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------|--------------------|--|--|--|
| Synta | ax:                                                                                                                                                                                                                                                                                                                                      | RETURN                                                                                                                                                        | {s}           |               |                    |  |  |  |
| Oper  | ands:                                                                                                                                                                                                                                                                                                                                    | <b>S</b> ∈ [0,1]                                                                                                                                              |               |               |                    |  |  |  |
| Oper  | ation:                                                                                                                                                                                                                                                                                                                                   | $(TOS) \rightarrow PC;$<br>if s = 1,<br>$(WS) \rightarrow W,$<br>$(STATUSS) \rightarrow STATUS,$<br>$(BSRS) \rightarrow BSR,$<br>PCLATU, PCLATH are unchanged |               |               |                    |  |  |  |
| Statu | s Affected:                                                                                                                                                                                                                                                                                                                              | None                                                                                                                                                          |               |               |                    |  |  |  |
| Enco  | ding:                                                                                                                                                                                                                                                                                                                                    | 0000                                                                                                                                                          | 0000          | 0001          | 001s               |  |  |  |
| Desc  | Description:<br>Return from subroutine. The stack is<br>popped and the top of the stack (TO<br>is loaded into the program counter. I<br>'s'= 1, the contents of the shadow<br>registers WS, STATUSS and BSRS is<br>loaded into their corresponding<br>registers W, STATUS and BSR. If<br>'s' = 0, no update of these registers<br>occurs |                                                                                                                                                               |               |               |                    |  |  |  |
| Word  | IS:                                                                                                                                                                                                                                                                                                                                      | 1                                                                                                                                                             |               |               |                    |  |  |  |
| Cycle | es:                                                                                                                                                                                                                                                                                                                                      | 2                                                                                                                                                             |               |               |                    |  |  |  |
| QC    | ycle Activity:                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                               |               |               |                    |  |  |  |
|       | Q1                                                                                                                                                                                                                                                                                                                                       | Q2                                                                                                                                                            | Q3            | 1             | Q4                 |  |  |  |
|       | Decode                                                                                                                                                                                                                                                                                                                                   | No<br>operation                                                                                                                                               | Proce<br>Data | ss F<br>a fro | POP PC<br>om stack |  |  |  |
|       | No                                                                                                                                                                                                                                                                                                                                       | No                                                                                                                                                            | No            |               | No                 |  |  |  |
|       | operation                                                                                                                                                                                                                                                                                                                                | operation                                                                                                                                                     | operat        | ion o         | peration           |  |  |  |
| Exam  | nple:                                                                                                                                                                                                                                                                                                                                    | RETURN                                                                                                                                                        |               |               |                    |  |  |  |

|         | Opera  | ition:                                              | $(f < n >) \rightarrow dest < n + 1 >,$<br>$(f < 7 >) \rightarrow C,$<br>$(C) \rightarrow dest < 0 >$ |                                                                     |                                                                                  |                                                               |                                                             |                                                  |
|---------|--------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------|-------------------------------------------------------------|--------------------------------------------------|
|         | Status | Affected:                                           | C, I                                                                                                  | N, Z                                                                |                                                                                  |                                                               |                                                             |                                                  |
|         | Encoc  | ling:                                               | C                                                                                                     | 0011                                                                | 01da                                                                             | fff                                                           | f                                                           | ffff                                             |
| 5<br>S) | Descr  | iption:                                             | The<br>one<br>If 'd<br>is '1<br>'f'.                                                                  | e conten<br>e bit to th<br>l' is '0', t<br>L', the re               | ts of regi<br>ne left thr<br>he result<br>esult is sto                           | ster 'f'<br>ough th<br>is plac<br>ored ba                     | are ro<br>ne Ca<br>ed in<br>ack in                          | otated<br>nrry flag.<br>W. If 'd'<br>register    |
| are     |        |                                                     | lf 'a<br>If 'a<br>GP                                                                                  | ı' is '0', t<br>ı' is '1', t<br>R bank.                             | he Acces<br>he BSR i                                                             | ss Banl<br>is used                                            | k is se<br>to se                                            | elected.<br>elect the                            |
|         |        |                                                     | If 'a<br>set<br>in Ir<br>mod<br>Sec<br>Bit-                                                           | i' is '0' a<br>is enab<br>ndexed<br>de wher<br>ction 25<br>-Oriente | Ind the ex<br>led, this i<br>Literal Of<br>never f ≤ 9<br>5.2.3 "By<br>ed Instru | ktended<br>nstruct<br>fset Ac<br>95 (5FI<br>te-Orie<br>ctions | d inst<br>ion op<br>Idres<br>n). Se<br><b>nted</b><br>in In | ruction<br>perates<br>sing<br>ee<br>and<br>dexed |
|         |        |                                                     | LITE                                                                                                  |                                                                     |                                                                                  | enister                                                       | etalis                                                      | ]                                                |
| ĸ       |        |                                                     |                                                                                                       | 0                                                                   |                                                                                  | egiotei                                                       | <u> </u>                                                    |                                                  |
| ı       | Words  | S:                                                  | 1                                                                                                     |                                                                     |                                                                                  |                                                               |                                                             |                                                  |
|         | Cycles | S:                                                  | 1                                                                                                     |                                                                     |                                                                                  |                                                               |                                                             |                                                  |
|         | Q Cy   | cle Activity:                                       |                                                                                                       |                                                                     |                                                                                  |                                                               |                                                             |                                                  |
|         | F      | Q1                                                  |                                                                                                       | Q2                                                                  | Q                                                                                | 3                                                             |                                                             | Q4                                               |
|         |        | Decode                                              | F<br>reg                                                                                              | Read<br>ister 'f'                                                   | Proce<br>Dat                                                                     | ess<br>ta                                                     | Wi<br>dest                                                  | rite to<br>tination                              |
|         | Exam   | ple:                                                | F                                                                                                     | RLCF                                                                | RE                                                                               | G, O,                                                         | 0                                                           |                                                  |
|         | E      | Before Instruction<br>REG<br>C<br>After Instruction | tion<br>=<br>=<br>on                                                                                  | 1110<br><b>0</b>                                                    | 0110                                                                             |                                                               |                                                             |                                                  |
|         |        | REG                                                 | =                                                                                                     | 1110                                                                | 0110                                                                             |                                                               |                                                             |                                                  |

After Instruction: PC = TOS

### 27.2 DC Characteristics: Power-Down and Supply Current PIC18F87J10 Family (Industrial) (Continued)

| PIC18F8<br>(Indu                      | 7J10 Family<br>strial) | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial |                        |    |       |                           |                              |  |  |  |
|---------------------------------------|------------------------|------------------------------------------------------------------------------------------------------------------------------------|------------------------|----|-------|---------------------------|------------------------------|--|--|--|
| Param<br>No.                          | Device                 | Тур                                                                                                                                | Гур Max Units Conditio |    |       |                           | ons                          |  |  |  |
| Supply Current (IDD) <sup>(2,3)</sup> |                        |                                                                                                                                    |                        |    |       |                           |                              |  |  |  |
|                                       | All devices            | 1.8                                                                                                                                | 3.27                   | mA | -10°C |                           |                              |  |  |  |
|                                       |                        | 1.8                                                                                                                                | 3.27                   | mA | +25°C | VDD = 2.0V <sup>(5)</sup> |                              |  |  |  |
|                                       |                        | 1.9                                                                                                                                | 3.27                   | mA | +70°C |                           |                              |  |  |  |
|                                       | All devices            | 4.0                                                                                                                                | 5.57                   | mA | -10°C |                           | Fosc = 32 kHz <sup>(4)</sup> |  |  |  |
|                                       |                        | 3.7                                                                                                                                | 5.57                   | mA | +25°C | VDD = 2.5V <sup>(5)</sup> | (SEC_RUN mode,               |  |  |  |
|                                       |                        | 3.5                                                                                                                                | 5.57                   | mA | +70°C |                           | Timer1 as clock)             |  |  |  |
|                                       | All devices            | 4.2                                                                                                                                | 5.97                   | mA | -10°C |                           |                              |  |  |  |
|                                       |                        | 4.0                                                                                                                                | 5.97                   | mA | +25°C | VDD = 3.3V <sup>(6)</sup> |                              |  |  |  |
|                                       |                        | 3.8                                                                                                                                | 5.97                   | mA | +70°C |                           |                              |  |  |  |
|                                       | All devices            | 1.8                                                                                                                                | 3.27                   | mA | -10°C |                           |                              |  |  |  |
|                                       |                        | 1.8                                                                                                                                | 3.27                   | mA | +25°C | VDD = 2.0V <sup>(5)</sup> |                              |  |  |  |
|                                       |                        | 1.9                                                                                                                                | 3.27                   | mA | +70°C |                           |                              |  |  |  |
|                                       | All devices            | 4.0                                                                                                                                | 5.57                   | mA | -10°C |                           | Fosc = 32 kHz <sup>(4)</sup> |  |  |  |
|                                       |                        | 3.7                                                                                                                                | 5.57                   | mA | +25°C | VDD = 2.5V <sup>(5)</sup> | (SEC_IDLE mode,              |  |  |  |
|                                       |                        | 3.5                                                                                                                                | 5.57                   | mA | +70°C |                           | Timer1 as clock)             |  |  |  |
|                                       | All devices            | 4.2                                                                                                                                | 5.97                   | mA | -10°C | VDD = 3.3V <sup>(6)</sup> |                              |  |  |  |
|                                       |                        | 4.0                                                                                                                                | 5.97                   | mA | +25°C |                           |                              |  |  |  |
|                                       |                        | 3.8                                                                                                                                | 5.97                   | mA | +70°C |                           |                              |  |  |  |

**Note 1:** The power-down current in Sleep mode does not depend on the oscillator type. Power-down current is measured with the part in Sleep mode, with all I/O pins in high-impedance state and tied to VDD or Vss, and all features that add delta current disabled (such as WDT, Timer1 oscillator, BOR, etc.).

2: The supply current is mainly a function of operating voltage, frequency and mode. Other factors, such as I/O pin loading and switching rate, oscillator type and circuit, internal code execution pattern and temperature, also have an impact on the current consumption.

The test conditions for all IDD measurements in active operation mode are:

OSC1 = external square wave, from rail-to-rail; all I/O pins tri-stated, pulled to VDD;

MCLR = VDD; WDT enabled/disabled as specified.

3: For RC oscillator configurations, current through REXT is not included. The current through the resistor can be estimated by the formula Ir = VDD/2REXT (mA) with REXT in kΩ.

4: Standard, low-cost 32 kHz crystals have an operating temperature range of -10°C to +70°C. Extended temperature crystals are available at a much higher cost.

**5:** ENVREG tied to Vss, voltage regulator disabled.

6: ENVREG tied to VDD, voltage regulator enabled.

### 27.4.2 TIMING CONDITIONS

The temperature and voltages specified in Table 27-5 apply to all timing specifications unless otherwise noted. Figure 27-3 specifies the load conditions for the timing specifications.

### TABLE 27-5: TEMPERATURE AND VOLTAGE SPECIFICATIONS – AC

|                    | Standard Operating Conditions (unless otherwise stated)                     |  |  |  |
|--------------------|-----------------------------------------------------------------------------|--|--|--|
| AC CHARACTERISTICS | Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial |  |  |  |
|                    | Operating voltage VDD range as described in DC spec Section 27.1 and        |  |  |  |
|                    | Section 27.3.                                                               |  |  |  |

### FIGURE 27-3: LOAD CONDITIONS FOR DEVICE TIMING SPECIFICATIONS





| Param.<br>No | Symbol   | Characteristics                                                                         | Min           | Тур     | Мах | Units |
|--------------|----------|-----------------------------------------------------------------------------------------|---------------|---------|-----|-------|
| 150          | TadV2alL | Address Out Valid to ALE $\downarrow$ (address setup time)                              | 0.25 Tcy – 10 | —       | _   | ns    |
| 151          | TalL2adl | ALE $\downarrow$ to Address Out Invalid (address hold time)                             | 5             | _       |     | ns    |
| 153          | TwrH2adl | $\overline{WRn}$ $\uparrow$ to Data Out Invalid (data hold time)                        | 5             | _       |     | ns    |
| 154          | TwrL     | WRn Pulse Width                                                                         | 0.5 Tcy – 5   | 0.5 TCY | _   | ns    |
| 156          | TadV2wrH | Data Valid before $\overline{WRn}$ $\uparrow$ (data setup time)                         | 0.5 Tcy – 10  | —       | _   | ns    |
| 157          | TbsV2wrL | Byte Select Valid before $\overline{\text{WRn}} \downarrow$<br>(byte select setup time) | 0.25 TCY      | —       | _   | ns    |
| 157A         | TwrH2bsl | WRn ↑ to Byte Select Invalid (byte select hold time)                                    | 0.125 Tcy – 5 | _       | _   | ns    |
| 166          | TalH2alH | ALE $\uparrow$ to ALE $\uparrow$ (cycle time)                                           | —             | Тсү     | _   | ns    |
| 171          | TalH2csL | Chip Enable Active to ALE $\downarrow$                                                  | 0.25 TCY – 20 | —       |     | ns    |
| 171A         | TubL2oeH | AD Valid to Chip Enable Active                                                          | _             | _       | 10  | ns    |



## TABLE 27-22: MASTER SSP I<sup>2</sup>C<sup>™</sup> BUS START/STOP BITS REQUIREMENTS

| Param.<br>No. | Symbol  | Characte        | eristic                   | Min              | Мах | Units | Conditions             |
|---------------|---------|-----------------|---------------------------|------------------|-----|-------|------------------------|
| 90            | TSU:STA | Start Condition | 100 kHz mode              | 2(Tosc)(BRG + 1) |     | ns    | Only relevant for      |
|               |         | Setup Time      | 400 kHz mode              | 2(Tosc)(BRG + 1) | _   |       | Repeated Start         |
|               |         |                 | 1 MHz mode <sup>(1)</sup> | 2(Tosc)(BRG + 1) | _   |       | condition              |
| 91            | THD:STA | Start Condition | 100 kHz mode              | 2(Tosc)(BRG + 1) | _   | ns    | After this period, the |
|               |         | Hold Time       | 400 kHz mode              | 2(Tosc)(BRG + 1) | —   |       | first clock pulse is   |
|               |         |                 | 1 MHz mode <sup>(1)</sup> | 2(Tosc)(BRG + 1) | _   |       | generated              |
| 92            | Tsu:sto | Stop Condition  | 100 kHz mode              | 2(Tosc)(BRG + 1) | _   | ns    |                        |
|               |         | Setup Time      | 400 kHz mode              | 2(Tosc)(BRG + 1) | _   |       |                        |
|               |         |                 | 1 MHz mode <sup>(1)</sup> | 2(Tosc)(BRG + 1) | _   |       |                        |
| 93            | THD:STO | Stop Condition  | 100 kHz mode              | 2(Tosc)(BRG + 1) | _   | ns    |                        |
|               |         | Hold Time       | 400 kHz mode              | 2(Tosc)(BRG + 1) | _   | ]     |                        |
|               |         |                 | 1 MHz mode <sup>(1)</sup> | 2(Tosc)(BRG + 1) | _   | ]     |                        |

**Note 1:** Maximum pin capacitance = 10 pF for all  $I^2C^{TM}$  pins.



