STM32F429串口接收出现过载错误

2019-07-14 15:53发布

今天发现我的程序老是因为数据过载导致接收的数据不完整,ORE置位了.然而理论上不应该发生这个错误,绝对不应该的!!!
1.这是我的串口初始化代码(初始化利用了HAL库,然而接收没有使用库函数)
//初始化IO 串口1
//bound:波特率
void uart_init(u32 bound)//bound设置为9600的,并不高
{        
        //UART 初始化设置
        UART1_Handler.Instance=USART1;                                            //USART1
        UART1_Handler.Init.BaudRate=bound;                                    //波特率
        UART1_Handler.Init.WordLength=UART_WORDLENGTH_8B;   //字长为8位数据格式
        UART1_Handler.Init.StopBits=UART_STOPBITS_2;            //一个停止位
        UART1_Handler.Init.Parity=UART_PARITY_NONE;                    //无奇偶校验位
        UART1_Handler.Init.HwFlowCtl=UART_HWCONTROL_NONE;   //无硬件流控
        UART1_Handler.Init.Mode=UART_MODE_TX_RX;                    //收发模式
        HAL_UART_Init(&UART1_Handler);                                            //HAL_UART_Init()会使能UART1
        
        HAL_UART_Receive_IT(&UART1_Handler, UART1RxBuffer, RXBUFFERSIZE);//该函数会开启接收中断:标志位UART_IT_RXNE,并且设置接收缓冲以及接收缓冲接收最大数据量  
}

void HAL_UART_MspInit(UART_HandleTypeDef *huart)
{
  //GPIO端口设置
        GPIO_InitTypeDef GPIO_Initure;
        
        if(huart->Instance==USART1)//如果是串口1,进行串口1 MSP初始化
        {
                __HAL_RCC_GPIOA_CLK_ENABLE();                        //使能GPIOA时钟
                __HAL_RCC_USART1_CLK_ENABLE();                        //使能USART1时钟
        
                GPIO_Initure.Pin=GPIO_PIN_9;                        //PA9
                GPIO_Initure.Mode=GPIO_MODE_AF_PP;                //复用推挽输出
                GPIO_Initure.Pull=GPIO_PULLUP;                        //上拉
                GPIO_Initure.Speed=GPIO_SPEED_FAST;                //高速
                GPIO_Initure.Alternate=GPIO_AF7_USART1;        //复用为USART1
                HAL_GPIO_Init(GPIOA,&GPIO_Initure);                   //初始化PA9

                GPIO_Initure.Pin=GPIO_PIN_10;                        //PA10
                HAL_GPIO_Init(GPIOA,&GPIO_Initure);                   //初始化PA10
               
                HAL_NVIC_EnableIRQ(USART1_IRQn);                                //使能USART1中断通道
                HAL_NVIC_SetPriority(USART1_IRQn,0,1);                        //抢占优先级0,子优先级1
        }

}
上面的代码是串口的初始化代码, 波特率9600,优先级0,响应优先级1,优先级分组为抢占2位,响应2位, 已经将其它所有的中断优先级都设为比它低了
2.这是串口接收中断
//串口1中断服务程序
void USART1_IRQHandler(void)                        
{
  u8 ch,*p;
  u32 t=tiM5->CNT;  
  LED1flash=1;  
  if(USART1->SR&(1<<3))
  {
    u32 t=USART1->SR;
    t=USART1->DR;
    printf(" error:guozai 1! ");
  }
  if(USART1->SR&(1<<5))
  {
    ch=USART1->DR;
    USART1->SR&=~(1<<5);
    p=WriteDATA(&uart2buff);
    if(p)
    {
      *p=ch;
      incDATA(&uart2buff);
    }
  }
  t=TIM5->CNT-t;
  printf("t=%u ",t);
}

经过测试每次处理时间在1us左右,TIM5的时钟1MHZ,然而偶尔会出现过载错误,并且丢失一个数据, 主频192M, 按道理这是不可能的,每次中断处理时间只是短短的几个微秒.怎么可能发生过载????


@ST的FAE

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
6条回答
ctwewer
1楼-- · 2019-07-14 21:27
你这个“UART1_Handler.Init.StopBits=UART_STOPBITS_2;  ”
是一个停止位还是2个停止位?
tan8561
2楼-- · 2019-07-14 22:18
ctwewer 发表于 2018-11-20 09:58
你这个“UART1_Handler.Init.StopBits=UART_STOPBITS_2;  ”
是一个停止位还是2个停止位?

两个停止位,而且停止位只影响发送,一般不会影响接收
ctwewer
3楼-- · 2019-07-15 02:08
 精彩回答 2  元偷偷看……
DAA000
4楼-- · 2019-07-15 07:31
过载?还是超时?
5616asaqwq
5楼-- · 2019-07-15 12:03
过载的时候读2个寄存器这个位就会自动清除了
tan8561
6楼-- · 2019-07-15 15:17
ctwewer 发表于 2018-11-20 10:23
这个停止位是USART通讯协议参数之一,关系发送和接收的数据位。应该是关系重大吧?

停止位说白了就是一字节数据发送完毕后再等待一段时间才进行下一字节的发送, 这是不影响接收的,因为接收完一字节数据后它要检测到下一个起始位才开始下一字节的接收,所有停止位多少跟它没关系

一周热门 更多>