这是以前学32的时候写的,那时候学了32之后感觉32真是太强大了,比51强的没影。关于dma网上有许多的资料,关于dma采集ad网上也有很多。亲们搜搜,这里只贴代码了,其实我也想详详细细地叙述一番,但是自己本身打字就慢,还有好多事情要做!代码是我亲自都在板子上测试过的,,当然粘贴/复制过去可能也不会尽如人意,知识这东西总是有许多道不清说不明的东西在里头,往往总是不经一番彻骨寒,哪得梅花扑鼻香。推荐一本书吧!这是野火出的。

这本书自从在图书馆借来就从来没有再放回去,总是在续借。像是在打广告了

#include <stm32f10x.h>
#include "ADC1.h"
#include "DMA1.h"
#include "USART1.h"
#include "time.h"
#include "stdio.h"extern uint32_t SendBuff;
float ADC_Received;
uint32_t ADC_Received1;
uint8_t ADC_Received2[11];//printf函数重新定向,方便在程序中使用
int fputc(int ch, FILE *f)
{  USART_SendData(USART1, (unsigned char) ch);while (!(USART1->SR & USART_FLAG_TXE)); return (ch);
}void usart_putchar(uint8_t ch)
{USART_SendData(USART1,ch);while(USART_GetFlagStatus(USART1,USART_FLAG_TXE) == RESET);
}int main()
{ADC1_Config();DMA_Config();USART1_Config();while(1){//      ADC_Received = (float)ADC_GetConversionValue(ADC1)*3.3/4069;
//      ADC_Received1 = ADC_Received * 1000000000;
     ADC_Received = (float)SendBuff*3.3/4069;ADC_Received1 = ADC_Received * 1000000000;ADC_Received2[0]=(ADC_Received1/1000000000 + 0x30);//usart_putchar(0x2e); ADC_Received2[1]=(ADC_Received1%1000000000/100000000 + 0x30);ADC_Received2[2]=(ADC_Received1%1000000000%100000000/10000000 + 0x30);ADC_Received2[3]=(ADC_Received1%1000000000%100000000%10000000/1000000 + 0x30);ADC_Received2[4]=(ADC_Received1%1000000000%100000000%10000000%1000000/100000 + 0x30);ADC_Received2[5]=(ADC_Received1%1000000000%100000000%10000000%1000000%100000/10000 + 0x30); ADC_Received2[6]=(ADC_Received1%1000000000%100000000%10000000%1000000%100000%10000/1000 + 0x30); ADC_Received2[7]=(ADC_Received1%1000000000%100000000%10000000%1000000%100000%10000%1000/100 + 0x30); ADC_Received2[8]=(ADC_Received1%1000000000%100000000%10000000%1000000%100000%10000%1000%100/10 + 0x30); ADC_Received2[9]=(ADC_Received1%10 + 0x30);ADC_Received2[10]=0x0d;USART_DMACmd(USART1, USART_DMAReq_Tx, ENABLE);
//      delay_ms(1000);
//      USART_DMACmd(USART1, USART_DMAReq_Tx, DISABLE);
//      delay_ms(1000);
//     ADC_Received = (float) SendBuff/4069*3.3;//      ADC_Received = (u16)ADC1 -> DR;
//      ADC_Received = (float)ADC_Received/4069*3.3;
//      printf("\r\n v = %f V \r\n",ADC_Received);
//        while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC ));//      usart_putchar('\r');
//      usart_putchar('\n'); //      usart_putchar(0x0d);
//      usart_putchar(0x0a); //      printf("\r");
//      printf("\n");
//      printf("\r\n V = %fv\r\n",ADC_Received);
    }
}
#include "ADC1.h"void ADC1_Config(void)
{ADC_InitTypeDef ADC_InitStructure;RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE);ADC1_Gpio_Config();ADC_DeInit(ADC1); //复位 ADC1,将外设 ADC1 的全部寄存器重设为缺省值// ADC1 配置ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; //ADC1工作在独立模式ADC_InitStructure.ADC_ScanConvMode = ENABLE;//使能扫描ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;;//ADC转换工作在连续模式ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;//由软件控制转换ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;//转换数据右对齐ADC_InitStructure.ADC_NbrOfChannel = 1;//转换通道为通道1ADC_Init(ADC1, &ADC_InitStructure); //初始化ADC //ADC1选择信道0,顺续等级1,采样时间239.5个周期ADC_RegularChannelConfig(ADC1, ADC_Channel_0, 1, ADC_SampleTime_28Cycles5);    //打开ADC1
  ADC_Cmd(ADC1, ENABLE);//重置ADC1校准寄存器
  ADC_ResetCalibration(ADC1); //等待ADC1校准重置完成while(ADC_GetResetCalibrationStatus(ADC1));  //开始ADC1校准
  ADC_StartCalibration(ADC1); //等待ADC1校准完成while(ADC_GetCalibrationStatus(ADC1)); //使能ADC1软件开始转换
  ADC_SoftwareStartConvCmd(ADC1, ENABLE);//配置ADC时钟=PCLK2 1/6    12MHz
  RCC_ADCCLKConfig(RCC_PCLK2_Div6); //使能ADC1模块DMA
  ADC_DMACmd(ADC1, ENABLE);
}static void ADC1_Gpio_Config(void)
{GPIO_InitTypeDef GPIO_InitStructure;RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;GPIO_Init(GPIOA , &GPIO_InitStructure);}
#include "DMA1.h"/* 其他函数里 USART_DMACmd(USART1, USART_DMAReq_Tx, ENABLE);     */
uint32_t  SendBuff;
extern float ADC_Received;
extern uint8_t ADC_Received2[11];
//描述  :DMA 串口的初始化配置void DMA_Config(void)
{//初始化结构体
    DMA_InitTypeDef DMA_InitStructure;//开启DMA时钟
      RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);    //配置DMA中断
      NVIC_Config();                   //设置DMA源:地址
     DMA_InitStructure.DMA_PeripheralBaseAddr = (u32)&ADC1 -> DR;      //*内存地址(要传输的变量的指针)DMA_InitStructure.DMA_MemoryBaseAddr = (u32)&SendBuff;//外设作为数据传输的来源DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;    //指定 DMA 通道的 DMA 缓存的大小,单位为数据单位。DMA_InitStructure.DMA_BufferSize = 1;//*外设地址不增        DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; //*内存地址不增DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Disable;    //*外设数据单位数据宽度为 16 位DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;//*内存数据单位数据宽度为 16 位DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;     //*DMA模式:一次传输/循环
