相比较于独立模式多通道电压采集实验,其实双重ADC同步模式实验就是多了另一个ADC同步而已,只是有些地方在配置和编程时需要注意而已,而且本文用的是单通道ADC。
双重ADC相对于独立模式,同时采集一个或多个通道,可以提高采样率。
可以直接配置ADC_CR1寄存器的 DUALMOD[3:0]位,用于启用双重ADC,这里我们配置为规则同步模式。
简单来讲,规则同步模式即为ADC1和ADC2同时转换规则通道组,其中ADC1为主,ADC2为从。ADC1转换的结果放在ADC_DR的低16位,ADC2转换的结果放在ADC_DR的高16位。如图23-1为ADC_DR寄存器描述。
![](https://i-blog.csdnimg.cn/blog_migrate/8a1eae5d929a72aee5903c9a1750c1a8.png)
图23-1
GPIO配置
我们选择ADC1的通道11和ADC2的通道14,这两个通道对应引脚为PC1和PC4,那么我们分别配置这两个引脚的GPIO。
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 | GPIO_Pin_4; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; GPIO_Init(GPIOC, &GPIO_InitStructure);
DMA配置
我们知道,ADC1对应DMA1的通道1,ADC3对应DMA2的通道5,而ADC2则没有DMA功能。所以我们依然使用ADC模数转换(二)——独立模式多通道电压采集实验的DMA配置,所不同的是,这里只有单个通道传输,所以缓冲区DMA_BufferSize的值应为1,还有一点,因为这是ADC1和ADC2双重ADC,所以内存(DMA_MemoryDataSize)和外设(DMA_PeripheralDataSize)的数据宽度应为一个字,即4个字节大小。
DMA_InitTypeDef DMA_InitStructure;
RC