

Welcome to E-XFL.COM

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

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

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

### Details

E·XFI

| 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) | 2V ~ 3.6V                                                                   |
| Data Converters            | A/D 10x10b                                                                  |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                                              |
| Supplier Device Package    | 28-SOIC                                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf24j10-i-so |

Email: info@E-XFL.COM

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

#### Note the following details of the code protection feature on Microchip devices:

- Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not
  mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION. QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights.

## QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV ISO/TS 16949:2002

### Trademarks

The Microchip name and logo, the Microchip logo, Accuron, dsPIC, KEELOQ, KEELOQ logo, MPLAB, PIC, PICmicro, PICSTART, rfPIC, SmartShunt and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

FilterLab, Hampshire, Linear Active Thermistor, MXDEV, MXLAB, SEEVAL, SmartSensor and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, Application Maestro, CodeGuard, dsPICDEM, dsPICDEM.net, dsPICworks, dsSPEAK, ECAN, ECONOMONITOR, FanSense, In-Circuit Serial Programming, ICSP, ICEPIC, Mindi, MiWi, MPASM, MPLAB Certified logo, MPLIB, MPLINK, mTouch, nanoWatt XLP, PICkit, PICDEM, PICDEM.net, PICtail, PIC<sup>32</sup> logo, PowerCal, PowerInfo, PowerMate, PowerTool, REAL ICE, rfLAB, Select Mode, Total Endurance, TSHARC, WiperLock and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

All other trademarks mentioned herein are property of their respective companies.

© 2009, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.



Microchip received ISO/TS-16949:2002 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001:2000 certified.

## 3.4 PLL Frequency Multiplier

A Phase Locked Loop (PLL) circuit is provided as an option for users who want to use a lower frequency oscillator circuit, or to clock the device up to its highest rated frequency from a crystal oscillator. This may be useful for customers who are concerned with EMI due to high-frequency crystals, or users who require higher clock speeds from an internal oscillator. For these reasons, the HSPLL and ECPLL modes are available.

The HSPLL and ECPLL modes provide the ability to selectively run the device at 4 times the external oscillating source to produce frequencies up to 40 MHz. The PLL is enabled by setting the PLLEN bit in the OSCTUNE register (Register 3-1).

### FIGURE 3-4: PLL BLOCK DIAGRAM



## REGISTER 3-1: OSCTUNE: PLL CONTROL REGISTER

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

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

| bit 7 | Unimplemented: Read as '0'                                |
|-------|-----------------------------------------------------------|
| bit 6 | PLLEN: Frequency Multiplier PLL Enable bit <sup>(1)</sup> |
|       | 1 = PLL enabled                                           |

0 = PLL disabled

- bit 5-0 Unimplemented: Read as '0'
- Note 1: Available only for ECPLL and HSPLL oscillator configurations; otherwise, this bit is unavailable and reads as '0'.

## 6.3.5 STATUS REGISTER

The STATUS register, shown in Register 6-2, contains the arithmetic status of the ALU. As with any other SFR, it can be the operand for any instruction.

If the STATUS register is the destination for an instruction that affects the Z, DC, C, OV or N bits, the results of the instruction are not written; instead, the STATUS register is updated according to the instruction performed. Therefore, the result of an instruction with the STATUS register as its destination may be different than intended. As an example, CLRF STATUS will set the Z bit and leave the remaining Status bits unchanged ('000u u1uu'). It is recommended that only BCF, BSF, SWAPF, MOVFF and MOVWF instructions are used to alter the STATUS register, because these instructions do not affect the Z, C, DC, OV or N bits in the STATUS register.

For other instructions that do not affect Status bits, see the instruction set summaries in Table 22-2 and Table 22-3.

Note: The C and DC bits operate as the borrow and digit borrow bits, respectively, in subtraction.

## REGISTER 6-2: STATUS REGISTER

