mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
114 lines
6.1 KiB
ReStructuredText
114 lines
6.1 KiB
ReStructuredText
PHY
|
||
==================
|
||
|
||
:link_to_translation:`en:[English]`
|
||
|
||
多根天线
|
||
-------------------
|
||
|
||
多根天线功能原理和组成
|
||
++++++++++++++++++++++++++++
|
||
|
||
多根天线功能主要通过将内部天线模块工作信号输出到具体 IO 引脚上,通过 IO 引脚控制外部天线切换器选择指定天线,最多支持 16 根天线。
|
||
|
||
下图描述多根天线功能组成:
|
||
|
||
.. code-block:: none
|
||
|
||
___________________________________________________________________________
|
||
____|____ _________ |
|
||
|PHY |--antenna_select[0] --> | | |
|
||
___|Antenna 0|--antenna_select[1] --> | | |
|
||
/ |Module |--antenna_select[2] --> | | ____|____
|
||
/ |_________|--antenna_select[3] --> | IO MUX |--GPIO[x0] --> ant_sel_in[0]--| | --- antenna 0
|
||
RX/TX ___/ | | And |--GPIO[x1] --> ant_sel_in[1]--| Antenna | --- antenna 1
|
||
\ ____|____ | GPIO |--GPIO[x2] --> ant_sel_in[2]--| Switch | ... ...
|
||
\ |PHY |--antenna_select[0] --> | Matrix |--GPIO[x3] --> ant_sel_in[3]--|_________| --- antenna 15
|
||
\___|Antenna 1|--antenna_select[1] --> | |
|
||
|Module |--antenna_select[2] --> | |
|
||
|_________|--antenna_select[3] --> |_________|
|
||
|
||
{IDF_TARGET_NAME} 多根天线功能主要包含 3 个部分:芯片内部的 PHY 天线模块、IO MUX 和 GPIO Matrix、以及外部的天线切换器。
|
||
|
||
1.芯片内部的天线选择模块 PHY Antenna Module:
|
||
|
||
- 两个天线模块均支持工作于发送 (TX) 或接收 (RX) 模式,可以通过软件配置发送和接收选用某个模块。
|
||
- 每个天线模块最多支持输出 4 个天线选择信号 ``antenna_select[3:0]``,该信号值可由软件配置并且可以一一映射到任意 IO 引脚。
|
||
- 当某个天线模块处于工作状态时,IO 引脚的高低电平值为软件配置的信号值。
|
||
|
||
2.IO MUX 和 GPIO Matrix:
|
||
|
||
- 将内部 4 路天线信号输出到具体的 IO 引脚上。
|
||
|
||
3.外部的天线切换器:
|
||
|
||
- 一般为多路选择器,通过 ``ant_sel_in[x]`` 引脚的电平,选择工作的天线,例如 ``ant_sel_in[3:0]`` 为 ``0b1011``,表示选中天线 11。
|
||
|
||
多根天线使用步骤
|
||
+++++++++++++++++++++++++++
|
||
|
||
1.根据硬件电路设计及外部天线切换器确定用于控制天线切换的 IO 引脚。
|
||
|
||
2.配置天线选择信号输出到指定 IO 引脚
|
||
|
||
- API :cpp:func:`esp_phy_set_ant_gpio()` 用于配置 ``antenna_selects[3:0]`` 信号连接 ``GPIO[x3:x0]``。如果 ``GPIO[x0]`` 连接到 ``antenna_select[0]``,``gpio_config->gpio_cfg[x0].gpio_select`` 应设置为 1,且 ``gpio_config->gpio_cfg[x0].gpio_num`` 的值为 ``GPIO[x0]``。
|
||
|
||
3.配置内部天线工作模式及输出信号
|
||
|
||
- API :cpp:func:`esp_phy_set_ant()` 用于配置发送或接收时使用内部天线模块 0 或 1,并配置当天线模块 0 或 1 工作时的输出信号值。
|
||
- 对于 ``ESP_PHY_ANT_MODE_AUTO`` 模式目前不推荐使用。
|
||
|
||
多根天线配置参考例子
|
||
++++++++++++++++++++++++++++
|
||
|
||
通常,可以执行以下步骤来配置多根天线:
|
||
|
||
- 配置 ``antenna_selects`` 连接哪些 GPIOs,例如,如果支持四根天线,且 GPIO20/GPIO21 连接到 ``antenna_select[0]/antenna_select[1]``,配置如下所示:
|
||
|
||
.. code-block:: c
|
||
|
||
esp_phy_ant_gpio_config_t ant_gpio_config = {
|
||
.gpio_cfg[0] = { .gpio_select = 1, .gpio_num = 20 },
|
||
.gpio_cfg[1] = { .gpio_select = 1, .gpio_num = 21 }
|
||
};
|
||
|
||
- 配置使能哪些天线、以及接收/发送数据如何使用使能的天线,例如,如果使能了天线 1 和天线 3,接收数据需要自动选择较好的天线,并将天线 1 作为默认天线,发送数据始终选择天线 3。配置如下所示:
|
||
|
||
.. code-block:: c
|
||
|
||
esp_phy_ant_config_t config = {
|
||
.rx_ant_mode = ESP_PHY_ANT_MODE_AUTO,
|
||
.rx_ant_default = ESP_PHY_ANT_ANT0,
|
||
.tx_ant_mode = ESP_PHY_ANT_MODE_ANT1,
|
||
.enabled_ant0 = 1,
|
||
.enabled_ant1 = 3
|
||
};
|
||
|
||
注意事项
|
||
++++++++++++++++++++++++++
|
||
|
||
1.不同天线切换器,``ant_sel_in[3:0]`` 的输入值中可能存在非法值,即 {IDF_TARGET_NAME} 通过外部天线开关支持的天线数可能小于 16 根。例如,ESP32-WROOM-DA 使用 RTC6603SP 作为天线切换器,仅支持 2 根天线。两个天线选择输入管脚为高电平有效,连接到两个 GPIO。``0b01`` 表示选中天线 0,``0b10`` 表示选中天线 1。输入值 ``0b00`` 和 ``0b11`` 为非法值。
|
||
|
||
2.尽管最多支持 16 根天线,发送和接收数据时,最多仅能同时使能两根天线。
|
||
|
||
3.对于 ``ESP_PHY_ANT_MODE_AUTO`` 模式目前不推荐使用,主要有以下限制情况需要考虑:
|
||
|
||
- 因为发送数据天线基于 ``ESP_PHY_ANT_MODE_AUTO`` 类型的接收数据天线选择算法,只有接收数据的天线模式为 ``ESP_PHY_ANT_MODE_AUTO`` 时,发送数据天线才能设置为 ``ESP_PHY_ANT_MODE_AUTO``。
|
||
- 接收或者发送天线模式配置为 ``ESP_PHY_ANT_MODE_AUTO`` 时,只要存在 RF 信号的恶化,很容易触发天线切换。如果射频信号不稳定,天线会频繁切换,使得总的射频性能无法达到预期效果。
|
||
|
||
推荐在以下场景中使用多根天线
|
||
++++++++++++++++++++++++++++
|
||
|
||
1.应用程序可以始终选择指定的天线,也可以执行自身天线选择算法,如根据应用程序收集的信息来选择天线模式等。请参考 IDF 示例 :idf_file:`examples/phy/antenna/README.md` 来设计天线选择算法。
|
||
|
||
2.接收/发送数据的天线模式均配置为 ``ESP_PHY_ANT_MODE_ANT0`` 或 ``ESP_PHY_ANT_MODE_ANT1``。
|
||
|
||
应用示例
|
||
--------------------
|
||
|
||
.. only:: esp32c3 or esp32s3
|
||
|
||
- :example:`phy/cert_test` 演示了如何在 {IDF_TARGET_NAME} 上使用认证测试 API,包括项目配置以及进行 RF、Wi-Fi 和 Bluetooth 认证测试。
|
||
|
||
- :example:`phy/antenna` 演示了如何在 {IDF_TARGET_NAME} 上进行多天线软件切换。
|