

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

E·XFI

| Dectano                    |                                                                                |
|----------------------------|--------------------------------------------------------------------------------|
| Product Status             | Active                                                                         |
| Core Processor             | PIC                                                                            |
| Core Size                  | 8-Bit                                                                          |
| Speed                      | 64MHz                                                                          |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                      |
| Peripherals                | Brown-out Detect/Reset, LCD, POR, PWM, WDT                                     |
| Number of I/O              | 69                                                                             |
| Program Memory Size        | 32KB (16K x 16)                                                                |
| Program Memory Type        | FLASH                                                                          |
| EEPROM Size                | 1K x 8                                                                         |
| RAM Size                   | 2K x 8                                                                         |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 5.5V                                                                    |
| Data Converters            | A/D 24x12b                                                                     |
| Oscillator Type            | Internal                                                                       |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                              |
| Mounting Type              | Surface Mount                                                                  |
| Package / Case             | 80-TQFP                                                                        |
| Supplier Device Package    | 80-TQFP (12x12)                                                                |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18f85k90t-i-ptrsl |
|                            |                                                                                |

Email: info@E-XFL.COM

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

The PIC18F87K90 family is also largely pin-compatible with other PIC18 families, such as the PIC18F8720, PIC18F8722, PIC18F85J11, PIC18F8490, PIC18F85J90, PIC18F87J90 and PIC18F87J93 families of microcontrollers with LCD drivers. This allows a new dimension to the evolution of applications, allowing developers to select different price points within Microchip's PIC18 portfolio, while maintaining a similar feature set.

## 1.2 LCD Driver

The on-chip LCD driver includes many features that ease the integration of displays in low-power applications. These include an integrated internal resistor ladder, so bias voltages can be generated internally. This enables software-controlled contrast control and eliminates the need for external bias voltage resistors.

## 1.3 Other Special Features

- Communications: The PIC18F87K90 family incorporates a range of serial communication peripherals including two Enhanced USART, that support LIN/J2602, and two Master SSP modules capable of both SPI and I<sup>2</sup>C<sup>™</sup> (Master and Slave) modes of operation.
- CCP Modules: PIC18F87K90 family devices incorporate up to seven or five Capture/ Compare/PWM (CCP) modules. Up to six different time bases can be used to perform several different operations at once.
- ECCP Modules: The PIC18F87K90 family has three Enhanced CCP (ECCP) modules to maximize flexibility in control applications:
  - Up to eight different time bases for performing several different operations at once
  - Up to four PWM outputs for each module, for a total of 12 PWMs
  - Other beneficial features, such as polarity selection, programmable dead time, auto-shutdown and restart, and Half-Bridge and Full-Bridge Output modes
- **12-Bit A/D Converter:** The PIC18F87K90 family has differential ADC. It incorporates programmable acquisition time, allowing for a channel to be selected and a conversion to be initiated without waiting for a sampling period, and thus, reducing code overhead.
- Charge Time Measurement Unit (CTMU): The CTMU is a flexible analog module that provides accurate differential time measurement between pulse sources, as well as asynchronous pulse generation.

Together with other on-chip analog modules, the CTMU can precisely measure time, measure capacitance or relative changes in capacitance, or generate output pulses that are independent of the system clock.

- LP Watchdog Timer (WDT): This enhanced version incorporates a 22-bit prescaler, allowing an extended time-out range that is stable across operating voltage and temperature. See Section 31.0 "Electrical Characteristics" for time-out periods.
- Real-Time Clock and Calendar Module (RTCC): The RTCC module is intended for applications requiring that accurate time be maintained for extended periods of time with minimum to no intervention from the CPU.

The module is a 100-year clock and calendar with automatic leap year detection. The range of the clock is from 00:00:00 (midnight) on January 1, 2000 to 23:59:59 on December 31, 2099.

### 1.4 Details on Individual Family Members

Devices in the PIC18F87K90 family are available in 64-pin and 80-pin packages. Block diagrams for the two groups are shown in Figure 1-1 and Figure 1-2.

The devices are differentiated from each other in these ways:

- Flash Program Memory:
  - PIC18FX5K90 (PIC18F65K90 and PIC18F85K90) – 32 Kbytes
  - PIC18FX6K90 (PIC18F66K90 and PIC18F86K90) 64 Kbytes
  - PIC18FX7K90 (PIC18F67K90 and PIC18F87K90) 128 Kbytes
- Data RAM:
  - All devices except PIC18FX5K90 4 Kbytes
  - PIC18FX5K90 2 Kbytes
- · I/O Ports:
  - PIC18F6XK90 (64-pin devices) 7 bidirectional ports
  - PIC18F8XK90 (80-pin devices) 9 bidirectional ports
- LCD Pixels:
  - PIC18F6XK90 132 pixels (33 SEGs x 4 COMs)
  - PIC18F8XK90 192 pixels (48 SEGs x 4 COMs)
- CCP Module:
  - All devices except PIC18FX5K90 have seven CCP modules, PIC18FX5K90 has only five CCP modules
- Timers:
  - All devices except 18FX5K90 have six 8-bit timers and five 16-bit timers, PIC18FX5K90 has only four 8-bit timers and four 16-bit timers.
- A/D Channels:
  - All PIC18F8XK90 devices have 24 A/D channels, all PIC18F6XK90 devices have 16 A/D channels

All other features for devices in this family are identical. These are summarized in Table 1-1 and Table 1-2.

The pinouts for all devices are listed in Table 1-3 and Table 1-4.

