CC2640 R2是德州儀器推出的面向 Bluetooth Smart 應用的低功耗無線 MCU。該芯片運行TI的BLE協議棧,具有功耗低,外設種類豐富,射頻性能好等特點。利用它可以實現許多有趣的應用,收到了用戶的廣泛歡迎。
可是很多用戶在量產的時候卻犯難了,用XDS110 + Flash Programmer 2,效率很低,還要在GUI上各種配置,產線工人操作起來十分困難而且容易失誤。買一拖多的編程器配上位機,又舍不得口袋里的銀子,而且不是TI官方出品,穩定性和可靠性難以得到保證。本文給大家介紹一種利用芯片內部Bootloader燒寫程序的方法,進入Boot模式,用普通的串行接口就可以進行固件的引導,FLASH的擦寫,Program,不花費額外成本。 而且這個bootloader是放在ROM里的,不會被誤擦除, Boot的時候UART/SPI不斷就沒事,實在不行load一半斷了也無傷大雅,再boot一次就好了,即快捷又安全。
我們來看一下CC2640R2的Bootloader是怎么Run的。CC13x0, CC26x0 SimpleLink Wireless MCU Technical Reference Manual(SWCU117H)第8章節Bootloader中詳細介紹了Bootloader的原理,功能,接口定義,包的組成,校驗等等,內容很多,容易犯困,現在來畫一下重點。
第一個常見的問題是什么情況下會進Bootloader,進Bootloader會不會影響應用程序的執行?如果使能了Bootloader,有兩種情況下會進,第一種情況是一個FLASH里沒有任何鏡像的新芯片在上電后;第二種情況是開啟了Bootloader backdoor,并且預先定義的backdoor PIN腳被設置到正確的邏輯電平。上述條件不滿足,在上電后,芯片優先執行應用程序。所以Bootloader和應用程序執行的條件不同,所以并不會相互影響。
第二個常見的問題是什么是Bootloader backdoor?實際上就是為芯片進入Bootloader留的一個后門。用戶可以通過BL_CONFIG寄存器的BL_ENABLE位使能這個backdoor,并預設某個GPIO在某個電平的時候啟用這個Backdoor,在Reset的時候,芯片內部會自動檢測預設條件是否滿足,來決定是否進入Bootloader模式。BL_CONFIG是實現Bootloader最重要的寄存器,我們后面在講代碼時會參照這個寄存器,其說明在SWCU117H也可以找到。
第三個常見的問題也是容易犯的錯誤是是不是CC2640R2的所有接口和PIN腳都支持Bootloader? 答案是否定的。CC2640R2的Bootloader只支持兩種接口,UART和SSI,而且僅有UART0 和 SSI0 支持,不同封裝的芯片對應的引腳也有差別,使用時要特別注意。
對于UART0來說,我們芯片理論上可以達到3Mbaud(48M/16)的最大波特率,但是片內ROM中的Bootloader固件只支持1.6Mbaud。SSI0是Motorolar格式的,SPH=1,SPO=1,SSI0時鐘最快頻率是4Mbaud(48M/12)。不過一味追求接口的速率也沒有必要,畢竟下載程序的速率瓶頸在FLASH的讀寫速度。
其實要點就這么多,很簡單吧。很多用戶會有疑問是不是要把TI規定的協議搞得很透才能實現Bootloader?當然不是,TI工程師的使命就是把復雜的問題變得簡單,只要把配置搞對,配上正確的上位機,一秒上手不是難事。下面就以UART為例詳細跟大伙說說Bootloader在CC2640R2上是怎么實現的。
工欲善其事,必先利其器,請準備好下面的IDE環境,藍牙協議棧和硬件平臺。插播一條廣告,LAUNCHXL-CC2640R2的demo板可以在TI的estore上購買。
IDE環境 | IAR 8.11.2 |
藍牙協議棧版本 | 1_50_00_58 |
硬件平臺 | LAUNCHXL-CC2640R2 |
工程文件 | simplelink_cc2640r2_sdk_1_50_00_58examplesrtosCC2640R2_LAUNCHXLblestacksimple_peripheral |
上位機軟件 | sblAppEx.exe |
仿真器 | LAUNCHPAD板載XDS110 |
值得一提的是,sblAppEx.exe 是TI專門為CC2640R2實現Bootloader開發的工具,并向客戶開放源碼,可以基于此二次開發。
首先,我們需要修改一下Bootloader的設置,在sourcetidevicescc26x0r2startup_files里,打開ccfg.c,對幾個宏定義做出配置。
在這里我們用DIO15高電平作為Bootloader backdoor的敲門磚,當然也可以根據用戶實際需要選擇相應的DIO。配置好后,點擊IAR的編譯下載按鈕,就可以在simple_peripheraltirtosiarappFlashROM_StackLibraryExe里看到剛剛編譯好的帶Bootloader功能的鏡像文件,我們需要的是.bin結尾的。
將生成的.bin文件復制到sblAppEx.exe所在根目錄下,即sblAppEx_1_02_00_00bin。由于sblAppEx.exe自動識別的是blinky_backdoor_select_btn2650.bin,所以需要把剛生成的ble_simple_peripheral_cc2640r2lp_app_FlashROM_StackLibrary.bin改個名字。當然了,也可以通過修改sblAppEx.exe的源碼識別用戶所需的.bin,此處不再贅述。然后,按如下步驟操作:
1) DIO15接成高電平。
2) RESET。重新上電或者按LAUNCHPAD的RESET按鈕均可。
3) 在DOS界面選擇0,即XDS110 Class Application/User UART ,回車。不同電腦可能會識別不同的串口號,這個無關緊要。
如果設置都正確的話Bootloader開始工作,經過Erasing flash,Writing flash,Calculating CRC on device,Comparing CRC這一系列過程后,Bootloader更新程序就完成了,最后系統會Reset device。
一路OK后,此時的LAUNCHPAD里就是新的固件所示現的功能啦!如果配置不對的話,這個App是會閃退的,無法完成Bootloader的功能。如果不想用板載的XDS110,用自己的USB轉串口工具也是可以的,只不過不會跳出那么多跟XDS110有關的COM ports了,取而代之的是USB Serial Ports,串口號不用太糾結。
當然啦,有可能你雙擊sblAppEx.exe來執行,但執行完一系列操作后會自動退出,看不到任何Log,解決的方法是不要雙擊進入程序,在windows的run里用cmd命令,切到sblAppEx.exe所在文件夾就可以啦。如果某個環節遇到任何問題,Bootloader就會中斷,DOS界面會提示ERROR,具體可以對照sblAppEx.exe的源碼進行檢查,此處不再贅述。需要注意的是,如果不用Bootloader模式,Bootloader backdoor的引腳一定要接固定電平,此處DIO15一定要接低電平,不能懸空。
重要的事再說一遍,sblAppEx.exe是開源的,用戶可以根據需要修改源碼實現定制化的功能,比如UART波特率和上文提到的鏡像名稱等等。
是不是產線上用起來既簡單又方便呢,基本是一鍵式下載,既高效又防止誤操作。當然啦,還可以適當修改一下下載工具和上位機軟件,就可以實現多個器件的下載。
審核編輯:郭婷
-
mcu
+關注
關注
146文章
17322瀏覽量
352651 -
uart
+關注
關注
22文章
1243瀏覽量
101771 -
GUI
+關注
關注
3文章
662瀏覽量
39891
發布評論請先 登錄
相關推薦
昇潤科技將在三月底推出CC2640R2 SDK開發平臺
CC2640R2調試出現奇怪的問題
CC2640和CC2640R2F的核心區別和重點是什么?不急,本文為你細細道來
CC2640和CC2640R2F的不同點及開發板有哪些?
CC2640R2軟件測評分享!
請問使用cc2640R2 CCS版本對之前版本的工程會產生影響嗎?
為什么更改CC2640的bootloader的默認IO口之后bootloader功能就失敗了?
利用芯片內部Bootloader燒寫程序的方法
CC2640R2的外設功能介紹
CC2640R2的Bootloader是怎么Run的
CC2640R2: TI BLE OAD(OTA)協議在Android和iOS上的APP流程和代碼解讀
![<b class='flag-5'>CC2640R2</b>: TI BLE OAD(OTA)協議在Android和iOS上的APP流程和代碼解讀](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
評論