RK3588-WIF/BT调试之AP6256 新动态

2024-9-21 19:51:01来源:jf_30051736

一、简介

专栏总目录AP6256是正基科技推出的一款低成本,低功耗的双模模块。是一款SDIO接口单通道802.11ac双频支持BT5.0 蓝牙WiFi二合一【yī】模块【kuài】。Model:AP6256:SDIO WIFI + UARTBTChip:BCM43456WiFi:2.4G&5GBT:5.0WIFI Throughput:up:196 Mbits/sec down: 187 Mbits/sec

二、DTS配置

2.1 配置SDIO

/* SDIO接口Wi-Fi专用配置【zhì】:SDIO接口节点 */&sdio {max-frequency = < 150000000 >;  /* sdio接口的最大频【pín】率,可调整【zhěng】 */supports-sdio;bus-width = < 4 >;    /* 4线模式,可调整1线模式【shì】 */disable-wp;cap-sd-highspeed;cap-sdio-irq;keep-power-in-suspend;mmc-pwrseq = < &sdio_pwrseq >;non-removable;num-slots = < 1 >;pinctrl-names = "default";pinctrl-0 = < &sdiom0_pins >;sd-uhs-sdr104;     /* 支持SDIO3.0 */status = "okay";};

2.2 WIFI的配置