| Address        | File Name | Bit 7                  | Bit 6                                | Bit 5                               | Bit 4        | Bit 3            | Bit 2         | Bit 1                      | Bit 0                  | Value on<br>POR, BOR |
|----------------|-----------|------------------------|--------------------------------------|-------------------------------------|--------------|------------------|---------------|----------------------------|------------------------|----------------------|
| EF4h           | LCDCON    | LCDEN                  | SLPEN                                | WERR                                | _            | CS1              | CS0           | LMUX1                      | LMUX0                  | 000- 0000            |
| EF5h           | LCDPS     | WFT                    | BIASMD                               | LCDA                                | WA           | LP3              | LP2           | LP1                        | LP0                    | 0000 0000            |
| EF6h           | LCDSE0    | SE07                   | SE06                                 | SE05                                | SE04         | SE03             | SE02          | SE01                       | SE00                   | 0000 0000            |
| EF7h           | LCDSE1    | SE15                   | SE14                                 | SE13                                | SE12         | SE11             | SE10          | SE09                       | SE08                   | 0000 0000            |
| EF8h           | LCDSE2    | SE23                   | SE22                                 | SE21                                | SE20         | SE19             | SE18          | SE17                       | SE16                   | 0000 0000            |
| EF9h           | LCDSE3    | SE31                   | SE30                                 | SE29                                | SE28         | SE27             | SE26          | SE25                       | SE24                   | 0000 0000            |
| EFAh           | LCDSE4    | SE39                   | SE38                                 | S37                                 | SE36         | SE35             | SE34          | SE33                       | SE32                   | 0000 0000            |
| EFBh           | LCDSE5(2) | SE47                   | SE46                                 | SE45                                | SE44         | SE43             | SE42          | SE41                       | SE40                   | 0000 0000            |
| EFCh           | LCDRL     | LRLAP1                 | LRLAP0                               | LRLBP1                              | LRLBP0       | _                | LRLAT2        | LRLAT1                     | LRLAT0                 | 0000 -000            |
| EFDh           | LCDREF    | LCDIRE                 | LCDIRS                               | LCDCST2                             | LCDCST1      | LCDCST0          | VLCD3PE       | VLCD2PE                    | VLCD1PE                | 0000 0000            |
| EFEh           | SSP2CON2  | GCEN                   | ACKSTAT                              | ACKDT                               | ACKEN        | RCEN             | PEN           | RSEN                       | SEN                    | 0000 0000            |
| EFFh           | SSP2CON1  | WCOL                   | SSPOV                                | SSPEN                               | CKP          | SSPM3            | SSPM2         | SSPM1                      | SSPM0                  | 0000 0000            |
| F00h           | SSP2STAT  | SMP                    | CKE                                  | D/A                                 | Р            | S                | R/W           | UA                         | BF                     | 0000 0000            |
| F01h           | SSP2ADD   | MSSP Addre             | ss Register in                       | I <sup>2</sup> C <sup>™</sup> Slave | Mode. SSP1 E | Baud Rate Rel    | load Register | in I <sup>2</sup> C Master | Mode                   | 0000 0000            |
| F02h           | SSP2BUF   | MSSP Receiv            | ve Buffer/Tran                       | smit Register                       |              |                  | -             |                            |                        | XXXX XXXX            |
| F03h           | T4CON     | _                      | T4OUTPS3                             | T4OUTPS2                            | T4OUTPS1     | T4OUTPS0         | TMR4ON        | T4CKPS1                    | T4CKPS0                | -000 0000            |
| F04h           | PR4       | Timer4 Perio           | d Register                           |                                     |              |                  |               |                            |                        | 0000 0000            |
| F05h           | TMR4      | Timer4 Regis           | ter                                  |                                     |              |                  |               |                            |                        | 1111 1111            |
| F06h           | CCP7CON   | _                      |                                      | DC7B1                               | DC7B0        | CCP7M3           | CCP7M2        | CCP7M1                     | CCP7M0                 | 00 0000              |
| F07h           | CCPR7L    | Capture/Com            | pare/PWM R                           | egister 7 Low                       | Byte         |                  |               |                            |                        | XXXX XXXX            |
| F08h           | CCPR7H    |                        | pare/PWM R                           |                                     |              |                  |               |                            |                        | XXXX XXXX            |
| F09h           | CCP6CON   |                        |                                      | DC6B1                               | DC6B0        | CCP6M3           | CCP6M2        | CCP6M1                     | CCP6M0                 | 00 0000              |
| F0Ah           | CCPR6L    | Capture/Com            | pare/PWM R                           |                                     |              |                  |               |                            |                        | XXXX XXXX            |
| F0Bh           | CCPR6H    |                        | pare/PWM R                           |                                     |              |                  |               |                            |                        | XXXX XXXX            |
| F0Ch           | CCP5CON   | _                      | _                                    | DC5B1                               | DC5B0        | CCP5M3           | CCP5M2        | CCP5M1                     | CCP5M0                 | 00 0000              |
| F0Dh           | CCPR5L    | Capture/Com            | pare/PWM R                           |                                     |              |                  |               |                            |                        | XXXX XXXX            |
| F0Eh           | CCPR5H    |                        | pare/PWM R                           |                                     |              |                  |               |                            |                        | XXXX XXXX            |
| F0Fh           | CCP4CON   | _                      | _                                    | DC4B1                               | DC4B0        | CCP4M3           | CCP4M2        | CCP4M1                     | CCP4M0                 | 00 0000              |
| F10h           | CCPR4L    | Capture/Com            | pare/PWM R                           |                                     |              |                  |               |                            |                        | XXXX XXXX            |
| F11h           | CCPR4H    |                        | pare/PWM R                           | -                                   | -            |                  |               |                            |                        | xxxx xxxx            |
| F12h           | T5GCON    | TMR5GE                 | T5GPOL                               | T5GTM                               | T5GSPM       | T5GGO/<br>T5DONE | T5GVAL        | T5GSS1                     | T5GSS0                 | 0000 0000            |
| F13h           | T5CON     | TMR5CS1                | TMR5CS0                              | T5CKPS1                             | T5CKPS0      | SOSCEN           | T5SYNC        | RD16                       | TMR5ON                 | 0000 0000            |
| F14h           | TMR5L     | Timer5 Regis           | ter Low Byte                         |                                     |              |                  |               |                            |                        | 0000 0000            |
| F15h           | TMR5H     |                        | ter High Byte                        |                                     |              |                  |               |                            |                        | XXXX XXXX            |
| F16h           | PMD3      | CCP10MD <sup>(3)</sup> | CCP9MD <sup>(3)</sup>                | CCP8MD                              | CCP7MD       | CCP6MD           | CCP5MD        | CCP4MD                     | TMR12MD <sup>(3)</sup> | 0000 0000            |
| F17h           | PMD2      | TMR10MD <sup>(3)</sup> | TMR8MD                               | TMR7MD <sup>(3)</sup>               | TMR6MD       | TMR5MD           | CMP3MD        | CMP2MD                     | CMP1MD                 | 0000 0000            |
| F18h           | PMD1      | _                      | CTMUMD                               | RTCCMD                              | TMR4MD       | TMR3MD           | TMR2MD        | TMR1MD                     | _                      | -000 000-            |
| F19h           | PMD0      | CCP3MD                 | CCP2MD                               | CCP1MD                              | UART2MD      | UART1MD          | SSP2MD        | SSP1MD                     | ADCMD                  | 0000 0000            |
| F1Ah           | PSTR3CON  | CMPL1                  | CMPL0                                | _                                   | STRSYNC      | STRD             | STRC          | STRB                       | STRA                   | 00-0 0001            |
| F1Bh           | PSTR2CON  | CMPL1                  | CMPL0                                | _                                   | STRSYNC      | STRD             | STRC          | STRB                       | STRA                   | 00-0 0001            |
| F1Ch           | TXREG2    |                        |                                      |                                     | enterne      | 01112            | 01110         | 01112                      | 01101                  | xxxx xxxx            |
| F1Dh           | RCREG2    |                        | Transmit Data FIFO Receive Data FIFO |                                     |              |                  |               |                            |                        |                      |
| F1Eh           | SPBRG2    |                        | Id Rate Gener                        | rator Low Byte                      | 9            |                  |               |                            |                        | 0000 0000            |
| F1Fh           | SPBRGH2   |                        | Id Rate Gener                        |                                     |              |                  |               |                            |                        | 0000 0000            |
| F20h           | BAUDCON2  | ABDOVF                 | RCIDL                                | RXDTP                               | TXCKP        | BRG16            | _             | WUE                        | ABDEN                  | 0100 0-00            |
| F21h           | TXSTA2    | CSRC                   | TX9                                  | TXEN                                | SYNC         | SENDB            | BRGH          | TRMT                       | TX9D                   | 0000 0010            |
| F2111<br>F22h  | RCSTA2    | SPEN                   | RX9                                  | SREN                                | CREN         | ADDEN            | FERR          | OERR                       | RX9D                   | 0000 0002            |
|                | 1         |                        |                                      |                                     |              |                  |               |                            |                        |                      |
| F23h<br>Note 1 | ANCON2    | ANSEL23                | ANSEL22                              | ANSEL21                             | ANSEL20      | ANSEL19          | ANSEL18       | ANSEL17                    | ANSEL16                | 1111 1111            |

| TABLE 6-2: | PIC18F87K90 FAMILY REGISTER FILE SUMMARY |
|------------|------------------------------------------|
|            |                                          |

Unimplemented in 64-pin devices (PIC18F6XK90). 2:

