实战案例分享:Android WLAN Hal层移植(MTK+QCA6696)

本文将详细介绍基于MTK平台,适配高通(Qualcomm)QCA6696芯片的Android WLAN HAL层的移植过程,包括HIDL接口定义、Wi-Fi驱动移植以及wpa_supplicant适配过程,涵盖STA与AP模式的常见问题与解决方法。

1. HIDL接口简介

HIDL(HAL Interface Definition Language)是一种用于定义Android HAL层与Framework之间接口的描述语言(IDL),其核心目的是隔离Framework与厂商提供的HAL实现,使得Framework更新时,无需重新编译厂商的HAL组件。厂商可独立编译并在Vendor分区中单独更新。

HIDL架构

HIDL架构由接口定义、服务端(Server)和客户端(Client)三部分构成。
  • 接口定义(Interface):.hal文件,定义接口及其方法。
  • 服务端(Server):实现HIDL接口,接收客户端调用并返回数据。
  • 客户端(Client):调用服务端提供的接口。
Android 8.0以前,HAL以.so库形式与Framework同进程运行;8.0之后则分属不同进程,通过HIDL进行通信。

2. HIDL的关键文件

HIDL相关的重要文件包括:
  • .hal接口定义文件,如IWifi.hal等以.hal为结尾的文件都是自己创建添加的。这里定义一些未实现的接口。

  • 根据.hal生成的.cpp和.h文件,每对这个文件都是根据前面的.hal生成的,这对文件是实现接口的关键文件。

  • 相关服务启动文件,如android.hardware.wifi@1.0-service.rc、service.cpp。
  • 构建文件,如Android.mk、Android.bp是用Andriod提供的工具生成
以setcountrycode为例:frameworks\opt\net\wifi\service\java\com\android\server\wifi\WifiNative.java

frameworks\opt\net\wifi\service\java\com\android\server\wifi\SupplicantStaIfaceHal.java

hardware\interfaces\wifi\supplicant\1.0\ISupplicantStaIface.hal

external\wpa_supplicant_8\wpa_supplicant\hidl\1.1\sta_iface.cpp

3. 移植(STA部分)

