串口3接收中断数据丢失求助

2019-10-15 06:40发布

使用原子哥的代码对串口3发送数据,有时候会丢失后面几个字节,请大神帮忙,是有时候,不是一直都是。很简单的代码,按道理讲应该没问题。见初始化代码:
void usart3_init(u32 bound)
{  

        NVIC_InitTypeDef NVIC_InitStructure;
        GPIO_InitTypeDef GPIO_InitStructure;
        USART_InitTypeDef USART_InitStructure;

        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);        // GPIOB时钟
        RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3,ENABLE); //串口3时钟使能

        USART_DeInit(USART3);  //复位串口3
                 //USART3_TX   PB10
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; //PB10
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;        //复用推挽输出
  GPIO_Init(GPIOB, &GPIO_InitStructure); //初始化PB10

    //USART3_RX          PB11
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;//浮空输入
  GPIO_Init(GPIOB, &GPIO_InitStructure);  //初始化PB11
       
        USART_InitStructure.USART_BaudRate = bound;//波特率一般设置为9600;
        USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字长为8位数据格式
        USART_InitStructure.USART_StopBits = USART_StopBits_1;//一个停止位
        USART_InitStructure.USART_Parity = USART_Parity_No;//无奇偶校验位
        USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//无硬件数据流控制
        USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;        //收发模式

        USART_Init(USART3, &USART_InitStructure); //初始化串口        3


        USART_Cmd(USART3, ENABLE);                    //使能串口
       
        //使能接收中断
  USART_ITConfig(USART3, USART_IT_RXNE, ENABLE);//开启中断   
       
        //设置中断优先级
        NVIC_InitStructure.NVIC_IRQChannel = USART3_IRQn;
        NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=2;//抢占优先级2
        NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;                //子优先级0
        NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                        //IRQ通道使能
        NVIC_Init(&NVIC_InitStructure);        //根据指定的参数初始化VIC寄存器
       
       
//        TIM7_Int_Init(99,7199);                //10ms中断
        USART3_RX_STA=0;                //清零
//        TIM_Cmd(TIM7,DISABLE);                        //关闭定时器7

}


下面是串口3中断服务:
void USART3_IRQHandler(void)
{
        u8 res;
        if(USART_GetITStatus(USART3, USART_IT_RXNE) != RESET)//接收到数据
        {
                res =USART_ReceiveData(USART3);
                USART3_RX_BUF[USART3_RX_STA]=res;
                if(USART3_RX_BUF[0]==0x65)
                {
                        if(USART3_RX_STA==10)
                        {
                                BBFLAG=1;//接收完成
                                USART3_RX_STA=0;
                                USART3_RX_BUF[0]=0x00;
                        }
                        else
                        USART3_RX_STA++;
                        }
        }
}

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
9条回答
落因飞虹
1楼-- · 2019-10-16 07:07
本帖最后由 落因飞虹 于 2017-1-18 10:20 编辑
lvkanger 发表于 2017-1-18 08:58
有没有可能是你通过串口调试助手发送的问题呢?你用串口调试助手等间隔时间发数据试试看


采用你的方法,我用等间隔时间发数据,1秒钟1组11个字节没问题,试了1000组无一丢失,但是我用手工点,时间间隔绝对超过1秒钟,10组里必有一组丢失,之前我用AVR单片机从未出现过类似情况,可否详细解释下。如果等间隔时间发送速度一快也不行,这个可以解释,我接收到数据后会有大量的代码,包括串口4的发送等等,但是我手工点时间间隔超过1s就说不通了。
lvkanger
2楼-- · 2019-10-16 08:29
落因飞虹 发表于 2017-1-18 10:14
采用你的方法,我用等间隔时间发数据,1秒钟1组11个字节没问题,试了1000组无一丢失,但是我用手工点, ...

这种情况串口3的接收应该是没问题的,问题可能出在你的串口4的打印上。
落因飞虹
3楼-- · 2019-10-16 13:22
lvkanger 发表于 2017-1-18 10:51
这种情况串口3的接收应该是没问题的,问题可能出在你的串口4的打印上。

但是我在线调试看了,串口3的接收数组,就是65 65。。。这种啊

一周热门 更多>