Unimplemented in devices with a program memory of 32 Kbytes (PIC18FX5K90). 3:

## 9.0 8 x 8 HARDWARE MULTIPLIER

#### 9.1 Introduction

All PIC18 devices include an 8 x 8 hardware multiplier as part of the ALU. The multiplier performs an unsigned operation and yields a 16-bit result that is stored in the product register pair, PRODH:PRODL. The multiplier's operation does not affect any flags in the STATUS register.

Making multiplication a hardware operation allows it to be completed in a single instruction cycle. This has the advantages of higher computational throughput and reduced code size for multiplication algorithms and allows PIC18 devices to be used in many applications previously reserved for digital-signal processors. A comparison of various hardware and software multiply operations, along with the savings in memory and execution time, is shown in Table 9-1.

#### 9.2 Operation

Example 9-1 shows the instruction sequence for an  $8 \times 8$  unsigned multiplication. Only one instruction is required when one of the arguments is already loaded in the WREG register.

Example 9-2 shows the sequence to do an 8 x 8 signed multiplication. To account for the sign bits of the arguments, each argument's Most Significant bit (MSb) is tested and the appropriate subtractions are done.

#### EXAMPLE 9-1: 8 x 8 UNSIGNED MULTIPLY ROUTINE

| MOVF  | ARG1, | W | ; |                |
|-------|-------|---|---|----------------|
| MULWF | ARG2  |   | ; | ARG1 * ARG2 -> |
|       |       |   | ; | PRODH:PRODL    |
|       |       |   |   |                |

#### EXAMPLE 9-2: 8 x 8 SIGNED MULTIPLY ROLITINE

| MOVF  | ARG1, W  |                  |  |
|-------|----------|------------------|--|
| MULWF | ARG2     | ; ARG1 * ARG2 -> |  |
|       |          | ; PRODH:PRODL    |  |
| BTFSC | ARG2, SB | ; Test Sign Bit  |  |
| SUBWF | PRODH, F | ; PRODH = PRODH  |  |
|       |          | ; – ARG1         |  |
| MOVF  | ARG2, W  |                  |  |
| BTFSC | ARG1, SB | ; Test Sign Bit  |  |
| SUBWF | PRODH, F | ; PRODH = PRODH  |  |
|       |          | ; – ARG2         |  |
|       |          |                  |  |

|                    |                           | Program           | Cycles | Time     |          |          |                      |  |  |
|--------------------|---------------------------|-------------------|--------|----------|----------|----------|----------------------|--|--|
| Routine            | Multiply Method           | Memory<br>(Words) | (Max)  | @ 64 MHz | @ 48 MHz | @ 10 MHz | @ 4 MHz              |  |  |
|                    | Without Hardware Multiply | 13                | 69     | 4.3 μs   | 5.7 μs   | 27.6 μs  | 69 μs                |  |  |
| 8 x 8 Unsigned     | Hardware Multiply         | 1                 | 1      | 62.5 ns  | 83.3 ns  | 400 ns   | 1 μs                 |  |  |
| 9 y 9 Signad       | Without Hardware Multiply | 33                | 91     | 5.6 μs   | 7.5 μs   | 36.4 μs  | 91 μ <b>s</b>        |  |  |
| 8 x 8 Signed       | Hardware Multiply         | 6                 | 6      | 375 ns   | 500 ns   | 2.4 μs   | 6 μs                 |  |  |
| 16 x 16            | Without Hardware Multiply | 21                | 242    | 15.1 μs  | 20.1 μs  | 96.8 μs  | 242 μs               |  |  |
| Unsigned           | Hardware Multiply         | 28                | 28     | 1.7 μs   | 2.3 μs   | 11.2 μs  | 28 μs                |  |  |
| 10 · · · 10 Oimmed | Without Hardware Multiply | 52                | 254    | 15.8 μs  | 21.2 μs  | 101.6 μs | 254 μs               |  |  |
| 16 x 16 Signed     | Hardware Multiply         | 35                | 40     | 2.5 μs   | 3.3 μs   | 16.0 μs  | <b>40</b> μ <b>s</b> |  |  |

#### TABLE 9-1: PERFORMANCE COMPARISON FOR VARIOUS MULTIPLY OPERATIONS

| R/W-0                  | R/W-0                                                                                                                                                                             | R/W-0                                                     | R/W-0         | R/W-0                 | R/W-0           | R/W-0           | R/W-0  |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|---------------|-----------------------|-----------------|-----------------|--------|
| TMR7GIF <sup>(1)</sup> | TMR12IF <sup>(1)</sup>                                                                                                                                                            | TMR10IF <sup>(1)</sup>                                    | TMR8IF        | TMR7IF <sup>(1)</sup> | TMR6IF          | TMR5IF          | TMR4IF |
| bit 7                  |                                                                                                                                                                                   | · · · · ·                                                 |               |                       |                 |                 | bit C  |
| Legend:                |                                                                                                                                                                                   |                                                           |               |                       |                 |                 |        |
| R = Readable           | bit                                                                                                                                                                               | W = Writable b                                            | it            | U = Unimplem          | nented bit, rea | d as '0'        |        |
| -n = Value at F        | OR                                                                                                                                                                                | '1' = Bit is set                                          |               | '0' = Bit is clea     | ared            | x = Bit is unkr | nown   |
| bit 7                  | TMR7GIF: TM                                                                                                                                                                       | /IR7 Gate Interro                                         | upt Flag bits | 1)                    |                 |                 |        |
|                        |                                                                                                                                                                                   | e interrupt occur<br>gate interrupt oc                    |               | e cleared in soft     | ware)           |                 |        |
| bit 6                  | 1 = TMR12 to                                                                                                                                                                      | IR12 to PR12 M<br>PR12 match o<br>I2 to PR12 matc         | ccurred (mu   | -                     | software)       |                 |        |
| bit 5                  | 1 = TMR10 to                                                                                                                                                                      | IR10 to PR10 M<br>o PR10 match o<br>I0 to PR10 matc       | ccurred (mu   |                       | software)       |                 |        |
| bit 4                  | 1 = TMR8 to                                                                                                                                                                       | R8 to PR8 Match<br>PR8 match occ<br>3 to PR8 match        | urred (must l | •                     | ftware)         |                 |        |
| bit 3                  | 1 = TMR7 reg                                                                                                                                                                      | R7 Overflow Inte<br>gister overflowe<br>gister did not ov | d (must be c  |                       | ire)            |                 |        |
| bit 2                  | <ul> <li>TMR6IF: TMR6 to PR6 Match Interrupt Flag bit</li> <li>1 = TMR6 to PR6 match occurred (must be cleared in software)</li> <li>0 = No TMR6 to PR6 match occurred</li> </ul> |                                                           |               |                       |                 |                 |        |
| bit 1                  | <ul> <li>TMR5IF: TMR5 Overflow Interrupt Flag bit</li> <li>1 = TMR5 register overflowed (must be cleared in software)</li> <li>0 = TMR5 register did not overflow</li> </ul>      |                                                           |               |                       |                 |                 |        |
| bit 0                  | <b>TMR4IF:</b> TMR4 to PR4 Match Interrupt Flag bit<br>1 = TMR4 to PR4 match occurred (must be cleared in software)<br>0 = No TMR4 to PR4 match occurred                          |                                                           |               |                       |                 |                 |        |

#### REGISTER 10-8: PIR5: PERIPHERAL INTERRUPT FLAG REGISTER 5

Note 1: Unimplemented in devices with a program memory of 32 Kbytes (PIC18FX5K90).

