

Hello, and welcome to this presentation of the STM32H7 power controller. The STM32H7's power management functions and all power modes will also be covered in this presentation.

#### Overview 2

- Provides power management and supply control functions
  - · Different supply configurations
  - Voltage scaling
  - Power control per domain
  - · Wakeup from low-power modes
- 5 low-power modes with fast wakeup
- VBAT backup mode with RTC and backup registers
- Independent power supplies

#### Application benefits

- Integrated step-down converter, lowering power consumption.
- Optimizing power consumption: Power control per domain Dynamic voltage scaling
- Autonomous D3 domain operation



The STM32H7 has several key features related to power management including several low-power modes, where it is still possible to wake up the MCU with an event on an I/O as well as a large number of peripherals that can wake up from the various low-power modes.

The D3 autonomous mode allows transfer of data on communication peripherals without waking up the CPUs. Several power supplies are independent, allowing reduction of the MCU power consumption while some peripherals are supplied at higher voltages.

Thanks to the large number of power modes and independent power domains, STM32H7 devices offer high flexibility to minimize the power consumption and adjust it depending on active peripherals, required performance and needed wake-up sources.

The integrated step-down converter reduces STM32H7 power consumption at minimal cost.



STM32H7 devices have several independent power supplies, which can be set at different voltages or tied together. The main power supply is VDD, supplying almost all I/Os except for some IOs of Ports A, C, and B. VDD also supplies the reset block, temperature sensor and all internal clock sources. In addition, it supplies the Standby circuitry which includes the wakeup logic and independent watchdog. VDD supplies the step-down converter which may directly provide the VCORE supply. VCORE supplies the 3 Domains (CPU1 Cortex-M7, CPU2 Cortex-M4 and D3 domain) with most of the digital peripherals and the SRAMs. The Flash memory is supplied by both VCORE and VDD. VCORE may be supplied through the voltage regulator

The STM32H7 features several independent supplies for peripherals: VDDA for the analog peripherals, VDD50USB and VDD33USB for the USB transceiver, VDDDSI and VDD12DSI for the DSI Physical layer. The VREF+ pin

which is supplied on VDDLDO.

provides the reference voltage to the analog-to-digital and to digital-to-analog converters and can be used as an external buffer reference for the application.

A backup battery can be connected to the VBAT pin to supply the backup domain.

### Power schemes -

#### 4

#### Optimized power and performance thanks to independent power supplies

- V<sub>DD</sub> from 1.71 to 3.6 V (1.62 to 3.6V with external supply supervisor)
- V<sub>BAT</sub> from 1.2 to 3.6V including the RTC and 128-byte backup registers
- V<sub>DDSMPS</sub> from 1.62 to 3.6 V
- $V_{DDLDO}$  from 1.62 to 3.6 V ( $V_{DDLDO} \le V_{DD}$ )
- V<sub>DDA</sub> from 1.62 to 3.6 V-
- V<sub>DD50USB</sub> from 4.5 to 5.5 V for USB regulator
- V<sub>DD33USB</sub> from 3 to 3.6 V for USB transceivers
- V<sub>DDDSI</sub> from 3 to 3.6 V for DSI regulator
- V<sub>DD12DSI</sub> from 1.2V for DSI Physical layer

- · 1.62 V min. when ADCs or COMPs are used
- 1.8 V when DACs are used
- · 2.0 V when op amps are used
- 1.8 V min. when V<sub>REFBUF</sub> is used

available only for STM32H7x7 line



The main power supply VDD ensures full featured operation in all power modes from 1.71 up to 3.6 V, allowing to be supplied by an external 1.8 V regulator. Device functionality is guaranteed down to 1.62 V, the minimum voltage after which a brown-out reset is generated. Other independent supplies are provided for peripherals operating at a different voltage.

The analog power supply VDDA can be connected to any voltage other than VDD. When the analog-to-digital converters or comparators are used, the VDDA voltage must be greater than 1.62 V. When the digital-to-analog converters or comparators are used, VDDA must be greater than 1.8 V. When operational amplifiers are used, VDD must be greater than 2.0 V.

The USB regulator supplied from VDD50USB at 5 V generates the USB power supply VDD33USB. When the USB is used, VDD33USB must be greater than 3 V. The DSI regulator supplied from VDDDSI greater than 1.62V

generates the DSI power supply VDD12DSI. When the DSI is used, VDD12DSI must be greater than 1.2 V.

A backup domain is supplied by VBAT, which must be greater than 1.2 V. The backup domain contains the RTC, the 32.768-kHz LSE external oscillator and the 128-byte backup registers.

#### Power schemes 5

#### Independent voltage reference supplies for analog performance

- V<sub>RFF+</sub>: reference voltage for ADCs and DACs
  - · It can be provided either by an external reference voltage or by the internal voltage reference buffer.
  - · VREF+ pin, and thus the internal voltage reference, is not available on the TFBGA100 package. On this package, this pin is double-bonded with V<sub>DDA</sub> which can be connected to an external reference. With this configuration, the internal voltage reference buffer is not available.



The ADC and DAC voltage references can be provided either by an external supply voltage or by the internal reference buffer. This allows the converters performance to be improved by providing an isolated and independent reference voltage.

