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
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值