| Name    | Bit 7           | Bit 6     | Bit 5   | Bit 4   | Bit 3   | Bit 2  | Bit 1  | Bit 0  | Reset<br>Values on<br>Page: |
|---------|-----------------|-----------|---------|---------|---------|--------|--------|--------|-----------------------------|
| PORTB   | RB7             | RB6       | RB5     | RB4     | RB3     | RB2    | RB1    | RB0    | 78                          |
| LATB    | LATB7           | LATB6     | LATB5   | LATB4   | LATB3   | LATB2  | LATB1  | LATB0  | 78                          |
| TRISB   | TRISB7          | TRISB6    | TRISB5  | TRISB4  | TRISB3  | TRISB2 | TRISB1 | TRISB0 | 78                          |
| INTCON  | <b>GIE/GIEH</b> | PEIE/GIEL | TMR0IE  | INT0IE  | RBIE    | TMR0IF | INT0IF | RBIF   | 75                          |
| INTCON2 | RBPU            | INTEDG0   | INTEDG1 | INTEDG2 | INTEDG3 | TMR0IP | INT3IP | RBIP   | 75                          |
| INTCON3 | INT2IP          | INT1IP    | INT3IE  | INT2IE  | INT1IE  | INT3IF | INT2IF | INT1IF | 75                          |
| LCDSE1  | SE15            | SE14      | SE13    | SE12    | SE11    | SE10   | SE09   | SE08   | 83                          |
| LCDSE3  | SE31            | SE30      | SE29    | SE28    | SE27    | SE26   | SE25   | SE24   | 83                          |

#### TABLE 11-4: SUMMARY OF REGISTERS ASSOCIATED WITH PORTB

Legend: Shaded cells are not used by PORTB.

### 13.2 Timer1 Operation

The Timer1 module is an 8 or 16-bit incrementing counter that is accessed through the TMR1H:TMR1L register pair.

When used with an internal clock source, the module is a timer and increments on every instruction cycle. When used with an external clock source, the module can be used as either a timer or counter. It increments on every selected edge of the external source.

Timer1 is enabled by configuring the TMR1ON and TMR1GE bits in the T1CON and T1GCON registers, respectively.

When SOSC is selected as a Crystal mode (by SOSCEL), the RC1/SOSCI/ECCP2/P2A/SEG32 and RC0/SOSCO/SCLKI pins become inputs. This means the values of TRISC<1:0> are ignored and the pins are read as '0'.

### 13.3 Clock Source Selection

The TMR1CS<1:0> and SOSCEN bits of the T1CON register are used to select the clock source for Timer1. Register 13-1 displays the clock source selections.

#### 13.3.1 INTERNAL CLOCK SOURCE

When the internal clock source is selected, the TMR1H:TMR1L register pair will increment on multiples of Fosc, as determined by the Timer1 prescaler.

### 13.3.2 EXTERNAL CLOCK SOURCE

When the external clock source is selected, the Timer1 module may work as a timer or a counter.

When enabled to count, Timer1 is incremented on the rising edge of the external clock input, T1CKI. Either of these external clock sources can be synchronized to the microcontroller system clock or they can run asynchronously.

When used as a timer with a clock oscillator, an external, 32.768 kHz crystal can be used in conjunction with the dedicated internal oscillator circuit.

**Note:** In Counter mode, a falling edge must be registered by the counter prior to the first incrementing rising edge after any one or more of the following conditions:

• Timer1 is enabled after a POR Reset

- Write to TMR1H or TMR1L
- Timer1 is disabled
- Timer1 is disabled (TMR1ON = 0)

When T1CKI is high, Timer1 is enabled (TMR1ON = 1) when T1CKI is low.

| TABLE 13-1: TIMER | 1 CLOCK SOURCE SELECTION |
|-------------------|--------------------------|
|-------------------|--------------------------|

| TMR1CS1 | TMR1CS0 | SOSCEN | Clock Source                           |
|---------|---------|--------|----------------------------------------|
| 0       | 1       | x      | Clock Source (Fosc)                    |
| 0       | 0       | x      | Instruction Clock (Fosc/4)             |
| 1       | 0       | 0      | External Clock on T1CKI Pin            |
| 1       | 0       | 1      | Oscillator Circuit on SOSCI/SOSCO Pins |

#### R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 TMRxCS1 TMRxCS0 TxCKPS1 TxCKPS0 SOSCEN TxSYNC **RD16 TMRxON** bit 7 bit 0 Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 7-6 TMRxCS<1:0>: Timerx Clock Source Select bits 10 = The Timer1 clock source is either a pin or an oscillator depending on the SOSCEN bit. SOSCEN = 0: External clock is from the T1CKI pin (on the rising edge). SOSCEN = 1: Crystal oscillator is on the SOSCI/SOSCO pins. 01 = Timerx clock source is the system clock (Fosc)<sup>(1)</sup> 00 = Timerx clock source is the instruction clock (Fosc/4) bit 5-4 TxCKPS<1:0>: Timerx Input Clock Prescale Select bits 11 = 1:8 Prescale value 10 = 1:4 Prescale value 01 = 1:2 Prescale value 00 = 1:1 Prescale value SOSCEN: SOSC Oscillator Enable bit bit 3 1 = SOSC is enabled for Timerx (based on SOSCSEL fuses) 0 = SOSC is disabled for Timerx bit 2 TxSYNC: Timerx External Clock Input Synchronization Control bit (Not usable if the device clock comes from Timer1/Timer3.) When TMRxCS<1:0> = 10: 1 = Do not synchronize external clock input 0 = Synchronize external clock input When TMRxCS<1:0> = 0x: This bit is ignored; Timer3 uses the internal clock. bit 1 RD16: 16-Bit Read/Write Mode Enable bit 1 = Enables register read/write of Timerx in one 16-bit operation 0 = Enables register read/write of Timerx in two 8-bit operations bit 0 TMRxON: Timerx On bit 1 =Enables Timerx 0 = Stops Timerx

#### REGISTER 15-1: TxCON: TIMER3/5/7 CONTROL REGISTER

**Note 1:** The Fosc clock source should not be selected if the timer will be used with the ECCP capture/compare features.

#### TABLE 18-5: REGISTERS ASSOCIATED WITH CAPTURE, COMPARE, TIMER1/3/5/7 (CONTINUED)

| Name                    | Bit 7   | Bit 6   | Bit 5  | Bit 4    | Bit 3   | Bit 2   | Bit 1   | Bit 0   | Reset<br>Values<br>on Page: |
|-------------------------|---------|---------|--------|----------|---------|---------|---------|---------|-----------------------------|
| CCP6CON                 |         | _       | DC6B1  | DC6B0    | CCP6M3  | CCP6M2  | CCP6M1  | CCP6M0  | 82                          |
| CCP7CON                 | _       | _       | DC7B1  | DC7B0    | CCP7M3  | CCP7M2  | CCP7M1  | CCP7M0  | 82                          |
| CCP8CON                 | _       | —       | DC8B1  | DC8B0    | CCP8M3  | CCP8M2  | CCP8M1  | CCP8M0  | 80                          |
| CCP9CON <sup>(1)</sup>  | _       | _       | DC9B1  | DC9B0    | CCP9M3  | CCP9M2  | CCP9M1  | CCP9M0  | 80                          |
| CCP10CON <sup>(1)</sup> | _       | _       | DC10B1 | DC10B0   | CCP10M3 | CCP10M2 | CCP10M1 | CCP10M0 | 81                          |
| CCPTMRS1                | C7TSEL1 | C7TSEL0 | _      | C6TSEL0  | —       | C5TSEL0 | C4TSEL1 | C4TSEL0 | 81                          |
| CCPTMRS2                | _       | —       | _      | C10TSEL0 | —       | C9TSEL0 | C8TSEL1 | C8TSEL0 | 81                          |

