



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 <sup>2</sup> C, SPI, UART/USART                                          |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 21                                                                         |
| Program Memory Size        | 16KB (8K x 16)                                                             |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 1K x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 3.6V                                                                |
| Data Converters            | A/D 10x10b                                                                 |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Through Hole                                                               |
| Package / Case             | 28-DIP (0.300", 7.62mm)                                                    |
| Supplier Device Package    | 28-SPDIP                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18f24j10-i-sp |

Email: info@E-XFL.COM

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

| Din Nama             | Pi                                                    | n Numt  | ber  | Pin  | Buffer | Description                            |  |  |
|----------------------|-------------------------------------------------------|---------|------|------|--------|----------------------------------------|--|--|
| Fin Name             | PDIP                                                  | QFN     | TQFP | Туре | Туре   | Description                            |  |  |
|                      |                                                       |         |      |      |        | PORTA is a bidirectional I/O port.     |  |  |
| RA0/AN0              | 2                                                     | 19      | 19   |      |        |                                        |  |  |
| RA0                  |                                                       |         |      | I/O  | TTL    | Digital I/O.                           |  |  |
| AN0                  |                                                       |         |      | I    | Analog | Analog Input 0.                        |  |  |
| RA1/AN1              | 3                                                     | 20      | 20   |      |        |                                        |  |  |
| RA1                  |                                                       |         |      | I/O  | TTL    | Digital I/O.                           |  |  |
| AN1                  |                                                       |         |      | I    | Analog | Analog Input 1.                        |  |  |
| RA2/AN2/VREF-/CVREF  | 4                                                     | 21      | 21   |      |        |                                        |  |  |
| RA2                  |                                                       |         |      | I/O  | TTL    | Digital I/O.                           |  |  |
| AN2                  |                                                       |         |      | I    | Analog | Analog Input 2.                        |  |  |
| VREF-                |                                                       |         |      |      | Analog | A/D reference voltage (low) input.     |  |  |
| CVREF                |                                                       |         |      | 0    | Analog | Comparator reference voltage output.   |  |  |
| RA3/AN3/VREF+        | 5                                                     | 22      | 22   |      |        |                                        |  |  |
| RA3                  |                                                       |         |      | I/O  | TTL    | Digital I/O.                           |  |  |
| AN3                  |                                                       |         |      | I    | Analog | Analog Input 3.                        |  |  |
| VREF+                |                                                       |         |      | I    | Analog | A/D reference voltage (high) input.    |  |  |
| RA5/AN4/SS1/C2OUT    | 7                                                     | 24      | 24   |      |        |                                        |  |  |
| RA5                  |                                                       |         |      | I/O  | TTL    | Digital I/O.                           |  |  |
| AN4                  |                                                       |         |      | I    | Analog | Analog Input 4.                        |  |  |
| SS1                  |                                                       |         |      |      | TTL    | SPI slave select input.                |  |  |
| C2001                |                                                       |         |      | 0    | —      | Comparator 2 output.                   |  |  |
| Legend: TTL = TTL co | mpatibl                                               | e input |      |      | C      | CMOS = CMOS compatible input or output |  |  |
| ST = Schmit          | ST = Schmitt Trigger input with CMOS levels I = Input |         |      |      |        |                                        |  |  |
| O = Output           |                                                       |         |      |      | P      | ' = Power                              |  |  |

## TABLE 1-3: PIC18F44J10/45J10 PINOUT I/O DESCRIPTIONS (CONTINUED)

**Note 1:** Default assignment for CCP2 when Configuration bit, CCP2MX, is set.

2: Alternate assignment for CCP2 when Configuration bit, CCP2MX, is cleared.

| Dia Mara             | Pi        | n Numb   | ber     | Pin    | Buffer | Description                                   |  |  |  |  |  |  |  |
|----------------------|-----------|----------|---------|--------|--------|-----------------------------------------------|--|--|--|--|--|--|--|
| Pin Name             | PDIP      | QFN      | TQFP    | Туре   | Туре   | Description                                   |  |  |  |  |  |  |  |
|                      |           |          |         |        |        | PORTC is a bidirectional I/O port.            |  |  |  |  |  |  |  |
| RC0/T1OSO/T1CKI      | 15        | 34       | 32      |        |        |                                               |  |  |  |  |  |  |  |
| RC0                  |           |          |         | I/O    | ST     | Digital I/O.                                  |  |  |  |  |  |  |  |
| T1OSO                |           |          |         | 0      |        | Timer1 oscillator output.                     |  |  |  |  |  |  |  |
| T1CKI                |           |          |         | I      | ST     | Timer1 external clock input.                  |  |  |  |  |  |  |  |
| RC1/T1OSI/CCP2       | 16        | 35       | 35      |        |        |                                               |  |  |  |  |  |  |  |
| RC1                  |           |          |         | I/O    | ST     | Digital I/O.                                  |  |  |  |  |  |  |  |
| T10SI                |           |          |         | I      | CMOS   | Timer1 oscillator input.                      |  |  |  |  |  |  |  |
| CCP2 <sup>(2)</sup>  |           |          |         | I/O    | ST     | Capture 2 input/Compare 2 output/PWM2 output. |  |  |  |  |  |  |  |
| RC2/CCP1/P1A         | 17        | 36       | 36      |        |        |                                               |  |  |  |  |  |  |  |
| RC2                  |           |          |         | I/O    | ST     | Digital I/O.                                  |  |  |  |  |  |  |  |
| CCP1                 |           |          |         | 1/0    | SI     | Capture 1 input/Compare 1 output/PWM1 output. |  |  |  |  |  |  |  |
| PIA                  |           |          |         | 0      |        |                                               |  |  |  |  |  |  |  |
| RC3/SCK1/SCL1        | 18        | 37       | 37      |        | oT     |                                               |  |  |  |  |  |  |  |
| RC3                  |           |          |         | 1/0    | SI     | Digital I/O.                                  |  |  |  |  |  |  |  |
| SUKI                 |           |          |         | 1/0    | 51     | Synchronous serial clock input/output for     |  |  |  |  |  |  |  |
| SCI 1                |           |          |         | 1/0    | ST     | Synchronous serial clock input/output for     |  |  |  |  |  |  |  |
| OOLI                 |           |          |         | "0     | 01     | $I^2C^{TM}$ mode.                             |  |  |  |  |  |  |  |
| RC4/SDI1/SDA1        | 23        | 42       | 42      |        |        |                                               |  |  |  |  |  |  |  |
| RC4                  | 20        | 12       |         | I/O    | ST     | Digital I/O.                                  |  |  |  |  |  |  |  |
| SDI1                 |           |          |         |        | ST     | SPI data in.                                  |  |  |  |  |  |  |  |
| SDA1                 |           |          |         | I/O    | ST     | I <sup>2</sup> C data I/O.                    |  |  |  |  |  |  |  |
| RC5/SDO1             | 24        | 43       | 43      |        |        |                                               |  |  |  |  |  |  |  |
| RC5                  |           | _        | _       | I/O    | ST     | Digital I/O.                                  |  |  |  |  |  |  |  |
| SDO1                 |           |          |         | 0      |        | SPI data out.                                 |  |  |  |  |  |  |  |
| RC6/TX/CK            | 25        | 44       | 44      |        |        |                                               |  |  |  |  |  |  |  |
| RC6                  |           |          |         | I/O    | ST     | Digital I/O.                                  |  |  |  |  |  |  |  |
| TX                   |           |          |         | 0      |        | EUSART asynchronous transmit.                 |  |  |  |  |  |  |  |
| СК                   |           |          |         | I/O    | ST     | EUSART synchronous clock (see related RX/DT). |  |  |  |  |  |  |  |
| RC7/RX/DT            | 26        | 1        | 1       |        |        |                                               |  |  |  |  |  |  |  |
| RC7                  |           |          |         | I/O    | ST     | Digital I/O.                                  |  |  |  |  |  |  |  |
| RX                   |           |          |         | I      | ST     | EUSART asynchronous receive.                  |  |  |  |  |  |  |  |
| DT                   |           |          |         | I/O    | ST     | EUSART synchronous data (see related TX/CK).  |  |  |  |  |  |  |  |
| Legend: TTL = TTL co | ompatibl  | e input  |         |        | C      | CMOS = CMOS compatible input or output        |  |  |  |  |  |  |  |
| ST = Schmi           | tt Trigge | er input | with CM | OS lev | els l  | = Input                                       |  |  |  |  |  |  |  |
| O = Output           | t         |          |         |        | F      | O = Output P = Power                          |  |  |  |  |  |  |  |

### TABLE 1-3: PIC18F44J10/45J10 PINOUT I/O DESCRIPTIONS (CONTINUED)

Note 1: Default assignment for CCP2 when Configuration bit, CCP2MX, is set.

2: Alternate assignment for CCP2 when Configuration bit, CCP2MX, is cleared.

## 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-1) 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 11. 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.

| R/W-1        | R/W-1               | R/W-1                             | R/W-1             | U-0               | R/W-1            | U-0              | R/W-1            |
|--------------|---------------------|-----------------------------------|-------------------|-------------------|------------------|------------------|------------------|
| RBPU         | INTEDG0             | INTEDG1                           | INTEDG2           | _                 | TMR0IP           |                  | RBIP             |
| bit 7        |                     |                                   |                   |                   |                  |                  | bit 0            |
|              |                     |                                   |                   |                   |                  |                  |                  |
| Legend:      |                     |                                   |                   |                   |                  |                  |                  |
| R = Readab   | le bit              | W = Writable                      | bit               | U = Unimplen      | nented bit, read | d as '0'         |                  |
| -n = Value a | t POR               | '1' = Bit is set                  |                   | '0' = Bit is clea | ared             | x = Bit is unkr  | nown             |
| hit 7        |                     | P Pullun Engl                     | ala hit           |                   |                  |                  |                  |
|              |                     | B Full-up Enai<br>R pull-ups are  | disabled          |                   |                  |                  |                  |
|              | 0 = PORTB p         | oull-ups are ena                  | abled by individ  | dual port latch v | values           |                  |                  |
| bit 6        | INTEDG0: Ex         | ternal Interrupt                  | 0 Edge Select     | t bit             |                  |                  |                  |
|              | 1 = Interrupt       | on rising edge                    | -                 |                   |                  |                  |                  |
|              | 0 = Interrupt       | on falling edge                   |                   |                   |                  |                  |                  |
| bit 5        | INTEDG1: Ex         | ternal Interrupt                  | : 1 Edge Select   | t bit             |                  |                  |                  |
|              | 1 = Interrupt       | on rising edge                    |                   |                   |                  |                  |                  |
|              |                     | on failing eage                   |                   |                   |                  |                  |                  |
| bit 4        |                     | ternal Interrupt                  | 2 Edge Select     | t bit             |                  |                  |                  |
|              | 1 = Interrupt       | on fising edge<br>on falling edge |                   |                   |                  |                  |                  |
| bit 3        | Unimplemen          | ted: Read as '                    | 0'                |                   |                  |                  |                  |
| bit 2        | TMROIP: TMF         | R0 Overflow Int                   | errupt Priority   | bit               |                  |                  |                  |
|              | 1 = High prio       | rity                              |                   |                   |                  |                  |                  |
|              | 0 = Low prior       | ity                               |                   |                   |                  |                  |                  |
| bit 1        | Unimplement         | ted: Read as '                    | כ'                |                   |                  |                  |                  |
| bit 0        | RBIP: RB Por        | rt Change Inter                   | rupt Priority bit | :                 |                  |                  |                  |
|              | 1 = High prior      | rity                              |                   |                   |                  |                  |                  |
|              | 0 = Low prior       | ity                               |                   |                   |                  |                  |                  |
| Note: In     | nterrupt flag bits  | are set when                      | an interrupt co   | ndition occurs    | regardless of t  | the state of its | corresponding    |
| е            | nable bit or the c  | global interrupt                  | enable bit. Use   | er software sho   | uld ensure the   | appropriate int  | errupt flag bits |
| а            | re clear prior to e | enabling an inte                  | errupt. This fea  | ature allows for  | software pollin  | g.               |                  |

#### **INTCON2: INTERRUPT CONTROL REGISTER 2 REGISTER 9-2:**

| 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                  | 47                         |
| RCON     | IPEN                                     | —                   | CM                  | RI                  | TO                  | PD                  | POR                   | BOR                   | 46                         |
| PIR1     | PSPIF <sup>(1)</sup>                     | ADIF                | RCIF                | TXIF                | SSP1IF              | CCP1IF              | TMR2IF                | TMR1IF                | 49                         |
| PIE1     | PSPIE <sup>(1)</sup>                     | ADIE                | RCIE                | TXIE                | SSP1IE              | CCP1IE              | TMR2IE                | TMR1IE                | 49                         |
| IPR1     | PSPIP <sup>(1)</sup>                     | ADIP                | RCIP                | TXIP                | SSP1IP              | CCP1IP              | TMR2IP                | TMR1IP                | 49                         |
| TRISB    | PORTB Da                                 | ata Direction       | Control Regi        | ster                |                     |                     |                       |                       | 50                         |
| TRISC    | PORTC Data Direction Control Register    |                     |                     |                     |                     |                     |                       |                       | 50                         |
| TMR2     | Timer2 Register                          |                     |                     |                     |                     |                     |                       |                       | 48                         |
| PR2      | Timer2 Period Register                   |                     |                     |                     |                     |                     |                       |                       | 48                         |
| T2CON    | —                                        | T2OUTPS3            | T2OUTPS2            | T2OUTPS1            | T2OUTPS0            | TMR2ON              | T2CKPS1               | T2CKPS0               | 48                         |
| CCPR1L   | Capture/Co                               | ompare/PWN          | I Register 1        | Low Byte            |                     |                     |                       |                       | 49                         |
| CCPR1H   | Capture/Co                               | ompare/PWN          | 1 Register 1        | High Byte           |                     |                     |                       |                       | 49                         |
| CCP1CON  | P1M1 <sup>(1)</sup>                      | P1M0 <sup>(1)</sup> | DC1B1               | DC1B0               | CCP1M3              | CCP1M2              | CCP1M1                | CCP1M0                | 49                         |
| CCPR2L   | Capture/Co                               | ompare/PWN          | I Register 2        | Low Byte            |                     |                     |                       |                       | 49                         |
| CCPR2H   | Capture/Compare/PWM Register 2 High Byte |                     |                     |                     |                     |                     |                       | 49                    |                            |
| CCP2CON  | —                                        | —                   | DC2B1               | DC2B0               | CCP2M3              | CCP2M2              | CCP2M1                | CCP2M0                | 49                         |
| ECCP1AS  | ECCPASE                                  | ECCPAS2             | ECCPAS1             | ECCPAS0             | PSSAC1              | PSSAC0              | PSSBD1 <sup>(1)</sup> | PSSBD0 <sup>(1)</sup> | 49                         |
| ECCP1DEL | PRSEN                                    | PDC6 <sup>(1)</sup> | PDC5 <sup>(1)</sup> | PDC4 <sup>(1)</sup> | PDC3 <sup>(1)</sup> | PDC2 <sup>(1)</sup> | PDC1 <sup>(1)</sup>   | PDC0 <sup>(1)</sup>   | 49                         |

### TABLE 14-5: REGISTERS ASSOCIATED WITH PWM AND TIMER2

Legend: — = unimplemented, read as '0'. Shaded cells are not used by PWM or Timer2.

Note 1: These bits are not implemented on 28-pin devices and should be read as '0'.

#### 15.4.6 PROGRAMMABLE DEAD-BAND DELAY

| Note: | Programmable | de  | ad-band | delay   | is | not  |
|-------|--------------|-----|---------|---------|----|------|
|       | implemented  | in  | 28-pin  | devices | ;  | with |
|       | standard CCP | mod | dules.  |         |    |      |

In half-bridge applications, where all power switches are modulated at the PWM frequency at all times, the power switches normally require more time to turn off than to turn on. If both the upper and lower power switches are switched at the same time (one turned on and the other turned off), both switches may be on for a short period of time until one switch completely turns off. During this brief interval, a very high current (*shootthrough current*) may flow through both power switches, shorting the bridge supply. To avoid this potentially destructive shoot-through current from flowing during switching, turning on either of the power switches is normally delayed to allow the other switch to completely turn off.

In the Half-Bridge Output mode, a digitally programmable dead-band delay is available to avoid shoot-through current from destroying the bridge power switches. The delay occurs at the signal transition from the nonactive state to the active state. See Figure 15-4 for an illustration. Bits PDC<6:0> of the ECCP1DEL register (Register 15-2) set the delay period in terms of microcontroller instruction cycles (TcY or 4 Tosc). These bits are not available in 28-pin devices as the standard CCP module does not support half-bridge operation.

#### 15.4.7 ENHANCED PWM AUTO-SHUTDOWN

When the ECCP1 is programmed for any of the Enhanced PWM modes, the active output pins may be configured for auto-shutdown. Auto-shutdown immediately places the Enhanced PWM output pins into a defined shutdown state when a shutdown event occurs.

A shutdown event can be caused by either of the comparator modules, a low level on the Fault input pin (FLT0) or any combination of these three sources. The comparators may be used to monitor a voltage input proportional to a current being monitored in the bridge circuit. If the voltage exceeds a threshold, the comparator switches state and triggers a shutdown. Alternatively, a low digital signal on FLT0 can also trigger a shutdown. The auto-shutdown feature can be disabled by not selecting any auto-shutdown sources. The auto-shutdown sources to be used are selected using the ECCPAS<2:0> bits (bits<6:4> of the ECCP1AS register).

When a shutdown occurs, the output pins are asynchronously placed in their shutdown states, specified by the PSSAC<1:0> and PSSBD<1:0> bits (ECCPAS<3:0>). Each pin pair (P1A/P1C and P1B/P1D) may be set to drive high, drive low or be tri-stated (not driving). The ECCPASE bit (ECCP1AS<7>) is also set to hold the Enhanced PWM outputs in their shutdown states.

The ECCPASE bit is set by hardware when a shutdown event occurs. If automatic restarts are not enabled, the ECCPASE bit is cleared by firmware when the cause of the shutdown clears. If automatic restarts are enabled, the ECCPASE bit is automatically cleared when the cause of the auto-shutdown has cleared.

If the ECCPASE bit is set when a PWM period begins, the PWM outputs remain in their shutdown state for that entire PWM period. When the ECCPASE bit is cleared, the PWM outputs will return to normal operation at the beginning of the next PWM period.

**Note:** Writing to the ECCPASE bit is disabled while a shutdown condition is active.

| R/W-0                                                                                                                              | R/W-0                              | R/W-0               | R/W-0                   | R/W-0               | R/W-0               | R/W-0               | R/W-0               |
|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|---------------------|-------------------------|---------------------|---------------------|---------------------|---------------------|
| PRSEN                                                                                                                              | PDC6 <sup>(1)</sup>                | PDC5 <sup>(1)</sup> | PDC4 <sup>(1)</sup>     | PDC3 <sup>(1)</sup> | PDC2 <sup>(1)</sup> | PDC1 <sup>(1)</sup> | PDC0 <sup>(1)</sup> |
| bit 7                                                                                                                              |                                    |                     |                         |                     |                     |                     | bit 0               |
|                                                                                                                                    |                                    |                     |                         |                     |                     |                     |                     |
| Legend:                                                                                                                            |                                    |                     |                         |                     |                     |                     |                     |
| R = Readable bit W = Writable bit                                                                                                  |                                    |                     |                         | U = Unimplem        | nented bit, read    | as '0'              |                     |
| -n = Value at                                                                                                                      | -n = Value at POR '1' = Bit is set |                     |                         | '0' = Bit is clea   | x = Bit is unkn     | iown                |                     |
|                                                                                                                                    |                                    |                     |                         |                     |                     |                     |                     |
| bit 7                                                                                                                              | PRSEN: PWN                         | A Restart Enab      | le bit                  |                     |                     |                     |                     |
|                                                                                                                                    | 1 = Upon aut<br>the PWM            | o-shutdown, the     | e ECCPASE b<br>atically | it clears automa    | tically once the    | e shutdown eve      | ent goes away;      |
|                                                                                                                                    | 0 = Upon aut                       | o-shutdown, E       | CCPASE must             | be cleared in s     | oftware to resta    | art the PWM         |                     |
| bit 6-0                                                                                                                            | PDC<6:0>: P                        | WM Delay Cou        | nt bits <sup>(1)</sup>  |                     |                     |                     |                     |
| Delay time, in number of Fosc/4 (4 * Tosc) cycles, between the scheduled and actual time for a PWM signal to transition to active. |                                    |                     |                         |                     |                     |                     |                     |
|                                                                                                                                    |                                    |                     |                         |                     |                     |                     |                     |

## REGISTER 15-2: ECCP1DEL: PWM DEAD-BAND DELAY REGISTER

Note 1: Reserved on 28-pin devices; maintain these bits clear.

#### 16.3.6 SLAVE MODE

In Slave mode, the data is transmitted and received as the external clock pulses appear on SCKx. When the last bit is latched, the SSPxIF interrupt flag bit is set.

Before enabling the module in SPI Slave mode, the clock line must match the proper Idle state. The clock line can be observed by reading the SCKx pin. The Idle state is determined by the CKP bit (SSPxCON1<4>).

While in Slave mode, the external clock is supplied by the external clock source on the SCKx pin. This external clock must meet the minimum high and low times as specified in the electrical specifications.

While in Sleep mode, the slave can transmit/receive data. When a byte is received, the device will wake-up from Sleep.

#### 16.3.7 SLAVE SELECT SYNCHRONIZATION

The  $\overline{SSx}$  pin allows a Synchronous Slave mode. The SPI must be in Slave mode with  $\overline{SSx}$  pin control enabled (SSPxCON1<3:0> = 04h). When the  $\overline{SSx}$  pin is low, transmission and reception are enabled and the

SDOx pin is driven. When the SSx pin goes high, the SDOx pin is no longer driven, even if in the middle of a transmitted byte and becomes a floating output. External pull-up/pull-down resistors may be desirable depending on the application.

- Note 1: When the SPI is in Slave mode with SSx pin control enabled (SSPxCON1<3:0> = 0100), the SPI module will reset if the SSx pin is set to VDD.
  - 2: If the SPI is used in Slave mode with CKE set, then the SSx pin control must be enabled.

When the SPI module resets, the bit counter is forced to '0'. This can be done by either forcing the SSx pin to a high level or clearing the SSPEN bit.

To emulate two-wire communication, the SDOx pin can be connected to the SDIx pin. When the SPI needs to operate as a receiver, the SDOx pin can be configured as an input. This disables transmissions from the SDOx. The SDIx can always be left as an input (SDIx function) since it cannot create a bus conflict.

#### FIGURE 16-4: SLAVE SYNCHRONIZATION WAVEFORM





## FIGURE 17-5: ASYNCHRONOUS TRANSMISSION (BACK TO BACK)



#### TABLE 17-5: REGISTERS ASSOCIATED WITH ASYNCHRONOUS TRANSMISSION

| 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   | 47                         |
| PIR1    | PSPIF <sup>(1)</sup>                               | ADIF        | RCIF        | TXIF        | SSP1IF | CCP1IF | TMR2IF | TMR1IF | 49                         |
| PIE1    | PSPIE <sup>(1)</sup>                               | ADIE        | RCIE        | TXIE        | SSP1IE | CCP1IE | TMR2IE | TMR1IE | 49                         |
| IPR1    | PSPIP <sup>(1)</sup>                               | ADIP        | RCIP        | TXIP        | SSP1IP | CCP1IP | TMR2IP | TMR1IP | 49                         |
| RCSTA   | SPEN                                               | RX9         | SREN        | CREN        | ADDEN  | FERR   | OERR   | RX9D   | 49                         |
| TXREG   | EUSART T                                           | ransmit Reg | jister      |             |        |        |        |        | 49                         |
| TXSTA   | CSRC                                               | TX9         | TXEN        | SYNC        | SENDB  | BRGH   | TRMT   | TX9D   | 49                         |
| BAUDCON | ABDOVF                                             | RCIDL       | _           | SCKP        | BRG16  | —      | WUE    | ABDEN  | 49                         |
| SPBRGH  | BRGH EUSART Baud Rate Generator Register High Byte |             |             |             |        |        |        |        |                            |
| SPBRG   | EUSART E                                           | Baud Rate G | enerator Re | egister Low | Byte   |        |        |        | 49                         |

Legend: — = unimplemented locations read as '0'. Shaded cells are not used for asynchronous transmission.

Note 1: These bits are not implemented on 28-pin devices and should be read as '0'.

| R/W-0         | U-0                                                                                                                                 | R/W-0                                                                                      | R/W-0                                          | R/W-0                                                          | R/W-0            | R/W-0           | R/W-0 |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|------------------------------------------------|----------------------------------------------------------------|------------------|-----------------|-------|
| ADFM          | —                                                                                                                                   | ACQT2                                                                                      | ACQT1                                          | ACQT0                                                          | ADCS2            | ADCS1           | ADCS0 |
| bit 7         |                                                                                                                                     |                                                                                            |                                                |                                                                |                  | -               | bit 0 |
|               |                                                                                                                                     |                                                                                            |                                                |                                                                |                  |                 |       |
| Legend:       |                                                                                                                                     |                                                                                            |                                                |                                                                |                  |                 |       |
| R = Readable  | e bit                                                                                                                               | W = Writable                                                                               | bit                                            | U = Unimplen                                                   | nented bit, read | d as '0'        |       |
| -n = Value at | POR                                                                                                                                 | '1' = Bit is set                                                                           |                                                | '0' = Bit is clea                                              | ared             | x = Bit is unkr | nown  |
| bit 7         | <b>ADFM:</b> A/D<br>1 = Right jus<br>0 = Left justi                                                                                 | Result Format S<br>stified<br>fied                                                         | elect bit                                      |                                                                |                  |                 |       |
| bit 6         | Unimpleme                                                                                                                           | nted: Read as '                                                                            | o'                                             |                                                                |                  |                 |       |
| bit 5-3       | ACQT<2:0>                                                                                                                           | : A/D Acquisition                                                                          | n Time Select                                  | bits                                                           |                  |                 |       |
|               | 111 = 20 TAI<br>110 = 16 TAI<br>101 = 12 TAI<br>100 = 8 TAD<br>011 = 6 TAD<br>010 = 4 TAD<br>001 = 2 TAD<br>000 = 0 TAD             | D<br>D<br>D<br>(1)                                                                         |                                                |                                                                |                  |                 |       |
| bit 2-0       | ADCS<2:0><br>111 = FRC (c<br>110 = Fosc/<br>101 = Fosc/<br>001 = Fosc/<br>011 = FRC (c<br>010 = Fosc/<br>001 = Fosc/<br>000 = Fosc/ | : A/D Conversio<br>clock derived fro<br>/64<br>/16<br>/4<br>clock derived fro<br>/32<br>/2 | n Clock Select<br>m A/D RC osc<br>m A/D RC osc | t bits<br>cillator) <sup>(1)</sup><br>cillator) <sup>(1)</sup> |                  |                 |       |

## REGISTER 18-3: ADCON2: A/D CONTROL REGISTER 2

**Note 1:** If the A/D FRC clock source is selected, a delay of one TcY (instruction cycle) is added before the A/D clock starts. This allows the SLEEP instruction to be executed before starting a conversion.

## **19.2** Comparator Operation

A single comparator is shown in Figure 19-2, along with the relationship between the analog input levels and the digital output. When the analog input at VIN+ is less than the analog input, VIN-, the output of the comparator is a digital low level. When the analog input at VIN+ is greater than the analog input, VIN-, the output of the comparator is a digital high level. The shaded areas of the output of the comparator in Figure 19-2 represent the uncertainty due to input offsets and response time.

## 19.3 Comparator Reference

Depending on the comparator operating mode, either an external or internal voltage reference may be used. The analog signal present at VIN- is compared to the signal at VIN+ and the digital output of the comparator is adjusted accordingly (Figure 19-2).





#### 19.3.1 EXTERNAL REFERENCE SIGNAL

When external voltage references are used, the comparator module can be configured to have the comparators operate from the same or different reference sources. However, threshold detector applications may require the same reference. The reference signal must be between Vss and VDD and can be applied to either pin of the comparator(s).

### 19.3.2 INTERNAL REFERENCE SIGNAL

The comparator module also allows the selection of an internally generated voltage reference from the comparator voltage reference module. This module is described in more detail in **Section 20.0 "Comparator Voltage Reference Module"**.

The internal reference is only available in the mode where four inputs are multiplexed to two comparators (CM<2:0> = 110). In this mode, the internal voltage reference is applied to the VIN+ pin of both comparators.

## 19.4 Comparator Response Time

Response time is the minimum time, after selecting a new reference voltage or input source, before the comparator output has a valid level. If the internal reference is changed, the maximum delay of the internal voltage reference must be considered when using the comparator outputs. Otherwise, the maximum delay of the comparators should be used (see Section 24.0 "Electrical Characteristics").

## **19.5 Comparator Outputs**

The comparator outputs are read through the CMCON register. These bits are read-only. The comparator outputs may also be directly output to the RB5 and RA5 I/O pins. When enabled, multiplexors in the output path of the RB5 and RA5 pins will switch and the output of each pin will be the unsynchronized output of the comparator. The uncertainty of each of the comparators is related to the input offset voltage and the response time given in the specifications. Figure 19-3 shows the comparator output block diagram.

The TRISA bits will still function as an output enable/ disable for the RB5 and RA5 pins while in this mode.

The polarity of the comparator outputs can be changed using the C2INV and C1INV bits (CMCON<5:4>).

- Note 1: When reading the PORT register, all pins configured as analog inputs will read as a '0'. Pins configured as digital inputs will convert an analog input according to the Schmitt Trigger input specification.
  - 2: Analog levels on any pin defined as a digital input may cause the input buffer to consume more current than is specified.



#### FIGURE 20-1: COMPARATOR VOLTAGE REFERENCE BLOCK DIAGRAM

## 20.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 20-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 24.0 "Electrical Characteristics"**.

## 20.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.

## 20.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.

## 20.5 Connection Considerations

The voltage reference module operates independently of the comparator module. The output of the reference generator may be connected to the RA2 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 RA2 as a digital output with CVRSS enabled will also increase current consumption.

The RA2 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 20-2 shows an example buffering technique.

## 21.0 SPECIAL FEATURES OF THE CPU

PIC18F45J10 family devices include several features intended to maximize reliability and minimize cost through elimination of external components. These are:

- · Oscillator Selection
- Resets:
  - Power-on Reset (POR)
  - Power-up Timer (PWRT)
  - Oscillator Start-up Timer (OST)
- Brown-out Reset (BOR)
- Interrupts
- Watchdog Timer (WDT)
- · Fail-Safe Clock Monitor
- Two-Speed Start-up
- Code Protection
- In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>)