| U-0        | U-0                                                 | U-0                                                                                                        | R/W-x                              | R/W-x                                 | R/W-x                                | R/W-x                              | R/W-x                          |
|------------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------|------------------------------------|---------------------------------------|--------------------------------------|------------------------------------|--------------------------------|
|            |                                                     |                                                                                                            | Ν                                  | OV                                    | Z                                    | DC <sup>(1)</sup>                  | C <sup>(2)</sup>               |
| bit 7      |                                                     |                                                                                                            |                                    |                                       |                                      |                                    | bit 0                          |
|            |                                                     |                                                                                                            |                                    |                                       |                                      |                                    |                                |
| Legend:    |                                                     |                                                                                                            |                                    |                                       |                                      | 1                                  |                                |
| R = Read   | lable bit                                           | W = Writable                                                                                               | bit                                |                                       | nented bit, rea                      | d as '0'                           |                                |
| -n = value | e at POR                                            | "1" = Bit is set                                                                                           |                                    | $0^{\circ} = Bit is clea$             | ared                                 | x = Bit is unkr                    | lown                           |
| bit 7-5    | Unimplemen                                          | ted: Read as '                                                                                             | )'                                 |                                       |                                      |                                    |                                |
| bit 4      | N: Negative b                                       | bit                                                                                                        |                                    |                                       |                                      |                                    |                                |
|            | This bit is use<br>(ALU MSB =                       | ed for signed ar<br>1).                                                                                    | ithmetic (2's co                   | omplement). It i                      | ndicates wheth                       | ner the result wa                  | as negative                    |
|            | 1 = Result wa<br>0 = Result wa                      | as negative<br>as positive                                                                                 |                                    |                                       |                                      |                                    |                                |
| bit 3      | OV: Overflow                                        | bit                                                                                                        |                                    |                                       |                                      |                                    |                                |
|            | This bit is use<br>which causes                     | ed for signed ar<br>the sign bit (bi                                                                       | ithmetic (2's co<br>t 7) to change | omplement). It i<br>state.            | ndicates an ov                       | erflow of the 7-                   | bit magnitude                  |
|            | 1 = Overflow<br>0 = No overflo                      | occurred for sig                                                                                           | gned arithmetic                    | c (in this arithm                     | etic operation)                      |                                    |                                |
| bit 2      | Z: Zero bit                                         |                                                                                                            |                                    |                                       |                                      |                                    |                                |
|            | 1 = The resul<br>0 = The resul                      | t of an arithmet<br>t of an arithmet                                                                       | ic or logic ope<br>ic or logic ope | ration is zero<br>ration is not zer   | 0                                    |                                    |                                |
| bit 1      | DC: Digit Car                                       | rry/Borrow bit <sup>(1)</sup>                                                                              |                                    |                                       |                                      |                                    |                                |
|            | For ADDWF, A                                        | DDLW, SUBLW <b>a</b>                                                                                       | nd SUBWF inst                      | ructions:                             |                                      |                                    |                                |
|            | 1 = A carry-o                                       | ut from the 4th                                                                                            | low-order bit o                    | f the result occi                     | urred                                |                                    |                                |
| hit 0      | C Carry/Borr                                        | $\frac{1}{1000}$ bit(2)                                                                                    |                                    | or the result                         |                                      |                                    |                                |
| bit 0      | For ADDWF, A                                        | For ADDWF, ADDLW, SUBLW and SUBWF instructions:                                                            |                                    |                                       |                                      |                                    |                                |
|            | 1 = A carry-o                                       | 1 = A carry-out from the Most Significant bit of the result occurred                                       |                                    |                                       |                                      |                                    |                                |
|            | 0 = No carry-                                       | out from the Mo                                                                                            | ost Significant                    | bit of the result                     | occurred                             |                                    |                                |
| Note 1:    | For borrow, the poperand. For rota                  | For borrow, the polarity is reversed. A subtraction is executed by adding the 2's complement of the second |                                    |                                       |                                      |                                    |                                |
| 2:         | For borrow, the poperand. For rota source register. | olarity is reverse<br>ite (RRF, RLF) ii                                                                    | ed. A subtractions, this           | on is executed I<br>s bit is loaded v | by adding the 2<br>vith either the l | 2's complement<br>high or low-orde | of the second<br>er bit of the |

## 9.3 PIE Registers

The PIE registers contain the individual enable bits for the peripheral interrupts. Due to the number of peripheral interrupt sources, there are three Peripheral Interrupt Enable registers (PIE1, PIE2, PIE3). When IPEN = 0, the PEIE bit must be set to enable any of these peripheral interrupts.

## REGISTER 9-7: PIE1: PERIPHERAL INTERRUPT ENABLE REGISTER 1

| R/W-0                | R/W-0 | R/W-0 | R/W-0 | R/W-0  | R/W-0  | R/W-0  | R/W-0  |
|----------------------|-------|-------|-------|--------|--------|--------|--------|
| PSPIE <sup>(1)</sup> | ADIE  | RCIE  | TXIE  | SSP1IE | CCP1IE | TMR2IE | TMR1IE |
| bit 7                |       |       |       |        |        |        | bit 0  |

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

| bit 7 | <b>PSPIE:</b> Parallel Slave Port Read/Write Interrupt Enable bit <sup>(1)</sup> <ol> <li>= Enables the PSP read/write interrupt</li> <li>= Disables the PSP read/write interrupt</li> </ol> |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 6 | ADIE: A/D Converter Interrupt Enable bit                                                                                                                                                     |
|       | <ul><li>1 = Enables the A/D interrupt</li><li>0 = Disables the A/D interrupt</li></ul>                                                                                                       |
| bit 5 | RCIE: EUSART Receive Interrupt Enable bit                                                                                                                                                    |
|       | <ul><li>1 = Enables the EUSART receive interrupt</li><li>0 = Disables the EUSART receive interrupt</li></ul>                                                                                 |
| bit 4 | TXIE: EUSART Transmit Interrupt Enable bit                                                                                                                                                   |
|       | <ul><li>1 = Enables the EUSART transmit interrupt</li><li>0 = Disables the EUSART transmit interrupt</li></ul>                                                                               |
| bit 3 | <b>SSP1IE:</b> Master Synchronous Serial Port 1 Interrupt Enable bit                                                                                                                         |
|       | <ul><li>1 = Enables the MSSP interrupt</li><li>0 = Disables the MSSP interrupt</li></ul>                                                                                                     |
| bit 2 | CCP1IE: ECCP1/CCP1 Interrupt Enable bit                                                                                                                                                      |
|       | <ul><li>1 = Enables the ECCP1/CCP1 interrupt</li><li>0 = Disables the ECCP1/CCP1 interrupt</li></ul>                                                                                         |
| bit 1 | TMR2IE: TMR2 to PR2 Match Interrupt Enable bit                                                                                                                                               |
|       | <ul><li>1 = Enables the TMR2 to PR2 match interrupt</li><li>0 = Disables the TMR2 to PR2 match interrupt</li></ul>                                                                           |
| bit 0 | TMR1IE: TMR1 Overflow Interrupt Enable bit                                                                                                                                                   |
|       | <ul><li>1 = Enables the TMR1 overflow interrupt</li><li>0 = Disables the TMR1 overflow interrupt</li></ul>                                                                                   |

Note 1: This bit is not implemented on 28-pin devices and should be read as '0'.

## 9.5 RCON Register

The RCON register contains bits used to determine the cause of the last Reset or wake-up from Idle or Sleep modes. RCON also contains the bit that enables interrupt priorities (IPEN).

## REGISTER 9-13: RCON: RESET CONTROL REGISTER

| R/W-0 | U-0 | R/W-1 | R/W-1 | R-1 | R-1 | R/W-0 | R/W-0 |
|-------|-----|-------|-------|-----|-----|-------|-------|
| IPEN  | —   | CM    | RI    | TO  | PD  | POR   | BOR   |
| bit 7 |     |       |       |     |     |       | bit 0 |

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

| bit 7 | IPEN: Interrupt Priority Enable bit                                      |
|-------|--------------------------------------------------------------------------|
|       | 1 = Enable priority levels on interrupts                                 |
|       | 0 = Disable priority levels on interrupts (PIC16CXXX Compatibility mode) |
| bit 6 | Unimplemented: Read as '0'                                               |
| bit 5 | CM: Configuration Mismatch Flag bit                                      |
|       | For details of bit operation, see Register 5-1.                          |
| bit 4 | RI: RESET Instruction Flag bit                                           |
|       | For details of bit operation, see Register 5-1.                          |
| bit 3 | TO: Watchdog Timer Time-out Flag bit                                     |
|       | For details of bit operation, see Register 5-1.                          |
| bit 2 | PD: Power-Down Detection Flag bit                                        |
|       | For details of bit operation, see Register 5-1.                          |
| bit 1 | POR: Power-on Reset Status bit                                           |
|       | For details of bit operation, see Register 5-1.                          |
| bit 0 | BOR: Brown-out Reset Status bit                                          |
|       | For details of bit operation, see Register 5-1.                          |

## 15.4.5 FULL-BRIDGE MODE

In Full-Bridge Output mode, four pins are used as outputs; however, only two outputs are active at a time. In the Forward mode, pin P1A is continuously active and pin P1D is modulated. In the Reverse mode, pin P1C is continuously active and pin P1B is modulated. These are illustrated in Figure 15-6. P1A, P1B, P1C and P1D outputs are multiplexed with the PORTC<2> and PORTD<7:5> data latches. The TRISC<2> and TRISD<7:5> bits must be cleared to make the P1A, P1B, P1C and P1D pins outputs.





## 16.3.2 OPERATION

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

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

Each MSSP consists of a transmit/receive shift register (SSPxSR) and a buffer register (SSPxBUF). The SSPxSR shifts the data in and out of the device, MSb first. The SSPxBUF holds the data that was written to the SSPxSR until the received data is ready. Once the 8 bits of data have been received, that byte is moved to the SSPxBUF register. Then, the Buffer Full detect bit, BF (SSPxSTAT<0>), and the interrupt flag bit, SSPxIF, are set. This double-buffering of the received data (SSPxBUF) allows the next byte to start reception before reading the data that was just received. Any write to the

SSPxBUF register during transmission/reception of data will be ignored and the Write Collision detect bit, WCOL (SSPxCON1<7>), will be set. User software must clear the WCOL bit so that it can be determined if the following write(s) to the SSPxBUF register completed successfully.

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

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

## EXAMPLE 16-1: LOADING THE SSP1BUF (SSP1SR) REGISTER

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







### 16.4.17.1 Bus Collision During a Start Condition

During a Start condition, a bus collision occurs if:

- a) SDAx or SCLx are sampled low at the beginning of the Start condition (Figure 16-26).
- b) SCLx is sampled low before SDAx is asserted low (Figure 16-27).

During a Start condition, both the SDAx and the SCLx pins are monitored.

If the SDAx pin is already low, or the SCLx pin is already low, then all of the following occur:

- · the Start condition is aborted;
- · the BCLxIF flag is set; and
- the MSSP module is reset to its Idle state (Figure 16-26).

The Start condition begins with the SDAx and SCLx pins deasserted. When the SDAx pin is sampled high, the Baud Rate Generator is loaded from SSPxADD<6:0> and counts down to '0'. If the SCLx pin is sampled low while SDAx is high, a bus collision occurs, because it is assumed that another master is attempting to drive a data '1' during the Start condition.

If the SDAx pin is sampled low during this count, the BRG is reset and the SDAx line is asserted early (Figure 16-28). If, however, a '1' is sampled on the SDAx pin, the SDAx pin is asserted low at the end of the BRG count. The Baud Rate Generator is then reloaded and counts down to 0. If the SCLx pin is sampled as '0' during this time, a bus collision does not occur. At the end of the BRG count, the SCLx pin is asserted low.

Note: The reason that bus collision is not a factor during a Start condition is that no two bus masters can assert a Start condition at the exact same time. Therefore, one master will always assert SDAx before the other. This condition does not cause a bus collision because the two masters must be allowed to arbitrate the first address following the Start condition. If the address is the same, arbitration must be allowed to continue into the data portion, Repeated Start or Stop conditions.

## FIGURE 16-26: BUS COLLISION DURING START CONDITION (SDAx ONLY)



|            | R/M/_0                       | R/W_0                            |                  |                   |                  | R-1             | R/M-0 |
|------------|------------------------------|----------------------------------|------------------|-------------------|------------------|-----------------|-------|
| CSRC       |                              | TXEN(1)                          | SYNC             | SENDR             | BRGH             | TRMT            |       |
| bit 7      | 173                          | TALIN                            | 51110            | JENDD             | DIXOIT           |                 | hit 0 |
| bit i      |                              |                                  |                  |                   |                  |                 | bit o |
| Legend:    |                              |                                  |                  |                   |                  |                 |       |
| R = Reada  | able 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      | CSRC: Clock                  | Source Select                    | bit              |                   |                  |                 |       |
|            | Asynchronou                  | <u>s mode:</u>                   |                  |                   |                  |                 |       |
|            | Don't care.                  | mada                             |                  |                   |                  |                 |       |
|            | 1 = Master m                 | inde (clock aen                  | erated internal  | lv from BRG)      |                  |                 |       |
|            | 0 = Slave mo                 | de (clock from                   | external source  | e)                |                  |                 |       |
| bit 6      | <b>TX9:</b> 9-Bit Tra        | ansmit Enable l                  | bit              |                   |                  |                 |       |
|            | 1 = Selects $9$              | 9-bit transmissio                | on               |                   |                  |                 |       |
| L:4 C      | $0 = \text{Selects } \delta$ |                                  | on<br>V          |                   |                  |                 |       |
| DIL 5      | 1 = Trans                    |                                  | ,                |                   |                  |                 |       |
|            | 0 = Transmit                 | disabled                         |                  |                   |                  |                 |       |
| bit 4      | SYNC: EUSA                   | ART Mode Sele                    | ct bit           |                   |                  |                 |       |
|            | 1 = Synchron                 | nous mode                        |                  |                   |                  |                 |       |
|            | 0 = Asynchro                 | onous mode                       |                  |                   |                  |                 |       |
| bit 3      | SENDB: Sen                   | d Break Chara                    | cter bit         |                   |                  |                 |       |
|            | 1 = Send Sv                  | <u>s mode:</u><br>nc Break on ne | ext transmission | (cleared by ha    | ardware upon o   | completion)     |       |
|            | 0 = Sync Bre                 | eak transmissio                  | n completed      | (0.00.00.00.0)    |                  | iempieden)      |       |
|            | Synchronous                  | mode:                            |                  |                   |                  |                 |       |
|            | Don't care.                  |                                  |                  |                   |                  |                 |       |
| bit 2      | BRGH: High                   | Baud Rate Sel                    | ect bit          |                   |                  |                 |       |
|            | 1 = High spe                 | ed                               |                  |                   |                  |                 |       |
|            | 0 = Low spe                  | ed                               |                  |                   |                  |                 |       |
|            | Synchronous                  | mode:                            |                  |                   |                  |                 |       |
| L:1 4      | Unused in thi                | s mode.                          |                  |                   |                  |                 |       |
| DIT        |                              | mit Snift Regist                 | er Status bit    |                   |                  |                 |       |
|            | 0 = TSR full                 | pty                              |                  |                   |                  |                 |       |
| bit 0      | TX9D: 9th Bi                 | t of Transmit Da                 | ata              |                   |                  |                 |       |
|            | Can be addre                 | ess/data bit or a                | a parity bit.    |                   |                  |                 |       |
| Note 1:    | SREN/CREN ove                | errides TXEN in                  | Sync mode.       |                   |                  |                 |       |



