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

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

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

面向 Bluetooth Smart 應(yīng)用的低功耗無線 MCU

電子設(shè)計(jì) ? 來源:網(wǎng)友電子設(shè)計(jì)發(fā)布 ? 作者:網(wǎng)友電子設(shè)計(jì)發(fā)布 ? 2021-12-29 14:32 ? 次閱讀

CC2640 R2是德州儀器推出的一款面向 Bluetooth Smart 應(yīng)用的低功耗無線 MCU。該芯片集成有Cortex M3內(nèi)核,可以運(yùn)行TI的BLE協(xié)議棧,具有功耗低,外設(shè)種類豐富,射頻性能好等特點(diǎn)。與CC2640相比,R2版本的芯片將部分協(xié)議棧遷移到了片內(nèi)的ROM中,留給客戶的應(yīng)用程序更多的Flash空間。CC2640R2芯片架構(gòu)及核心特點(diǎn)如下圖1所示。

而CC2640R2F本身集成有可以支持藍(lán)牙5.0的PHY,TI協(xié)議棧支持部分藍(lán)牙5.0的協(xié)議,如High speed,Long Range等等?;贑C2640R2F可以實(shí)現(xiàn)很多炫酷的應(yīng)用。不過有時(shí)候,有些應(yīng)用并沒有按鍵或者屏幕等輸入設(shè)備,要求APP輸入密碼與BLE從機(jī)配對(duì)后方可讀取BLE設(shè)備的數(shù)據(jù),這篇文章就跟大家詳細(xì)聊聊如何用用戶自定義的密碼進(jìn)行配對(duì)。

本文所使用的軟硬件平臺(tái)如下:

IDE環(huán)境 IAR 8.11.2
藍(lán)牙協(xié)議棧版本 1_50_00_62
實(shí)驗(yàn)所用工程 .\examples\rtos\CC2640R2_LAUNCHXL\bleapps\hid_emu_kbd
硬件平臺(tái) LAUNCHXL-CC2640R2
手機(jī)Android版本 4.4.4
手機(jī)IOS版本 11.3.1

本文是以hid_emu_kbd例程為參考。其他工程比如SimpleBLEPeripheral或者其他,都可以參照這個(gè)來修改。HID設(shè)備對(duì)BLE來說比較特殊,BLE的HID profile是規(guī)定HID設(shè)備必須配對(duì)和綁定的。

下圖是配對(duì)和綁定的基本流程。Initiator是連接中的主設(shè)備,responder是連接中的從設(shè)備。

BLE的配對(duì)與綁定則發(fā)生在連接之后。綁定是在配對(duì)之后發(fā)生的事,需不需要綁定取決于用戶在代碼里的設(shè)置。

上圖的phase 1和phase2是配對(duì)的過程。Phase 3是綁定的過程。要不要進(jìn)行phase 3,在phase 1發(fā)送配對(duì)請(qǐng)求的時(shí)候就已經(jīng)決定了,這個(gè)決定就是用戶在代碼里面的配置。

如果要用戶在配對(duì)過程中人為輸入密碼或進(jìn)行其他認(rèn)為操作,是在phase 2。而具體的誤認(rèn)為操作方式,也是在phase 1中決定,這個(gè)決定也是用戶在代碼里面的配置。其實(shí)phase 2能用到的配對(duì)有很多種方式,最簡(jiǎn)單的就是just works的方式,用大家都知道的000000作為配對(duì)密碼,這個(gè)方式很不安全,非常容易被破解。其實(shí)BLE到了4.2以上的版本,已經(jīng)有了用DH(Diffie–Hellman key exchange)方式交換密碼,這個(gè)方式已經(jīng)很安全,且密碼也是隨機(jī)產(chǎn)生的。

有些應(yīng)用場(chǎng)景可能需求比較特殊,產(chǎn)品需要自定義的配對(duì)密碼,所以要達(dá)到這個(gè)目的,就需要我們靈活配置配phase 1中的各個(gè)參數(shù),這也是這篇文章的目的。

我們繼續(xù)以hid_emu_kbd為例,BLE配對(duì)phase 1所需要的幾個(gè)重要參數(shù)的配置在hidemukbd.c里,如下:

第一個(gè)關(guān)鍵參數(shù)是PAIRING_MODE,配對(duì)是由GAPBOND_PAIRING_MODE_INITIATE一端發(fā)起的,可以是主機(jī),也可以是從機(jī)。本文中由手機(jī)(手機(jī))發(fā)起配對(duì)請(qǐng)求,從機(jī)(CC2640R2)則被動(dòng)等待,所以需要將宏定義配置為GAPBOND_PAIRING_MODE_WAIT_FOR_REQ。

