Module esp32c2_hal::clock

source ·
Expand description

Clock Control

Overview

This Clock driver provides an interface for configuring and managing various clocks present on the ESP microcontrollers.

Proper clock configuration is essential for the correct functioning of the microcontroller and its peripherals.

The Clock driver supports configuring multiple clocks, including:

  • CPU clock
  • APB (Advanced Peripheral Bus) clock
  • XTAL clock
  • PLL clock

and other specific clocks based on the ESP microcontroller’s architecture.

The CPU clock is responsible for defining the speed at which the central processing unit (CPU) operates. This driver provides predefined options for different CPU clock speeds, such

  • 80 MHz
  • 96 MHz
  • 120 MHz
  • 160 MHz
  • 240 MHz

and others, depending on the microcontroller model.

Clock Control

The ClockControl struct allows users to configure the desired clock frequencies before applying them. It offers flexibility in selecting appropriate clock frequencies based on specific application requirements.

Frozen clock frequencies

Once the clock configuration is applied using the freeze function of the ClockControl struct, the clock frequencies become frozen and cannot be changed. The Clocks struct is returned after freezing, providing read-only access to the configured clock frequencies.

Examples

Initialize with default clock frequency for this chip
let clocks = ClockControl::boot_defaults(system.clock_control).freeze();
Initialize with the highest possible frequency for this chip
let clocks = ClockControl::max(system.clock_control).freeze();
Initialize with custom clock frequency
let clocks = ClockControl::configure(system.clock_control, CpuClock::Clock160MHz).freeze();

Structs

  • Used to configure the frequencies of the clocks present in the chip.
  • Frozen clock frequencies

Enums

Traits