stm32H7 HAL库 定时器触发多通道adc采样 DMA

stm32H7 HAL库 定时器触发多通道adc采样 DMA


ps:忙了一阵竞赛,考试,开始学点新东西

环境

keil
stm32cubemx v1.9.1
stm32h750vbt6

配置

外部时钟,时钟树好像只能手动配置
在这里插入图片描述
在这里插入图片描述

定时器

用的time6 ,50khz,修改 触发 输出参数中 的触发事件选择
在这里插入图片描述

adc

选择 adc 和需要的通道口
我这选 adc1 和 3个通道
在这里插入图片描述

DMA

在这里插入图片描述
首先说明 这样配置后功能是:
开启adc_dma后,以50khz 触发 采样,每次 采样3个通道,不断循环,不需要后续再开启

记得修改手动修改成 自己的adc通道和 通道个数
在这里插入图片描述
最后生成工程

测试代码

#define DMA_BUF_SIZE 27
volatile uint16_t DMABuf1[DMA_BUF_SIZE]={0};


//线性校正
HAL_ADCEx_Calibration_Start(&hadc1,ADC_CALIB_OFFSET_LINEARITY, ADC_SINGLE_ENDED);  
HAL_TIM_Base_Start(&htim6);
HAL_ADC_Start_DMA(&hadc1, (uint32_t *)DMABuf1,DMA_BUF_SIZE);

测试结果
接3.3,gnd,和一个正弦波
在这里插入图片描述
正弦波转换后
在这里插入图片描述

意外发现将默认的 编译器 从 5改到6 编译速度快了好多
在这里插入图片描述
以及 stm32cubeide 真的难用。。。表达式里的变量都不自动实时更新,还没ccs好用。。。 又滚回到keil了,

  • 10
    点赞
  • 65
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
可以使用STM32定时器来控制ADC采样。具体的步骤如下: 1. 配置ADC模块,包括通道选择、采样时间、转换模式等。 2. 配置定时器模块,包括定时器时钟、计数值、时钟分频等。 3. 在定时器中断服务函数中启动ADC转换,并读取转换结果。 4. 在主函数中可以根据需要对ADC采样进行处理。 下面是一个简单的示例代码: ``` #include "stm32f10x.h" void ADC1_Init(void) { GPIO_InitTypeDef GPIO_InitStructure; ADC_InitTypeDef ADC_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_ADC1, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; GPIO_Init(GPIOA, &GPIO_InitStructure); ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; ADC_InitStructure.ADC_ScanConvMode = DISABLE; ADC_InitStructure.ADC_ContinuousConvMode = ENABLE; 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)); } void TIM2_Init(void) { TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE); TIM_TimeBaseStructure.TIM_Period = 1000; TIM_TimeBaseStructure.TIM_Prescaler = 7200; TIM_TimeBaseStructure.TIM_ClockDivision = 0; TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure); TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE); TIM_Cmd(TIM2, ENABLE); } void TIM2_IRQHandler(void) { if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET) { ADC_SoftwareStartConvCmd(ADC1, ENABLE); while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC)); uint16_t adc_value = ADC_GetConversionValue(ADC1); // 处理ADC采样结果 TIM_ClearITPendingBit(TIM2, TIM_IT_Update); } } int main(void) { ADC1_Init(); TIM2_Init(); while(1); } ``` 在这个示例中,我们使用PA0作为ADC采样通道,TIM2作为定时器定时器的计数值为1000,时钟分频为7200,因此定时器的周期为100ms。在TIM2的中断服务函数中,启动ADC转换,并在转换完成后读取转换结果。在主函数中可以根据需要对ADC采样结果进行处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值