1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/cpu/lpc2387/periph/adc.c
Benjamin Valentin 13e578bc84 cpu/lpc2387: implement periph/adc
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.
2020-02-10 13:25:26 +01:00

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;
}