Android BLE HIDS Data ,从问询DB 到写入Android 节点的flow 之五

问题点 7 关于BLE HIDS data 写入到Android 节点"/dev/uhid"的flow

关于BLE中的HIDS,首先我们需要理解好角色的定义:

GATT Server 作为HID Service 提供者,对应HID Device角色;

GATT Client 作为BLE的主动连接发起方,对应HID Host角色;

Android BT中的BlueDroid 部分,关于HID Host Le的处理和BR/EDR HID Host 同一个文件夹下,为bta_hh_le.cc

 需注意的是:HIDS 中的Report Descriptor是通过BLE ”Read Request”指令获取到;

如游戏手柄的按键信息,是通过Notification 形式发送到GATT Client(手机端)

当收到Notification时,最终通过bta_hh_co_writereportAndroid

-->当收到Notification时,触发API bta_hh_le_input_rpt_notify,内部直接调用

bta_hh_co_data,最终通过bta_hh_co_writereport到Android 节点"/dev/uhid"

比较特别的是:其在收到的Report Len中,自行附上了一个Report ID值;

附上Report ID值后,基本和BR/EDR HID一样的数据格式“Report ID + Data”

最后总结:

BLEHID操作Android 节点"/dev/uhid"实现,相比BR/EDR HID其没有GET_REPORT等指令操作,只需Open后,通过API bta_hh_co_send_hid_info 把Report Map 写入到Android 节点,然后再把 UUID 为0x2A4D 所对应的Value Handle 接收到的Notification 通过 API bta_hh_co_data写入,但这里写Report DataBR/EDR HID的最大差异是:Notification中的Report Data 是不带Report ID的,需要我们在收到HID Report 的Notification后,自行组合为“Report ID + Report Data”形式再调用API bta_hh_co_data;

而Report ID的识别是在Report Map中解析得到,我们目前使用“Report ID +Data长度”形式进行识别,例如:加入当前我们识别到两个Report ID 分别对应不同的长度,那么在收到Notification时通过匹配Data长度来决定使用哪一个Report ID(如果Report Map中不同Report ID 所对应的Data 长度一致,将无法识别,但这里没有其他办法进行识别);

Note:如果Report MAP 中没有Report ID,此时需默认Report ID 0

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 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[email protected]进程加载 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、付费专栏及课程。

余额充值