49 lines
1.2 KiB
C
49 lines
1.2 KiB
C
/* esp/wdt_regs.h
|
|
*
|
|
* ESP8266 Watchdog Timer register definitions
|
|
*
|
|
* Not compatible with ESP SDK register access code.
|
|
*/
|
|
|
|
#ifndef _ESP_WDT_REGS_H
|
|
#define _ESP_WDT_REGS_H
|
|
|
|
#include "esp/types.h"
|
|
#include "common_macros.h"
|
|
|
|
#define WDT_BASE 0x60000900
|
|
#define WDT (*(struct WDT_REGS *)(WDT_BASE))
|
|
|
|
/* WDT register(s)
|
|
|
|
Not fully understood yet. Writing 0 to CTRL disables WDT.
|
|
|
|
See ROM functions esp_wdt_xxx
|
|
*/
|
|
|
|
struct WDT_REGS {
|
|
uint32_t volatile CTRL; // 0x00
|
|
uint32_t volatile REG1; // 0x04
|
|
uint32_t volatile REG2; // 0x08
|
|
uint32_t volatile _unused[2]; // 0x0c - 0x10
|
|
uint32_t volatile FEED; // 0x14
|
|
};
|
|
|
|
_Static_assert(sizeof(struct WDT_REGS) == 0x18, "WDT_REGS is the wrong size");
|
|
|
|
/* Details for CTRL register */
|
|
|
|
/* Note: these are currently just guesses based on interpretation of the startup code */
|
|
|
|
#define WDT_CTRL_ENABLE BIT(0)
|
|
#define WDT_CTRL_FIELD0_M 0x00000003
|
|
#define WDT_CTRL_FIELD0_S 1
|
|
#define WDT_CTRL_FLAG3 BIT(3)
|
|
#define WDT_CTRL_FLAG4 BIT(4)
|
|
#define WDT_CTRL_FLAG5 BIT(5)
|
|
|
|
/* Writing WDT_FEED_MAGIC to WDT.FEED register "feeds the dog" and holds off
|
|
* triggering for another cycle (unconfirmed) */
|
|
#define WDT_FEED_MAGIC 0x73
|
|
|
|
#endif /* _ESP_WDT_REGS_H */
|