* device/include/pic16/pic18f[24][3456]k20.h,
[fw/sdcc] / device / lib / pic16 / libio / adc / adcopen.c
1
2 /*
3  * adcopen - initialize AD module
4  *
5  * written by Vangelis Rokas, 2004 <vrokas AT otenet.gr>
6  *
7  * This program is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Library General Public License
9  * as published by the Free Software Foundation; either version 2
10  * of the License, or (at your option) any later version.
11  *
12  * This library is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software
19  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
20  */
21
22 #include <pic18fregs.h>
23 #include <adc.h>
24
25
26 /*
27  * parameters are:
28  *   channel: one of ADC_CHN_*
29  *   fosc:    one of ADC_FOSC_* | ADC_ACQT_* | ADC_CAL
30  *   pcfg:    one of ADC_CFG_* (a bitmask with set bits denoting digital ports for 1220/65j50-style)
31  *   config:  ADC_FRM_* | ADC_INT_* | ADC_VCFG_*
32  */
33
34 #if defined(__SDCC_ADC_STYLE65J50)
35 void adc_open(unsigned char channel, unsigned char fosc, unsigned int pcfg, unsigned char config)
36 #else
37 void adc_open(unsigned char channel, unsigned char fosc, unsigned char pcfg, unsigned char config)
38 #endif
39 {
40   /* disable ADC */
41 #if defined(__SDCC_ADC_STYLE65J50)
42   WDTCONbits.ADSHR = 0; /* access ADCON0/1 */
43 #endif
44   ADCON0 = 0;
45
46 #if defined(__SDCC_ADC_STYLE242)
47   ADCON0 = ((channel & 0x07) << 3) | ((fosc & 0x03) << 6);
48   ADCON1 = (pcfg & 0x0f) | (config & ADC_FRM_RJUST);
49   if (fosc & 0x04) {
50     ADCON1bits.ADCS2 = 1;
51   }
52 #elif defined (__SDCC_ADC_STYLE1220)
53   ADCON0 = ((channel & 0x07) | (config & ADC_VCFG_AN3_AN2)) << 2;
54   ADCON1 = (pcfg & 0x7f);
55   ADCON2 = (ADCON2 & 0x38) | (fosc & 0x07) | (config & ADC_FRM_RJUST);
56 #elif defined(__SDCC_ADC_STYLE2220)
57   ADCON0 = (channel & 0x0f) << 2;
58   /* XXX: Should be (pcfg & 0x0f) as VCFG comes from config,
59    * but we retain compatibility for now ... */
60   ADCON1 = (pcfg & 0x3f) | (config & ADC_VCFG_AN3_AN2);
61   ADCON2 = (ADCON2 & 0x38) | (fosc & 0x07) | (config & ADC_FRM_RJUST);
62 #elif defined(__SDCC_ADC_STYLE65J50)
63   WDTCONbits.ADSHR = 1; /* access ANCON0/1 */
64   ANCON0 = pcfg;
65   ANCON1 = (pcfg >> 8);
66   WDTCONbits.ADSHR = 0; /* access ADCON0/1 */
67   ADCON0 = ((channel & 0x0f) << 2) | ((config & ADC_VCFG_AN3_AN2) << 2);
68   ADCON1 = (config & ADC_FRM_RJUST) | (fosc & 0x7f);
69 #else /* unsupported ADC style */
70 #error Unsupported ADC style.
71 #endif
72
73   if (config & ADC_INT_ON) {
74     PIR1bits.ADIF = 0;
75     PIE1bits.ADIE = 1;
76     INTCONbits.PEIE = 1;
77   }
78
79   /* enable the A/D module */
80   ADCON0bits.ADON = 1;
81 }
82