本文以華大MCU HC32F003為例說明相應的操作。
HC32F003一共有7個復位信號來源,每個復位信號都可以讓CPU重新運行,絕大多數寄存器會被復位到復位值,程序計數器 PC 會被復位指向 00000000。
復位時復位標識寄存器(Reset_flag )的復位值為 00000000_00000000_00000000_xxxxxx11b。
Ÿ POR/BOR 復位(VCC 域及 Vcore 域)
Ÿ 外部 Reset PAD 復位Ÿ WDT 復位
Ÿ PCA 復位Ÿ LVD 復位
Ÿ Cortex-M0+ SYSRESETREQ 軟件復位
Ÿ Cortex-M0+ LOCKUP 硬件復位
每個復位源由相應的復位標志進行指示。復位標志均由硬件置位,需要用戶軟件清零。
芯片復位時,如果查詢到 Reset_flag. POR15V 或 Reset_flag. POR5V 為 1 則為 上電復位。
由于仿真器的局限性,芯片復位的時候不建議用仿真器來讀Reset_flag的值。建議使用UART將Reset_flag的值輸出。
下面以一段WDT復位的程序顯示一下,相關代碼如下:
#define DEBUG #include "gpio.h"
int main(){ int8_t RstData = 0; if ( M0P_RESET->RESET_FLAG_f.POR15 || M0P_RESET->RESET_FLAG_f.POR5V ) //上電復位,清Reset_flag { M0P_RESET->RESET_FLAG = 0X00; } Clk_SetPeripheralGate(ClkPeripheralUart0, TRUE); //開UART0外設時鐘 Clk_SetPeripheralGate(ClkPeripheralBt, TRUE); //開定時器外設時鐘 Clk_SetPeripheralGate(ClkPeripheralGpio, TRUE); //開GPIO外設時鐘 RstData = (int8_t)M0P_RESET->RESET_FLAG ; #ifdef DEBUG Debug_UartInit(); //調試串口初始化#endif #ifdef DEBUG printf("The RESET_FLAG is %x \n",RstData); //輸出調試內容#endif M0P_RESET->RESET_FLAG = 0X00; //清Reset_flag M0P_CLOCK->PERI_CLKEN_f.WDT = 0X01; //打開WDT時鐘 M0P_WDT->CON_f.WOV = 0X0A; //定時1.64s M0P_WDT->CON_f.WINT_EN = 0X00; //WDT溢出復位 M0P_WDT->RST = 0x1E; //啟動WDT M0P_WDT->RST = 0xE1; while(1) { __enable_irq(); ; }}
|