The oscillator can be configured for the application depending on frequency, power, accuracy and cost. All of the options are discussed in detail in **Section 3.0 "Oscillator Configurations"**.

A complete discussion of device Resets and interrupts is available in previous sections of this data sheet.

In addition to their Power-up and Oscillator Start-up Timers provided for Resets, the PIC18F45J10 family of devices have a configurable Watchdog Timer which is controlled in software.

The inclusion of an internal RC oscillator also provides the additional benefits of a Fail-Safe Clock Monitor (FSCM) and Two-Speed Start-up. FSCM provides for background monitoring of the peripheral clock and automatic switchover in the event of its failure. Two-Speed Start-up enables code to be executed almost immediately on start-up, while the primary clock source completes its start-up delays.

All of these features are enabled and configured by setting the appropriate Configuration register bits.

## 21.1 Configuration Bits

The Configuration bits can be programmed (read as '0') or left unprogrammed (read as '1') to select various device configurations. These bits are mapped starting at program memory location 300000h. A complete list is shown in Table 21-1. A detailed explanation of the various bit functions is provided in Register 21-1 through Register 21-8.

#### 21.1.1 CONSIDERATIONS FOR CONFIGURING THE PIC18F45J10 FAMILY DEVICES

Unlike most PIC18 microcontrollers, devices of the PIC18F45J10 family do not use persistent memory registers to store configuration information. The configuration bytes are implemented as volatile memory which means that configuration data must be programmed each time the device is powered up.