Wi-Fi驱动中的wpa_supplicant不是使用的HIDL,换句话说不是为了Andriod设计的,所以我们要使用MTK平台原生的wpa_supplicant。
boardconfig.mk的修改,这里面用到的宏尽量保持和在高通平台用的一致。
准备适配高通的wpa_supplciant时出现问题,关键在于高通的这个wpa_supplicant用的是1.2的,要改成和原来适配的1.1,像下面的报错就是wpa_supplicant中客户端调用的hidl接口没有完全满足。
这个时候就去external\wpa_supplicant_8\wpa_supplicant\hidl\1.1下面去把这些声明加上吗,这是一个比较耗时的操作。
遇到下面这个问题时,换个ctrl_interface
09-01 06:26:22.755 3699 3699 E wpa_supplicant: mkdir[ctrl_interface=/var/run/wpa_supplicant]: No such file or directory
09-01 06:26:22.755 3699 3699 E wpa_supplicant: Failed to initialize control interface '/var/run/wpa_supplicant'.
如下:
ctrl_interface=/data/vendor/wifi/wpa/sockets
#ctrl_interface=/var/run/wpa_supplicant
因为我们执行wpa_cli默认的接口是/var/run/wpa_supplicant,当我们执行wpa_cli时就会去这个接口里找socket,所以此时应该指定接口:
wpa_cli -i wlan0 -p /data/vendor/wifi/wpa/sockets # 这个ctrl_interface只是创建了一个sockets给用户侧交互而已。
把Wi-Fi驱动名字换成wlan.ko,否则会报类似下面的错误:
在我第一天把STA模式导通后,后面导通完AP模式,再来看STA模式时,发现总是报下面的log,找不到原因。
然后就代码跟进去一行一行的看,才发现是以下导致的。
我首先发现以下不对,我是从界面上点击Wi-Fi按钮,log中也能看到WLAN0口起来了
09-16 07:43:01.267 2410 2410 E wificond: :p2p0:wlan0
09-16 07:43:01.267 2410 2410 E wificond: :wlan0:wlan0
为什么下面的代码走的是IfaceType::P2P的分支??
进一步追代码可知,在supplicant.cpp中通过调用wpa_supplicant_get_iface来获取global 接口,默认接口被p2p填充了,而在p2p_supplciant.c中能看到若p2p_disabled参数没有被定义,则p2p会把整个init流程走下来。也就是出问题的点。
而最根本的原因是wpa_supplicant_overlay.conf不知道什么原因没有了,所以得把这个文件加在下面默认的目录下/vendor/etc/wifi/,然后在wpa_supplicant_overlay.conf中会默认定义p2p_disabled=1。
Supplicant.cpp:
constexpr char kStaIfaceConfOverlayPath[] ="/vendor/etc/wifi/wpa_supplicant_overlay.conf";
下面是正常Log(左侧)和异常Log(右侧)的对比。
下面是正常Log:
09-17 05:20:22.112 2912 2912 E wpa_supplicant: Initializing interface 'wlan0' conf '/data/vendor/wifi/wpa/wpa_supplicant.conf' driver 'nl80211' ctrl_interface 'N/A' bridge 'N/A'
09-17 05:20:22.112 2912 2912 E wpa_supplicant: Configuration file '/data/vendor/wifi/wpa/wpa_supplicant.conf' -> '/data/vendor/wifi/wpa/wpa_supplicant.conf'
09-17 05:20:22.112 2912 2912 D wpa_supplicant: Reading configuration file '/data/vendor/wifi/wpa/wpa_supplicant.conf'
09-17 05:20:22.112 2912 2912 D wpa_supplicant: update_config=1
09-17 05:20:22.112 2912 2912 D wpa_supplicant: eapol_version=1
09-17 05:20:22.113 2912 2912 D wpa_supplicant: ap_scan=1
09-17 05:20:22.113 2912 2912 D wpa_supplicant: fast_reauth=1
09-17 05:20:22.113 2912 2912 D wpa_supplicant: pmf=1
09-17 05:20:22.113 2912 2912 D wpa_supplicant: p2p_add_cli_chan=1
09-17 05:20:22.113 2912 2912 D wpa_supplicant: Reading configuration file '/vendor/etc/wifi/wpa_supplicant_overlay.conf'
09-17 05:20:22.113 2912 2912 D wpa_supplicant: disable_scan_offload=1
09-17 05:20:22.113 2912 2912 D wpa_supplicant: p2p_disabled=1

4. 移植(AP部分)

1、AP部分:出现下面的log时,把hostapd.conf中的下面参数注释掉
#ctrl_interface_group=radio
09-10 08:45:53.858 3720 3720 D hostapd : Using existing control interface directory.
09-10 08:45:53.858 3720 3720 E hostapd : billy ctrl_interface_gid_set:1,ctrl_interface:/data/vendor/wifi/wpa/sockets,ctrl_interface_gid:1001,ctrl_iface_group:0
09-10 08:45:53.858 3720 3720 E hostapd : billy1 lchown[ctrl_interface]: Operation not permitted
09-10 08:45:53.858 3720 3720 E hostapd : Failed to setup control interface for wlan0
2、出现下面的权限问题时chmod 777 /sys/module/wlan/parameters/fwpath
3、解决完了会遇到下面的问题。
09-10 10:52:23.461 4043 4043 E android.hardware.wifi@1.0-service: Unknown iface name: ap0
我在hardware/interface下面发现createApIfaceInternal里面获取interface时直接写死成了ap0,不知道是不是MTK的操作。Ap0我们是没有这样的接口的,把它释放后,上面的错误就OK了。
下面是起AP时起的wlan0口。
09-15 00:43:38.992 2579 2677 I WifiNative: Interface state changed on Iface:{Name=wlan0,Id=16,Type=AP}, isUp=true
09-15 00:43:38.992 2579 2677 I WifiNative: Successfully setup Iface:{Name=wlan0,Id=16,Type=AP}

