使用stm32CubeMX自动配置的工程文件,进行串口的不定长接收(非DMA方式)

方法描述:使用stm32CubeMX自动配置的工程文件,进行串口的不定长接收(非DMA方式)。

实际问题解决尝试

1.HAL库函数只有接收定长数据HAL_UART_Receive()和HAL_UART_Receive_IT();函数声明如下:
使用stm32CubeMX自动配置的工程文件,进行串口的不定长接收(非DMA方式)_第1张图片
通过查看论坛等找到的解决方式,一种是通过HAL_UART_Receive_IT(&huart1,(uint8_t *)buffer,1);来进入串口中断回调函数HAL_UART_RxCpltCallback();函数原型如下:
使用stm32CubeMX自动配置的工程文件,进行串口的不定长接收(非DMA方式)_第2张图片
实际测试中,这种方式每次都需要去调用HAL_UART_Receive_IT函数,系统处理效率低。


2.通过审查生成的代码,如下所示:
首先是串口中断的代码,只有一条语句:
使用stm32CubeMX自动配置的工程文件,进行串口的不定长接收(非DMA方式)_第3张图片
进行go to definition,可以看到接收中断会进入UART_Receive_IT这个函数。
使用stm32CubeMX自动配置的工程文件,进行串口的不定长接收(非DMA方式)_第4张图片
继续往下级看,则可看到下图画线处所示,UART的RXNE中断使能被关闭了。
使用stm32CubeMX自动配置的工程文件,进行串口的不定长接收(非DMA方式)_第5张图片
所以,另一种解决方法是将这一句给屏蔽掉,HAL_UART_Receive_IT只需要执行一次就可以了,类似于打开RXNE中断的操作。但是,这种方法不好的地方在于,如果stm32cubeMX里重新配置并生成代码的话,这个地方的屏蔽会重新打开,也就是说每重新生成一次代码,cube工程不在用户操作区的改动都会被撤回。如果代码只是最终版本,这并无多大关系,如果后续还有其他的功能添加,则会很麻烦。


3.如果cubeMX配置的串口没有开启RXNE中断的话,那我们在初始化处添加试试:使用stm32CubeMX自动配置的工程文件,进行串口的不定长接收(非DMA方式)_第6张图片
经过测试,在经过初始化后,程序能够成功DEBUG进入串口中断函数,所以对串口中断里添加我们自己的处理函数即可,本人的处理代码是通过改编原子的串口代码而成,当然你也可以添加自己的处理算法,根据实际问题而定。这种方式即使重新生成工程,所做的处理也不会更改。
以下是本人实际测试代码:
使用stm32CubeMX自动配置的工程文件,进行串口的不定长接收(非DMA方式)_第7张图片
通过KEIL的DEBUG测试,通过此方法处理的程序,在运行到HAL_UART_IRQHandler函数中时,由于串口ORE位会置位为1,
errorflags = (isrflags & (uint32_t)(USART_SR_PE | USART_SR_FE | USART_SR_ORE | USART_SR_NE));相应的不能够为RESET,则UART_Receive_IT函数并未能够进入,所以__HAL_UART_DISABLE_IT(huart, UART_IT_RXNE);这句也就不能够被执行到。
下图为实际测试效果图:
使用stm32CubeMX自动配置的工程文件,进行串口的不定长接收(非DMA方式)_第8张图片
图中时间并不是正确时间,且由图可看出即使间隔10ms发一次数据,串口端都能够对数据进行准确接收方便程序处理。

你可能感兴趣的:(stm32)