STM32F401用配置串口2的dma,并用串口dma发送数据给上位机,请只用c语言标准库详细编写相关代码

时间: 2023-11-22 13:54:53 浏览: 35
以下是使用标准库配置STM32F401串口2 DMA发送数据的代码: ```c #include "stm32f4xx.h" #include <string.h> #define USART_TX_BUFFER_SIZE 100 uint8_t usart_tx_buffer[USART_TX_BUFFER_SIZE]; // 串口发送缓冲区 volatile uint16_t usart_tx_head = 0; // 缓冲区头指针 volatile uint16_t usart_tx_tail = 0; // 缓冲区尾指针 void USART2_Init(void) { GPIO_InitTypeDef GPIO_InitStruct; USART_InitTypeDef USART_InitStruct; DMA_InitTypeDef DMA_InitStruct; // 使能GPIOA时钟 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE); // 配置PA2为USART2_TX GPIO_InitStruct.GPIO_Pin = GPIO_Pin_2; GPIO_InitStruct.GPIO_Mode = GPIO_Mode_AF; GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStruct.GPIO_OType = GPIO_OType_PP; GPIO_InitStruct.GPIO_PuPd = GPIO_PuPd_UP; GPIO_Init(GPIOA, &GPIO_InitStruct); // 配置USART2时钟 RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE); // 初始化USART2参数 USART_InitStruct.USART_BaudRate = 115200; USART_InitStruct.USART_WordLength = USART_WordLength_8b; USART_InitStruct.USART_StopBits = USART_StopBits_1; USART_InitStruct.USART_Parity = USART_Parity_No; USART_InitStruct.USART_HardwareFlowControl = USART_HardwareFlowControl_None; USART_InitStruct.USART_Mode = USART_Mode_Tx; USART_Init(USART2, &USART_InitStruct); // 使能USART2 USART_Cmd(USART2, ENABLE); // 配置DMA1时钟 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_DMA1, ENABLE); // 配置DMA1_Stream6 DMA_InitStruct.DMA_Channel = DMA_Channel_4; DMA_InitStruct.DMA_PeripheralBaseAddr = (uint32_t)&USART2->DR; DMA_InitStruct.DMA_Memory0BaseAddr = (uint32_t)usart_tx_buffer; DMA_InitStruct.DMA_DIR = DMA_DIR_MemoryToPeripheral; DMA_InitStruct.DMA_BufferSize = 0; DMA_InitStruct.DMA_PeripheralInc = DMA_PeripheralInc_Disable; DMA_InitStruct.DMA_MemoryInc = DMA_MemoryInc_Enable; DMA_InitStruct.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte; DMA_InitStruct.DMA_MemoryDataSize = DMA_MemoryDataSize_Byte; DMA_InitStruct.DMA_Mode = DMA_Mode_Normal; DMA_InitStruct.DMA_Priority = DMA_Priority_High; DMA_InitStruct.DMA_FIFOMode = DMA_FIFOMode_Disable; DMA_InitStruct.DMA_FIFOThreshold = DMA_FIFOThreshold_HalfFull; DMA_InitStruct.DMA_MemoryBurst = DMA_MemoryBurst_Single; DMA_InitStruct.DMA_PeripheralBurst = DMA_PeripheralBurst_Single; DMA_Init(DMA1_Stream6, &DMA_InitStruct); // 使能DMA1_Stream6传输完成中断 DMA_ITConfig(DMA1_Stream6, DMA_IT_TC, ENABLE); // 配置NVIC中断优先级 NVIC_InitTypeDef NVIC_InitStruct; NVIC_InitStruct.NVIC_IRQChannel = DMA1_Stream6_IRQn; NVIC_InitStruct.NVIC_IRQChannelPreemptionPriority = 0; NVIC_InitStruct.NVIC_IRQChannelSubPriority = 0; NVIC_InitStruct.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStruct); } void USART2_DMA_Send(uint8_t *data, uint16_t len) { uint16_t i; for (i = 0; i < len; i++) { // 将数据写入缓冲区 usart_tx_buffer[usart_tx_head] = data[i]; usart_tx_head = (usart_tx_head + 1) % USART_TX_BUFFER_SIZE; } // 如果DMA未在传输,则启动DMA传输 if (DMA_GetCmdStatus(DMA1_Stream6) == DISABLE) { DMA_Cmd(DMA1_Stream6, DISABLE); DMA_SetCurrDataCounter(DMA1_Stream6, usart_tx_head > usart_tx_tail ? usart_tx_head - usart_tx_tail : USART_TX_BUFFER_SIZE - usart_tx_tail); DMA_Cmd(DMA1_Stream6, ENABLE); } } void DMA1_Stream6_IRQHandler(void) { // 清除传输完成中断标志位 DMA_ClearITPendingBit(DMA1_Stream6, DMA_IT_TCIF6); // 更新缓冲区尾指针 usart_tx_tail = usart_tx_head; // 如果缓冲区不为空,则启动DMA传输 if (usart_tx_head != usart_tx_tail) { DMA_Cmd(DMA1_Stream6, DISABLE); DMA_SetCurrDataCounter(DMA1_Stream6, usart_tx_head > usart_tx_tail ? usart_tx_head - usart_tx_tail : USART_TX_BUFFER_SIZE - usart_tx_tail); DMA_Cmd(DMA1_Stream6, ENABLE); } } int main(void) { USART2_Init(); // 发送字符串 "Hello, world!\r\n" USART2_DMA_Send((uint8_t *)"Hello, world!\r\n", strlen("Hello, world!\r\n")); while (1); return 0; } ``` 在上面的代码中,首先定义了一个`usart_tx_buffer`数组作为串口发送缓冲区,以及`usart_tx_head`和`usart_tx_tail`两个指针来指示缓冲区的头和尾。然后,在`USART2_Init()`函数中,配置了USART2和DMA1,使其能够通过DMA发送数据。其中,`USART2_DMA_Send()`函数用于将数据写入缓冲区,并启动DMA传输。最后,在`main()`函数中,调用`USART2_DMA_Send()`发送字符串"Hello, world!\r\n"。当DMA传输完成时,会触发`DMA1_Stream6_IRQHandler()`中断处理函数,更新缓冲区的尾指针,并在缓冲区不为空时启动DMA传输。

相关推荐

最新推荐

recommend-type

STM32的使用之SPI通信DMA模式

MCU:STM32F303VC,在SPI通信中,可以同时开启发送和接收DMA请求,自动数据的发送和接收,完成数据的交换。
recommend-type

STM32串口发送注意问题

本文介绍了使用STM32串口发送数据时由TC状态位引起的错误以及解决方法。
recommend-type

在STM32上通过UART+DMA实现One-Wire总线

One-wire总线使用一根并联总线完成对于多个设备的访问,通过上拉的OD门实现多设备的读写操作,通过ID区别设备,通过CRC5完成数据校验。
recommend-type

用Proteus8.9自带STM32F401VE的Controller仿真STM32F407ZGT6,F429IGT6

一, 目前得到的 Proteus8.9版本软件能够支持的...但STM32F401VE的固件库基于Cortex-M4,笔者就想利用Proteus8.9版本软件现有的STM32F401VE的固件库,对F407,F429系列芯片通过Proteus VSM Studio进行仿真实验应用。
recommend-type

setuptools-40.7.3-py2.py3-none-any.whl

Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。