12.2.2 Wake-up Using Interrupts
When global interrupts are disabled (GIE cleared) and any interrupt source, with the exception of the clock switch interrupt, has both its interrupt enable bit and interrupt flag bit set, one of the following will occur:
- If the interrupt occurs before the execution of a
SLEEP
instruction- The
SLEEP
instruction will execute as aNOP
- WDT and WDT prescaler will not be cleared
- The TO bit of the STATUS register will not be set
- The PD bit of the STATUS register will not be cleared
- The
- If the interrupt occurs during or after the execution of a
SLEEP
instruction- The
SLEEP
instruction will be completely executed - Device will immediately wake up from Sleep
- WDT and WDT prescaler will be cleared
- The TO bit of the STATUS register will be set
- The PD bit of the STATUS register will be cleared
- The
Even if the flag bits were checked before executing a
SLEEP
instruction, it may be possible for flag bits to become set
before the SLEEP
instruction completes. To determine whether a
SLEEP
instruction executed, test the PD bit. If the PD bit is
set, the SLEEP
instruction was executed as a NOP
.