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

时间:2015-09-18 16:33:30

标签: android bluetooth-lowenergy android-bluetooth

我尝试过蓝牙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 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,谷歌Nexus 6,谷歌Nexus 9,HTC One M9,三星Galaxy S6 Edge。

至于“脏细节”,在此之前我总是可以在LogCat中看到“GKI_Exception”:

  

GKI_exception():65524 getbuf:out of buffers

在第一个“GKI_Exception”之后不久,广告以AdvertiseCallback.ADVERTISE_FAILED_INTERNAL_ERROR失败。这条线...

  

E / BtGatt.btif? ### ASSERT:   external / bluetooth / bluedroid / main /../ btif / src / btif_gatt_client.c line   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
Scanning large number of BLE Tags
Bluetooth Crash on Samsung S4

1 个答案:

答案 0 :(得分:2)

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

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