
UART应用异常案例分析 - U# ~$ s! m1 O, @" j9 | 前言7 ^9 ~! L8 D* H3 a 在Cube软件包中,为不同系列MCU、不同外设提供了对应的例程方便开发参考。其中,针对STM324xG-EVAL平台提供了UART中断发送接收的例程。开发者参考了这个例程进行UART功能开发,并且为了实现不间断的接收功能,在接收回调函数中,再次调用中断接收函数。在这种情况下,出现了例程执行异常。本文分析了这种情况出现原因及解决方法。 8 m% Z% N3 A* K" F' D" q 问题描述 测试验证板: STM3240G-EVAL0 F( N" s4 r+ B 参考例程路径:STM32Cube_FW_F4_V1.15.0\Projects\STM324xG_EVAL\Examples\UART\UART_Hyperterminal_IT 基于上述例程,出于前言中交代的应用目的,在接收回调函数HAL_UART_RxCpltCallback中,再次调用HAL_UART_Receive_IT。 随后出现例程执**死在下面红色标识的语句处,导致了UART中断发送无**确被执行。 ![]() 问题分析及解决) t' z" H2 W Y# n$ J& v 根据描述,首先考虑到是否由于UART始终处于接收忙状态,导致中断发送收到影响。但是UART外设具有发送数据寄存器和接收数据寄存器,以及互不影响的接收、发送中断。+ n6 f1 q, @; ^ 继续对问题进行定位,发现在HAL_UART_GetState函数中,会同时获取发送和接收状态。这意味着,只有在发送和接收同时处于就绪状态时,中断发送函数才会被执行。而开发者的应用实现中,使得UART始终处于接收状态,从而判断无法通过。- Z; L# Q5 v: B8 \, p& b1 H! E 清楚了产生原因后,问题解决就一目了然了。只需将对发送和接收状态的判断,改写成仅对发送的状态的判断,如下所示。其中gState对应着发送状态。 ![]() + B$ o w8 \' E6 Z! Y: [ 总结 在使用Cube软件包例程时,最好能够对各驱动接口函数有一定认识。例如上述问题,对于例程来说,没有问题。但是转移到应用时,就需要考虑到例程中调用的判断函数是否符合应用目的了。 而对于各驱动接口函数,在函数定义处,都给出了介绍,包括各参数说明。同时,在Cube软件包的Drivers目录下,提供了对驱动接口函数介绍的文档。 $ K5 q( _ d8 w$ T% M ![]() |
哦 不错 见识了 |
哦 原来如此 |
哦 原来如此. |
谢谢分享 |
感谢分享 |
MCSDK FOC应用详解
STM32F10xxx 正交编码器接口应用笔记 及源代码
基于STM32定时器ETR信号的应用示例
STM32 生态系统|基于STM32WB的低功耗蓝牙应用(一)
《无刷直流电机控制应用 基于STM8S系列单片机》
STM32定时器触发SPI逐字收发之应用示例
【银杏科技ARM+FPGA双核心应用】STM32H7系列10——ADC
【银杏科技ARM+FPGA双核心应用】STM32H7系列57——MDK_FLM
【STM32图书分享之九】—《STM32F 32位ARM微控制器应用设计与实践》
无刷直流电机控制应用+基于STM8S系列单片机---电子书