mirror of
https://github.com/betaflight/betaflight.git
synced 2025-07-17 21:35:44 +03:00
Fix powerAdcChannel on STM32F1.
Initialisation of ADC was incorrect.
This commit is contained in:
parent
4b58dc110d
commit
b957def2f3
3 changed files with 32 additions and 29 deletions
|
@ -10,25 +10,20 @@
|
||||||
|
|
||||||
adc_config_t adcConfig[ADC_CHANNEL_COUNT];
|
adc_config_t adcConfig[ADC_CHANNEL_COUNT];
|
||||||
volatile uint16_t adcValues[ADC_CHANNEL_COUNT];
|
volatile uint16_t adcValues[ADC_CHANNEL_COUNT];
|
||||||
uint8_t adcChannelCount = 0;
|
|
||||||
|
|
||||||
extern int16_t debug[4];
|
extern int16_t debug[4];
|
||||||
|
|
||||||
uint16_t adcGetChannel(uint8_t channel)
|
uint16_t adcGetChannel(uint8_t channel)
|
||||||
{
|
{
|
||||||
#if 0
|
#if 1
|
||||||
switch (adcChannelCount) {
|
if (adcConfig[0].enabled) {
|
||||||
case 3:
|
debug[0] = adcValues[adcConfig[0].dmaIndex];
|
||||||
debug[2] = adcValues[adcConfig[2].dmaIndex];
|
}
|
||||||
/* no break */
|
if (adcConfig[1].enabled) {
|
||||||
case 2:
|
debug[1] = adcValues[adcConfig[1].dmaIndex];
|
||||||
debug[1] = adcValues[adcConfig[1].dmaIndex];
|
}
|
||||||
/* no break */
|
if (adcConfig[2].enabled) {
|
||||||
case 1:
|
debug[2] = adcValues[adcConfig[2].dmaIndex];
|
||||||
debug[0] = adcValues[adcConfig[0].dmaIndex];
|
|
||||||
/* no break */
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
return adcValues[adcConfig[channel].dmaIndex];
|
return adcValues[adcConfig[channel].dmaIndex];
|
||||||
|
|
|
@ -12,6 +12,7 @@ typedef enum {
|
||||||
typedef struct adc_config_t {
|
typedef struct adc_config_t {
|
||||||
uint8_t adcChannel; // ADC1_INxx channel number
|
uint8_t adcChannel; // ADC1_INxx channel number
|
||||||
uint8_t dmaIndex; // index into DMA buffer in case of sparse channels
|
uint8_t dmaIndex; // index into DMA buffer in case of sparse channels
|
||||||
|
bool enabled;
|
||||||
} adc_config_t;
|
} adc_config_t;
|
||||||
|
|
||||||
typedef struct drv_adc_config_t {
|
typedef struct drv_adc_config_t {
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "system_common.h"
|
#include "system_common.h"
|
||||||
|
@ -19,30 +20,31 @@
|
||||||
extern adc_config_t adcConfig[ADC_CHANNEL_COUNT];
|
extern adc_config_t adcConfig[ADC_CHANNEL_COUNT];
|
||||||
extern volatile uint16_t adcValues[ADC_CHANNEL_COUNT];
|
extern volatile uint16_t adcValues[ADC_CHANNEL_COUNT];
|
||||||
|
|
||||||
extern uint8_t adcChannelCount;
|
|
||||||
|
|
||||||
void adcInit(drv_adc_config_t *init)
|
void adcInit(drv_adc_config_t *init)
|
||||||
{
|
{
|
||||||
ADC_InitTypeDef adc;
|
ADC_InitTypeDef adc;
|
||||||
DMA_InitTypeDef dma;
|
DMA_InitTypeDef dma;
|
||||||
uint8_t i;
|
uint8_t i;
|
||||||
|
|
||||||
|
uint8_t configuredAdcChannels = 0;
|
||||||
|
memset(&adcConfig, 0, sizeof(adcConfig));
|
||||||
|
|
||||||
// configure always-present battery index (ADC4)
|
// configure always-present battery index (ADC4)
|
||||||
adcConfig[ADC_BATTERY].adcChannel = ADC_Channel_4;
|
adcConfig[ADC_BATTERY].adcChannel = ADC_Channel_4;
|
||||||
adcConfig[ADC_BATTERY].dmaIndex = adcChannelCount;
|
adcConfig[ADC_BATTERY].dmaIndex = configuredAdcChannels++;
|
||||||
adcChannelCount++;
|
adcConfig[ADC_BATTERY].enabled = true;
|
||||||
|
|
||||||
// optional ADC5 input on rev.5 hardware
|
// optional ADC5 input on rev.5 hardware
|
||||||
if (hse_value == 12000000) {
|
if (hse_value == 12000000) {
|
||||||
adcConfig[ADC_EXTERNAL1].adcChannel = ADC_Channel_5;
|
adcConfig[ADC_EXTERNAL1].adcChannel = ADC_Channel_5;
|
||||||
adcConfig[ADC_EXTERNAL1].dmaIndex = adcChannelCount;
|
adcConfig[ADC_EXTERNAL1].dmaIndex = configuredAdcChannels++;
|
||||||
adcChannelCount++;
|
adcConfig[ADC_EXTERNAL1].enabled = true;
|
||||||
}
|
}
|
||||||
// another channel can be stolen from PWM for current measurement or other things
|
// another channel can be stolen from PWM for current measurement or other things
|
||||||
if (init->powerAdcChannel > 0) {
|
if (init->powerAdcChannel > 0) {
|
||||||
adcConfig[ADC_EXTERNAL2].adcChannel = init->powerAdcChannel;
|
adcConfig[ADC_EXTERNAL2].adcChannel = ADC_Channel_1; // init->powerAdcChannel;
|
||||||
adcConfig[ADC_EXTERNAL2].dmaIndex = adcChannelCount;
|
adcConfig[ADC_EXTERNAL2].dmaIndex = configuredAdcChannels++;
|
||||||
adcChannelCount++;
|
adcConfig[ADC_EXTERNAL2].enabled = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ADC driver assumes all the GPIO was already placed in 'AIN' mode
|
// ADC driver assumes all the GPIO was already placed in 'AIN' mode
|
||||||
|
@ -50,9 +52,9 @@ void adcInit(drv_adc_config_t *init)
|
||||||
dma.DMA_PeripheralBaseAddr = (uint32_t)&ADC1->DR;
|
dma.DMA_PeripheralBaseAddr = (uint32_t)&ADC1->DR;
|
||||||
dma.DMA_MemoryBaseAddr = (uint32_t)adcValues;
|
dma.DMA_MemoryBaseAddr = (uint32_t)adcValues;
|
||||||
dma.DMA_DIR = DMA_DIR_PeripheralSRC;
|
dma.DMA_DIR = DMA_DIR_PeripheralSRC;
|
||||||
dma.DMA_BufferSize = adcChannelCount;
|
dma.DMA_BufferSize = configuredAdcChannels;
|
||||||
dma.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
|
dma.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
|
||||||
dma.DMA_MemoryInc = adcChannelCount > 1 ? DMA_MemoryInc_Enable : DMA_MemoryInc_Disable;
|
dma.DMA_MemoryInc = configuredAdcChannels > 1 ? DMA_MemoryInc_Enable : DMA_MemoryInc_Disable;
|
||||||
dma.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;
|
dma.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;
|
||||||
dma.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
|
dma.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
|
||||||
dma.DMA_Mode = DMA_Mode_Circular;
|
dma.DMA_Mode = DMA_Mode_Circular;
|
||||||
|
@ -62,15 +64,20 @@ void adcInit(drv_adc_config_t *init)
|
||||||
DMA_Cmd(DMA1_Channel1, ENABLE);
|
DMA_Cmd(DMA1_Channel1, ENABLE);
|
||||||
|
|
||||||
adc.ADC_Mode = ADC_Mode_Independent;
|
adc.ADC_Mode = ADC_Mode_Independent;
|
||||||
adc.ADC_ScanConvMode = adcChannelCount > 1 ? ENABLE : DISABLE;
|
adc.ADC_ScanConvMode = configuredAdcChannels > 1 ? ENABLE : DISABLE;
|
||||||
adc.ADC_ContinuousConvMode = ENABLE;
|
adc.ADC_ContinuousConvMode = ENABLE;
|
||||||
adc.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;
|
adc.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;
|
||||||
adc.ADC_DataAlign = ADC_DataAlign_Right;
|
adc.ADC_DataAlign = ADC_DataAlign_Right;
|
||||||
adc.ADC_NbrOfChannel = adcChannelCount;
|
adc.ADC_NbrOfChannel = configuredAdcChannels;
|
||||||
ADC_Init(ADC1, &adc);
|
ADC_Init(ADC1, &adc);
|
||||||
|
|
||||||
for (i = 0; i < adcChannelCount; i++)
|
uint8_t rank = 1;
|
||||||
ADC_RegularChannelConfig(ADC1, adcConfig[i].adcChannel, i + 1, ADC_SampleTime_28Cycles5);
|
for (i = 0; i < ADC_CHANNEL_COUNT; i++) {
|
||||||
|
if (!adcConfig[i].enabled) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
ADC_RegularChannelConfig(ADC1, adcConfig[i].adcChannel, rank++, ADC_SampleTime_28Cycles5);
|
||||||
|
}
|
||||||
|
|
||||||
ADC_DMACmd(ADC1, ENABLE);
|
ADC_DMACmd(ADC1, ENABLE);
|
||||||
ADC_Cmd(ADC1, ENABLE);
|
ADC_Cmd(ADC1, ENABLE);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue