mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
feat(ledc): add ledc support on c61
This commit is contained in:
parent
eff2e4eddd
commit
2e2cbd9aa8
@ -689,7 +689,7 @@ esp_err_t ledc_channel_config(const ledc_channel_config_t *ledc_conf)
|
|||||||
if (!new_speed_mode_ctx_created && !p_ledc_obj[speed_mode]) {
|
if (!new_speed_mode_ctx_created && !p_ledc_obj[speed_mode]) {
|
||||||
return ESP_ERR_NO_MEM;
|
return ESP_ERR_NO_MEM;
|
||||||
}
|
}
|
||||||
#if !(CONFIG_IDF_TARGET_ESP32 || CONFIG_IDF_TARGET_ESP32H2 || CONFIG_IDF_TARGET_ESP32P4 || CONFIG_IDF_TARGET_ESP32C5)
|
#if !(CONFIG_IDF_TARGET_ESP32 || CONFIG_IDF_TARGET_ESP32H2 || CONFIG_IDF_TARGET_ESP32P4 || CONFIG_IDF_TARGET_ESP32C5 || CONFIG_IDF_TARGET_ESP32C61)
|
||||||
// On such targets, the default ledc core(global) clock does not connect to any clock source
|
// On such targets, the default ledc core(global) clock does not connect to any clock source
|
||||||
// Set channel configurations and update bits before core clock is on could lead to error
|
// Set channel configurations and update bits before core clock is on could lead to error
|
||||||
// Therefore, we should connect the core clock to a real clock source to make it on before any ledc register operation
|
// Therefore, we should connect the core clock to a real clock source to make it on before any ledc register operation
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
| Supported Targets | ESP32 | ESP32-C2 | ESP32-C3 | ESP32-C5 | ESP32-C6 | ESP32-H2 | ESP32-P4 | ESP32-S2 | ESP32-S3 |
|
| Supported Targets | ESP32 | ESP32-C2 | ESP32-C3 | ESP32-C5 | ESP32-C6 | ESP32-C61 | ESP32-H2 | ESP32-P4 | ESP32-S2 | ESP32-S3 |
|
||||||
| ----------------- | ----- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- |
|
| ----------------- | ----- | -------- | -------- | -------- | -------- | --------- | -------- | -------- | -------- | -------- |
|
||||||
|
@ -472,7 +472,7 @@ TEST_CASE("LEDC multi fade test", "[ledc]")
|
|||||||
}
|
}
|
||||||
#endif // SOC_LEDC_GAMMA_CURVE_FADE_SUPPORTED
|
#endif // SOC_LEDC_GAMMA_CURVE_FADE_SUPPORTED
|
||||||
|
|
||||||
#if SOC_PCNT_SUPPORTED // Note. C3, C2 do not have PCNT peripheral, the following test cases cannot be tested
|
#if SOC_PCNT_SUPPORTED // Note. C61, C3, C2 do not have PCNT peripheral, the following test cases cannot be tested
|
||||||
|
|
||||||
#include "driver/pulse_cnt.h"
|
#include "driver/pulse_cnt.h"
|
||||||
|
|
||||||
|
565
components/hal/esp32c61/include/hal/ledc_ll.h
Normal file
565
components/hal/esp32c61/include/hal/ledc_ll.h
Normal file
@ -0,0 +1,565 @@
|
|||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
// The LL layer for LEDC register operations.
|
||||||
|
// Note that most of the register operations in this layer are non-atomic operations.
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "hal/assert.h"
|
||||||
|
#include "hal/ledc_types.h"
|
||||||
|
#include "soc/ledc_struct.h"
|
||||||
|
#include "soc/ledc_reg.h"
|
||||||
|
#include "soc/clk_tree_defs.h"
|
||||||
|
#include "soc/pcr_struct.h"
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define LEDC_LL_GET_HW() &LEDC
|
||||||
|
|
||||||
|
#define LEDC_LL_DUTY_NUM_MAX (LEDC_CH0_GAMMA_RANGE0_DUTY_NUM_V)
|
||||||
|
#define LEDC_LL_DUTY_CYCLE_MAX (LEDC_CH0_GAMMA_RANGE0_DUTY_CYCLE_V)
|
||||||
|
#define LEDC_LL_DUTY_SCALE_MAX (LEDC_CH0_GAMMA_RANGE0_SCALE_V)
|
||||||
|
#define LEDC_LL_HPOINT_VAL_MAX (LEDC_HPOINT_CH0_V)
|
||||||
|
#define LEDC_LL_FRACTIONAL_BITS (8)
|
||||||
|
#define LEDC_LL_FRACTIONAL_MAX ((1 << LEDC_LL_FRACTIONAL_BITS) - 1)
|
||||||
|
#define LEDC_LL_GLOBAL_CLOCKS SOC_LEDC_CLKS
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Enable peripheral register clock
|
||||||
|
*
|
||||||
|
* @param enable Enable/Disable
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_enable_bus_clock(bool enable)
|
||||||
|
{
|
||||||
|
PCR.ledc_conf.ledc_clk_en = enable;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Reset whole peripheral register to init value defined by HW design
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_enable_reset_reg(bool enable)
|
||||||
|
{
|
||||||
|
PCR.ledc_conf.ledc_rst_en = enable;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Enable the power for LEDC memory block
|
||||||
|
*
|
||||||
|
* Note. This function cannot overwrite the power control of the mem block in sleep mode
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_enable_mem_power(bool enable)
|
||||||
|
{
|
||||||
|
PCR.ledc_pd_ctrl.ledc_mem_force_pd = !enable;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Enable LEDC function clock
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param en True to enable, false to disable
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_enable_clock(ledc_dev_t *hw, bool en)
|
||||||
|
{
|
||||||
|
(void)hw;
|
||||||
|
PCR.ledc_sclk_conf.ledc_sclk_en = en;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set LEDC low speed timer clock
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param slow_clk_sel LEDC low speed timer clock source
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_set_slow_clk_sel(ledc_dev_t *hw, ledc_slow_clk_sel_t slow_clk_sel)
|
||||||
|
{
|
||||||
|
(void) hw;
|
||||||
|
uint32_t clk_sel_val = 3;
|
||||||
|
switch (slow_clk_sel)
|
||||||
|
{
|
||||||
|
case LEDC_SLOW_CLK_XTAL:
|
||||||
|
clk_sel_val = 0;
|
||||||
|
break;
|
||||||
|
case LEDC_SLOW_CLK_RC_FAST:
|
||||||
|
clk_sel_val = 1;
|
||||||
|
break;
|
||||||
|
case LEDC_SLOW_CLK_PLL_DIV:
|
||||||
|
clk_sel_val = 2;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
abort();
|
||||||
|
}
|
||||||
|
|
||||||
|
PCR.ledc_sclk_conf.ledc_sclk_sel = clk_sel_val;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get LEDC low speed timer clock
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param slow_clk_sel LEDC low speed timer clock source
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_get_slow_clk_sel(ledc_dev_t *hw, ledc_slow_clk_sel_t *slow_clk_sel)
|
||||||
|
{
|
||||||
|
(void) hw;
|
||||||
|
switch (PCR.ledc_sclk_conf.ledc_sclk_sel)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
*slow_clk_sel = LEDC_SLOW_CLK_XTAL;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
*slow_clk_sel = LEDC_SLOW_CLK_RC_FAST;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
*slow_clk_sel = LEDC_SLOW_CLK_PLL_DIV;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
abort();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Update LEDC low speed timer
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param timer_sel LEDC timer index (0-3), select from ledc_timer_t
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_ls_timer_update(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_timer_t timer_sel)
|
||||||
|
{
|
||||||
|
hw->timer_group[speed_mode].timer[timer_sel].conf.para_up = 1;
|
||||||
|
// Here, we don't wait for the bit gets cleared since it can take quite long depends on the pwm frequency
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Reset LEDC timer
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param timer_sel LEDC timer index (0-3), select from ledc_timer_t
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_timer_rst(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_timer_t timer_sel)
|
||||||
|
{
|
||||||
|
hw->timer_group[speed_mode].timer[timer_sel].conf.rst = 1;
|
||||||
|
hw->timer_group[speed_mode].timer[timer_sel].conf.rst = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Pause LEDC timer
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param timer_sel LEDC timer index (0-3), select from ledc_timer_t
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_timer_pause(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_timer_t timer_sel)
|
||||||
|
{
|
||||||
|
hw->timer_group[speed_mode].timer[timer_sel].conf.pause = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Resume LEDC timer
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param timer_sel LEDC timer index (0-3), select from ledc_timer_t
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_timer_resume(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_timer_t timer_sel)
|
||||||
|
{
|
||||||
|
hw->timer_group[speed_mode].timer[timer_sel].conf.pause = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set LEDC timer clock divider
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param timer_sel LEDC timer index (0-3), select from ledc_timer_t
|
||||||
|
* @param clock_divider Timer clock divide value, the timer clock is divided from the selected clock source
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_set_clock_divider(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_timer_t timer_sel, uint32_t clock_divider)
|
||||||
|
{
|
||||||
|
hw->timer_group[speed_mode].timer[timer_sel].conf.clk_div = clock_divider;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get LEDC timer clock divider
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param timer_sel LEDC timer index (0-3), select from ledc_timer_t
|
||||||
|
* @param clock_divider Timer clock divide value, the timer clock is divided from the selected clock source
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_get_clock_divider(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_timer_t timer_sel, uint32_t *clock_divider)
|
||||||
|
{
|
||||||
|
*clock_divider = hw->timer_group[speed_mode].timer[timer_sel].conf.clk_div;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get LEDC timer clock source
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param timer_sel LEDC timer index (0-3), select from ledc_timer_t
|
||||||
|
* @param clk_src Pointer to accept the timer clock source
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_get_clock_source(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_timer_t timer_sel, ledc_clk_src_t *clk_src)
|
||||||
|
{
|
||||||
|
// The target has no timer-specific clock source option
|
||||||
|
HAL_ASSERT(hw->timer_group[speed_mode].timer[timer_sel].conf.tick_sel == 0);
|
||||||
|
*clk_src = LEDC_SCLK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set LEDC duty resolution
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param timer_sel LEDC timer index (0-3), select from ledc_timer_t
|
||||||
|
* @param duty_resolution Resolution of duty setting in number of bits. The range of duty values is [0, (2**duty_resolution)]
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_set_duty_resolution(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_timer_t timer_sel, uint32_t duty_resolution)
|
||||||
|
{
|
||||||
|
hw->timer_group[speed_mode].timer[timer_sel].conf.duty_res = duty_resolution;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get LEDC duty resolution
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param timer_sel LEDC timer index (0-3), select from ledc_timer_t
|
||||||
|
* @param duty_resolution Pointer to accept the resolution of duty setting in number of bits.
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_get_duty_resolution(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_timer_t timer_sel, uint32_t *duty_resolution)
|
||||||
|
{
|
||||||
|
*duty_resolution = hw->timer_group[speed_mode].timer[timer_sel].conf.duty_res;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get LEDC max duty
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param timer_sel LEDC timer index (0-3), select from ledc_timer_t
|
||||||
|
* @param max_duty Pointer to accept the max duty
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_get_max_duty(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_timer_t timer_sel, uint32_t *max_duty)
|
||||||
|
{
|
||||||
|
*max_duty = (1 << (hw->timer_group[speed_mode].timer[timer_sel].conf.duty_res));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Update channel configure when select low speed mode
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_ls_channel_update(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num)
|
||||||
|
{
|
||||||
|
hw->channel_group[speed_mode].channel[channel_num].conf0.para_up = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set LEDC hpoint value
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param hpoint_val LEDC hpoint value(max: 0xfffff)
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_set_hpoint(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num, uint32_t hpoint_val)
|
||||||
|
{
|
||||||
|
hw->channel_group[speed_mode].channel[channel_num].hpoint.hpoint = hpoint_val;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get LEDC hpoint value
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param hpoint_val Pointer to accept the LEDC hpoint value(max: 0xfffff)
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_get_hpoint(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num, uint32_t *hpoint_val)
|
||||||
|
{
|
||||||
|
*hpoint_val = hw->channel_group[speed_mode].channel[channel_num].hpoint.hpoint;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set LEDC the integer part of duty value
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param duty_val LEDC duty value, the range of duty setting is [0, (2**duty_resolution)]
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_set_duty_int_part(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num, uint32_t duty_val)
|
||||||
|
{
|
||||||
|
hw->channel_group[speed_mode].channel[channel_num].duty_init.duty = duty_val << 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get LEDC duty value
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param duty_val Pointer to accept the LEDC duty value
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_get_duty(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num, uint32_t *duty_val)
|
||||||
|
{
|
||||||
|
*duty_val = (hw->channel_group[speed_mode].channel[channel_num].duty_r.duty >> 4);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Function to set fade parameters all-in-one
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param range Gamma fade range index, 0 ~ SOC_LEDC_GAMMA_CURVE_FADE_RANGE_MAX
|
||||||
|
* @param dir LEDC duty change direction, increase or decrease
|
||||||
|
* @param cycle The duty cycles
|
||||||
|
* @param scale The step scale
|
||||||
|
* @param step The number of increased or decreased times
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_set_fade_param_range(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num, uint8_t range, uint32_t dir, uint32_t cycle, uint32_t scale, uint32_t step)
|
||||||
|
{
|
||||||
|
ledc_channel_gamma_fade_param_t range_param = {
|
||||||
|
.duty_inc = dir,
|
||||||
|
.duty_cycle = cycle,
|
||||||
|
.scale = scale,
|
||||||
|
.duty_num = step,
|
||||||
|
};
|
||||||
|
LEDC_GAMMA_RAM.channel[channel_num].entry[range].val = range_param.val;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set the total number of ranges in one fading
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param range_num Total number of ranges (1 - SOC_LEDC_GAMMA_CURVE_FADE_RANGE_MAX) of the fading configured
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_set_range_number(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num, uint32_t range_num)
|
||||||
|
{
|
||||||
|
hw->channel_gamma_conf_group[speed_mode].gamma_conf[channel_num].gamma_entry_num = range_num;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get the total number of ranges in one fading
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param range_num Pointer to accept fade range number
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_get_range_number(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num, uint32_t *range_num)
|
||||||
|
{
|
||||||
|
*range_num = hw->channel_gamma_conf_group[speed_mode].gamma_conf[channel_num].gamma_entry_num;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get fade configurations in gamma_rd register
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param range Gamma fade range index to get, 0 ~ SOC_LEDC_GAMMA_CURVE_FADE_RANGE_MAX
|
||||||
|
* @param dir Pointer to accept fade direction value
|
||||||
|
* @param cycle Pointer to accept fade cycle value
|
||||||
|
* @param scale Pointer to accept fade scale value
|
||||||
|
* @param step Pointer to accept fade step value
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_get_fade_param_range(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num, uint8_t range, uint32_t *dir, uint32_t *cycle, uint32_t *scale, uint32_t *step)
|
||||||
|
{
|
||||||
|
ledc_channel_gamma_fade_param_t range_param = {
|
||||||
|
.val = LEDC_GAMMA_RAM.channel[channel_num].entry[range].val,
|
||||||
|
};
|
||||||
|
|
||||||
|
*dir = range_param.duty_inc;
|
||||||
|
*cycle = range_param.duty_cycle;
|
||||||
|
*scale = range_param.scale;
|
||||||
|
*step = range_param.duty_num;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set the output enable
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param sig_out_en The output enable status
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
__attribute__((always_inline))
|
||||||
|
static inline void ledc_ll_set_sig_out_en(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num, bool sig_out_en)
|
||||||
|
{
|
||||||
|
hw->channel_group[speed_mode].channel[channel_num].conf0.sig_out_en = sig_out_en;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set the duty start
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param duty_start The duty start
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_set_duty_start(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num, bool duty_start)
|
||||||
|
{
|
||||||
|
hw->channel_group[speed_mode].channel[channel_num].conf1.duty_start = duty_start;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set output idle level
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param idle_level The output idle level
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
__attribute__((always_inline))
|
||||||
|
static inline void ledc_ll_set_idle_level(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num, uint32_t idle_level)
|
||||||
|
{
|
||||||
|
hw->channel_group[speed_mode].channel[channel_num].conf0.idle_lv = idle_level & 0x1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set fade end interrupt enable
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param fade_end_intr_en The fade end interrupt enable status
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_set_fade_end_intr(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num, bool fade_end_intr_en)
|
||||||
|
{
|
||||||
|
uint32_t value = hw->int_ena.val;
|
||||||
|
uint32_t int_en_base = LEDC_DUTY_CHNG_END_CH0_INT_ENA_S;
|
||||||
|
hw->int_ena.val = fade_end_intr_en ? (value | BIT(int_en_base + channel_num)) : (value & (~(BIT(int_en_base + channel_num))));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get fade end interrupt status
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param intr_status The fade end interrupt status
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_get_fade_end_intr_status(ledc_dev_t *hw, ledc_mode_t speed_mode, uint32_t *intr_status)
|
||||||
|
{
|
||||||
|
uint32_t value = hw->int_st.val;
|
||||||
|
uint32_t int_en_base = LEDC_DUTY_CHNG_END_CH0_INT_ENA_S;
|
||||||
|
*intr_status = (value >> int_en_base) & 0xff;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Clear fade end interrupt status
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_clear_fade_end_intr_status(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num)
|
||||||
|
{
|
||||||
|
uint32_t int_en_base = LEDC_DUTY_CHNG_END_CH0_INT_ENA_S;
|
||||||
|
hw->int_clr.val = BIT(int_en_base + channel_num);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set timer index of the specified channel
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param timer_sel LEDC timer index (0-3), select from ledc_timer_t
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_bind_channel_timer(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num, ledc_timer_t timer_sel)
|
||||||
|
{
|
||||||
|
hw->channel_group[speed_mode].channel[channel_num].conf0.timer_sel = timer_sel;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get timer index of the specified channel
|
||||||
|
*
|
||||||
|
* @param hw Beginning address of the peripheral registers
|
||||||
|
* @param speed_mode LEDC speed_mode, low-speed mode only
|
||||||
|
* @param channel_num LEDC channel index (0-5), select from ledc_channel_t
|
||||||
|
* @param timer_sel Pointer to accept the LEDC timer index
|
||||||
|
*
|
||||||
|
* @return None
|
||||||
|
*/
|
||||||
|
static inline void ledc_ll_get_channel_timer(ledc_dev_t *hw, ledc_mode_t speed_mode, ledc_channel_t channel_num, ledc_timer_t *timer_sel)
|
||||||
|
{
|
||||||
|
*timer_sel = (ledc_timer_t)(hw->channel_group[speed_mode].channel[channel_num].conf0.timer_sel);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
@ -55,6 +55,10 @@ config SOC_I2C_SUPPORTED
|
|||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config SOC_LEDC_SUPPORTED
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
config SOC_SYSTIMER_SUPPORTED
|
config SOC_SYSTIMER_SUPPORTED
|
||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
@ -323,10 +327,34 @@ config SOC_LEDC_SUPPORT_PLL_DIV_CLOCK
|
|||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config SOC_LEDC_SUPPORT_XTAL_CLOCK
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
config SOC_LEDC_CHANNEL_NUM
|
config SOC_LEDC_CHANNEL_NUM
|
||||||
int
|
int
|
||||||
default 6
|
default 6
|
||||||
|
|
||||||
|
config SOC_LEDC_TIMER_BIT_WIDTH
|
||||||
|
int
|
||||||
|
default 20
|
||||||
|
|
||||||
|
config SOC_LEDC_SUPPORT_FADE_STOP
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
|
config SOC_LEDC_GAMMA_CURVE_FADE_SUPPORTED
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
|
config SOC_LEDC_GAMMA_CURVE_FADE_RANGE_MAX
|
||||||
|
int
|
||||||
|
default 16
|
||||||
|
|
||||||
|
config SOC_LEDC_FADE_PARAMS_BIT_WIDTH
|
||||||
|
int
|
||||||
|
default 10
|
||||||
|
|
||||||
config SOC_MMU_PAGE_SIZE_CONFIGURABLE
|
config SOC_MMU_PAGE_SIZE_CONFIGURABLE
|
||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -20,38 +20,38 @@ typedef union {
|
|||||||
* Configures which timer is channel n selected.\\0: Select timer0\\1: Select
|
* Configures which timer is channel n selected.\\0: Select timer0\\1: Select
|
||||||
* timer1\\2: Select timer2\\3: Select timer3
|
* timer1\\2: Select timer2\\3: Select timer3
|
||||||
*/
|
*/
|
||||||
uint32_t timer_sel_chn:2;
|
uint32_t timer_sel:2;
|
||||||
/** sig_out_en_chn : R/W; bitpos: [2]; default: 0;
|
/** sig_out_en_chn : R/W; bitpos: [2]; default: 0;
|
||||||
* Configures whether or not to enable signal output on channel n.\\0: Signal output
|
* Configures whether or not to enable signal output on channel n.\\0: Signal output
|
||||||
* disable\\1: Signal output enable
|
* disable\\1: Signal output enable
|
||||||
*/
|
*/
|
||||||
uint32_t sig_out_en_chn:1;
|
uint32_t sig_out_en:1;
|
||||||
/** idle_lv_chn : R/W; bitpos: [3]; default: 0;
|
/** idle_lv_chn : R/W; bitpos: [3]; default: 0;
|
||||||
* Configures the output value when channel n is inactive. Valid only when
|
* Configures the output value when channel n is inactive. Valid only when
|
||||||
* LEDC_SIG_OUT_EN_CHn is 0.\\0: Output level is low\\1: Output level is high
|
* LEDC_SIG_OUT_EN_CHn is 0.\\0: Output level is low\\1: Output level is high
|
||||||
*/
|
*/
|
||||||
uint32_t idle_lv_chn:1;
|
uint32_t idle_lv:1;
|
||||||
/** para_up_chn : WT; bitpos: [4]; default: 0;
|
/** para_up_chn : WT; bitpos: [4]; default: 0;
|
||||||
* Configures whether or not to update LEDC_HPOINT_CHn, LEDC_DUTY_START_CHn,
|
* Configures whether or not to update LEDC_HPOINT_CHn, LEDC_DUTY_START_CHn,
|
||||||
* LEDC_SIG_OUT_EN_CHn, LEDC_TIMER_SEL_CHn, LEDC_OVF_CNT_EN_CHn fields and duty cycle
|
* LEDC_SIG_OUT_EN_CHn, LEDC_TIMER_SEL_CHn, LEDC_OVF_CNT_EN_CHn fields and duty cycle
|
||||||
* range configuration for channel n, and will be automatically cleared by
|
* range configuration for channel n, and will be automatically cleared by
|
||||||
* hardware.\\0: Invalid. No effect\\1: Update
|
* hardware.\\0: Invalid. No effect\\1: Update
|
||||||
*/
|
*/
|
||||||
uint32_t para_up_chn:1;
|
uint32_t para_up:1;
|
||||||
/** ovf_num_chn : R/W; bitpos: [14:5]; default: 0;
|
/** ovf_num_chn : R/W; bitpos: [14:5]; default: 0;
|
||||||
* Configures the maximum times of overflow minus 1.The LEDC_OVF_CNT_CHn_INT interrupt
|
* Configures the maximum times of overflow minus 1.The LEDC_OVF_CNT_CHn_INT interrupt
|
||||||
* will be triggered when channel n overflows for (LEDC_OVF_NUM_CHn + 1) times.
|
* will be triggered when channel n overflows for (LEDC_OVF_NUM_CHn + 1) times.
|
||||||
*/
|
*/
|
||||||
uint32_t ovf_num_chn:10;
|
uint32_t ovf_num:10;
|
||||||
/** ovf_cnt_en_chn : R/W; bitpos: [15]; default: 0;
|
/** ovf_cnt_en_chn : R/W; bitpos: [15]; default: 0;
|
||||||
* Configures whether or not to enable the ovf_cnt of channel n.\\0: Disable\\1: Enable
|
* Configures whether or not to enable the ovf_cnt of channel n.\\0: Disable\\1: Enable
|
||||||
*/
|
*/
|
||||||
uint32_t ovf_cnt_en_chn:1;
|
uint32_t ovf_cnt_en:1;
|
||||||
/** ovf_cnt_reset_chn : WT; bitpos: [16]; default: 0;
|
/** ovf_cnt_reset_chn : WT; bitpos: [16]; default: 0;
|
||||||
* Configures whether or not to reset the ovf_cnt of channel n.\\0: Invalid. No
|
* Configures whether or not to reset the ovf_cnt of channel n.\\0: Invalid. No
|
||||||
* effect\\1: Reset the ovf_cnt
|
* effect\\1: Reset the ovf_cnt
|
||||||
*/
|
*/
|
||||||
uint32_t ovf_cnt_reset_chn:1;
|
uint32_t ovf_cnt_reset:1;
|
||||||
uint32_t reserved_17:15;
|
uint32_t reserved_17:15;
|
||||||
};
|
};
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
@ -66,7 +66,7 @@ typedef union {
|
|||||||
* Configures high point of signal output on channel n. The output value changes to
|
* Configures high point of signal output on channel n. The output value changes to
|
||||||
* high when the selected timers has reached the value specified by this register.
|
* high when the selected timers has reached the value specified by this register.
|
||||||
*/
|
*/
|
||||||
uint32_t hpoint_chn:20;
|
uint32_t hpoint:20;
|
||||||
uint32_t reserved_20:12;
|
uint32_t reserved_20:12;
|
||||||
};
|
};
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
@ -80,7 +80,7 @@ typedef union {
|
|||||||
/** duty_chn : R/W; bitpos: [24:0]; default: 0;
|
/** duty_chn : R/W; bitpos: [24:0]; default: 0;
|
||||||
* Configures the duty of signal output on channel n.
|
* Configures the duty of signal output on channel n.
|
||||||
*/
|
*/
|
||||||
uint32_t duty_chn:25;
|
uint32_t duty:25;
|
||||||
uint32_t reserved_25:7;
|
uint32_t reserved_25:7;
|
||||||
};
|
};
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
@ -96,7 +96,7 @@ typedef union {
|
|||||||
* Configures whether the duty cycle fading configurations take effect.\\0: Not take
|
* Configures whether the duty cycle fading configurations take effect.\\0: Not take
|
||||||
* effect\\1: Take effect
|
* effect\\1: Take effect
|
||||||
*/
|
*/
|
||||||
uint32_t duty_start_chn:1;
|
uint32_t duty_start:1;
|
||||||
};
|
};
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
} ledc_chn_conf1_reg_t;
|
} ledc_chn_conf1_reg_t;
|
||||||
@ -109,30 +109,30 @@ typedef union {
|
|||||||
/** timern_duty_res : R/W; bitpos: [4:0]; default: 0;
|
/** timern_duty_res : R/W; bitpos: [4:0]; default: 0;
|
||||||
* Configures the bit width of the counter in timer n. Valid values are 1 to 20.
|
* Configures the bit width of the counter in timer n. Valid values are 1 to 20.
|
||||||
*/
|
*/
|
||||||
uint32_t timern_duty_res:5;
|
uint32_t duty_res:5;
|
||||||
/** clk_div_timern : R/W; bitpos: [22:5]; default: 0;
|
/** clk_div_timern : R/W; bitpos: [22:5]; default: 0;
|
||||||
* Configures the divisor for the divider in timer n.The least significant eight bits
|
* Configures the divisor for the divider in timer n.The least significant eight bits
|
||||||
* represent the fractional part.
|
* represent the fractional part.
|
||||||
*/
|
*/
|
||||||
uint32_t clk_div_timern:18;
|
uint32_t clk_div:18;
|
||||||
/** timern_pause : R/W; bitpos: [23]; default: 0;
|
/** timern_pause : R/W; bitpos: [23]; default: 0;
|
||||||
* Configures whether or not to pause the counter in timer n.\\0: Normal\\1: Pause
|
* Configures whether or not to pause the counter in timer n.\\0: Normal\\1: Pause
|
||||||
*/
|
*/
|
||||||
uint32_t timern_pause:1;
|
uint32_t pause:1;
|
||||||
/** timern_rst : R/W; bitpos: [24]; default: 1;
|
/** timern_rst : R/W; bitpos: [24]; default: 1;
|
||||||
* Configures whether or not to reset timer n. The counter will show 0 after
|
* Configures whether or not to reset timer n. The counter will show 0 after
|
||||||
* reset.\\0: Not reset\\1: Reset
|
* reset.\\0: Not reset\\1: Reset
|
||||||
*/
|
*/
|
||||||
uint32_t timern_rst:1;
|
uint32_t rst:1;
|
||||||
/** tick_sel_timern : R/W; bitpos: [25]; default: 0;
|
/** tick_sel_timern : R/W; bitpos: [25]; default: 0;
|
||||||
* Configures which clock is timer n selected. Unused.
|
* Configures which clock is timer n selected. Unused.
|
||||||
*/
|
*/
|
||||||
uint32_t tick_sel_timern:1;
|
uint32_t tick_sel:1;
|
||||||
/** timern_para_up : WT; bitpos: [26]; default: 0;
|
/** timern_para_up : WT; bitpos: [26]; default: 0;
|
||||||
* Configures whether or not to update LEDC_CLK_DIV_TIMERn and
|
* Configures whether or not to update LEDC_CLK_DIV_TIMERn and
|
||||||
* LEDC_TIMERn_DUTY_RES.\\0: Invalid. No effect\\1: Update
|
* LEDC_TIMERn_DUTY_RES.\\0: Invalid. No effect\\1: Update
|
||||||
*/
|
*/
|
||||||
uint32_t timern_para_up:1;
|
uint32_t para_up:1;
|
||||||
uint32_t reserved_27:5;
|
uint32_t reserved_27:5;
|
||||||
};
|
};
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
@ -146,17 +146,17 @@ typedef union {
|
|||||||
/** chn_gamma_entry_num : R/W; bitpos: [4:0]; default: 0;
|
/** chn_gamma_entry_num : R/W; bitpos: [4:0]; default: 0;
|
||||||
* Configures the number of duty cycle fading rages for LEDC chn.
|
* Configures the number of duty cycle fading rages for LEDC chn.
|
||||||
*/
|
*/
|
||||||
uint32_t chn_gamma_entry_num:5;
|
uint32_t gamma_entry_num:5;
|
||||||
/** chn_gamma_pause : WT; bitpos: [5]; default: 0;
|
/** chn_gamma_pause : WT; bitpos: [5]; default: 0;
|
||||||
* Configures whether or not to pause duty cycle fading of LEDC chn.\\0: Invalid. No
|
* Configures whether or not to pause duty cycle fading of LEDC chn.\\0: Invalid. No
|
||||||
* effect\\1: Pause
|
* effect\\1: Pause
|
||||||
*/
|
*/
|
||||||
uint32_t chn_gamma_pause:1;
|
uint32_t gamma_pause:1;
|
||||||
/** chn_gamma_resume : WT; bitpos: [6]; default: 0;
|
/** chn_gamma_resume : WT; bitpos: [6]; default: 0;
|
||||||
* Configures whether or nor to resume duty cycle fading of LEDC chn.\\0: Invalid. No
|
* Configures whether or nor to resume duty cycle fading of LEDC chn.\\0: Invalid. No
|
||||||
* effect\\1: Resume
|
* effect\\1: Resume
|
||||||
*/
|
*/
|
||||||
uint32_t chn_gamma_resume:1;
|
uint32_t gamma_resume:1;
|
||||||
uint32_t reserved_7:25;
|
uint32_t reserved_7:25;
|
||||||
};
|
};
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
@ -633,7 +633,7 @@ typedef union {
|
|||||||
/** duty_chn_r : RO; bitpos: [24:0]; default: 0;
|
/** duty_chn_r : RO; bitpos: [24:0]; default: 0;
|
||||||
* Represents the current duty of output signal on channel n.
|
* Represents the current duty of output signal on channel n.
|
||||||
*/
|
*/
|
||||||
uint32_t duty_chn_r:25;
|
uint32_t duty:25;
|
||||||
uint32_t reserved_25:7;
|
uint32_t reserved_25:7;
|
||||||
};
|
};
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
@ -1017,45 +1017,90 @@ typedef union {
|
|||||||
uint32_t val;
|
uint32_t val;
|
||||||
} ledc_date_reg_t;
|
} ledc_date_reg_t;
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
volatile ledc_chn_conf0_reg_t conf0;
|
volatile ledc_chn_conf0_reg_t conf0;
|
||||||
volatile ledc_chn_hpoint_reg_t hpoint;
|
volatile ledc_chn_hpoint_reg_t hpoint;
|
||||||
volatile ledc_chn_duty_reg_t duty;
|
volatile ledc_chn_duty_reg_t duty_init;
|
||||||
volatile ledc_chn_conf1_reg_t conf1;
|
volatile ledc_chn_conf1_reg_t conf1;
|
||||||
volatile ledc_chn_duty_r_reg_t duty_rd;
|
volatile ledc_chn_duty_r_reg_t duty_r;
|
||||||
} ledc_chn_reg_t;
|
} ledc_chn_reg_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile ledc_chn_reg_t channel[6];
|
||||||
|
} ledc_ch_group_reg_t;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
volatile ledc_timern_conf_reg_t conf;
|
volatile ledc_timern_conf_reg_t conf;
|
||||||
volatile ledc_timern_value_reg_t value;
|
volatile ledc_timern_value_reg_t value;
|
||||||
} ledc_timerx_reg_t;
|
} ledc_timerx_reg_t;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
volatile ledc_chn_reg_t channel[6];
|
|
||||||
uint32_t reserved_078[10];
|
|
||||||
volatile ledc_timerx_reg_t timer[4];
|
volatile ledc_timerx_reg_t timer[4];
|
||||||
|
} ledc_timer_group_reg_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile ledc_chn_gamma_conf_reg_t gamma_conf[6];
|
||||||
|
} ledc_ch_gamma_conf_group_reg_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile ledc_timern_cmp_reg_t cmp[4];
|
||||||
|
} ledc_timer_cmp_group_reg_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile ledc_timern_cnt_cap_reg_t cnt_cap[4];
|
||||||
|
} ledc_timer_cnt_cap_group_reg_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile ledc_ch_group_reg_t channel_group[1];
|
||||||
|
uint32_t reserved_078[10];
|
||||||
|
volatile ledc_timer_group_reg_t timer_group[1];
|
||||||
volatile ledc_int_raw_reg_t int_raw;
|
volatile ledc_int_raw_reg_t int_raw;
|
||||||
volatile ledc_int_st_reg_t int_st;
|
volatile ledc_int_st_reg_t int_st;
|
||||||
volatile ledc_int_ena_reg_t int_ena;
|
volatile ledc_int_ena_reg_t int_ena;
|
||||||
volatile ledc_int_clr_reg_t int_clr;
|
volatile ledc_int_clr_reg_t int_clr;
|
||||||
uint32_t reserved_0d0[12];
|
uint32_t reserved_0d0[12];
|
||||||
volatile ledc_chn_gamma_conf_reg_t chn_gamma_conf[6];
|
volatile ledc_ch_gamma_conf_group_reg_t channel_gamma_conf_group[1];
|
||||||
uint32_t reserved_118[2];
|
uint32_t reserved_118[2];
|
||||||
volatile ledc_evt_task_en0_reg_t evt_task_en0;
|
volatile ledc_evt_task_en0_reg_t evt_task_en0;
|
||||||
volatile ledc_evt_task_en1_reg_t evt_task_en1;
|
volatile ledc_evt_task_en1_reg_t evt_task_en1;
|
||||||
volatile ledc_evt_task_en2_reg_t evt_task_en2;
|
volatile ledc_evt_task_en2_reg_t evt_task_en2;
|
||||||
uint32_t reserved_12c[5];
|
uint32_t reserved_12c[5];
|
||||||
volatile ledc_timern_cmp_reg_t timern_cmp[4];
|
volatile ledc_timer_cmp_group_reg_t timer_cmp_group[1];
|
||||||
volatile ledc_timern_cnt_cap_reg_t timern_cnt_cap[4];
|
volatile ledc_timer_cnt_cap_group_reg_t timer_cnt_cap_group[1];
|
||||||
uint32_t reserved_160[4];
|
uint32_t reserved_160[4];
|
||||||
volatile ledc_conf_reg_t conf;
|
volatile ledc_conf_reg_t conf;
|
||||||
volatile ledc_date_reg_t date;
|
volatile ledc_date_reg_t date;
|
||||||
} ledc_dev_t;
|
} ledc_dev_t;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gamma fade param group ram type
|
||||||
|
*/
|
||||||
|
typedef union {
|
||||||
|
struct {
|
||||||
|
uint32_t duty_inc :1;
|
||||||
|
uint32_t duty_cycle :10;
|
||||||
|
uint32_t scale :10;
|
||||||
|
uint32_t duty_num :10;
|
||||||
|
uint32_t reserved :1;
|
||||||
|
};
|
||||||
|
uint32_t val;
|
||||||
|
} ledc_channel_gamma_fade_param_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile ledc_channel_gamma_fade_param_t entry[16];
|
||||||
|
} ledc_gamma_channel_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile ledc_gamma_channel_t channel[6];
|
||||||
|
} ledc_gamma_ram_t;
|
||||||
|
|
||||||
extern ledc_dev_t LEDC;
|
extern ledc_dev_t LEDC;
|
||||||
|
extern ledc_gamma_ram_t LEDC_GAMMA_RAM;
|
||||||
|
|
||||||
#ifndef __cplusplus
|
#ifndef __cplusplus
|
||||||
_Static_assert(sizeof(ledc_dev_t) == 0x178, "Invalid size of ledc_dev_t structure");
|
_Static_assert(sizeof(ledc_dev_t) == 0x178, "Invalid size of ledc_dev_t structure");
|
||||||
|
_Static_assert(sizeof(ledc_gamma_ram_t) == 0x180, "Invalid size of ledc_gamma_ram_t structure");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
@ -37,8 +37,8 @@
|
|||||||
#define SOC_RTC_MEM_SUPPORTED 1 //TODO: [ESP32C61] IDF-9274
|
#define SOC_RTC_MEM_SUPPORTED 1 //TODO: [ESP32C61] IDF-9274
|
||||||
// \#define SOC_I2S_SUPPORTED 1 //TODO: [ESP32C61] IDF-9312, IDF-9313
|
// \#define SOC_I2S_SUPPORTED 1 //TODO: [ESP32C61] IDF-9312, IDF-9313
|
||||||
// \#define SOC_GPSPI_SUPPORTED 1 //TODO: [ESP32C61] IDF-9299, IDF-9300, IDF-9301
|
// \#define SOC_GPSPI_SUPPORTED 1 //TODO: [ESP32C61] IDF-9299, IDF-9300, IDF-9301
|
||||||
// \#define SOC_LEDC_SUPPORTED 1 //TODO: [ESP32C61] IDF-9291
|
|
||||||
#define SOC_I2C_SUPPORTED 1
|
#define SOC_I2C_SUPPORTED 1
|
||||||
|
#define SOC_LEDC_SUPPORTED 1
|
||||||
#define SOC_SYSTIMER_SUPPORTED 1 //TODO: [ESP32C61] IDF-9307, IDF-9308
|
#define SOC_SYSTIMER_SUPPORTED 1 //TODO: [ESP32C61] IDF-9307, IDF-9308
|
||||||
// \#define SOC_SUPPORT_COEXISTENCE 1
|
// \#define SOC_SUPPORT_COEXISTENCE 1
|
||||||
// \#define SOC_SHA_SUPPORTED 1 //TODO: [ESP32C61] IDF-9234
|
// \#define SOC_SHA_SUPPORTED 1 //TODO: [ESP32C61] IDF-9234
|
||||||
@ -238,15 +238,14 @@
|
|||||||
// #define SOC_I2S_SUPPORTS_TDM (1)
|
// #define SOC_I2S_SUPPORTS_TDM (1)
|
||||||
|
|
||||||
/*-------------------------- LEDC CAPS ---------------------------------------*/
|
/*-------------------------- LEDC CAPS ---------------------------------------*/
|
||||||
//TODO: [ESP32C61] IDF-9291
|
|
||||||
#define SOC_LEDC_SUPPORT_PLL_DIV_CLOCK (1)
|
#define SOC_LEDC_SUPPORT_PLL_DIV_CLOCK (1)
|
||||||
// #define SOC_LEDC_SUPPORT_XTAL_CLOCK (1)
|
#define SOC_LEDC_SUPPORT_XTAL_CLOCK (1)
|
||||||
#define SOC_LEDC_CHANNEL_NUM (6)
|
#define SOC_LEDC_CHANNEL_NUM (6)
|
||||||
// #define SOC_LEDC_TIMER_BIT_WIDTH (20)
|
#define SOC_LEDC_TIMER_BIT_WIDTH (20)
|
||||||
// #define SOC_LEDC_SUPPORT_FADE_STOP (1)
|
#define SOC_LEDC_SUPPORT_FADE_STOP (1)
|
||||||
// #define SOC_LEDC_GAMMA_CURVE_FADE_SUPPORTED (1)
|
#define SOC_LEDC_GAMMA_CURVE_FADE_SUPPORTED (1)
|
||||||
// #define SOC_LEDC_GAMMA_CURVE_FADE_RANGE_MAX (16)
|
#define SOC_LEDC_GAMMA_CURVE_FADE_RANGE_MAX (16)
|
||||||
// #define SOC_LEDC_FADE_PARAMS_BIT_WIDTH (10)
|
#define SOC_LEDC_FADE_PARAMS_BIT_WIDTH (10)
|
||||||
|
|
||||||
/*-------------------------- MMU CAPS ----------------------------------------*/
|
/*-------------------------- MMU CAPS ----------------------------------------*/
|
||||||
#define SOC_MMU_PAGE_SIZE_CONFIGURABLE (1)
|
#define SOC_MMU_PAGE_SIZE_CONFIGURABLE (1)
|
||||||
|
@ -11,6 +11,7 @@ PROVIDE ( SPIMEM1 = 0x60003000 );
|
|||||||
PROVIDE ( I2C0 = 0x60004000 );
|
PROVIDE ( I2C0 = 0x60004000 );
|
||||||
PROVIDE ( UART2 = 0x60006000 );
|
PROVIDE ( UART2 = 0x60006000 );
|
||||||
PROVIDE ( LEDC = 0x60007000 );
|
PROVIDE ( LEDC = 0x60007000 );
|
||||||
|
PROVIDE ( LEDC_GAMMA_RAM = 0x60007400 );
|
||||||
PROVIDE ( TIMERG0 = 0x60008000 );
|
PROVIDE ( TIMERG0 = 0x60008000 );
|
||||||
PROVIDE ( TIMERG1 = 0x60009000 );
|
PROVIDE ( TIMERG1 = 0x60009000 );
|
||||||
PROVIDE ( SYSTIMER = 0x6000A000 );
|
PROVIDE ( SYSTIMER = 0x6000A000 );
|
||||||
|
17
components/soc/esp32c61/ledc_periph.c
Normal file
17
components/soc/esp32c61/ledc_periph.c
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "soc/ledc_periph.h"
|
||||||
|
#include "soc/gpio_sig_map.h"
|
||||||
|
|
||||||
|
/*
|
||||||
|
Bunch of constants for every LEDC peripheral: GPIO signals
|
||||||
|
*/
|
||||||
|
const ledc_signal_conn_t ledc_periph_signal[1] = {
|
||||||
|
{
|
||||||
|
.sig_out0_idx = LEDC_LS_SIG_OUT0_IDX,
|
||||||
|
}
|
||||||
|
};
|
@ -97,7 +97,6 @@ api-reference/peripherals/touch_element.rst
|
|||||||
api-reference/peripherals/ppa.rst
|
api-reference/peripherals/ppa.rst
|
||||||
api-reference/peripherals/ana_cmpr.rst
|
api-reference/peripherals/ana_cmpr.rst
|
||||||
api-reference/peripherals/camera_driver.rst
|
api-reference/peripherals/camera_driver.rst
|
||||||
api-reference/peripherals/ledc.rst
|
|
||||||
api-reference/peripherals/temp_sensor.rst
|
api-reference/peripherals/temp_sensor.rst
|
||||||
api-reference/peripherals/spi_features.rst
|
api-reference/peripherals/spi_features.rst
|
||||||
api-reference/peripherals/sdio_slave.rst
|
api-reference/peripherals/sdio_slave.rst
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
LED Control (LEDC)
|
LED Control (LEDC)
|
||||||
==================
|
==================
|
||||||
|
|
||||||
{IDF_TARGET_LEDC_MAX_FADE_RANGE_NUM: default="1", esp32c6="16", esp32h2="16", esp32p4="16", esp32c5="16"}
|
{IDF_TARGET_LEDC_MAX_FADE_RANGE_NUM: default="1", esp32c6="16", esp32h2="16", esp32p4="16", esp32c5="16", esp32c61="16"}
|
||||||
|
|
||||||
:link_to_translation:`zh_CN:[中文]`
|
:link_to_translation:`zh_CN:[中文]`
|
||||||
|
|
||||||
@ -169,7 +169,7 @@ The source clock can also limit the PWM frequency. The higher the source clock f
|
|||||||
- 48 MHz
|
- 48 MHz
|
||||||
- Dynamic Frequency Scaling compatible
|
- Dynamic Frequency Scaling compatible
|
||||||
|
|
||||||
.. only:: esp32c6
|
.. only:: esp32c6 or esp32c61 or esp32p4
|
||||||
|
|
||||||
.. list-table:: Characteristics of {IDF_TARGET_NAME} LEDC source clocks
|
.. list-table:: Characteristics of {IDF_TARGET_NAME} LEDC source clocks
|
||||||
:widths: 15 15 30
|
:widths: 15 15 30
|
||||||
@ -188,25 +188,6 @@ The source clock can also limit the PWM frequency. The higher the source clock f
|
|||||||
- 40 MHz
|
- 40 MHz
|
||||||
- Dynamic Frequency Scaling compatible
|
- Dynamic Frequency Scaling compatible
|
||||||
|
|
||||||
.. only:: esp32p4
|
|
||||||
|
|
||||||
.. list-table:: Characteristics of {IDF_TARGET_NAME} LEDC source clocks
|
|
||||||
:widths: 15 15 30
|
|
||||||
:header-rows: 1
|
|
||||||
|
|
||||||
* - Clock name
|
|
||||||
- Clock freq
|
|
||||||
- Clock capabilities
|
|
||||||
* - PLL_80M_CLK
|
|
||||||
- 80 MHz
|
|
||||||
- /
|
|
||||||
* - RC_FAST_CLK
|
|
||||||
- ~ 20 MHz
|
|
||||||
- Dynamic Frequency Scaling compatible, Light sleep compatible
|
|
||||||
* - XTAL_CLK
|
|
||||||
- 40 MHz
|
|
||||||
- Dynamic Frequency Scaling compatible
|
|
||||||
|
|
||||||
.. only:: esp32h2
|
.. only:: esp32h2
|
||||||
|
|
||||||
.. list-table:: Characteristics of {IDF_TARGET_NAME} LEDC source clocks
|
.. list-table:: Characteristics of {IDF_TARGET_NAME} LEDC source clocks
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
LED PWM 控制器
|
LED PWM 控制器
|
||||||
==============
|
==============
|
||||||
|
|
||||||
{IDF_TARGET_LEDC_MAX_FADE_RANGE_NUM: default="1", esp32c6="16", esp32h2="16", esp32p4="16", esp32c5="16"}
|
{IDF_TARGET_LEDC_MAX_FADE_RANGE_NUM: default="1", esp32c6="16", esp32h2="16", esp32p4="16", esp32c5="16", esp32c61="16"}
|
||||||
|
|
||||||
:link_to_translation:`en:[English]`
|
:link_to_translation:`en:[English]`
|
||||||
|
|
||||||
@ -169,7 +169,7 @@ LED PWM 控制器可在无需 CPU 干预的情况下自动改变占空比,实
|
|||||||
- 48 MHz
|
- 48 MHz
|
||||||
- 支持动态调频 (DFS) 功能
|
- 支持动态调频 (DFS) 功能
|
||||||
|
|
||||||
.. only:: esp32c6
|
.. only:: esp32c6 or esp32c61 or esp32p4
|
||||||
|
|
||||||
.. list-table:: {IDF_TARGET_NAME} LEDC 时钟源特性
|
.. list-table:: {IDF_TARGET_NAME} LEDC 时钟源特性
|
||||||
:widths: 10 10 30
|
:widths: 10 10 30
|
||||||
@ -188,25 +188,6 @@ LED PWM 控制器可在无需 CPU 干预的情况下自动改变占空比,实
|
|||||||
- 40 MHz
|
- 40 MHz
|
||||||
- 支持动态调频 (DFS) 功能
|
- 支持动态调频 (DFS) 功能
|
||||||
|
|
||||||
.. only:: esp32p4
|
|
||||||
|
|
||||||
.. list-table:: {IDF_TARGET_NAME} LEDC 时钟源特性
|
|
||||||
:widths: 10 10 30
|
|
||||||
:header-rows: 1
|
|
||||||
|
|
||||||
* - 时钟名称
|
|
||||||
- 时钟频率
|
|
||||||
- 时钟功能
|
|
||||||
* - PLL_80M_CLK
|
|
||||||
- 80 MHz
|
|
||||||
- /
|
|
||||||
* - RC_FAST_CLK
|
|
||||||
- ~ 20 MHz
|
|
||||||
- 支持动态调频 (DFS) 功能,支持 Light-sleep 模式
|
|
||||||
* - XTAL_CLK
|
|
||||||
- 40 MHz
|
|
||||||
- 支持动态调频 (DFS) 功能
|
|
||||||
|
|
||||||
.. only:: esp32h2
|
.. only:: esp32h2
|
||||||
|
|
||||||
.. list-table:: {IDF_TARGET_NAME} LEDC 时钟源特性
|
.. list-table:: {IDF_TARGET_NAME} LEDC 时钟源特性
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
| Supported Targets | ESP32 | ESP32-C2 | ESP32-C3 | ESP32-C5 | ESP32-C6 | ESP32-H2 | ESP32-P4 | ESP32-S2 | ESP32-S3 |
|
| Supported Targets | ESP32 | ESP32-C2 | ESP32-C3 | ESP32-C5 | ESP32-C6 | ESP32-C61 | ESP32-H2 | ESP32-P4 | ESP32-S2 | ESP32-S3 |
|
||||||
| ----------------- | ----- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- |
|
| ----------------- | ----- | -------- | -------- | -------- | -------- | --------- | -------- | -------- | -------- | -------- |
|
||||||
|
|
||||||
# _LEDC Basic Example_
|
# _LEDC Basic Example_
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
| Supported Targets | ESP32 | ESP32-C2 | ESP32-C3 | ESP32-C5 | ESP32-C6 | ESP32-H2 | ESP32-P4 | ESP32-S2 | ESP32-S3 |
|
| Supported Targets | ESP32 | ESP32-C2 | ESP32-C3 | ESP32-C5 | ESP32-C6 | ESP32-C61 | ESP32-H2 | ESP32-P4 | ESP32-S2 | ESP32-S3 |
|
||||||
| ----------------- | ----- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- |
|
| ----------------- | ----- | -------- | -------- | -------- | -------- | --------- | -------- | -------- | -------- | -------- |
|
||||||
|
|
||||||
# _LEDC Fade Example_
|
# _LEDC Fade Example_
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
| Supported Targets | ESP32-C5 | ESP32-C6 | ESP32-H2 | ESP32-P4 |
|
| Supported Targets | ESP32-C5 | ESP32-C6 | ESP32-C61 | ESP32-H2 | ESP32-P4 |
|
||||||
| ----------------- | -------- | -------- | -------- | -------- |
|
| ----------------- | -------- | -------- | --------- | -------- | -------- |
|
||||||
|
|
||||||
# _LEDC Gamma Curve Fade Example_
|
# _LEDC Gamma Curve Fade Example_
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user