循环启动和停止时蓝牙 LE 广告失败

Posted

技术标签:

【中文标题】循环启动和停止时蓝牙 LE 广告失败【英文标题】:Bluetooth LE advertising fails when started and stopped cyclically 【发布时间】:2015-09-18 16:33:30 【问题描述】:

我已经尝试过蓝牙 LE 广告,即将 android 手机用作 BLE“外围”设备。启动和停止持续的广告一次效果很好,但如果我想实际传输一些不同的数据,我需要循环启动、停止和重新启动广告,并始终更改广告包。

我当然使用这些方法:BluetoothLeAdvertiser.startAdvertising()BluetoothLeAdvertiser.stopAdvertising()

至少在摩托罗拉 Moto G 4G 第二代上。 (XT1072) 与 Android 5.0.2 的循环仅运行一段时间,然后蓝牙堆栈出现问题,无法再开始新的广告。当快速运行循环时,这种情况很快发生,如果运行缓慢,则需要更多时间,因此可能与某些缓冲区已满有关。

我的问题是:除摩托罗拉以外的其他设备上是否也会发生这种情况?

(当然欢迎任何其他相关的 cmets。)

理论上它可能取决于某些制造商特定的 HAL 实施等,所以我想知道我是否应该让另一台设备能够解决这个问题,因为谷歌/摩托罗拉的任何修复都需要一些时间.

这个测试应用。可以用来试试这个:

https://bitbucket.org/MarkusKauppinen/bleadvertisertest

如果一切顺利,它会很高兴地一直做广告,如果这个问题再次出现,它会在几分钟左右显示一个对话框。如果您的设备根本不支持蓝牙 LE 广告或 BLE,它只会崩溃。 (这只是一个快速而肮脏的测试应用程序。)

另一种重现此问题的简单方法是从https://github.com/devunwired/accessory-samples 运行“bluetoothadvertiser”应用程序,然后快速点击 UI 上的“更新广告”按钮一会儿。

其他细节:

在 Lollipop 中添加了蓝牙 LE 外围模式支持(广告需要),但在 4.x 中不可用。只有某些设备具有外围模式支持。兼容性至少包含在:

https://altbeacon.github.io/android-beacon-library/beacon-transmitter-devices.html Chipsets/Devices supporting Android 5 BLE peripheral mode chipsets supporting BLE peripheral role on Android 5

例如,这些设备应该支持:摩托罗拉 Moto E 4G (2015)、摩托罗拉 Moto G 4G(第二代)、索尼 Xperia M4 Aqua、中兴 Blade S6、摩托罗拉 Moto X (2014)、三星 Galaxy S6、 Google Nexus 6、Google Nexus 9、HTC One M9、三星 Galaxy S6 Edge。

至于“肮脏的细节”,在这种情况发生之前,我总是可以在 LogCat 中看到“GKI_Exception”:

GKI_exception(): 65524 getbuf: 缓冲区不足

在第一个“GKI_Exception”之后不久,广告失败并出现 AdvertiseCallback.ADVERTISE_FAILED_INTERNAL_ERROR。线...

E/BtGatt.btif? ### 断言: 外部/蓝牙/bluedroid/main/../btif/src/btif_gatt_client.c 行 803 上下文传输失败! (3) ###

...可能是相关的,但我不熟悉 BlueDroid。所说的断言在这里:

https://android.googlesource.com/platform/external/bluetooth/bluedroid/+/android-5.0.2_r1/btif/src/btif_gatt_client.c#803

一些可能相关的问题:https://code.google.com/p/android/issues/detail?id=65455 https://code.google.com/p/android-developer-preview/issues/detail?id=1753Scanning large number of BLE TagsBluetooth Crash on Samsung S4

【问题讨论】:

我在使用 5.1 的 Moto G XT1032 和使用 5.0.2 的 Moto G XT1063 时遇到了类似的问题。我正在尝试扫描 -> 连接 -> 读取特征 -> 断开连接 -> 再次扫描,但重新启动扫描时会失败。您找到解决方案了吗? 很遗憾没有找到解决方案。 【参考方案1】:

我在 Moto G 2nd Gen 上测试了您的应用并遇到了同样的问题。

我在运行 Android 6.0 的 Nexus 9 平板电脑上进行了尝试,但我无法重现该错误,但它似乎可以正常工作。同样在带有 Android 5.1.1 的 nexus 播放器上,它似乎可以毫无问题地运行。 所以要么这真的是 Moto G 的问题,要么 - 我认为更有可能 - Android 5.0.2 的错误已在更高版本中得到解决。

【讨论】:

以上是关于循环启动和停止时蓝牙 LE 广告失败的主要内容,如果未能解决你的问题,请参考以下文章

Xamarin IOS 蓝牙 LE 广告

蓝牙双 LE 和经典模式标志

在 LE 读取远程使用的功能时,树莓派的蓝牙连接失败

蓝牙 LE iOS 无法在后台扫描

Android蓝牙LE:连接后未发现服务

通过 disassemble manucaftures 库从蓝牙 le scale 获取重量数据