0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

INGCHIPS BLE芯片如何獲得最大吞吐量?

桃芯科技 ? 來(lái)源:桃芯科技 ? 2023-07-12 16:56 ? 次閱讀

一、結(jié)論

使用INGCHIPS SDK中測(cè)試吞吐率的例程peripheral_throughput和central_throughput,使用兩個(gè)開(kāi)發(fā)板進(jìn)行測(cè)試。

1M phy吞吐率≥93KBps;

2M phy吞吐率≥152KBps。

二、1MPHY

01 實(shí)測(cè)

為了最小化包頭、包尾、校驗(yàn)等無(wú)法避免的數(shù)據(jù)開(kāi)銷(xiāo),每一包數(shù)據(jù)MTU設(shè)置為247。 除去3bytes的ATT Header,則實(shí)際的ATT payload為244。 在central端連接參數(shù)使用默認(rèn)值的情況下:

static initiating_phy_config_t phy_configs[] =              
{              
    {              
        .phy = PHY_1M,              
        .conn_param =              
        {              
            .scan_int = 200,              
            .scan_win = 180,              
            .interval_min = 50,              
            .interval_max = 50,              
            .latency = 0,              
            .supervision_timeout = 600,              
            .min_ce_len = 90,              
            .max_ce_len = 90              
        }              
    }              
};

對(duì)于1M phy來(lái)說(shuō),由主設(shè)備統(tǒng)計(jì)的吞吐率為:687104bps。

ad40a692-2091-11ee-962d-dac502259ad0.png? ??

使用藍(lán)盒(ellisys)抓包:

ad6c0c6a-2091-11ee-962d-dac502259ad0.png

一包間隔為62.5ms(即50*1.25ms),觀察其中的數(shù)據(jù)包發(fā)現(xiàn),一個(gè)間隔有23包數(shù)據(jù)發(fā)出去。

實(shí)際發(fā)出的有效數(shù)據(jù)=23x244bytes=23x244x8bits=44896bits。 吞吐率=44896/0.0625=718336bps. 比串口統(tǒng)計(jì)的略大,仔細(xì)觀察Ellisys窗口,發(fā)現(xiàn)每個(gè)連接間隔發(fā)滿時(shí),都有一次retry。

在連接間隔的末尾,從設(shè)備沒(méi)有回復(fù)主設(shè)備連接包,主設(shè)備進(jìn)行了一次重傳。

ad9044b8-2091-11ee-962d-dac502259ad0.png

也就是一個(gè)連接間隔實(shí)際只發(fā)了22包。

吞吐率=22x244x8/0.0625=687104,與串口的統(tǒng)計(jì)對(duì)應(yīng)上了。

想要提升吞吐率,從上面的分析可以看到,有兩個(gè)可以調(diào)整的地方,一個(gè)是每次重傳的那一包,一個(gè)是連接間隔中空閑的6.116ms。

adb84576-2091-11ee-962d-dac502259ad0.png

6.116ms足夠傳2包數(shù)據(jù)(具體傳送一包的時(shí)長(zhǎng),參照下面的理論分析部分)。

調(diào)整連接間隔

.interval_min = 51,
.interval_max = 51,

可以看到,每個(gè)連接間隔變成了63.75ms,比剛才多傳了一包,24包(由于依然有一個(gè)retry包,有效包23包),連接間隔中浪費(fèi)的時(shí)間4.89ms,比剛才的6.116ms少,本次吞吐率理論上比上次高。

adef0728-2091-11ee-962d-dac502259ad0.png

23x244x8/0.06375=704205

ae114c66-2091-11ee-962d-dac502259ad0.png

串口顯示基本上兩次718336,一次673440, (718336x2+673440)/3=703370,基本一致。 參數(shù)設(shè)置為

.conn_param =              
       {              
            .scan_int = 200,              
            .scan_win = 180,              
            .interval_min = 100,              
            .interval_max = 100,              
            .latency = 0,              
            .supervision_timeout = 600,              
            .min_ce_len = 200,              
            .max_ce_len = 200              
        }

ae3c7aa8-2091-11ee-962d-dac502259ad0.png

每個(gè)連接間隔125ms,傳輸有效包48包。

ae57394c-2091-11ee-962d-dac502259ad0.png

48x244x8/0.125=749568bps=93696Bps≈93KBps,

此時(shí)連接間隔的空閑時(shí)間為4.447ms,

基本上已經(jīng)達(dá)到極限。

02 理論分析

BLE連接數(shù)據(jù)包分解如下:

ae76a656-2091-11ee-962d-dac502259ad0.png

