1
0
Fork 0
mirror of https://github.com/betaflight/betaflight.git synced 2025-07-25 17:25:20 +03:00
betaflight/src/main/drivers/adc.c
Hans Christian Olaussen 15e5f9980f Place ADC DMA buffer in DTCM RAM
Places adcValues in non cached DTCM RAM to avoid problems when D-cache is enabled for F7 mcus.
2019-03-01 13:31:45 +01:00

134 lines
3 KiB
C

/*
* This file is part of Cleanflight and Betaflight.
*
* Cleanflight and Betaflight are free software. You can redistribute
* this software and/or modify this software under the terms of the
* GNU General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option)
* any later version.
*
* Cleanflight and Betaflight are distributed in the hope that they
* will be useful, but WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this software.
*
* If not, see <http://www.gnu.org/licenses/>.
*/
#include <stdbool.h>
#include <stdint.h>
#include "platform.h"
#include "common/utils.h"
#ifdef USE_ADC
#include "build/build_config.h"
#include "build/debug.h"
#include "drivers/adc_impl.h"
#include "drivers/io.h"
#include "pg/adc.h"
#include "adc.h"
//#define DEBUG_ADC_CHANNELS
adcOperatingConfig_t adcOperatingConfig[ADC_CHANNEL_COUNT];
volatile FAST_RAM_ZERO_INIT uint16_t adcValues[ADC_CHANNEL_COUNT];
#ifdef USE_ADC_INTERNAL
uint16_t adcTSCAL1;
uint16_t adcTSCAL2;
int16_t adcTSSlopeK;
uint16_t adcVREFINTCAL;
#endif
uint8_t adcChannelByTag(ioTag_t ioTag)
{
for (uint8_t i = 0; i < ARRAYLEN(adcTagMap); i++) {
if (ioTag == adcTagMap[i].tag)
return adcTagMap[i].channel;
}
return 0;
}
ADCDevice adcDeviceByInstance(ADC_TypeDef *instance)
{
if (instance == ADC1) {
return ADCDEV_1;
}
#if defined(STM32F3) || defined(STM32F4) || defined(STM32F7)
if (instance == ADC2) {
return ADCDEV_2;
}
if (instance == ADC3) {
return ADCDEV_3;
}
#endif
#ifdef STM32F3
if (instance == ADC4) {
return ADCDEV_4;
}
#endif
return ADCINVALID;
}
uint16_t adcGetChannel(uint8_t channel)
{
#ifdef DEBUG_ADC_CHANNELS
if (adcOperatingConfig[0].enabled) {
debug[0] = adcValues[adcOperatingConfig[0].dmaIndex];
}
if (adcOperatingConfig[1].enabled) {
debug[1] = adcValues[adcOperatingConfig[1].dmaIndex];
}
if (adcOperatingConfig[2].enabled) {
debug[2] = adcValues[adcOperatingConfig[2].dmaIndex];
}
if (adcOperatingConfig[3].enabled) {
debug[3] = adcValues[adcOperatingConfig[3].dmaIndex];
}
#endif
return adcValues[adcOperatingConfig[channel].dmaIndex];
}
// Verify a pin designated by tag has connection to an ADC instance designated by device
bool adcVerifyPin(ioTag_t tag, ADCDevice device)
{
if (!tag) {
return false;
}
for (int map = 0 ; map < ADC_TAG_MAP_COUNT ; map++) {
#if defined(STM32F1)
UNUSED(device);
if ((adcTagMap[map].tag == tag)) {
return true;
}
#else
if ((adcTagMap[map].tag == tag) && (adcTagMap[map].devices & (1 << device))) {
return true;
}
#endif
}
return false;
}
#else
uint16_t adcGetChannel(uint8_t channel)
{
UNUSED(channel);
return 0;
}
#endif