第二個(gè)關(guān)鍵參數(shù)是MITM_MODE,MITM即Man In The Middle保護(hù),如果MITM為FALSE,則說明不需要人參與中間,后面相應(yīng)的IO capabilities設(shè)置也會(huì)被忽略,但是為了使配對(duì)需要Passcode才能成功,必須要把MITM_MODE的宏定義設(shè)置為TRUE。

第三個(gè)關(guān)鍵參數(shù)是IO_CAPABILITIES,表示本機(jī)是否有輸入或者顯示的功能,比如GAPBOND_IO_CAP_DISPLAY_ONLY,表示可以將密碼顯示在屏幕上給操作人看,如果有I/O接口可以輸入密碼,也可以選擇GAPBOND_IO_CAP_KEYBOARD_ONLY。本文中將I/O capabilities的屬性設(shè)置為GAPBOND_IO_CAP_DISPLAY_ONLY,如下:

這樣做的目的就是告訴主機(jī),我這邊能顯示配對(duì)密碼,最終用戶作為MITM,需要在主機(jī)那邊(手機(jī)上)跳出的窗口里輸入我從機(jī)這邊顯示的配對(duì)密碼就行。到這一步,phase 2要用的配對(duì)的方式就確定好了。但是這樣設(shè)置的話從機(jī)這邊顯示的密碼是隨機(jī)產(chǎn)生的6位數(shù),并不是我們想要的自定義的固定6位數(shù)。

×注意,即使實(shí)際的從設(shè)備產(chǎn)品不帶顯示功能(沒屏幕),IO_CAPABILITIES配置成GAPBOND_IO_CAP_DISPLAY_ONLY,也是可以的,前提就是用自定義的固定6位數(shù)作為配對(duì)密碼,不然就會(huì)導(dǎo)致產(chǎn)生的6位隨機(jī)數(shù)沒地方顯示,就會(huì)無法完成配對(duì)。

接下來就來設(shè)置固定的6位數(shù)配對(duì)密碼來達(dá)到我們的目的。

CC2640R2的修改方式CC2541不同,CC2541可以參考這個(gè)帖子:https://e2echina.ti.com/question_answer/wireless_connectivity/bluetooth/f/103/t/112619

首先看一下哪里設(shè)置這個(gè)自定義配對(duì)密碼passcode的6位數(shù)。CC2640R2的這個(gè)Passcode隱藏的比較深,在bcomdef.h里,把宏定義改成你自己需要的密碼就可以了。這里設(shè)置成123412,注意這個(gè)密碼必須是6位。

那么這個(gè)默認(rèn)自定義passcode是怎么被用上的呢?

首先,就是要在初始化的時(shí)候注冊(cè)bond manager的回調(diào):

這個(gè)回調(diào)的HidDev_PasscodeCB()就是處理passcode請(qǐng)求的回調(diào)函數(shù)。

當(dāng)配對(duì)的phase 2被配置成前面提到的方式時(shí),配對(duì)過程會(huì)觸發(fā)passcode請(qǐng)求,就會(huì)調(diào)用HidDev_passcodeCB()。最終會(huì)觸發(fā)HidDev_processPasscodeEvt():

所以可以看到,只要其中pHidDevCB->passcodeCB這個(gè)回調(diào)為NULL,那么就會(huì)使用默認(rèn)自定義密碼,這樣就能達(dá)到目的。(如果這個(gè)回調(diào)不為NULL,那么就會(huì)調(diào)用這個(gè)回調(diào)來獲取密碼,那很有可能是應(yīng)用層用戶手動(dòng)輸入密碼或者其他方式。)

pHidDevCB這個(gè)回調(diào)是在應(yīng)用層用戶自己初始化的:

第三個(gè)回調(diào)函數(shù)就是passcodeCB,這個(gè)修改為NULL。

這個(gè)回調(diào)結(jié)構(gòu)體是在HidDev_Register()被調(diào)用,并初始化給pHidDevCB指針的。

修改完了,為了調(diào)試的方便,我們把斷開連接后自動(dòng)廣播打開,在IAR開發(fā)環(huán)境中,右擊工程 -> Options -> C/C++ Compiler -> Preprocessor中Define Symbols里,把AUTO_ADV的值改為TRUE。

如果是用iPhone作為主機(jī)的話,有幾個(gè)連接參數(shù)要改一下,不然iOS會(huì)拒絕連接參數(shù)更新請(qǐng)求。

下面到了見證奇跡的時(shí)刻,拿出你的手機(jī),以iPhone為例,由于是HID的工程,可以用iPhone自帶的藍(lán)牙界面:(如果不是HID工程,iOS上的lightblue app或者TI的sensorTag app都能做演示)

搜索到設(shè)備:

點(diǎn)擊搜索到的HID Keyboard,這樣會(huì)發(fā)起連接請(qǐng)求,自動(dòng)跳出密碼框:

