.

INCLUDES RFID interfacing with avr GPS interfacing with avr RF Module interfacing with avr Stepper Motor With AVR

Saturday, December 17, 2011

How to configure Watchdog Timers of AVR Microcontroller (ATmega16)

       Some high end applications require multiple or critical calculations to be done by the microcontroller. This may lead to cases when the controller enters into wrong or infinite loops. As a result of this, the system either hangs up or gets crashed. The solution to overcome these situations is to automatically reset the system whenever such a situation arises.

The Watchdog Timer is a hardware or software generated timer interrupt which reboots/resets the system in the situations mentioned above. The watchdog timers are also used in cases when you intentionally require resetting the system without any physical interference.
The AVR microcontroller has an in-built watchdog timer. This article explains the working of watchdog timer in ATmega16.

The Watchdog Timer is a special timer which can be enabled in any section of the code and when enabled it ensures that a certain number of instructions execute within a pre-defined time frame. This time frame or the time delay can be configured/set using the registers of the watchdog timer. In case the instructions execute within the time frame, watchdog timer needs to be turned off and the program execution continues. However, if the instructions fail to execute within this time frame (this conditions is called time out condition) the entire system reboots thus avoiding any system crash or hang up.

Watchdog Timer in ATmega16:
The Watchdog timer of Atmega16 can be configured by using WDTCR register of AVR microcontroller. When the time out condition is set, the watchdog timer starts counting clock cycles. The watchdog’s timer is clocked from separate on-chip watchdog oscillator of 1MHz frequency. The time out condition is set by configuring prescaler bits of WDTCR register.

WDTCR (Watch Dog Timer Control Register): 
  -          -         -         WDTOE      WDE       WDP2         WDP1       WDP0
Bit 7    Bit 6    Bit 5        Bit 4          Bit 3          Bit 2           Bit 1          Bit 0

  
WDTOE (Watch Dog Turn-Off Enable) – The watchdog timer is disabled by configuring WDTOE and WDE bits (explained later in the article).

WDE (Watch Dog Enable) – Watchdog timer is enabled by writing 1 to WDE bit.

WDP [2:0] (Watch Dog Prescaler) bits - These three bits determine the watchdog time out condition.
  
How Watchdog Timer works:
The watchdog timer starts when the WDE bit is enabled and prescaler bits are configured for time-out condition. As watchdog timer reaches time-out condition, watchdog timer is reset and generates a pulse of one clock cycle which resets the program counter. When watch dog timer resets the timer, the WDRF (Watch Dog Reset Flag) bit in MCUCSR register is set by the hardware. To disable the watchdog timer following steps must be followed:
1. Set the WDE and WDTOE bits in same clock cycle WDTCR register. The logic one must be written to WDE bit even though it is set to one already.
2. After four clock pulses, write logic 0 to the WDE bit. Otherwise watchdog timer will not be disabled.

Objective:
To set watchdog timer condition at 2 seconds (approx.) and check the reset condition.

Circuit diagram:
The connection for above mentioned objective is shown in circuit diagram. An LED is connected at pin PB0 which blinks continuously. Another LED is connected to PB1 pin. This LED will glow when watchdog time out condition occurs.

Programming steps:
1. Check the status of WDRF bit. If this bit is high, set the PB1 pin of the controller.
2. Set the WDE bit in WDTCR register to activate the watchdog timer.
3. Set the prescaler bits WDP [2:0] = 111 for the time-out condition of 2 sec.
4. Write an infinite loop to toggle the PB0 bits toggles with a certain delay.
5. On time-out condition, watchdog timer resets the controller and this event reinitialize the program counter to go back at step 1.




// Program to configure watchdog timer in ATmega16 Microcontroller
#include<avr/io.h>
#include<util/delay.h>

int main()
{
    DDRB=0x03;

    if(bit_is_set(MCUCSR,WDRF))
    {
        PORTB|=(1<<PB1);
        _delay_ms(1000);   
    }
   
    PORTB&=~(1<<PB1);
    WDTCR=0x0F;
    while(1)
    {
        PORTB|=(1<<PB0);
        _delay_ms(400);
        PORTB&=~(1<<PB0);
        _delay_ms(400);
    }
}

No comments:

Post a Comment