mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-10-26 03:37:51 +00:00 
			
		
		
		
	esp_system: add VDD_SDIO power domain configuration for light sleep
VDD_SDIO power domain can now be configured for light sleep by the application. It is now possible to keep the power domain ON during light sleep, keeping the GPIOs connected to it powered. The power domain will, by default be: - Kept ON if CONFIG_ESP_SYSTEM_PD_FLASH is not set - Turned OFF if not set The application can still force it to be ON by calling `esp_sleep_pd_config(ESP_PD_DOMAIN_VDDSDIO, ESP_PD_OPTION_ON);`
This commit is contained in:
		| @@ -50,6 +50,7 @@ typedef enum { | |||||||
|     ESP_PD_DOMAIN_RTC_FAST_MEM,    //!< RTC fast memory |     ESP_PD_DOMAIN_RTC_FAST_MEM,    //!< RTC fast memory | ||||||
|     ESP_PD_DOMAIN_XTAL,            //!< XTAL oscillator |     ESP_PD_DOMAIN_XTAL,            //!< XTAL oscillator | ||||||
|     ESP_PD_DOMAIN_CPU,             //!< CPU core |     ESP_PD_DOMAIN_CPU,             //!< CPU core | ||||||
|  |     ESP_PD_DOMAIN_VDDSDIO,         //!< VDD_SDIO | ||||||
|     ESP_PD_DOMAIN_MAX              //!< Number of domains |     ESP_PD_DOMAIN_MAX              //!< Number of domains | ||||||
| } esp_sleep_pd_domain_t; | } esp_sleep_pd_domain_t; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -151,7 +151,7 @@ typedef struct { | |||||||
| } sleep_config_t; | } sleep_config_t; | ||||||
|  |  | ||||||
| static sleep_config_t s_config = { | static sleep_config_t s_config = { | ||||||
|     .pd_options = { ESP_PD_OPTION_AUTO, ESP_PD_OPTION_AUTO, ESP_PD_OPTION_AUTO, ESP_PD_OPTION_AUTO, ESP_PD_OPTION_AUTO }, |     .pd_options = { ESP_PD_OPTION_AUTO, ESP_PD_OPTION_AUTO, ESP_PD_OPTION_AUTO, ESP_PD_OPTION_AUTO, ESP_PD_OPTION_AUTO, ESP_PD_OPTION_AUTO }, | ||||||
|     .ccount_ticks_record = 0, |     .ccount_ticks_record = 0, | ||||||
|     .sleep_time_overhead_out = DEFAULT_SLEEP_OUT_OVERHEAD_US, |     .sleep_time_overhead_out = DEFAULT_SLEEP_OUT_OVERHEAD_US, | ||||||
|     .wakeup_triggers = 0 |     .wakeup_triggers = 0 | ||||||
| @@ -715,9 +715,13 @@ esp_err_t esp_light_sleep_start(void) | |||||||
|     // If it needs to be powered down, adjust sleep time. |     // If it needs to be powered down, adjust sleep time. | ||||||
|     const uint32_t flash_enable_time_us = VDD_SDIO_POWERUP_TO_FLASH_READ_US + DEEP_SLEEP_WAKEUP_DELAY; |     const uint32_t flash_enable_time_us = VDD_SDIO_POWERUP_TO_FLASH_READ_US + DEEP_SLEEP_WAKEUP_DELAY; | ||||||
|  |  | ||||||
| #if CONFIG_ESP_SYSTEM_PD_FLASH |     /** | ||||||
|  |      * If VDD_SDIO power domain is requested to be turned off, bit `RTC_SLEEP_PD_VDDSDIO` | ||||||
|  |      * will be set in `pd_flags`. | ||||||
|  |      */ | ||||||
|  |     if ((pd_flags & RTC_SLEEP_PD_VDDSDIO) != 0) { | ||||||
|         /* |         /* | ||||||
|      * When SPIRAM is disabled in menuconfig, the minimum sleep time of the |         * When VDD_SDIO power domain has to be turned off, the minimum sleep time of the | ||||||
|         * system needs to meet the sum below: |         * system needs to meet the sum below: | ||||||
|         * 1. Wait time for the flash power-on after waking up; |         * 1. Wait time for the flash power-on after waking up; | ||||||
|         * 2. The execution time of codes between RTC Timer get start time |         * 2. The execution time of codes between RTC Timer get start time | ||||||
| @@ -734,16 +738,20 @@ esp_err_t esp_light_sleep_start(void) | |||||||
|                         + rtc_time_slowclk_to_us(RTC_MODULE_SLEEP_PREPARE_CYCLES, s_config.rtc_clk_cal_period)); |                         + rtc_time_slowclk_to_us(RTC_MODULE_SLEEP_PREPARE_CYCLES, s_config.rtc_clk_cal_period)); | ||||||
|  |  | ||||||
|         if (s_config.sleep_duration > vddsdio_pd_sleep_duration) { |         if (s_config.sleep_duration > vddsdio_pd_sleep_duration) { | ||||||
|         pd_flags |= RTC_SLEEP_PD_VDDSDIO; |  | ||||||
|             if (s_config.sleep_time_overhead_out < flash_enable_time_us) { |             if (s_config.sleep_time_overhead_out < flash_enable_time_us) { | ||||||
|                 s_config.sleep_time_adjustment += flash_enable_time_us; |                 s_config.sleep_time_adjustment += flash_enable_time_us; | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|  |             /** | ||||||
|  |              * Minimum sleep time is not enough, then keep the VDD_SDIO power | ||||||
|  |              * domain on. | ||||||
|  |              */ | ||||||
|  |             pd_flags &= ~RTC_SLEEP_PD_VDDSDIO; | ||||||
|             if (s_config.sleep_time_overhead_out > flash_enable_time_us) { |             if (s_config.sleep_time_overhead_out > flash_enable_time_us) { | ||||||
|                 s_config.sleep_time_adjustment -= flash_enable_time_us; |                 s_config.sleep_time_adjustment -= flash_enable_time_us; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| #endif //CONFIG_ESP_SYSTEM_PD_FLASH |     } | ||||||
|  |  | ||||||
|     periph_inform_out_light_sleep_overhead(s_config.sleep_time_adjustment - sleep_time_overhead_in); |     periph_inform_out_light_sleep_overhead(s_config.sleep_time_adjustment - sleep_time_overhead_in); | ||||||
|  |  | ||||||
| @@ -1316,6 +1324,27 @@ static uint32_t get_power_down_flags(void) | |||||||
|     pd_flags |= RTC_SLEEP_PD_XTAL; |     pd_flags |= RTC_SLEEP_PD_XTAL; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * VDD_SDIO power domain shall be kept on during the light sleep | ||||||
|  |      * when CONFIG_ESP_SYSTEM_PD_FLASH is not set and off when it is set. | ||||||
|  |      * The application can still force the power domain to remain on by calling | ||||||
|  |      * `esp_sleep_pd_config` before getting into light sleep mode. | ||||||
|  |      * | ||||||
|  |      * In deep sleep mode, the power domain will be turned off, regardless the | ||||||
|  |      * value of this field. | ||||||
|  |      */ | ||||||
|  |     if (s_config.pd_options[ESP_PD_DOMAIN_VDDSDIO] == ESP_PD_OPTION_AUTO) { | ||||||
|  | #ifdef CONFIG_ESP_SYSTEM_PD_FLASH | ||||||
|  |         s_config.pd_options[ESP_PD_DOMAIN_VDDSDIO] = ESP_PD_OPTION_OFF; | ||||||
|  | #else | ||||||
|  |         s_config.pd_options[ESP_PD_DOMAIN_VDDSDIO] = ESP_PD_OPTION_ON; | ||||||
|  | #endif | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (s_config.pd_options[ESP_PD_DOMAIN_VDDSDIO] != ESP_PD_OPTION_ON) { | ||||||
|  |         pd_flags |= RTC_SLEEP_PD_VDDSDIO; | ||||||
|  |     } | ||||||
|  |  | ||||||
| #if ((defined CONFIG_ESP32_RTC_CLK_SRC_EXT_CRYS) && (defined CONFIG_ESP32_RTC_EXT_CRYST_ADDIT_CURRENT)) | #if ((defined CONFIG_ESP32_RTC_CLK_SRC_EXT_CRYS) && (defined CONFIG_ESP32_RTC_EXT_CRYST_ADDIT_CURRENT)) | ||||||
|     if ((s_config.wakeup_triggers & (RTC_TOUCH_TRIG_EN | RTC_ULP_TRIG_EN)) == 0) { |     if ((s_config.wakeup_triggers & (RTC_TOUCH_TRIG_EN | RTC_ULP_TRIG_EN)) == 0) { | ||||||
|     // If enabled EXT1 only and enable the additional current by touch, should be keep RTC_PERIPH power on. |     // If enabled EXT1 only and enable the additional current by touch, should be keep RTC_PERIPH power on. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Omar Chebib
					Omar Chebib