【问题标题】:BLE: Relationship between MTU and maximum characteristic size?BLE:MTU 和最大特征尺寸之间的关系?
【发布时间】:2018-01-15 06:45:38
【问题描述】:

如何找出低功耗蓝牙 (BLE) 中 MTU 和最大特征尺寸之间的关系?

我有一个运行“回声”程序的 BLE 开发板 - 所以无论它收到什么,它都会立即回复。

在我的 Android 设备上,如果我请求 247 字节的 MTU(成功),然后写入 247 字节的特征,它将作为两个数据包发送:一个具有 242 字节,一个具有 5 字节。任何写入超过 244 字节的特征的尝试都会导致 2 个数据包 - 第一个具有 242 字节,第二个具有剩余字节。不知道为什么第一个数据包的长度是 242 字节而不是 244,但确实如此。

如果我请求一个 100 字节的 MTU,则会发生同样的事情,但是当特征长度超过 97 字节时数据包会被拆分,并且第一个数据包总是 95 字节长。

所以很明显,在这个特定的 Android 设备上,最大数据包长度比 MTU 值短 3 个字节。我在 iOS 上看到过有关 MTU 的页面,其中数据包长度比 MTU 值短 3 个字节。

我是否保证在所有移动设备和所有 BLE 实现上 MTU 和最大特征长度之间的差异为 3 个字节?

【问题讨论】:

    标签: android ios bluetooth bluetooth-lowenergy


    【解决方案1】:

    几乎。 ATT 头由一个字节的操作码和两个字节的 ATT 句柄组成。如果您使用“Write Long Characteristic Values”,还有一个两字节偏移参数。如果您使用“无响应签名写入”过程(没有人使用并且几乎没有堆栈支持),那么还有一个 12 字节的签名。

    另请注意,最大特征长度为 512 字节。然而,允许的最大 MTU 为 65535 字节。无论您的 MTU 有多大,您都不能写入大于 512 字节的特征值。

    如果您对 ATT 协议的底层细节感兴趣,可以阅读蓝牙核心规范https://www.bluetooth.com/specifications/bluetooth-core-specification,第 3 卷 F 部分。

    【讨论】:

    • Emil 很好,只是补充一点:有效负载中的开销对于写入特性(3 字节)和读取特性(1 字节)是不同的。
    猜你喜欢
    • 1970-01-01
    • 2013-12-23
    • 1970-01-01
    • 2017-06-29
    • 1970-01-01
    • 2020-08-20
    • 2016-10-27
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多