关于HAL库,在stm32f4上串口溢出问题。

2019-07-20 06:10发布

今天移植了原子的  ALIENTEK 阿波罗STM32F429开发板 的HAL库版串口程序,发现如果发送数量大于接收缓存就会造成串口溢出,表现为,之后PC端能正常接收到开发板发过来的信息,但是PC端发送给开发板信息无反应。各位有遇到过得嘛

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
6条回答
linxiaoming
2019-07-21 01:53
本帖最后由 linxiaoming 于 2018-9-11 17:20 编辑

可以做一个双缓冲,用于 接收中断中存放接收字节的数组 rx_fifo可以设置为1。然后自己再根据实际需求,定义一个缓冲数组 fifo[];实测用PC发送一组数据到单片机,发送完成后触发超时,标志位F_timeout=1, 然后单片机再发给PC数据。

代码如下


#include "app.h"

/*============================================================================================
*                系统定时器中断
*============================================================================================*/
static uint16 count1 = 0;
static uint16 count2 = 0;
void HAL_SYSTICK_Callback(void)
{
        sys.F_1ms = 1;
        count1++;
        if(count1>=10)
        {
                count1 = 0;
                sys.F_10ms = 1;
        }
        count2++;
        if(count2>=100)
        {
                count2 = 0;
                sys.F_100ms = 1;
        }
}


/*============================================================================================
*                串口接收中断
*============================================================================================*/

uint8 fifo[5000];                        //二层接收缓冲
uint16 p1=0;                                //接收数量
uint8 rx_fifo[1];                        //一层接收缓冲,用于官方库函数
extern UART_HandleTypeDef huart1;


/*============================================================================================
*                超时检测
*============================================================================================*/
uint8 E_timeout=0;
uint8 F_timeout=0;
uint8 C_timeout=0;
void func_timeout()
{
        if(E_timeout)
        {
                C_timeout++;
                if(C_timeout>=100)
                {
                        C_timeout = 0;
                        F_timeout = 1;
                }
        }
        else
        {
                C_timeout = 0;
                F_timeout = 0;
        }
}


void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
{
        uint8 i=0;
        UNUSED(huart1);
        HAL_UART_Receive_IT(&huart1,rx_fifo,sizeof(rx_fifo));        //接收函数
        fifo[p1] = rx_fifo[0];
        p1++;
        if(p1>=5000)
        {
                p1 = 0;       
        }
        /*接收超时检测:接收到数据-->开启超时检测并reset计数值*/
        E_timeout = 1;
        C_timeout = 0;
}



然后主程序中
                if(sys.F_1ms)
                {
                        sys.F_1ms = 0;
                        func_timeout();
                        if(F_timeout)
                        {
                                F_timeout = 0;
                                E_timeout = 0;
                                HAL_UART_Transmit_IT(&huart1,fifo,p1);
                                p1 = 0;
                        }
                }




实测截图:同一段文字复制了很多次,一次发送总计4000多byte
file:///D:/%E5%B8%B8%E7%94%A8%E8%BD%AF%E4%BB%B6/YoudaoNote/%E7%AC%94%E8%AE%B0/qq127390A56C09F11E62A2848E550B9AE2/937870868bab47bf83f8b02436721836/%7Eqhb_d2d_gfa.png


一周热门 更多>