WIFI
介绍WIFI的移植和使用方法。
模块介绍
K1平台上主要通过外部WIFI模块来实现WIFI功能,主要支持PCIE,SDIO以及USB等接口的模块。
功能介绍
WIFI框架图可以分为以下几个层次:
源码结构介绍
WIFI相关的源码可以分为三个部分:
- WIFI驱动,由WIFI厂商提供,主要实现WIFI功能。
- 平台相关部分,主要实现模组供电以及使能等相关接口,供WIFI驱动调用。
- 接口驱动,主要实现WIFI数据传输接口功能,如PCIE,SDIO以及USB等接口。
WIFI驱动的源码一般放到以下目录:
drivers/net/wireless
|-- aic8800 #aic厂商驱动
|-- realtek #realtek厂商驱动
|-- rtl8852be #rtl8852be
|-- rtl8852bs #rtl8852bs
|-- wuqi #wuqi厂商驱动
平台相关的源码:
drivers/soc/spacemit/spacemit-rf
|-- spacemit-pwrseq.c #WIFI和蓝牙等公共部分实现
|-- spacemit-wlan.c #WIFI供电,gpio以及时钟相关接口实现
|-- spacemit-bt.c #bt供电,gpio以及时钟相关接口实现
接口相关的源码参考各个接口驱动说明文档。
关键特性
sdio接口特性
特性 | 特性说明 |
---|---|
兼容SDIO v4.10 | 兼容4bit SDIO 4.10规范 |
支持SD 3.0模式 | 支持SDR12/SDR25/DDR50/SDR50/SDR104模式 |
支持PIO/DMA | 支持PIO,SDMA,ADMA,ADMA2传输模式 |
性能参数
模组型号 | TX(Mb/s) | RX(Mb/s) |
---|---|---|
rtl8852bs | 460 | 480 |
aic8800d80 | 410 | 470 |
测试方法
同一局域网段
服务端:iperf3 -s
客 户端:iperf3 -c 192.168.1.xxx -t 72000
配置介绍
主要包括驱动使能配置和dts配置
CONFIG配置
CONFIG_SPACEMIT_RFKILL 为WIFI模组提供平台相关支持,默认情况,此选项为Y
Device Drivers
SOC (System On Chip) specific Drivers
Spacemit rfkill driver (SPACEMIT_RFKILL [=y])
dts配置
sdio pinctrl
方案上一般 slot2 用于 sdio,对应 pinctrl_mmc2。
pinctrl_mmc2: mmc2_grp {
pinctrl-single,pins =<
K1X_PADCONF(GPIO_15, MUX_MODE1, (EDGE_NONE | PULL_UP | PAD_1V8_DS2)) /* mmc2_data3 */
K1X_PADCONF(GPIO_16, MUX_MODE1, (EDGE_NONE | PULL_UP | PAD_1V8_DS2)) /* mmc2_data2 */
K1X_PADCONF(GPIO_17, MUX_MODE1, (EDGE_NONE | PULL_UP | PAD_1V8_DS2)) /* mmc2_data1 */
K1X_PADCONF(GPIO_18, MUX_MODE1, (EDGE_NONE | PULL_UP | PAD_1V8_DS2)) /* mmc2_data0 */
K1X_PADCONF(GPIO_19, MUX_MODE1, (EDGE_NONE | PULL_UP | PAD_1V8_DS2)) /* mmc2_cmd */
K1X_PADCONF(GPIO_20, MUX_MODE1, (EDGE_NONE | PULL_UP | PAD_1V8_DS2)) /* mmc2_clk */
>;
};
如果需要支持WIFI唤醒,需要将wlan_hostwake配置为pinctl模式:
pinctrl_wlan_wakeup: wlan_wakeup_grp {
pinctrl-single,pins =<
K1X_PADCONF(GPIO_66, MUX_MODE0, (EDGE_FALL | PULL_DOWN | PAD_3V_DS2)) /* wifi edge detect */
>;
};
电源配置
sdio 需要配置两个电源,分别是 vmmc-supply 和 vqmmc-supply,分别对应卡的功能和 io 供电,vqmmc-supply 建议1.8v,具体根据sdio卡的模式选择实际电压。
&sdhci1 {
vmmc-supply = <&dcdc_3>;
vqmmc-supply = <&ldo_1>;
};
tuning 配置
sdio 跑高速模式下需要进行 tuning,不同的硬件版型都需要调整 tx 的相关参数。
sdio dts 配置示例
sdio 的完整方案配置如下:
/* SDIO */
&sdhci1 {
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_mmc2>;
bus-width = <4>;
non-removable;
vqmmc-supply = <&dcdc_3>;
no-mmc;
no-sd;
keep-power-in-suspend;
spacemit,sdh-host-caps-disable = <(
MMC_CAP_UHS_DDR50 |
MMC_CAP_NEEDS_POLL
)>;
spacemit,sdh-quirks = <(
SDHCI_QUIRK_BROKEN_CARD_DETECTION |
SDHCI_QUIRK_BROKEN_TIMEOUT_VAL
)>;
spacemit,sdh-quirks2 = <(
SDHCI_QUIRK2_PRESET_VALUE_BROKEN |
SDHCI_QUIRK2_BROKEN_PHY_MODULE
)>;
spacemit,rx_dline_reg = <0x0>;
spacemit,tx_delaycode = <0x7f>;
spacemit,rx_tuning_limit = <50>;
spacemit,sdh-freq = <375000000>;
status = "okay";
};
sdio tx_delaycode 的默认值是0x7f,实际上需要根据具体的方案走线等差异进行调整。
平台部分dts配置
平台完整方案配置如下:
rf_pwrseq: rf-pwrseq {
compatible = "spacemit,rf-pwrseq";
//vdd-supply = <&ldo_7>;
//vdd_voltage = <3300000>;
io-supply = <&dcdc_3>;
io_voltage = <1800000>;
pwr-gpios = <&gpio 67 0>;
status = "okay";
wlan_pwrseq: wlan-pwrseq {
compatible = "spacemit,wlan-pwrseq";
regon-gpios = <&gpio 116 0>;
interrupt-parent = <&pinctrl>;
interrupts = <268>;
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_wlan_wakeup>;
};
bt_pwrseq: bt-pwrseq {
compatible = "spacemit,bt-pwrseq";
reset-gpios = <&gpio 63 0>;
};
};
目前市面上很多模组都是WIFI和蓝牙二合一,WIFI和蓝牙的供电部分很多都是共用的,共用的部分建议放到rf_pwrseq中进行配置,仅影响WIFI的部分,放到wlan_pwrseq中进行配置。
单WIFI模组只需要配置wlan_pwrseq即可,不需要配置rf_pwrseq,但要使能rf_pwrseq节点。
在打开WIFI电源时会先使能共用部分的电源以及gpio状态,平台会维护对应的引用计数,关闭时只有WIFI和蓝牙都关闭后才会真正关闭共用部分的电源以及gpio状态。
rf_pwrseq:
- vdd-supply是配置模组的供电,具体按实际硬件配置。
- vdd_voltage用于设定模组供电的电压。
- io-supply是配置模组io的供电,具体按实际硬件配置。
- io_voltage用于设定模组io供电的电压。
- pwr-gpios是模组使能脚,配置后会默认拉高,支持多个gpio的配置。
- clock是模组共用的时钟配置。
- power-on-delay-ms是设置模组上电后的延时,默认是100ms。
wlan_pwrseq:
- regon-gpios是WIFI部分的使能脚,调用spacemit_wlan_set_power(1)接口时会拉高。
- interrupts配置WIFI的中断唤醒脚,表示采用pinctl的方式进行唤醒。
- power-on-delay-ms是设置WIFI上电后的延时,默认是10ms。
bt_pwrseq:
- reset-gpios是蓝牙的使能脚,使能蓝牙对应的rfkill时会将该gpio拉高。
- clock是蓝牙的时钟配置。
- power-on-delay-ms是设置蓝牙上电后的延时,默认是10ms。