[Bluedroid] 蓝牙重新打开之后蓝牙鼠标(HOGP)大概率无法自动回连

1.问题现象

        在客户项目中遇见一个问题,有一部分蓝牙鼠标在与设备配对之后,关闭设备的蓝牙再重新打开之后,会出现大概率无法自动回连的问题。

2.问题分析

        由于是部分鼠标存在这种异常,对比多款不同蓝牙鼠标进行分析,发现问题复现的鼠标用的均为HOGP的方案。

        问题复现过程发现一个问题,当出现设备蓝牙重新打开之后再次搜索周边蓝牙设备可重新搜索到一个相同名称的蓝牙鼠标设备,再次配对连接之后通过设备页面发现前后的蓝牙鼠标MAC地址变了。

        那么问题已经很明显了,由于蓝牙鼠标的MAC地址发生改变,设备无法再次进行重连,这样似乎能解释的通。但是问题没有这么简单。客户使用复现问题的蓝牙鼠标配合其他平台进行对比发现,其他平台均未出现异常。

        BBQ了~~~~~,继续分析吧。

        已知蓝牙鼠标走的是HOGP,BLE总是由主设备发起连接。那么为什么没有连接成功呢?蓝牙鼠标又为何MAC会改变呢?有以下猜想:当蓝牙重新打开时设备端有主动回连的动作,但是在timeout内由于没有扫描到设备或者没有成功连接,蓝牙鼠标存在某种机制,MAC地址会发生变化,再次广播出去,好被其他新的设备发现。

        所以设备蓝牙重新打开时如何快速发现蓝牙鼠标以及回连呢?尝试了以下验证方案:

        1)换天线,在屏蔽房中测试,排查硬件上是否有影响。

        2)调整tag83中的射频功率为12dB,扫描范围更广,能更快发现设备

        3)以上验证方案均未成功,只能老老实实梳理代码流程。

3.问题解决方案

救命链接:蓝牙BLE设备回连流程_51CTO博客_ble 蓝牙

这篇博客很好的梳理了HOGP回连的流程,这块还是比较复杂的,如果没有参考可能会耗时比较久才能解决此问题。

最终在协议栈中ble backgrouund connect中调低扫描参数连接参数后解决此问题。我这个调的比较低了,各位如果遇到类似问题,可根据实际情况调整合理的值。

4.写在最后

个人小结,仅供参考,如若有误请留言讨论。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ble audio补丁原理是利用hidraw节点捕捉协议栈发送的语音数据,目前Android Blueroid将ble语音数据和按键信息通过hid发送出去,通过建立hidraw节点,可以从中捕捉到语音数据。目前通过ble hal实现从hidraw中读取遥控器语音数据,在Android框架层上就通过配置文件将ble hal导入到音频框架中,并通过绑定Android原生已有的耳麦设备来完成audio音频策略选择,通过apk检测ble连接状态,通知audio服务耳麦设备的状态就可以使得录音通路切换至ble hal,实现从ble获取录音数据功能。 打补丁前最好使用干净的环境,不要有别家方案ble补丁,否则可能会有不兼容问题。 补丁如若不能使用首先检查节点是否存在和其权限,正常节点权限如下: ls -l /dev/hidraw* crw-rw---- 1 system audio 241, 0 2018-12-18 13:42 /dev/hidraw0 audio用户组有读写权限。 2、如果selinux模式为Enforcing,可以通过logcat搜索avc关键字。有如下类似提示则为异常,提示进程没有权限,检查sepolicy是否设置正常: avc: denied { read } for name="/" dev="tmpfs" ino=6145 scontext=u:r:mediaserver:s0 tcontext=u:object_r:device:s0 tclass=dir permissive=0 //Android 5.0和6.0版本,audio hal被mediaserver进程加载 avc: denied { read } for name="/" dev="tmpfs" ino=8125 scontext=u:r:audioserver:s0 tcontext=u:object_r:device:s0 tclass=dir permissive=0 //Android 7.0版本,audio hal被audioserver进程加载 avc: denied { read } for name="hidraw" dev="sysfs" ino=16332 scontext=u:r:hal_audio_default:s0 tcontext=u:object_r:sysfs:s0 tclass=dir permissive=0 //Android 8.0和9.0版本,audio hal被android.hardware.audio@2.0-service进程加载 3、检查audio的配置,打上patch后,首先确认小机上文件是否有修改到,目前文件可能位于/vendor/etc或/system/etc目录下,其中/vendor/etc下的配置文件是优先解析的。确保文件无误后,通过dumpsys media.audio_policy查看ble hal是否正常加载。 以下是相关说明: AudioPolicyManager: 0xf20c5200 Command Thread: 0xf20af140 Tones Thread: 0xf20af020 ... - Available input devices: Device 1: - id: 3 - type: AUDIO_DEVICE_IN_BUILTIN_MIC - Profiles: Profile 0: - format: AUDIO_FORMAT_PCM_16_BIT - sampling rates:8000, 11025, 12000, 16000, 22050, 24000, 32000, 44100, 48000 - channel masks:0x000c, 0x0010 Device 2: - id: 20 - type: AUDIO_DEVICE_IN_WIRED_HEADSET //对应的数值是0x80000010 - name: RemoteDM1204 - Profiles: Available input devices指示当前可用设备,目前ble hal是和AUDIO_DEVICE_IN_WIRED_HEADSET设备绑定,如果需要录音走ble hal,AUDIO_DEVICE_IN_WIRED_HEADSET设备必须出现在可用设备中,如果没有,就可能是补丁中hidaudio.apk的问题。 HW Modules dump: ... - H
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值