sleep_gpio.c 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. /*
  2. * SPDX-FileCopyrightText: 2015-2021 Espressif Systems (Shanghai) CO LTD
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #include <stddef.h>
  7. #include <string.h>
  8. #include <sys/lock.h>
  9. #include <sys/param.h>
  10. #include "esp_attr.h"
  11. #include "esp_sleep.h"
  12. #include "esp_log.h"
  13. #include "soc/soc_caps.h"
  14. #include "sdkconfig.h"
  15. #include "driver/gpio.h"
  16. #include "esp_private/gpio.h"
  17. #include "esp_private/sleep_gpio.h"
  18. #include "bootloader_common.h"
  19. #ifdef CONFIG_IDF_TARGET_ESP32
  20. #include "esp32/spiram.h"
  21. #elif CONFIG_IDF_TARGET_ESP32S2
  22. #include "esp32s2/spiram.h"
  23. #elif CONFIG_IDF_TARGET_ESP32S3
  24. #include "esp32s3/spiram.h"
  25. #endif
  26. static const char *TAG = "sleep";
  27. #if SOC_GPIO_SUPPORT_SLP_SWITCH
  28. #if CONFIG_GPIO_ESP32_SUPPORT_SWITCH_SLP_PULL
  29. void gpio_sleep_mode_config_apply(void)
  30. {
  31. for (gpio_num_t gpio_num = GPIO_NUM_0; gpio_num < GPIO_NUM_MAX; gpio_num++) {
  32. if (GPIO_IS_VALID_GPIO(gpio_num)) {
  33. gpio_sleep_pupd_config_apply(gpio_num);
  34. }
  35. }
  36. }
  37. IRAM_ATTR void gpio_sleep_mode_config_unapply(void)
  38. {
  39. for (gpio_num_t gpio_num = GPIO_NUM_0; gpio_num < GPIO_NUM_MAX; gpio_num++) {
  40. if (GPIO_IS_VALID_GPIO(gpio_num)) {
  41. gpio_sleep_pupd_config_unapply(gpio_num);
  42. }
  43. }
  44. }
  45. #endif
  46. void esp_sleep_config_gpio_isolate(void)
  47. {
  48. ESP_LOGI(TAG, "Configure to isolate all GPIO pins in sleep state");
  49. for (gpio_num_t gpio_num = GPIO_NUM_0; gpio_num < GPIO_NUM_MAX; gpio_num++) {
  50. if (GPIO_IS_VALID_GPIO(gpio_num)) {
  51. gpio_sleep_set_direction(gpio_num, GPIO_MODE_DISABLE);
  52. gpio_sleep_set_pull_mode(gpio_num, GPIO_FLOATING);
  53. }
  54. }
  55. #if CONFIG_ESP_SLEEP_PSRAM_LEAKAGE_WORKAROUND && CONFIG_SPIRAM
  56. gpio_sleep_set_pull_mode(esp_spiram_get_cs_io(), GPIO_PULLUP_ONLY);
  57. #endif
  58. #if CONFIG_ESP_SLEEP_FLASH_LEAKAGE_WORKAROUND
  59. gpio_sleep_set_pull_mode(bootloader_flash_get_cs_io(), GPIO_PULLUP_ONLY);
  60. #endif
  61. }
  62. void esp_sleep_enable_gpio_switch(bool enable)
  63. {
  64. ESP_LOGI(TAG, "%s automatic switching of GPIO sleep configuration", enable ? "Enable" : "Disable");
  65. for (gpio_num_t gpio_num = GPIO_NUM_0; gpio_num < GPIO_NUM_MAX; gpio_num++) {
  66. if (GPIO_IS_VALID_GPIO(gpio_num)) {
  67. if (enable) {
  68. gpio_sleep_sel_en(gpio_num);
  69. } else {
  70. gpio_sleep_sel_dis(gpio_num);
  71. }
  72. }
  73. }
  74. }
  75. #endif // SOC_GPIO_SUPPORT_SLP_SWITCH