我用STM8的串口中断接收GSM模块的数据,波特率是38400,串口接收到的字符串有时候是对的,有时候会少一个字符。我发现是串口溢出错误引起的,如果不清除溢出标志,就会在串口中断里跳不出来了。
问题是,为啥我的程序老是溢出错误呢? 有的人说是串口的FIFO不够,所以溢出,有的人说是中断优先级不够高,是这样么?我这里也就一个串口中断,一个定时器中断。希望高手指教,非常感谢!!
int main( void )
{
u8 *pr,i;
u8 loc_temp[20];
GPIO_Init(GPIOC, GPIO_Pin_3, GPIO_Mode_Out_PP_High_Fast); //TXD //txd初始化为高电平互补推挽输出模式
GPIO_Init(GPIOC, GPIO_Pin_2, GPIO_Mode_In_PU_No_IT); //RXD //rxd初始化为不带中断上拉输入模式
CLK_PeripheralClockConfig (CLK_Peripheral_USART1,ENABLE);//开启USART时钟
USART_Init(USART1,38400,USART_WordLength_8b,USART_StopBits_1,USART_Parity_No,USART_Mode_Tx|USART_Mode_Rx);//设置USART参数9600,8N1,接收/发送
USART_ITConfig (USART1,USART_IT_RXNE,ENABLE);//使能接收中断
USART_Cmd (USART1,ENABLE);//使能USART
CLK_PeripheralClockConfig (CLK_Peripheral_TIM4,ENABLE); //使能外设时钟
TIM4_TimeBaseInit(TIM4_Prescaler_128, 0xff);
TIM4_ClearFlag(TIM4_FLAG_Update);
TIM4_ITConfig(TIM4_IT_Update, ENABLE);
TIM4_Cmd(ENABLE);
enableInterrupts();
Delay(60000);
GSM_Start_Config();
while(1)
{
}
}
//===============================================================
INTERRUPT_HANDLER(USART1_RX_TIM5_CC_IRQHandler,28) //串口中断处理程序
{
/* In order to detect unexpected events during development,
it is recommended to set a breakpoint on the following instruction.
*/
u8 cc;
if( USART_GetITStatus(USART1,USART_IT_RXNE)!=RESET)//接收中断处理
{
USART_ClearITPendingBit (USART1,USART_IT_RXNE);//清中断标志
cc=USART_ReceiveData8 (USART1);
if(USART_RX_STA<200)
{
receive_count=0;
if(USART_RX_STA==0)
{
count_start_flag =1;//计数器开始计数
}
USART_RX_BUF[USART_RX_STA++]=cc;
}
else
{
USART_RX_STA|=1<<14;
count_start_flag =0;
}
}
if(USART_GetFlagStatus(USART1,USART_FLAG_OR)==SET)//溢出中断处理
{
USART_ClearFlag(USART1,USART_FLAG_OR);
USART_ReceiveData8 (USART1);
}
}
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
改为
USART_ITConfig (USART1,USART_IT_RXNE_OR,ENABLE);//使能接收中断 USART_IT_RXNE_OR 试试
//USART_ClearITPendingBit (USART1,USART_IT_RXNE);//清中断标志
主要是中断处理程序没弄好,你可以把中断处理程序发出来我看下 没有清响应的标志位
你这种情况一般都是由于某些原因产生了溢出中断。但是你的中断处理程序没有写好,你可以看下官方的手册,如果产生错误标准位后,必须要先读状态位,再读数据位,再清除状态位。这样就不会溢出了
一周热门 更多>