## FIGURE 17-2: BRG OVERFLOW SEQUENCE



#### 17.2.5 BREAK CHARACTER SEQUENCE

The EUSART module has the capability of sending the special Break character sequences that are required by the LIN/J2602 support standard. The Break character transmit consists of a Start bit, followed by twelve '0' bits and a Stop bit. The frame Break character is sent whenever the SENDB and TXEN bits (TXSTA<3> and TXSTA<5>) are set while the Transmit Shift register is loaded with data. Note that the value of data written to TXREG will be ignored and all '0's will be transmitted.

The SENDB bit is automatically reset by hardware after the corresponding Stop bit is sent. This allows the user to preload the transmit FIFO with the next transmit byte following the Break character (typically, the Sync character in the LIN/J2602 support).

Note that the data value written to the TXREG for the Break character is ignored. The write simply serves the purpose of initiating the proper sequence.

The TRMT bit indicates when the transmit operation is active or Idle, just as it does during normal transmission. See Figure 17-10 for the timing of the Break character sequence.

#### 17.2.5.1 Break and Sync Transmit Sequence

The following sequence will send a message frame header made up of a Break, followed by an Auto-Baud Sync byte. This sequence is typical of a LIN bus master.

- Configure the EUSART for the desired mode. 1.
- 2. Set the TXEN and SENDB bits to set up the Break character.
- 3. Load the TXREG with a dummy character to initiate transmission (the value is ignored).
- Write '55h' to TXREG to load the Sync character 4 into the transmit FIFO buffer.
- 5. After the Break has been sent, the SENDB bit is reset by hardware. The Sync character now transmits in the preconfigured mode.

