Watchdog Timer
6-10
t
int
= t
clk
X (LO 1) x 2
(PTV+1)
Table 6–10 shows the characteristics of the watchdog timer for different
LOAD_TIM values.
Table 6–10. Watchdog Timer Characteristics
Input clock,
CLKIN
t
clk
,
Clock Period
†
LOAD_TIM
t
int
, Timer Interrupt Period,
for PTV = 7
12 MHz
1167 ns
0001
597.34
µ
s
12 MHz
1167 ns
FFFF (max interrupt period)
19.57 s
† The 12-MHz clock is divided by 14.
If LOAD_TIM = 0 and AR (auto-reload mode) = 1, the timer is always 0 and can
never decrement. Here the timer interrupt is asserted and stays asserted all
the time. Since the timer interrupts are edge-senditive, only one interrupt is
recognized because there is one initial edge, and then the interrupt is asserted
constantly.
6.3.2
Programming the Watchdog Timer in Watchdog Mode
On power up, the watchdog timer defaults to watchdog mode and the value
loaded into the LOAD_TIM register is set to the maximum value (0xFFFF).
This gives the user a time of 16,777,216 * t
clk
(19.57 seconds) to change the
timer mode or write a new value (different from 0xFFFF) into the LOAD_TIM
register.
The user program or the OS must write periodically to the count register,
LOAD_TIM, before the counter underflows. The new loaded value must be
different from the previous value because the write is taken into account only
if the newly loaded value is different from the previous value. Due to internal
sequencing, the user must wait three timer clock periods before writing a new
value into the LOAD_TIM register. If CLKIN is 12 MHz, the duration of three
timer clock periods is approximately 3.5
µ
s.
By writing a predefined sequence (0xF5 followed by 0xA0) to the TIM-
ER_MODE register (see Table 6–15), the timer can be configured as a gener-
al-purpose timer. A sequence decode is initialized when 0xF5 is written to the
TIMER_MODE register. Once in this state, if the next write is different from
0xA0, the state machine causes a reset as if the watchdog timer has under-
flowed. You cannot disable the watchdog timer by simply clearing the watch-
dog bit of the TIMER_MODE register.