gpio.rst 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. GPIO & RTC GPIO
  2. ===============
  3. :link_to_translation:`en:[English]`
  4. GPIO 汇总
  5. ---------
  6. .. include:: gpio/{IDF_TARGET_PATH_NAME}.inc
  7. :start-after: gpio-summary
  8. :end-before: ---
  9. GPIO 驱动提供了一个函数 :cpp:func:`gpio_dump_io_configuration` 用来输出指定管脚的实时配置状态,包括上下拉、输入输出使能、管脚映射等。输出示例如下:
  10. ::
  11. ================IO DUMP Start================
  12. IO[4] -
  13. Pullup: 1, Pulldown: 0, DriveCap: 2
  14. InputEn: 1, OutputEn: 0, OpenDrain: 0
  15. FuncSel: 1 (GPIO)
  16. GPIO Matrix SigIn ID: (simple GPIO input)
  17. SleepSelEn: 1
  18. IO[18] -
  19. Pullup: 0, Pulldown: 0, DriveCap: 2
  20. InputEn: 0, OutputEn: 1, OpenDrain: 0
  21. FuncSel: 1 (GPIO)
  22. GPIO Matrix SigOut ID: 256 (simple GPIO output)
  23. SleepSelEn: 1
  24. IO[26] **RESERVED** -
  25. Pullup: 1, Pulldown: 0, DriveCap: 2
  26. InputEn: 1, OutputEn: 0, OpenDrain: 0
  27. FuncSel: 0 (IOMUX)
  28. SleepSelEn: 1
  29. =================IO DUMP End==================
  30. 当 IO 管脚是通过 GPIO 交换矩阵连接到内部外设信号,输出信息打印中的外设信号 ID 定义可以在 ``soc/gpio_sig_map.h`` 文件中查看。``**RESERVED**`` 字样则表示此 IO 被用于连接 FLASH 或 PSRAM,因此该引脚不应该被其他任何应用场景所征用并进行重新配置。
  31. .. only:: SOC_RTCIO_INPUT_OUTPUT_SUPPORTED
  32. .. only:: not SOC_LP_PERIPHERALS_SUPPORTED
  33. 当 GPIO 连接到 RTC 低功耗和模拟子系统时,{IDF_TARGET_NAME} 芯片还单独支持 RTC GPIO。可在以下情况时使用这些管脚功能:
  34. .. only:: SOC_LP_PERIPHERALS_SUPPORTED
  35. 当 GPIO 连接到 RTC 低功耗、模拟子系统、低功耗外设时,{IDF_TARGET_NAME} 芯片还单独支持 RTC GPIO。可在以下情况时使用这些管脚功能:
  36. .. list::
  37. - 处于 Deep-sleep 模式时
  38. :SOC_ULP_SUPPORTED and not esp32c6: - :doc:`超低功耗协处理器 (ULP) <../../api-reference/system/ulp>` 运行时
  39. - 使用 ADC/DAC 等模拟功能时
  40. :SOC_LP_PERIPHERALS_SUPPORTED: - 使用低功耗外设时,例如: LP_UART , LP_I2C 等
  41. .. only:: SOC_GPIO_SUPPORT_PIN_GLITCH_FILTER or SOC_GPIO_FLEX_GLITCH_FILTER_NUM
  42. GPIO 毛刺过滤器
  43. ---------------
  44. {IDF_TARGET_NAME} 内置硬件的过滤器可以过滤掉 GPIO 输入端口上的毛刺信号,在一定程度上避免错误触发中断或者是错把噪声当成有效的外设信号。
  45. .. only:: SOC_GPIO_SUPPORT_PIN_GLITCH_FILTER
  46. 每个 GPIO 都可以使用独立的毛刺过滤器,该过滤器可以将那些脉冲宽度窄于 **2** 个采样时钟的信号剔除掉,该宽度无法配置。GPIO 对输入信号的采样时钟通常是 IO_MUX 的时钟源。在驱动中,此类过滤器称为 ``管脚毛刺过滤器``。可以调用 :cpp:func:`gpio_new_pin_glitch_filter` 函数创建一个过滤器句柄。过滤器的相关配置保存在 :cpp:type:`gpio_pin_glitch_filter_config_t` 结构体中。
  47. - :cpp:member:`gpio_pin_glitch_filter_config_t::gpio_num` 设置启用毛刺过滤器的 GPIO 编号。
  48. .. only:: SOC_GPIO_FLEX_GLITCH_FILTER_NUM
  49. {IDF_TARGET_FLEX_GLITCH_FILTER_NUM:default="8"}
  50. {IDF_TARGET_NAME} 提供了 {IDF_TARGET_FLEX_GLITCH_FILTER_NUM} 个灵活的毛刺过滤器,被过滤信号的脉冲宽度可以由软件进行配置。此类过滤器则称为 ``灵活毛刺过滤器``。每个过滤器都可以应用于任意 GPIO 输入,然而,将多个过滤器应用于同一 GPIO 上效果并不会叠加。可以调用 :cpp:func:`gpio_new_flex_glitch_filter` 函数来创建一个过滤器句柄。过滤器的相关配置保存在 :cpp:type:`gpio_flex_glitch_filter_config_t` 结构体中。
  51. - :cpp:member:`gpio_flex_glitch_filter_config_t::gpio_num` 设置启用毛刺过滤器的 GPIO 编号。
  52. - :cpp:member:`gpio_flex_glitch_filter_config_t::window_width_ns` 和 :cpp:member:`gpio_flex_glitch_filter_config_t::window_thres_ns` 是毛刺过滤器的关键参数。在:cpp:member:`gpio_flex_glitch_filter_config_t::window_width_ns` 时间内,任何脉冲信号,如果它的宽度小于 :cpp:member:`gpio_flex_glitch_filter_config_t::window_thres_ns` ,那么该脉冲信号就会被滤除掉。:cpp:member:`gpio_flex_glitch_filter_config_t::window_thres_ns` 的值不能大于 :cpp:member:`gpio_flex_glitch_filter_config_t::window_width_ns`。
  53. .. only:: SOC_GPIO_SUPPORT_PIN_GLITCH_FILTER and SOC_GPIO_FLEX_GLITCH_FILTER_NUM
  54. 请注意,``管脚毛刺过滤器`` 和 ``灵活毛刺过滤器`` 是各自独立的,支持为同一 GPIO 同时启用这两种过滤器。
  55. 毛刺过滤器默认关闭,可调用 :cpp:func:`gpio_glitch_filter_enable` 使能过滤器。如需回收这个过滤器,可以调用 :cpp:func:`gpio_del_glitch_filter` 函数。在回收句柄前,请确保过滤器处于关闭状态,否则需调用 :cpp:func:`gpio_glitch_filter_disable`。
  56. .. only:: SOC_GPIO_SUPPORT_PIN_HYS_FILTER
  57. GPIO 迟滞过滤器
  58. ---------------
  59. {IDF_TARGET_NAME} 支持输入引脚的硬件迟滞,这可以减少由于输入电压在逻辑 0、1 临界值附近时采样不稳定造成的 GPIO 中断误触,尤其是当输入逻辑电平转换较慢,电平建立时间较长时。
  60. .. only:: SOC_GPIO_SUPPORT_PIN_HYS_CTRL_BY_EFUSE
  61. 每个引脚可以独立启用迟滞功能。默认情况下,它由 eFuse 控制,且处于关闭状态,但也可以由软件控制启用或禁用。你可以通过配置 :cpp:member:`gpio_config_t::hys_ctrl_mode` 来选择迟滞控制模式。迟滞控制模式会和其余 GPIO 配置一起在 :cpp:func:`gpio_config` 中生效。
  62. .. note::
  63. 当迟滞功能由 eFuse 控制时,仍然可以独立的控制每个引脚的该功能,你需要 `烧断 eFuse <https://docs.espressif.com/projects/esptool/en/latest/esp32/espefuse/index.html>`_ ,以在特定 GPIO 上启用迟滞功能。
  64. .. only:: not SOC_GPIO_SUPPORT_PIN_HYS_CTRL_BY_EFUSE
  65. 每个引脚可以独立启用迟滞功能。默认情况下,它处于关闭状态。你可以通过配置 :cpp:member:`gpio_config_t::hys_ctrl_mode` 来选择启用与否。迟滞控制模式会和其余 GPIO 配置一起在 :cpp:func:`gpio_config` 中生效。
  66. 应用示例
  67. -------------------
  68. * GPIO 输出和输入中断示例::example:`peripherals/gpio/generic_gpio`。
  69. API 参考 - 普通 GPIO
  70. ---------------------------
  71. .. include-build-file:: inc/gpio.inc
  72. .. include-build-file:: inc/gpio_types.inc
  73. .. only:: SOC_RTCIO_INPUT_OUTPUT_SUPPORTED
  74. API 参考 - RTC GPIO
  75. ------------------------
  76. .. include-build-file:: inc/rtc_io.inc
  77. .. include-build-file:: inc/lp_io.inc
  78. .. include-build-file:: inc/rtc_io_types.inc
  79. .. only:: SOC_GPIO_SUPPORT_PIN_GLITCH_FILTER or SOC_GPIO_FLEX_GLITCH_FILTER_NUM
  80. API 参考 - GPIO 毛刺过滤器
  81. --------------------------
  82. .. include-build-file:: inc/gpio_filter.inc