【问题标题】:Advertise Bluetooth LE Service using HCITool使用 HCITool 宣传蓝牙 LE 服务
【发布时间】:2016-06-22 16:15:03
【问题描述】:

我正在尝试在我的 Linux 计算机上创建一个低功耗蓝牙外围设备(目标是通过蓝牙从 iPhone 发送数据)。我目前正在使用工具hciconfighcitoolhcidump

我目前的实验是宣传具有特定 UUID 的服务,iOS CoreBluetooth 库将获取该服务。 (注意:我不是要创建 iBeacon)。

现在,它实际上就像困扰我的一个单一命令一样简单。

hcitool -i hci0 cmd 0x08 0x0008 15 02 01 1a 11 07 41 42 43 44 45 46 47 48 49 4a 4b 4c 4d 4e 4f 50

我认为它应该做的如下:

  • 0x08:将组设置为 BLE
  • 0x0008:将命令设置为 HCI_LE_Set_Advertising_Data

  • 0x15:将Header中的有效字节长度设置为21。(3字节用于标志包,18字节用于服务结构)
  • 0x02:将标志结构的长度设置为 2 个字节
  • 0x01:将结构类型设置为 AD 标志
  • 0x1a:标志值:

    bit 0 (OFF) LE Limited Discoverable Mode
    bit 1 (ON) LE General Discoverable Mode
    bit 2 (OFF) BR/EDR Not Supported
    bit 3 (ON) Simultaneous LE and BR/EDR to Same Device Capable (controller)
    bit 4 (ON) Simultaneous LE and BR/EDR to Same Device Capable (Host)
    

(标志结束)

  • 0x11 设置服务结构长度为17字节
  • 0x07 将结构类型设置为 128 位完整服务 UUID 列表
  • 0x41 ... 0x50 将测试服务的 UUID 设置为 ABCDEFGHIJKLMNOP

据我所见,hcidump 已正确执行并且看起来像我想要的那样。但它被错误拒绝:

LE Set Advertising Data (0x08|0x0008) ncmd 1
status 0x12
Error: Invalid HCI Command Parameters

我已经花了一整天的时间试图让它正确。有技术人员看到我做错了吗?这是宣传服务的正确方式吗?

(感兴趣的读者的上下文:我已经成功地使用 NodeJs 中的 Bleno 库完成了我想做的事情。但是,这不适合我们系统的大局。直接使用 HCITool 进行广告只是为了实验和后面会用Python写)

【问题讨论】:

    标签: bluetooth-lowenergy gatt bluetooth-peripheral


    【解决方案1】:

    HCI_LE_Set_Advertising_Data 有效负载的长度应该正好是 32 字节。尝试对命令进行零填充以达到 32 个字节:

    hcitool -i hci0 cmd 0x08 0x0008 15 02 01 1a 11 07 41 42 43 44 45 46 47 48 49 4a 4b 4c 4d 4e 4f 50 00 00 00 00 00 00 00 00 00 00
    

    您可以使用hcidump --raw. 获得更多见解 比较原始命令的输出:

    $hcidump --raw
    HCI sniffer - Bluetooth packet analyzer ver 5.30
    device: hci0 snap_len: 1500 filter: 0xffffffffffffffff
    < 01 08 20 16 15 02 01 1A 11 07 41 42 43 44 45 46 47 48 49 4A 
      4B 4C 4D 4E 4F 50 
    > 04 0E 04 01 08 2
    

    用零填充一个:

    HCI sniffer - Bluetooth packet analyzer ver 5.30
    device: hci0 snap_len: 1500 filter: 0xffffffffffffffff
    < 01 08 20 20 15 02 01 1A 11 07 41 42 43 44 45 46 47 48 49 4A 
      4B 4C 4D 4E 4F 50 00 00 00 00 00 00 00 00 00 00 
    > 04 0E 04 01 08 20 00 
    

    另一种获得更多洞察力的方法是运行 hciconfig hci0 leadv 并使用 hcidump --raw 检查 hciconfig 发送的 SET_ADVERTISING_PARAMETERS 命令的负载。

    顺便说一句,我注意到有时非零填充命令也可以工作,这可能取决于您使用的 bluez 版本。

    【讨论】:

    • 我向您的专业知识低头。我之前尝试过零填充,但我猜当时还有其他问题。
    • 对于 hcidump --raw 部分,我使用的是 -X,它以 ascii 和 hex 打印...使用 raw 有什么好处吗?
    • -X 更好我猜 :)
    • 如我所愿,太好了:)
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-11-30
    • 2017-10-26
    • 2013-10-25
    • 1970-01-01
    相关资源
    最近更新 更多