diff --git a/components/driver/gpio.c b/components/driver/gpio.c index ec9294d6a3..3054bdaf96 100644 --- a/components/driver/gpio.c +++ b/components/driver/gpio.c @@ -585,6 +585,9 @@ esp_err_t gpio_wakeup_disable(gpio_num_t gpio_num) #endif portENTER_CRITICAL(&gpio_context.gpio_spinlock); gpio_hal_wakeup_disable(gpio_context.gpio_hal, gpio_num); +#if SOC_GPIO_SUPPORT_SLP_SWITCH && CONFIG_ESP32C3_LIGHTSLEEP_GPIO_RESET_WORKAROUND + gpio_hal_sleep_sel_en(gpio_context.gpio_hal, gpio_num); +#endif portEXIT_CRITICAL(&gpio_context.gpio_spinlock); return ret; } @@ -907,6 +910,9 @@ esp_err_t gpio_deep_sleep_wakeup_enable(gpio_num_t gpio_num, gpio_int_type_t int } portENTER_CRITICAL(&gpio_context.gpio_spinlock); gpio_hal_deepsleep_wakeup_enable(gpio_context.gpio_hal, gpio_num, intr_type); +#if SOC_GPIO_SUPPORT_SLP_SWITCH && CONFIG_ESP32C3_LIGHTSLEEP_GPIO_RESET_WORKAROUND + gpio_hal_sleep_sel_dis(gpio_context.gpio_hal, gpio_num); +#endif portEXIT_CRITICAL(&gpio_context.gpio_spinlock); return ESP_OK; } @@ -919,6 +925,9 @@ esp_err_t gpio_deep_sleep_wakeup_disable(gpio_num_t gpio_num) } portENTER_CRITICAL(&gpio_context.gpio_spinlock); gpio_hal_deepsleep_wakeup_disable(gpio_context.gpio_hal, gpio_num); +#if SOC_GPIO_SUPPORT_SLP_SWITCH && CONFIG_ESP32C3_LIGHTSLEEP_GPIO_RESET_WORKAROUND + gpio_hal_sleep_sel_en(gpio_context.gpio_hal, gpio_num); +#endif portEXIT_CRITICAL(&gpio_context.gpio_spinlock); return ESP_OK; }