

Hello, and welcome to this presentation of the STM32 Reset and Clock Controller.

## Overview 📥

- The STM32F7 reset and clock controller manages system and peripherals clocks
  - · 2 internal oscillators
  - · 2 external oscillators (crystal or resonator)
  - 3 PLLs
  - Flexible peripheral clock sources
- The RCC manages the different system and peripheral resets.

### Application benefits

- High flexibility in clock sources to meet consumption and accuracy requirements.
- The clock controller provides a high degree of flexibility to the application in the choice of the external crystal or the oscillator to run the core and peripherals at the highest frequency.
- Safe and flexible reset management



The RCC controller integrated inside STM32 products manages system and peripheral clocks.

STM32F7 devices embed two internal oscillators, 2 oscillators for an external crystal or resonator, and three phase-locked loops (PLL).

Many peripherals have their own clock, independent of the system clock.

The RCC also manages the various resets present in the device.

The STM32F7 RCC provides high flexibility in the choice of clock sources, which allows the system designer to meet both power consumption and accuracy requirements.

The independent peripheral clocks allow a designer to adjust the system power consumption without impacting the communication baud rates. Finally, the RCC provides safe and flexible reset management.



Safe and flexible reset management without any need for external components reduces application costs. The RCC manages three types of resets: the system reset, the power reset and the backup domain reset. The peripherals have individual reset control bits.

## Reset sources

No external components needed thanks to internal filter and power monitoring Internal reset sources can reset whole application VDD R<sub>PU</sub> External RESET Filter System reset NRST WWDG reset IWDG reset Pulse Firewall reset Generator (min 20 us) Option byte loading reset Software reset BOR reset Low power management reset 57

Here is the simplified block diagram of the system reset. All internal reset sources provide a reset signal on the NRST pin, which can be used to reset other components of the application board. In addition, no external reset circuitry is needed due to the internal glitch filter and the safe power monitoring feature which guarantees the reset of the application when VDD is below the selected threshold.

An internal pull-up on the NRST pin, allows to maintain a high level when no reset signal is driven low.

# System reset Resets all registers except the RCC registers and the backup domain Sources Low level on the NRST pin (External Reset) WWDG end of count condition IWDG end of count condition A software reset (through NVIC) Low power management reset (Standby/Stop entry, enabled by option byte) Power reset Resets all registers except the backup domain Sources Power-on/Power-down reset (POR/PDR) BOR



Exit from Standby

The first type of reset is the system reset, which resets all the registers except certain registers for the Reset and Clock Controller. It also does not reset the backup domain.

The system reset sources are the external reset (generated by a low level on the NRST pin), a window watchdog event, an independent watchdog event, a software event through the Nested Vectored Interrupt Controller, a low-power-mode security reset (which is generated when Stop or Standby mode is entered but is prohibited by the option byte configuration). The reset source flag can be found in the RCC Control and Status register.

The second type of reset is the power reset. The Brownout reset (BOR) resets all registers except those in the Backup domain powered by VBAT which contains the RTC and the external low-speed oscillator.

When exiting Standby mode, all registers powered by the regulator are reset. When exiting Standby mode, a reset is generated.

## Reset sources

- Backup domain reset
  - Resets in the backup domain: RTC registers + Backup registers + RCC BDCR register
  - Sources
    - · BDRST bit in RCC BDCR register set by software
    - · VBAT and VDD power-on reset



The third type of reset is the backup domain reset, which resets the RTC registers, the Backup registers, and the RCC Backup Domain Control Register. This reset occurs when the BDRST bit is set in the RCC Backup Domain control register.

It also occurs when VDD and VBAT are powered on if both supplies have previously been powered off.



The RCC offers a large choice of clock sources, which can be selected depending on low-power, accuracy, and performance requirements.

STM32F7 devices embed two internal clock sources: a high-speed internal 16 MHz RC oscillator (HSI), and a low-speed internal 32 kHz RC oscillator (LSI).

STM32F7 devices embed two oscillators for use with an external crystal or resonator: a high-speed external 4 to 26 MHz oscillator (HSE) with a clock security system and a low-speed external 32.768 kHz oscillator (LSE) also with a clock security system.

STM32F7 devices embed three phase-locked loops, each with three independent outputs for clocking different peripherals at different frequencies.

# Clocks: HSE (High-Speed External)

Safe crystal system clock