When the TXREG becomes empty, as indicated by the TXIF, the next data byte can be written to TXREG.

#### 17.2.6 **RECEIVING A BREAK CHARACTER**

The Enhanced USART module can receive a Break character in two ways.

The first method forces configuration of the baud rate at a frequency of 9/13 the typical speed. This allows for the Stop bit transition to be at the correct sampling location (13 bits for Break versus Start bit and 8 data bits for typical data).

The second method uses the auto-wake-up feature described in Section 17.2.4 "Auto-Wake-up on Sync Break Character". By enabling this feature, the EUSART will sample the next two transitions on RX/DT, cause an RCIF interrupt and receive the next data byte followed by another interrupt.

Note that following a Break character, the user will typically want to enable the Auto-Baud Rate Detect feature. For both methods, the user can set the ABD bit once the TXIF interrupt is observed.



#### FIGURE 17-10: SEND BREAK CHARACTER SEQUENCE

## 20.0 COMPARATOR VOLTAGE REFERENCE MODULE

The comparator voltage reference is a 16-tap resistor ladder network that provides a selectable reference voltage. Although its primary purpose is to provide a reference for the analog comparators, it may also be used independently of them.

A block diagram of the module is shown in Figure 20-1. The resistor ladder is segmented to provide two ranges of CVREF values and has a power-down function to conserve power when the reference is not being used. The module's supply reference can be provided from either device VDD/VSS or an external voltage reference.

## 20.1 Configuring the Comparator Voltage Reference

-----

The voltage reference module is controlled through the CVRCON register (Register 20-1). The comparator voltage reference provides two ranges of output voltage, each with 16 distinct levels. The range to be