5. 总结

通过上述方法和注意点,能顺利完成MTK平台对QCA6696 WLAN HAL层的移植。整体改下来,主要是改的wpa_supplciant下面的hidl和.c部分,比较少改动hardware/interface/下面,没有改动framework部分。
也就是说主要改的是HIDL 的server端,即接收hidl调用并返回数据的一方,client端怎么调用那是固定好的,比如在该获取interface的时候我们不管它怎么调,我能保证我返回的interface可用就行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/72712.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Greenplum6.19集群搭建

一,安装说明 1.1环境说明 1、首先确定部署的环境,确定下服务器的端口,一般默认是22的端口; 2、当前这份文档是服务器处于10022端口下部署的(现场生产环境要求,22端口在生产环境存在安全隐患)&…

电商项目-秒杀系统(四)秒杀异步下单防止重复秒杀

一、 防止恶意刷单解决 在生产场景下,可能会有一些人会恶意访问当前网站,来进行恶意的刷单。这样会造成当前系统出现一些业务上的业务混乱,出现脏数据,或者造成后端访问压力大等问题。 一般要解决这个问题的话,前端可…

原生android 打包.aar到uniapp使用

1.原生安卓里面引入uniapp官方提供的包文件: uniapp-v8-release.aar 2.提供uniapp调用的接口,新建类文件继承UniModule, package com.dermandar.panoramal;import com.scjt.lib.certlib;import io.dcloud.feature.uniapp.annotation.UniJSM…

Android 多用户相关

Android 多用户相关 本文主要记录下android 多用户相关的adb 命令操作. 1: 获取用户列表 命令: adb shell pm list users 输出如下: Users:UserInfo{0:机主:c13} running默认只有一个用户, id为0 ,用户状态为运行 2: 创建新用户 命令: adb shell …

基于Spring Boot的高校就业招聘系统的设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导,欢迎高校老师/同行前辈交流合作✌。 技术范围:SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容:…

前端安全面试题汇总及参考答案

目录 简述 XSS 攻击的原理及三种常见类型(存储型、反射型、DOM 型) 如何在前端防御 XSS 攻击?列举编码、过滤、CSP 策略的具体实现方式 富文本编辑器场景下如何安全处理用户输入的 HTML 内容? 如何通过 HttpOnly 属性增强 Cookie 安全性?它与 XSS 防御的关系是什么? …

Linux驱动开发(1.基础创建)

序言:从高层逻辑到底层硬件的回归 在当今的软件开发中,我们习惯于用高级语言构建抽象层——通过框架、库和云服务快速实现功能。这种“软逻辑”的便利性让开发效率倍增,却也逐渐模糊了我们对计算机本质的认知:一切代码终将落地为…

Gradle本地配置文件分享

