Datasheet
2002 Microchip Technology Inc. Preliminary DS39598C-page 83
PIC16F818/819
The ADRESH:ADRESL registers contain the result of
the A/D conversion. When the A/D conversion is com-
plete, the result is loaded into the A/D result register
pair, the GO/DONE
bit (ADCON0<2>) is cleared, and
A/D interrupt flag bit ADIF is set. The block diagram of
the A/D module is shown in Figure 11-1.
After the A/D module has been configured as desired,
the selected channel must be acquired before the con-
version is started. The analog input channels must
have their corresponding TRIS bits selected as inputs.
To determine sample time, see Section 11.1. After this
sample time has elapsed the A/D conversion can be
started.
These steps should be followed for doing an A/D
conversion:
1. Configure the A/D module:
• Configure analog pins/voltage reference and
digital I/O (ADCON1)
• Select A/D input channel (ADCON0)
• Select A/D conversion clock (ADCON0)
• Turn on A/D module (ADCON0)
2. Configure A/D interrupt (if desired):
• Clear ADIF bit
• Set ADIE bit
• Set GIE bit
3. Wait the required acquisition time.
4. Start conversion:
• Set GO/DONE
bit (ADCON0)
5. Wait for A/D conversion to complete, by either:
• Polling for the GO/DONE
bit to be cleared
(with interrupts disabled); OR
• Waiting for the A/D interrupt
6. Read A/D Result register pair
(ADRESH:ADRESL), clear bit ADIF if required.
7. For next conversion, go to step 1 or step 2 as
required. The A/D conversion time per bit is
defined as T
AD. A minimum wait of 2 TAD is
required before the next acquisition starts.
FIGURE 11-1: A/D BLOCK DIAGRAM
(Input Voltage)
V
IN
VREF+
(Reference
Voltage)
AV
DD
PCFG<3:0>
CHS<3:0>
RA3/AN3/VREF+
RA2/AN2/V
REF-
RA1/AN1
RA0/AN0
011
010
001
000
A/D
Converter
VREF-
(Reference
Voltage)
AV
SS
PCFG<3:0>
RA4/AN4
100