1 u8 _data1[4];
2 void Configuration(void)
3 {
4 USART_InitTypeDef USART_InitStructure;
5 DMA_InitTypeDef DMA_InitStructure;
6 GPIO_InitTypeDef GPIO_InitStructure;
7 RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3, ENABLE);
8 //TX
9 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
10 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
11 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
12 GPIO_InitStructure.GPIO_OType = GPIO_OType_OD;
13 GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
14 GPIO_Init(GPIOB, &GPIO_InitStructure);
15 //RX
16 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;
17 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
18 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
19 GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
20 GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
21 GPIO_Init(GPIOB, &GPIO_InitStructure);
22
23 GPIO_PinAFConfig(GPIOB, GPIO_PinSource10, GPIO_AF_USART3);
24 GPIO_PinAFConfig(GPIOB, GPIO_PinSource11, GPIO_AF_USART3);
25
26 DMA_InitStructure.DMA_Channel = DMA_Channel_4;
27 DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)&(USART3->DR);
28 DMA_InitStructure.DMA_Memory0BaseAddr = (uint32_t)_data1;
29 DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralToMemory;
30 DMA_InitStructure.DMA_BufferSize = 4;
31 DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
32 DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
33 DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;
34 DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_Byte;
35 DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;
36 DMA_InitStructure.DMA_Priority = DMA_Priority_High;
37 DMA_InitStructure.DMA_FIFOMode = DMA_FIFOMode_Disable;
38 DMA_InitStructure.DMA_FIFOThreshold = DMA_FIFOThreshold_HalfFull;
39 DMA_InitStructure.DMA_MemoryBurst = DMA_MemoryBurst_Single;
40 DMA_InitStructure.DMA_PeripheralBurst = DMA_PeripheralBurst_Single;
41 DMA_Init(DMA1_Stream1, &DMA_InitStructure);
42 DMA_Cmd(DMA1_Stream1, ENABLE);
43
44 USART_OverSampling8Cmd(USART3, ENABLE);
45 USART_InitStructure.USART_BaudRate = 38400;
46 USART_InitStructure.USART_WordLength = USART_WordLength_8b;
47 USART_InitStructure.USART_StopBits = USART_StopBits_1;
48 USART_InitStructure.USART_Parity = USART_Parity_No;
49 USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
50 USART_InitStructure.USART_Mode = USART_Mode_Rx|USART_Mode_Tx;
51 USART_Init(USART3, &USART_InitStructure);
52 USART_DMACmd(USART3, USART_DMAReq_Rx, ENABLE);
53 DMA_Cmd(DMA1_Stream1, ENABLE);
54 USART_Cmd(USART3, ENABLE);
55 }