used is selected by the CVRR bit (CVRCON<5>). The primary difference between the ranges is the size of the steps selected by the CVREF Selection bits (CVR<3:0>), with one range offering finer resolution. The equations used to calculate the output of the comparator voltage reference are as follows:

<u>If CVRR = 1:</u> CVREF = ((CVR<3:0>)/24) x CVRSRC <u>If CVRR = 0:</u> CVREF = (CVRSRC x 1/4) + (((CVR<3:0>)/32) x CVRSRC)

The comparator reference supply voltage can come from either VDD and VSS, or the external VREF+ and VREF- that are multiplexed with RA2 and RA3. The voltage source is selected by the CVRSS bit (CVRCON<4>).

The settling time of the comparator voltage reference must be considered when changing the CVREF output (see Table 24-3 in **Section 24.0 "Electrical Characteristics"**).

## **REGISTER 20-1: CVRCON: COMPARATOR VOLTAGE REFERENCE CONTROL REGISTER**

| R/W-0 | R/W-0                | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
|-------|----------------------|-------|-------|-------|-------|-------|-------|
| CVREN | CVROE <sup>(1)</sup> | CVRR  | CVRSS | CVR3  | CVR2  | CVR1  | CVR0  |
| bit 7 |                      |       |       |       |       |       | bit 0 |

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

| bit /   | <b>CVREN</b> : Comparator Voltage Reference Enable bit                                                                                                                |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | 1 = CVREF circuit powered on                                                                                                                                          |
|         | 0 = GVREF circuit powered down                                                                                                                                        |
| bit 6   | CVROE: Comparator VREF Output Enable bit <sup>(1)</sup>                                                                                                               |
|         | <ul> <li>1 = CVREF voltage level is also output on the RA2/AN2/VREF-/CVREF pin</li> <li>0 = CVREF voltage is disconnected from the RA2/AN2/VREF-/CVREF pin</li> </ul> |
| bit 5   | CVRR: Comparator VREF Range Selection bit                                                                                                                             |
|         | <ul> <li>1 = 0 to 0.667 CVRSRC, with CVRSRC/24 step size (low range)</li> <li>0 = 0.25 CVRSRC to 0.75 CVRSRC, with CVRSRC/32 step size (high range)</li> </ul>        |
| bit 4   | CVRSS: Comparator VREF Source Selection bit                                                                                                                           |
|         | <ul> <li>1 = Comparator reference source, CVRSRC = (VREF+) – (VREF-)</li> <li>0 = Comparator reference source, CVRSRC = VDD – VSS</li> </ul>                          |
| bit 3-0 | <b>CVR&lt;3:0&gt;:</b> Comparator VREF Value Selection bits ( $0 \le (CVR<3:0>) \le 15$ )                                                                             |
|         | When CVRR = 1:                                                                                                                                                        |
|         | $\overline{\text{CVREF}} = ((\text{CVR} < 3:0 >)/24) \bullet (\text{CVRSRC})$                                                                                         |
|         | When CVRR = 0:                                                                                                                                                        |
|         | CVREF = (CVRSRC/4) + ((CVR<3:0>)/32) • (CVRSRC)                                                                                                                       |
|         |                                                                                                                                                                       |

Note 1: CVROE overrides the TRISA<2> bit setting.

## TABLE 21-1: CONFIGURATION BITS AND DEVICE IDs