Configuration data is stored in the four words at the top of the on-chip program memory space, known as the Flash Configuration Words. It is stored in program memory in the same order shown in Table 21-1, with CONFIG1L at the lowest address and CONFIG3H at the highest. The data is automatically loaded in the proper Configuration registers during device power-up.

When creating applications for these devices, users should always specifically allocate the location of the Flash Configuration Word for configuration data; this is to make certain that program code is not stored in this address when the code is compiled.

The volatile memory cells used for the Configuration bits always reset to '1' on Power-on Resets. For all other type of Reset events, the previously programmed values are maintained and used without reloading from program memory.

The four Most Significant bits of CONFIG1H, CONFIG2H and CONFIG3H in program memory should also be '1111'. This makes these Configuration Words appear to be NOP instructions in the remote event that their locations are ever executed by accident. Since Configuration bits are not implemented in the corresponding locations, writing '1's to these locations has no effect on device operation.

To prevent inadvertent configuration changes during code execution, all programmable Configuration bits are write-once. After a bit is initially programmed during a power cycle, it cannot be written to again. Changing a device configuration requires a device Reset.

## 21.2 Watchdog Timer (WDT)

For PIC18F45J10 family devices, the WDT is driven by the INTRC oscillator. 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 INTRC 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 multiplexor, controlled by the WDTPS bits in Configuration Register 2H. Available periods range from about 4 ms to 135 seconds (2.25 minutes) depending on voltage, temperature and Watchdog postscaler. The WDT and postscaler are cleared whenever a SLEEP or CLRWDT instruction is executed, or a clock failure (primary or Timer1 oscillator) has occurred.

