【STM32】UART通信-FIFO形式-个人理解

      一、接收:

        1.准备工作:自定义数组作为FIFO接收缓冲区;开启串口接收中断;建立并在主循环或者定时器中断函数中调用 检测FIFO缓冲区是否有数据的函数。

        2.流程:STM32作为下位机,当上位机给下位机发送数据时,当下位机收到数据(接收寄存器被赋值),会产生中断,在中断服务函数中,将接收到的数据存入FIFO接收缓冲区中;此时检测函数检测到FIFO缓冲区有不为空(有数据),会将数据以先入先出的顺序读取出来,进行下一步的处理。        

      二、发送:

        1.准备工作:自定义数组作为FIFO发送缓冲区;开启串口发送中断。

        2.流程:STM32作为上位机,上位机发送数据,此时会,面临三种情况:1.此时发送寄存器为空,那么就将要发送的数据赋值给发送寄存器,进行发送;2.此时发送寄存器不为空,且FIFO发送缓冲区未满,那么就将要发送的数据存入缓冲区;3.此时发送缓冲区不为空,FIFO发送缓冲区已满。那么就在while循环等待,直至缓冲区有位置后,存入缓冲区。当发送完成后,会生产中断,在中断服务函数中,检查FIFO发送缓冲区是否有数据,如果没有,则失能发送中断;如果有,则按照先入先出的顺序,读取缓冲区的数据,赋值给发送寄存器,进行发送,如此反复,直至最后一个数据被发送完成后,在中断函数中,判断FIFO发送缓冲区为空,则失能发送中断。

        三、总结:

        FIFO作为缓冲区,一方面,当STM32正在处理上接收到的数据时,此时有数据发送过来,会将其存入FIFO缓冲区(可以理解为一个数组),待STM32处理结束后,从FIFO缓冲区读取数据(先入先出原则),继续进行处理,因此不用担心由于数据处理不及时而导致上位机发送给下位机的数据丢失(正常来说,将收到的数据存入缓冲区的时间比对收到的数据进行数据处理解析的时间更快);另一方面,当STM32正在发送数据时,STM32只需要读取FIFO缓冲区数据,赋值给发送寄存器,待发送成功后,进入串口中断读取FIFO缓冲区数据,赋值给发送寄存器,如此反复,直至FIFO缓冲区为空。在缓冲区仍有数据的时间里,STM32可以去处理其他事情,不用等待数据发完(因为数据发送完成后,会自动进入串口中断读取数据,进行发送)。

如果有哪里描述不对的地方,还望指出

制作不易,如果对你有帮助,给个关注呗......

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: STM32UART DMA FIFO接收功能是通过使用DMA(直接存储器访问)来实现的。DMA是一种直接从外设设备到内存(或相反)进行数据传输的技术,在UART中,它可以用于接收通过串口传输的数据。 在使用DMA FIFO接收功能时,首先需要将UART设置为工作在DMA模式下。然后,需要配置DMA通道和相关的寄存器,以指定DMA传输的源地址和目标地址,以及传输的数据长度。 接下来,创建一个FIFO(First In First Out)缓冲区,用于存储接收到的数据。FIFO可以是一个数组或使用专门的FIFO库或数据结构。在每次接收到数据时,将数据存储在FIFO中。可以使用指针来跟踪FIFO的读写位置。 一旦配置好DMA和FIFO,就可以开始接收数据了。当UART接收到新的数据时,它会触发DMA请求,自动将接收到的数据传输到指定的目标地址。DMA会根据配置的设置自动进行数据的传输。 在数据接收完成后,可以通过检查DMA传输的标志位或使用中断来通知数据接收完成。然后,可以从FIFO中读取接收到的数据,并进行相应的处理。 使用DMA FIFO接收功能可以提高接收数据的效率和可靠性。由于DMA的高速传输和FIFO的缓存功能,可以减少CPU的运算压力,提高系统的性能。 总而言之,STM32UART DMA FIFO接收功能通过使用DMA和FIFO来实现串口数据的高效接收,适用于需要高速和可靠数据传输的应用场景。 ### 回答2: 在STM32微控制器中,UART是一种常用的通信接口,而DMA(直接内存访问)是一种特殊的数据传输方式,用于提高数据传输的效率。在UART接收数据时,使用DMA FIFO接收模式可以使数据的接收更加高效。 首先,使用DMA FIFO接收模式需要先使能相应的UART接收DMA请求。在STM32的寄存器中,可以设置DMA控制器和UART之间的数据流向,使DMA能够自动接收UART传输的数据。 然后,设置DMA通道的配置参数。在配置参数中,需要指定DMA的传输方向为从外设到内存,并设置外设数据宽度、内存数据宽度、传输大小等参数。通过配置这些参数,DMA可以按照指定的方式从UART接收数据并存储到内存中的指定位置。 接着,配置DMA FIFO模式。在DMA的相关寄存器中,可以设置DMA在FIFO模式下的工作方式,如FIFO传输使能、FIFO接收阈值等参数。通过配置这些参数,可以控制DMA的数据传输方式,以适应具体的应用需求。 最后,启动DMA传输。在配置DMA相关寄存器后,可以通过设置相关的标志位或调用相关的函数启动DMA传输。一旦启动了DMA传输,DMA会自动从UART接收数据并存储到内存中,无需CPU的干预。 总之,通过配置STM32UART、DMA和FIFO参数,并启动DMA传输,可以实现高效的UART接收数据。这种方式减少了CPU的负担,提高了数据传输的效率,特别适用于大量数据的接收和处理。 ### 回答3: 在STM32微控制器中,UART是一种通用异步收发传输接口,而DMA是直接内存访问控制器,用于实现高效的数据传输。FIFO(First-In-First-Out)则是一种数据缓冲区,用于存储串口接收的数据。 使用UART DMA FIFO接收数据的过程如下: 首先,需要配置UART和DMA的相关寄存器。通过设置UART的波特率、数据位数、停止位数等参数,以及DMA的通道、传输方向和缓冲区地址等信息。 接着,可以启用UART的接收中断并设置接收缓冲区的大小。当接收到数据后,将触发中断,并将数据存储在接收缓冲区中。 然后,配置DMA的传输方式。可以选择单次传输还是循环传输,以及传输长度等。 接下来,将DMA的源地址设置为UART的数据寄存器地址,将目标地址设置为FIFO缓冲区的地址,然后启动DMA传输。 最后,可以通过查询或DMA中断来检测DMA传输是否完成。当传输完成时,可以读取FIFO缓冲区中的数据,并进行相关处理。 总结来说,STM32UART DMA FIFO接收过程包括配置UART和DMA的相关寄存器、启用接收中断、设置接收缓冲区、配置DMA传输方式、启动DMA传输和检测传输完成,以实现高效的数据接收。使用UART DMA FIFO可以减少CPU的工作负载,提高系统的响应速度。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值