STM32 cubemx配置USART DMA传输


前言

本篇文章来讲解DMA的概念,并使用DMA来进行串口的数据收发。

一、DMA概念

DMA(Direct Memory Access,直接内存访问)是一种计算机系统的技术,允许外部设备(如硬盘驱动器、网络适配器或图形卡)直接与计算机内存进行数据传输,而不需要CPU的直接参与。这种直接的内存访问可以提高数据传输的效率,并减轻CPU的负担。
在没有DMA的情况下,数据传输通常需要通过CPU来完成,这涉及到CPU的中断处理程序从设备读取数据,然后将数据写入内存,或者从内存读取数据,然后将数据发送到设备。这种方式会消耗CPU的时间和计算资源,限制了系统的性能和吞吐量。
通过DMA技术,外部设备可以直接与系统内存进行数据传输,而不需要CPU的干预。在DMA传输开始之前,系统配置好DMA控制器,并提供一个DMA缓冲区,外部设备可以将数据直接写入到该缓冲区或者从该缓冲区读取数据。当DMA传输完成后,DMA控制器会发出一个中断信号,以通知CPU。

使用DMA的好处包括:

1.提高数据传输速度:由于数据传输不需要CPU的介入,DMA可以以更高的速度进行数据传输,从而提高系统性能和吞吐量。
2.减轻CPU负担:传统的数据传输需要CPU的参与,消耗CPU的时间和计算资源。而使用DMA进行数据传输时,CPU可以专注于其他的计算任务,减轻了CPU的负担。
3.支持大规模数据传输:DMA技术可以支持大规模的数据传输,例如高清视频流、大型文件和网络数据包的处理。

总之,DMA是一种能够提高系统性能和数据传输效率的技术,通过允许外部设备直接与内存进行数据传输,减少了CPU的介入。这在需要高速、大量或连续数据传输的场景中特别有用,如高性能计算、网络通信和存储系统等。

二、STM32 DMA数据手册分析

从DMA的描述来看在STM32 F103这款芯片中有DMA1和DMA2,DMA1有7个通道,DMA2有5个通道。
在这里插入图片描述
DMA架构图:
DMA支持直接和SRMA进行数据的传输,不需要经过CPU,这样就可以让CPU去做其他的事情,提高系统的运行效率。

在这里插入图片描述
使用DMA(Direct Memory Access)进行数据传输时,通常需要经过以下步骤:

1.设置DMA控制器:首先,需要在系统中配置和设置DMA控制器。这包括设置DMA的源地址和目标地址,传输长度,传输方向(从内存到设备或从设备到内存),以及其他相关参数。

2.发送DMA请求:在数据传输之前,需要向DMA控制器发送DMA请求。该请求通常由CPU或设备发起,用于指示DMA控制器执行特定的数据传输操作。

3.DMA传输:一旦DMA请求被接收和识别,DMA控制器将启动数据传输。它将直接从源地址读取数据,并将数据传输到目标地址。在传输过程中,DMA控制器绕过CPU,直接控制内存和设备之间的数据传输,以提高数据传输效率并减轻CPU的负担。

4.中断或完成通知:一旦DMA传输完成,DMA控制器通常会生成一个中断信号或发送一个完成通知,以通知CPU或相关设备传输已经完成。

正常进行数据的发送:

不使用DMA进行串口的数据发送时,CPU需要从SRMA中读取出存储的数据,然后再发送给串口,发送少量数据是不会影响CPU执行其他事情的,假如我想发送10000个数据,那么这个时候就会让CPU处于一直在发送数据的状态,这样就会影响到其他程序的执行。

在这里插入图片描述
根据手册描述DMA和CPU共享总线来执行直接的内存传输。
在这里插入图片描述

DMA可以直接访问到外设和SRMA,那么这样就不需要CPU来进行数据的读取交换了,直接使用DMA就可以解决这个问题,那么这样的话就可以提高系统的运行效率了。
在这里插入图片描述

3.DMA模式介绍

下面我们来看到DMA的两种模式,一种是循环模式,一种是内存到内存的模式。
在这里插入图片描述

DMA的循环模式(Circular Mode):
在循环模式下,DMA传输的数据可以在源和目的地之间循环传输,以连续地进行数据传输操作。这种模式下,一旦DMA传输完成,它会自动重新开始下一轮传输,而无需软件干预。
循环模式对于需要在连续数据块之间进行重复传输的应用非常有用,如音频、视频流等。它可以在不中断DMA传输的情况下循环传输数据,大大提高了数据传输效率和系统性能。

