mirror of
https://github.com/espressif/esp-idf.git
synced 2025-09-02 14:49:04 +00:00
fix(ledc): left-off gamma ram registers should be cleared
Hardware reads in (range_number+1) fade parameter registers, which could cause output waveform error.
This commit is contained in:
@@ -1,11 +1,11 @@
|
||||
/*
|
||||
* SPDX-FileCopyrightText: 2019-2022 Espressif Systems (Shanghai) CO LTD
|
||||
* SPDX-FileCopyrightText: 2019-2025 Espressif Systems (Shanghai) CO LTD
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
// The HAL layer for LEDC (common part, in iram)
|
||||
// make these functions in a seperate file to make sure all LL functions are in the IRAM.
|
||||
// make these functions in a separate file to make sure all LL functions are in the IRAM.
|
||||
|
||||
#include "esp_attr.h"
|
||||
#include "hal/ledc_hal.h"
|
||||
@@ -70,6 +70,17 @@ void ledc_hal_get_range_number(ledc_hal_context_t *hal, ledc_channel_t channel_n
|
||||
{
|
||||
ledc_ll_get_range_number(hal->dev, hal->speed_mode, channel_num, range_num);
|
||||
}
|
||||
|
||||
void ledc_hal_clear_left_off_fade_param(ledc_hal_context_t *hal, ledc_channel_t channel_num, uint32_t start_range)
|
||||
{
|
||||
for (int i = start_range; i < SOC_LEDC_GAMMA_CURVE_FADE_RANGE_MAX; i++) {
|
||||
ledc_ll_set_duty_direction(hal->dev, hal->speed_mode, channel_num, 0);
|
||||
ledc_ll_set_duty_cycle(hal->dev, hal->speed_mode, channel_num, 0);
|
||||
ledc_ll_set_duty_scale(hal->dev, hal->speed_mode, channel_num, 0);
|
||||
ledc_ll_set_duty_num(hal->dev, hal->speed_mode, channel_num, 0);
|
||||
ledc_ll_set_duty_range_wr_addr(hal->dev, hal->speed_mode, channel_num, i);
|
||||
}
|
||||
}
|
||||
#endif //SOC_LEDC_GAMMA_CURVE_FADE_SUPPORTED
|
||||
|
||||
void ledc_hal_get_fade_end_intr_status(ledc_hal_context_t *hal, uint32_t *intr_status)
|
||||
|
Reference in New Issue
Block a user