#### FIGURE 21-1: WDT BLOCK DIAGRAM



**2:** When a CLRWDT instruction is executed, the postscaler count will be cleared.

#### 21.2.1 CONTROL REGISTER

The WDTCON register (Register 21-9) is a readable and writable register. The SWDTEN bit enables or disables WDT operation.



#### REGISTER 21-9: WDTCON: WATCHDOG TIMER CONTROL REGISTER

| u-0   | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0                 |
|-------|-----|-----|-----|-----|-----|-----|-----------------------|
| —     | —   | —   | —   | —   | —   | —   | SWDTEN <sup>(1)</sup> |
| bit 7 |     |     |     |     |     |     | bit 0                 |
|       |     |     |     |     |     |     |                       |

Legend:

| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | 1 as '0'           |
|-------------------|------------------|-----------------------------|--------------------|
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

bit 7-1 Unimplemented: Read as '0'

bit 0 **SWDTEN:** Software Controlled Watchdog Timer Enable bit<sup>(1)</sup>

1 = Watchdog Timer is on

0 = Watchdog Timer is off

**Note 1:** This bit has no effect if the Configuration bit, WDTEN, is enabled.

#### TABLE 21-2:SUMMARY OF WATCHDOG TIMER REGISTERS

| Name   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0  | Reset Values<br>on page |
|--------|-------|-------|-------|-------|-------|-------|-------|--------|-------------------------|
| RCON   | IPEN  | _     | CM    | RI    | TO    | PD    | POR   | BOR    | 48                      |
| WDTCON |       | _     | —     | —     | —     | _     | _     | SWDTEN | 48                      |

