这是以前学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[]; //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()
{ // ADC_Received = (float)ADC_GetConversionValue(ADC1)*3.3/4069;
// ADC_Received1 = ADC_Received * 1000000000; ADC_Received = (float)SendBuff*3.3/;
ADC_Received1 = ADC_Received * ; ADC_Received2[]=(ADC_Received1/ + 0x30);
//usart_putchar(0x2e);
ADC_Received2[]=(ADC_Received1%/ + 0x30);
ADC_Received2[]=(ADC_Received1%%/ + 0x30);
ADC_Received2[]=(ADC_Received1%%%/ + 0x30);
ADC_Received2[]=(ADC_Received1%%%%/ + 0x30);
ADC_Received2[]=(ADC_Received1%%%%%/ + 0x30);
ADC_Received2[]=(ADC_Received1%%%%%%/ + 0x30);
ADC_Received2[]=(ADC_Received1%%%%%%%/ + 0x30);
ADC_Received2[]=(ADC_Received1%%%%%%%%/ + 0x30);
ADC_Received2[]=(ADC_Received1% + 0x30);
ADC_Received2[]=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
ADC_Init(ADC1, &ADC_InitStructure); //初始化ADC //ADC1选择信道0,顺续等级1,采样时间239.5个周期
ADC_RegularChannelConfig(ADC1, ADC_Channel_0, , 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[];
//描述 :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 = ; //*外设地址不增
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 = ; //*外设地址不增
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();
} }
#include "USART1.h" //描述 :USART1 GPIO 配置,工作模式配置。115200 8-N-1 void 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 = ;
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);
}

stm32_DMA采集一个AD数据_并通过DMA向串口发送的更多相关文章

  1. C#串口通信—向串口发送数据,同步接收返回数据

    最近写C#串口通信程序,系统是B/S架构.SerialPort类有一个DataReceived事件,用来接收串口返回的数据,但这种方式在C/S架构下很好用,但B/S就不好处理了.所以写了一个同步模式接 ...

  2. 把采集到的数据发送到一个Google Docs或者Google Form上 这个网站提供了参考和例子

    把采集到的数据发送到一个Google Docs或者Google Form上这个网站提供了参考和例子 http://www.instructables.com/id/Post-to-Google-Doc ...

  3. MySQL 仅保留7天、一个月数据

    /************************************************************************** * MySQL 仅保留7天.一个月数据 * 说明 ...

  4. DirectSound播放PCM(可播放实时采集的音频数据)

    前言 该篇整理的原始来源为http://blog.csdn.net/leixiaohua1020/article/details/40540147.非常感谢该博主的无私奉献,写了不少关于不同多媒体库的 ...

  5. 如何将域中的AD数据导入SharePoint

    转:http://www.cnblogs.com/wallis0922/archive/2010/09/29/1838292.html 最近刚装好sharepoint2010,想要研究一下,第一件想做 ...

  6. Hello_Motion_Tracking 任务一:Project Tango采集运动追踪数据

    我们来看一下中的几个基本的例子 (区域描述.深度感知.运动追踪.视频4个) 参考:Google Tango初学者教程 1. hello_motion_tracking package com.proj ...

  7. 使用火蜘蛛采集器Firespider采集天猫商品数据并上传到微店

    有很多朋友都需要把天猫的商品迁移到微店上去.可在天猫上的商品数据非常复杂,淘宝开放接口禁止向外提供数据,一般的采集器对ajax数据采集的支持又不太好. 还有现在有了火蜘蛛采集器,经过一定的配置,终于把 ...

  8. 如何基于Go搭建一个大数据平台

    如何基于Go搭建一个大数据平台 - Go中国 - CSDN博客 https://blog.csdn.net/ra681t58cjxsgckj31/article/details/78333775 01 ...

  9. 用Python实现一个大数据搜索引擎

    用Python实现一个大数据搜索引擎 搜索是大数据领域里常见的需求.Splunk和ELK分别是该领域在非开源和开源领域里的领导者.本文利用很少的Python代码实现了一个基本的数据搜索功能,试图让大家 ...

随机推荐

  1. css实现自适应正方形的方法

    页面布局中,我们经常需要用百分比来实现宽度自适应,但是如果这时候高度要跟宽度呈固定比例变化,该怎么办呢? 很简单,我们可以利用元素的padding或margin的百分比值是参照父元素的宽度这一特性来实 ...

  2. 取消Fetch API请求

    如今,Fetch API已经成为现在浏览器异步网络请求的标准方法,但Fetch也是有弊端的,比如: Fetch还没有方法终止一个请求,而且Fetch无法检测上传进度 现在我们可以通过 AbortCon ...

  3. 活字格Web应用平台学习笔记5 - 编辑和删除记录

    了几天,今天上活字格网站一看,他们获奖了,好厉害 荣膺盘古奖!活字格引领企业信息化建设新潮流 好吧,我继续学习,希望早点拿到认证证书. 今天要学的是编辑删除记录.目标: 还是接续之前的工程.做好后是这 ...

  4. TensorFlow数据读取方式:Dataset API

    英文详细版参考:https://www.cnblogs.com/jins-note/p/10243716.html Dataset API是TensorFlow 1.3版本中引入的一个新的模块,主要服 ...

  5. 排错-Ad Hoc Distributed Queries组件被禁用的解决办法

    Ad Hoc Distributed Queries组件被禁用的解决办法 by:授客 QQ:1033553122 SQL Server 阻止了对组件 'Ad Hoc Distributed Queri ...

  6. 原生JSON解析

    原生JSON解析 JSONObject:JSON数据封装对象JSONArray:JSON数据封装数组 布局: <?xml version="1.0" encoding=&qu ...

  7. Python 面向对象补充

    什么是面向对象编程 类 + 对象 class 类: def 函数1(): pass def 函数2(): pass obj是对象, 实例化的过程 obj = 类() obj.函数1() 例1 , 某些 ...

  8. cmd 命令总结

    1.windows 系统定时关机  定时关机:shutdown -s -t 300                 at 18:30 shutdown -s 取消定时:shutdown -a 注意:3 ...

  9. eclipse中svn插件的工程不能与svn资源库同步的解决方法

    eclipse中svn插件的工程不能与svn资源库同步的解决办法 最近几天自己的工程与资源库同步总是出现问题,重启机器后发现资源库丢失了,无法进行同步. 解决办法如下: 1.右键工程---->选 ...

  10. MySQL案例-mysqld got signal 11

    背景:MySQL-5.7.12, debian 8核16G虚拟机, 业务方反馈在某一个时间点, 出现了大量的数据库报错, 之后恢复正常; 场景:开发查看日志后, 发现在某个时间点, 应用断开了所有与数 ...