當(dāng)ATT payload設(shè)置為244,傳輸一包數(shù)據(jù)需額外傳輸?shù)腷ytes數(shù)為:

1(preamble)+4(access address)+2(LL Header)+4(L2CAP Header)+3(ATT Header)+3(CRC)=17(因?yàn)椴患用?,所以沒(méi)有MIC)。

一包總的數(shù)據(jù)長(zhǎng)度為17+244=261bytes=261x8bits=2088bits。

對(duì)于1Mphy來(lái)說(shuō),傳輸1bit時(shí)間為1us,傳輸一包數(shù)據(jù)就需要2088us,即2.088ms。

ae9d0314-2091-11ee-962d-dac502259ad0.png

數(shù)據(jù)傳輸還有另外兩個(gè)無(wú)法避免的時(shí)間開(kāi)銷(xiāo):1)傳輸完一個(gè)數(shù)據(jù)包后,需要另一個(gè)設(shè)備回一個(gè)空包來(lái)保持?jǐn)?shù)據(jù)傳輸;2)數(shù)據(jù)包之間需要有一個(gè)空閑時(shí)間來(lái)讓協(xié)議棧完成數(shù)據(jù)處理,這個(gè)時(shí)間即T_IFS,150us。

aec4091e-2091-11ee-962d-dac502259ad0.png

空包的長(zhǎng)度為1(preamble)+4(Access Address)+2(PDU)+3(crc)=10Bytes=80bits。

也就是說(shuō)傳輸一個(gè)空包時(shí)間為80us,加上兩個(gè)T_IFS,總共380us。

af2f219a-2091-11ee-962d-dac502259ad0.png

也就是說(shuō),傳輸244Bytes數(shù)據(jù),實(shí)際花費(fèi)的總時(shí)間=2088us+380us=2468us=2.468ms. 如果可以保持不間斷地發(fā)送,吞吐率=244/0.002468=98865Bytes≈98KBps。

但是實(shí)際必然無(wú)法達(dá)到這個(gè)速度,就是由于上面說(shuō)的,每一個(gè)連接間隔無(wú)法全部用于發(fā)送數(shù)據(jù),即便讓連接間隔是2.468ms的整數(shù)倍,協(xié)議棧也會(huì)留出一些空隙用于內(nèi)部業(yè)務(wù)處理,對(duì)于Ingchips來(lái)說(shuō),這個(gè)間隙大約在4-6ms。 因此實(shí)測(cè)的93KBps已接近理論吞吐量的極限。

根據(jù)上面的分析,合理猜測(cè)如果把連接間隔無(wú)限拉長(zhǎng),可以最小化每個(gè)連接間隔空隙4-6ms的影響。

但實(shí)際上,協(xié)議??傂枰獣r(shí)間來(lái)處理自己的事務(wù),如果把連接間隔設(shè)的過(guò)長(zhǎng),且全部用于發(fā)送數(shù)據(jù),協(xié)議棧就會(huì)在一定時(shí)間停止發(fā)送,且此連接間隔剩下的時(shí)間也不再用于發(fā)送數(shù)據(jù),因此數(shù)據(jù)速率還會(huì)下降。

af4bd196-2091-11ee-962d-dac502259ad0.png

af719728-2091-11ee-962d-dac502259ad0.png

三、2MPHY

01 Ellisys抓包2M PHY 方法

如下圖所示,勾選2M PHY

af963196-2091-11ee-962d-dac502259ad0.png

02 實(shí)測(cè)

在連接間隔設(shè)為60,152kBps以上。

具體過(guò)程不再贅述。

afcdce8a-2091-11ee-962d-dac502259ad0.png

四、實(shí)操

01 環(huán)境準(zhǔn)備

硬件

INGCHIPS開(kāi)發(fā)板兩套,可以咨詢(xún)INGCHIPS代理商購(gòu)買(mǎi)(上面的膠棒天線需要自備)。

Micro USB線兩條。

軟件:

INGCHIPS SDK,下載最新版本。

串口調(diào)試工具,比如SSCOM。

02 測(cè)試過(guò)程

說(shuō)明:

關(guān)于INGCHIPS SDK的下載和安裝、開(kāi)發(fā)軟件環(huán)境的配置、例程的編譯和固件下載等具體問(wèn)題,桃芯官網(wǎng)提供了豐富的由淺入深的開(kāi)發(fā)資料,前期搭建環(huán)境過(guò)程中可以參照。

SDK安裝好后,在兩塊開(kāi)發(fā)板分別下載SDK提供的專(zhuān)門(mén)用于吞吐量測(cè)試的主從例程。

