Back to Esp Idf

外设

docs/zh_CN/migration-guides/release-5.x/5.5/peripherals.rst

6.1-dev4.3 KB
Original Source

外设

:link_to_translation:en:[English]

.. only:: SOC_TOUCH_SENSOR_SUPPORTED

触摸传感器
------------

电容式触摸传感器的驱动已更新为 :doc:`Capacitive Touch Sensor <../../../api-reference/peripherals/cap_touch_sens>`。

- 新的驱动位于 ``esp_driver_touch_sens`` 组件中,包含路径为 ``driver/touch_sens.h``。
- 旧版驱动仍然可用,其包含路径为 ``driver/touch_sensor.h``。

尽管我们推荐使用新的驱动 API, 旧版驱动仍然可用,其头文件引用路径为 ``driver/touch_sensor.h``。但是,引用 ``driver/touch_sensor.h`` 会默认触发如下编译警告,可通过配置 Kconfig 选项 :ref:`CONFIG_TOUCH_SUPPRESS_DEPRECATE_WARN` 关闭该警告。

使用方法上的主要更新如下所示:

主要使用方法更新
^^^^^^^^^^^^^^^^^^^^^^^^^

- 基于不同硬件版本的触摸传感器 API 现已经整合为一套 API,每个子功能都有独立的 API 可配置。
- 所有的硬件配置都可配置,以提供足够的灵活性,同时驱动程序还提供了一些默认配置,以便您不必花费时间去确定可用的基本配置。
- 新的触摸驱动实现了有限状态机(FSM)以确保正确的触摸传感器操作。请参阅编程指南 :doc:`电容式触摸传感器 <../../../api-reference/peripherals/cap_touch_sens>` 了解更多详情。
- 所有新的API都保证是线程安全的。
- 为触摸传感器 V1(ESP32)实现了软件滤波器,并开放自定义滤波器接口。

.. only:: SOC_TWAI_SUPPORTED

双线汽车接口 (TWAI)
--------------------

TWAI 提供一套全新驱动接口以支持更多更方便的功能,请参考编程指南 :doc:`双线汽车接口 (TWAI)<../../../api-reference/peripherals/twai>`.

相较于老驱动,新版驱动主要亮点有:

- 事件驱动,支持注册多种回调函数
- 支持运行时更改波特率、过滤器配置
- 提供更友好直观的波特率配置、过滤器配置方法
- 支持 ESP32C5 及其 FD(Flexible Datarate, 灵活数据速率)功能
- 支持多个 TWAI 控制器同时使用

新驱动位于 :component:`esp_driver_twai` 组件中,添加该组件依赖即可使用。包含头文件为 :component_file:`esp_driver_twai/include/esp_twai.h` 和 :component_file:`esp_driver_twai/include/esp_twai_onchip.h`。

+---------------------------+----------------------------+---------------------------------------------------------------------+
| 删除/弃用项目             | 替代                       | 备注                                                                |
+===========================+============================+=====================================================================+
| twai_read_alerts          | 无                         | 需要注册 on_state_change 和 on_error 回调来获取状态转换和在错误信息 |
+---------------------------+----------------------------+---------------------------------------------------------------------+
| twai_receive              | twai_node_receive_from_isr | 只能在 on_rx_done 回调中使用该函数                                  |
+---------------------------+----------------------------+---------------------------------------------------------------------+
| twai_clear_transmit_queue | 无                         | 暂不支持                                                            |
+---------------------------+----------------------------+---------------------------------------------------------------------+
| twai_clear_receive_queue  | 无                         | receive 是事件驱动的,暂不提供阻塞版本的函数                        |
+---------------------------+----------------------------+---------------------------------------------------------------------+

尽管我们推荐使用新的驱动 API,但旧版驱动仍然可用,其头文件引用路径为 ``driver/twai.h``。继续使用旧版驱动请注意:

- 新旧驱动不互相兼容,不可混合使用,否则将在启动时打印警告,甚至崩溃并重启。可打开配置项 :ref:`CONFIG_TWAI_SKIP_LEGACY_CONFLICT_CHECK` 以屏蔽该检查。
- 旧版驱动将不再添加新特性(如 TWAIFD)的支持。