WIFI
本文介绍 WIFI 的移植和使用方法。
模块介绍
K1平台上主要通过外部WIFI模块来实现WIFI功能,主要支持PCIE,SDIO以及USB等接口的模块。 K1 平台主要通过外部 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>;
};
};
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:Wi-Fi 模块使能脚,调用spacemit_wlan_set_power(1)时拉高;interrupts:Wi-Fi 模块的唤醒中断引脚,表示采用pinctl的方式进行唤醒;power-on-delay-ms:Wi-Fi 上电延时,默认 10ms。
bt_pwrseq 配置说明:
reset-gpios:蓝牙模块复位脚,使能蓝牙对应rfkill节点时拉高;clock:蓝牙时钟配置;power-on-delay-ms:蓝牙上电延时,默认 10ms。
当前市面上大多数模组为 Wi-Fi 和蓝牙二合一,其供电部分通常共用。建议将共用部分配置在 rf_pwrseq 节点中,Wi-Fi 专属部分配置在 wlan_pwrseq 节点中。
如果使用的是单 Wi-Fi 模组,仅需配置 wlan_pwrseq,不需要配置 rf_pwrseq,但要使能rf_pwrseq节点。
在打开 Wi-Fi 电源时,平台会优先启用共用电源及 GPIO 状态,并维护相应的引用计数。关闭时,只有 Wi-Fi 和蓝牙都关闭后,平台才会真正关闭共用电源及 GPIO 状态。
接口介绍
API 介绍
平台部分的接口,包含 Wi-Fi 上下电控制、中断获取及 SDIO 扫描等功能:
-
void spacemit_wlan_set_power(bool on_off);设置WIFI电源,0为关闭,1为打开。 -
int spacemit_wlan_get_oob_irq(void);获取平台中断请求(IRQ)号。 -
void spacemit_sdio_detect_change(int enable_scan);扫描 SDIO 总线。
Debug介绍
sysfs
SDIO 的 tx_delaycode 参数默认在方案的 DTS 中指定。
调试时,可以通过 sysfs 下对应节点动态修改该值,方便验证。
echo 0x7f > /sys/devices/platform/soc/d4280800.sdh
注意: 动态修改必须在 WiFi 驱动加载之前完成,才能生效。
debugfs
常用于查询 SDIO 的工作状态,包括频率,位宽,模式等信息。
cat /sys/kernel/debug/mmc1/ios
clock: 204800000 Hz
actual clock: 187500000 Hz
vdd: 21 (3.3 ~ 3.4 V)
bus mode: 2 (push-pull)
chip select: 0 (don't care)
power mode: 2 (on)
bus width: 2 (4 bits)
timing spec: 6 (sd uhs SDR104)
signal voltage: 1 (1.80 V)
driver type: 0 (driver type B)