**Legend:** — = unimplemented, read as '0'. Shaded cells are not used by Capture/Compare or Timer1/3/5/7.

Note 1: Unimplemented in devices with a program memory of 32 Kbytes (PIC18FX5K90).

**2:** Unimplemented in 64-pin devices.

#### 18.4 PWM Mode

In Pulse-Width Modulation (PWM) mode, the CCP4 pin produces up to a 10-bit resolution PWM output. Since the CCP4 pin is multiplexed with a PORTC or PORTE data latch, the appropriate TRIS bit must be cleared to make the CCP4 pin an output.

| Note: | Clearing the CCP4CON register will force the RC1 or RE7 output latch (depending |
|-------|---------------------------------------------------------------------------------|
|       | on device configuration) to the default low                                     |
|       | level. This is not the PORTC or PORTE                                           |
|       | I/O data latch.                                                                 |

Figure 18-3 shows a simplified block diagram of the ECCP1 module in PWM mode.

For a step-by-step procedure on how to set up the CCP module for PWM operation, see **Section 18.4.3** "Setup for PWM Operation".

## FIGURE 18-3:

#### SIMPLIFIED PWM BLOCK DIAGRAM





## 22.0 ENHANCED UNIVERSAL SYNCHRONOUS ASYNCHRONOUS RECEIVER TRANSMITTER (EUSART)

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

The Enhanced USART module implements additional features, including automatic baud rate detection and calibration, automatic wake-up on Sync Break reception and 12-bit Break character transmit. These make it ideally suited for use in Local Interconnect Network bus (LIN/J2602 bus) systems.

All members of the PIC18F87K90 family are equipped with two independent EUSART modules, referred to as EUSART1 and EUSART2. They can be configured in the following modes:

- Asynchronous (full duplex) with:
  - Auto-wake-up on character reception
  - Auto-baud calibration
  - 12-bit Break character transmission
- Synchronous Master (half duplex) with selectable clock polarity
- Synchronous Slave (half duplex) with selectable clock polarity

The pins of EUSART1 and EUSART2 are multiplexed with the functions of PORTC (RC6/TX1/CK1/ SEG27 and RC7/RX1/DT1/SEG28) and PORTG (RG1/TX2/CK2/AN19/C3OUT and RG2/RX2/DT2/ AN18/C3INA), respectively. In order to configure these pins as an EUSART:

- For EUSART1:
  - SPEN (RCSTA1<7>) bit must be set (= 1)
  - TRISC<7> bit must be set (= 1)
  - TRISC<6> bit must be cleared (= 0) for Asynchronous and Synchronous Master modes
  - TRISC<6> bit must be set (= 1) for Synchronous Slave mode
- For EUSART2:
  - SPEN (RCSTA2<7>) bit must be set (= 1)
  - TRISG<2> bit must be set (= 1)
  - TRISG<1> bit must be cleared (= 0) for Asynchronous and Synchronous Master modes
  - TRISC<6> bit must be set (= 1) for Synchronous Slave mode

The operation of each Enhanced USART module is controlled through three registers:

- Transmit Status and Control (TXSTAx)
- Receive Status and Control (RCSTAx)
- Baud Rate Control (BAUDCONx)

These are detailed in Register 22-1, Register 22-2 and Register 22-3, respectively, on the following pages.

Note: Throughout this section, references to register and bit names that may be associated with a specific EUSART module are referred to generically by the use of 'x' in place of the specific module number. Thus, "RCSTAx" might refer to the Receive Status register for either EUSART1 or EUSART2.

Note: The EUSART control will automatically reconfigure the pin from input to output as needed.



#### FIGURE 22-2: BRG OVERFLOW SEQUENCE



#### 22.2.4 AUTO-WAKE-UP ON SYNC BREAK CHARACTER

During Sleep mode, all clocks to the EUSART are suspended. Because of this, the Baud Rate Generator is inactive and a proper byte reception cannot be performed. The auto-wake-up feature allows the controller to wake-up due to activity on the RXx/DTx line while the EUSART is operating in Asynchronous mode.

The auto-wake-up feature is enabled by setting the WUE bit (BAUDCONx<1>). Once set, the typical receive sequence on RXx/DTx is disabled and the EUSART remains in an Idle state, monitoring for a wake-up event independent of the CPU mode. A wake-up event consists of a high-to-low transition on the RXx/DTx line. (This coincides with the start of a Sync Break or a Wake-up Signal character for the LIN/J2602 protocol.)

Following a wake-up event, the module generates an RCxIF interrupt. The interrupt is generated synchronously to the Q clocks in normal operating modes (Figure 22-8) and asynchronously if the device is in Sleep mode (Figure 22-9). The interrupt condition is cleared by reading the RCREGx register.

The WUE bit is automatically cleared once a low-to-high transition is observed on the RXx line following the wake-up event. At this point, the EUSART module is in Idle mode and returns to normal operation. This signals to the user that the Sync Break event is over.

#### 22.2.4.1 Special Considerations Using Auto-Wake-up

Since auto-wake-up functions by sensing rising edge transitions on RXx/DTx, information with any state changes before the Stop bit may signal a false End-of-Character (EOC) and cause data or framing errors. To work properly, therefore, the initial character in the transmission must be all '0's. This can be 00h (8 bits) for standard RS-232 devices or 000h (12 bits) for LIN/J2602 bus.

Oscillator start-up time must also be considered, especially in applications using oscillators with longer start-up intervals (i.e., HS or HSPLL mode). The Sync Break (or Wake-up Signal) character must be of sufficient length and be followed by a sufficient interval to allow enough time for the selected oscillator to start and provide proper initialization of the EUSART.

The module is enabled by setting the HLVDEN bit (HLVDCON<4>). Each time the HLVD module is enabled, the circuitry requires some time to stabilize. The IRVST bit (HLVDCON<5>) is a read-only bit used to indicate when the circuit is stable. The module can only generate an interrupt after the circuit is stable and IRVST is set.

The VDIRMAG bit (HLVDCON<7>) determines the overall operation of the module. When VDIRMAG is cleared, the module monitors for drops in VDD below a predetermined set point. When the bit is set, the module monitors for rises in VDD above the set point.

### 26.1 Operation

When the HLVD module is enabled, a comparator uses an internally generated reference voltage as the set point. The set point is compared with the trip point, where each node in the resistor divider represents a trip point voltage. The "trip point" voltage is the voltage level at which the device detects a high or low-voltage event, depending on the configuration of the module.

When the supply voltage is equal to the trip point, the voltage tapped off of the resistor array is equal to the internal reference voltage generated by the voltage reference module. The comparator then generates an interrupt signal by setting the HLVDIF bit.

The trip point voltage is software programmable to any of 16 values. The trip point is selected by programming the HLVDL<3:0> bits (HLVDCON<3:0>).

The HLVD module has an additional feature that allows the user to supply the trip voltage to the module from an external source. This mode is enabled when bits, HLVDL<3:0>, are set to '1111'. In this state, the comparator input is multiplexed from the external input pin, HLVDIN. This gives users the flexibility of configuring the High/Low-Voltage Detect interrupt to occur at any voltage in the valid operating range.



FIGURE 26-1: HLVD MODULE BLOCK DIAGRAM (WITH EXTERNAL INPUT)

