STM32 ADC 多通道采集非DMA模式

网上的列子大多数为DMA,所以写个帖子说一下非DMA怎么操作。

由于多通道的时候采集的时候,AD是连续的按照设定好的通道顺序进行采集的,所以一般会

发生这个通道的数据把另一个通道的数据覆盖的问题,让人感觉每个通道好像错乱一样。比如我明明读的通道5,却显示的通道7的数据。我开始困扰了许久,以为是板子丝印错误了。

下面说一下怎么配置的,简单的讲就是把所有通道的GPIO口都设置好,也就是模拟输入

但是!!!要设置成单通道单次采集,代码如下

(始终开启)

(GPIO设置成模拟输入)  

ADC_DeInit(ADC1);  

ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;    
ADC_InitStructure.ADC_ScanConvMode = DISABLE;    
ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;    
ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;    
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;    
ADC_InitStructure.ADC_NbrOfChannel = 1;    
ADC_Init(ADC1, &ADC_InitStructure);       
ADC_Cmd(ADC1, ENABLE);   
ADC_ResetCalibration(ADC1);     
while(ADC_GetResetCalibrationStatus(ADC1));   
ADC_StartCalibration(ADC1);   

while(ADC_GetCalibrationStatus(ADC1)){};   

这样设置之后怎么读取各个端口的数据呢?代码如下

uint16_t read_adc_value(uint8_t ch)   
{
    uint16_t adc_val = 0;
    
    ADC_RegularChannelConfig(ADC1, ch, 1, ADC_SampleTime_239Cycles5 );    
    ADC_SoftwareStartConvCmd(ADC1, ENABLE);        
    while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC )){};
    
    adc_val = ADC_GetConversionValue(ADC1);    
    //adc_dbg("ch = %d,adc_val = %d\r\n",ch,adc_val);   
        
    return adc_val;

}

也就是每次读取的时候都设置一下采样通道的顺序

  • 7
    点赞
  • 59
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
STM32中,可以使用DMA(直接内存访问)技术来实现多通道ADC采集DMA技术可以在不占用CPU时间的情况下,直接将ADC采集到的数据存储到内存中。下面是一个简单的代码示例,演示如何使用DMA实现多通道ADC采集: 首先,配置ADC多通道采集模式: ```c // 初始化ADC HAL_ADC_Init(&hadc1); // 配置ADC多通道采集模式 ADC_ChannelConfTypeDef sConfig = {0}; sConfig.Channel = ADC_CHANNEL_0; // 采集通道0 sConfig.Rank = ADC_REGULAR_RANK_1; sConfig.SamplingTime = ADC_SAMPLETIME_3CYCLES; HAL_ADC_ConfigChannel(&hadc1, &sConfig); sConfig.Channel = ADC_CHANNEL_1; // 采集通道1 sConfig.Rank = ADC_REGULAR_RANK_2; HAL_ADC_ConfigChannel(&hadc1, &sConfig); sConfig.Channel = ADC_CHANNEL_2; // 采集通道2 sConfig.Rank = ADC_REGULAR_RANK_3; HAL_ADC_ConfigChannel(&hadc1, &sConfig); sConfig.Channel = ADC_CHANNEL_3; // 采集通道3 sConfig.Rank = ADC_REGULAR_RANK_4; HAL_ADC_ConfigChannel(&hadc1, &sConfig); ``` 然后,配置DMA: ```c // 初始化DMA hdma_adc.Instance = DMA1_Channel1; hdma_adc.Init.Direction = DMA_PERIPH_TO_MEMORY; hdma_adc.Init.PeriphInc = DMA_PINC_DISABLE; hdma_adc.Init.MemInc = DMA_MINC_ENABLE; hdma_adc.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD; hdma_adc.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD; hdma_adc.Init.Mode = DMA_CIRCULAR; hdma_adc.Init.Priority = DMA_PRIORITY_HIGH; HAL_DMA_Init(&hdma_adc); __HAL_LINKDMA(&hadc1, DMA_Handle, hdma_adc); ``` 最后,启动ADCDMA: ```c HAL_ADC_Start_DMA(&hadc1, (uint32_t*)adc_data, 4); // 采集4个通道的数据 ``` 在这个例子中,我们将采集到的数据存储在名为“adc_data”的数组中,该数组可以是任意大小。DMA将自动填充该数组,并在填充完成后触发DMA完成中断。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

有一双挣钱的小能手

您的打赏是众人更好的前行!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值