CH582,CH592,CH57x芯片死机通过看门狗中断打印PC指针使用示例

#include "CH58x_common.h"

/*********************************************************************
 * @fn      DebugInit
 *
 * @brief   调试初始化
 *
 * @return  none
 */
void DebugInit(void)
{
    GPIOA_SetBits(GPIO_Pin_9);
    GPIOA_ModeCfg(GPIO_Pin_8, GPIO_ModeIN_PU);
    GPIOA_ModeCfg(GPIO_Pin_9, GPIO_ModeOut_PP_5mA);
    UART1_DefInit();
}

void WWDG_Config(void)
{
    WWDG_SetCounter(0);//喂狗处理
    WWDG_ITCfg(ENABLE);//配置看门狗中断
    WWDG_ResetCfg(DISABLE);//看门狗中断生效后不复位,如果需要产生看门狗中断后立即复位,则参数填写ENABLE
    PFIC_EnableIRQ(WDOG_BAT_IRQn);//使能看门狗中断生效
}

void TEST_Code(void)
{
    WWDG_SetCounter(0);//喂狗处理
    static uint32_t count=0;
    count++;
    while(count>32000);//写一个死循环,产生现象后读取PC指针,去.lst文件中查看跑死在哪个地方
}

/*********************************************************************
 * @fn      main
 *
 * @brief   主函数
 *
 * @return  none
 */
int main()
{
    SetSysClock(CLK_SOURCE_PLL_60MHz);
    /* 配置串口调试 */
    DebugInit();
    PRINT("Start @ChipID=%02X\n", R8_CHIP_ID);
    WWDG_Config();

    while(1)
    {
        TEST_Code();
    }
}

uint32_t __get_MEPC(void);
uint32_t __get_MTVAL(void);
uint32_t __get_MCAUSE(void);
__attribute__((interrupt("WCH-Interrupt-fast")))
__attribute__((section(".highcode")))
void WDOG_BAT_IRQHandler(void)
{
  GPIOA_ModeCfg(1<<9, GPIO_ModeOut_PP_5mA);//串口IO引脚配置
  UART1_DefInit();
  UART1_BaudRateCfg(115200); //串口初始化,波特率配置

  uint32_t mepc = __get_MEPC();
  uint32_t mtval = __get_MTVAL();
  uint32_t mcause = __get_MCAUSE();
  printf("mepc = %08x\nmtval = %08x\nmcause = %08x\n",mepc,mtval,mcause); //异常后,如果没有喂狗,看门狗中断后,打印pc指针
  while(1);
}

 跑死后查看PC指针停在了0x00000bbe,前去.lst文件中查找对应函数

 

posted on 2024-06-07 15:48  ZDeST  阅读(29)  评论(4编辑  收藏  举报