#### EXAMPLE 27-2: CURRENT CALIBRATION ROUTINE

```
#include "pl8cxxx.h"
#define COUNT 500
                                          //@ 8MHz = 125uS.
#define DELAY for(i=0;i<COUNT;i++)</pre>
                                          //R value is 4200000 (4.2M)
#define RCAL .027
                                          //scaled so that result is in
                                          //1/100th of uA
#define ADSCALE 1023
                                          //for unsigned conversion 10 sig bits
#define ADREF 3.3
                                          //Vdd connected to A/D Vr+
int main(void)
{
    int i;
   int j = 0; //index for loop
   unsigned int Vread = 0;
    double VTot = 0;
    float Vavg=0, Vcal=0, CTMUISrc = 0; //float values stored for calcs
//{\tt assume} CTMU and A/D have been setup correctly
//see Example 25-1 for CTMU & A/D setup
setup();
CTMUCONHbits.CTMUEN = 1;
                                          //Enable the CTMU
    for(j=0;j<10;j++)</pre>
    {
        CTMUCONHbits.IDISSEN = 1;
                                          //drain charge on the circuit
        DELAY;
                                          //wait 125us
        CTMUCONHbits.IDISSEN = 0;
                                          //end drain of circuit
       CTMUCONLbits.EDG1STAT = 1;
                                         //Begin charging the circuit
                                          //using CTMU current source
       DELAY;
                                          //wait for 125us
       CTMUCONLbits.EDG1STAT = 0;
                                          //Stop charging circuit
        PIR1bits.ADIF = 0;
                                          //make sure A/D Int not set
        ADCON0bits.GO=1;
                                          //and begin A/D conv.
        while(!PIR1bits.ADIF);
                                          //Wait for A/D convert complete
        Vread = ADRES;
                                          //Get the value from the A/D
        PIR1bits.ADIF = 0;
                                          //Clear A/D Interrupt Flag
        VTot += Vread;
                                          //Add the reading to the total
    }
   Vavg = (float)(VTot/10.000);
                                          //Average of 10 readings
    Vcal = (float)(Vavg/ADSCALE*ADREF);
    CTMUISrc = Vcal/RCAL;
                                          //CTMUISrc is in 1/100ths of uA
```

}

| U-0          | R/P-1                                                                                                                                                                                       | R/P-1             | R/P-1           | R/P-1          | R/P-1           | R/P-1    | R/P-1  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------------|----------------|-----------------|----------|--------|--|
| —            | WDTPS4                                                                                                                                                                                      | WDTPS3            | WDTPS2          | WDTPS1         | WDTPS0          | WDTEN1   | WDTEN0 |  |
| bit 7        |                                                                                                                                                                                             |                   |                 |                |                 |          | bit    |  |
| Legend:      |                                                                                                                                                                                             | P = Programr      | nable bit       |                |                 |          |        |  |
| R = Readab   | ole bit                                                                                                                                                                                     | W = Writable      | bit             | U = Unimpler   | nented bit, rea | d as '0' |        |  |
| -n = Value a | Value at POR '1' = Bit is set '0' = Bit is cleared x = B                                                                                                                                    |                   | x = Bit is unkr | lit is unknown |                 |          |        |  |
| bit 7        | Unimplemen                                                                                                                                                                                  | ted: Read as '    | 0'              |                |                 |          |        |  |
| bit 6-2      | WDTPS<4:0                                                                                                                                                                                   | -: Watchdog Ti    | mer Postscale   | Select bits    |                 |          |        |  |
|              | 11111 = 1:1,048,576                                                                                                                                                                         |                   |                 |                |                 |          |        |  |
|              | 10011 <b>= 1:52</b>                                                                                                                                                                         | 10011 = 1:524,288 |                 |                |                 |          |        |  |
|              | 10010 = 1:262,144                                                                                                                                                                           |                   |                 |                |                 |          |        |  |
|              | 10001 = 1:131,072                                                                                                                                                                           |                   |                 |                |                 |          |        |  |
|              | 10000 = 1.65,536                                                                                                                                                                            |                   |                 |                |                 |          |        |  |
|              | 01111 = 1:32,768<br>01110 = 1:16,384                                                                                                                                                        |                   |                 |                |                 |          |        |  |
|              |                                                                                                                                                                                             | 01101 = 1.8,192   |                 |                |                 |          |        |  |
|              | 01100 = 1:4,                                                                                                                                                                                |                   |                 |                |                 |          |        |  |
|              | 01011 = 1:2,                                                                                                                                                                                |                   |                 |                |                 |          |        |  |
|              | 01010 = 1:1,                                                                                                                                                                                |                   |                 |                |                 |          |        |  |
|              | 01001 = 1:51                                                                                                                                                                                |                   |                 |                |                 |          |        |  |
|              | 01000 = 1:25                                                                                                                                                                                |                   |                 |                |                 |          |        |  |
|              | 00111 = 1:12<br>00110 = 1:64                                                                                                                                                                | -                 |                 |                |                 |          |        |  |
|              | 00101 = 1:32                                                                                                                                                                                |                   |                 |                |                 |          |        |  |
|              | 00100 = 1:16                                                                                                                                                                                |                   |                 |                |                 |          |        |  |
|              | 00011 = 1:8                                                                                                                                                                                 |                   |                 |                |                 |          |        |  |
|              | 00010 = 1:4                                                                                                                                                                                 |                   |                 |                |                 |          |        |  |
|              | 00001 = 1:2                                                                                                                                                                                 |                   |                 |                |                 |          |        |  |
|              | 00000 = 1:1                                                                                                                                                                                 |                   |                 |                |                 |          |        |  |
| bit 1-0      |                                                                                                                                                                                             | >: Watchdog Ti    |                 |                |                 |          |        |  |
|              |                                                                                                                                                                                             | enabled in har    |                 |                | oled            |          |        |  |
|              |                                                                                                                                                                                             | controlled by t   |                 |                |                 |          |        |  |
|              | <ul> <li>01 = WDT is enabled only while device is active and is disabled in Sleep mode; SWDTEN bit is disabled</li> <li>00 = WDT is disabled in hardware; SWDTEN bit is disabled</li> </ul> |                   |                 |                |                 |          |        |  |

## REGISTER 28-4: CONFIG2H: CONFIGURATION REGISTER 2 HIGH (BYTE ADDRESS 300003h)

### 28.2 Watchdog Timer (WDT)

For the PIC18F87K90 family of devices, the WDT is driven by the LF-INTOSC source. When the WDT is enabled, the clock source is also enabled. The nominal WDT period is 4 ms and has the same stability as the LF-INTOSC oscillator.

The 4 ms period of the WDT is multiplied by a 16-bit postscaler. Any output of the WDT postscaler is selected by a multiplexer, controlled by bits in Configuration Register 2H. Available periods range from 4 ms to 4,194 seconds (about one hour). The WDT and postscaler are cleared when any of the following events occur: a SLEEP or CLRWDT instruction is executed, the IRCF bits (OSCCON<6:4>) are changed or a clock failure has occurred.

The WDT can be operated in one of four modes as determined by the CONFIG2H bits (WDTEN<1:0>) The four modes are:

- WDT Enabled
- WDT Disabled
- WDT under Software Control (WDTCON<0>, SWDTEN)
- WDT
  - Enabled during normal operation
  - Disabled during Sleep

Note 1: The CLRWDT and SLEEP instructions clear the WDT and postscaler counts when executed.

- Changing the setting of the IRCF bits (OSCCON<6:4>) clears the WDT and postscaler counts.
- **3:** When a CLRWDT instruction is executed, the postscaler count will be cleared.