HSE 4-50 MHz

- · External source (Bypass mode) up to 50 MHz
- External Crystal/Ceramic resonator (4-26 MHz)
- Clock Security System (CSS)
  - · Automatic detection of HSE failure with
    - NMI generation
    - Break input to TIM1/TIM8 => critical applications such as motor control put in a safe state.
  - Backup clock is HSI => application software does not stop in case of crystal failure



The high-speed internal oscillator is a 16 MHz RC oscillator which provides 1% accuracy and fast wakeup times. The HSI is trimmed during production testing, and can also be user-trimmed.

The HSI is selected as clock at wakeup from Stop mode, and as the backup clock if an HSE failure is detected by the Clock Security System.

If an HSE failure is detected, the Clock Security System allows to put system in safe state by generating break events to critical applications such as motor control.

| Clo                               | cks: LSE (Low-                                          | Speed Exte                 | rnal) 🚥    |
|-----------------------------------|---------------------------------------------------------|----------------------------|------------|
| 32                                | .768 kHz configurable for lov<br>Available in all modes |                            |            |
|                                   | be used with an external quar in bypass mode            | tz or resonator, or with a | n external |
| <ul> <li>LSE oscillato</li> </ul> | r drive capability programmabl                          | e on the fly               |            |
| The LSE can                       | be used for RTC, U(S)ARTs, I                            | PTIM, HDMI-CEC             |            |
|                                   | LSE drive                                               | Added consumption (µA)     |            |
|                                   | Medium-low drive vs Low drive                           | 0.02                       |            |
|                                   | Medium-high drive vs Medium-low drive                   | 0.14                       |            |
|                                   | High drive vs Medium-high drive                         | 0.09                       |            |
|                                   | High drive vs Low drive                                 | 0.23                       |            |
| life.ougmented                    |                                                         |                            |            |

The 32.768 kHz low-speed external oscillator can be used with external quartz or resonator, or with an external clock source in bypass mode.

The oscillator driving capability is programmable. Four modes are available, from ultra-low power mode, to high-driving mode.

The LSE can be used to clock the RTC, the low-power timer, the HDMI-CEC interface, and the USARTs peripherals.



STM32F7 devices embed 3 phase-locked loops, each with 3 independent outputs. The input clock of the PLL can be selected between HSI and HSE.

The main PLL can provide the system clock. The different PLL outputs can be used for the serial audio interfaces, USB, Random Number Generator, SDMMC peripherals and LTDC/ and DSI-HOST interfaces when available.