### Supply configurations

#### Flexible selection between performance and cost

- Core supply from SD convertor and/or Voltage regulator
  - 1. LDO Supply (SD disabled)
    - · LDO supplied from same supply as VDD
  - 2. Direct SD Supply (LDO disabled)
    - · Regulator follows device operation modes
  - · 3. SD supplies LDO (No external supply)
    - · Both regulators follow device operation modes
  - · 4. SD external supply, supplies LDO
    - · SD is forced on in high performance mode
    - · LDO follow device operation modes
  - 5. SD external supply & LDO bypass (LDO disabled)
    - · SD is forced on in high performance mode



6. Bypass (SD & LDO disabled)

(SD can't be used to supply VDD)

VDOSMPS
VESSMPS
VESSMP

The SMPS step-down convertor (SD convertor) can be used in 3 different modes or disabled:

- 1 Directly supply the VCORE domain as shown in Configuration 2. This offers the lowest power consumption.
- 2 Used to supply the voltage regulator at an intermediate supply level, as shown in Configuration 3. This offers low power consumption with a low noise VCORE supply.
- 3 Used to supply external circuitry, as shown in Configurations 4 and 5. In this case, the voltage regulator can still be supplied from the same external supply provided by the step-down convertor.
- 4 Disabled, as shown in Configurations 1 and 6. This offers a low-cost solution at higher power consumption rates. At STM32H7 startup, the supply configuration is programmed in PWR controller's CR3 register. This register is "write once" to protect against accidental over-writes.

The step-down convertor cannot be used to supply the

STM32H7's VDD supply, but can be used to supply the VDDIO2 supply.

### Step-down converter

- Used to step down the V<sub>DD</sub> supply to:
  - Directly supply the V<sub>CORE</sub> domains
    - · SD operating modes will follow the device operating modes (Run, Stop, and Standby).
    - · SD output level will be according the selected VOS and SVOS.
  - · Provide intermediate supply to supply the Core LDO
    - · SD operating modes will follow the device operating modes (Run, Stop, and Standby).
    - SD output level will be according the selected SDLEVEL (1.8 or 2.5 V).
  - · Provide external supply.
    - · SD forced always on in High Performance operating mode.
    - · SD output level will be according the selected SDLEVEL (1.8 or 2.5 V).
- Operating modes
  - · High-performance (Run or External supply)
  - Low-power (Stop)



· Off (Standby)

When directly supplying the  $V_{CORE}$  domain, the step-down convertor provides the supply level according to VOS and SVOS scaling. The step-down converter's operating mode follows the device's modes.

When used to supply the voltage regulator, the step-down convertor may provide an intermediate voltage at 1.8 or 2.5 V. The step-down converter's operating mode follows the device's modes.

When the step-down converter is used to supply external circuitry, it may provide a voltage at 1.8 or 2.5 V. In this case, the operating modes are fixed to "High Performance".

### LDO regulator

- Used to regulate the V<sub>DDLDO</sub> supply to the V<sub>CORE</sub> level
  - Directly supply the V<sub>CORE</sub> domains
    - · LDO operating modes will follow the device operating modes (Run, Stop, and Standby).
    - · LDO output level will be according the selected VOS and SVOS.
  - Bypass
    - LDO is off, the Core domain is directly supplied on V<sub>CORE</sub>.
- Operating modes
  - Main (Run)
  - Low-power (Stop)
  - Off (Standby)



When used, the voltage regulator provides the VCORE supply level according to VOS and SVOS scaling. The voltage regulator's operating mode follows the device's modes.

When the VCORE is supplied from another supply, the voltage regulator is placed in bypassed mode.

### Backup domain regulator

- Operating modes
  - On
  - Off
- Used to regulate the V<sub>SW</sub> supply to the Backup RAM level
  - When V<sub>CORE</sub> is present
    - · Backup domain regulator is off. (Allows to reduce backup battery consumption)
    - Backup RAM is supplied from V<sub>CORE</sub>.
  - When V<sub>CORE</sub> is absent (Standby or V<sub>BAT</sub> mode) and backup regulator is enabled
    - · Backup domain regulator is on.
    - Backup RAM is supplied from V<sub>BKUP</sub>
  - When V<sub>CORE</sub> is absent (Standby or V<sub>BAT</sub> mode) and backup regulator is disabled
    - · Backup domain regulator is off.
    - · Backup RAM is powered down. (data lost)



The Backup regulator is used to keep the context of the Backup RAM in STANDBY and VBAT modes. The backup regulator is enabled by the BREN bit in PWR register CR2 and checks its readiness before entering STANDBY or VBAT mode.

## Other regulators

- USB regulator
  - · Used to supply the USB interface. Can't supply external logic.
  - · See USB training
- DSI regulator
  - · Used to supply the DSI interface. Can't supply external logic.
  - · See DSI training



An independent USB regulator generates the  $V_{\text{DD33USB}}$  from a 5V supply.

### Voltage supply supervision

#### Supply supervision enabling dynamic power management

- Supply voltage monitoring is provided on:
  - V<sub>DD</sub>, & V<sub>DDSMPS</sub> via POR/PDR, BOR (reset), and PVD (threshold interrupt on EXTI).
  - V<sub>DDA</sub> via AVD (threshold interrupt on EXTI)
  - V<sub>BAT</sub> via V<sub>BAT</sub> threshold (interrupt via Tamper)
  - V<sub>CORE</sub> Core domain supply, via level detector (reset).
  - Core domain over voltage detection (forces SD to 1.0V, ACTVOSRDY signal invalid)
  - V<sub>SW</sub> Backup domain supply, via level detector (reset).
  - V<sub>BKP</sub> Backup domain RAM supply, via level detector (ready register bit BRRDY)
  - V<sub>FBSMPS</sub> SD regulated supply, via level detector (ready register bit SDEXTRDY)
  - V<sub>DD33USB</sub> USB regulated supply, via level detector (ready register bit USBRDY)
  - V<sub>CAPDSI</sub> DSI regulated supply, via level detector (ready register bit RRS)



The power supply supervisor ensures dynamic power supply management.

STM32H7 devices embed power management on main VDD, analog VDDA, VBAT supply input, VCORE domain, Backup VSW domain, Backup regulator VBKP supply, stepdown convertor VFBSMPS, USB interface VDD33USB supply and DSI VCAPDSI supplies.

The main VDD supervisor handles reset management and voltage detection via the programmable voltage detector (PVD) when VDD crosses the selected threshold. The PVD can be enabled in all modes except Standby modes. 7 thresholds can be selected by software. In addition, comparisons can be done with an external pin.

The analog VDDA supervisor handles voltage detection via the analog voltage detector (AVD) when VDDA crosses the selected threshold. The AVD can be enabled in all modes except Standby modes. 4 thresholds can be selected by software.

The VBAT supply voltage is monitored to detect when VBAT crosses the minimum and maximum thresholds. The VBAT voltage detection function can be enabled in all modes. The main VCORE supervisor handles reset management and over-voltage detection.

The Backup domain VSW supervisor handles reset management when the supply drops below the operating level.

The Backup regulator VBKP supply supervisor verifies that the regulator is ready to supply the backup RAM, before entering Standby mode.

The step-down convertor VFBSMPS supply supervisor verifies that the converter ready and the supply is at the selected level.

The USB interface VDD33USB supply supervisor verifies that the USB interface supply is present. The USB supervision can be enabled in all modes except Standby modes.

The DSI regulator VCAPDSI supply supervisor verifies that the DSI regulator is ready to supply the DSI interface.

#### POR/PDR & BOR =12

#### Safe and ultra-low-power reset management

- POR (Power On Reset)
  - Supervises V<sub>DD</sub>.
  - Fixed level to disable reset when V<sub>DD</sub> level rises above threshold.
- PDR
  - Supervises V<sub>DD</sub>.
  - Fixed level to generate reset when V<sub>DD</sub> level drops below threshold.
  - · Can be enabled/disabled with PDR ON input pin.
- BOR
  - Supervises V<sub>DD</sub>.
  - Provides 4 selectable levels from V<sub>BOR0</sub> = 1.62 V to V<sub>BOR3</sub> = 2.78 V through option bits **BOR\_LEV[2:0]**, generates reset when V<sub>DD</sub> level drops below threshold.
  - Can be disabled with system option bits.



The V<sub>DD</sub> power supply supervisor guarantees a safe and ultra-low power reset management.

STM32H7 devices embed an ultra-low-power brown-out reset (BOR) which is always enabled in all power modes. The BOR ensures reset generation as soon as the MCU drops below the selected threshold, regardless of the  $V_{\rm DD}$ slope. Four thresholds from 1.62 to 2.78 V are selected by option byte programmed in Flash memory.

The BOR consumption with the 1.7 V threshold is indicated in the datasheet.

## Temperature supervision 13

- Temperature threshold
  - · Supervises junction temperature.
  - · Can be enabled/disabled with register bit MONEN.
  - Provides TEMPH and TEMPL register flags, connected to Tamper wakeup interrupt.



The temperature supervisor detects when the junction temperature crosses the minimum and maximum thresholds. The temperature detection function can be enabled in all modes.



The battery charging feature can charge a super-cap connected to the VBAT pin through an internal resistor when the  $V_{DD}$  supply is present. The charging is enabled by software and is done either through a 5k Ohm or 1.5 kOhm resistor depending on software. Battery charging is automatically disabled in VBAT mode.

#### Dynamic sub-system configuration for optimized consumption

- The system allows to configure the environment for its sub-system:
  - CPU1 (Cortex M7)
  - CPU2 (Cortex M4)
  - D3 autonomous
- The system is configurable based on peripheral allocation
  - A CPU sub-system is composed of the:
    - CPU and associated domain bus matrix
    - · D3 domain bus matrix
    - · Bus matrix fixed peripherals
    - Allocated peripheral with associated domain bus matrix (PERxEN)
  - The D3 domain autonomous mode is composed of the:
    - D3 domain bus matrix



Autonomous mode allocated peripherals (PERXAMEN). Autonomous mode peripherals need also to be allocated by a CPU sub-system.

By allocating peripherals to a CPU or the D3 autonomous mode, the boundary of the sub-system can be controlled. The sub-system will follow its associated CPU or D3 autonomous mode operating mode. This is used to optimize the sub-system's power consumption.

Peripheral allocation is done in the RCC via the PERxEN and PERxAMEN register bits, enabling the automatic wakeup of the domains associated with the woken-up subsystem.



When CPU1 is in CRUN mode, the fixed allocated D1 bus matrix and D3 bus matrix peripherals are clocked. Other peripherals may be allocated when needed. When allocating a peripheral in the D2 domain, the D2 domain will be powered and the D2 bus matrix with its fixed peripherals and the CPU1 allocated peripheral(s) will be clocked. When CPU2 is in CRUN mode, the fixed allocated D2 bus matrix and D3 bus matrix peripherals are clocked. Other peripherals may be allocated when needed. When allocating a peripheral in the D1 domain, the D1 domain will be powered and the D1 bus matrix with its fixed peripherals and the CPU2 allocated peripheral(s) will be clocked. When D3 is in Autonomous run mode, the fixed allocated D3 bus matrix peripherals and the D3 domain Autonomous mode allocated peripherals are clocked.

### Power Management 17

Optimized consumption due to the different V<sub>CORE</sub> domains, voltage scaling and independent operating modes

- The Power management controls the V<sub>CORE</sub> supply level and domain supply
  - V<sub>CORF</sub> domain partitioning
    - · D1 domain CPU1 (CM7), Flash memory, RAM, and peripherals
    - · D2 domain CPU2 (CM4), RAM, and peripherals
    - · D3 domain RAM, and peripherals
  - Operating modes
    - CPU modes (CRun, CSleep, and CStop)
    - Domain modes (DRun, DStop, and DStandby)
    - · System modes (Run, Stop, and Standby)
  - Voltage scaling
    - RUN mode Voltage Scaling (VOS), provides 3 ranges.



STOP mode Voltage Scaling (SVOS), provides 3 ranges.

Power management functions control the power supply for the different domains based on the domain operating mode. The system and domain operating mode depend on the CPU operating mode and the CPU's sub-system boundaries.

### Voltage scaling modes \_\_\_\_\_

#### Flexibility between required performance and consumption

| Voltage<br>range | Mode | SYSCLK      | CM7     | CM4     | D2/D3 domain | Stop mode<br>Wakeup<br>Peripheral |
|------------------|------|-------------|---------|---------|--------------|-----------------------------------|
| Range 0          | Run  | 480 MHz max | 480 MHz | 240 MHz | 240 MHz      |                                   |
| Range 1          | Run  | 400 MHz max | 400 MHz | 200 MHz | 200 MHz      |                                   |
| Range 2          | Run  | 300 MHz max | 300 MHz | 150 MHz | 150 MHz      | Kamal dada a                      |
|                  | Run  | 200 MHz max | 200 MHz | 100 MHz | 100 MHz      | Kernel clock on                   |
| Range 3          | Stop |             | off     | off     | off          |                                   |
| Range 4          | Stop | off         |         |         |              | off                               |
| Range 5          | Stop |             |         |         |              |                                   |

Thanks to voltage scaling, the various Run modes offer flexibility between the required performance and consumption. In Run Mode Range 0 (enhanced performance with high power consumption), the system clock is limited to 480 MHz. In Run Mode Range 1 (high performance with high power

consumption), the system clock is limited to 400 MHz. In Run Mode Range 2 (medium performance and power

consumption), the system clock is limited to 300 MHz.

In Run Mode Range 3 (low performance with low power consumption), the system clock is limited to 200 MHz.

The internal and external oscillators as well as the PLL can be used in all modes, respecting the maximum frequencies.

The Run mode range is determined by the system clock frequency even when a CPU is in CStop mode.

In Stop Mode Range 3, the peripherals with wakeup from Stop mode capabilities (UART, SPI, I2C, and LPTIM) are operational. In Stop Mode Ranges 4 and 5, the peripherals with wakeup from Stop mode capabilities are disabled.

- Each peripheral clock can be configured to be ON or OFF
  - · After reset, all peripheral clocks are OFF, except Flash interface clock
  - TCM and AXISRAM clocks are always ON in D1Run mode
  - · D2SRAMs clocks are always ON in D2Run mode
- When the Cortex-M4 (D2 domain CPU2) is running from D2SRAMs, or D3SRAM:
  - D1 domain can be switched to Power-down mode
  - · Interrupt vectors must also be re-mapped to SRAM!



Each peripheral clock can be configured to be ON or OFF in Run and Low-power run modes. By default all peripherals clocks are OFF, except the Flash interface clock. The SRAM clocks are enabled in Run mode.

When running from D1SRAM, D2SRAM or D3SRAM, the Flash memory can be put in Power-down mode thanks to software, and the Flash clock can be switched off. The Flash memory must not be accessed when it is switched off, consequently interrupts must be mapped in SRAM, using the Cortex-M Vector Table Offset Register.

### CPU operating modes 20

| Mode   | Description                                                                                                |  |
|--------|------------------------------------------------------------------------------------------------------------|--|
| CRun   | CPU Active → CPU, CPU-sub system bus matrix(s), CPU enabled peripheral clock(s) active.                    |  |
| CSleep | ep CPU Sleep → CPU clock stopped, CPU-sub system bus matrix(s), CPU sleep enabled peripheral clock(s) acti |  |
| CStop  | CPU Deepsleep → CPU, CPU-sub system bus matrix(s), CPU peripheral clock(s) stopped.                        |  |

- · CPU operating modes are directly controlled from the CPU
  - Entering low power modes
    - CSleep is entered by executing WF/WE or on return from ISR. (DEPSLEEP = 0)
    - CStop is entered by executing WFI/WE or on return from ISR. (DEEPSLEEP = 1)
  - Exiting low power modes
    - When low-power mode was entered by WFI or return from ISR
      - · on any CPU interrupt with sufficient priority
    - · When low-power mode was entered by WÆ
      - · on CPU event
      - SVONPEND = 0 → on interrupts with sufficient priority
      - SVONPEND = 1 → on any interrupt



The CPU entering low power mode is controlled by the Cortex-M WFI and WFE, and the DEEPSLEEP bit allows to select between CSleep and CStop mode.

When the CPU enters CStop mode, the domain and system operating mode depend on the other CPU and the D3 autonomous modes.

A CPU NVIC interrupt with sufficient priority will wake up the CPU after a WFI or return from ISR.

A CPU event input (rxev) will wake up the CPU after a WFE. In addition when the Cortex-M SVONPEND bit is clear, an NVIC interrupt with sufficient priority will wake up the CPU after a WFE. When the SVONPEND bit is set, any NVIC interrupt will wake up the CPU after a WFE.

### Domain operating modes 21

| Mode     | Description                                               |  |  |  |
|----------|-----------------------------------------------------------|--|--|--|
| DRun     | Domain bus matrix, clock active.                          |  |  |  |
| DStop    | Domain bus matrix and domain peripheral clock(s) stopped. |  |  |  |
| DStandby | Domain powered down.                                      |  |  |  |

- D1 & D2 domain operating modes are controlled from the CPUs having allocated peripherals in the domain.
  - · The domain is in:
    - DRun when a CPU with allocated domain peripherals is in CRun or Csleep mode
    - · DStop when the CPU(s) with allocated domain peripherals is(are) in CStop mode and at least one domain PDDS Dn bit selects Stop
    - DStandby when the CPU(s) with allocated domain peripherals is(are) in CStop mode and all domain PDDS\_Dn bits select Standby



Power management functions control the power supply for the different domains based on the CPU operating mode and the domain Power Down Deepsleep selection through the PWR register bits PDDS\_Dn. Each CPU has its own control bits for the 3 domains.

A domain will only enter DStop mode when the domain CPU is in CStop mode and the other CPU has no allocated peripherals or is also in CStop mode.

### System operating modes 22

| Mode    | Description                                                |  |  |  |  |
|---------|------------------------------------------------------------|--|--|--|--|
| Run     | System clock is active and forwarded to the system.        |  |  |  |  |
| Stop    | System clock is stopped.                                   |  |  |  |  |
| Standby | System is powered down. (Backup domain may be kept active) |  |  |  |  |

- System operating modes controlled from the CPUs and wakeup sources.
  - · Run when a CPU is in CRun or CSleep mode or a wakeup source is active.
  - Stop when the CPUs are in CStop mode and all wakeup sources are cleared and D3 domain is not forced in Run mode, and at least one PDDS Dn bit selects Stop.
  - Standby when the CPUs are in CStop mode and all wakeup sources are cleared and D3 domain is not forced in Run mode, and all PDDS Dn bits select Standby.
- The System supports an D3 autonomous RUN mode:
  - A peripheral in the D3 domain needs to be enabled for Autonomous mode.



· A CPU forces the D3 domain to stay in Run mode via its RUN D3 register bit

The STM32H7 system (D3 domain) operating mode is controlled from both CPUs and the D3 autonomous mode. The system will only enter Stop or Standby mode when both CPUs are in CStop mode and there is no active wakeup source or if the D3 domain is forced in Run mode.

The system will only enter Standby mode when the Power Down Deepsleep selection in PWR register bits PDDS\_Dn allows all domains to enter Standby mode.

The D3 autonomous mode can set the system in Run mode, either by a CPU forcing the D3 domain in Run mode via its RUN\_D3 register bit, or by a peripheral wakeup source request.

### System power control states 23

- · System power state is controlled from both CPUs and the D3 domain.
- · State transitions may be initiated by:
  - · a CPU going to low-power mode.
    - · CPU, Domain and System modes
  - · a peripheral allocation / de-location
    - · Domain mode
  - a wakeup event
    - · CPU, Domain and System modes
  - changing PDDS setting to Standby
    - · Domain mode





This figure gives the complete overview of the power modes in relation to the CPU operating modes and the D3 autonomous mode.

#### All peripherals available and fastest wakeup time

- Core is stopped, each peripheral clock can be gated ON or OFF
- Entered by executing WFI (Wait For Interrupt) or WFE (Wait For Event)
- Two mechanisms to enter this mode:
  - Sleep Now: MCU enters Sleep mode as soon as WFI/WFE instructions are executed
  - Sleep on Exit: MCU enters Sleep mode as soon as it exits the lowest priority ISR
    - · The stack is not popped before entering Sleep mode, it will not be pushed when the next interrupt occurs, saving running time.
  - Controlled by Cortex-M System Control Register [SLEEPONEXIT]



Sleep and Low-power sleep modes enable all peripherals to be used and features the fastest wakeup time.

In these modes, the CPU is stopped and each peripheral clock can be configured by software to be gated ON or OFF during the Sleep and Low-power sleep modes.

These modes are entered by executing the assembler instruction Wait for Interrupt or Wait for Event. When executed in Low-power run mode, the device enters Lowpower sleep mode.

Depending on the SLEEPONEXIT bit configuration in the CortexM4 System Control Register, the MCU enters Sleep mode as soon as the instruction is executed, or as soon as it exits the lowest priority Interrupt Sub Routine. This last configuration saves time and consumption by removing the need to pop and push the stack.

#### Lowest power modes with full retention, 38 µs wakeup time to 64 MHz

- All memory and all peripheral register data is retained
- All high-speed clocks are stopped
- LSE (32.768 kHz external oscillator) and LSI (32 kHz internal oscillator) can be enabled
- Several peripherals can be active and wake up from Stop modes
- System clock at wakeup can be HSI or CSI up to 64 MHz
- Stop Ranges 4 and 5 consumption is lower, Stop Range 3 supports more active peripherals



STM32H7 devices features three Stop modes: Stop range 3, range 4 and range 5, which are the lowest power modes with full retention and fast wakeup time to Run mode **at 64 MHz**. The contents of SRAMs and all peripherals registers are preserved in all Stop modes.

All high speed clocks are stopped.

The 32.768 kHz external oscillator and 32 kHz internal oscillator can be enabled.

Several peripherals can be active and wake up from Stop mode.

System clock on wake-up can be the internal high-speed and Low-power (CSI) oscillators up to 64 MHz with only a 12 µs from FLASH.

Stop range 4 and Range 5 consumption is lower than Stop Range 3, but support less active wakeup peripherals.

#### Allow system clock re-initialization by a "master" CPU

- · When waking up from Stop modes, the clock system is reset.
- The Stop hold function allows a "master" CPU to re-initialize the clock system.
  - A wakeup interrupt to the "slave" CPU will hold the "slave" CPU and issue a wakeup hold interrupt to the "master" CPU.
  - The "master" CPU after having re-initialized the clock system removes the hold on the "slave" CPU.



To be able to re-initialize the clock system by a so called "master" CPU, when exiting from Stop modes, the Stop hold function holds the so-called "slave" CPU until the "master" CPU has re-initialized the system. To do this, a "slave" CPU wakeup from Stop mode interrupt will hold the "slave" CPU and wake up the "master" CPU with a wakeup hold interrupt. Once the "master" CPU has re-initialized the system, it clears the "slave" CPU hold, where afterwards the "slave" CPU will receive the initial wakeup interrupt.

|                       | Stop Range 3                                     | Stop Range 4                            | Stop Range 5         |  |  |  |
|-----------------------|--------------------------------------------------|-----------------------------------------|----------------------|--|--|--|
| 0                     | 25 °C, 3,3 V                                     |                                         |                      |  |  |  |
| Consumption           | 350 μΑ                                           | 220 μΑ                                  | 150 μΑ               |  |  |  |
| Wakeup time to 64 MHz | 12 µs in Hash memory                             | 23 μs in Hash memory                    | 38 µs in Hash memory |  |  |  |
| Wakeup clock          | HSI up to 64 MHz or CSI at 4 MHz                 |                                         |                      |  |  |  |
| Regulator             | Regulator Main mode                              | Regulator Low power mode                |                      |  |  |  |
|                       | LPTIM, RT                                        | C, I/Os, BOR, PVD, AVD, COMPs, and IWDG |                      |  |  |  |
| Peripherals           | Other peripherals allowing wakeup from Stop mode | None                                    |                      |  |  |  |



When comparing Stop modes:

Stop Range 3 consumption is higher than Stop Ranges 4 and 5, but the wakeup time is shorter and the number of active peripherals is higher.

Stop Range 3 keeps the V<sub>CORE</sub> domain at the same supply level as Run Range 3, allowing a very short wake-up time lower than 12 µs when restarting from the RAM to the expense of a higher consumption than Stop mode with Ranges 4 and 5.

It is possible to wake up from Stop Range 3 with peripherals supporting wakeup from Stop mode (UART, SPI, I2C, and LPTIM).

### Standby mode 28

#### Lowest power mode with Backup RAM retention, switch to V<sub>BAT</sub> and I/O control

- By default: no RAM nor registers retention (voltage regulators in power down).
   128-byte backup registers always retained.
- Possibility to retain 4 Kbytes of Backup RAM
- Ultra Low Power BOR always ON: safe reset regardless of V<sub>DD</sub> slope.
- 6 wakeup pins: the polarity of each of the 6 wakeup pins is configurable
- Wakeup clock is HSI 64 MHz.



The Standby mode is the lowest power mode in which 4 Kbytes of Backup RAM can be retained, the automatic switch from VDD to VBAT is supported and the I/Os level can be configured by independent pull-up and pull-down circuitry.

By default, the voltage regulators are in Power down mode and the SRAMs and the peripherals registers are lost. The 128-byte backup registers are always retained.

Thanks to software, it is possible to retain 4 Kbytes of Backup RAM.

The ultra-low-power brown-out reset is always ON to ensure a safe reset regardless of the VDD slope.

Each I/O can be configured with or without a pull-up or pull-down, which is applied and released thanks to the APC control bit. This allows control of the inputs state of external components even during Standby mode.

6 wakeup pins are available to wake up the device from Standby mode. The polarity of each of the 6 wakeup pins is configurable.

The wakeup clock is HSI with a frequency of 64 MHz.

#### VBAT mode

#### RTC still running and backup registers preserved in case of V<sub>DD</sub> loss

- Backup domain contains:
  - RTC clocked by 32.768 kHz LSE oscillator, including 3 tamper pins
  - 128 bytes backup registers
  - · RCC BDCR register
  - 4 Kbyte Backup memory, when backup regulator is enabled.
- Automatic internal switch between V<sub>BAT</sub> and V<sub>DD</sub> when V<sub>DD</sub> is powered down and powered on.
- Internal connection to ADC for voltage monitoring (V<sub>BAT</sub>/4)
- V<sub>BAT</sub> charging



The backup domain allows us to keep the RTC functional and to preserve the backup registers in case the VDD supply is down, thanks to a backup battery connected to the VBAT pin.

The backup domain contains the RTC clocked by the lowspeed external oscillator at 32.768 kHz. 3 tamper pins are functional in VBAT mode, and will erase the 128-byte backup registers also included in the VBAT domain, in case of intrusion detection.

The backup domain also contains the RTC clock control logic.

In case VDD drops below a certain threshold, the backup domain power supply automatically switches to VBAT. When VDD is back to normal, the backup domain power supply automatically switches back to VDD.

The VBAT voltage is internally connected to an ADC input channel in order to monitor the backup battery level. When VDD is present, the battery connected to VBAT can be charged from the VDD supply.

- When a CPU enters CStop mode
  - · the CPU domain may
    - · stay in Run mode when the other domain CPU in CRun or CSleep mode has allocated peripherals
    - · enter DStop mode
    - · enter DStandby mode when allowed.
  - the System may
    - · stay in Run mode when the other domain CPU stays in CRun or CSleep mode, or a wakeup source remains active
    - · enter Stop mode
    - · enter Standby mode when allowed.
- The domain and system operating mode depend on both CPUs and the autonomous mode settings.

A CPU will enter CStop mode when executing a WFI or WFE with the DEEPSLEEP bit set. The domain and system state will also depend on the other CPU's operating mode and wakeup source status. Only when the other CPU has no allocated peripherals in the domain or the other CPU is also in CStop mode, the domain may enter DStop or DStandby mode. When in addition none of the wakeup sources is active, the system may enter Stop or Standby mode.

- To know from which domain and system low-power mode the CPU wakes up from CStop mode, flags are provided.
  - SBF Dn
    - · CPU domain has woken up from DStandby mode (The system may have stayed in Run mode or have been woken up from Stop mode)
      - · CPU starts from reset
  - STOPF
    - · System has woken up from Stop mode
      - · Wakeup interrupt to the CPU will be pending in AIEC or peripheral
  - SBF
    - · System has woken up from Standby mode
      - · CPU starts from reset, there is no wakeup interrupt pending in the AIEC.



When a CPU wakes up from its CStop mode, it has to know from which mode the domains and system have woken up. For this, the CPU has dedicated flag bits SBF D1, SBF D2, SBF and STOPF. These bits inform the CPU about the state of the system, and which parts may need to be reinitialized.

## Software low-power procedure 32

- The Low-power mode to enter is configured by:
  - · The Cortex-M SLEEPDEEP bit
    - · Sleep or Other low power modes
  - · and the PWR Domain PDDS bits.
    - · STOP or STANDBY
- To know from which low-power mode the CPU is woken up, the following bit must be checked:
  - · The Cortex-M SLEEPDEEP bit
    - · Sleep
  - PWR control
    - STOPF
    - Domain SBF\_D1 and SBF\_D2.
    - System SBF





The Cortex-M SLEEPDEEP bit allows selection of the CPU to enter CSleep or CStop modes.

When the CPU enters CStop mode, the PWR control bits PDDS\_D1, PDDS\_D2, and PDDS\_D3 select which state the Domains may enter in. The state of the domains depend also on the other CPU's sub-system configuration and operating mode and the wakeup source status.

From CSleep mode, the CPU will always wake up through an interrupt or event. In this case, the Cortex-M DEEPSLEEP bit is 0.

From CStop mode, the CPU may wake up through an interrupt or via a reset depending on the domain state. If the domain was in DStop mode, the CPU woke up through an interrupt. In this case, the Cortex-M DEEPSLEEP bit is 1. When in addition the STOPF bit is 0, the system remained in Run mode, so there is no need to re-initialize the clock system.

If the STOPF bit is also set, it means that the system woke

up from Stop mode and the clock system needs reinitialization. If the CPU has allocated peripherals in the other domain, check the other domain's SBF\_Dn flag to know if the domain was in DStandby mode. In this case, the peripheral in the other domain needs to be reinitialized.

If the domain was in DStandby mode, the CPU will wake up through a reset. If the SBF flag is also set, the system was in Standby. In this case a full system initialization is need. When the SBF flag is 0 and the CPU domain SBF\_Dn flag is set, the system remained either in Run or Stop mode and only the CPU domain has exited from DStandby. In this case, only the CPU and its domain need to be re-initialized, afterwards the system state must be checked to know if the system remained in Run mode or was in Stop mode. When the CPU domain SBF\_Dn flag doesn't indicate DStandby, the CPU woke up via a system POR reset.

## Wakeup 33

The CPU wakeup state depends on the domain and system state

| CPU<br>mode | Domain<br>mode | System<br>Mode | S<br>B<br>F_D<br>n | S B F | S<br>T<br>O<br>P<br>F                            | CPU wakeup to RUN           | System clock        |
|-------------|----------------|----------------|--------------------|-------|--------------------------------------------------|-----------------------------|---------------------|
| CSleep      | DRun           | Run            |                    | 0     | 0                                                | By NVIC interrupt or event. | Unchanged           |
|             |                |                | 0                  |       |                                                  |                             |                     |
| DStop       |                |                |                    |       | By EXTI wakeup interrupt through NVIC, or event. |                             |                     |
|             | Stop           | 0              | 0                  | 1     |                                                  | Default after Stop          |                     |
| CStop       |                | Run            | 1                  | 0     | 0                                                | By EXTI wakeup via reset    | Unchanged           |
|             | DStandby       | Stop           | 1                  | 0     | 1                                                | by EATT wakeup via Teset    | Default after Stop  |
|             |                | Standby        | 0                  | 1     | 0                                                | By WKUP wakeup via reset    | Reset after Standby |
| Any         | Any            | Any            | 0                  | 0     | 0                                                | By POR via reset            | Default after reset |



This table gives an complete overview of the CPU, domain and system mode and the wakeup flag bits. It also shows how the CPU was awaken, through an interrupt or an event, or a CPU reset.

# PWR interrupts 34

| Interrupt<br>event | Description                                                              | Availability          |
|--------------------|--------------------------------------------------------------------------|-----------------------|
| WKUP[6:1]          | Wakeup from Standby mode. Wakeup from Stop mode via event signal to EXTI | Run, Stop and Standby |
| PVDO               | Wakeup from Stop mode via event signal to EXTI                           | Run and Stop          |
| AVDO               | Wakeup from Stop mode via event signal to EXTI                           | Run and Stop          |
| VBATH,<br>VBATL    | Wakeup from Standby mode & STOP mode via RTC Tamper Interrupt            | Run, Stop and Standby |
| TEMPH,<br>TEMPL    | Wakeup from Standby mode & STOP mode via RTC Tamper Interrupt            | Run, Stop and Standby |



Here a summary of the PWR control related interrupts.

## Option bytes 35

- · The following option bits can be configured to prohibit a given low-power mode:
  - · nRST\_STDBY: When cleared, a reset is generated when entering Standby mode
  - · nRST STOP: When cleared, a reset is generated when entering Stop mode



2 bits are available in the Flash option bytes to prohibit entering a given low-power mode. When cleared, these option bits trigger a reset when entering either Standby or Stop modes. This is a security feature used to reduce the impact of unintentional entry into these low-power modes. If these low-power modes are not used in user code, the option should be enabled.

- The DBGMCU\_CR register enables debugging in Standby mode:
  - DBG STANDBY: When set, the digital part is not powered down in Standby mode. When exiting from Standby mode, a reset is generated.
- When DBG STANDBY is enabled, the connection with the debugger is kept during the Standby mode. After wakeup, debugging is still possible.



The Debug Control Register is used to enable debugging in Standby mode. When the related bit is set, the regulator is kept ON and the Domains are supplied in Standby modes. This maintains the connection with the debugger during the low-power modes, and continues debugging after wakeup. Remember to clear these bits when the MCU is not under debug, because the consumption is higher in all low-power modes when these bits are set, due to the fact they force the regulators to remain enabled.

### Related peripherals 37

- Refer to the following list of peripheral trainings for more details about their dependencies with the power modes:
  - · Reset and clock control (RCC)
  - · Interrupts (NVIC EXTI)
  - Digital-to-analog converter (DAC)
  - Comparator (COMP)
  - Low-power timer (LPTIM)
  - Independent watchdog (IWDG)
  - · Real-time clock (RTC)
  - Inter-integrated circuit (I2C) interface
  - Universal synchronous asynchronous receiver transmitter (USART)
  - Low-power universal asynchronous receiver transmitter (LPUART)
  - · Single Wire Protocol Master Interface (SWPMI)



USB On-The-Go Full-Speed (OTG\_FS)

In addition to this training, you can refer to the Reset and Clock Control and Interrupts trainings as well as those for all the peripherals with wakeup from Stop and Standby capability.