19.5.3.3 Sleep Mode Controller

A Sleep mode is entered by executing the Wait For Interrupt instruction (WFI). The Sleep Mode bits in the Sleep Configuration register (SLEEPCFG.SLEEPMODE) select the level of the Sleep mode. Before entering any sleep mode, ensure any commands written to the NVM controller have completed by confirming the NVMCTRL INTFLAG.READY bit is '1'.

Note: A small latency happens between the store instruction and actual writing of the SLEEPCFG register due to bridges. Software must ensure that the SLEEPCFG register reads the desired value before issuing a WFI instruction.
Table 19-1. Sleep Mode Entry and Exit Table
ModeMode EntryWake-Up Sources
IDLE0SLEEPCFG.SLEEPMODE = IDLE0Synchronous (2) (CAN included), asynchronous (1)
IDLE2SLEEPCFG.SLEEPMODE = IDLE2Synchronous (2) (CAN excluded), asynchronous (1)
STANDBYSLEEPCFG.SLEEPMODE = STANDBY
Synchronous(3) (CAN excluded), Asynchronous(1)
Note:
  1. Asynchronous: interrupt generated on GCLK generic clock, external clock, or external event.
  2. Synchronous: interrupt generated on the APB clock.
  3. Synchronous interrupt only for peripherals configured to run in standby.
Note: The type of wake-up sources (synchronous or asynchronous) is given in each module interrupt section.

The sleep modes (idle, standby) and their effect on the clocks activity, the regulator and the SRAM state are described in the table and the sections below.

Table 19-2. Sleep Mode Overview
ModeCPU clockAHB/APB clocksMain clockGCLK0 clockGCLK1-8 clocksClock SourcesRegulatorSRAM
ONDEMAND = 0ONDEMAND = 1
IDLE0StopRun(1), CAN includedRunRunRun/Stop (3)RunRun/Stop (4)MainNormal
IDLE2StopRun(2), CAN excluded
STANDBYStopStop (5)Stop (5)Stop if RUNSTDBY = 0Stop if RUNSTDBY=0LPVREG (8)Low Power (9)
Stop/Run if RUNSTDBY=1 (6)Run if RUNSTDBY=1Stop/Run if RUNSTDBY=1 (7)
Note:
  1. The AHB/APB clocks are running up to MCLK, and then provided only to the IPs requesting them and to the CAN (which is a specific IP with no clock request mechanism). For the other IPs not requesting their AHB/APB clocks, these are gated at MCLK output.
  2. The AHB/APB clocks are running up to MCLK, and then provided only to the IPs requesting them. For the CAN and for the other IPs not requesting the clocks, they are gated at MCLK output.
  3. Each GCLK1 to GCLK8 is running if the associated generated clock is requested by at least one IP. It is stopped if no IP is requesting this clock.
  4. The clock source is running if the clock is requested by at least one GCLK Generator. It is stopped if no GCLK Generator is requesting this clock and will be restarted as soon as an IP requests a clock coming from a GCLK fed by this clock source.
  5. The AHB/APB clocks are stopped, except if requested by at least one IP, and in this case, only provided to this/these IP(s) through GCLK0 and MCLK.
  6. Each GCLK generators is stopped, except if the clock it generates is requested by at least one IP.
  7. Each Clock Source is stopped, except if the clock it generates is requested by at least one GCLK Generator.
  8. Regulator state is programmable by using STDBYCFG.VREGSMOD bits.
  9. SRAM state is programmable by using STDBYCFG.BBIASHS bit.