#### WDT Enabled, SWDTEN Disabled WDT Controlled with SWDTEN bit Setting WDT Enabled only While Device Active, Disabled WDT Disabled in Hardware. SWDTEN Disabled Enable WDT WDTEN1 WDTEN0-WDT Counter Wake-up from ÷128 INTRC Source-Power-Managed Modes Change on IRCF<2:0> bits -Programmable Postscaler WDT Reset CLRWDT Reset 1:1 to 1:1,048,576 All Device Resets 4 WDTPS<3:0> Sleep Enable WDT SWDTEN WDTEN<1:0> **INTRC Source**

### FIGURE 28-1: WDT BLOCK DIAGRAM

| GOTO                                                                                                                        | Unconditio                | Unconditional Branch        |                            |                                         |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------|---------------------------|-----------------------------|----------------------------|-----------------------------------------|--|--|--|
| Syntax:                                                                                                                     | GOTO k                    | GOTO k                      |                            |                                         |  |  |  |
| Operands:                                                                                                                   | $0 \le k \le 104$         | 8575                        |                            |                                         |  |  |  |
| Operation:                                                                                                                  | $k \rightarrow PC<20$     | ):1>                        |                            |                                         |  |  |  |
| Status Affected:                                                                                                            | None                      |                             |                            |                                         |  |  |  |
| Encoding:<br>1st word (k<7:0>)<br>2nd word(k<19:8>)                                                                         | 1110<br>1111              | 1111<br>k <sub>19</sub> kkk | k <sub>7</sub> kkk<br>kkkk | kkkk <sub>0</sub><br>kkkk <sub>8</sub>  |  |  |  |
| Description: GOTO allows an unco<br>anywhere within entire<br>range. The 20-bit valu<br>PC<20:1>. GOTO is a<br>instruction. |                           |                             |                            | /te memory<br>loaded into               |  |  |  |
| Words:                                                                                                                      | 2                         | 2                           |                            |                                         |  |  |  |
| Cycles:                                                                                                                     | 2                         |                             |                            |                                         |  |  |  |
| Q Cycle Activity:                                                                                                           |                           |                             |                            |                                         |  |  |  |
| Q1                                                                                                                          | Q2                        | Q3                          |                            | Q4                                      |  |  |  |
| Decode                                                                                                                      | Read literal<br>'k'<7:0>, | No<br>operat                | ion '                      | ead literal<br>k'<19:8>,<br>/rite to PC |  |  |  |
| No<br>operation                                                                                                             | No<br>operation           | No<br>operation             |                            | No<br>operation                         |  |  |  |
| Example: GOTO THERE<br>After Instruction<br>PC = Address (THERE)                                                            |                           |                             |                            |                                         |  |  |  |

| INCF                                                                                                                                                                                                                                                                                 | Increment                                             | f                                                                                                        |                               |                                                       |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-------------------------------|-------------------------------------------------------|--|--|--|
| Syntax:                                                                                                                                                                                                                                                                              | INCF f{,c                                             | l {,a}}                                                                                                  |                               |                                                       |  |  |  |
| Operands:                                                                                                                                                                                                                                                                            | $0 \leq f \leq 255$                                   |                                                                                                          |                               |                                                       |  |  |  |
|                                                                                                                                                                                                                                                                                      | d ∈ [0,1]<br>a ∈ [0,1]                                |                                                                                                          |                               |                                                       |  |  |  |
| Operation:                                                                                                                                                                                                                                                                           | (f) + 1 $\rightarrow$ dest                            |                                                                                                          |                               |                                                       |  |  |  |
| Status Affected:                                                                                                                                                                                                                                                                     | C, DC, N,                                             | C, DC, N, OV, Z                                                                                          |                               |                                                       |  |  |  |
| Encoding:                                                                                                                                                                                                                                                                            | 0010                                                  | 10da                                                                                                     | fff                           | f ffff                                                |  |  |  |
| Description:                                                                                                                                                                                                                                                                         | The conten<br>incremente<br>placed in W<br>placed bac | d. lf 'd' is<br>/. lf 'd' is                                                                             | '0', the<br>'1', the          | e result is                                           |  |  |  |
|                                                                                                                                                                                                                                                                                      | ,                                                     | If 'a' is '0', the Access Bank is selected.<br>If 'a' is '1', the BSR is used to select the<br>GPR bank. |                               |                                                       |  |  |  |
| If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operation<br>in Indexed Literal Offset Addressing<br>mode whenever f ≤ 95 (5Fh). See<br>Section 29.2.3 "Byte-Oriented and<br>Bit-Oriented Instructions in Indexe<br>Literal Offset Mode" for details. |                                                       |                                                                                                          |                               |                                                       |  |  |  |
|                                                                                                                                                                                                                                                                                      | Bit-Oriente                                           | ed Instru                                                                                                | te-Orie<br>ctions             | ented and<br>in Indexed                               |  |  |  |
| Words:                                                                                                                                                                                                                                                                               | Bit-Oriente                                           | ed Instru                                                                                                | te-Orie<br>ctions             | ented and<br>in Indexed                               |  |  |  |
|                                                                                                                                                                                                                                                                                      | Bit-Oriente                                           | ed Instru                                                                                                | te-Orie<br>ctions             | ented and<br>in Indexed                               |  |  |  |
|                                                                                                                                                                                                                                                                                      | Bit-Oriente<br>Literal Offs<br>1                      | ed Instru                                                                                                | te-Orie<br>ctions             | ented and<br>in Indexed                               |  |  |  |
| Cycles:<br>Q Cycle Activity:<br>Q1                                                                                                                                                                                                                                                   | Bit-Oriente<br>Literal Offs<br>1<br>1<br>Q2           | ed Instru<br>set Mode                                                                                    | te-Orie<br>ctions<br>?" for d | ented and<br>i in Indexed<br>letails.<br>Q4           |  |  |  |
| Cycles:<br>Q Cycle Activity:                                                                                                                                                                                                                                                         | Bit-Oriente<br>Literal Offs<br>1<br>1                 | ed Instru<br>set Mode                                                                                    | te-Orie<br>ctions<br>" for d  | ented and<br>i in Indexed<br>letails.                 |  |  |  |
| Q1                                                                                                                                                                                                                                                                                   | Bit-Oriente<br>Literal Offs<br>1<br>1<br>Q2<br>Read   | Q3<br>Proce<br>Data                                                                                      | te-Orie<br>ctions<br>" for d  | ented and<br>in Indexed<br>letails.<br>Q4<br>Write to |  |  |  |

### 29.2.2 EXTENDED INSTRUCTION SET

| ADD                 | FSR            | Add Liter        | Add Literal to FSR                    |              |          |  |  |  |
|---------------------|----------------|------------------|---------------------------------------|--------------|----------|--|--|--|
| Syntax: ADDFSR f, k |                |                  |                                       |              |          |  |  |  |
| Oper                | ands:          | $0 \le k \le 63$ | $0 \le k \le 63$                      |              |          |  |  |  |
|                     |                | f ∈ [ 0, 1,      | 2]                                    |              |          |  |  |  |
| Oper                | ation:         | FSR(f) + k       | $s \rightarrow FSR($                  | f)           |          |  |  |  |
| Statu               | s Affected:    | None             |                                       |              |          |  |  |  |
| Enco                | ding:          | 1110             | 1000                                  | 000 ffkk kkk |          |  |  |  |
| Desc                | ription:       | The 6-bit        | The 6-bit literal 'k' is added to the |              |          |  |  |  |
|                     |                | contents of      | contents of the FSR specified by 'f'. |              |          |  |  |  |
| Word                | ls:            | 1                | 1                                     |              |          |  |  |  |
| Cycle               | es:            | 1                |                                       |              |          |  |  |  |
| QC                  | ycle Activity: |                  |                                       |              |          |  |  |  |
|                     | Q1             | Q2               | Q3                                    |              | Q4       |  |  |  |
|                     | Decode         | Read             | Proces                                | ss \         | Write to |  |  |  |
|                     |                | literal 'k'      | Data                                  |              | FSR      |  |  |  |

