OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 2437|回复: 10

串口3接收中断错误

[复制链接]

10

主题

41

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
207
金钱
207
注册时间
2018-2-27
在线时间
43 小时
发表于 2018-7-14 14:04:10 | 显示全部楼层 |阅读模式
M3的串口3:硬件仿真,在初始化执行到USART_Cmd(USART3, ENABLE);//启动串口,这一句之后,也就是初始化函数刚刚完成,就如图。查手册看到是溢出错误和桢错误,但是我此时没有发任何东西给M3(之前有发,然后把线拔了),然后试着清除错误标志位,把中断函数改成:如图……没有作用…束手无策,求大神搭救!!!

[mw_shl_code=c,true]int main(void)
{
       
        NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//设置中断优先级分组为组2:2位抢占优先级,2位响应优先级
        USART3_Init(115200);
        while(1);
}[/mw_shl_code]

[mw_shl_code=applescript,true]void USART3_Init(u32 bound)                                        //串口3配置
{
    //结构体声明
        GPIO_InitTypeDef  GPIO_InitStructure;              
        NVIC_InitTypeDef NVIC_InitStructure;
  USART_InitTypeDef      USART_InitStructure;            
       
//        RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);          //重映射时钟
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);          //GPIOC 时钟
  RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3 , ENABLE); //USART3时钟

  /*USART3管脚设置*/
//  GPIO_PinRemapConfig(GPIO_PartialRemap_USART3, ENABLE); //将USART3局部重映射到PC10,PC11

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;             //管脚10
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;       //复用推挽输出
  GPIO_Init(GPIOB, &GPIO_InitStructure);                //TX初始化

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;            //管脚11
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; //浮空输入
  GPIO_Init(GPIOB, &GPIO_InitStructure);                //RX初始化
        //Usart3 NVIC 中断优先级配置
  NVIC_InitStructure.NVIC_IRQChannel = USART3_IRQn;
        NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3 ;        //        抢占优先级3
        NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;                        //        响应优先级2

        NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                        //IRQ通道使能
        NVIC_Init(&NVIC_InitStructure);        //根据NVIC_InitStruct中指定的参数初始化外设NVIC寄存器USART1
  //串口参数初始化  
  USART_InitStructure.USART_BaudRate   = bound;                  //波特率9600
  USART_InitStructure.USART_WordLength = USART_WordLength_8b;   //字长8位
  USART_InitStructure.USART_StopBits   = USART_StopBits_1;      //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;//打开Rx接收和Tx发送功能

  USART_Init(USART3, &USART_InitStructure);                      //初始化
        USART_ITConfig(USART3, USART_IT_RXNE, ENABLE);//开启接受中断
//        USART_ClearFlag(USART3, USART_FLAG_TC);                          //清零发送置位
//        USART_ITConfig(USART3,USART_IT_TC,ENABLE);           //开发送中断  
  USART_Cmd(USART3, ENABLE);                                     //启动串口
  }