b091f008-2091-11ee-962d-dac502259ad0.png

連接主設(shè)備的串口,主設(shè)備上電會(huì)有打印,有相關(guān)調(diào)試指令的說(shuō)明。

主設(shè)備掃描到從設(shè)備后,會(huì)自動(dòng)進(jìn)行連接。

之后發(fā)送測(cè)試指令(start m->s表示主設(shè)備發(fā),從設(shè)備收),主設(shè)備的串口就會(huì)1秒鐘發(fā)送一次實(shí)時(shí)吞吐率測(cè)試結(jié)果。

b0c4c41a-2091-11ee-962d-dac502259ad0.png

可以參照第二部分中,調(diào)整連接參數(shù)的配置,觀察吞吐率的變化。如果有條件,也可以用Ellisys實(shí)時(shí)抓取連接過(guò)程,觀察空中包的發(fā)送情況。

注意:測(cè)試時(shí)把兩套開(kāi)發(fā)板放在靠近的位置上,保證二者有穩(wěn)定的信號(hào)連接,信號(hào)不穩(wěn)或者太差會(huì)影響吞吐率,信號(hào)強(qiáng)度對(duì)吞吐率的影響歡迎小伙伴們自行測(cè)試。




審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 連接器
    +關(guān)注

    關(guān)注

    98

    文章

    14062

    瀏覽量

    135701
  • PHY
    PHY
    +關(guān)注

    關(guān)注

    2

    文章

    299

    瀏覽量

    51617
  • BLE
    BLE
    +關(guān)注

    關(guān)注

    12

    文章

    644

    瀏覽量

    59250

原文標(biāo)題:INGCHIPS BLE芯片如何獲得最大吞吐量