|                                    |                                          | System clock                                            |
|------------------------------------|------------------------------------------|---------------------------------------------------------|
| Selected bef                       | ween HIS, HSE, or PLL                    |                                                         |
| • Maximum fr                       | equency 216 MHz, APB1 & APB              | 2 up to 54 MHz and 108                                  |
| MHz respect                        | tively<br>ock source frequency depends ( | on voltage scaling:                                     |
| MHz respect                        |                                          | ON VOITAGE SCAIING:<br>Max HCLK frequency Over-Drive ON |
| MHz respect                        | ock source frequency depends             | U U                                                     |
| MHz respect MHz respect Maximum cl | OCK SOURCE frequency depends             | U U                                                     |

The system clock is selected between the HSI, HSE and PLL output.

The maximum system clock frequency is 216 MHz. The APB1 and APB2 bus frequencies are also up to 54 MHz. and 108 MHz respectively

The maximum clock source frequency depends on the voltage scaling. The maximum system clock is reached with voltage scale 1 and when enabling Over-Drive. When Over-Drive is off, the maximum system clock frequency is 180MHz.

| Peripheral clock                                                                                                                                                                 | k sources summary                                                                                                                                                                |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>U(S)ARTs:</li> </ul>                                                                                                                                                    | <ul> <li>The HDMI-CEC clock:</li> </ul>                                                                                                                                          |
| <ul> <li>System clock (SYSCLK)</li> </ul>                                                                                                                                        | LSE clock                                                                                                                                                                        |
| HSI clock                                                                                                                                                                        | HSI clock divided by 488                                                                                                                                                         |
| <ul> <li>LSE clock</li> <li>PCLK1 or PCLk2 clock</li> <li>I2Cx: <ul> <li>System clock (SYSCLK)</li> </ul> </li> </ul>                                                            | <ul> <li>The RTC clock:</li> <li>LSE clock</li> <li>LSI clock</li> </ul>                                                                                                         |
| HSI clock                                                                                                                                                                        | HSE clock divided by 32                                                                                                                                                          |
| PCLK1 clock                                                                                                                                                                      | <ul> <li>The IWDG clock is always the LSI clock</li> </ul>                                                                                                                       |
| <ul> <li>LPTIM1:</li> <li>LSI clock</li> <li>LSE clock</li> <li>HSI clock</li> <li>HSI clock</li> <li>APB1 clock (PCLK1)</li> <li>External clock mapped on LPTIM1_IN1</li> </ul> | <ul> <li>The USB OTG HS (60 MHz) clock is provided from the external PHY</li> <li>The Ethernet MAC clocks (TX, RX and RMII) which are provided from the external PHY.</li> </ul> |

Several peripherals have their own clock independent from the system clock. This is the case for the USARTs, I2Cs, low-power timer, HDMI-CEC interface, independent watchdog, USB OTG HS external PHY clock and Ethernet MAC clocks (when available in the device package). All of these clocks can be selected from the internal/external oscillators' dedicated external clock pin or bus interface clocks.



Serial audio interfaces, USB OTG FS, random number generator, and SDMMC interfaces have independent clock sources that are generated from the different PLL outputs.

In addition to PLL outputs the serial audio interfaces clock can be generated from External clock mapped on the I2S\_CKIN pin or from HSI/HSE clocks if this feature is available.



Several peripherals available only on some F7 device part numbers, such as the DFSDM1 interface, the SDMMC2 interface and the DSI-HOST interface have dedicated input clock sources. The clocks are derived from PLL outputs or from system clocks. In addition to PLL outputs, the DSI-HOST interface clock can be generated from its own PLL.



The various clocks can be output on an I/O. The Microcontroller Clock Output feature allows you to output on a pin one of these six clocks: HSI, HSE, LSE, SYSCLK, PLLCLK, and PLLI2S.



The dynamic power consumption can be optimized by using peripheral clock gating.

Each peripheral clock can be gated ON or OFF in Run and Sleep mode, except SRAM and FLASH which are always clocked in Run and Sleep modes. By default, the peripheral's clock is disabled, except the DTCMRAM clock and RTC interface clock which are enabled by default. When a peripheral's clock is disabled, the peripheral's registers cannot be read or written. Dedicated registers allow for configuring the peripheral's clock during the Sleep mode. These control bits have no effect if the corresponding peripheral clock is disabled.

| PLLI2S ready interrupt flag       Clock ready caused by PLLI2S lock         PLL ready interrupt flag       Clock ready caused by PLL lock         HSE ready       Clock ready caused by the HSE oscillator         HSI ready       Clock ready caused by the HSI oscillator | Interrupt event             | Description                              |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|------------------------------------------|--|
| PLL ready interrupt flag       Clock ready caused by PLL lock         HSE ready       Clock ready caused by the HSE oscillator         HSI ready       Clock ready caused by the HSI oscillator                                                                             | PLLSAI ready interrupt flag | Clock ready caused by PLLSAI lock        |  |
| HSE ready       Clock ready caused by the HSE oscillator         HSI ready       Clock ready caused by the HSI oscillator                                                                                                                                                   | PLLI2S ready interrupt flag | Clock ready caused by PLLI2S lock        |  |
| HSI ready Clock ready caused by the HSI oscillator                                                                                                                                                                                                                          | PLL ready interrupt flag    | Clock ready caused by PLL lock           |  |
|                                                                                                                                                                                                                                                                             | HSE ready                   | Clock ready caused by the HSE oscillator |  |
| LSE ready Clock ready caused by the LSE oscillator                                                                                                                                                                                                                          | HSI ready                   | Clock ready caused by the HSI oscillator |  |
|                                                                                                                                                                                                                                                                             | LSE ready                   | Clock ready caused by the LSE oscillator |  |
| LSI ready Clock ready caused by the LSI oscillator                                                                                                                                                                                                                          | LSI ready                   | Clock ready caused by the LSI oscillator |  |

This slide lists the RCC interrupts. The PLLs ready and all oscillators ready signals can generate an interrupt.



In addition to this training, you may find the Power Control and Interrupt Controller trainings useful.



For more details, please refer to application note AN2867, an oscillator design guide for STM8S, STM8A and STM32 microcontrollers .