//         DMA_Mode_Circular 工作在循环缓存模式
//    DMA_Mode_Normal 工作在正常缓存模式
//     DMA_InitStructure.DMA_Mode = DMA_Mode_Normal ;    DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;        //*优先级:高DMA_InitStructure.DMA_Priority = DMA_Priority_High;  //*禁止内存到内存的传输    DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;//*配置DMA1的1通道           DMA_Init(DMA1_Channel1, &DMA_InitStructure); //使能DMA
      DMA_Cmd (DMA1_Channel1,ENABLE);//配置DMA发送完成后产生中断
//       DMA_ITConfig(DMA1_Channel1,DMA_IT_TC,ENABLE); //****************************************************///
//****************************************************///
//****************************************************/////设置DMA源:地址DMA_InitStructure.DMA_PeripheralBaseAddr = (u32)&USART1 -> DR;      //*内存地址(要传输的变量的指针)DMA_InitStructure.DMA_MemoryBaseAddr = (u32)ADC_Received2;//外设作为数据传输的目的地DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralDST;    //指定 DMA 通道的 DMA 缓存的大小,单位为数据单位。DMA_InitStructure.DMA_BufferSize = 11;//*外设地址不增        DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; //*内存地址不增DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;    //*外设数据单位数据宽度为 16 位DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;//*内存数据单位数据宽度为 16 位DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_Byte;     //*DMA模式:一次传输/循环
//         DMA_Mode_Circular 工作在循环缓存模式
//    DMA_Mode_Normal 工作在正常缓存模式
//     DMA_InitStructure.DMA_Mode = DMA_Mode_Normal ;    DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;        //*优先级:中DMA_InitStructure.DMA_Priority = DMA_Priority_Medium;  //*禁止内存到内存的传输    DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;//*配置DMA1的4通道           DMA_Init(DMA1_Channel4, &DMA_InitStructure); //使能DMA
      DMA_Cmd (DMA1_Channel4,ENABLE);//配置DMA发送完成后产生中断
//       DMA_ITConfig(DMA1_Channel1,DMA_IT_TC,ENABLE);
}
#include "time.h"/****************
延时多少个 1/72 us
****************/
void delay_1_72us(uint32_t time)
{SysTick -> LOAD = (u32) time; //定时器赋初值
    SysTick -> CTRL = 0x00000005; //选择72MHz 并 打开定时器while(!(SysTick -> CTRL & 0x00010000));//等待计数到零
SysTick -> CTRL = 0x00000004;//关闭定时器

}void delay_ms(u32 time)
{while(time -- ){delay_1_72us(72000);}}
#include "USART1.h"//描述  :USART1 GPIO 配置,工作模式配置。115200 8-N-1void USART1_Config(void)
{GPIO_InitTypeDef GPIO_InitStructure;USART_InitTypeDef USART_InitStructure;// 打开  USART1 的时钟RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA, ENABLE);// USART1 Tx (PA_9) GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;//复用推挽输出GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;GPIO_Init(GPIOA, &GPIO_InitStructure);    // USART1 Tx (PA_10) GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;//浮空输入GPIO_Init(GPIOA, &GPIO_InitStructure);/* USART1 mode config */USART_InitStructure.USART_BaudRate = 115200;USART_InitStructure.USART_WordLength = USART_WordLength_8b;USART_InitStructure.USART_StopBits = USART_StopBits_1;USART_InitStructure.USART_Parity = USART_Parity_No ;USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;USART_Init(USART1, &USART_InitStructure); USART_Cmd(USART1, ENABLE);
}

转载于:https://www.cnblogs.com/yangfengwu/p/5297147.html

