STM32 串口中的硬件BUG,注意!
微控制器参考手册(2009年12月第10版)P541发现如下说明:
也就是说只要接收中断打开,即RXNEIE设置为1,那么ORE中断也自动打开了。
可是USART_GetITStatus(USART1,USART_IT_ORE )== RESET!!!!
找到USART_GetITStatus(USART1,USART_IT_RXNE)函数,发现只有当USART_IT_ERR中断使能时,才能读到ORE中断。
在这里要指出这个BUG:产生ORE中断了,但使用USART_GetITStatus()函数却无法读到这个中断被SET起来!
5.把ORE中断标志位清除
既然找到了是什么中断,那么把相应的中断标志位清除,就应该可以了吧?
USART_ClearITPendingBit(USART1,USART_IT_ORE);
但是,结果是没有任何效果!清除之后,马上读ORE中断状态,USART_GetITStatus(USART1,USART_IT_ORE)==RESET.程序仍然跑死在接收中断。再使用另一个函数USART_GetFlagStatus(USART1,USART_FLAG_ORE) = SET,原来ORE标志位还没有清除。
6.问题解决
为什么清除不掉?头疼了,再找找资料,有发现,在P523页如下图:
接收中断程序改为:
void UART_Receive(void)
{
if (USART_GetFlagStatus(USART1,USART_FLAG_ORE) != RESET)//注意!不能使用if(USART_GetITStatus(USART1,USART_IT_RXNE) != RESET)来判断
{
USART_ReceiveData(USART1);
}
//正在处理上一条通讯,接收到数据不处理
if(bRecieveOK)
{
if(USART_GetITStatus(USART1,USART_IT_RXNE) != RESET)
USART_ClearITPendingBit(USART1,USART_IT_RXNE);
return;//processing receive data,dont receive again
}
if(USART_GetITStatus(USART1,USART_IT_RXNE) != RESET)
{
if(MoudBusExpir == 0)
{
ucRcePtr = 0;
MoudBusExpir = 20;//50ms
}
else
MoudBusExpir = 20;
/* Read one byte from the receive data register */
ucRS485Buff[ucRcePtr++] =USART_ReceiveData(USART1);
/* Clear theUSART1 Receive interrupt */
USART_ClearITPendingBit(USART1,USART_IT_RXNE);
}
}
总结:
注意问题:1.USART_ITConfig(USART1,USART_IT_RXNE, ENABLE);使能了接收中断,那么ORE中断也同时被开启了。
2.ORE中断只能使用USART_GetFlagStatus(USART1,USART_FLAG_ORE) 读到(没有使能USART_IT_ERR中断时)
BUG建议:1.在STM32库中,能不能修改USART_GetITStatus()函数对USART_IT_ORE中断的处理?也就是我只要打开了接收中断,那么有ORE中断时,我也能使用USART_GetITStatus(USART1,USART_IT_ORE)读到.
STM32串口硬件BU 相关文章:
- Windows CE 进程、线程和内存管理(11-09)
- RedHatLinux新手入门教程(5)(11-12)
- uClinux介绍(11-09)
- openwebmailV1.60安装教学(11-12)
- Linux嵌入式系统开发平台选型探讨(11-09)
- Windows CE 进程、线程和内存管理(二)(11-09)