輸入正確的預(yù)設(shè)6位密碼123412并點(diǎn)擊配對(duì):

配對(duì)成功連接建立完成:

如果輸入密碼錯(cuò)誤,那么會(huì)連接建立失敗,重新回到最初界面:

為了加深理解,我們可以從空中抓包的log來看一下過程。下圖是配對(duì)成功后,連接進(jìn)行加密:

那么可以看到加密以后的數(shù)據(jù)就都是紅的,這是因?yàn)閟niffer沒法解析了,通過MITM方式配對(duì)是比較安全的模式。

那么如果iPhone上密碼輸入錯(cuò)誤,非指定密碼,CC2640R2就會(huì)直接回復(fù)Pairing Failed給iPhone:

iPhone就會(huì)立即斷開連接:

最后,靈活運(yùn)用前面提到過的配對(duì)參數(shù)搭配,能達(dá)到不同的配對(duì)場(chǎng)景效果。我們這里只是舉了一個(gè)例子,讀者有興趣的話可以自己嘗試一下各種搭配,這樣對(duì)理解BLE的安全機(jī)制也會(huì)很有幫助。

審核編輯:何安

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

    關(guān)注

    146

    文章

    16667

    瀏覽量

    347804
  • 嵌入式處理
    +關(guān)注

    關(guān)注

    0

    文章

    341

    瀏覽量

    9955
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    藍(lán)牙模塊選經(jīng)典藍(lán)牙還是低功耗藍(lán)牙?

    energy和Bluetooth smart兩者又有什么區(qū)別?我的應(yīng)用應(yīng)該選經(jīng)典藍(lán)牙技術(shù)還是低功耗藍(lán)牙技術(shù)?首先,在2010年以前,當(dāng)我們談?wù)撍{(lán)牙的時(shí)候,就是在說的經(jīng)典藍(lán)牙,因?yàn)槟莻€(gè)時(shí)候還沒有
    的頭像 發(fā)表于 05-23 17:57 ?609次閱讀
    藍(lán)牙模塊選經(jīng)典藍(lán)牙還是<b class='flag-5'>低功耗</b>藍(lán)牙?

    TIDA-020032-汽車門禁低功耗 Bluetooth? + CAN衛(wèi)星模塊 PCB layout 設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《TIDA-020032-汽車門禁低功耗 Bluetooth? + CAN衛(wèi)星模塊 PCB layout 設(shè)計(jì).pdf》資料免費(fèi)下載
    發(fā)表于 05-17 18:12 ?0次下載
    TIDA-020032-汽車門禁<b class='flag-5'>低功耗</b> <b class='flag-5'>Bluetooth</b>? + CAN衛(wèi)星模塊 PCB layout 設(shè)計(jì)

    面向低功耗無線應(yīng)用的雙節(jié)超低IQ降壓轉(zhuǎn)換器TPS62745數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《面向低功耗無線應(yīng)用的雙節(jié)超低IQ降壓轉(zhuǎn)換器TPS62745數(shù)據(jù)表.pdf》資料免費(fèi)下載
    發(fā)表于 04-12 14:11 ?0次下載
    <b class='flag-5'>面向</b><b class='flag-5'>低功耗</b><b class='flag-5'>無線</b>應(yīng)用的雙節(jié)超低IQ降壓轉(zhuǎn)換器TPS62745數(shù)據(jù)表

    面向低功耗無線應(yīng)用的雙節(jié)超低 IQ 降壓轉(zhuǎn)換器TPS62745數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《面向低功耗無線應(yīng)用的雙節(jié)超低 IQ 降壓轉(zhuǎn)換器TPS62745數(shù)據(jù)表.pdf》資料免費(fèi)下載
    發(fā)表于 03-08 10:48 ?0次下載
    <b class='flag-5'>面向</b><b class='flag-5'>低功耗</b><b class='flag-5'>無線</b>應(yīng)用的雙節(jié)超低 IQ 降壓轉(zhuǎn)換器TPS62745數(shù)據(jù)表

    數(shù)據(jù)透?jìng)鬟x擇低功耗WiFi模塊還是選擇低功耗藍(lán)牙模塊?

    WiFi模塊和藍(lán)牙模塊,針對(duì)部分領(lǐng)域的低功耗數(shù)據(jù)透?jìng)餍枨?,工程師是該選擇低功耗WiFi模塊還是低功耗藍(lán)牙模塊呢? ? 數(shù)據(jù)透?jìng)鬟x擇低功耗WiFi模塊還是選擇
    的頭像 發(fā)表于 01-10 18:44 ?507次閱讀
    數(shù)據(jù)透?jìng)鬟x擇<b class='flag-5'>低功耗</b>WiFi模塊還是選擇<b class='flag-5'>低功耗</b>藍(lán)牙模塊?

    HOLTEK新推出HT32F67742 Arm? Cortex?-M0+藍(lán)牙5.2低功耗MCU

    Holtek新推出通過BQB(Bluetooth Qualification Body)認(rèn)證Bluetooth 5.2 Arm Cortex-M0+低功耗藍(lán)牙(Bluetooth Lo
    的頭像 發(fā)表于 01-08 15:23 ?638次閱讀

    MCU低功耗時(shí)的靜態(tài)功耗解析

    隨著半導(dǎo)體技術(shù)和工藝的進(jìn)步,MCU功耗做的是越來越好。很多廠家都宣傳自家的MCU低功耗(Low Power)或者超低功耗(Ultra L
    的頭像 發(fā)表于 12-13 09:06 ?1272次閱讀
    <b class='flag-5'>MCU</b>在<b class='flag-5'>低功耗</b>時(shí)的靜態(tài)<b class='flag-5'>功耗</b>解析

    【應(yīng)用筆記】STM32WB 低功耗藍(lán)牙無線接口

    低功耗藍(lán)牙是由藍(lán)牙技術(shù)聯(lián)盟(Bluetooth SIG)設(shè)計(jì)和銷售的無線個(gè)人局域網(wǎng)技術(shù),該技術(shù)面向醫(yī)療保健、健身、信標(biāo)、安全和家庭娛樂行業(yè)的創(chuàng)新應(yīng)用。與標(biāo)準(zhǔn)藍(lán)牙相比,
    發(fā)表于 12-12 16:30 ?1次下載

    面向極端高溫應(yīng)用的低功耗、精密、高溫器件

    電子發(fā)燒友網(wǎng)站提供《面向極端高溫應(yīng)用的低功耗、精密、高溫器件.pdf》資料免費(fèi)下載
    發(fā)表于 11-28 09:53 ?0次下載
    <b class='flag-5'>面向</b>極端高溫應(yīng)用的<b class='flag-5'>低功耗</b>、精密、高溫器件

    MCU在線技術(shù)講座-EFM和EFR: 面向物聯(lián)網(wǎng)開發(fā)的通用MCU平臺(tái)

    : 面向物聯(lián)網(wǎng)開發(fā)的通用MCU平臺(tái)”。 本次技術(shù)講座將詳細(xì)說明以芯科科技8位和32位MCU,以及無線SoC作為物聯(lián)網(wǎng)開發(fā)通用平臺(tái)的諸多優(yōu)勢(shì),包括
    發(fā)表于 11-23 13:45

    SS809QW集成無線充電 RX 控制器的低功耗 MCU 芯片

    SS809QW 是一款集成無線充電 RX 控制器的低功耗 MCU 芯片,3*3 芯片尺寸廣泛適用于各類帶無線充電接收及電池充放電管理的智能硬件設(shè)備。SS809QW 內(nèi)置豐富的接口功能,
    發(fā)表于 11-22 16:59 ?4次下載

    具有高性價(jià)比的無線 MCU 如何幫助您將低功耗 Bluetooth?? 技術(shù)應(yīng)用到更多產(chǎn)品中

    具有高性價(jià)比的無線 MCU 如何幫助您將低功耗 Bluetooth?? 技術(shù)應(yīng)用到更多產(chǎn)品中
    的頭像 發(fā)表于 10-24 17:41 ?443次閱讀

    N32L4系列低功耗MCU應(yīng)用案例分享

    水、氣、電、熱 | N32L4系列低功耗MCU應(yīng)用案例分享
    的頭像 發(fā)表于 10-24 15:43 ?481次閱讀
    N32L4系列<b class='flag-5'>低功耗</b><b class='flag-5'>MCU</b>應(yīng)用案例分享

    海凌科BLE低功耗藍(lán)牙模塊物聯(lián)網(wǎng)應(yīng)用

    低功耗藍(lán)牙(Bluetooth Low Energy、低功耗藍(lán)牙,俗稱BLE,以前稱為Bluetooth Smart )一般來說是指支持藍(lán)牙
    的頭像 發(fā)表于 10-16 10:12 ?1009次閱讀
    海凌科BLE<b class='flag-5'>低功耗</b>藍(lán)牙模塊物聯(lián)網(wǎng)應(yīng)用

    Microchip SMART SAM L系列器件的低功耗特性

    電子發(fā)燒友網(wǎng)站提供《Microchip SMART SAM L系列器件的低功耗特性.pdf》資料免費(fèi)下載
    發(fā)表于 09-25 10:12 ?0次下載
    Microchip <b class='flag-5'>SMART</b> SAM L系列器件的<b class='flag-5'>低功耗</b>特性