Example: ADDFSR 2, 23h

| Before Instruction |   |       |  |  |  |
|--------------------|---|-------|--|--|--|
| FSR2               | = | 03FFh |  |  |  |
| After Instruction  |   |       |  |  |  |
| FSR2               | = | 0422h |  |  |  |

| ADDULNK Add Literal to FSR2 and Retur                                                                                            |                |                          |                                                                                                                          |      | Return          |  |  |
|----------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------|------|-----------------|--|--|
| Synta                                                                                                                            | ax:            | ADDULN                   | ADDULNK k                                                                                                                |      |                 |  |  |
| Oper                                                                                                                             | ands:          | $0 \le k \le 63$         | $0 \le k \le 63$                                                                                                         |      |                 |  |  |
| Oper                                                                                                                             | ation:         | FSR2 + k                 | $\rightarrow$ FSR2,                                                                                                      |      |                 |  |  |
|                                                                                                                                  |                | $(TOS) \rightarrow I$    | $(TOS) \rightarrow PC$                                                                                                   |      |                 |  |  |
| Statu                                                                                                                            | s Affected:    | None                     |                                                                                                                          |      |                 |  |  |
| Enco                                                                                                                             | ding:          | 1110                     | 1000                                                                                                                     | 11kk | kkkk            |  |  |
| Description: The 6-bit literal 'k' is added to the<br>contents of FSR2. A RETURN is t<br>executed by loading the PC with<br>TOS. |                |                          |                                                                                                                          |      | IRN is then     |  |  |
|                                                                                                                                  |                | execute; a               | The instruction takes two cycles to execute; a NOP is performed during the second cycle.                                 |      |                 |  |  |
|                                                                                                                                  |                | case of the<br>where f = | This may be thought of as a special case of the ADDFSR instruction, where f = 3 (binary '11'); it operates only on FSR2. |      |                 |  |  |
| Word                                                                                                                             | ls:            | 1                        |                                                                                                                          |      |                 |  |  |
| Cycle                                                                                                                            | es:            | 2                        |                                                                                                                          |      |                 |  |  |
| QC                                                                                                                               | vcle Activity: |                          |                                                                                                                          |      |                 |  |  |
|                                                                                                                                  | Q1             | Q2                       | Q3                                                                                                                       |      | Q4              |  |  |
|                                                                                                                                  | Decode         | Read<br>literal 'k'      | Proces<br>Data                                                                                                           |      | Write to<br>FSR |  |  |
|                                                                                                                                  | No             | No                       | No                                                                                                                       |      | No              |  |  |
|                                                                                                                                  | Operation      | Operation                | Operati                                                                                                                  | on   | Operation       |  |  |
| <u>Exan</u>                                                                                                                      | nple:          | ADDULNK 2                | 23h                                                                                                                      |      |                 |  |  |

| ample:          | Al    | ADDULNK |  |
|-----------------|-------|---------|--|
| Before Instruc  | ction |         |  |
| FSR2            | =     | 03FFh   |  |
| PC              | =     | 0100h   |  |
| After Instructi | on    |         |  |
| FSR2            | =     | 0422h   |  |
| PC              | =     | (TOS)   |  |
|                 |       |         |  |

**Note:** All PIC18 instructions may take an optional label argument preceding the instruction mnemonic for use in symbolic addressing. If a label is used, the instruction format then becomes: {label} instruction argument(s).

## 31.0 ELECTRICAL CHARACTERISTICS

## Absolute Maximum Ratings<sup>(†)</sup>

| Ambient temperature under bias                                                            | -40°C to +125°C      |
|-------------------------------------------------------------------------------------------|----------------------|
| Storage temperature                                                                       |                      |
|                                                                                           |                      |
| Voltage on any digital only I/O pin with respect to Vss (except VDD)                      | 0.3V to 7.5V         |
| Voltage on MCLR with respect to Vss                                                       | 0.3V to +9.0V        |
| Voltage on any combined digital and analog pin with respect to VSS (except VDD and MCLR)0 | ).3V to (VDD + 0.3V) |
| Voltage on VDD with respect to Vss (regulator enabled)                                    | 0.3V to 5.5V         |
| Voltage on VDD with respect to Vss (regulator disabled)                                   | 0.3V to 3.6V         |
| Total power dissipation (Note 1)                                                          | 1W                   |
| Maximum current out of Vss pin                                                            | 300 mA               |
| Maximum current into Vod pin                                                              | 250 mA               |
| Input clamp current, Iıк (Vı < 0 or Vı > Vɒɒ)                                             | ±20 mA               |
| Output clamp current, Ioк (Vo < 0 or Vo > VDD)                                            | ±20 mA               |
| Maximum output current sunk by PORTA<7:6> and any PORTB and PORTC I/O pins                | 25 mA                |
| Maximum output current sunk by any PORTD, PORTE and PORTJ I/O pins                        | 8 mA                 |
| Maximum output current sunk by PORTA<5:0> and any PORTF, PORTG and PORTH I/O pins         | 2 mA                 |
| Maximum output current sourced by PORTA<7:6> and any PORTB and PORTC I/O pins             | 25 mA                |
| Maximum output current sourced by any PORTD, PORTE and PORTJ I/O pins                     | 8 mA                 |
| Maximum output current sourced by PORTA<5:0> and any PORTF, PORTG and PORTH I/O pins      | 2 mA                 |
| Maximum current sunk by all ports combined                                                | 200 mA               |
| <b>Note 1:</b> Power dissipation is calculated as follows:                                |                      |

Note 1: Power dissipation is calculated as follows: Pdis = VDD x {IDD  $-\Sigma$  IOH} +  $\Sigma$  {(VDD - VOH) x IOH} +  $\Sigma$ (VOL x IOL)

**NOTICE:** Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

t



## TABLE 31-18: I<sup>2</sup>C<sup>™</sup> BUS START/STOP BITS REQUIREMENTS (SLAVE MODE)

| Param.<br>No. | Symbol  | Characteristic  |              | Min  | Max | Units | Conditions                   |
|---------------|---------|-----------------|--------------|------|-----|-------|------------------------------|
| 90            | TSU:STA | Start Condition | 100 kHz mode | 4700 | _   | ns    | Only relevant for Repeated   |
|               |         | Setup Time      | 400 kHz mode | 600  | _   |       | Start condition              |
| 91            | THD:STA | Start Condition | 100 kHz mode | 4000 | _   | ns    | After this period, the first |
|               |         | Hold Time       | 400 kHz mode | 600  | _   |       | clock pulse is generated     |
| 92            | TSU:STO | Stop Condition  | 100 kHz mode | 4700 | —   | ns    |                              |
|               |         | Setup Time      | 400 kHz mode | 600  | _   |       |                              |
| 93            | THD:STO | Stop Condition  | 100 kHz mode | 4000 | _   | ns    |                              |
|               |         | Hold Time       | 400 kHz mode | 600  | _   |       |                              |