Skip to content

Latest commit

 

History

History
42 lines (30 loc) · 2.42 KB

peripherals.rst

File metadata and controls

42 lines (30 loc) · 2.42 KB

外设

:link_to_translation:`en:[English]`

.. only:: SOC_UART_SUPPORTED

    UART
    ----

    - :c:macro:`UART_FIFO_LEN` 已弃用,更新为 :c:macro:`UART_HW_FIFO_LEN`。

.. only:: SOC_I2C_SUPPORTED

    I2C
    ---

    I2C 驱动已经被重新设计在 :doc:`I2C <../../../api-reference/peripherals/i2c>`, 以统一接口并扩展 I2C 外设的使用。尽管我们推荐使用新驱动的接口, 但用户仍然可以通过包含路径 ``driver/i2c.h`` 来使用老驱动。

    主要的概念上和用法上的改变如下所示:

    主要概念更新
    ~~~~~~~~~~~~~~~~~~

    -  用于初始化整个 I2C 总线的结构体 ``i2c_config_t`` 已经被移除. 在新驱动中, 从机和主机是分开的. 用户可以独立调用 :cpp:type:`i2c_master_bus_config_t` 和 :cpp:type:`i2c_slave_config_t`。
    - ``i2c_mode_t`` 用来判断 I2C 控制器是工作在从模式还是主模式。该枚举器已被弃用。在新驱动程序中,用户无需自行设置,驱动程序会妥善处理。
    - ``i2c_rw_t`` 用来判断 I2C 主控制器是在进行 "写 "还是 "读"。现在,它已被弃用。
    - ``i2c_addr_mode_t`` 被重命名为 ``i2c_addr_bit_len_t``.
    -  在老驱动中,你需要将 I2C 命令通过 ``I2C_LINK_RECOMMENDED_SIZE``, ``i2c_cmd_link_create_static``, 等链接成链表. 在新驱动中,你不需要这么做,你只需要调用相关的接口函数即可。
    -  在老驱动中,选择时钟通过例如 ``I2C_SCLK_SRC_FLAG_FOR_NOMAL`` 的时钟标志位. 在新驱动中,你可以直接选择时钟源。

    主要用法更新
    ~~~~~~~~~~~~~~~~~~

    -  I2C 总线初始化通过两部分完成. 第一步通过 :cpp:func:`i2c_new_master_bus` 初始化 I2C 总线, 然后初始化 I2C 设备通过 :cpp:func:`i2c_master_bus_add_device`。
    - ``i2c_reset_tx_fifo`` 和 ``i2c_reset_rx_fifo`` 已被删除,因为用户不太需要重置 fifo。但可以通过 ``i2c_master_bus_reset`` 重置整个总线。
    - 删除了 ``i2c_cmd_link_xxx`` 函数,用户不需要自己使用 link 来链接命令。
    - ``i2c_master_write_to_device`` 更名为 ``i2c_master_transmit``。
    - ``i2c_master_read_from_device`` 已更名为 ``i2c_master_receive``。
    - ``i2c_master_write_read_device`` 已更名为 ``i2c_master_transmit_receive``。
    - ``i2c_slave_write_buffer`` 重命名为 ``i2c_slave_transmit``。
    - ``i2c_slave_read_buffer`` 已更名为 ``i2c_slave_receive``。