| File Name |          | Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Default/<br>Unprogrammed<br>Value <sup>(1)</sup> |
|-----------|----------|-------|-------|--------|-------|--------|--------|--------|--------|--------------------------------------------------|
| 300000h   | CONFIG1L | DEBUG | XINST | STVREN | _     | _      | _      | _      | WDTEN  | 1111                                             |
| 300001h   | CONFIG1H | (2)   | (2)   | _(2)   | (2)   | _(3)   | CP0    | _      | _      | 1111 01                                          |
| 300002h   | CONFIG2L | IESO  | FCMEN | _      | _     | _      | FOSC2  | FOSC1  | FOSC0  | 11111                                            |
| 300003h   | CONFIG2H | (2)   | (2)   | (2)    | (2)   | WDTPS3 | WDTPS2 | WDTPS1 | WDTPS0 | 1111 1111                                        |
| 300004h   | CONFIG3L | _     | —     | _      | _     | —      | —      | _      | —      |                                                  |
| 300005h   | CONFIG3H | (2)   | _(2)  | _(2)   | (2)   | —      | —      | _      | CCP2MX | 11111                                            |
| 3FFFFEh   | DEVID1   | DEV2  | DEV1  | DEV0   | REV4  | REV3   | REV2   | REV1   | REV0   | xxxx xxxx <sup>(4)</sup>                         |
| 3FFFFFh   | DEVID2   | DEV10 | DEV9  | DEV8   | DEV7  | DEV6   | DEV5   | DEV4   | DEV3   | 0001 110x <sup>(4)</sup>                         |

 $\label{eq:legend: Legend: Legend: Legend: Legend: u = unchanged, - = unimplemented. Shaded cells are unimplemented, read as '0'.$ 

**Note 1:** Values reflect the unprogrammed state as received from the factory and following Power-on Resets. In all other Reset states, the configuration bytes maintain their previously programmed states.

2: The value of these bits in program memory should always be '1'. This ensures that the location is executed as a NOP if it is accidentally executed.

**3:** This bit should always be maintained as '0'.

4: See Register 21-7 and Register 21-8 for DEVID values. These registers are read-only and cannot be programmed by the user.

|           | 2-2.                    |                                |            |                         |      |      |      | 1                      |       |
|-----------|-------------------------|--------------------------------|------------|-------------------------|------|------|------|------------------------|-------|
| Mnemonic, |                         | Description                    | 0          | 16-Bit Instruction Word |      |      |      | Status                 | Natas |
| Opera     | nds                     | Description                    | Cycles     | MSb                     |      |      | LSb  | Affected               | Notes |
| BIT-ORIEN | BIT-ORIENTED OPERATIONS |                                |            |                         |      |      |      |                        |       |
| BCF       | f, b, a                 | Bit Clear f                    | 1          | 1001                    | bbba | ffff | ffff | None                   | 1, 2  |
| BSF       | f, b, a                 | Bit Set f                      | 1          | 1000                    | bbba | ffff | ffff | None                   | 1, 2  |
| BTFSC     | f, b, a                 | Bit Test f, Skip if Clear      | 1 (2 or 3) | 1011                    | bbba | ffff | ffff | None                   | 3, 4  |
| BTFSS     | f, b, a                 | Bit Test f, Skip if Set        | 1 (2 or 3) | 1010                    | bbba | ffff | ffff | None                   | 3, 4  |
| BTG       | f, d, a                 | Bit Toggle f                   | 1          | 0111                    | bbba | ffff | ffff | None                   | 1, 2  |
| CONTROL   | OPERA                   | TIONS                          |            |                         |      |      |      | •                      |       |
| BC        | n                       | Branch if Carry                | 1 (2)      | 1110                    | 0010 | nnnn | nnnn | None                   |       |
| BN        | n                       | Branch if Negative             | 1 (2)      | 1110                    | 0110 | nnnn | nnnn | None                   |       |
| BNC       | n                       | Branch if Not Carry            | 1 (2)      | 1110                    | 0011 | nnnn | nnnn | None                   |       |
| BNN       | n                       | Branch if Not Negative         | 1 (2)      | 1110                    | 0111 | nnnn | nnnn | None                   |       |
| BNOV      | n                       | Branch if Not Overflow         | 1 (2)      | 1110                    | 0101 | nnnn | nnnn | None                   |       |
| BNZ       | n                       | Branch if Not Zero             | 1 (2)      | 1110                    | 0001 | nnnn | nnnn | None                   |       |
| BOV       | n                       | Branch if Overflow             | 1 (2)      | 1110                    | 0100 | nnnn | nnnn | None                   |       |
| BRA       | n                       | Branch Unconditionally         | 2          | 1101                    | 0nnn | nnnn | nnnn | None                   |       |
| BZ        | n                       | Branch if Zero                 | 1 (2)      | 1110                    | 0000 | nnnn | nnnn | None                   |       |
| CALL      | n, s                    | Call subroutine 1st Word       | 2          | 1110                    | 110s | kkkk | kkkk | None                   |       |
|           |                         | 2nd Word                       |            | 1111                    | kkkk | kkkk | kkkk |                        |       |
| CLRWDT    | _                       | Clear Watchdog Timer           | 1          | 0000                    | 0000 | 0000 | 0100 | TO, PD                 |       |
| DAW       | —                       | Decimal Adjust WREG            | 1          | 0000                    | 0000 | 0000 | 0111 | С                      |       |
| GOTO      | n                       | Go to address 1st Word         | 2          | 1110                    | 1111 | kkkk | kkkk | None                   |       |
|           |                         | 2nd Word                       |            | 1111                    | kkkk | kkkk | kkkk |                        |       |
| NOP       | —                       | No Operation                   | 1          | 0000                    | 0000 | 0000 | 0000 | None                   |       |
| NOP       | —                       | No Operation                   | 1          | 1111                    | XXXX | XXXX | XXXX | None                   | 4     |
| POP       | —                       | Pop Top of Return Stack (TOS)  | 1          | 0000                    | 0000 | 0000 | 0110 | None                   |       |
| PUSH      | —                       | Push Top of Return Stack (TOS) | 1          | 0000                    | 0000 | 0000 | 0101 | None                   |       |
| RCALL     | n                       | Relative Call                  | 2          | 1101                    | 1nnn | nnnn | nnnn | None                   |       |
| RESET     |                         | Software Device Reset          | 1          | 0000                    | 0000 | 1111 | 1111 | All                    |       |
| RETFIE    | S                       | Return from Interrupt Enable   | 2          | 0000                    | 0000 | 0001 | 000s | GIE/GIEH,<br>PEIE/GIEL |       |
| RETLW     | k                       | Return with Literal in WREG    | 2          | 0000                    | 1100 | kkkk | kkkk | None                   |       |
| RETURN    | S                       | Return from Subroutine         | 2          | 0000                    | 0000 | 0001 | 001s | None                   |       |
| SLEEP     | _                       | Go into Standby mode           | 1          | 0000                    | 0000 | 0000 | 0011 | TO, PD                 |       |

### TABLE 22-2: PIC18FXXXX INSTRUCTION SET (CONTINUED)

**Note 1:** When a PORT register is modified as a function of itself (e.g., MOVF PORTB, 1, 0), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.

2: If this instruction is executed on the TMR0 register (and where applicable, 'd' = 1), the prescaler will be cleared if assigned.

**3:** If the Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP.

4: Some instructions are two-word instructions. The second word of these instructions will be executed as a NOP unless the first word of the instruction retrieves the information embedded in these 16 bits. This ensures that all program memory locations have a valid instruction.

| ADDWFC                                                      | Α                                                                                             | ADD W and Carry bit to f                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                      |     |                      |      |  |  |  |
|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-----|----------------------|------|--|--|--|
| Syntax:                                                     | A                                                                                             | ADDWFC f {,d {,a}}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                      |     |                      |      |  |  |  |
| Operands:                                                   | 0 :<br>d<br>a                                                                                 | ≤f≤255<br>∈[0,1]<br>∈[0,1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |     |                      |      |  |  |  |
| Operation:                                                  | (V                                                                                            | /) + (f) +                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | $(C) \rightarrow de$ | est |                      |      |  |  |  |
| Status Affected:                                            | N,                                                                                            | OV, C, D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | C, Z                 |     |                      |      |  |  |  |
| Encoding:                                                   |                                                                                               | 0010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 00da                 | ffi | Ēf                   | ffff |  |  |  |
| Description:                                                | A<br>loo<br>pla<br>pla<br>If '<br>If '<br>G<br>If '<br>Se<br>in<br>m<br><b>Se</b><br>Bi<br>Li | Add W, the Carry flag and data memory<br>location 'f'. If 'd' is '0', the result is<br>placed in W. If 'd' is '1', the result is<br>placed in data memory location 'f'.<br>If 'a' is '0', the Access Bank is selected.<br>If 'a' is '1', the BSR is used to select the<br>GPR bank (default).<br>If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operates<br>in Indexed Literal Offset Addressing<br>mode whenever $f \le 95$ (5Fh). See<br>Section 22.2.3 "Byte-Oriented and<br>Bit-Oriented Instructions in Indexed<br>Literal Offset Mode" for details |                      |     |                      |      |  |  |  |
| Words:                                                      | 1                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                      |     |                      |      |  |  |  |
| Cycles:                                                     | 1                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                      |     |                      |      |  |  |  |
| Q Cycle Activity:                                           |                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                      |     |                      |      |  |  |  |
| Q1                                                          |                                                                                               | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Q3                   |     |                      | Q4   |  |  |  |
| Decode                                                      | l<br>reg                                                                                      | Read<br>gister 'f'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Process<br>Data      |     | Write to destination |      |  |  |  |
| Example:                                                    |                                                                                               | DDWFC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | REG,                 | 0,  | 1                    |      |  |  |  |
| Before Instruc<br>Carry bit<br>REG<br>W<br>After Instructio | tion<br>=<br>=<br>n                                                                           | 1<br>02h<br>4Dh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                      |     |                      |      |  |  |  |
| REG<br>W                                                    | =                                                                                             | 02h<br>50h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |     |                      |      |  |  |  |

| AND                      | DLW            | AND Lit                   | AND Literal with W           |                    |                            |  |  |  |  |  |
|--------------------------|----------------|---------------------------|------------------------------|--------------------|----------------------------|--|--|--|--|--|
| Synta                    | ax:            | ANDLW                     | ANDLW k                      |                    |                            |  |  |  |  |  |
| Operands:                |                | $0 \le k \le 25$          | $0 \leq k \leq 255$          |                    |                            |  |  |  |  |  |
| Oper                     | ation:         | (W) .AND                  | ). k → W                     |                    |                            |  |  |  |  |  |
| Statu                    | is Affected:   | N, Z                      |                              |                    |                            |  |  |  |  |  |
| Enco                     | oding:         | 0000                      | 1011                         | kkk                | k kkkk                     |  |  |  |  |  |
| Desc                     | cription:      | The conte<br>8-bit litera | ents of W a<br>al 'k'. The r | are AN<br>esult is | Ded with the s placed in W |  |  |  |  |  |
| Words:                   |                | 1                         |                              |                    |                            |  |  |  |  |  |
| Cycle                    | es:            | 1                         |                              |                    |                            |  |  |  |  |  |
| QC                       | ycle Activity: |                           |                              |                    |                            |  |  |  |  |  |
|                          | Q1             | Q2                        | Q                            | 3                  | Q4                         |  |  |  |  |  |
|                          | Decode         | Read litera<br>'k'        | I Proce<br>Dat               | ess<br>a           | Write to W                 |  |  |  |  |  |
| Example:                 |                | ANDLW                     | 05Fh                         |                    |                            |  |  |  |  |  |
| Before Instruction       |                | tion                      |                              |                    |                            |  |  |  |  |  |
| W =<br>After Instruction |                | = A3h                     |                              |                    |                            |  |  |  |  |  |
|                          |                | on                        |                              |                    |                            |  |  |  |  |  |
|                          | W              | = 03h                     |                              |                    |                            |  |  |  |  |  |
|                          |                |                           |                              |                    |                            |  |  |  |  |  |

## 23.11 PICSTART Plus Development Programmer

The PICSTART Plus Development Programmer is an easy-to-use, low-cost, prototype programmer. It connects to the PC via a COM (RS-232) port. MPLAB Integrated Development Environment software makes using the programmer simple and efficient. The PICSTART Plus Development Programmer supports most PIC devices in DIP packages up to 40 pins. Larger pin count devices, such as the PIC16C92X and PIC17C76X, may be supported with an adapter socket. The PICSTART Plus Development Programmer is CE compliant.

## 23.12 PICkit 2 Development Programmer

The PICkit<sup>™</sup> 2 Development Programmer is a low-cost programmer and selected Flash device debugger with an easy-to-use interface for programming many of Microchip's baseline, mid-range and PIC18F families of Flash memory microcontrollers. The PICkit 2 Starter Kit includes a prototyping development board, twelve sequential lessons, software and HI-TECH's PICC<sup>™</sup> Lite C compiler, and is designed to help get up to speed quickly using PIC<sup>®</sup> microcontrollers. The kit provides everything needed to program, evaluate and develop applications using Microchip's powerful, mid-range Flash memory family of microcontrollers.

## 23.13 Demonstration, Development and Evaluation Boards

A wide variety of demonstration, development and evaluation boards for various PIC MCUs and dsPIC DSCs allows quick application development on fully functional systems. Most boards include prototyping areas for adding custom circuitry and provide application firmware and source code for examination and modification.

The boards support a variety of features, including LEDs, temperature sensors, switches, speakers, RS-232 interfaces, LCD displays, potentiometers and additional EEPROM memory.

The demonstration and development boards can be used in teaching environments, for prototyping custom circuits and for learning about various microcontroller applications.

In addition to the PICDEM<sup>™</sup> and dsPICDEM<sup>™</sup> demonstration/development board series of circuits, Microchip has a line of evaluation kits and demonstration software for analog filter design, KEELOQ<sup>®</sup> security ICs, CAN, IrDA<sup>®</sup>, PowerSmart battery management, SEEVAL<sup>®</sup> evaluation system, Sigma-Delta ADC, flow rate sensing, plus many more.

Check the Microchip web page (www.microchip.com) for the complete list of demonstration, development and evaluation kits.

| DC CHARACTERISTICS |        |                                                      | Standard Operating Conditions (unless otherwise stated)<br>Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial |          |       |                                                    |  |
|--------------------|--------|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|----------|-------|----------------------------------------------------|--|
| Param<br>No.       | Symbol | Characteristic                                       | Min                                                                                                                                    | Мах      | Units | Conditions                                         |  |
|                    | VIL    | Input Low Voltage                                    |                                                                                                                                        |          |       |                                                    |  |
|                    |        | All I/O Ports:                                       |                                                                                                                                        |          |       |                                                    |  |
| D030               |        | with TTL Buffer                                      | Vss                                                                                                                                    | 0.15 Vdd | V     | VDD < 3.3V                                         |  |
| D030A              |        |                                                      |                                                                                                                                        | 0.8      | V     | $3.3V \le VDD \le 3.6V$                            |  |
| D031               |        | with Schmitt Trigger Buffer                          | Vss                                                                                                                                    | 0.2 Vdd  | V     |                                                    |  |
| D032               |        | MCLR                                                 | Vss                                                                                                                                    | 0.2 VDD  | V     |                                                    |  |
| D033               |        | OSC1                                                 | Vss                                                                                                                                    | 0.3 VDD  | V     | HS, HSPLL modes                                    |  |
| D033A              |        | OSC1                                                 | Vss                                                                                                                                    | 0.2 VDD  | V     | EC, ECPLL modes <sup>(1)</sup>                     |  |
| D034               |        | T1CKI                                                | Vss                                                                                                                                    | 0.3      | V     |                                                    |  |
|                    | VIH    | Input High Voltage                                   |                                                                                                                                        |          |       |                                                    |  |
|                    |        | I/O Ports with non 5.5V<br>Tolerance: <sup>(4)</sup> |                                                                                                                                        |          |       |                                                    |  |
| D040               |        | with TTL Buffer                                      | 0.25 VDD + 0.8V                                                                                                                        | Vdd      | V     | Vdd < 3.3V                                         |  |
| D040A              |        |                                                      | 2.0                                                                                                                                    | Vdd      | V     | $3.3V \leq V\text{DD} \leq 3.6V$                   |  |
| D041               |        | with Schmitt Trigger Buffer                          | 0.8 Vdd                                                                                                                                | Vdd      | V     |                                                    |  |
|                    |        | I/O Ports with 5.5V<br>Tolerance: <sup>(4)</sup>     |                                                                                                                                        |          |       |                                                    |  |
| Dxxx               |        | with TTL Buffer                                      | 0.25 VDD + 0.8V                                                                                                                        | 5.5      | V     | Vdd < 3.3V                                         |  |
| DxxxA              |        |                                                      | 2.0                                                                                                                                    | 5.5      | V     | $3.3V \leq V\text{DD} \leq 3.6V$                   |  |
| Dxxx               |        | with Schmitt Trigger Buffer                          | 0.8 Vdd                                                                                                                                | 5.5      | V     |                                                    |  |
| D042               |        | MCLR                                                 | 0.8 Vdd                                                                                                                                | Vdd      | V     |                                                    |  |
| D043               |        | OSC1                                                 | 0.7 Vdd                                                                                                                                | Vdd      | V     | HS, HSPLL modes                                    |  |
| D043A              |        | OSC1                                                 | 0.8 Vdd                                                                                                                                | Vdd      | V     | EC, ECPLL modes                                    |  |
| D044               |        | т1СКІ                                                | 1.6                                                                                                                                    | Vdd      | V     |                                                    |  |
|                    | lı∟    | Input Leakage Current <sup>(2,3)</sup>               |                                                                                                                                        |          |       |                                                    |  |
| D060               |        | I/O Ports with non 5.5V<br>Tolerance <sup>(4)</sup>  | —                                                                                                                                      | ±0.2     | μA    | $Vss \le VPIN \le VDD,$ Pin at high-impedance      |  |
| D060A              |        | I/O Ports with 5.5V<br>Tolerance <sup>(4)</sup>      | —                                                                                                                                      | ±0.2     | μA    | Vss $\leq$ VPIN $\leq$ 5.5V, Pin at high-impedance |  |
| D061               |        | MCLR                                                 |                                                                                                                                        | ±0.2     | μA    | $Vss \leq V PIN \leq V DD$                         |  |
| D063               |        | OSC1                                                 |                                                                                                                                        | ±0.2     | μA    | $Vss \leq V PIN \leq V DD$                         |  |
|                    | IPU    | Weak Pull-up Current                                 |                                                                                                                                        |          |       |                                                    |  |
| D070               | IPURB  | PORTB Weak Pull-up Current                           | 30                                                                                                                                     | 240      | μA    | VDD = 3.3V, VPIN = VSS                             |  |

## 24.3 DC Characteristics: PIC18F45J10 Family (Industrial)

**Note 1:** In RC oscillator configuration, the OSC1/CLKI pin is a Schmitt Trigger input. It is not recommended that the PIC<sup>®</sup> device be driven with an external clock while in RC mode.

2: The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages.

**3:** Negative current is defined as current sourced by the pin.

4: Refer to Table 10-2 for the pins that have corresponding tolerance limits.

## Package Marking Information (Continued)

40-Lead PDIP



### 44-Lead QFN



Example



## Example



44-Lead TQFP



Example