DMA的内存到内存模式(Memory-to-memory Mode):
内存到内存模式允许DMA直接在两个内存区域之间进行数据传输,而无需外设的参与。在这种模式下,DMA通道可以从一个内存位置读取数据,并将数据直接写入另一个内存位置,而不需要CPU的介入。
内存到内存模式非常适用于需要在内存之间快速传输数据的应用场景,例如内存拷贝、内存填充等。通过使用这种模式,DMA可以独立地执行数据传输,减轻CPU的负担,提高传输效率。

总结:DMA的循环模式允许数据在源和目的地之间循环传输,连续进行数据传输操作,并在每次传输完成后自动重新开始下一轮传输。而DMA的内存到内存模式允许DMA直接在两个内存区域之间传输数据,而不需要外设的触发请求,并且能够快速、高效地在内存之间传输数据。这两种模式都有助于提高数据传输效率并减轻CPU的负担,适用于不同的应用场景。

4.cubemx配置DMA

4.1cubemx的配置

配置一个LED灯观察实验现象:
在这里插入图片描述
配置串口1:
在这里插入图片描述
开启串口中断:
这里不开启串口中断的话无法判断串口是否发送完成一次数据,这样串口就一直处于忙状态导致完成进行下一次的发送。

在这里插入图片描述
DMA通道设置:

TX设置为从内存到外设,因为串口的发送就是把内存中的数据取出来再发给外设,RX设置为从外设到内存,串口发送过来的数据将会保存在内存中。

模式选择Normal,循环模式的话只需要调用一次发送函数就会一直进行数据的发送了。

在这里插入图片描述

4.2DMA发送函数解析

HAL_UART_Transmit_DMA 函数是STM32 Cube HAL库中用于通过DMA(直接存储器访问)方式发送UART数据的函数。下面是该函数的原型:

HAL_StatusTypeDef HAL_UART_Transmit_DMA(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size);

参数:
huart:

类型:UART_HandleTypeDef *
描述:UART句柄,包含了UART通信所需的硬件配置和状态信息。
pData:

类型:uint8_t *
描述:指向要发送的数据缓冲区的指针。
Size:

类型:uint16_t
描述:要发送的数据字节数。

返回值:
HAL_StatusTypeDef 类型,表示函数的执行状态。这是一个枚举类型,可能的取值包括:

HAL_OK:操作成功完成。
HAL_BUSY:资源正在使用中,无法执行请求的操作。
HAL_ERROR:操作失败。
HAL_TIMEOUT:操作超时。

函数作用:
HAL_UART_Transmit_DMA 函数的作用是通过DMA方式发送一定数量的数据到UART外设。它会启动DMA传输,将数据从指定的缓冲区传输到UART的数据寄存器,实现异步的数据传输,而不需要CPU的直接干预。

在调用这个函数后,数据会被DMA引擎传输到UART的数据寄存器,而不会阻塞CPU的执行。DMA传输完成后,函数会返回相应的状态值,表示传输是否成功。

当DMA发送接收后会调用到串口发送完成回调函数:

下面是DMA发送函数的代码分析:

在使用DMA进行数据传输的时候设置了huart->hdmatx->XferCpltCallback = UART_DMATransmitCplt;

在这里插入图片描述
在UART_DMATransmitCplt函数内部会调用到HAL_UART_TxCpltCallback回调函数。
在这里插入图片描述

在DMA中断中会调用到hdma->XferCpltCallback(hdma);也就是调用HAL_UART_TxCpltCallback串口发送完成回调函数。
在这里插入图片描述
在这里插入图片描述

4.3具体使用示例

具体代码:
这里发送一个非常长的数据,同时让这个LED闪烁,看看串口的发送会不会影响到LED的闪烁,结果是不会的。

uint8_t msg[1024] = "hellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohellohello";

  while (1)
  {
    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
		HAL_UART_Transmit_DMA(&huart1, msg, strlen(msg) + 1);
		
		
		HAL_GPIO_TogglePin(GPIOB, GPIO_PIN_5);
		HAL_Delay(100);
  }

总结

本篇文章就讲解到这里,下篇文章我们讲解DMA的具体配置和DMA串口接收不定长数据。

  • 9
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 8
    评论
