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

我尝试过蓝牙LE广告,即使用Android手机作为BLE“外围设备”。 启动和停止持续广告一旦正常工作但如果我想实际传输一些不同的数据,我需要在一个周期内启动,停止和重新启动广告,并始终更改广告包。

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

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

我的问题是:这是否也发生在摩托罗拉以外的其他设备上?

(当然,欢迎任何其他相关评论。)

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

这个测试应用程序 可以用来试试这个:

https://bitbucket.org/MarkusKauppinen/bleadvertisertest

如果一切顺利,它将乐意继续广告,如果这个问题再现,它将在几分钟左右的时间内显示一个对话框。 如果您的设备根本不支持蓝牙LE广告或BLE,它就会崩溃。 (这只是一个快速而肮脏的测试应用程序。)

另一种简单的方法是从https://github.com/devunwired/accessory-samples运行“bluetoothadvertiser”应用程序,并快速点击UI上的“更新广告”按钮一段时间。

额外细节:

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

https://altbeacon.github.io/android-beacon-library/beacon-transmitter-devices.html 支持Android 5 BLE外设模式 芯片 组的芯片组/设备支持Android 5上的 BLE外设角色

例如,这些设备应该得到支持:摩托罗拉Moto E 4G(2015),摩托罗拉Moto G 4G(第二代),索尼Xperia M4 Aqua,中兴Blade S6,摩托罗拉Moto X(2014),三星Galaxy S6,谷歌Nexus 6 ,谷歌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? ### ASSERT:external / bluetooth / 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=1753
扫描大量BLE标签
三星S4上的蓝牙崩溃

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

我在运行Android 6.0的Nexus 9平板电脑上试过它,在那里我无法重现错误,它似乎工作。 同样在Android 5.1.1的nexus播放器上,它似乎运行没有问题。 所以要么它真的是Moto G的一个问题,要么 – 我认为更有可能 – 在以后的版本中解决了Android 5.0.2的错误。