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 - Microcontrollers</u>" | Details | | |----------------------------|----------------------------------------------------------------------------| | Product Status | Active | | Core Processor | PIC | | Core Size | 8-Bit | | Speed | 40MHz | | Connectivity | EBI/EMI, I²C, SPI, UART/USART | | Peripherals | Brown-out Detect/Reset, HLVD, POR, PWM, WDT | | Number of I/O | 70 | | Program Memory Size | 128KB (64K x 16) | | Program Memory Type | FLASH | | EEPROM Size | 1K x 8 | | RAM Size | 3.8K x 8 | | Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V | | Data Converters | A/D 16x12b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 80-TQFP | | Supplier Device Package | 80-TQFP (12x12) | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf8723-i-pt | # PIC18F8723 ## **Table of Contents** | 1.0 | Device Overview | 9 | |-------|------------------------------------------------------|------| | 2.0 | 12-Bit Analog-to-Digital Converter (A/D) Module | . 31 | | 3.0 | Special Features of the CPU | . 41 | | 4.0 | Electrical Characteristics | . 43 | | 5.0 | Packaging Information | | | Appe | ndix A: Revision History | . 51 | | | ndix B: Device Differences | | | Appe | ndix C: Conversion Considerations | . 52 | | Appe | ndix D: Migration From Baseline to Enhanced Devices | . 52 | | Appe | ndix E: Migration From Mid-Range to Enhanced Devices | . 53 | | Appe | ndix F: Migration From High-End to Enhanced Devices | . 53 | | | | | | | /licrochip Web Site | | | Custo | mer Change Notification Service | . 57 | | Custo | mer Support | . 57 | | Read | omer Supporter Response | . 58 | | | 3F8723 family Product Identification System | | TABLE 1-1: DEVICE FEATURES | | | | | · | | |---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--| | Features | PIC18F6628 | PIC18F6723 | PIC18F8628 | PIC18F8723 | | | Operating Frequency | DC – 40 MHz | DC – 40 MHz | DC – 40 MHz | DC – 40 MHz | | | Program Memory (Bytes) | 96K | 128K | 96K | 128K | | | Program Memory (Instructions) | 49152 | 65536 | 49152 | 65536 | | | Data Memory (Bytes) | 3936 | 3936 | 3936 | 3936 | | | Data EEPROM Memory (Bytes) | 1024 | 1024 | 1024 | 1024 | | | Interrupt Sources | 28 | 28 | 29 | 29 | | | I/O Ports | Ports A, B, C, D, E, F, G | Ports A, B, C, D, E, F, G | Ports A, B, C, D, E,<br>F, G, H, J | Ports A, B, C, D, E,<br>F, G, H, J | | | Timers | 5 | 5 | 5 | 5 | | | Capture/Compare/PWM<br>Modules | 2 | 2 | 2 | 2 | | | Enhanced Capture/Compare/<br>PWM Modules | 3 | 3 | 3 | 3 | | | Enhanced USART | 2 | 2 | 2 | 2 | | | Serial Communications | MSSP,<br>Enhanced USART | MSSP,<br>Enhanced USART | MSSP,<br>Enhanced USART | MSSP,<br>Enhanced USART | | | Parallel Communications (PSP) | Yes | Yes | Yes | Yes | | | 12-Bit Analog-to-Digital Module | 12 Input Channels | 12 Input Channels | 16 Input Channels | 16 Input Channels | | | Resets (and Delays) | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | | | Programmable<br>High/Low-Voltage Detect | | | Yes | Yes | | | Programmable Brown-out<br>Reset | Yes | Yes | Yes | Yes | | | Instruction Set 75 Instructions; 83 with Extended Instruction Set Enabled | | 75 Instructions;<br>83 with Extended<br>Instruction Set Enabled | 75 Instructions;<br>83 with Extended<br>Instruction Set Enabled | 75 Instructions;<br>83 with Extended<br>Instruction Set Enabled | | | Packages | 64-Pin TQFP | 64-Pin TQFP | 80-Pin TQFP | 80-Pin TQFP | | TABLE 1-2: PIC18F6628/6723 (64-PIN) PINOUT I/O DESCRIPTIONS | Pin Name | Pin Number | Pin | Buffer | Description | |-----------------------------|------------|------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pili Name | TQFP | Туре | Туре | Description | | RG5/MCLR/VPP<br>RG5<br>MCLR | 7 | <br> | ST<br>ST | Master Clear (input) or programming voltage (input). Digital input. Master Clear (Reset) input. This pin is an active-low Reset to the device. | | VPP | | Р | | Programming voltage input. | | OSC1/CLKI/RA7<br>OSC1 | 39 | I | ST | Oscillator crystal or external clock input. Oscillator crystal input or external clock source input. ST buffer when configured in RC mode, CMOS otherwise. | | CLKI | | I | CMOS | External clock source input. Always associated with pin function OSC1. (See related OSC1/CLKI, OSC2/CLKO pins.) | | RA7 | | I/O | TTL | General purpose I/O pin. | | OSC2/CLKO/RA6<br>OSC2 | 40 | 0 | _ | Oscillator crystal or clock output. Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode. | | CLKO | | 0 | _ | In RC mode, OSC2 pin outputs CLKO, which has 1/4 the frequency of OSC1 and denotes the instruction cycle rate. | | RA6 | | I/O | TTL | General purpose I/O pin. | **Legend:** TTL = TTL compatible input ST = Schmitt Trigger input with CMOS levels I = Input P = Power CMOS = CMOS compatible input or output Analog = Analog input O = Output $I^2C^{TM} = I^2C/SMBus$ input buffer Note 1: Default assignment for ECCP2 when Configuration bit, CCP2MX, is set. **2:** Alternate assignment for ECCP2 when Configuration bit, CCP2MX, is cleared. TABLE 1-2: PIC18F6628/6723 (64-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Din Nome | Pin Number | Pin | Buffer | Description | |----------------------------------------------|------------|---------------|----------------|-------------------------------------------------------------------------------------| | Pin Name | TQFP | Type | Type | Description | | | | | | PORTE is a bidirectional I/O port. | | RE0/RD/P2D<br>RE0<br>RD<br>P2D | 2 | I/O<br>I<br>O | ST<br>TTL<br>— | Digital I/O.<br>Read control for Parallel Slave Port.<br>ECCP2 PWM output D. | | RE1/WR/P2C<br>RE1<br>WR<br>P2C | 1 | I/O<br>I<br>O | ST<br>TTL<br>— | Digital I/O. Write control for Parallel Slave Port. ECCP2 PWM output C. | | RE2/CS/P2B<br>RE2<br>CS<br>P2B | 64 | I/O<br>I<br>O | ST<br>TTL<br>— | Digital I/O.<br>Chip select control for Parallel Slave Port.<br>ECCP2 PWM output B. | | RE3/P3C<br>RE3<br>P3C | 63 | I/O<br>O | ST<br>— | Digital I/O.<br>ECCP3 PWM output C. | | RE4/P3B<br>RE4<br>P3B | 62 | I/O<br>O | ST<br>— | Digital I/O.<br>ECCP3 PWM output B. | | RE5/P1C<br>RE5<br>P1C | 61 | I/O<br>O | ST<br>— | Digital I/O.<br>ECCP1 PWM output C. | | RE6/P1B<br>RE6<br>P1B | 60 | I/O<br>O | ST<br>— | Digital I/O.<br>ECCP1 PWM output B. | | RE7/ECCP2/P2A<br>RE7<br>ECCP2 <sup>(2)</sup> | 59 | I/O<br>I/O | ST<br>ST | Digital I/O. Enhanced Capture 2 input/Compare 2 output/ PWM2 output. | | P2A <sup>(2)</sup> | | 0 | _ | ECCP2 PWM output A. | Legend: TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels Analog = Analog input I = Input P = Power O = Output $I^2C^{TM}$ = $I^2C/SMBus$ input buffer Note 1: Default assignment for ECCP2 when Configuration bit, CCP2MX, is set. **2:** Alternate assignment for ECCP2 when Configuration bit, CCP2MX, is cleared. TABLE 1-3: PIC18F8628/8723 (80-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Dis Nove | Pin Number | Pin | Buffer | Donatistics. | |------------------------------------------------------------------|------------|--------------------------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pin Name | TQFP | Туре | Туре | Description | | | | | | PORTD is a bidirectional I/O port. | | RD0/AD0/PSP0<br>RD0<br>AD0<br>PSP0 | 72 | I/O<br>I/O<br>I/O | ST<br>TTL<br>TTL | Digital I/O.<br>External memory address/data 0.<br>Parallel Slave Port data. | | RD1/AD1/PSP1<br>RD1<br>AD1<br>PSP1 | 69 | I/O<br>I/O<br>I/O | ST<br>TTL<br>TTL | Digital I/O.<br>External memory address/data 1.<br>Parallel Slave Port data. | | RD2/AD2/PSP2<br>RD2<br>AD2<br>PSP2 | 68 | I/O<br>I/O<br>I/O | ST<br>TTL<br>TTL | Digital I/O.<br>External memory address/data 2.<br>Parallel Slave Port data. | | RD3/AD3/PSP3<br>RD3<br>AD3<br>PSP3 | 67 | I/O<br>I/O<br>I/O | ST<br>TTL<br>TTL | Digital I/O.<br>External memory address/data 3.<br>Parallel Slave Port data. | | RD4/AD4/PSP4/SDO2<br>RD4<br>AD4<br>PSP4<br>SDO2 | 66 | I/O<br>I/O<br>I/O<br>O | ST<br>TTL<br>TTL | Digital I/O.<br>External memory address/data 4.<br>Parallel Slave Port data.<br>SPI data out. | | RD5/AD5/PSP5/<br>SDI2/SDA2<br>RD5<br>AD5<br>PSP5<br>SDI2<br>SDA2 | 65 | I/O<br>I/O<br>I/O<br>I | ST<br>TTL<br>TTL<br>ST<br>I <sup>2</sup> C/SMB | Digital I/O.<br>External memory address/data 5.<br>Parallel Slave Port data.<br>SPI data in.<br>I <sup>2</sup> C™ data I/O. | | RD6/AD6/PSP6/<br>SCK2/SCL2<br>RD6<br>AD6<br>PSP6<br>SCK2<br>SCL2 | 64 | I/O<br>I/O<br>I/O<br>I/O | ST<br>TTL<br>TTL<br>ST<br>I <sup>2</sup> C/SMB | Digital I/O.<br>External memory address/data 6.<br>Parallel Slave Port data.<br>Synchronous serial clock input/output for SPI mode.<br>Synchronous serial clock input/output for I <sup>2</sup> C mode. | | RD7/AD7/PSP7/SS2<br>RD7<br>AD7<br>PSP7<br>SS2 | 63 | I/O<br>I/O<br>I/O | ST<br>TTL<br>TTL<br>TTL | Digital I/O.<br>External memory address/data 7.<br>Parallel Slave Port data.<br>SPI slave select input. | **Legend:** TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels Analog I = Input O O = Output P = Power $I^2C^{TM}/SMB = I^2C/SMBus$ input buffer = Analog input **Note 1:** Alternate assignment for ECCP2 when Configuration bit, CCP2MX, is cleared (all operating modes except Microcontroller mode). - 2: Default assignment for ECCP2 in all operating modes (CCP2MX is set). - 3: Alternate assignment for ECCP2 when CCP2MX is cleared (Microcontroller mode only). - 4: Default assignment for P1B/P1C/P3B/P3C (ECCPMX is set). - **5:** Alternate assignment for P1B/P1C/P3B/P3C (ECCPMX is clear). TABLE 1-3: PIC18F8628/8723 (80-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin Number | Pin | Buffer | Description | |------------------------------------|------------|-----------------|----------------|----------------------------------------------------------------------------------------------| | Pili Name | TQFP | Type | Туре | Description | | | | | | PORTG is a bidirectional I/O port. | | RG0/ECCP3/P3A<br>RG0<br>ECCP3 | 5 | I/O<br>I/O | ST<br>ST | Digital I/O. Enhanced Capture 3 input/Compare 3 output/ PWM3 output. | | P3A | | 0 | _ | ECCP3 PWM output A. | | RG1/TX2/CK2<br>RG1<br>TX2<br>CK2 | 6 | I/O<br>O<br>I/O | ST<br>—<br>ST | Digital I/O. EUSART2 asynchronous transmit. EUSART2 synchronous clock (see related RX2/DT2). | | RG2/RX2/DT2<br>RG2<br>RX2<br>DT2 | 7 | I/O<br>I<br>I/O | ST<br>ST<br>ST | Digital I/O. EUSART2 asynchronous receive. EUSART2 synchronous data (see related TX2/CK2). | | RG3/CCP4/P3D<br>RG3<br>CCP4<br>P3D | 8 | I/O<br>I/O<br>O | ST<br>ST | Digital I/O. Capture 4 input/Compare 4 output/PWM4 output. ECCP3 PWM output D. | | RG4/CCP5/P1D<br>RG4<br>CCP5<br>P1D | 10 | I/O<br>I/O<br>O | ST<br>ST<br>— | Digital I/O.<br>Capture 5 input/Compare 5 output/PWM5 output.<br>ECCP1 PWM output D. | | RG5 | | | | See RG5/MCLR/VPP pin. | **Legend:** TTL = TTL compatible input ST = Schmitt Trigger input with CMOS levels I = Input P = Power CMOS = CMOS compatible input or output Analog = Analog input O = Output $I^{2}C^{TM}/SMB = I^{2}C/SMBus$ input buffer **Note 1:** Alternate assignment for ECCP2 when Configuration bit, CCP2MX, is cleared (all operating modes except Microcontroller mode). - 2: Default assignment for ECCP2 in all operating modes (CCP2MX is set). - 3: Alternate assignment for ECCP2 when CCP2MX is cleared (Microcontroller mode only). - 4: Default assignment for P1B/P1C/P3B/P3C (ECCPMX is set). - 5: Alternate assignment for P1B/P1C/P3B/P3C (ECCPMX is clear). ### REGISTER 2-2: ADCON1: A/D CONTROL REGISTER 1 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-------|-------|-------|-------|-------|-------| | _ | _ | VCFG1 | VCFG0 | PCFG3 | PCFG2 | PCFG1 | PCFG0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 7-6 **Unimplemented:** Read as '0' bit 5-4 VCFG1:VCFG0: Voltage Reference Configuration bits | | A/D VREF+ | A/D VREF- | | | |-----|----------------|----------------|--|--| | 0.0 | AVDD | AVss | | | | 01 | External VREF+ | AVss | | | | 10 | AVDD | External VREF- | | | | 11 | External VREF+ | External VREF- | | | ### bit 3-0 **PCFG3:PCFG0:** A/D Port Configuration Control bits: | PCFG<3:0> | AN15 <sup>(1)</sup> | AN14 <sup>(1)</sup> | AN13 <sup>(1)</sup> | AN12 <sup>(1)</sup> | AN11 | AN10 | AN9 | AN8 | AN7 | AN6 | AN5 | AN4 | AN3 | AN2 | AN1 | ANO | |-----------|---------------------|---------------------|---------------------|---------------------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0000 | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0001 | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0010 | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0011 | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0100 | D | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0101 | D | D | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0110 | D | D | D | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0111 | D | D | D | D | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | | 1000 | D | D | D | D | D | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | | 1001 | D | D | D | D | D | D | D | D | D | D | Α | Α | Α | Α | Α | Α | | 1010 | D | D | D | D | D | D | D | D | D | D | D | Α | Α | Α | Α | Α | | 1011 | D | D | D | D | D | D | D | D | D | D | D | D | Α | Α | Α | Α | | 1100 | D | D | D | D | D | D | D | D | D | D | D | D | D | Α | Α | Α | | 1101 | D | D | D | D | D | D | D | D | D | D | D | D | D | D | Α | Α | | 1110 | D | D | D | D | D | D | D | D | D | D | D | D | D | D | D | Α | | 1111 | D | D | D | D | D | D | D | D | D | D | D | D | D | D | D | D | A = Analog input D = Digital I/O Note 1: AN15 through AN12 are available only on PIC18F8628/8723 devices. #### REGISTER 2-3: ADCON2: A/D CONTROL REGISTER 2 | 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 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 **ADFM:** A/D Result Format Select bit 1 = Right justified0 = Left justified Unimplemented: Read as '0' bit 5-3 ACQT2:ACQT0: A/D Acquisition Time Select bits 111 = 20 TAD 110 = 16 TAD 101 = 12 TAD 100 = 8 TAD 011 = 6 TAD 010 = 4 TAD bit 6 001 = 2 TAD $000 = 0 \text{ TAD}^{(1)}$ bit 2-0 ADCS2:ADCS0: A/D Conversion Clock Select bits 111 = FRC (clock derived from A/D RC oscillator)(1) 110 = Fosc/64 101 = Fosc/16 100 = Fosc/4 011 = FRC (clock derived from A/D RC oscillator)(1) 010 = Fosc/32 001 = Fosc/8 000 = Fosc/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. The analog reference voltage is software selectable to either the device's positive and negative supply voltage (VDD and VSS), or the voltage level on the RA3/AN3/ VREF+ and RA2/AN2/VREF-/CVREF pins. The A/D Converter has a unique feature of being able to operate while the device is in Sleep mode. To operate in Sleep, the A/D conversion clock must be derived from the A/D's internal RC oscillator. The output of the sample and hold is the input into the converter, which generates the result via successive approximation. A device Reset forces all registers to their Reset state. This forces the A/D module to be turned off and any conversion in progress is aborted. Each port pin associated with the A/D Converter can be configured as an analog input or a digital I/O. The ADRESH and ADRESL registers contain the result of the A/D conversion. When the A/D conversion is complete, the result is loaded into the ADRESH:ADRESL register pair, the GO/DONE bit (ADCON0<1>) is cleared and the A/D Interrupt Flag bit, ADIF, is set. The block diagram of the A/D module is shown in Figure 2-1. FIGURE 2-1: A/D BLOCK DIAGRAM # 2.2 Selecting and Configuring Acquisition Time The ADCON2 register allows the user to select an acquisition time that occurs each time the GO/DONE bit is set. It also gives users the option to use an automatically determined acquisition time. Acquisition time may be set with the ACQT2:ACQT0 bits (ADCON2<5:3>), which provide a range of 2 to 20 TAD. When the GO/DONE bit is set, the A/D module continues to sample the input for the selected acquisition time, then automatically begins a conversion. Since the acquisition time is programmed, there may be no need to wait for an acquisition time between selecting a channel and setting the GO/DONE bit. Manual acquisition is selected when ACQT2:ACQT0 = 000. When the GO/DONE bit is set, sampling is stopped and a conversion begins. The user is responsible for ensuring the required acquisition time has passed between selecting the desired input channel and setting the GO/DONE bit. This option is also the default Reset state of the ACQT2:ACQT0 bits and is compatible with devices that do not offer programmable acquisition times. In either case, when the conversion is completed, the GO/DONE bit is cleared, the ADIF flag is set and the A/D begins sampling the currently selected channel again. If an acquisition time is programmed, there is nothing to indicate if the acquisition time has ended or if the conversion has begun. # 2.3 Selecting the A/D Conversion Clock The A/D conversion time per bit is defined as TAD. The A/D conversion requires 13 TAD per 12-bit conversion. The source of the A/D conversion clock is software selectable. There are seven possible options for TAD: - 2 Tosc - 4 Tosc - 8 Tosc - 16 Tosc - 32 Tosc - 64 Tosc - Internal RC Oscillator For correct A/D conversions, the A/D conversion clock (TAD) must be as short as possible, but greater than the minimum TAD (see parameter 130 for more information). Table 2-1 shows the resultant TAD times derived from the device operating frequencies and the A/D clock source selected. TABLE 2-1: TAD vs. DEVICE OPERATING FREQUENCIES | A/D Clock So | A/D Clock Source (TAD) | | | | | | |-------------------|------------------------|-------------------------|--|--|--|--| | Operation | ADCS2:ADCS0 | Maximum Fosc | | | | | | 2 Tosc | 000 | 2.50 MHz | | | | | | 4 Tosc | 100 | 5.00 MHz | | | | | | 8 Tosc | 001 | 10.00 MHz | | | | | | 16 Tosc | 101 | 20.00 MHz | | | | | | 32 Tosc | 010 | 40.00 MHz | | | | | | 64 Tosc | 110 | 40.00 MHz | | | | | | RC <sup>(1)</sup> | x11 | 1.00 MHz <sup>(2)</sup> | | | | | - **Note 1:** The RC source has a typical TAD time of 2.5 $\mu$ s. - 2: For device frequencies above 1 MHz, the device must be in Sleep for the entire conversion or a Fosc divider should be used instead; otherwise, the A/D accuracy specification may not be met. #### 2.6 A/D Conversions Figure 2-4 shows the operation of the A/D Converter after the GO/DONE bit has been set and the ACQT2:ACQT0 bits are cleared. A conversion is started after the following instruction to allow entry into Sleep mode before the conversion begins. Figure 2-5 shows the operation of the A/D Converter after the GO/DONE bit has been set, the ACQT2:ACQT0 bits are set to '010' and a 4 TAD acquisition time has been selected before the conversion starts. Clearing the GO/DONE bit during a conversion will abort the current conversion. The A/D Result register pair will NOT be updated with the partially completed A/D conversion sample. This means the ADRESH:ADRESL registers will continue to contain the value of the last completed conversion (or the last value written to the ADRESH:ADRESL registers). After the A/D conversion is completed or aborted, a 2 Tcy wait is required before the next acquisition can be started. After this wait, acquisition on the selected channel is automatically started. Note: The GO/DONE bit should NOT be set in the same instruction that turns on the A/D. Code should wait at least 2 μs after enabling the A/D before beginning an acquisition and conversion cycle. ### 2.7 Discharge The discharge phase is used to initialize the value of the holding capacitor. The array is discharged before every sample. This feature helps to optimize the unity gain amplifier, as the circuit always needs to charge the capacitor array, rather than charge/discharge based on previous measure values. ### FIGURE 2-4: A/D CONVERSION TAD CYCLES (ACQT<2:0> = 000, TACQ = 0) #### FIGURE 2-5: A/D CONVERSION TAD CYCLES (ACQT<2:0> = 010, TACQ = 4 TAD) ### 2.8 Use of the ECCP2 Trigger An A/D conversion can be started by the Special Event Trigger of the ECCP2 module. This requires that the CCP2M3:CCP2M0 bits (CCP2CON<3:0>) be programmed as '1011' and that the A/D module is enabled (ADON bit is set). When the trigger occurs, the GO/DONE bit will be set, starting the A/D acquisition and conversion, and the Timer1 (or Timer3) counter will be reset to zero. Timer1 (or Timer3) is reset to automatically repeat the A/D acquisition period with minimal software overhead (moving ADRESH:ADRESL to the desired location). The appropriate analog input channel must be selected and the minimum acquisition period is either timed by the user, or an appropriate TACQ time selected before the Special Event Trigger sets the GO/DONE bit (starts a conversion). If the A/D module is not enabled (ADON is cleared), the Special Event Trigger will be ignored by the A/D module but will still reset the Timer1 (or Timer3) counter. TABLE 2-2: REGISTERS ASSOCIATED WITH A/D OPERATION | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset<br>Values | |----------------------|-------------------------------|-----------------------|--------|--------|--------|--------|---------|--------|-----------------| | INTCON | GIE/GIEH | PEIE/GIEL | TMR0IE | INT0IE | RBIE | TMR0IF | INT0IF | RBIF | (3) | | PIR1 | PSPIF | ADIF | RC1IF | TX1IF | SSP1IF | CCP1IF | TMR2IF | TMR1IF | (3) | | PIE1 | PSPIE | ADIE | RC1IE | TX1IE | SSP1IE | CCP1IE | TMR2IE | TMR1IE | (3) | | IPR1 | PSPIP | ADIP | RC1IP | TX1IP | SSP1IP | CCP1IP | TMR2IP | TMR1IP | (3) | | PIR2 | OSCFIF | CMIF | _ | EEIF | BCL1IF | HLVDIF | TMR3IF | CCP2IF | (3) | | PIE2 | OSCFIE | CMIE | _ | EEIE | BCL1IE | HLVDIE | TMR3IE | CCP2IE | (3) | | IPR2 | OSCFIP | CMIP | _ | EEIP | BCL1IP | HLVDIP | TMR3IP | CCP2IP | (3) | | ADRESH | A/D Result Register High Byte | | | | | | | | | | ADRESL | A/D Result Register Low Byte | | | | | | | | (3) | | ADCON0 | _ | _ | CHS3 | CHS2 | CHS1 | CHS0 | GO/DONE | ADON | (3) | | ADCON1 | _ | _ | VCFG1 | VCFG0 | PCFG3 | PCFG2 | PCFG1 | PCFG0 | (3) | | ADCON2 | ADFM | _ | ACQT2 | ACQT1 | ACQT0 | ADCS2 | ADCS1 | ADCS0 | (3) | | TRISA | TRISA7 <sup>(1)</sup> | TRISA6 <sup>(1)</sup> | TRISA5 | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 | (3) | | TRISF | TRISF7 | TRISF6 | TRISF5 | TRISF4 | TRISF3 | TRISF2 | TRISF1 | TRISF0 | (3) | | TRISH <sup>(2)</sup> | TRISH7 | TRISH6 | TRISH5 | TRISH4 | TRISH3 | TRISH2 | TRISH1 | TRISH0 | (3) | **Legend:** — = unimplemented, read as '0'. Shaded cells are not used for A/D conversion. **Note 1:** PORTA<7:6> and their direction bits are individually configured as port pins based on various primary oscillator modes. When disabled, these bits read as '0'. - 2: These registers are not implemented on PIC18F6628/6723 devices. - 3: For these Reset values, see the "PIC18F8722 Family Data Sheet" (DS39646). ### REGISTER 3-1: DEVID1: DEVICE ID REGISTER 1 FOR PIC18F8723 FAMILY DEVICES | R | R | R | R | R | R | R | R | |-------|------|------|------|------|------|------|-------| | DEV2 | DEV1 | DEV0 | REV4 | REV3 | REV2 | REV1 | REV0 | | bit 7 | | | | | | | bit 0 | Legend: R = Read-only bit P = Programmable bit U = Unimplemented bit, read as '0' -n = Value when device is unprogrammed u = Unchanged from programmed state bit 7-5 **DEV2:DEV0:** Device ID bits See Register 3-2 for a complete listing. bit 4-0 **REV4:REV0:** Revision ID bits These bits are used to indicate the device revision. #### REGISTER 3-2: DEVID2: DEVICE ID REGISTER 2 FOR PIC18F8723 FAMILY DEVICES | R | R | R | R | R | R | R | R | |-------|------|------|------|------|------|------|-------| | DEV10 | DEV9 | DEV8 | DEV7 | DEV6 | DEV5 | DEV4 | DEV3 | | bit 7 | | | | | | | bit 0 | Legend: R = Read-only bit P = Programmable bit U = Unimplemented bit, read as '0' -n = Value when device is unprogrammed u = Unchanged from programmed state ### bit 7-0 **DEV10:DEV3:** Device ID bits | DEV10:DEV3<br>(DEVID2<7:0>) | DEV2:DEV0<br>(DEVID1<7:5>) | Device | |-----------------------------|----------------------------|------------| | 0100 1001 | 110 | PIC18F6628 | | 0100 1010 | 000 | PIC18F6723 | | 0100 1001 | 111 | PIC18F8628 | | 0100 1010 | 001 | PIC18F8723 | FIGURE 4-1: PIC18F8723 FAMILY VOLTAGE-FREQUENCY GRAPH (INDUSTRIAL) FIGURE 4-2: PIC18F8723 FAMILY VOLTAGE-FREQUENCY GRAPH (EXTENDED) FIGURE 4-4: A/D CONVERSION TIMING TABLE 4-2: A/D CONVERSION REQUIREMENTS | Param<br>No. | Symbol | Characte | Min | Max | Units | Conditions | | |--------------|--------|-----------------------------------------------------------------|----------------------|----------|---------------------|------------|--------------------------------------------------------------------| | 130 | TAD | A/D Clock Period | PIC18 <b>F</b> XXXX | 0.8 | 12.5 <sup>(1)</sup> | μS | Tosc based, VREF ≥ 3.0V | | | | | PIC18 <b>LF</b> XXXX | 1.4 | 25.0 <sup>(1)</sup> | μS | V <sub>DD</sub> = 3.0V;<br>Tosc based, V <sub>REF</sub> full range | | | | | PIC18FXXXX | _ | 1 | μS | A/D RC mode | | | | | PIC18 <b>LF</b> XXXX | _ | 3 | μS | VDD = 3.0V; A/D RC mode | | 131 | TCNV | Conversion Time (not including acquisition time) <sup>(2)</sup> | | 13 | 14 | TAD | | | 132 | TACQ | Acquisition Time <sup>(3)</sup> | 1.4 | _ | μS | | | | 135 | Tswc | Switching Time from Co | _ | (Note 4) | | | | | 137 | TDIS | Discharge Time | | 0.2 | _ | μS | | Note 1: The time of the A/D clock period is dependent on the device frequency and the TAD clock divider. - 2: ADRES registers may be read on the following Tcy cycle. - 3: The time for the holding capacitor to acquire the "New" input voltage when the voltage changes full scale after the conversion (VDD to Vss or Vss to VDD). The source impedance (Rs) on the input channels is $50\Omega$ . - 4: On the following cycle of the device clock. NOTES: ## 5.0 PACKAGING INFORMATION For packaging information, see the "PIC18F8722 Family Data Sheet" (DS39646). | RD1/AD1/PSP1 | 25 | |------------------------|--------| | RD1/PSP1 | | | | | | RD2/AD2/PSP2 | | | RD2/PSP2 | 17 | | RD3/AD3/PSP3 | 25 | | RD3/PSP3 | | | RD4/AD4/PSP4/SDO2 | | | | | | RD4/PSP4/SDO2 | | | RD5/AD5/PSP5/SDI2/SDA2 | 25 | | RD5/PSP5/SDI2/SDA2 | 17 | | RD6/AD6/PSP6/SCK2/SCL2 | | | RD6/PSP6/SCK2/SCL2 | | | RD0/P3P0/3CK2/3CL2 | 17 | | RD7/AD7/PSP7/SS2 | | | RD7/PSP7/SS2 | | | RE0/AD8/RD/P2D | 26 | | RE0/RD/P2D | | | RE1/AD9/WR/P2C | | | | | | RE1/WR/P2C | 18 | | RE2/AD10/CS/P2B | 26 | | RE2/CS/P2D | 18 | | RE3/AD11/P3C | | | RE3/P3C | | | | | | RE4/AD12/P3B | | | RE4/P3B | | | RE5/AD13/P1C | 26 | | RE5/P1C | 18 | | RE6/AD14/P1B | 26 | | RE6/P1B | | | RE7/AD15/ECCP2/P2A | | | | | | RE7/ECCP2/P2A | | | RF0/AN5 | | | RF1/AN6/C2OUT | 19, 27 | | RF2/AN7/C1OUT | 19, 27 | | RF3/AN8 | | | RF4/AN9 | | | | | | RF5/AN10/CVREF | | | RF6/AN11 | , | | RF7/SS1 | | | RG0/ECCP3/P3A | 20, 28 | | RG1/TX2/CK2 | 20. 28 | | RG2/RX2/DT2 | 20 28 | | RG3/CCP4/P3D | | | | | | RG4/CCP5/P1D | | | RG5 | | | RG5/MCLR/VPP | 13, 21 | | RH0/A16 | 29 | | RH1/A17 | 29 | | RH2/A18 | | | RH3/A19 | | | RH4/AN12/P3C | | | | | | RH5/AN13/P3B | | | RH6/AN14/P1C | | | RH7/AN15/P1B | 29 | | RJ0/ALE | 30 | | RJ1/ <del>OE</del> | 30 | | RJ2/WRL | | | RJ3/WRH | | | | | | RJ4/BA0 | | | RJ5/ <u>CE</u> | | | RJ6/ <u>LB</u> | 30 | | RJ7/ <del>UB</del> | 30 | | VDD | 20 | | VDD | | | Vss | | | Vss | | | v 00 | ວ∪ | | Pinout I/O Descriptions | | |------------------------------------|------| | PIC18F6628/6723 | . 13 | | PIC18F8628/8723 | . 21 | | Power-Managed Modes | 3 | | and A/D Operation | . 38 | | Product Identification System | . 59 | | R | | | Reader Response | . 58 | | Registers | | | ADCON0 (A/D Control 0) | . 31 | | ADCON1 (A/D Control 1) | . 32 | | ADCON2 (A/D Control 2) | . 33 | | DEVID1 (Device ID 1) | . 42 | | DEVID2 (Device ID 2) | . 42 | | Revision History | . 51 | | S | | | Special Features of the CPU | . 41 | | Device ID Registers | . 41 | | Special Microcontroller Features | 3 | | Т | | | Timing Diagrams | | | A/D Conversion | . 47 | | Timing Diagrams and Specifications | | | A/D Conversion Requirements | . 47 | | V | | | Voltage-Frequency Graphs | | | Extended (PIC18F8723) | . 44 | | Industrial (PIC18F8723) | | | Industrial (PIC18LF8723) | | | w | | | WWW Address | 57 | | MMM On Line Support | | #### THE MICROCHIP WEB SITE Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the web site contains the following information: - Product Support Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software - General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing - Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives # CUSTOMER CHANGE NOTIFICATION SERVICE Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest. To register, access the Microchip web site at www.microchip.com, click on Customer Change Notification and follow the registration instructions. #### **CUSTOMER SUPPORT** Users of Microchip products can receive assistance through several channels: - · Distributor or Representative - · Local Sales Office - Field Application Engineer (FAE) - · Technical Support - · Development Systems Information Line Customers should contact their distributor, representative or field application engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document. Technical support is available through the web site at: http://support.microchip.com