mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
13e578bc84
lpc23xx has a 10 bit ADC with up to 8 channels. The ADC should be clocked at 4.5 MHz or less, so it uses (72MHz CCLK / 8) / 2.
82 lines
1.9 KiB
C
82 lines
1.9 KiB
C
/*
|
|
* Copyright (C) 2019 Beuth Hochschule für Technik Berlin
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
* Public License v2.1. See the file LICENSE in the top level directory for more
|
|
* details.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup drivers_periph
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Low-level ADC driver implementation for lpc23xx family
|
|
*
|
|
* @author Benjamin Valentin <benpicco@beuth-hochschule.de>
|
|
*
|
|
* @}
|
|
*/
|
|
|
|
#include "cpu.h"
|
|
#include "kernel_defines.h"
|
|
#include "periph/adc.h"
|
|
#include "periph_conf.h"
|
|
|
|
int adc_init(adc_t line)
|
|
{
|
|
/* check if the line is valid */
|
|
if (line >= ADC_NUMOF) {
|
|
return -1;
|
|
}
|
|
|
|
/* enable clock/power for ADC */
|
|
PCONP |= BIT12;
|
|
|
|
/* set ADC PCLK to CCLK/8 */
|
|
PCLKSEL0 |= BIT25 + BIT25;
|
|
|
|
/* configure AF for ADC pin */
|
|
*(&PINSEL0 + adc_config[line].pinsel) |= adc_config[line].pinsel_msk;
|
|
|
|
/* power down ADC */
|
|
AD0CR = 0;
|
|
|
|
return 0;
|
|
}
|
|
|
|
int32_t adc_sample(adc_t line, adc_res_t res)
|
|
{
|
|
uint32_t val;
|
|
|
|
/* check if the line is valid */
|
|
if (line >= ADC_NUMOF) {
|
|
return -1;
|
|
}
|
|
|
|
/* check if resolution is applicable */
|
|
if (res > 0xf0) {
|
|
return -1;
|
|
}
|
|
|
|
/* Enable & configure ADC.
|
|
* burst mode is used even though we only do one conversion here
|
|
* in order to being able to configure the resolution.
|
|
*/
|
|
AD0CR = (1 << adc_config[line].chan) /* select channel */
|
|
| (1 << 8) /* clocked at 4.5 MHz */
|
|
| (1 << 16) /* enable burst mode */
|
|
| (res << 17) /* select resolution */
|
|
| (1 << 21) /* enable ADC */
|
|
| (1 << 24); /* start conversion */
|
|
|
|
do {
|
|
val = *(&AD0DR0 + adc_config[line].chan);
|
|
} while (!(val & BIT31));
|
|
|
|
/* power down ADC */
|
|
AD0CR = 0;
|
|
|
|
return val & 0xFFFF;
|
|
}
|