From 11fac8637a3429dcfdf9e10aef6281a21ac96e3c Mon Sep 17 00:00:00 2001 From: Angus Gratton Date: Wed, 29 Jan 2020 09:31:14 +1100 Subject: [PATCH] docs: Resolve doxygen & Sphinx warnings --- .../bt/esp_ble_mesh/api/esp_ble_mesh_defs.h | 12 +- .../bluedroid/api/include/api/esp_a2dp_api.h | 11 +- .../bluedroid/api/include/api/esp_bt_defs.h | 6 +- .../driver/esp32s2/include/touch_sensor.h | 27 ++-- components/driver/include/driver/timer.h | 12 -- components/esp32/include/esp_intr_alloc.h | 12 +- components/esp32s2/include/esp_intr_alloc.h | 12 +- components/esp_event/include/esp_event.h | 1 + .../common/include/esp_modbus_common.h | 2 +- components/soc/include/hal/i2c_types.h | 4 +- .../soc/include/hal/touch_sensor_types.h | 19 ++- components/soc/include/hal/uart_types.h | 2 +- components/vfs/include/esp_vfs.h | 132 +++++++++--------- docs/build_docs.py | 15 +- docs/conf_common.py | 16 ++- docs/doxygen-known-warnings.txt | 1 + docs/en/api-guides/fatal-errors.rst | 4 +- docs/en/api-guides/freertos-smp.rst | 2 +- docs/en/api-guides/lwip.rst | 10 +- docs/en/api-reference/peripherals/adc.rst | 2 +- .../peripherals/esp_slave_protocol.rst | 6 - docs/en/api-reference/peripherals/index.rst | 10 +- .../api-reference/peripherals/sdio_slave.rst | 8 -- .../api-reference/peripherals/sdmmc_host.rst | 89 ++++++------ .../api-reference/peripherals/sdspi_host.rst | 6 +- .../api-reference/peripherals/temp_sensor.rst | 41 +++--- docs/en/api-reference/storage/sdmmc.rst | 85 +++++------ docs/en/api-reference/system/system_time.rst | 6 +- docs/sphinx-known-warnings.txt | 6 + docs/zh_CN/api-guides/unit-tests-legacy.rst | 10 +- docs/zh_CN/api-guides/unit-tests.rst | 6 +- docs/zh_CN/api-reference/network/esp_mesh.rst | 2 +- docs/zh_CN/api-reference/network/esp_now.rst | 2 +- .../zh_CN/api-reference/peripherals/index.rst | 8 +- docs/zh_CN/api-reference/peripherals/ledc.rst | 3 +- .../api-reference/peripherals/touch_pad.rst | 3 +- docs/zh_CN/api-reference/protocols/index.rst | 2 +- docs/zh_CN/api-reference/storage/sdmmc.rst | 8 +- 38 files changed, 321 insertions(+), 282 deletions(-) diff --git a/components/bt/esp_ble_mesh/api/esp_ble_mesh_defs.h b/components/bt/esp_ble_mesh/api/esp_ble_mesh_defs.h index 733c718aa6cb..486a3a8a82a0 100644 --- a/components/bt/esp_ble_mesh/api/esp_ble_mesh_defs.h +++ b/components/bt/esp_ble_mesh/api/esp_ble_mesh_defs.h @@ -439,11 +439,11 @@ typedef struct { struct esp_ble_mesh_model { /** Model ID */ union { - const uint16_t model_id; - struct { - uint16_t company_id; - uint16_t model_id; - } vnd; + const uint16_t model_id; /*!< 16-bit model identifier */ + struct esp_ble_mesh_vnd_struct { + uint16_t company_id; /*!< 16-bit company identifier */ + uint16_t model_id; /*!< 16-bit model identifier */ + } vnd; /*!< Structure encapsulating a model ID with a company ID */ }; /** Internal information, mainly for persistent storage */ @@ -656,7 +656,7 @@ typedef struct { typedef struct { union { struct { - esp_ble_mesh_bd_addr_t addr; /*!< Device address */ + esp_ble_mesh_bd_addr_t addr; /*!< Device address */ esp_ble_mesh_addr_type_t addr_type; /*!< Device address type */ }; uint8_t uuid[16]; /*!< Device UUID */ diff --git a/components/bt/host/bluedroid/api/include/api/esp_a2dp_api.h b/components/bt/host/bluedroid/api/include/api/esp_a2dp_api.h index 3b002a405fba..903b17c32b17 100644 --- a/components/bt/host/bluedroid/api/include/api/esp_a2dp_api.h +++ b/components/bt/host/bluedroid/api/include/api/esp_a2dp_api.h @@ -31,7 +31,8 @@ extern "C" { typedef uint8_t esp_a2d_mct_t; -/// A2DP media codec capabilities union +/** A2DP media codec capabilities union + */ typedef struct { esp_a2d_mct_t type; /*!< A2DP media codec type */ #define ESP_A2D_CIE_LEN_SBC (4) @@ -39,10 +40,10 @@ typedef struct { #define ESP_A2D_CIE_LEN_M24 (6) #define ESP_A2D_CIE_LEN_ATRAC (7) union { - uint8_t sbc[ESP_A2D_CIE_LEN_SBC]; - uint8_t m12[ESP_A2D_CIE_LEN_M12]; - uint8_t m24[ESP_A2D_CIE_LEN_M24]; - uint8_t atrac[ESP_A2D_CIE_LEN_ATRAC]; + uint8_t sbc[ESP_A2D_CIE_LEN_SBC]; /*!< SBC codec capabilities */ + uint8_t m12[ESP_A2D_CIE_LEN_M12]; /*!< MPEG-1,2 audio codec capabilities */ + uint8_t m24[ESP_A2D_CIE_LEN_M24]; /*!< MPEG-2, 4 AAC audio codec capabilities */ + uint8_t atrac[ESP_A2D_CIE_LEN_ATRAC]; /*!< ATRAC family codec capabilities */ } cie; /*!< A2DP codec information element */ } __attribute__((packed)) esp_a2d_mcc_t; diff --git a/components/bt/host/bluedroid/api/include/api/esp_bt_defs.h b/components/bt/host/bluedroid/api/include/api/esp_bt_defs.h index 51044d45c7a9..906dbd3e78d9 100644 --- a/components/bt/host/bluedroid/api/include/api/esp_bt_defs.h +++ b/components/bt/host/bluedroid/api/include/api/esp_bt_defs.h @@ -86,9 +86,9 @@ typedef struct { #define ESP_UUID_LEN_128 16 uint16_t len; /*!< UUID length, 16bit, 32bit or 128bit */ union { - uint16_t uuid16; - uint32_t uuid32; - uint8_t uuid128[ESP_UUID_LEN_128]; + uint16_t uuid16; /*!< 16bit UUID */ + uint32_t uuid32; /*!< 32bit UUID */ + uint8_t uuid128[ESP_UUID_LEN_128]; /*!< 128bit UUID */ } uuid; /*!< UUID */ } __attribute__((packed)) esp_bt_uuid_t; diff --git a/components/driver/esp32s2/include/touch_sensor.h b/components/driver/esp32s2/include/touch_sensor.h index b677b85e5187..d4de6ba3a7d7 100644 --- a/components/driver/esp32s2/include/touch_sensor.h +++ b/components/driver/esp32s2/include/touch_sensor.h @@ -51,22 +51,22 @@ esp_err_t touch_pad_sw_start(void); * sleep_cycle decide the interval between each measurement. * t_sleep = sleep_cycle / (RTC_SLOW_CLK frequency). * The approximate frequency value of RTC_SLOW_CLK can be obtained using rtc_clk_slow_freq_get_hz function. - * @param meas_timers The times of charge and discharge in each measure process of touch channels. - * The timer frequency is 8Mhz. Range: 0 ~ 0xffff. - * Recommended typical value: Modify this value to make the measurement time around 1ms. + * @param meas_time The time of charge and discharge in each measure process of touch channels. + * The timer frequency is 8Mhz. Range: 0 ~ 0xffff. + * Recommended typical value: Modify this value to make the measurement time around 1ms. * @return * - ESP_OK on success */ -esp_err_t touch_pad_set_meas_time(uint16_t sleep_cycle, uint16_t meas_times); +esp_err_t touch_pad_set_meas_time(uint16_t sleep_cycle, uint16_t meas_time); /** * @brief Get touch sensor times of charge and discharge and sleep time * @param sleep_cycle Pointer to accept sleep cycle number - * @param meas_times Pointer to accept measurement times count. + * @param meas_time Pointer to accept measurement time count. * @return * - ESP_OK on success */ -esp_err_t touch_pad_get_meas_time(uint16_t *sleep_cycle, uint16_t *meas_times); +esp_err_t touch_pad_get_meas_time(uint16_t *sleep_cycle, uint16_t *meas_time); /** * @brief Set connection type of touch channel in idle status. @@ -196,7 +196,7 @@ uint32_t touch_pad_read_intr_status_mask(void); /** * @brief Enable touch sensor interrupt by bitmask. - * @param type interrupt type + * @param int_mask Pad mask to enable interrupts * @return * - ESP_OK on success */ @@ -204,7 +204,7 @@ esp_err_t touch_pad_intr_enable(touch_pad_intr_mask_t int_mask); /** * @brief Disable touch sensor interrupt by bitmask. - * @param type interrupt type + * @param int_mask Pad mask to disable interrupts * @return * - ESP_OK on success */ @@ -215,12 +215,13 @@ esp_err_t touch_pad_intr_disable(touch_pad_intr_mask_t int_mask); * The handler will be attached to the same CPU core that this function is running on. * @param fn Pointer to ISR handler * @param arg Parameter for ISR + * @param int_mask Initial pad mask to enable interrupt for * @return * - ESP_OK Success ; * - ESP_ERR_INVALID_ARG GPIO error * - ESP_ERR_NO_MEM No memory */ -esp_err_t touch_pad_isr_register(intr_handler_t fn, void* arg, touch_pad_intr_mask_t intr_mask); +esp_err_t touch_pad_isr_register(intr_handler_t fn, void* arg, touch_pad_intr_mask_t int_mask); /** * @brief get raw data of touch sensor. @@ -239,7 +240,7 @@ esp_err_t touch_pad_read_raw_data(touch_pad_t touch_num, uint32_t *raw_data); * @brief get baseline of touch sensor. * @note After initialization, the baseline value is the maximum during the first measurement period. * @param touch_num touch pad index - * @param touch_value pointer to accept touch sensor value + * @param basedata pointer to accept touch sensor baseline value * @return * - ESP_OK Success * - ESP_ERR_INVALID_ARG Touch channel 0 havent this parameter. @@ -331,7 +332,7 @@ esp_err_t touch_pad_denoise_disable(void); /** * @brief Get denoise measure value (TOUCH_PAD_NUM0). - * @param denoise value of denoise + * @param data Pointer to receive denoise value * @return * - ESP_OK Success */ @@ -405,7 +406,7 @@ esp_err_t touch_pad_proximity_get_config(touch_pad_proximity_t *proximity); * @brief Get measure count of proximity channel. * The proximity sensor measurement is the accumulation of touch channel measurements. * @param touch_num touch pad index - * @param proximity parameter of proximity + * @param cnt Pointer to receive proximity channel measurement count * @return * - ESP_OK Success * - ESP_ERR_INVALID_ARG parameter is NULL @@ -462,4 +463,4 @@ esp_err_t touch_pad_sleep_channel_read_proximity_cnt(uint32_t *proximity_cnt); #ifdef __cplusplus } -#endif \ No newline at end of file +#endif diff --git a/components/driver/include/driver/timer.h b/components/driver/include/driver/timer.h index f99784410fa2..a4888fb08849 100644 --- a/components/driver/include/driver/timer.h +++ b/components/driver/include/driver/timer.h @@ -331,8 +331,6 @@ esp_err_t timer_disable_intr(timer_group_t group_num, timer_idx_t timer_num); * @param group_num Timer group number, 0 for TIMERG0 or 1 for TIMERG1 * @param timer_num Timer index. * - * @return - * - None */ void timer_group_intr_clr_in_isr(timer_group_t group_num, timer_idx_t timer_num) __attribute__((deprecated)); @@ -341,8 +339,6 @@ void timer_group_intr_clr_in_isr(timer_group_t group_num, timer_idx_t timer_num) * @param group_num Timer group number, 0 for TIMERG0 or 1 for TIMERG1 * @param timer_num Timer index. * - * @return - * - None */ void timer_group_clr_intr_status_in_isr(timer_group_t group_num, timer_idx_t timer_num); @@ -351,8 +347,6 @@ void timer_group_clr_intr_status_in_isr(timer_group_t group_num, timer_idx_t tim * @param group_num Timer group number, 0 for TIMERG0 or 1 for TIMERG1 * @param timer_num Timer index. * - * @return - * - None */ void timer_group_enable_alarm_in_isr(timer_group_t group_num, timer_idx_t timer_num); @@ -372,8 +366,6 @@ uint64_t timer_group_get_counter_value_in_isr(timer_group_t group_num, timer_idx * @param timer_num Timer index. * @param alarm_val Alarm threshold. * - * @return - * - None */ void timer_group_set_alarm_value_in_isr(timer_group_t group_num, timer_idx_t timer_num, uint64_t alarm_val); @@ -383,8 +375,6 @@ void timer_group_set_alarm_value_in_isr(timer_group_t group_num, timer_idx_t tim * @param timer_num Timer index. * @param counter_en Enable/disable. * - * @return - * - None */ void timer_group_set_counter_enable_in_isr(timer_group_t group_num, timer_idx_t timer_num, timer_start_t counter_en); @@ -411,8 +401,6 @@ uint32_t timer_group_get_intr_status_in_isr(timer_group_t group_num); * @param group_num Timer group number, 0 for TIMERG0 or 1 for TIMERG1 * @param intr_mask Masked interrupt. * - * @return - * - None */ void timer_group_clr_intr_sta_in_isr(timer_group_t group_num, timer_intr_t intr_mask) __attribute__((deprecated)); diff --git a/components/esp32/include/esp_intr_alloc.h b/components/esp32/include/esp_intr_alloc.h index cafc178bfc07..67aca5b7797b 100644 --- a/components/esp32/include/esp_intr_alloc.h +++ b/components/esp32/include/esp_intr_alloc.h @@ -56,7 +56,6 @@ extern "C" { #define ESP_INTR_FLAG_LEVELMASK (ESP_INTR_FLAG_LEVEL1|ESP_INTR_FLAG_LEVEL2|ESP_INTR_FLAG_LEVEL3| \ ESP_INTR_FLAG_LEVEL4|ESP_INTR_FLAG_LEVEL5|ESP_INTR_FLAG_LEVEL6| \ ESP_INTR_FLAG_NMI) ///< Mask for all level flags -/**@}*/ /** @addtogroup Intr_Alloc_Pseudo_Src @@ -78,16 +77,23 @@ extern "C" { /**@}*/ -// This is used to provide SystemView with positive IRQ IDs, otherwise sheduler events are not shown properly +/** Provides SystemView with positive IRQ IDs, otherwise scheduler events are not shown properly + */ #define ETS_INTERNAL_INTR_SOURCE_OFF (-ETS_INTERNAL_PROFILING_INTR_SOURCE) +/** Enable interrupt by interrupt number */ #define ESP_INTR_ENABLE(inum) xt_ints_on((1<::@NUM not ::name) + RE_ANONYMOUS_FIELD = re.compile(r".+:line: warning: parameters of member [^:\s]+(::[^:\s]+)*(::@\d+)+ are not \(all\) documented") + all_messages = [msg for msg in all_messages if not re.match(RE_ANONYMOUS_FIELD, msg.sanitized_text)] + # Collect all new messages that are not match with the known messages. # The order is an important. new_messages = list() diff --git a/docs/conf_common.py b/docs/conf_common.py index 6d4e94b0ed81..cd1d3768e5c5 100644 --- a/docs/conf_common.py +++ b/docs/conf_common.py @@ -21,6 +21,7 @@ import os.path import re import subprocess +from idf_extensions.util import download_file_if_missing # build_docs on the CI server sometimes fails under Python3. This is a workaround: sys.setrecursionlimit(3500) @@ -132,22 +133,31 @@ def update_exclude_patterns(tags): 'api-guides/esp-ble-mesh/**', 'api-guides/ulp-legacy.rst', 'api-guides/unit-tests-legacy.rst', + 'api-guides/ulp_instruction_set.rst', 'api-guides/jtag-debugging/configure-wrover.rst', 'api-reference/system/himem.rst', 'api-reference/bluetooth/**', + 'api-reference/peripherals/sdio_slave.rst', + 'api-reference/peripherals/esp_slave_protocol.rst', + 'api-reference/peripherals/mcpwm.rst', + 'api-reference/peripherals/sd_pullup_requirements.rst', + 'api-reference/peripherals/sdmmc_host.rst', + 'api-reference/protocols/esp_serial_slave_link.rst', 'api-reference/system/ipc.rst', 'get-started-legacy/**', 'gnu-make-legacy.rst', - 'hw-reference/esp32/**']: + 'hw-reference/esp32/**', + ]: exclude_patterns.append(e) if "esp32s2" not in tags: # Exclude ESP32-only document pages so they aren't found in the initial search for .rst files # note: in toctrees, these also need to be marked with a :esp32: filter - for e in ['hw-reference/esp32s2/**']: + for e in ['hw-reference/esp32s2/**', + 'api-guides/ulps2_instruction_set.rst', + 'api-reference/peripherals/temp_sensor.rst']: exclude_patterns.append(e) - # The reST default role (used for this markup: `text`) to use for all # documents. # default_role = None diff --git a/docs/doxygen-known-warnings.txt b/docs/doxygen-known-warnings.txt index e69de29bb2d1..a2fd1018ee37 100644 --- a/docs/doxygen-known-warnings.txt +++ b/docs/doxygen-known-warnings.txt @@ -0,0 +1 @@ +semphr.h:line: warning: argument 'pxStaticSemaphore' of command @param is not found in the argument list of xSemaphoreCreateCounting(uxMaxCount, uxInitialCount) diff --git a/docs/en/api-guides/fatal-errors.rst b/docs/en/api-guides/fatal-errors.rst index 8dd54b561ff9..c01a70c780f5 100644 --- a/docs/en/api-guides/fatal-errors.rst +++ b/docs/en/api-guides/fatal-errors.rst @@ -62,7 +62,9 @@ Behavior of panic handler is affected by two other configuration options. - If :doc:`Core Dump ` feature is enabled, then system state (task stacks and registers) will be dumped either to Flash or UART, for later analysis. -- If :ref:`CONFIG_ESP_PANIC_HANDLER_IRAM` is disabled (disabled by default), the panic handler code is placed in flash memory not IRAM. This means that if ESP-IDF crashes while flash cache is disabled, the panic handler will automatically re-enable flash cache before running GDB Stub or Core Dump. This adds some minor risk, if the flash cache status is also corrupted during the crash. +.. only:: esp32 + + - If :ref:`CONFIG_ESP_PANIC_HANDLER_IRAM` is disabled (disabled by default), the panic handler code is placed in flash memory not IRAM. This means that if ESP-IDF crashes while flash cache is disabled, the panic handler will automatically re-enable flash cache before running GDB Stub or Core Dump. This adds some minor risk, if the flash cache status is also corrupted during the crash. If this option is enabled, the panic handler code is placed in IRAM. This allows the panic handler to run without needing to re-enable cache first. This may be necessary to debug some complex issues with crashes while flash cache is disabled (for example, when writing to SPI flash). diff --git a/docs/en/api-guides/freertos-smp.rst b/docs/en/api-guides/freertos-smp.rst index 1c017747156a..e5c2fd62a857 100644 --- a/docs/en/api-guides/freertos-smp.rst +++ b/docs/en/api-guides/freertos-smp.rst @@ -412,7 +412,7 @@ matter. .. _floating-points: Floating Point Arithmetic - ------------------------ + ------------------------- ESP-IDF FreeRTOS implements Lazy Context Switching for FPUs. In other words, the state of a core's FPU registers are not immediately saved when a context diff --git a/docs/en/api-guides/lwip.rst b/docs/en/api-guides/lwip.rst index 66b43818303c..a4497afbfabf 100644 --- a/docs/en/api-guides/lwip.rst +++ b/docs/en/api-guides/lwip.rst @@ -325,7 +325,15 @@ IP layer features Limitations ^^^^^^^^^^^ -- Calling ``send()`` or ``sendto()`` repeatedly on a UDP socket may eventually fail with ``errno`` equal to ``ENOMEM``. This is a limitation of buffer sizes in the lower layer network interface drivers. If all driver transmit buffers are full then UDP transmission will fail. Applications sending a high volume of UDP datagrams who don't wish for any to be dropped by the sender should check for this error code and re-send the datagram after a short delay. Increasing the number of TX buffers in the :ref:`Wi-Fi ` or :ref:`Ethernet ` project configuration (as applicable) may also help. +- Calling ``send()`` or ``sendto()`` repeatedly on a UDP socket may eventually fail with ``errno`` equal to ``ENOMEM``. This is a limitation of buffer sizes in the lower layer network interface drivers. If all driver transmit buffers are full then UDP transmission will fail. Applications sending a high volume of UDP datagrams who don't wish for any to be dropped by the sender should check for this error code and re-send the datagram after a short delay. + +.. only::esp32 + + Increasing the number of TX buffers in the :ref:`Wi-Fi ` or :ref:`Ethernet ` project configuration (as applicable) may also help. + +.. only::esp32s2 + + Increasing the number of TX buffers in the :ref:`Wi-Fi ` project configuration may also help. Performance Optimization ------------------------ diff --git a/docs/en/api-reference/peripherals/adc.rst b/docs/en/api-reference/peripherals/adc.rst index b81a6747fdc7..b07bad67c9bd 100644 --- a/docs/en/api-reference/peripherals/adc.rst +++ b/docs/en/api-reference/peripherals/adc.rst @@ -85,7 +85,7 @@ Reading voltage on ADC2 channel 7 ({IDF_TARGET_ADC2_CH7}):: The reading may fail due to collision with Wi-Fi, should check it. An example using the ADC2 driver to read the output of DAC is available in esp-idf: :example:`peripherals/adc2` -.. only: esp32 +.. only:: esp32 Reading the internal hall effect sensor:: diff --git a/docs/en/api-reference/peripherals/esp_slave_protocol.rst b/docs/en/api-reference/peripherals/esp_slave_protocol.rst index 2e1b5e615ab6..c0650a966055 100644 --- a/docs/en/api-reference/peripherals/esp_slave_protocol.rst +++ b/docs/en/api-reference/peripherals/esp_slave_protocol.rst @@ -6,12 +6,6 @@ Communication with ESP SDIO Slave ESP SDIO slave initialization ------------------------------ -.. only:: esp32s2 - - .. note:: - - {IDF_TARGET_NAME} does not have a SDIO peripheral. - The host should initialize the {IDF_TARGET_NAME} SDIO slave according to the standard SDIO initialization process (Sector 3.1.2 of `SDIO Simplified Specification `_). In this specification diff --git a/docs/en/api-reference/peripherals/index.rst b/docs/en/api-reference/peripherals/index.rst index 23fec20d6ae4..7a3d5105fe2a 100644 --- a/docs/en/api-reference/peripherals/index.rst +++ b/docs/en/api-reference/peripherals/index.rst @@ -14,17 +14,17 @@ Peripherals API I2C I2S LED Control - MCPWM + :esp32: MCPWM Pulse Counter Remote Control - SD Pull-up Requirements - SDMMC Host + :esp32: SD Pull-up Requirements + :esp32: SDMMC Host SD SPI Host - SDIO Slave + :esp32: SDIO Slave Sigma-delta Modulation SPI Master SPI Slave - Temp sensor + :esp32s2: Temp sensor Timer Touch Sensor UART diff --git a/docs/en/api-reference/peripherals/sdio_slave.rst b/docs/en/api-reference/peripherals/sdio_slave.rst index 8c303b1833eb..93d3e241a515 100644 --- a/docs/en/api-reference/peripherals/sdio_slave.rst +++ b/docs/en/api-reference/peripherals/sdio_slave.rst @@ -4,14 +4,6 @@ SDIO Card Slave Driver Overview -------- -.. only:: esp32s2 - - .. note:: - - {IDF_TARGET_NAME} does not have a SDIO peripheral. - -.. only:: esp32 - The ESP32 SDIO Card peripherals (Host, Slave) shares two sets of pins as below table. The first set is usually occupied by SPI0 bus which is responsible for the SPI flash holding the code to run. This means SDIO slave driver can only runs on the second set of pins while SDIO host is not using it. diff --git a/docs/en/api-reference/peripherals/sdmmc_host.rst b/docs/en/api-reference/peripherals/sdmmc_host.rst index d9157d027b14..a092c9c07094 100644 --- a/docs/en/api-reference/peripherals/sdmmc_host.rst +++ b/docs/en/api-reference/peripherals/sdmmc_host.rst @@ -3,54 +3,47 @@ SDMMC Host Driver Overview -------- -.. only:: esp32s2 - - .. note:: - - {IDF_TARGET_NAME} does not have a SDMMC host peripheral. - -.. only:: esp32 - - ESP32's SDMMC host peripheral has two slots: - - - Slot 0 (:c:macro:`SDMMC_HOST_SLOT_0`) is an 8-bit slot. It uses ``HS1_*`` signals in the PIN MUX. - - Slot 1 (:c:macro:`SDMMC_HOST_SLOT_1`) is a 4-bit slot. It uses ``HS2_*`` signals in the PIN MUX. - - Pin mappings of these slots are given in the table below. - - +--------+-------------+-------------+ - | Signal | Slot 0 | Slot 1 | - +========+=============+=============+ - | CMD | GPIO11 | GPIO15 | - +--------+-------------+-------------+ - | CLK | GPIO6 | GPIO14 | - +--------+-------------+-------------+ - | D0 | GPIO7 | GPIO2 | - +--------+-------------+-------------+ - | D1 | GPIO8 | GPIO4 | - +--------+-------------+-------------+ - | D2 | GPIO9 | GPIO12 | - +--------+-------------+-------------+ - | D3 | GPIO10 | GPIO13 | - +--------+-------------+-------------+ - | D4 | GPIO16 | | - +--------+-------------+-------------+ - | D5 | GPIO17 | | - +--------+-------------+-------------+ - | D6 | GPIO5 | | - +--------+-------------+-------------+ - | D7 | GPIO18 | | - +--------+-------------+-------------+ - | CD | any input via GPIO matrix | - +--------+---------------------------+ - | WP | any input via GPIO matrix | - +--------+---------------------------+ - - The Card Detect and Write Protect signals can be routed to arbitrary pins using the GPIO matrix. To reserve the pins, set the ``gpio_cd`` and ``gpio_wp`` members of the :cpp:class:`sdmmc_slot_config_t` structure before calling :cpp:func:`sdmmc_host_init_slot`. Please note that it is not advised to specify a Card Detect pin when working with SDIO cards, because the card detect signal in ESP32 can also trigger SDIO slave interrupt. - - .. warning:: - - Pins used by Slot 0 (``HS1_*``) are also used to connect the SPI flash chip in ESP32-WROOM and ESP32-WROVER modules. These pins cannot be shared between an SD card and SPI flash. If you need to use Slot 0, connect SPI flash to different pins and set eFuses accordingly. + +ESP32's SDMMC host peripheral has two slots: + +- Slot 0 (:c:macro:`SDMMC_HOST_SLOT_0`) is an 8-bit slot. It uses ``HS1_*`` signals in the PIN MUX. +- Slot 1 (:c:macro:`SDMMC_HOST_SLOT_1`) is a 4-bit slot. It uses ``HS2_*`` signals in the PIN MUX. + +Pin mappings of these slots are given in the table below. + ++--------+-------------+-------------+ +| Signal | Slot 0 | Slot 1 | ++========+=============+=============+ +| CMD | GPIO11 | GPIO15 | ++--------+-------------+-------------+ +| CLK | GPIO6 | GPIO14 | ++--------+-------------+-------------+ +| D0 | GPIO7 | GPIO2 | ++--------+-------------+-------------+ +| D1 | GPIO8 | GPIO4 | ++--------+-------------+-------------+ +| D2 | GPIO9 | GPIO12 | ++--------+-------------+-------------+ +| D3 | GPIO10 | GPIO13 | ++--------+-------------+-------------+ +| D4 | GPIO16 | | ++--------+-------------+-------------+ +| D5 | GPIO17 | | ++--------+-------------+-------------+ +| D6 | GPIO5 | | ++--------+-------------+-------------+ +| D7 | GPIO18 | | ++--------+-------------+-------------+ +| CD | any input via GPIO matrix | ++--------+---------------------------+ +| WP | any input via GPIO matrix | ++--------+---------------------------+ + +The Card Detect and Write Protect signals can be routed to arbitrary pins using the GPIO matrix. To reserve the pins, set the ``gpio_cd`` and ``gpio_wp`` members of the :cpp:class:`sdmmc_slot_config_t` structure before calling :cpp:func:`sdmmc_host_init_slot`. Please note that it is not advised to specify a Card Detect pin when working with SDIO cards, because the card detect signal in ESP32 can also trigger SDIO slave interrupt. + +.. warning:: + + Pins used by Slot 0 (``HS1_*``) are also used to connect the SPI flash chip in ESP32-WROOM and ESP32-WROVER modules. These pins cannot be shared between an SD card and SPI flash. If you need to use Slot 0, connect SPI flash to different pins and set eFuses accordingly. Supported Speed Modes diff --git a/docs/en/api-reference/peripherals/sdspi_host.rst b/docs/en/api-reference/peripherals/sdspi_host.rst index c20337b539c0..1f89b52849c7 100644 --- a/docs/en/api-reference/peripherals/sdspi_host.rst +++ b/docs/en/api-reference/peripherals/sdspi_host.rst @@ -4,7 +4,11 @@ SD SPI Host Driver Overview -------- -The SD SPI host driver allows using the SPI2 (HSPI) or SPI3 (VSPI) controller for communication with SD cards. This driver's naming pattern was adopted from the :doc:`SDMMC Host ` driver due to their similarity. Likewise, the APIs of both drivers are also very similar. +The SD SPI host driver allows using the SPI2 (HSPI) or SPI3 (VSPI) controller for communication with SD cards. + +.. only:: esp32 + + This driver's naming pattern was adopted from the :doc:`SDMMC Host ` driver due to their similarity. Likewise, the APIs of both drivers are also very similar. The SD SPI host driver has the following modes: diff --git a/docs/en/api-reference/peripherals/temp_sensor.rst b/docs/en/api-reference/peripherals/temp_sensor.rst index 9cfe8f819d66..9fa4a977cf30 100644 --- a/docs/en/api-reference/peripherals/temp_sensor.rst +++ b/docs/en/api-reference/peripherals/temp_sensor.rst @@ -4,30 +4,23 @@ ESP32-S2 Temperature Sensor Overview -------- -.. only:: esp32 - - .. note:: - - ESP32 does not have a built-in temperature sensor. - -.. only:: esp32s2 - - The ESP32-S2 has a built-in temperature sensor. The temperature sensor module contains an 8-bit Sigma-Delta ADC and a temperature offset DAC. - The conversion relationship is the first columns of the table below. Among them, offset = 0 is the main measurement option, and other values are extended measurement options. - - +--------+------------------------+------------------------+ - | offset | measure range(Celsius) | measure error(Celsius) | - +========+========================+========================+ - | -2 | 50 ~ 125 | < 3 | - +--------+------------------------+------------------------+ - | -1 | 20 ~ 100 | < 2 | - +--------+------------------------+------------------------+ - | 0 | -10 ~ 80 | < 1 | - +--------+------------------------+------------------------+ - | 1 | -30 ~ 50 | < 2 | - +--------+------------------------+------------------------+ - | 2 | -40 ~ 20 | < 3 | - +--------+------------------------+------------------------+ +The ESP32-S2 has a built-in temperature sensor. The temperature sensor module contains an 8-bit Sigma-Delta ADC and a temperature offset DAC. + +The conversion relationship is the first columns of the table below. Among them, offset = 0 is the main measurement option, and other values are extended measurement options. + ++--------+------------------------+------------------------+ +| offset | measure range(Celsius) | measure error(Celsius) | ++========+========================+========================+ +| -2 | 50 ~ 125 | < 3 | ++--------+------------------------+------------------------+ +| -1 | 20 ~ 100 | < 2 | ++--------+------------------------+------------------------+ +| 0 | -10 ~ 80 | < 1 | ++--------+------------------------+------------------------+ +| 1 | -30 ~ 50 | < 2 | ++--------+------------------------+------------------------+ +| 2 | -40 ~ 20 | < 3 | ++--------+------------------------+------------------------+ Application Example ------------------- diff --git a/docs/en/api-reference/storage/sdmmc.rst b/docs/en/api-reference/storage/sdmmc.rst index 4555cfa5cbd3..86aea717080d 100644 --- a/docs/en/api-reference/storage/sdmmc.rst +++ b/docs/en/api-reference/storage/sdmmc.rst @@ -16,74 +16,79 @@ SDMMC and SD SPI host drivers (:component:`driver/include/driver/sdmmc_host.h`) For functions used to initialize and configure: -- SDMMC host, see :doc:`SDMMC Host API <../peripherals/sdmmc_host>` -- SD SPI host, see :doc:`SD SPI Host API <../peripherals/sdspi_host>` +.. only:: esp32 + - SDMMC host, see :doc:`SDMMC Host API <../peripherals/sdmmc_host>` -The SDMMC protocol layer described in this document handles the specifics of the SD protocol, such as the card initialization and data transfer commands. + - SD SPI host, see :doc:`SD SPI Host API <../peripherals/sdspi_host>` -The protocol layer works with the host via the :cpp:class:`sdmmc_host_t` structure. This structure contains pointers to various functions of the host. + The SDMMC protocol layer described in this document handles the specifics of the SD protocol, such as the card initialization and data transfer commands. -Application Example -------------------- + The protocol layer works with the host via the :cpp:class:`sdmmc_host_t` structure. This structure contains pointers to various functions of the host. -An example which combines the SDMMC driver with the FATFS library is provided in the :example:`storage/sd_card` directory of ESP-IDF examples. This example initializes the card, then writes and reads data from it using POSIX and C library APIs. See README.md file in the example directory for more information. + Application Example + ------------------- + An example which combines the SDMMC driver with the FATFS library is provided in the :example:`storage/sd_card` directory of ESP-IDF examples. This example initializes the card, then writes and reads data from it using POSIX and C library APIs. See README.md file in the example directory for more information. -Protocol layer API ------------------- -The protocol layer is given the :cpp:class:`sdmmc_host_t` structure. This structure describes the SD/MMC host driver, lists its capabilities, and provides pointers to functions of the driver. The protocol layer stores card-specific information in the :cpp:class:`sdmmc_card_t` structure. When sending commands to the SD/MMC host driver, the protocol layer uses the :cpp:class:`sdmmc_command_t` structure to describe the command, arguments, expected return values, and data to transfer if there is any. + Protocol layer API + ------------------ -Using API with SD memory cards -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + The protocol layer is given the :cpp:class:`sdmmc_host_t` structure. This structure describes the SD/MMC host driver, lists its capabilities, and provides pointers to functions of the driver. The protocol layer stores card-specific information in the :cpp:class:`sdmmc_card_t` structure. When sending commands to the SD/MMC host driver, the protocol layer uses the :cpp:class:`sdmmc_command_t` structure to describe the command, arguments, expected return values, and data to transfer if there is any. -1. To initialize the host, call the host driver functions, e.g., :cpp:func:`sdmmc_host_init`, :cpp:func:`sdmmc_host_init_slot`. -2. To initialize the card, call :cpp:func:`sdmmc_card_init` and pass to it the parameters ``host`` - the host driver information, and ``card`` - a pointer to the structure :cpp:class:`sdmmc_card_t` which will be filled with information about the card when the function completes. -3. To read and write sectors of the card, use :cpp:func:`sdmmc_read_sectors` and :cpp:func:`sdmmc_write_sectors` respectively and pass to it the parameter ``card`` - a pointer to the card information structure. -4. If the card is not used anymore, call the host driver function - e.g., :cpp:func:`sdmmc_host_deinit` - to disable the host peripheral and free the resources allocated by the driver. + Using API with SD memory cards + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ -Using API with eMMC chips -^^^^^^^^^^^^^^^^^^^^^^^^^ + 1. To initialize the host, call the host driver functions, e.g., :cpp:func:`sdmmc_host_init`, :cpp:func:`sdmmc_host_init_slot`. + 2. To initialize the card, call :cpp:func:`sdmmc_card_init` and pass to it the parameters ``host`` - the host driver information, and ``card`` - a pointer to the structure :cpp:class:`sdmmc_card_t` which will be filled with information about the card when the function completes. + 3. To read and write sectors of the card, use :cpp:func:`sdmmc_read_sectors` and :cpp:func:`sdmmc_write_sectors` respectively and pass to it the parameter ``card`` - a pointer to the card information structure. + 4. If the card is not used anymore, call the host driver function - e.g., :cpp:func:`sdmmc_host_deinit` - to disable the host peripheral and free the resources allocated by the driver. -From the protocol layer's perspective, eMMC memory chips behave exactly like SD memory cards. Even though eMMCs are chips and do not have a card form factor, the terminology for SD cards can still be applied to eMMC due to the similarity of the protocol (`sdmmc_card_t`, `sdmmc_card_init`). Note that eMMC chips cannot be used over SPI, which makes them incompatible with the SD SPI host driver. -To initialize eMMC memory and perform read/write operations, follow the steps listed for SD cards in the previous section. + Using API with eMMC chips + ^^^^^^^^^^^^^^^^^^^^^^^^^ + From the protocol layer's perspective, eMMC memory chips behave exactly like SD memory cards. Even though eMMCs are chips and do not have a card form factor, the terminology for SD cards can still be applied to eMMC due to the similarity of the protocol (`sdmmc_card_t`, `sdmmc_card_init`). Note that eMMC chips cannot be used over SPI, which makes them incompatible with the SD SPI host driver. -Using API with SDIO cards -^^^^^^^^^^^^^^^^^^^^^^^^^ + To initialize eMMC memory and perform read/write operations, follow the steps listed for SD cards in the previous section. + + + Using API with SDIO cards + ^^^^^^^^^^^^^^^^^^^^^^^^^ + + Initialization and the probing process is the same as with SD memory cards. The only difference is in data transfer commands in SDIO mode. -Initialization and the probing process is the same as with SD memory cards. The only difference is in data transfer commands in SDIO mode. + During the card initialization and probing, performed with :cpp:func:`sdmmc_card_init`, the driver only configures the following registers of the IO card: -During the card initialization and probing, performed with :cpp:func:`sdmmc_card_init`, the driver only configures the following registers of the IO card: + 1. The IO portion of the card is reset by setting RES bit in the I/O Abort (0x06) register. + 2. If 4-line mode is enabled in host and slot configuration, the driver attempts to set the Bus width field in the Bus Interface Control (0x07) register. If setting the filed is successful, which means that the slave supports 4-line mode, the host is also switched to 4-line mode. + 3. If high-speed mode is enabled in the host configuration, the SHS bit is set in the High Speed (0x13) register. -1. The IO portion of the card is reset by setting RES bit in the I/O Abort (0x06) register. -2. If 4-line mode is enabled in host and slot configuration, the driver attempts to set the Bus width field in the Bus Interface Control (0x07) register. If setting the filed is successful, which means that the slave supports 4-line mode, the host is also switched to 4-line mode. -3. If high-speed mode is enabled in the host configuration, the SHS bit is set in the High Speed (0x13) register. + In particular, the driver does not set any bits in (1) I/O Enable and Int Enable registers, (2) I/O block sizes, etc. Applications can set them by calling :cpp:func:`sdmmc_io_write_byte`. -In particular, the driver does not set any bits in (1) I/O Enable and Int Enable registers, (2) I/O block sizes, etc. Applications can set them by calling :cpp:func:`sdmmc_io_write_byte`. + For card configuration and data transfer, choose the pair of functions relevant to your case from the table below. -For card configuration and data transfer, choose the pair of functions relevant to your case from the table below. + ========================================================================= ================================= ================================= + Action Read Function Write Function + ========================================================================= ================================= ================================= + Read and write a single byte using IO_RW_DIRECT (CMD52) :cpp:func:`sdmmc_io_read_byte` :cpp:func:`sdmmc_io_write_byte` + Read and write multiple bytes using IO_RW_EXTENDED (CMD53) in byte mode :cpp:func:`sdmmc_io_read_bytes` :cpp:func:`sdmmc_io_write_bytes` + Read and write blocks of data using IO_RW_EXTENDED (CMD53) in block mode :cpp:func:`sdmmc_io_read_blocks` :cpp:func:`sdmmc_io_write_blocks` + ========================================================================= ================================= ================================= -========================================================================= ================================= ================================= -Action Read Function Write Function -========================================================================= ================================= ================================= -Read and write a single byte using IO_RW_DIRECT (CMD52) :cpp:func:`sdmmc_io_read_byte` :cpp:func:`sdmmc_io_write_byte` -Read and write multiple bytes using IO_RW_EXTENDED (CMD53) in byte mode :cpp:func:`sdmmc_io_read_bytes` :cpp:func:`sdmmc_io_write_bytes` -Read and write blocks of data using IO_RW_EXTENDED (CMD53) in block mode :cpp:func:`sdmmc_io_read_blocks` :cpp:func:`sdmmc_io_write_blocks` -========================================================================= ================================= ================================= + SDIO interrupts can be enabled by the application using the function :cpp:func:`sdmmc_io_enable_int`. When using SDIO in 1-line mode, the D1 line also needs to be connected to use SDIO interrupts. -SDIO interrupts can be enabled by the application using the function :cpp:func:`sdmmc_io_enable_int`. When using SDIO in 1-line mode, the D1 line also needs to be connected to use SDIO interrupts. + If you want the application to wait until the SDIO interrupt occurs, use :cpp:func:`sdmmc_io_wait_int`. -If you want the application to wait until the SDIO interrupt occurs, use :cpp:func:`sdmmc_io_wait_int`. + .. only:: esp32 -There is a component ESSL (ESP Serial Slave Link) to use if you are communicating with an ESP32 -SDIO slave. See :doc:`/api-reference/protocols/esp_serial_slave_link` and example :example:`peripherals/sdio/host`. + There is a component ESSL (ESP Serial Slave Link) to use if you are communicating with an ESP32 + SDIO slave. See :doc:`/api-reference/protocols/esp_serial_slave_link` and example :example:`peripherals/sdio/host`. Combo (memory + IO) cards ^^^^^^^^^^^^^^^^^^^^^^^^^ diff --git a/docs/en/api-reference/system/system_time.rst b/docs/en/api-reference/system/system_time.rst index d0b94ef0e2e7..22a52ad39c7e 100644 --- a/docs/en/api-reference/system/system_time.rst +++ b/docs/en/api-reference/system/system_time.rst @@ -19,7 +19,7 @@ The settings for the system time source are as follows: - High-resolution timer - None -It is recommended to stick to the default setting which provides maximum accuracy. If you want to choose a different timer, configure :ref:`CONFIG_ESP32_TIME_SYSCALL` in project configuration. +It is recommended to stick to the default setting which provides maximum accuracy. If you want to choose a different timer, configure :ref:`CONFIG_{IDF_TARGET_CFG_PREFIX}_TIME_SYSCALL` in project configuration. RTC Clock Source @@ -35,7 +35,7 @@ The RTC timer has the following clock sources: - ``Internal 8.5MHz oscillator, divided by 256 (~33kHz)``. Provides better frequency stability than the ``internal 150kHz RC oscillator`` at the expense of higher (by 5 uA) deep sleep current consumption. It also does not require external components. -The choice depends on your requirements for system time accuracy and power consumption in sleep modes. To modify the RTC clock source, set :ref:`CONFIG_ESP32_RTC_CLK_SRC` in project configuration. +The choice depends on your requirements for system time accuracy and power consumption in sleep modes. To modify the RTC clock source, set :ref:`CONFIG_{IDF_TARGET_CFG_PREFIX}_RTC_CLK_SRC` in project configuration. More details on wiring requirements for the ``External 32kHz crystal`` and ``External 32kHz oscillator at 32K_XP pin`` sources can be found in Section 2.1.4 *Crystal Oscillator* of `Hardware Design Guidelines `_. @@ -130,4 +130,4 @@ Once these steps are completed, call the standard C library function ``localtime API Reference ------------- -.. include:: /_build/inc/sntp.inc +.. include-build-file:: inc/sntp.inc diff --git a/docs/sphinx-known-warnings.txt b/docs/sphinx-known-warnings.txt index 777b2138f0fd..89e5f494380b 100644 --- a/docs/sphinx-known-warnings.txt +++ b/docs/sphinx-known-warnings.txt @@ -40,6 +40,12 @@ ulp.rst:line: WARNING: Duplicate declaration, esp_err_t ulp_load_binary(uint32_t ulp.rst:line: WARNING: Duplicate declaration, esp_err_t ulp_run(uint32_t entry_point) ulp.rst:line: WARNING: Duplicate declaration, esp_err_t ulp_set_wakeup_period(size_t period_index, uint32_t period_us) README.rst:line: WARNING: Duplicate declaration, esp_err_t ulp_run(uint32_t entry_point) + + +# This seems like a bug, as the field are ::model_id and ::vnd::model_id +esp_ble_mesh_defs.inc:line: WARNING: Duplicate declaration, uint16_t esp_ble_mesh_model::model_id + + # # Issue present only when building on msys2 / mingw32 START >>> # diff --git a/docs/zh_CN/api-guides/unit-tests-legacy.rst b/docs/zh_CN/api-guides/unit-tests-legacy.rst index 26e6b6c88759..81a1a4495861 100644 --- a/docs/zh_CN/api-guides/unit-tests-legacy.rst +++ b/docs/zh_CN/api-guides/unit-tests-legacy.rst @@ -92,14 +92,14 @@ GPIO、SPI)需要与其通信的其他设备,因此不能使用常规测试 DUT1(master)终端: -.. code:: bash +.. code:: Waiting for signal: [output high level]! Please press "Enter" key once any board send this signal. DUT2(slave)终端: -.. code:: bash +.. code:: Send signal: [output high level]! @@ -183,7 +183,7 @@ DUT2 终端:: 当单元测试应用程序空闲时,输入回车键,它会打印出测试菜单,其中包含所有的测试项目。 -.. code:: bash +.. code:: Here's the test menu, pick your combo: (1) "esp_ota_begin() verifies arguments" [ota] @@ -230,7 +230,7 @@ DUT2 终端:: 一旦选择了多设备测试用例,它会打印一个子菜单: -.. code:: bash +.. code:: Running gpio master/slave test example... gpio master/slave test example @@ -241,7 +241,7 @@ DUT2 终端:: 与多设备测试用例相似,多阶段测试用例也会打印子菜单: -.. code:: bash +.. code:: Running reset reason check for deepsleep... reset reason check for deepsleep diff --git a/docs/zh_CN/api-guides/unit-tests.rst b/docs/zh_CN/api-guides/unit-tests.rst index fed2fd130373..0145544df34c 100644 --- a/docs/zh_CN/api-guides/unit-tests.rst +++ b/docs/zh_CN/api-guides/unit-tests.rst @@ -175,7 +175,7 @@ DUT2(slave)终端: 当单元测试应用程序空闲时,输入回车键,它会打印出测试菜单,其中包含所有的测试项目。 -.. code:: bash +.. code:: Here's the test menu, pick your combo: (1) "esp_ota_begin() verifies arguments" [ota] @@ -222,7 +222,7 @@ DUT2(slave)终端: 一旦选择了多设备测试用例,它会打印一个子菜单: -.. code:: bash +.. code:: Running gpio master/slave test example... gpio master/slave test example @@ -233,7 +233,7 @@ DUT2(slave)终端: 与多设备测试用例相似,多阶段测试用例也会打印子菜单: -.. code:: bash +.. code:: Running reset reason check for deepsleep... reset reason check for deepsleep diff --git a/docs/zh_CN/api-reference/network/esp_mesh.rst b/docs/zh_CN/api-reference/network/esp_mesh.rst index 187a864a1fdf..a5487ad8ed6c 100644 --- a/docs/zh_CN/api-reference/network/esp_mesh.rst +++ b/docs/zh_CN/api-reference/network/esp_mesh.rst @@ -332,5 +332,5 @@ ESP-IDF 包含以下 ESP-MESH 示例项目: API 参考 -------------- -.. include:: /_build/inc/esp_mesh.inc +.. include-build-file:: inc/esp_mesh.inc diff --git a/docs/zh_CN/api-reference/network/esp_now.rst b/docs/zh_CN/api-reference/network/esp_now.rst index 7ce944212cd1..1c58c1efe739 100644 --- a/docs/zh_CN/api-reference/network/esp_now.rst +++ b/docs/zh_CN/api-reference/network/esp_now.rst @@ -84,5 +84,5 @@ ESP-NOW 采用 CCMP 方法保护供应商特定动作帧的安全,具体可参 API 参考 ------------- -.. include:: /_build/inc/esp_now.inc +.. include-build-file:: inc/esp_now.inc diff --git a/docs/zh_CN/api-reference/peripherals/index.rst b/docs/zh_CN/api-reference/peripherals/index.rst index 22d2cd55dad9..9f4fd1dcb067 100644 --- a/docs/zh_CN/api-reference/peripherals/index.rst +++ b/docs/zh_CN/api-reference/peripherals/index.rst @@ -13,16 +13,16 @@ I2C I2S LED Control - MCPWM + :esp32: MCPWM Pulse Counter Remote Control - SDMMC Host + :esp32: SDMMC Host SD SPI Host - SDIO Slave + :esp32: SDIO Slave Sigma-delta Modulation SPI Master SPI Slave - Temp sensor + :esp32s2: Temp sensor Timer Touch Sensor UART diff --git a/docs/zh_CN/api-reference/peripherals/ledc.rst b/docs/zh_CN/api-reference/peripherals/ledc.rst index 0c50edc45d02..5822d9d65ed4 100644 --- a/docs/zh_CN/api-reference/peripherals/ledc.rst +++ b/docs/zh_CN/api-reference/peripherals/ledc.rst @@ -172,4 +172,5 @@ LED PWM 改变占空比和渐变控制的实例请参照 :example:`peripherals/l API 参考 ------------- -.. include:: /_build/inc/ledc.inc \ No newline at end of file +.. include-build-file:: inc/ledc.inc + diff --git a/docs/zh_CN/api-reference/peripherals/touch_pad.rst b/docs/zh_CN/api-reference/peripherals/touch_pad.rst index 1c9476fec44a..57ae30302528 100644 --- a/docs/zh_CN/api-reference/peripherals/touch_pad.rst +++ b/docs/zh_CN/api-reference/peripherals/touch_pad.rst @@ -156,7 +156,8 @@ ESP32 可支持最多 10 个电容式触摸板/GPIO,触摸板可以以矩阵 API 参考 ------------- -.. include-build-file:: inc/touch_pad.inc +.. include-build-file:: inc/touch_sensor.inc +.. include-build-file:: inc/touch_sensor_common.inc GPIO 宏查找表 ^^^^^^^^^^^^^^^^^^ diff --git a/docs/zh_CN/api-reference/protocols/index.rst b/docs/zh_CN/api-reference/protocols/index.rst index 66a1b3303c86..b77f7eb545a4 100644 --- a/docs/zh_CN/api-reference/protocols/index.rst +++ b/docs/zh_CN/api-reference/protocols/index.rst @@ -16,7 +16,7 @@ ESP-MQTT Modbus slave Local Control - ESP Serial Slave Link + :esp32: ESP Serial Slave Link 此 API 部分的示例代码在 ESP-IDF 示例工程的 :example:`protocols` 目录下提供。 diff --git a/docs/zh_CN/api-reference/storage/sdmmc.rst b/docs/zh_CN/api-reference/storage/sdmmc.rst index 11ad8cf9eaaa..e9af6a3d6389 100644 --- a/docs/zh_CN/api-reference/storage/sdmmc.rst +++ b/docs/zh_CN/api-reference/storage/sdmmc.rst @@ -16,7 +16,11 @@ SDMMC 主机驱动和 SD SPI 主机驱动(:component:`driver/include/driver/sd 初始化函数及配置函数: -- 如需初始化和配置 SDMMC 主机,请参阅 :doc:`SDMMC 主机 API <../peripherals/sdmmc_host>` +.. only:: esp32 + + - 如需初始化和配置 SDMMC 主机,请参阅 :doc:`SDMMC 主机 API <../peripherals/sdmmc_host>` + + - 如需初始化和配置 SD SPI 主机,请参阅 :doc:`SD SPI 主机 API <../peripherals/sdspi_host>` 本文档中所述的 SDMMC 协议层仅处理 SD 协议相关事项,例如卡初始化和数据传输命令。 @@ -94,4 +98,4 @@ API 参考 .. include-build-file:: inc/sdmmc_cmd.inc -.. include-build-file:: inc/sdmmc_types.inc \ No newline at end of file +.. include-build-file:: inc/sdmmc_types.inc