WIFI_REG_ON: Wi-Fi的电源使能PIN脚配置 ( 控制【zhì】WIFI模块电源【yuán】的【de】GPIO )WL_REG_ON由sdio_pwrseq节点进行管理控制,不【bú】需【xū】要【yào】在wireless-wlan节点下面重复添【tiān】加WIFI,poweren_gpio配置;
/* SDIO接口Wi-Fi专用【yòng】配置: WIFI_REG_ON: Wi-Fi的【de】电源【yuán】使能PIN脚 */sdio_pwrseq: sdio-pwrseq {compatible = "mmc-pwrseq-simple";clocks = < &hym8563 >;clock-names = "ext_clock";pinctrl-names = "default";pinctrl-0 = < &wifi_enable_h >;reset-gpios = < &gpio0 RK_PC4 GPIO_ACTIVE_LOW >;  /*跟【gēn】电源使能状态恰好相反【fǎn】:高有效【xiào】为LOW,低有效【xiào】则为HIGH。切记:这个【gè】配置跟下面的WIFI,poweren_gpio是互斥【chì】的,不【bú】能同时配置【zhì】!!!*/ /*特别注【zhù】意:reset-gpios的【de】GPIO_ACTIVE 配置跟poweren_gpio配置的【de】电源【yuán】使能状态恰好是相反的*/};/* SDIO接口Wi-Fi专用配置【zhì】:WIFI_REG_ON脚的pinctrl的【de】配置 */&pinctrl {sdio-pwrseq {wifi_enable_h: wifi-enable-h {rockchip,pins = < 0 RK_PC4 RK_FUNC_GPIO &pcfg_pull_none >;  /* 对应上面的WIFI_REG_ON,关掉上下【xià】拉,防【fáng】止不【bú】能拉【lā】高或拉低 */};};}
WIFI节点配置
/* Wi-Fi节点 */wireless_wlan: wireless-wlan {compatible = "wlan-platdata";wifi_chip_type = "ap6256";        //模块名称【chēng】pinctrl-names = "default";pinctrl-0 = < &wifi_host_wake_irq >;WIFI,host_wake_irq = < &gpio0 RK_PB2 GPIO_ACTIVE_HIGH >;     //WIFI模块唤醒CPU的//WIFI,poweren_gpio = < &gpio0 RK_PC4 GPIO_ACTIVE_HIGH >;    //控【kòng】制【zhì】WIFI模块电源的GPIO,配置了sdio_pwrseq就【jiù】不需要再配置poweren_gpio status = "okay";};
WIFI,host_wake_irq的配置说明:
WIFI,host_wake_irq = < &gpio0 RK_PB2 GPIO_ACTIVE_HIGH >; /* WIFI_WAKE_HOST: Wi-Fi中【zhōng】断通【tōng】知主控的PIN脚。* 特【tè】别【bié】注意:确认下【xià】这个Wi-Fi pin脚跟主控的【de】pin的硬件连接关系,直连的话就是GPIO_ACTIVE_HIGH;* 如果【guǒ】中间加了【le】一个【gè】反【fǎn】向管就要改成低电平GPIO_ACTIVE_LOW触【chù】发*/
WIFI_WAKE_HOST脚的pinctrl的配置:
&pinctrl {wireless-wlan {wifi_host_wake_irq: wifi-host-wake-irq {rockchip,pins = < 0 RK_PB2 RK_FUNC_GPIO &pcfg_pull_down >;};};}/* 注意【yì】一般Wi-Fi的wake host pin都是【shì】高电平【píng】触发,* 所以默认这里要配置为下拉; 如果【guǒ】客户的硬件设【shè】计【jì】* 是反向的则要【yào】改为上拉【lā】,总【zǒng】之要初始化为与触【chù】发电平* 相反【fǎn】的状态*/

2.3 蓝牙的配置

以下UART相关的都【dōu】要配置为实际使用的UART口的所【suǒ】对【duì】应【yīng】PIN,注意RTS/CTS pin一【yī】定要按照SDK设计


【资料图】

接【jiē】(具【jù】体【tǐ】接法参【cān】考7.3章节的UART描述),很多客户反馈的异常都【dōu】是因为这两个PIN脚没有【yǒu】接导致【zhì】初始化【huà】

异常,下面假设蓝牙使用UART4:

bt_uart6: wireless_bluetooth: wireless-bluetooth {compatible = "bluetooth-platdata";clocks = < &hym8563 >;                                     //外部时钟clock-names = "ext_clock"; uart_rts_gpios = < &gpio1 RK_PA2 GPIO_ACTIVE_LOW >;        //uart的rts脚pinctrl-names = "default", "rts_gpio";pinctrl-0 = < &uart6m1_rtsn >;pinctrl-1 = < &uart6_gpios >;BT,reset_gpio    = < &gpio3 RK_PA6 GPIO_ACTIVE_HIGH >;     //蓝牙【yá】的复位脚BT,wake_host_irq = < &gpio0 RK_PC5 GPIO_ACTIVE_HIGH >;     //蓝【lán】牙模块唤醒CPU的GPIOstatus = "okay";};&pinctrl {wireless-bluetooth {uart6_gpios: uart6-gpios {rockchip,pins = < 1 RK_PA2 RK_FUNC_GPIO &pcfg_pull_none >;};};}
蓝牙对应的uart6配置
/* 打开【kāi】对应的【de】UART配置【zhì】 */&uart6 {pinctrl-names = "default";/* 这里配置对应主控UART的【de】TX/RX/CTS PIN ,不要【yào】配置RTS PIN*/pinctrl-0 = < &uart6m1_xfer &uart6m1_ctsn >;status = "okay";};

三 、内核配置

3.1 WIFI配置:kernel配置defconfig

MK文件中【zhōng】定【dìng】义的Kernel defconfig:kernel的defconfig对【duì】应到这【zhè】个文件: "kernel\\arch\\arm64\\configs\\rockchip_linux_defconfig"
# Kernel defconfigexport RK_KERNEL_DEFCONFIG=rockchip_linux_defconfig
cd kernelmake ARCH=arm64 menuconfigmake savedefconfig

选择:Device Drivers ---> Network device support ---> Wireless LAN ---> Rockchip Wireless LAN support

Wi-Fi驱【qū】动可【kě】编译到内核或者ko方式, 切记【jì】下面两个配置必须【xū】二选一,否【fǒu】则【zé】Wi-Fi无法加载!

KO 配置:[* ] build wifi ko modules

CONFIG_WIFI_BUILD_MODULE=y# CONFIG_WIFI_LOAD_DRIVER_WHEN_KERNEL_BOOTUP is not set

buildin 配置:[* ] Wifi load driver when kernel bootup

CONFIG_WIFI_LOAD_DRIVER_WHEN_KERNEL_BOOTUP=y# CONFIG_WIFI_BUILD_MODULE is not set

buildin 只【zhī】能选择【zé】一个型【xíng】号,realtek 模组和【hé】 ap6xxx 模【mó】组不能同时选【xuǎn】择为y,且realtek的【de】也只能选择其

中一个;

ap6xxx 和 cypress也是互斥的,只能选择【zé】一个且如果选【xuǎn】择ap6xxx,cypress的配【pèi】置自动消失,去掉【diào】ap

配置,cypress自动出现;

ko方式则可以选择多个Wi-Fi

3.2 蓝牙配置:kernel配置defconfig

正【zhèng】基和【hé】海华的【de】模块使用内核的默认CONFIG_BT_HCIUART 驱动:
cd kernelmake ARCH=arm64 menuconfigmake savedefconfig

选择: Networking support ---> Bluetooth subsystem support ---> Bluetooth device drivers

注意:配置完成后要保存到对应的defconfig

四、Wi-Fi/BT的文件及更新及编译说明

4.1 查看板上生成的ko文件和firmware / nvram文件

正基/海华模组以AP6256为例:对应的Wi-Fi/BT的【de】firmware在SDK中的位置【zhì】:
external/rkwifibt/firmware/broadcom/AP6256/├── bt│ └── BCM4345C5.hcd└── wifi├── fw_bcm43456c5_ag.bin├── fw_bcm43456c5_ag_mfg.bin└── nvram_ap6256.txt
经过编【biān】译【yì】规则编译后,对应的文件被拷贝到【dào】工程的output目录:(kernel4.19内【nèi】核由system变【biàn】更为vendor目录【lù】)
buildroot/output/rockchip_rk3xxxx/target//system(vendor)/lib/modules/bcmdhd.ko #驱动ko(如【rú】果是ko编【biān】译的话【huà】)/system(vendor)/etc/firmware/fw_bcm43456c5_ag.bin #驱动firmware文件存放位置/system(vendor)/etc/firmware/fw_bcm43456c5_ag_mfg.bin #驱动【dòng】firmware文【wén】件存放位置/system(vendor)/etc/firmware/nvram_ap6256.txt #驱动nvram文【wén】件存【cún】放位置/system(vendor)/etc/firmware/BCM4345C5.hcd #蓝【lán】牙firmware文件(如果【guǒ】有蓝牙功能)
最终烧录到机器中后,Wi-Fi运行时所需的文件及存放位置:
/system(vendor)/lib/modules/bcmdhd.ko #驱【qū】动ko(如果是ko编译的话【huà】)/system(vendor)/etc/firmware/fw_bcm43456c5_ag.bin #驱动firmware文件存放位置/system(vendor)/etc/firmware/fw_bcm43456c5_ag_mfg.bin #驱【qū】动firmware文件存放位置/system(vendor)/etc/firmware/nvram_ap6256.txt #驱动【dòng】nvram文件【jiàn】存放位【wèi】置【zhì】/system(vendor)/etc/firmware/BCM4345C5.hcd #蓝【lán】牙firmware文件(如果有蓝牙功能)

4.2 编译配置说明

mk文【wén】件【jiàn】配【pèi】置路径:3588_linux5.10_v1.0.5/device/rockchip/rk3588/BoardConfig-rk3588-pi5.mk兼容正【zhèng】基和RealtekRK_WIFIBT_TTY这个参数【shù】根据蓝【lán】牙对应的串口来配置【zhì】,此处【chù】蓝牙对应的是uart6
# Define WiFi BT chip# Compatible with Realtek and AP6XXX WiFi : RK_WIFIBT_CHIP=ALL_AP# Compatible with Realtek and CYWXXX WiFi : RK_WIFIBT_CHIP=ALL_CY# Single WiFi configuration: AP6256 or CYW43455: RK_WIFIBT_CHIP=AP6256export RK_WIFIBT_CHIP=ALL_AP# Define BT ttySXexport RK_WIFIBT_TTY=ttyS6

审核编辑:汤梓红

为你推荐

最新资讯

股票软件