STM32F103ZET6 之 ADC+TIM+DMA+USART 综合实验

1、实验目的

1)使用 TIM1 触发 ADC,ADC 采集的数据通过DMA 传至内存,然后通过串口打印出采集的数据;  

2)学会 DMA 传输数据并将数据进行保存;

3)验证ADC 的采样率与实际设置的是否相符。


2、硬件资源

1)指示灯

2)ADC

3)DMA

4)TIM

5)杜邦线


3、软件设计

void  Adc_Configuration(void)
{ 	
  DMA_InitTypeDef DMA_InitStructure;
  ADC_InitTypeDef	ADC_InitStructure;	
  GPIO_InitTypeDef GPIO_InitStructure; 

  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC	| RCC_APB2Periph_AFIO, ENABLE);	   
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_Init(GPIOC, &GPIO_InitStructure);
	
  /* Enable DMA1 clock */
  RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
	
  DMA_DeInit(DMA1_Channel1);		          
  • 4
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 12
    评论
STM32F103ZET6是一款STM32系列的微控制器,具有很强的性能和可靠性,广泛应用于各种嵌入式系统中。其中,TIM定时器)和ADC(模数转换器)是STM32F103ZET6中非常重要的外设,可以用来完成各种任务。 下面是一个使用TIM2和ADC1实现定时采集模拟信号并进行处理的例程,供参考: ``` #include "stm32f10x.h" #define ADC1_DR_Address ((u32)0x4001244C) u16 ADC_ConvertedValue; //存放ADC转换结果 void TIM2_IRQHandler(void) { if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET) //检查TIM2更新中断是否发生 { TIM_ClearITPendingBit(TIM2, TIM_IT_Update); //清除TIM2更新中断标志位 ADC_SoftwareStartConvCmd(ADC1, ENABLE); //启动ADC转换 while (!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC)); //等待转换完成 ADC_ConvertedValue = ADC_GetConversionValue(ADC1); //读取ADC转换结果 //进行处理,例如将转换结果通过串口发送出去 } } void TIM_Configuration(void) { TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; NVIC_InitTypeDef NVIC_InitStructure; RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE); //使能TIM2时钟 TIM_TimeBaseStructure.TIM_Period = 999; //设置自动重装载寄存器 TIM_TimeBaseStructure.TIM_Prescaler = 7199; //设置预分频 TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; //向上计数模式 TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; //时钟分频因子 TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure); //初始化TIM2 TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE); //使能TIM2更新中断 NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn; //TIM2中断 NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; //抢占优先级 NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1; //子优先级 NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //使能中断通道 NVIC_Init(&NVIC_InitStructure); //初始化NVIC } void ADC_Configuration(void) { GPIO_InitTypeDef GPIO_InitStructure; ADC_InitTypeDef ADC_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_ADC1, ENABLE); //使能GPIOA和ADC1时钟 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; //PA0作为ADC输入引脚 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; //模拟输入模式 GPIO_Init(GPIOA, &GPIO_InitStructure); //初始化GPIOA 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); //初始化ADC1 ADC_RegularChannelConfig(ADC1, ADC_Channel_0, 1, ADC_SampleTime_239Cycles5); //配置ADC通道0 ADC_Cmd(ADC1, ENABLE); //使能ADC1 ADC_ResetCalibration(ADC1); //复位ADC1校准寄存器 while (ADC_GetResetCalibrationStatus(ADC1)); //等待复位完成 ADC_StartCalibration(ADC1); //开始ADC1校准 while (ADC_GetCalibrationStatus(ADC1)); //等待校准完成 } int main(void) { TIM_Configuration(); //配置TIM2 ADC_Configuration(); //配置ADC1 while (1) { } } ``` 以上代码中,首先定义了一个全局变量ADC_ConvertedValue,用来存放ADC转换结果。在TIM2的中断服务函数中,启动ADC转换,并等待转换完成后读取转换结果,然后进行一些处理操作,例如通过串口发送出去。TIM2的时钟频率为72MHz/7200=10kHz,定时周期为100ms。ADC1的采样时间为239.5个时钟周期,即每次转换时间为239.5/10e3=23.95us。在主函数中,只需要调用TIM_Configuration()和ADC_Configuration()函数进行初始化即可。 需要注意的是,ADC的输入引脚需要根据实际连接情况进行修改,例如上面的代码中使用PA0作为ADC输入引脚。另外,根据需要可以对TIM2的定时周期和ADC1的采样时间进行调整,以达到最佳效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值