### 回答1: STM32F103是一款基于ARM Cortex-M3内核的单片机,它具有丰富的外设和性能优势。FreeRTOS是一款流行的实时操作系统,可用于在STM32F103上实现多任务和调度。USARTSTM32F103系列的串行通信接口,用于与外部设备进行通信。DMA(直接内存访问)是一种数据传输方式,可实现高效的数据传输,提高系统性能。CubeMX是一款图形化开发工具,可用于配置和生成STM32F103的初始化代码。 在STM32F103上使用FreeRTOS框架,可以实现多任务和调度功能。通过配置CubeMX,可以方便地设置USARTDMA外设。首先,使用CubeMX配置USART外设的工作模式、波特率等参数,并使用DMA传输数据。然后,通过编程将USART设置为DMA模式,使数据在接收和发送时通过DMA传输,提高效率和性能。在FreeRTOS任务中,可以编写代码实现与外设的通信,通过USART发送和接收数据。使用FreeRTOS的任务和调度功能,可以同时处理多个任务,提高系统的并发性和响应能力。 总之,通过结合STM32F103、FreeRTOS、USARTDMA,以及使用CubeMX配置工具,可以方便地实现多任务调度和串口通信。这样的架构可以提高系统性能,实现更复杂的应用。 ### 回答2: STM32F103是一款由意法半导体(STMicroelectronics)推出的32位单片机,它使用了Cortex-M3内核。在STM32F103中,我们可以使用FreeRTOS(Real-Time Operating System)来实现多任务处理和实时性。 USART是通用异步收发传输器,它可以用于串行通信。在STM32F103中,我们可以使用USART来进行与外部设备的通信。 DMA(Direct Memory Access)是一种数据传输方法,它可以在系统的CPU不直接参与的情况下进行数据传输。在STM32F103中,通过配置USARTDMA,可以实现高效的数据传输DMA还可以在多个外设之间进行数据传输,提高系统的效率。 CubeMX是一个图形化的配置工具,它可以帮助我们快速地配置和初始化STM32的硬件资源,生成相应的代码框架。 通过结合使用FreeRTOS、USARTDMACubeMX,我们可以实现在STM32F103上进行多任务处理、串行通信和高效数据传输的需求。首先,使用CubeMX快速配置USARTDMA相关的硬件资源,并生成代码框架。然后,根据需要,使用FreeRTOS进行任务的创建、调度和管理,实现多任务处理。在任务中,通过调用USART的相应接口来进行串行通信,并通过配置DMA来实现高效的数据传输。 总的来说,使用STM32F103、FreeRTOS、USARTDMACubeMX的组合,可以帮助我们充分发挥STM32的功能,实现复杂的应用需求,并提升系统的性能和效率。 ### 回答3: stm32f103是STMicroelectronics(ST)公司推出的一款32位单片机,它的系列名称是STM32。该系列的芯片具有高性能和低功耗的特点,广泛应用于嵌入式系统中。 FreeRTOS是一款实时操作系统(RTOS),广泛应用于嵌入式系统开发中。它提供了丰富的功能,包括任务管理、时间管理、内存管理和通信等。使用FreeRTOS能够更好地组织和管理任务,提高系统的实时性和稳定性。 USART是通用同步/异步收发器(Universal Synchronous/Asynchronous Receiver Transmitter)的缩写,是一种常用的串口通信接口。它可以实现串行数据的发送和接收,常见的应用场景包括与外部设备进行数据通信和调试信息的输出。 DMA是直接内存访问(Direct Memory Access)的缩写,它是一种不需要CPU干预的数据传输方式。在数据量较大或者需要高速传输的场景下,使用DMA能够提高数据传输的效率,减轻CPU负担。 CubeMX是一个集成开发环境(IDE),用于简化STM32芯片的配置和代码生成。通过CubeMX可以轻松地配置芯片的外设、时钟和中断等,方便开发者快速搭建项目框架。它还可以生成基于CMSIS和HAL库的初始化代码,简化开发流程。 结合以上信息,stm32f103 freertos usart dma cubemx可以理解为在使用stm32f103芯片开发嵌入式系统时,使用FreeRTOS实现任务管理和时间管理,通过USART进行与外部设备的通信,利用DMA实现高效的数据传输,同时使用CubeMX进行芯片配置和代码生成的开发流程。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

花落已飘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值