3.28.4 Dual Watchdog Timer (DWDT)

The Dual Watchdog Timer (DWDT) is used to prevent system lock-up if the software becomes trapped in a deadlock. It features two 12-bit down counters that allow two watchdog periods of up to 16 seconds (Monitoring Domain Slow Clock (MD_SLCK) around 32 kHz). In addition, it can be stopped while the processor is in Debug mode or Sleep mode (Idle mode).

Using The Library

Dual watchdog timer is a combination of two watchdog timers:

  1. A watchdog timer that operates in secure domain called programmable secure watchdog timer (PSWDT)

  2. A watchdog timer that operates in non-secure domain called never secure watchdog timer (NSWDT)

PSWDT can reset the system upon detection of an overflow or repeat threshold violations. Both PSDWDT and NSWDT can generate interrupts upon detecting an overflow, repeat threshold violation or level threshold violation. PSWDT can also be configured such that the NSWDT interrupt can be rerouted to be generated in the secure domain.

Library Interface

Dual Watchdog Timer peripheral library provides the following interfaces:

Functions

NameDescription
DWDT_InitializeInitializes Dual watchdog timer peripheral
DWDT_PS_ClearClears the programmable secure watchdog timer
DWDT_PS_DisableDisables the programmable secure watchdog timer
DWDT_NS_ClearClears the never secure watchdog timer
DWDT_NS_DisableDisables the never secure watchdog timer
DWDT_PS_RegisterCallbackAllows application to register callback with PLIB
DWDT_NS_RegisterCallbackAllows application to register callback with PLIB

Data types and constants

NameTypeDescription
DWDT_CALLBACKTypedefDWDT callback function definition