Files
esp-idf/components/esp_hal_clock/README.md
2026-01-13 15:50:20 +08:00

43 lines
2.2 KiB
Markdown

# ESP Hardware Abstraction Layer for Clock Tree
> [!NOTE]
> This component is currently in beta. Its API, behavior, and compatibility may change at any time and without notice; backward compatibility is not guaranteed. Use caution when integrating into production systems.
## Overview
The `esp_hal_clock` component provides the **Hardware Abstraction Layer** for the SoC clock tree across ESP-IDF supported targets. It exposes helpers to query and configure clock sources, select roots, and manage clock gates in a target-agnostic way while delegating register details to per-target Low-Level (LL) implementations.
## Architecture
The Clock HAL is organized in two layers:
1. **HAL Layer (Upper)**: Target-independent logic and APIs to interact with the clock tree (e.g., querying frequencies, switching roots, enabling/disabling gates).
2. **Low-Level Layer (Bottom)**: Per-target register accessors defined by:
- `clk_tree_ll.h` — clock source/root select, muxes, dividers, and frequency helpers.
- `clk_gate_ll.h` — clock gate enable/disable, reset, and configuration of default clock gate status for peripherals.
- `clkout_channel.h` — clock output channel IDs and related helpers used to route internal clocks to GPIOs.
Per-target HAL sources implement SoC-specific behavior in `clk_tree_hal.c`, using the LL accessors above.
## Features
- Query effective frequencies of common clock domains.
- Select and switch clock roots (when supported).
- Configure dividers/multipliers per domain (target-dependent).
- Gate/ungate peripheral clocks via unified helpers.
- Apply default peripheral clock gate configuration during early boot (target-dependent).
- Configure and map on-chip clocks to GPIOs via clock-out channels (`clkout_channel.h`) on supported targets.
## Usage
This HAL is consumed by ESP-IDF internal components (e.g., `esp_hw_support`, drivers, bootloader code) to perform clock configuration and queries.
Advanced users may interact with the HAL directly when implementing custom bring-up or performance-sensitive flows. API stability is not guaranteed during beta.
## Dependencies
- `soc`: SoC register definitions and clock tree constants
- `hal`: Common HAL utilities and macros