文章出處:【微信號(hào):INGCHIPS_OFFICIAL,微信公眾號(hào):桃芯科技】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    全志R128 BLE最高吞吐量測(cè)試正確配置測(cè)試方法

    在R128使用前我們需要了解BLE的最高吞吐量,以方便評(píng)估相關(guān)功能的開(kāi)發(fā)。
    的頭像 發(fā)表于 10-27 17:17 ?1189次閱讀
    全志R128 <b class='flag-5'>BLE</b>最高<b class='flag-5'>吞吐量</b>測(cè)試正確配置測(cè)試方法

    如何通過(guò)UBFS獲得流式ADC數(shù)據(jù)的最高吞吐量?

    的上方,PSoC似乎在幾秒鐘后就崩潰了,并且沒(méi)有更多的USB數(shù)據(jù)進(jìn)入PC。我錯(cuò)過(guò)了什么?人們通常使用另一種策略來(lái)通過(guò)UBFS獲得流式ADC數(shù)據(jù)的最高吞吐量嗎?任何幫助或提示贊賞!謝謝,費(fèi)利克斯
    發(fā)表于 10-11 10:46

    請(qǐng)問(wèn)BLE 4.2連接(1中心和1外圍設(shè)備)的最大理論有效載荷吞吐量是多少?

    BLE 4.2連接(1中心和1外圍設(shè)備)的最大理論有效載荷吞吐量是多少?每個(gè)連接間隔可以發(fā)送最多四個(gè)分組,并且每個(gè)分組可以具有多達(dá)251字節(jié)的有效載荷。根據(jù)BLE規(guī)范,連接參數(shù)的允許范
    發(fā)表于 10-15 09:26

    如何計(jì)算延遲和吞吐量

    如何計(jì)算延遲和吞吐量?在ISE時(shí)序報(bào)告中,我們發(fā)現(xiàn)一個(gè)名為“最大組合路徑延遲”的參數(shù)是否與最大時(shí)鐘頻率有關(guān)?
    發(fā)表于 03-19 08:55

    提高BLE吞吐量的可行辦法

    提高BLE吞吐量的可行辦法如何實(shí)現(xiàn)更快的BLE吞吐量
    發(fā)表于 01-18 06:26

    全志R128 BLE最高吞吐量測(cè)試正確配置測(cè)試

    影響。例如,R128設(shè)備支持藍(lán)牙5.0,而藍(lán)牙5.0版本后支持2M PHY,使用2M PHY會(huì)獲得更高的數(shù)據(jù)吞吐量。 2、DLE(數(shù)據(jù)長(zhǎng)度擴(kuò)展): 在藍(lán)牙4.2版本之后,BLE(藍(lán)牙低功耗)開(kāi)始支持DLE
    發(fā)表于 10-16 15:22

    全志R128 BLE最高吞吐量測(cè)試正確配置測(cè)試

    影響。例如,R128設(shè)備支持藍(lán)牙5.0,而藍(lán)牙5.0版本后支持2M PHY,使用2M PHY會(huì)獲得更高的數(shù)據(jù)吞吐量。 2、DLE(數(shù)據(jù)長(zhǎng)度擴(kuò)展): 在藍(lán)牙4.2版本之后,BLE(藍(lán)牙低功耗)開(kāi)始支持DLE
    發(fā)表于 10-26 16:46

    防火墻術(shù)語(yǔ)-吞吐量

    防火墻術(shù)語(yǔ)-吞吐量  術(shù)語(yǔ)名稱(chēng):吞吐量 術(shù)語(yǔ)解釋?zhuān)壕W(wǎng)絡(luò)中的數(shù)據(jù)是由一個(gè)個(gè)數(shù)據(jù)包組成,防火
    發(fā)表于 02-24 11:06 ?1517次閱讀

    基于系統(tǒng)吞吐量最大化的功率分配算法

    針對(duì)認(rèn)知能量采集網(wǎng)絡(luò),提出一種基于系統(tǒng)吞吐量最大化的功率分配算法。該算法在滿足2個(gè)次用戶節(jié)點(diǎn)采集能量的因果性限制和對(duì)主用戶干擾限制的條件下,構(gòu)建了系統(tǒng)吞吐量的優(yōu)化模型;通過(guò)變量代換和問(wèn)題等價(jià)性變換
    發(fā)表于 01-14 16:49 ?0次下載
    基于系統(tǒng)<b class='flag-5'>吞吐量</b><b class='flag-5'>最大</b>化的功率分配算法

    DM6467的吞吐量性能信息和系統(tǒng)芯片(SoC)架構(gòu)的詳細(xì)概述

    本應(yīng)用報(bào)告提供了關(guān)于DM6467的吞吐量性能信息并介紹了片上系統(tǒng)(SoC)DM6467架構(gòu),數(shù)據(jù)路徑基礎(chǔ)設(shè)施和影響吞吐量和不同優(yōu)化的約束條件最佳系統(tǒng)性能的技術(shù)。該文件還提供信息關(guān)于SOC上不同外設(shè)的最大可能
    發(fā)表于 04-18 14:49 ?11次下載
    DM6467的<b class='flag-5'>吞吐量</b>性能信息和系統(tǒng)<b class='flag-5'>芯片</b>(SoC)架構(gòu)的詳細(xì)概述

    EE-47:ADSP-2106x鏈路端口-最大吞吐量

    EE-47:ADSP-2106x鏈路端口-最大吞吐量
    發(fā)表于 04-29 17:12 ?9次下載
    EE-47:ADSP-2106x鏈路端口-<b class='flag-5'>最大</b><b class='flag-5'>吞吐量</b>

    debug 吞吐量的辦法

    Debug 網(wǎng)絡(luò)質(zhì)量的時(shí)候,我們一般會(huì)關(guān)注兩個(gè)因素:延遲和吞吐量(帶寬)。延遲比較好驗(yàn)證,Ping 一下或者 mtr[1] 一下就能看出來(lái)。這篇文章分享一個(gè) debug 吞吐量的辦法。
    的頭像 發(fā)表于 08-23 09:17 ?894次閱讀

    debug 吞吐量的辦法

    Debug 網(wǎng)絡(luò)質(zhì)量的時(shí)候,我們一般會(huì)關(guān)注兩個(gè)因素:延遲和吞吐量(帶寬)。延遲比較好驗(yàn)證,Ping 一下或者 mtr[1] 一下就能看出來(lái)。這篇文章分享一個(gè) debug 吞吐量的辦法。
    的頭像 發(fā)表于 09-02 09:36 ?818次閱讀

    iperf吞吐量的測(cè)試流程

    iperf吞吐量測(cè)試指南
    發(fā)表于 04-03 15:40 ?2次下載

    INGCHIPS BLE芯片如何獲得最大吞吐量

    概述:文章第一部分先公布結(jié)論,第二部分是1M PHY吞吐率的實(shí)測(cè)過(guò)程與理論分析,第三部分是2M PHY的實(shí)測(cè)數(shù)據(jù),第四部分是實(shí)操部分,喜歡BLE的朋友可以按照此部分的說(shuō)明自己動(dòng)手進(jìn)行測(cè)試。
    的頭像 發(fā)表于 07-12 16:56 ?750次閱讀
    <b class='flag-5'>INGCHIPS</b> <b class='flag-5'>BLE</b><b class='flag-5'>芯片</b>如何<b class='flag-5'>獲得</b><b class='flag-5'>最大</b><b class='flag-5'>吞吐量</b>