stm32_DMA采集一个AD数据_并通过DMA向串口发送相关推荐

  1. stm32串口接收不定长数据_基于STM32之UART串口通信协议--接收

    一.前言 1.简介 回顾上一篇UART发送当中,已经讲解了如何实现UART的发送操作了,接下来这一篇将会继续讲解如何实现UART的接收操作. 2.UART简介 嵌入式开发中,UART串口通信协议是我们 ...

  2. stm32串口发送数据的配置,以及通过串口发送结构体数组总是多一个00字节的问题

    最近用stm32编写串口发送程序,在硬件方面需要做如下准备: 1.stm32开发板,这里我的是stm32f030f4p4开发板,单片机的串口发送的引脚为PA9-TX,PA10-RX. 2.为了调试串口 ...

  3. 怎么用vc采集ni卡数据_智能水表读数怎么看?家用智能水表怎么安装?

    平时生活中最离不开的就是水源,因此这也就与电表有着密不可分的联系,现在很多家庭使用的都是智能水表,但是对其怎么看?怎么安装相信绝大多数人都不太了解,下面就跟随装一网一起来看看吧! 智能水表的类型 1. ...

  4. 怎么用vc采集ni卡数据_利用labview、matlab和c实现非ni接口卡的数据采集及处理

    利用LabVIEW .MATLAB 和C 实现非NI 接口卡的数据采集及处理** 周旭欣1 董兵超1 向明礼2 李拥秋1 袁支润1? (1.四川大学生物力学研究所,成都:610065:2.四川大学化工 ...

  5. python采集抖音数据_【图片】如何采集抖音的数据?【python吧】_百度贴吧

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 抖音App和服务端交互使用的是HTTPS协议,使用Fiddler很容易可以捕获到数据,如下图所示. 不过想要自己模拟一个有效的请求可不是那么容易了,因为它 ...

  6. 怎么用vc采集ni卡数据_作家型INFJ的N灵感采集 | INFJ自我成长

    "美是美妙,是奇异,艺术家唯有通过灵魂的煎熬,才能从宇宙的混沌中创造出美.而当美出现,它并非为了让每个人都认出它自己.要认识它,你必须重复和艺术家一样的奇异之旅.这是一支他唱给你的旋律,要想 ...

  7. python采集抖音数据_抖音数据采集,最全python库selenium自动化使用!

    driver = webdriver.Chrome() driver.maximize_window() 四.访问页面 from selenium import webdriver driver = ...

  8. python采集直播间数据_如何抓取实时/直播数据网站?

    此网站的数据每1秒更新一次import time import requests from bs4 import BeautifulSoup l=[] def get_data(): url='htt ...

  9. hal 双串口同时接收丢失数据_【STM32Cube_06】使用USART发送和接收数据(查询模式)...

    寻求更简洁舒适的阅读体验,请移步Mculover666的个人博客: [STM32Cube_06]使用USART发送和接收数据(查询模式)​www.mculover666.cn 本篇文章主要介绍如何使用 ...

最新文章

  1. pyhton object is not subscriptable 解决
  2. 如何用 ajax 连接mysql数据库,并且获取从中返回的数据。ajax获取从mysql返回的数据。responseXML分别输出不同数据的方法。...
  3. python网络通信编程实例_python网络编程之数据传输UDP实例分析
  4. 九省联考2018总结
  5. 【debug】使用lambda在循环中传参时,参数总为同一个值
  6. android camera2 qcom,lineage编译环境里,编译QCamera2的技术总结
  7. 月薪2万是一种怎样的人生体验?
  8. 2021-2025年中国超细氢氧化铝行业市场供需与战略研究报告
  9. 烂泥:Postfix邮件服务器搭建之软件安装与配置
  10. java实现 mysql导入_怎么用java实现mysql数据库的导入导出
  11. 优先级调度算法和高响应比优先调度算法
  12. Python打包exe程序太大的解决方法
  13. 加州大学戴维斯分校 计算机科学,美国王牌专业!加州大学戴维斯分校计算机科学专业等你来...
  14. 一文读懂:制造业头部企业如何构建经营分析数字化体系
  15. 前端页面导出为xls、xlsx格式的excel文件
  16. Android模拟键盘输入功能的实现
  17. linux下repo文件的配置
  18. 2022年11月(下半年)信息系统项目管理师考试-案例分析真题及解析
  19. (16)业务数据导入HDFS
  20. c51抢答器程序汇编语言,c51单片机汇编语言单片机八位抢答器程序

热门文章

  1. 就业阶段-java语言进价_day06
  2. JavaScript 打印结果时多出一个undefined/出现undefined
  3. Web框架——Flask系列之数据库迁移(二十)
  4. LeetCode 1473. 给房子涂色 III(DP)
  5. LeetCode 784. 字母大小写全排列(位运算回溯)
  6. 字符串匹配算法(BM)
  7. Python中查找包含它的列表元素的索引,index报错!!!
  8. Django创建图书管理项目(完整版
  9. 无内鬼,来点ICML/ACL审稿人笑话
  10. 腾讯天衍实验室新算法入选国际万维网大会 新冠疫苗AI问答上线