**Legend:** — = unimplemented, read as '0'. Shaded cells are not used by the Watchdog Timer.

| BNC          | ;                                                                    | Branch if                                                                                                                 | Not Carry                                                                                                                 |                                                                                         | BNN                              |                                                                           | Branch if                                                                                                       | f Not Ne                                                                                                   | gative                                                                  |                                                                      |
|--------------|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|----------------------------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|----------------------------------------------------------------------|
| Synta        | ax:                                                                  | BNC n                                                                                                                     |                                                                                                                           |                                                                                         | Syntax:                          |                                                                           | BNN n                                                                                                           |                                                                                                            |                                                                         |                                                                      |
| Oper         | ands:                                                                | -128 ≤ n ≤ 1                                                                                                              | 127                                                                                                                       |                                                                                         | Operands                         | s:                                                                        | -128 ≤ n ≤                                                                                                      | 127                                                                                                        |                                                                         |                                                                      |
| Oper         | ation:                                                               | if Carry bit i<br>(PC) + 2 + 2                                                                                            | s '0',<br>2n → PC                                                                                                         |                                                                                         | Operation                        | n:                                                                        | if Negative bit is '0',<br>(PC) + 2 + 2n $\rightarrow$ PC                                                       |                                                                                                            |                                                                         |                                                                      |
| Statu        | is Affected:                                                         | None                                                                                                                      |                                                                                                                           |                                                                                         | Status Af                        | fected:                                                                   | None                                                                                                            |                                                                                                            |                                                                         |                                                                      |
| Enco         | oding:                                                               | 1110                                                                                                                      | 0011 nn                                                                                                                   | nn nnnn                                                                                 | Encoding                         | j:                                                                        | 1110                                                                                                            | 0111                                                                                                       | nnnn                                                                    | nnnn                                                                 |
| Desc         | ription:                                                             | If the Carry<br>will branch.<br>The 2's con<br>added to the<br>incrementer<br>instruction,<br>PC + 2 + 2r<br>two-cycle in | bit is '0', then<br>nplement num<br>e PC. Since th<br>d to fetch the<br>the new addre<br>n. This instruct<br>instruction. | the program<br>ber, '2n', is<br>e PC will have<br>next<br>ess will be<br>tion is then a | Descriptio                       | on:                                                                       | If the Nega<br>program w<br>The 2's co<br>added to th<br>incremente<br>instruction<br>PC + 2 + 2<br>two-cycle i | ative bit is<br>ill branch<br>mplement<br>he PC. Sir<br>ed to fetch<br>the new<br>n. This in<br>nstruction | '0', ther<br>t number<br>nce the F<br>n the new<br>address<br>structior | n the<br>r, '2n', is<br>PC will have<br>ct<br>will be<br>n is then a |
| Word         | ls:                                                                  | 1                                                                                                                         |                                                                                                                           |                                                                                         | Words:                           |                                                                           | 1                                                                                                               |                                                                                                            |                                                                         |                                                                      |
| Cycle        | es:                                                                  | 1(2)                                                                                                                      |                                                                                                                           |                                                                                         | Cycles:                          |                                                                           | 1(2)                                                                                                            |                                                                                                            |                                                                         |                                                                      |
| Q C<br>If Ju | ycle Activity:<br>imp:                                               |                                                                                                                           |                                                                                                                           |                                                                                         | Q Cycle<br>If Jump:              | Activity:                                                                 |                                                                                                                 |                                                                                                            |                                                                         |                                                                      |
|              | Q1                                                                   | Q2                                                                                                                        | Q3                                                                                                                        | Q4                                                                                      |                                  | Q1                                                                        | Q2                                                                                                              | Q3                                                                                                         |                                                                         | Q4                                                                   |
|              | Decode                                                               | Read literal<br>'n'                                                                                                       | Process<br>Data                                                                                                           | Write to PC                                                                             | [                                | Decode                                                                    | Read literal<br>'n'                                                                                             | Proce<br>Data                                                                                              | ess V<br>a                                                              | Vrite to PC                                                          |
|              | No<br>operation                                                      | No<br>operation                                                                                                           | No<br>operation                                                                                                           | No<br>operation                                                                         | ot                               | No<br>peration                                                            | No<br>operation                                                                                                 | No<br>operat                                                                                               | tion                                                                    | No<br>operation                                                      |
| lf No        | o Jump:                                                              |                                                                                                                           |                                                                                                                           |                                                                                         | If No Jur                        | mp:                                                                       |                                                                                                                 |                                                                                                            |                                                                         |                                                                      |
|              | Q1                                                                   | Q2                                                                                                                        | Q3                                                                                                                        | Q4                                                                                      |                                  | Q1                                                                        | Q2                                                                                                              | Q3                                                                                                         |                                                                         | Q4                                                                   |
|              | Decode                                                               | Read literal<br>'n'                                                                                                       | Process<br>Data                                                                                                           | No<br>operation                                                                         |                                  | Decode                                                                    | Read literal<br>'n'                                                                                             | Proce<br>Data                                                                                              | ess<br>a                                                                | No<br>operation                                                      |
| <u>Exan</u>  | nple:<br>PC<br>After Instruction<br>If Carry<br>PC<br>If Carry<br>PC | HERE<br>tion = add<br>on = 0;<br>= add<br>= 1;<br>= add                                                                   | BNC Jump<br>dress (HERE<br>dress (Jump<br>dress (HERE                                                                     | )<br>)<br>+ 2)                                                                          | <u>Example</u> :<br>Befo<br>Afte | ore Instruc<br>PC<br>r Instructio<br>If Negativ<br>PC<br>If Negativ<br>PC | HERE<br>tion = ac<br>on ve = 0;<br>ve = 0;<br>ve = 1;<br>= ac                                                   | BNN ddress (1<br>ddress (1<br>ddress (1                                                                    | Jump<br>HERE)<br>Jump)<br>HERE +                                        | 2)                                                                   |

|                   | LW                                      | Multiply                                                                                                                                                                                                                                                                                                                                                                                 | Multiply Literal with W |                    |                                           |  |  |  |  |
|-------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------|-------------------------------------------|--|--|--|--|
| Synt              | ax:                                     | MULLW                                                                                                                                                                                                                                                                                                                                                                                    | k                       |                    |                                           |  |  |  |  |
| Oper              | ands:                                   | $0 \le k \le 255$                                                                                                                                                                                                                                                                                                                                                                        | $0 \le k \le 255$       |                    |                                           |  |  |  |  |
| Oper              | ation:                                  | (W) x k $\rightarrow$                                                                                                                                                                                                                                                                                                                                                                    | PRODH:F                 | PRODL              |                                           |  |  |  |  |
| Statu             | is Affected:                            | None                                                                                                                                                                                                                                                                                                                                                                                     |                         |                    |                                           |  |  |  |  |
| Enco              | oding:                                  | 0000                                                                                                                                                                                                                                                                                                                                                                                     | 1101                    | kkkk               | kkkk                                      |  |  |  |  |
| Desc              | cription:                               | An unsigned multiplication is carried<br>out between the contents of W and th<br>8-bit literal 'k'. The 16-bit result is<br>placed in the PRODH:PRODL registe<br>pair. PRODH contains the high byte.<br>W is unchanged.<br>None of the Status flags are affected.<br>Note that neither overflow nor carry is<br>possible in this operation. A zero resu<br>is possible but not detected. |                         |                    |                                           |  |  |  |  |
| Word              | ds:                                     | 1                                                                                                                                                                                                                                                                                                                                                                                        |                         |                    |                                           |  |  |  |  |
| Cycle             | es:                                     | 1                                                                                                                                                                                                                                                                                                                                                                                        |                         |                    |                                           |  |  |  |  |
| Q Cycle Activity: |                                         |                                                                                                                                                                                                                                                                                                                                                                                          |                         |                    |                                           |  |  |  |  |
| . U               |                                         |                                                                                                                                                                                                                                                                                                                                                                                          |                         |                    |                                           |  |  |  |  |
| QU                | Q1                                      | Q2                                                                                                                                                                                                                                                                                                                                                                                       | Q3                      |                    | Q4                                        |  |  |  |  |
|                   | Q1<br>Decode                            | Q2<br>Read<br>literal 'k'                                                                                                                                                                                                                                                                                                                                                                | Q3<br>Proces<br>Data    | ss<br>P<br>F       | Q4<br>Write<br>egisters<br>RODH:<br>PRODL |  |  |  |  |
| Exar              | Q1<br>Decode                            | Q2<br>Read<br>literal 'k'                                                                                                                                                                                                                                                                                                                                                                | Q3<br>Proces<br>Data    | ss<br>re<br>P<br>F | Q4<br>Write<br>egisters<br>RODH:<br>PRODL |  |  |  |  |
| Exar              | Q1<br>Decode<br>nple:<br>Before Instruc | Q2<br>Read<br>literal 'k'<br><sup>MULLW</sup>                                                                                                                                                                                                                                                                                                                                            | Q3<br>Proces<br>Data    | ss<br>P<br>F       | Q4<br>Write<br>egisters<br>RODH:<br>PRODL |  |  |  |  |

| MULWF                                          | Multiply                                                                                                                                                                                                                                                                                                                                                       | Multiply W with f                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |              |                            |  |  |  |
|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------------------------|--|--|--|
| Syntax:                                        | MULWF                                                                                                                                                                                                                                                                                                                                                          | f {,a}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |                            |  |  |  |
| Operands:                                      | 0 ≤ f ≤ 255<br>a ∈ [0 , 1]                                                                                                                                                                                                                                                                                                                                     | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |              |                            |  |  |  |
| Operation:                                     | (W) x (f) –                                                                                                                                                                                                                                                                                                                                                    | → PRODH:P                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RODL         |                            |  |  |  |
| Status Affected:                               | None                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                            |  |  |  |
| Encoding:                                      | 0000                                                                                                                                                                                                                                                                                                                                                           | 001a f                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | fff          | ffff                       |  |  |  |
| Description:                                   | An unsign<br>out betwee<br>register file<br>result is st<br>register pa<br>high byte.<br>unchange<br>None of th<br>Note that 1<br>possible ir<br>result is pr<br>If 'a' is '0',<br>selected. I<br>to select th<br>If 'a' is '0' a<br>set is enal<br>operates i<br>Addressin<br>$f \le 95$ (5FH<br><b>''Byte-Oric</b><br><b>Instructio</b><br><b>Mode''</b> for | An unsigned multiplication is carried<br>out between the contents of W and the<br>register file location 'f'. The 16-bit<br>result is stored in the PRODH:PRODL<br>register pair. PRODH contains the<br>high byte. Both W and 'f' are<br>unchanged.<br>None of the Status flags are affected.<br>Note that neither overflow nor carry is<br>possible in this operation. A zero<br>result is possible but not detected.<br>If 'a' is '0', the Access Bank is<br>selected. If 'a' is '1', the BSR is used<br>to select the GPR bank (default).<br>If 'a' is '0' and the extended instruction<br>set is enabled, this instruction<br>operates in Indexed Literal Offset<br>Addressing mode whenever<br>$f \le 95$ (5Fh). See Section 22.2.3<br>"Byte-Oriented and Bit-Oriented<br>Instructions in Indexed Literal Offset |              |                            |  |  |  |
| Words:                                         | 1                                                                                                                                                                                                                                                                                                                                                              | uctans.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |              |                            |  |  |  |
| Cycles:                                        | 1                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                            |  |  |  |
|                                                | I                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                            |  |  |  |
|                                                | 02                                                                                                                                                                                                                                                                                                                                                             | 03                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |              | 04                         |  |  |  |
| Decode                                         | Read                                                                                                                                                                                                                                                                                                                                                           | Process                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |              | Write                      |  |  |  |
|                                                | register 'f'                                                                                                                                                                                                                                                                                                                                                   | Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | re<br>P<br>F | egisters<br>RODH:<br>PRODL |  |  |  |
| Example:                                       | MULWF                                                                                                                                                                                                                                                                                                                                                          | REG, 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |                            |  |  |  |
| Before Instruc                                 | tion                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                            |  |  |  |
| W<br>REG<br>PRODH<br>PRODL<br>After Instructio | = C4<br>= B5<br>= ?<br>= ?                                                                                                                                                                                                                                                                                                                                     | łh<br>ih                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |              |                            |  |  |  |

| W     | = | C4h |
|-------|---|-----|
| REG   | = | B5h |
| PRODH | = | 8Ah |
| PRODL | = | 94h |
|       |   |     |

| POF                                                                                                                                                                                                                                                                                                     | )                             | Рор Тор             | Pop Top of Return Stack |                |         |                |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|---------------------|-------------------------|----------------|---------|----------------|--|--|--|
| Synta                                                                                                                                                                                                                                                                                                   | ax:                           | POP                 | POP                     |                |         |                |  |  |  |
| Oper                                                                                                                                                                                                                                                                                                    | ands:                         | None                | None                    |                |         |                |  |  |  |
| Operation: $(TOS) \rightarrow bit bucket$                                                                                                                                                                                                                                                               |                               |                     |                         |                |         |                |  |  |  |
| Statu                                                                                                                                                                                                                                                                                                   | is Affected:                  | None                |                         |                |         |                |  |  |  |
| Enco                                                                                                                                                                                                                                                                                                    | oding:                        | 0000                | 0000                    | 000            | 0       | 0110           |  |  |  |
| Description: The TOS value is pulled off the return<br>stack and is discarded. The TOS value<br>then becomes the previous value that<br>was pushed onto the return stack.<br>This instruction is provided to enable<br>the user to properly manage the return<br>stack to incorporate a software stack. |                               |                     |                         |                |         |                |  |  |  |
| Word                                                                                                                                                                                                                                                                                                    | ls:                           | 1                   |                         |                |         |                |  |  |  |
| Cycle                                                                                                                                                                                                                                                                                                   | es:                           | 1                   |                         |                |         |                |  |  |  |
| QC                                                                                                                                                                                                                                                                                                      | ycle Activity:                |                     |                         |                |         |                |  |  |  |
|                                                                                                                                                                                                                                                                                                         | Q1                            | Q2                  | Q3                      | 5              | Q4      |                |  |  |  |
|                                                                                                                                                                                                                                                                                                         | Decode                        | No<br>operation     | POP 1<br>valu           | TOS<br>le      | ор      | No<br>peration |  |  |  |
| <u>Exar</u>                                                                                                                                                                                                                                                                                             | nple:                         | POP<br>GOTO         | NEW                     |                |         |                |  |  |  |
| Before Instructio<br>TOS<br>Stack (1 le                                                                                                                                                                                                                                                                 |                               | tion<br>level down) | = (<br>= (              | 031A2<br>14332 | 2h<br>h |                |  |  |  |
|                                                                                                                                                                                                                                                                                                         | After Instructic<br>TOS<br>PC | n                   | = (<br>= N              | )14332<br>NEW  | h       |                |  |  |  |

| PUS                                                                                                                                                                                                                                                  | 6H                                        | Push Top                            | Push Top of Return Stack |                         |    |                                                           |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-------------------------------------|--------------------------|-------------------------|----|-----------------------------------------------------------|--|--|--|
| Synta                                                                                                                                                                                                                                                | ax:                                       | PUSH                                | PUSH                     |                         |    |                                                           |  |  |  |
| Oper                                                                                                                                                                                                                                                 | ands:                                     | None                                |                          |                         |    |                                                           |  |  |  |
| Oper                                                                                                                                                                                                                                                 | ation:                                    | $(PC + 2) \rightarrow$              | TOS                      |                         |    |                                                           |  |  |  |
| Statu                                                                                                                                                                                                                                                | is Affected:                              | None                                |                          |                         |    |                                                           |  |  |  |
| Enco                                                                                                                                                                                                                                                 | oding:                                    | 0000                                | 0000                     | 000                     | 0  | 0101                                                      |  |  |  |
| Description: The PC + 2 is pushed onto the top o<br>the return stack. The previous TOS<br>value is pushed down on the stack.<br>This instruction allows implementing<br>software stack by modifying TOS an<br>then pushing it onto the return stack. |                                           |                                     |                          |                         |    | e top of<br>TOS<br>stack.<br>enting a<br>OS and<br>stack. |  |  |  |
| Word                                                                                                                                                                                                                                                 | ds:                                       | 1                                   |                          |                         |    |                                                           |  |  |  |
| Cycle                                                                                                                                                                                                                                                | es:                                       | 1                                   |                          |                         |    |                                                           |  |  |  |
| QC                                                                                                                                                                                                                                                   | ycle Activity:                            |                                     |                          |                         |    |                                                           |  |  |  |
|                                                                                                                                                                                                                                                      | Q1                                        | Q2                                  | Q3                       |                         |    | Q4                                                        |  |  |  |
|                                                                                                                                                                                                                                                      | Decode                                    | PUSH<br>PC + 2 onto<br>return stack | l<br>ope                 | No<br>eration           | op | No<br>peration                                            |  |  |  |
| Exan                                                                                                                                                                                                                                                 | nple:                                     | PUSH                                |                          |                         |    |                                                           |  |  |  |
|                                                                                                                                                                                                                                                      | Before Instruc<br>TOS<br>PC               | tion                                | =<br>=                   | 345Ah<br>0124h          |    |                                                           |  |  |  |
|                                                                                                                                                                                                                                                      | After Instructio<br>PC<br>TOS<br>Stack (1 | on<br>level down)                   | =<br>=<br>=              | 0126h<br>0126h<br>345Ah |    |                                                           |  |  |  |

|       | = | 0126h |
|-------|---|-------|
| down) | = | 345Ah |

| CAL         | .LW                                                    | Subroutir                                                                                                                                                                                                                                                                                                                                                                          | Subroutine Call Using WREG    |                 |  |  |  |  |  |
|-------------|--------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|-----------------|--|--|--|--|--|
| Synta       | ax:                                                    | CALLW                                                                                                                                                                                                                                                                                                                                                                              |                               |                 |  |  |  |  |  |
| Oper        | ands:                                                  | None                                                                                                                                                                                                                                                                                                                                                                               |                               |                 |  |  |  |  |  |
| Oper        | ration:                                                | $(PC + 2) \rightarrow$<br>$(W) \rightarrow PCL$<br>(PCLATH) -<br>(PCLATU) -                                                                                                                                                                                                                                                                                                        | TOS,<br>,,<br>→ PCH,<br>→ PCU |                 |  |  |  |  |  |
| Statu       | is Affected:                                           | None                                                                                                                                                                                                                                                                                                                                                                               | None                          |                 |  |  |  |  |  |
| Enco        | oding:                                                 | 0000 0000 0001 0100                                                                                                                                                                                                                                                                                                                                                                |                               |                 |  |  |  |  |  |
|             |                                                        | pushed onto the return stack. Next, the<br>contents of W are written to PCL; the<br>existing value is discarded. Then, the<br>contents of PCLATH and PCLATU are<br>latched into PCH and PCU,<br>respectively. The second cycle is<br>executed as a NOP instruction while the<br>new next instruction is fetched.<br>Unlike CALL, there is no option to<br>update W, STATUS or BSR. |                               |                 |  |  |  |  |  |
| Word        | ds:                                                    | 1                                                                                                                                                                                                                                                                                                                                                                                  |                               |                 |  |  |  |  |  |
| Cycle       | es:                                                    | 2                                                                                                                                                                                                                                                                                                                                                                                  |                               |                 |  |  |  |  |  |
| QC          | ycle Activity:                                         |                                                                                                                                                                                                                                                                                                                                                                                    |                               |                 |  |  |  |  |  |
|             | Q1                                                     | Q2                                                                                                                                                                                                                                                                                                                                                                                 | Q3                            | Q4              |  |  |  |  |  |
|             | Decode                                                 | Read<br>WREG                                                                                                                                                                                                                                                                                                                                                                       | PUSH PC to stack              | No<br>operation |  |  |  |  |  |
|             | No                                                     | No                                                                                                                                                                                                                                                                                                                                                                                 | No                            | No              |  |  |  |  |  |
|             | operation                                              | operation                                                                                                                                                                                                                                                                                                                                                                          | operation                     | operation       |  |  |  |  |  |
| <u>Exan</u> | nple:<br>Before Instruc<br>PC<br>PCLATH<br>PCLATU<br>W | HERE<br>= address<br>= 10h<br>= 00h<br>= 06h                                                                                                                                                                                                                                                                                                                                       | CALLW (HERE)                  |                 |  |  |  |  |  |

| MO                     | /SF                                     | Move Inc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Move Indexed to f                                                          |              |                                 |   |  |  |  |
|------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------|---------------------------------|---|--|--|--|
| Synta                  | ax:                                     | MOVSF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | MOVSF [z <sub>s</sub> ], f <sub>d</sub>                                    |              |                                 |   |  |  |  |
| Oper                   | ands:                                   | $0 \le z_s \le 12$<br>$0 \le f_d \le 40$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | $\begin{array}{l} 0 \leq z_s \leq 127 \\ 0 \leq f_d \leq 4095 \end{array}$ |              |                                 |   |  |  |  |
| Oper                   | ation:                                  | ((FSR2) +                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | $z_s) \rightarrow f_d$                                                     |              |                                 |   |  |  |  |
| Statu                  | s Affected:                             | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                            |              |                                 |   |  |  |  |
| Enco<br>1st w<br>2nd v | ding:<br>ord (source)<br>vord (destin.) | 1110<br>1111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1110 1011 0zzz zz<br>1111 ffff ffff ff                                     |              |                                 |   |  |  |  |
| Desc                   | ription:                                | The contents of the source register are<br>moved to destination register 'f <sub>d</sub> '. The<br>actual address of the source register is<br>determined by adding the 7-bit literal<br>offset ' $z_s$ ' in the first word to the value of<br>FSR2. The address of the destination<br>register is specified by the 12-bit literal<br>'f <sub>d</sub> ' in the second word. Both addresses<br>can be anywhere in the 4096-byte data<br>space (000h to FFFh).<br>The MOVSF instruction cannot use the<br>PCL, TOSU, TOSH or TOSL as the<br>destination register.<br>If the resultant source address points to<br>an indirect addressing register, the<br>value returned will be 00h. |                                                                            |              |                                 |   |  |  |  |
| Word                   | s:                                      | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                            |              |                                 |   |  |  |  |
| Cycle                  | es:                                     | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                            |              |                                 |   |  |  |  |
| QC                     | vcle Activity:                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                            |              |                                 |   |  |  |  |
|                        | Q1                                      | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Q3                                                                         | 3            | Q4                              |   |  |  |  |
|                        | Decode                                  | Determine source addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Detern                                                                     | nine<br>addr | Read source reg                 | 1 |  |  |  |
|                        | Decode                                  | No<br>operation<br>No dummy<br>read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | No<br>opera                                                                | )<br>tion    | Write<br>register 'f'<br>(dest) |   |  |  |  |
| <u>Exan</u>            | nple:                                   | MOVSF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | [05h],                                                                     | REG2         |                                 |   |  |  |  |
|                        | Before Instruc                          | tion _ o                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Ъ                                                                          |              |                                 |   |  |  |  |
|                        | Contents<br>of 85h<br>REG2              | = 3:<br>= 1 <sup>·</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 3h<br>Ih                                                                   |              |                                 |   |  |  |  |
|                        | After Instruction<br>FSR2               | on<br>= 80                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Dh                                                                         |              |                                 |   |  |  |  |
|                        | of 85h<br>REG2                          | = 3:<br>= 3:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 3h<br>3h                                                                   |              |                                 |   |  |  |  |

## 22.2.5 SPECIAL CONSIDERATIONS WITH MICROCHIP MPLAB<sup>®</sup> IDE TOOLS

The latest versions of Microchip's software tools have been designed to fully support the extended instruction set of the PIC18F45J10 family of devices. This includes the MPLAB C18 C compiler, MPASM assembly language and MPLAB Integrated Development Environment (IDE).

When selecting a target device for software development, MPLAB IDE will automatically set default Configuration bits for that device. The default setting for the XINST Configuration bit is '0', disabling the extended instruction set and Indexed Literal Offset Addressing mode. For proper execution of applications developed to take advantage of the extended instruction set, XINST must be set during programming.

To develop software for the extended instruction set, the user must enable support for the instructions and the Indexed Addressing mode in their language tool(s). Depending on the environment being used, this may be done in several ways:

- A menu option, or dialog box within the environment, that allows the user to configure the language tool and its settings for the project
- · A command line option
- · A directive in the source code

These options vary between different compilers, assemblers and development environments. Users are encouraged to review the documentation accompanying their development systems for the appropriate information.

## 24.1 DC Characteristics: Supply Voltage PIC18F24J10/25J10/44J10/45J10 (Industrial) PIC18LF24J10/25J10/44J10/45J10 (Industrial)

| PIC18F4      | 5 <b>J10 Fami</b><br>strial) | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial |                    |     |      |       |                                                                                                      |
|--------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|------|-------|------------------------------------------------------------------------------------------------------|
| Param<br>No. | Symbol                       | Characteristic                                                                                                                     | Min                | Тур | Max  | Units | Conditions                                                                                           |
| D001         | Vdd                          | Supply Voltage                                                                                                                     | VDDCORE            | —   | 3.6  | V     | PIC18LF4XJ10, PIC18LF2XJ10                                                                           |
| D001         | Vdd                          | Supply Voltage                                                                                                                     | 2.7 <sup>(1)</sup> | _   | 3.6  | V     | PIC18F4X/2XJ10                                                                                       |
| D001B        | VDDCORE                      | External Supply for<br>Microcontroller Core                                                                                        | 2.0                | _   | 2.7  | V     | Valid only in parts designated "LF".<br>See Section 21.3 "On-Chip<br>Voltage Regulator" for details. |
| D002         | Vdr                          | RAM Data Retention<br>Voltage <sup>(1)</sup>                                                                                       | 1.5                | _   | _    | V     |                                                                                                      |
| D003         | VPOR                         | VDD <b>Start Voltage</b><br>to ensure internal<br>Power-on Reset signal                                                            | —                  | —   | 0.15 | V     | SeeSection 5.3 "Power-on<br>Reset (POR)" for details                                                 |
| D004         | SVDD                         | <b>VDD Rise Rate</b><br>to ensure internal<br>Power-on Reset signal                                                                | 0.05               | _   | _    | V/ms  | See Section 5.3 "Power-on<br>Reset (POR)" for details                                                |
| D005         | VBOR                         | Brown-out Reset (BOR)<br>Voltage                                                                                                   | 2.35               | 2.5 | 2.7  | V     |                                                                                                      |

