你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

STM32F429串口接收莫名其妙的过载问题

[复制链接]
aqua-375372 提问时间:2017-1-9 14:10 /
今天发现我的程序老是因为数据过载导致接收的数据不完整,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("\r\nerror:guozai 1!\r\n");
  }
  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\r\n",t);
}

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


@ST的FAE


收藏 1 评论8 发布时间:2017-1-9 14:10

举报

8个回答
aqua-375372 回答时间:2017-1-10 09:50:17
问题找到了是原子的例程里面SD卡的读写操作时关闭了中断导致的, 我尝试屏蔽这段代码运行也正常,看来读SD卡并不需要关闭中断

评分

参与人数 1ST金币 +2 收起 理由
zero99 + 2 结贴奖励

查看全部评分

wenyangzeng 回答时间:2017-1-9 14:51:58
你这个“UART1_Handler.Init.StopBits=UART_STOPBITS_2;  ”
是一个停止位还是2个停止位?

评分

参与人数 1ST金币 +2 收起 理由
zero99 + 2

查看全部评分

aqua-375372 回答时间:2017-1-9 15:03:39
wenyangzeng 发表于 2017-1-9 14:51
你这个“UART1_Handler.Init.StopBits=UART_STOPBITS_2;  ”
是一个停止位还是2个停止位? ...

两个停止位,而且停止位只影响发送,一般不会影响接收
wenyangzeng 回答时间:2017-1-9 17:49:02
aqua-375372 发表于 2017-1-9 15:03
两个停止位,而且停止位只影响发送,一般不会影响接收

这个停止位是USART通讯协议参数之一,关系发送和接收的数据位。应该是关系重大吧?
suoma 回答时间:2017-1-9 23:28:10
过载?还是超时?
海迹天涯 回答时间:2017-1-10 08:45:07
过载的时候读2个寄存器这个位就会自动清除了

点评

问题是数据已经丢了...  发表于 2017-1-10 09:51

评分

参与人数 1ST金币 +2 收起 理由
zero99 + 2

查看全部评分

aqua-375372 回答时间:2017-1-10 09:48:43
wenyangzeng 发表于 2017-1-9 17:49
这个停止位是USART通讯协议参数之一,关系发送和接收的数据位。应该是关系重大吧? ...

停止位说白了就是一字节数据发送完毕后再等待一段时间才进行下一字节的发送, 这是不影响接收的,因为接收完一字节数据后它要检测到下一个起始位才开始下一字节的接收,所有停止位多少跟它没关系
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版