博客
关于我
STM32G031-使用STM32CubeIDE实现DMA处理ADC
阅读量:490 次
发布时间:2019-03-07

本文共 1869 字,大约阅读时间需要 6 分钟。

STM32G031-使用STM32CubeIDE实现DMA处理ADC

一、USART配置

在这里插入图片描述

二、ADC配置

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
配置完成后,生成代码即可。。。

三、用户代码

/* USER CODE BEGIN Includes */#include "stdio.h"/* USER CODE END Includes *//* USER CODE BEGIN PD */#ifdef __GNUC__#define PUTCHAR_PROTOTYPE int __io_putchar(int ch)#else#define PUTCHAR_PROTOTYPE int fputc(int ch,FILE F)#endifPUTCHAR_PROTOTYPE{   	LL_USART_TransmitData8(USART2, (uint8_t)ch);	while(!LL_USART_IsActiveFlag_TXE(USART2)){   }	return ch;}/* USER CODE END PD *//* USER CODE BEGIN PV */uint16_t ADC_ConvertedValue[150];uint8_t i;uint32_t ad0,ad1,ad4;/* USER CODE END PV *//* USER CODE BEGIN 0 */void ADC_DMA_Config_Start(void){   	LL_mDelay(2); //延时2ms,避免DMA读取数据通道不对	// LL_DMA_SetChannelPriorityLevel(DMA1, LL_DMA_CHANNEL_1, LL_DMA_PRIORITY_HIGH);	LL_DMA_SetDataLength(DMA1, LL_DMA_CHANNEL_1, 150);	LL_DMA_SetMemoryAddress(DMA1, LL_DMA_CHANNEL_1,(uint32_t)ADC_ConvertedValue);	LL_DMA_SetPeriphAddress(DMA1, LL_DMA_CHANNEL_1,LL_ADC_DMA_GetRegAddr(ADC1,LL_ADC_DMA_REG_REGULAR_DATA));	LL_DMA_EnableChannel(DMA1, LL_DMA_CHANNEL_1);	LL_ADC_StartCalibration(ADC1);	while(LL_ADC_IsCalibrationOnGoing(ADC1));	LL_ADC_Enable(ADC1);	LL_ADC_REG_StartConversion(ADC1);	LL_ADC_REG_SetDMATransfer(ADC1, LL_ADC_REG_DMA_TRANSFER_UNLIMITED);}/* USER CODE END 0 *//* USER CODE BEGIN 2 */  printf("STM32CubeMX Test...\r\n");  ADC_DMA_Config_Start();  /* USER CODE END 2 *//* USER CODE BEGIN 3 */    for(i = 0,ad0 = 0,ad1 = 0,ad4 = 0; i < 150;){   		ad0 += ADC_ConvertedValue[i++];		ad1 += ADC_ConvertedValue[i++];		ad4 += ADC_ConvertedValue[i++];	}	ad0 /= 50;	// 实现均匀滤波	ad1 /= 50;	// 实现均匀滤波	ad4 /= 50;	// 实现均匀滤波//	printf("ADC->CH1 Value:%lf\r\n",(float)ad0*3.3/4095);//	printf("ADC->CH2 Value:%lf\r\n",(float)ad1*3.3/4095);//	printf("ADC->CH4 Value:%lf\r\n",(float)ad4*3.3/4095);	printf("ADC Value:%lf,%lf,%lf\r\n",(float)ad0*3.3/4095,(float)ad1*3.3/4095,(float)ad4*3.3/4095);  }  /* USER CODE END 3 */

转载地址:http://gwccz.baihongyu.com/

你可能感兴趣的文章
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>