Note 1: This is the limit to which VDD can be lowered in Sleep mode, or during a device Reset, without losing RAM data.

## 24.2 DC Characteristics: Power-Down and Supply Current PIC18F24J10/25J10/44J10/45J10 (Industrial) PIC18LF24J10/25J10/44J10/45J10 (Industrial) (Continued)

| PIC18F45J10 Family<br>(Industrial) |                                     | 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 | Conditions |            |                  |  |
|                                    | Supply Current (IDD) <sup>(2)</sup> |                                                                                                                                    |     |       |            |            |                  |  |
|                                    | All devices                         | 6.2                                                                                                                                | 14  | mA    | -40°C      | VDD = 2.5V | Fosc = 4 MHz,    |  |
|                                    |                                     | 5.7                                                                                                                                | 13  | mA    | +25°C      |            | 16 MHz internal  |  |
|                                    |                                     | 5.7                                                                                                                                | 13  | mA    | +85°C      |            | (PRI_RUN HS+PLL) |  |
|                                    | All devices                         | 6.6                                                                                                                                | 15  | mA    | -40°C      |            | Fosc = 4 MHz,    |  |
|                                    |                                     | 6.1                                                                                                                                | 14  | mA    | +25°C      | VDD = 3.3V | 16 MHz internal  |  |
|                                    |                                     | 6.1                                                                                                                                | 14  | mA    | +85°C      |            | (PRI_RUN HS+PLL) |  |
|                                    | All devices                         | 11.0                                                                                                                               | 22  | mA    | -40°C      |            | Fosc = 10 MHz,   |  |
|                                    |                                     | 10.5                                                                                                                               | 21  | mA    | +25°C      | VDD = 2.5V | 40 MHz internal  |  |
|                                    |                                     | 10.0                                                                                                                               | 20  | mA    | +85°C      |            | (PRI_RUN HS+PLL) |  |
|                                    | All devices                         | 12.0                                                                                                                               | 24  | mA    | -40°C      |            | Fosc = 10 MHz,   |  |
|                                    |                                     | 11.5                                                                                                                               | 23  | mA    | +25°C      | VDD = 3.3V | 40 MHz internal  |  |
|                                    |                                     | 11.0                                                                                                                               | 22  | mA    | +85°C      |            | (PRI_RUN HS+PLL) |  |

**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, 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:** 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.