Atmel AVR132 Application Note Download Page 11

11

AVR 132 Application Note

2551A–AVR–11/03

The first conditional branch handles the case where no reset flags are set upon startup.
Since the reset flags are always cleared in the initialization routine, this only happens
when runaway code wraps back to address 0 and runs the startup code once again
without a reset. This clearly indicates a bug or fault in software and is handled like a
WDT System Reset. The initialization routine just enters an infinite loop and waits for the
WDT to reset the device properly.

The code then checks the WDT Reset Flag. If it is set, the routine increments the WDT
Reset counter and checks it against a predefined limit. If this limit is exceeded, the appli-
cation assumes that there is a permanent repeating error and indicates this by turning
on the failure indicator LED and halting execution. By entering an infinite loop with a
WDR instruction inside, execution is effectively halted until an external reset occurs.

Power-up or external reset events are considered to be manual intervention and the
WDT Reset counter is cleared. This makes it possible for a human operator to manually
reset an application that has been halted by too many WDT System Resets. The opera-
tor must of course try to find the source of the WDT System Resets before resetting.
Blindly resetting and hoping for things to fix themselves is not a recommended solu-
tion.The rest of the flowchart should be self-explanatory.

Communicate Command

The routine that gets a command is an example of a poorly designed communication
routine. It flashes a LED 10 times and then waits for any button to be pressed. The prob-
lem arises when the user waits too long. A robust design should implement some sort of
timeout check and return with an error code if the communication times out. However,
this routine does not, and the WDT will reset the device if no button is pressed within the
WDT timeout period. The flowchart for the communication routine is shown in Figure 9.

Figure 9.  Flash LED and Wait for User to Press Some Buttons

If a command button is pressed in time, the routine sets its health flag and returns the
button press bit pattern.

Any buttons

pressed ?

Communicate()

Flash LED 10 times

No

Yes

Save button bits

Turn off LED and wait

a number of cycles

Set health flag for

this routine

Return button bits

Potential WDT timeout here if
user waits too long before
pressing a command button

Summary of Contents for AVR132

Page 1: ...ous damage to its surroundings Automatic handling and recovery of such cases is the job of a watchdog timer The Enhanced Watchdog Timer WDT runs independent of the rest of the system causing system re...

Page 2: ...age 3 shows what happens when a WDT timeout occurs The dotted boxes describe actions performed by the system The solid lined boxes describe actions to be performed by the application When using the En...

Page 3: ...tion path through the main loop of your application This includes expected interrupt handlers as well If your main loop is very large several checkpoints could be inserted inside the loop to allow a s...

Page 4: ...period The Everything ok check at the end of the loop is the part of the loop deciding whether the application is operating correctly or not One solution is to use flags that are set in different part...

Page 5: ...to WDT System Reset The Write Complete Flag could be a byte in EEPROM indicating whether the backup operation was finished before the system reset This flag is checked in the startup code if the WDT...

Page 6: ...3V supply voltage An example on how to use the WDT as a wakeup source is shown in Figure 4 Figure 4 Using the WDT as a Wakeup Timer If periodic wakeups are preferred the disabling of the WDT Interrupt...

Page 7: ...pt or a timeout warning interrupt An example interrupt handler is shown in Figure 5 Figure 5 Dual purpose WDT Interrupt Handler Note that the wakeup flag must be set manually prior to entering sleep m...

Page 8: ...safe state or at least be able to supply some debugging information to the operator Changing the WDT Configuration To prevent accidental changes to the WDT configuration special timed sequences are n...

Page 9: ...igure 7 Figure 7 Circuit Diagram for Application Example The examples demonstrate the following concepts Using the WDT as a system reset source Using the WDT as a Wakeup Timer Using the WDT as a combi...

Page 10: ...dashed frames are only used in the Combined Operation code example and are described later Figure 8 Initialization Routine When Using the WDT as a System Reset Source Any res et f lags s et Initializa...

Page 11: ...uman operator to manually reset an application that has been halted by too many WDT System Resets The opera tor must of course try to find the source of the WDT System Resets before resetting Blindly...

Page 12: ...in the switch block Execute Command In this routine the command code decides which action to perform Command 1 has no particular action but it keeps the main loop running healthy by being a valid comm...

Page 13: ...loop of this example flashes the LED connected to PB0 10 times to show that it is awake It then resets the WDT enables the WDT Interrupt Mode and enters sleep mode When the WDT times out it wakes up t...

Page 14: ...decides what action to take If it is already cleared an error has occurred and the failure LED is lit The rest of the interrupt handler implementation complies with the flowchart The rest of the code...

Page 15: ...9F Tonetsu Shinkawa Bldg 1 24 8 Shinkawa Chuo ku Tokyo 104 0033 Japan Tel 81 3 3523 3551 Fax 81 3 3523 7581 Memory 2325 Orchard Parkway San Jose CA 95131 USA Tel 1 408 441 0311 Fax 1 408 436 4314 Mic...

Reviews: