关于STM32程序仿真时卡死在default_handler的解决方法

问题描述:在debugger模式下,运行后,串口通信正常,过一会串口通信异常,暂停仿真发现程序死在default_Handler

原因:没有中断入口函数,当然了,有些人可能会这么写

void USART1_IRQHandler(void)
{

}

以为这样就算是加了中断入口函数了,开启串口中断接收 USART_ITConfig(USART2, USART_IT_RXNE, ENABLE)  时,同时也打开了串口ORE中断。所以,中断入口函数应该这么写

void USART1_IRQHandler(void)
{
   uint8_t value;
   if(USART_GetFlagStatus(USART1,USART_IT_RXNE) == SET) 
    {   
        value = USART_ReceiveData(USART1);
    }
    if(USART_GetITStatus(USART1, USART_IT_RXNE) == SET) 
    { 
        /* Clear the USART1 Receive interrupt */ 
        USART_ClearITPendingBit(USART1, USART_IT_RXNE);
    }
   if(USART_GetFlagStatus(USART1,USART_FLAG_ORE) == SET)   
   {               
       USART_ReceiveData(USART1); 
       USART_ClearFlag(USART1,USART_FLAG_ORE);               
   }
}


个人小结:在调试个人STM32程序过程时,程序卡死在default_Handler。查找原因是因为漏掉了中断处理函数。


问题描述:在debugger模式下,运行后,串口通信正常,过一会串口通信异常,暂停仿真发现程序死在default_Handler

原因:没有中断入口函数,当然了,有些人可能会这么写

void USART1_IRQHandler(void)
{

}

以为这样就算是加了中断入口函数了,开启串口中断接收 USART_ITConfig(USART2, USART_IT_RXNE, ENABLE)  时,同时也打开了串口ORE中断。所以,中断入口函数应该这么写

void USART1_IRQHandler(void)
{
   uint8_t value;
   if(USART_GetFlagStatus(USART1,USART_IT_RXNE) == SET) 
    {   
        value = USART_ReceiveData(USART1);
    }
    if(USART_GetITStatus(USART1, USART_IT_RXNE) == SET) 
    { 
        /* Clear the USART1 Receive interrupt */ 
        USART_ClearITPendingBit(USART1, USART_IT_RXNE);
    }
   if(USART_GetFlagStatus(USART1,USART_FLAG_ORE) == SET)   
   {               
       USART_ReceiveData(USART1); 
       USART_ClearFlag(USART1,USART_FLAG_ORE);               
   }
}


个人小结:在调试个人STM32程序过程时,程序卡死在default_Handler。查找原因是因为漏掉了中断处理函数。

猜你喜欢

转载自blog.csdn.net/yd4330152763132/article/details/78267454