HAL_ChibiOS: record reason for reset

allows us to tell if reset was due to watchdog
This commit is contained in:
Andrew Tridgell 2019-04-11 19:50:46 +10:00
parent 5823a6b963
commit ac5294c974
3 changed files with 61 additions and 2 deletions

View File

@ -18,6 +18,7 @@
#include "hal.h" #include "hal.h"
#include "usbcfg.h" #include "usbcfg.h"
#include "stm32_util.h" #include "stm32_util.h"
#include "watchdog.h"
#if HAL_USE_PAL || defined(__DOXYGEN__) #if HAL_USE_PAL || defined(__DOXYGEN__)
/** /**
@ -65,6 +66,7 @@ void __early_init(void) {
void __late_init(void) { void __late_init(void) {
halInit(); halInit();
chSysInit(); chSysInit();
stm32_watchdog_save_reason();
#if CH_CFG_USE_HEAP == TRUE #if CH_CFG_USE_HEAP == TRUE
malloc_init(); malloc_init();
#endif #endif

View File

@ -8,13 +8,38 @@
#ifndef IWDG_BASE #ifndef IWDG_BASE
#if defined(STM32H7) #if defined(STM32H7)
#define IWDG_BASE 0x58004800 #define IWDG_BASE 0x58004800
#elif defined(STM32F7) || defined(STM32F4) || defined(STM32F1) #elif defined(STM32F7) || defined(STM32F4)
#define IWDG_BASE 0x40003000
#elif defined(STM32F1)
#define IWDG_BASE 0x40003000 #define IWDG_BASE 0x40003000
#else #else
#error "Unknown IWDG_BASE" #error "Unsupported IWDG MCU config"
#endif #endif
#endif #endif
#ifndef RCC_BASE
#error "Unsupported IWDG RCC MCU config"
#endif
/*
defines for working out if the reset was from the watchdog
*/
#if defined(STM32H7)
#define WDG_RESET_STATUS (*(__IO uint32_t *)(RCC_BASE + ))
#define WDG_RESET_CLEAR (1U<<16)
#define WDG_RESET_IS_IWDG (1U<<26)
#elif defined(STM32F7) || defined(STM32F4)
#define WDG_RESET_STATUS (*(__IO uint32_t *)(RCC_BASE + 0x74))
#define WDG_RESET_CLEAR (1U<<24)
#define WDG_RESET_IS_IWDG (1U<<29)
#elif defined(STM32F1)
#define WDG_RESET_STATUS (*(__IO uint32_t *)(RCC_BASE + 0x24))
#define WDG_RESET_CLEAR (1U<<24)
#define WDG_RESET_IS_IWDG (1U<<29)
#else
#error "Unsupported IWDG MCU config"
#endif
typedef struct typedef struct
{ {
__IO uint32_t KR; /*!< IWDG Key register, Address offset: 0x00 */ __IO uint32_t KR; /*!< IWDG Key register, Address offset: 0x00 */
@ -46,3 +71,25 @@ void stm32_watchdog_pat(void)
{ {
IWDGD.KR = 0xAAAA; IWDGD.KR = 0xAAAA;
} }
static bool was_watchdog_reset;
/*
save reason code for reset
*/
void stm32_watchdog_save_reason(void)
{
if (WDG_RESET_STATUS & WDG_RESET_IS_IWDG) {
was_watchdog_reset = true;
}
WDG_RESET_STATUS = WDG_RESET_CLEAR;
}
/*
return true if reboot was from a watchdog reset
*/
bool stm32_was_watchdog_reset(void)
{
return was_watchdog_reset;
}

View File

@ -14,6 +14,16 @@ void stm32_watchdog_init(void);
*/ */
void stm32_watchdog_pat(void); void stm32_watchdog_pat(void);
/*
return true if reboot was from a watchdog reset
*/
bool stm32_was_watchdog_reset(void);
/*
save the reset reason code
*/
void stm32_watchdog_save_reason(void);
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif