STM32之ADC配置,ADC_Mode模式理解

对于STM32,在使用ADC的时候需要配置几个参数。

  1. 第一个参数是ADC_Mode,这里设置为独立模式:
	ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;

在这个模式下,双ADC不能同步,每个ADC接口独立工作。所以如果不需要ADC同步或者只是用了一个ADC的时候,就应该设成独立模式了。

  1. 第二个参数是ADC_ScanConvMode,这里设置为DISABLE。
	ADC_InitStructure.ADC_ScanConvMode = DISABLE;

如果只是用了一个通道的话,DISABLE就可以了,如果使用了多个通道的话,则必须将其设置为ENABLE。

  1. 第三个参数是ADC_ContinuousConvMode,这里设置为ENABLE,即连续转换。如果设置为DISABLE,则是单次转换。两者的区别在于连续转换直到所有的数据转换完成后才停止转换,而单次转换则只转换一次数据就停止,要再次触发转换才可以。所以如果需要一次性采集1024个数据或者更多,则采用连续转换。

  2. 第四个参数是ADC_ExternalTrigConv,即选择外部触发模式。这里只讲三种:

  • 第一种是最简单的软件触发,参数为ADC_ExternalTrigConv_None。设置好后还要记得调用库函数:
	ADC_SoftwareStartConvCmd(ADC1, ENABLE);

这样触发才会启动。

  • 第二种是定时器通道输出触发。共有这几种:
ADC_ExternalTrigConv_T1_CC1、
ADC_ExternalTrigConv_T1_CC2、
ADC_ExternalTrigConv_T2_CC2、
ADC_ExternalTrigConv_T3_T 、
ADC_ExternalTrigConv_T4_CC4 、

定时器输出触发比较麻烦,还需要设置相应的定时器。ADC_ExternalTrigConv_T2_CC2触发为例设置相应的定时器:

void TIM2_Configuration(void){

		TIM_TimeBaseInitTypeDef   TIM_TimeBaseStructure;
		TIM_OCInitTypeDef         TIM_OCInitStructure;
		
		TIM_TimeBaseStructure.TIM_Prescaler = 4;
		TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
		TIM_TimeBaseStructure.TIM_Period = 0XFF;
		TIM_TimeBaseStructure.TIM_ClockDivision = 0;
		TIM_TimeBaseStructure.TIM_RepetitionCounter = 0;
		TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);
		
		TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
		TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
		TIM_OCInitStructure.TIM_Pulse = 0X7F;
		TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low;
		TIM_OCInitStructure.TIM_OCIdleState = TIM_OCIdleState_Set;        
		TIM_OC2Init(TIM2, &TIM_OCInitStructure);
		
		TIM_Cmd(TIM2, ENABLE);
		
		TIM_CtrlPWMOutputs(TIM2, ENABLE);
}

这样设置之后就可以用定时器2的输出触发了,至于触发的周期,设置TIM2的时间即可。这里不再赘述。

  • 第三种是外部引脚触发,对于规则通道,选择EXTI线11和TIM8_TRGO作为外部触发事件;而注入通道组则选择EXTI线15和TIM8_CC4作为外部触发事件。
  1. 第五个参数是ADC_DataAlign,这里设置为ADC_DataAlign_Right右对齐方式。建议采用右对齐方式,因为这样处理数据会比较方便。当然如果要从高位开始传输数据,那么采用左对齐优势就明显了。
  2. 第六个参数是ADC_NbrOfChannel,顾名思义:通道的数量。要是到多个通道采集数据的话就得设置一下这个参数。此外在规则通道组的配置函数中也许将各个通道的顺序定义一下,如:
      ADC_RegularChannelConfig(ADC1,ADC_Channel_13,1,ADC_SampleTime_13Cycles5);
      ADC_RegularChannelConfig(ADC1,ADC_Channel_14,2,ADC_SampleTime_13Cycles5);

多通道数据传输时有一点还要注意:若一个数组为ADC_ValueTab[4],且设置了两个通道:通道1和通道2,则转换结束后,ADC_ValueTab[0]ADC_ValueTab[2]存储的是通道1的数据,而ADC_ValueTab[1]ADC_ValueTab[3]存储的是通道2的数据。如果数组容量大则依次类推

STM32 HAL_ADC_Start_DMA 函数是用于在STM32微控制器上使用DMA(Direct Memory Access)进行高速数据转换的高级API。它通常应用于需要大量数据快速采集并传输到内存的情况,比如连续测量或者实时处理。 当使用这个函数时,你需要做以下几个步骤: 1. 首先,初始化ADC模块,包括配置通道、启动模式等。例如: ```c ADC_HandleTypeDef hadc1; hadc1.Instance = ADC1; // 指定ADC1外设 hadc1.Init.Channel = ADC_CHANNEL_0; // 设置要采集的通道 // 其他初始化设置... HAL_ADC_Init(&hadc1); ``` 2. 然后,配置DMA,使其能从ADC的特定寄存器读取数据: ```c DMA_HandleTypeDef hdma_adc1; hdma_adc1.Init.Channel = DMA_CHANNEL_1; // 根据实际使用的DMA通道 hdma_adc1.Init.Direction = DMA_PERIPH_TO_MEMORY; hdma_adc1.Init.PeriphInc = DMA_PINC_DISABLE; hdma_adc1.Init.MemInc = DMA_MINC_ENABLE; hdma_adc1.Init.Mode = DMA_NORMAL; hdma_adc1.Init.Priority = DMA_PRIORITY_LOW; hdma_adc1.Init.FIFOMode = DMA_FIFOMODE_DISABLE; hdma_adc1.Init.Request = DMA请求标志; // 初始化其他参数... HAL_DMA_Init(&hdma_adc1); ``` 3. 安排DMA将数据传输到指定的内存地址,并开始ADC的数据采集: ```c __HAL_ADC_ENABLE(&hadc1); // 开启ADC DMA_HandleTypeDef *hdmaHandle = &hdma_adc1; HAL_DMA_ConfigChannel(&hdmaHandle, &hadc1, ADC_DMA_REQUEST, (uint32_t)&hadc1->DR, (uint32_t)adcBuffer, ADC_BUFFER_SIZE); HAL_DMA_Start_IT(hdmaHandle); // 启动DMA传输 HAL_ADC_Start_DMA(&hadc1, NULL, (uint32_t)adcBuffer); // 开始ADC采样并将结果通过DMA发送到缓冲区 ``` 4. 最后,在DMA完成之前,ADC会继续运行直到停止采集。你可以通过中断或定期检查DMA完成标志来结束这一过程。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值