博客專欄

EEPW首頁 > 博客 > 藍牙BLE MTU規(guī)則與約定

藍牙BLE MTU規(guī)則與約定

發(fā)布人:電子禪石 時間:2021-05-15 來源:工程師 發(fā)布文章

1. 問題引言:

想在gatt client上(一般是手機上)傳輸長一點的數(shù)據(jù)給gatt server(一般是一個Bluetooth smart設備,即只有BLE功能的設備),但通過

[java]

writeCharacteristic(BluetoothGattCharacteristic) 

來寫的時候發(fā)現(xiàn)最多只能寫入20byte的數(shù)據(jù)。

這篇文章會回答下面幾個問題:

1)為什么會是20?

2)如何突破20?

3)如何更優(yōu)雅的來實現(xiàn)?

2. 為什么為限制成20個字節(jié)?

core spec里面定義了ATT的默認MTU23bytes, 除去ATTopcode一個字節(jié)以及ATThandle 2個字節(jié)之后,剩下的20個字節(jié)便是留給GATT的了。

考慮到有些Bluetooth smart設備功能弱小,不敢太奢侈的使用內(nèi)存空間,因此core spec規(guī)定每一個設備都必須支持MTU23

在兩個設備連接初期,大家都像新交的朋友一樣,不知對方底細,因此嚴格的按照套路來走,即最多一次發(fā)20個字節(jié),是最保險的。

由于ATT的最大長度為512byte

因此一般認為MTU的最大長度為512byte就夠了,再大也沒什么意義,你不可能發(fā)一個超過512ATT的數(shù)據(jù)。

所以ATTMTU的最大長度可視為512bytes。

3. 如何突破20?

很簡單嘛,改變傳輸?shù)?span style="overflow-wrap: break-word;">ATT的MTU就行了,大家經(jīng)過友好的協(xié)商,得到雙方都想要的結果,是最好的。在Android上(API 21),改變ATT MTU的接口為:

public boolean requestMtu (int mtu)    

Added in API level 21 

Request an MTU size used for a given connection. 

When performing a write request operation (write without response), the data sent is truncated to the MTU size. This function may be used to request a larger MTU size to be able to send more data at once. 

 A onMtuChanged(BluetoothGatt, int, int) callback will indicate whether this operation was successful. 

  Requires BLUETOOTH permission. 

 

Returns 

true, if the new MTU value has been requested successfully 

大聲的說出來你想要一下子傳多少,調(diào)用上面的接口就可以了,然后在下面的函數(shù)中看最終結果(當然了,如果你的peripheral申請改變MTU并且成功的話,那這個回調(diào)也會被調(diào)用):

@Override 

public void onMtuChanged(BluetoothGatt gatt, int mtu, int status) { 

    super.onMtuChanged(gatt, mtu, status); 

 

    if (status == BluetoothGatt.GATT_SUCCESS) { 

        this.supportedMTU = mtu;//local var to record MTU size 

    } 

之后你就可以快樂的發(fā)送supported  MTU-3的長度的數(shù)據(jù)了。

                                                                                                

4. 如何優(yōu)雅的來實現(xiàn)?

萬一對方設備不同意你的請求怎么辦?

對于app來說,一般是知道自己要最****送多少數(shù)據(jù)的,例如一次要發(fā)100bytes,那么就首先試試申請一下103,失敗的話,則申請一下53,即二分法,剩下的只能自己分段拆著發(fā)了。

一般來講,app的開發(fā)者和對端設備的開發(fā)者都是同一伙兒人,這是好事,他們可以根據(jù)自己設備的硬件情況,來商量MTU應該是多少。

藍牙BLE MTU規(guī)則與約定-zhenhuaqin-ChinaUnix博客

*博客內(nèi)容為網(wǎng)友個人發(fā)布,僅代表博主個人觀點,如有侵權請聯(lián)系工作人員刪除。



關鍵詞: bluetooth

相關推薦

技術專區(qū)

關閉