STM32F4库函数初始化系列:串口DMA接收的更多相关文章

  1. STM32之串口DMA接收不定长数据

    STM32之串口DMA接收不定长数据 引言 在使用stm32或者其他单片机的时候,会经常使用到串口通讯,那么如何有效地接收数据呢?假如这段数据是不定长的有如何高效接收呢? 同学A:数据来了就会进入串口 ...

  2. STM32串口DMA接收数据错位——暴力解决方法

    背景:两片STM32通过串口通信,为了减小CPU负担,采用DMA进行通信,发送端为STM32F103C8T6,接收端为STM32F407VET6.在调试的过程中发现,一直出现数据错位的问题,接收端尝试 ...

  3. STM32 HAL 库实现乒乓缓存加空闲中断的串口 DMA 收发机制,轻松跑上 2M 波特率

    前言 直接储存器访问(Direct Memory Access,DMA),允许一些设备独立地访问数据,而不需要经过 CPU 介入处理.因此在访问大量数据时,使用 DMA 可以节约可观的 CPU 处理时 ...

  4. STM32 串口DMA方式接收(转)

    STM32 是一款基于ARM Cortex-M3内核的32位MCU,主频最高可达72M.最近因为要在车机上集成TPMS功能, 便开始着手STM32的开发工作,STM32F10x系列共有5个串口(USA ...

  5. STM32—无需中断来实现使用DMA接收串口数据

    本节目标: 通过DMA,无需中断,接收不定时长的串口数据 描述:当在串口多数据传输下,CPU会产生多次中断来接收串口数据,这样会大大地降低CPU效率,同时又需要CPU去做其它更重要的事情,我们应该如何 ...

  6. STM32 串口功能 库函数 详解和DMA 串口高级运用(转载)

    数据传输时要从支持那些相关的标准?传输的速度?什么时候开始?什么时候结束?传输的内容?怎样防止通信出错?数据量大的时候怎么弄?硬件怎么连接出发,当然对于stm32还要熟悉库函数的功能 具起来rs232 ...

  7. STM32使用串口1配合DMA接收不定长数据,减轻CPU载荷

    STM32使用串口1配合DMA接收不定长数据,减轻CPU载荷 http://www.openedv.com/thread-63849-1-1.html 实现思路:采 用STM32F103的串口1,并配 ...

  8. STM32CubeMX HAL库串口+DMA数据发送不定长度数据接收

    参考资料:1.ST HAL库官网资料 2.https://blog.csdn.net/u014470361/article/details/79206352#comments 一.STM32CubeM ...

  9. 串口配合DMA接收不定长数据(空闲中断+DMA接收)-(转载)

    1.空闲中断和别的接收完成(一个字节)中断,发送完成(发送寄存器控)中断的一样是串口中断: 2.空闲中断是接收到一个数据以后,接收停顿超过一字节时间  认为桢收完,总线空闲中断是在检测到在接收数据后, ...

  10. 串口1配合DMA接收不定长数据(空闲中断+DMA接收)

    1.空闲中断和别的接收完成(一个字节)中断,发送完成(发送寄存器控)中断的一样是串口中断: 2.空闲中断是接收到一个数据以后,接收停顿超过一字节时间  认为桢收完,总线空闲中断是在检测到在接收数据后, ...

随机推荐

  1. Kafka教程(二)API开发-生产者、消费者、topic

    一.地址 1.实时更新的思维导图 https://www.mubucm.com/doc/4uqlpedefuj 2.图片 二.具体内容   5.producer生产者   demo   发送pro.s ...

  2. 4.10:Spark之wordcount

    〇.概述 1.拓扑结构 2.目标 使用spark完成计数实验 一.启动环境 二.新建数据文件 三.查看文件内容 四.启动spark服务 五.编写代码 复制以下代码到shell中(复制后在终端右键-&g ...

  3. tcp/udp 协议特性和三次握手

    一.TCP/UDP协议特性1)TCP特性:工作在传输层.建立连接.可靠的.错误检查 2)UDP特性:工作在传输层.不需要连接.不可靠的.有限的错误检查.传输性能高 2.控制位及确认号解释 控制位:由6 ...

  4. Qt多线程开发总览,既然用到了就记录一下

    多线程 在LBD_VM_Intercom中使用的一个简单的实例 陶工给的dll需要进行异步操作才可以将视频画面附到窗体上,必须得在画面出现之后才可以附加画面,否则就有可能出现意外bug,所以需要在这个 ...

  5. APP异常测试点汇总

    在测试APP时异常测试是非常必要的. 安装卸载中的异常测试 一.安装 安装过程中设备重启 安装过程中息屏 安装过程中断网 安装过程中切换网络 安装过程中收到短信提醒 安装过程中收到来电提醒 安装过程中 ...

  6. Vulnhub之Credit_Card_Scammers靶场渗透

    前言 一次"夺旗"练习,涵盖了许多不同的技巧. 背后的故事:骗子正在利用人们,各种假冒购物网站已经建立起来,但人们发现他们的订单从未到达.我们发现了一个诈骗网站,我们认为该网站正在 ...

  7. 论文解读(CAN)《Contrastive Adaptation Network for Unsupervised Domain Adaptation》

    论文信息 论文标题:Contrastive Adaptation Network for Unsupervised Domain Adaptation论文作者:Guoliang Kang, Lu Ji ...

  8. [编程基础] C++多线程入门5-使用互斥锁解决资源竞争

    原始C++标准仅支持单线程编程.新的C++标准(称为C++11或C++0x)于2011年发布.在C++11中,引入了新的线程库.因此运行本文程序需要C++至少符合C++11标准. 文章目录 5 使用互 ...

  9. MongoDB从入门到实战之.NET Core使用MongoDB开发ToDoList系统(2)-Swagger框架集成

    Swagger是什么? Swagger是一个规范且完整API文档管理框架,可以用于生成.描述和调用可视化的RESTful风格的 Web 服务.Swagger 的目标是对 REST API 定义一个标准 ...

  10. mysql基础命令语法

    删除空格 update 表名 set 字段名 = replace(字段名 ,' ','') ; 临时表创建与删除 -- 创建临时表 create temporary table if not exis ...