//中断服务
void USART3_IRQHandler(void)
{
if(USART3->SR&(1<<5))//接收到数据
    {   
               
                USART3_RX_BUF[USART3_RX_STA++] = USART3->DR;
//        USART3_RX_BUF[USART3_RX_STA++] = USART_ReceiveData(USART3);         //读取接收到的数据   //接收数据增加1
                if(USART3_RX_STA == USART3_REC_LEN)
                {
                        USART3_RX_STA=0;
                }
}
void USART_SendArray(USART_TypeDef *USARTx,u8 *buf,u16 len)
{
        u8 t;
        USART_ClearFlag(USARTx, USART_FLAG_TC);                /*防止首字节丢失*/
          for(t=0;t<len;t++)                //循环发送数据
        {                        
               
                USART_SendData(USARTx,buf[t]);
                while(USART_GetFlagStatus(USARTx, USART_FLAG_TC) == RESET);
        }                   
}[/mw_shl_code]
微信图片_20180714135916.png
微信图片_20180714140234.png
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

10

主题

41

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
207
金钱
207
注册时间
2018-2-27
在线时间
43 小时
 楼主| 发表于 2018-7-14 14:05:48 | 显示全部楼层
自顶!!!!!!!!!!!!
回复 支持 反对

使用道具 举报

10

主题

41

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
207
金钱
207
注册时间
2018-2-27
在线时间
43 小时
 楼主| 发表于 2018-7-14 14:08:21 | 显示全部楼层
对了!在没有清除标志位之前,也就是一开始的中断函数,会一直进去(没有发东西给它)…修改之后进不去USART3_RX_STA=0;
回复 支持 反对

使用道具 举报

51

主题

2166

帖子

2

精华

论坛元老

Rank: 8Rank: 8

积分
10653
金钱
10653
注册时间
2017-4-14
在线时间
2780 小时
发表于 2018-7-14 14:11:27 | 显示全部楼层

回帖奖励 +1 金钱

616765512 发表于 2018-7-14 14:05
自顶!!!!!!!!!!!!

  加个这试试
if(USART_GetFlagStatus(USART1_DMA_InitStructure.USARTx,USART_FLAG_ORE) == SET) // 检查 ORE 标志,防止断线死机,放在接收中断清除接收标记前面
  {
      USART_ClearFlag(USART1_DMA_InitStructure.USARTx,USART_FLAG_ORE);
      USART_ReceiveData(USART1_DMA_InitStructure.USARTx);
  }
回复 支持 反对

使用道具 举报

3

主题

1155

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
7464
金钱
7464
注册时间
2015-1-15
在线时间
1368 小时
发表于 2018-7-14 14:27:02 | 显示全部楼层
也许硬件有问题
一分耕耘一分收获。
回复 支持 反对

使用道具 举报

31

主题

1955

帖子

3

精华

论坛元老

Rank: 8Rank: 8

积分
4524
金钱
4524
注册时间
2018-5-11
在线时间
947 小时
发表于 2018-7-14 14:40:02 | 显示全部楼层
没有看懂你的中断服务程序,
一大堆的
USART3->CR1;
USART3->CR2;
USART3->CR3;
既不读,也不写,什么意思?
我的开源链接 https://github.com/ShuifaHe/STM32.git  请关注,点赞支持哦。
回复 支持 反对

使用道具 举报

10

主题

41

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
207
金钱
207
注册时间
2018-2-27
在线时间
43 小时
 楼主| 发表于 2018-7-14 15:10:16 | 显示全部楼层

是硬件问题…拿去给硬件的人改了
回复 支持 反对

使用道具 举报

10

主题

41

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
207
金钱
207
注册时间
2018-2-27
在线时间
43 小时
 楼主| 发表于 2018-7-14 15:12:42 | 显示全部楼层
warship 发表于 2018-7-14 14:40
没有看懂你的中断服务程序,
一大堆的
USART3->CR1;

手册说的…要读CR,但是没有说读哪个
微信图片_20180714151151.png
回复 支持 反对

使用道具 举报

10

主题

41

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
207
金钱
207
注册时间
2018-2-27
在线时间
43 小时
 楼主| 发表于 2018-7-14 15:12:58 | 显示全部楼层
275891381 发表于 2018-7-14 14:11
加个这试试
if(USART_GetFlagStatus(USART1_DMA_InitStructure.USARTx,USART_FLAG_ORE) == SET) // 检 ...

我都没有用DMA
回复 支持 反对

使用道具 举报

35

主题

560

帖子

2

精华

资深版主

Rank: 8Rank: 8

积分
17786
金钱
17786
注册时间
2018-3-3
在线时间
523 小时
发表于 2018-7-14 15:35:56 | 显示全部楼层
。。。。
回复 支持 反对

使用道具 举报

31

主题

1955

帖子

3

精华

论坛元老

Rank: 8Rank: 8

积分
4524
金钱
4524
注册时间
2018-5-11
在线时间
947 小时
发表于 2018-7-14 17:28:58 | 显示全部楼层
616765512 发表于 2018-7-14 15:12
手册说的…要读CR,但是没有说读哪个

ORE过载错误,当RXNE仍然是’1’的时候,当前被接收在移位寄存器中的数据,需要传送至RDR寄存器时,硬件将该位置位。如果USART_CR1中的RXNEIE为’1’的话, 则产生中断。由软件序列将其清零(先读USART_SR,然后读USART_CR)。定义:0(没有过载错误),1(检测到过载错误)
这个意思应该是,先读SR的ORE,再读CR1中的RXNEIE
不过,不读到位,读整个应该也可以,但总得真的读一下吧?
设一个变量temp,  temp=USART3->SR;  temp=USART3->CR1;   
写成USART3->SR;  USART3->CR1;会不会被编译器优化掉啊?  
我的开源链接 https://github.com/ShuifaHe/STM32.git  请关注,点赞支持哦。
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-15 15:31

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表