Gradle本地配置文件分享 allprojects {repositories {mavenLocal()maven { name "Alibaba" ; url "https://maven.aliyun.com/repository/public" }maven { name "Bstek" ; url "https://nexus.bsdn.org/content/groups/public/" }ma…

deepseek 本地部署

deepseek 本地部署 纯新手教学,手把手5分钟带你在本地部署一个私有的deepseek,再也不用受网络影响。流畅使用deepseek!!! 如果不想看文章,指路:Deep seek R1本地部署 小白超详细教程 &#xff0…

HTML学习笔记(全)

基本结构 <!DOCTYPE html> <html> <head><meta charset"UTF-8"><title></title> </head> <body></body> </html> 基本标签元素 标题&#xff08;heading&#xff09; <h1>一级标题</h1> &…

腾讯云对象存储服务(COS)

腾讯云对象存储服务&#xff08;COS&#xff09; 安全、可扩展、低成本的云存储解决方案 腾讯云 对象存储服务&#xff08;COS&#xff0c;Cloud Object Storage&#xff09; 是一种高可靠、高性能、可扩展的云存储服务&#xff0c;专为海量非结构化数据&#xff08;如图片、…

从ETL到数仓分层:大数据处理的“金字塔”构建之道

在当今数据驱动的时代&#xff0c;大数据处理已成为企业决策和业务优化的核心。而ETL&#xff08;Extract, Transform, Load&#xff09;作为数据处理的基石&#xff0c;其背后的数仓分层理念更是决定了数据处理的效率与质量。本文将深入探讨ETL工作中的数仓分层理念&#xff0…

数字孪生对于新基建的价值浅析,算是抛砖引玉。

数字孪生&#xff08;Digital Twin&#xff09;作为一项融合物理世界与数字世界的关键技术&#xff0c;在新基建中扮演着虚实协同、智能决策、全生命周期管理的核心角色&#xff0c;其价值贯穿于基础设施的设计、建设、运维到优化全流程。 一、核心价值&#xff1a;虚实映射与智…

从零开始实现大语言模型(十三):预训练大语言模型GPTModel

1. 前言 使用梯度下降算法通过下一个token预测任务预训练大语言模型GPTModel&#xff0c;前向传播流程每次会输入一个batch的长度均为context_len的训练样本&#xff0c;执行 batch_size context_len \text{batch\_size}\times\text{context\_len} batch_sizecontext_len次下…

QWQ大模型评测榜单

评测榜单说明 在数学推理基准AIME24上&#xff0c;QwQ-32B达到了79.5分&#xff0c;几乎与DeepSeek-R1-617B的79.8分持平&#xff0c;远超OpenAI o1-mini的63.6分&#xff0c;及相同尺寸的R1蒸馏模型。 在编程能力方面&#xff0c;QwQ-32B 在LiveCodeBench上获得了63.4分&…

bash: uwsgi: 未找到命令

针对你提出的“bash: uwsgi: command not found”问题&#xff0c;以下是一些可能的解决方案&#xff0c;请按照步骤逐一排查&#xff1a; ‌1、检查uwsgi命令是否正确‌&#xff1a; 确保你输入的命令是uwsgi&#xff0c;而不是uWSGI或其他变体。 ‌2、确认uwsgi是否已安装‌&…

超图(Hypergraph)

超图&#xff08;Hypergraph&#xff09;是图结构学习&#xff08;Graph Learning&#xff09;中的一种扩展形式&#xff0c;它比传统图&#xff08;Graph&#xff09;更具表达能力&#xff0c;适用于建模复杂的多元关系。 超图是一种由 超节点&#xff08;Hypernodes&#xff…

PyTorch中的线性变换:nn.Parameter VS nn.Linear

self.weight nn.Parameter(torch.randn(in_channels, out_channels)) 和 self.linear nn.Linear(in_channels, out_channels) 并不完全一致&#xff0c;尽管它们都可以用于实现线性变换&#xff08;即全连接层&#xff09;&#xff0c;但它们的使用方式和内部实现有所不同。 …

鸿蒙生态日日新,夸克、顺丰速运、驾校一点通等多款应用功能更新

3月5日鸿蒙生态日日新PLOG&#xff1a;吉事办、健康甘肃等政务服务App上架原生鸿蒙应用市场&#xff1b;夸克、顺丰速运、驾校一点通等多款应用功能更新。

基于SpringBoot的智慧停车场小程序(源码+论文+部署教程)

运行环境 • 前端&#xff1a;小程序 Vue • 后端&#xff1a;Java • IDE工具&#xff1a;IDEA&#xff08;可自行选择&#xff09; HBuilderX 微信开发者工具 • 技术栈&#xff1a;小程序 SpringBoot Vue MySQL 主要功能 智慧停车场微信小程序主要包含小程序端和…