當(dāng)前位置:首頁(yè) > 模擬 > 模擬
[導(dǎo)讀]對(duì)于基于閃存的嵌入式系統(tǒng),一個(gè)重要的要求就是,當(dāng)該系統(tǒng)安裝在終端產(chǎn)品上后具有更新固件的能力,即在應(yīng)用中編程(In-Application Programming,IAP)。本文介紹了STM32F10x處理器的特點(diǎn)及內(nèi)存映射;詳細(xì)論述了IAP功能的基本原理和IAP驅(qū)動(dòng)流程;給出了在STM32F10x處理器中實(shí)現(xiàn)IAP功能的方法。

引 言
   
Cortex-M3是首款基于ARMv7-M體系結(jié)構(gòu)的32位標(biāo)準(zhǔn)處理器,RISC結(jié)構(gòu),包含高效靈活的Thumb-2指令集,擁有杰出的低功耗特性,為微控制器系統(tǒng)、汽車車身控制系統(tǒng)、工業(yè)控制系統(tǒng)和無(wú)線網(wǎng)絡(luò)等嵌入式應(yīng)用量身設(shè)計(jì)。ST公司推出基于Cortex-M3內(nèi)核的STM32系列處理器,憑借其出眾的性能、創(chuàng)新的外設(shè)、優(yōu)越的功耗控制,得到眾多工程師的青睞。
    針對(duì)嵌入式應(yīng)用的特點(diǎn),STM32處理器提供功能強(qiáng)大的硬件調(diào)試接口——JTAG接口和串行接口,極大方便了設(shè)計(jì),縮短了產(chǎn)品的開(kāi)發(fā)周期。不僅如此,STM32處理器內(nèi)嵌的閃存存儲(chǔ)器允許在電路編程(In-Circuit Pro-gramming,ICP)和在應(yīng)用中編程(In-Application Program-ming,IAP)。利用在應(yīng)用中編程,僅需通過(guò)一根串口線,就可以完成產(chǎn)品固件的更新。本文對(duì)STM32處理器的在應(yīng)用中編程進(jìn)行了詳細(xì)的分析,結(jié)合硬件和驅(qū)動(dòng)給出了IAP的具體實(shí)現(xiàn)方法,稍加修改,便可應(yīng)用于STM32處理器的所有系列產(chǎn)品。

1 STM32F10x處理器
1.1 STM32處理器特點(diǎn)

    STM32全系列處理器具有腳對(duì)腳、外設(shè)及軟件的高度兼容性。這給應(yīng)用帶來(lái)很好的靈活性,易于將應(yīng)用升級(jí)到不同存儲(chǔ)空間或不同封裝的平臺(tái)。STM32處理器的產(chǎn)品全系列兼容,使得項(xiàng)目之間的代碼重用和移植很方便。
1.2 STM32處理器內(nèi)存映射
    Cortex-M3的存儲(chǔ)系統(tǒng)采用統(tǒng)一編址的方式,程序存儲(chǔ)器、數(shù)據(jù)存儲(chǔ)器、寄存器被組織在4 GB的線性地址空間內(nèi),以小端格式(little-endian)存放。內(nèi)存映射如圖1所示。

    在代碼區(qū),0x00000000地址為啟動(dòng)區(qū)。上電以后,CPU從這個(gè)地址開(kāi)始執(zhí)行代碼0x08000000為用戶Flash的起始地址,0x1FFFF000為系統(tǒng)存儲(chǔ)器(system memory)的起始地址。對(duì)于STM32處理器,可以通過(guò)配置BOOT0和BOOT1兩個(gè)引腳來(lái)選擇不同的啟動(dòng)模式,如表1所列。CPU在時(shí)鐘信號(hào)的第4個(gè)上升沿鎖存BOOT引腳的值,根據(jù)兩個(gè)引腳的值將對(duì)應(yīng)的存儲(chǔ)器物理地址映射到啟動(dòng)區(qū)。

    系統(tǒng)存儲(chǔ)器也稱為“大信息塊”,有2 KB的容量。所有上市的STM32處理器,在出廠前已經(jīng)燒寫(xiě)進(jìn)去自舉模式下的啟動(dòng)程序(Bootloader),并且將之鎖定防止用戶擦寫(xiě)。通過(guò)配置BOOT0和BOOT1選擇系統(tǒng)存儲(chǔ)器啟動(dòng),相應(yīng)的啟動(dòng)程序在復(fù)位后得以執(zhí)行,配合PC端的通信軟件,通過(guò)USART1口允許用戶將程序燒寫(xiě)到用戶Flash區(qū)。之后,將BOOT0和B00T1重新配置為用戶Flash存儲(chǔ)器啟動(dòng),進(jìn)入正常的應(yīng)用程序。
    上述的自舉模式類似于ISP編程,相比其他燒寫(xiě)方式方便許多,但真正方便靈活的是在應(yīng)用中編程(IAP),只需一根串口線就可以載入程序,復(fù)位后立即執(zhí)行新的應(yīng)用程序。

2 IAP功能原理
    在應(yīng)用中編程(IAP)使得用戶可以在程序運(yùn)行時(shí)重新對(duì)Flash進(jìn)行編程。簡(jiǎn)單地說(shuō),IAP的編程工作是:下載編譯好的二進(jìn)制文件數(shù)據(jù)到RAM;將數(shù)據(jù)重新編程到特定的Flash區(qū)。這兩個(gè)工作是由IAP驅(qū)動(dòng)程序完成的。使用IAP功能后,系統(tǒng)的固件由2部分組成:第1部分是IAP驅(qū)動(dòng),不執(zhí)行通常的功能,而是通過(guò)微控制器支持的任一種通信管道(如USB、USART、SPI等,本文使用USART)接收數(shù)據(jù),并執(zhí)行對(duì)第2部分代碼的更新;第2部分是真正的應(yīng)用程序代碼,實(shí)現(xiàn)具體的功能。這兩部分代碼共同燒寫(xiě)在Flash中。要注意的是,這兩部分代碼不能重疊,否則無(wú)法實(shí)現(xiàn)IAP功能。
    系統(tǒng)上電以后,IAP驅(qū)動(dòng)首先運(yùn)行,它主要執(zhí)行如下的操作:
    ①根據(jù)硬件信號(hào)或軟件條件判斷是否需要對(duì)第2部分代碼進(jìn)行更新;
    ②如果不需要更新,則跳轉(zhuǎn)到④;
    ③執(zhí)行更新操作;
    ④跳轉(zhuǎn)到第2部分代碼執(zhí)行。
    STM3210x處理器IAP驅(qū)動(dòng)的流程如圖2所示。圖中顯示IAP主界面是利用超級(jí)終端實(shí)現(xiàn)的,傳輸協(xié)議用的是Ymodem協(xié)議。需要注意的是,由于IAP驅(qū)動(dòng)占用了用戶Flash區(qū)的一段起始空間,因此Flash的可編程最大空間要把這部分除去。

3 IAP功能實(shí)現(xiàn)
3.1 硬件電路
   
采用STM32F10x型處理器作為核心。該處理器可全速工作在72 MHz,擁有3個(gè)USART接口,內(nèi)嵌128 KB Flash和20 KB SRAM。Flash是以頁(yè)的形式組織的,擦除1頁(yè)的時(shí)間約為20~40 ms;在整個(gè)工作范圍內(nèi)其擦除次數(shù)可達(dá)10 000次,經(jīng)10 000次擦除后,在+55℃的保存環(huán)境中數(shù)據(jù)保存期限仍可達(dá)20年。用戶完全不必?fù)?dān)心使用了IAP功能后對(duì)產(chǎn)品造成不良影響。
    IAP驅(qū)動(dòng)使用USART1口作為通信管道,PB口的第9引腳作為IAP判斷是否進(jìn)入IAP功能的信號(hào)線。引出一個(gè)按鍵,作為IAP功能選擇按鍵,只要在上電或復(fù)位時(shí)按住此鍵就會(huì)進(jìn)入IAP功能主界面,否則直接執(zhí)行正常應(yīng)用程序。BOOT0和BOOT1是啟動(dòng)配置跳線。相應(yīng)的硬件電路分別如圖3、圖4和圖5所示。

3.2 IAP驅(qū)動(dòng)
    IAP驅(qū)動(dòng)主要包含如下源文件。
    main.c:完成Flash解鎖、按鍵端口初始化、按鍵判斷、USART1的初始化以及處理器的始終初始化,另外還初始化指針和跳轉(zhuǎn)到應(yīng)用程序處語(yǔ)句。然后從common.c執(zhí)行主菜單。
    common.c:顯示主菜單。主菜單上顯示一系列操作,如加載二進(jìn)制文件、執(zhí)行應(yīng)用程序以及禁止寫(xiě)保護(hù)(如果事先Flash被寫(xiě)保護(hù))。
    download.c:等待用戶選擇傳送文件操作,或者放棄操作以及一些提示信息,但真正實(shí)現(xiàn)傳送的是ymodem.c源文件。
    ymodem.c:負(fù)責(zé)從超級(jí)終端接收數(shù)據(jù)(使用Ymodem協(xié)議),并將數(shù)據(jù)加載到內(nèi)部RAM中。如果接收數(shù)據(jù)正常,則將數(shù)據(jù)編程到Flash中;如果發(fā)生錯(cuò)誤,則提示出錯(cuò)。
3.3 軟件實(shí)現(xiàn)
    要實(shí)現(xiàn)IAP功能,還需做一些準(zhǔn)備工作:
    ①要準(zhǔn)備BIN類型的代碼文件。開(kāi)發(fā)環(huán)境使用的是Keil,默認(rèn)情況下Keil生成HEX類型的編譯文件。利用Keil自帶的fromelf.exe工具,就可以生成二進(jìn)制文件。
    ②對(duì)超級(jí)終端進(jìn)行設(shè)置。IAP驅(qū)動(dòng)中對(duì)USART1的設(shè)置為:波特率為115 200 kb/s,8位數(shù)據(jù)位,1位停止位,無(wú)校驗(yàn)位和硬件控制。超級(jí)終端也必須保持相同設(shè)置。
    IAP驅(qū)動(dòng)和應(yīng)用程序代碼需要分配在Flash的合適位置。圖6是2部分代碼在Flash中的存儲(chǔ)情況。由于IAP驅(qū)動(dòng)代碼占用8 KB的空間,故而將Flash最初的8 KB劃出來(lái),應(yīng)用程序是從0x08020000地址處開(kāi)始存放的。這是通過(guò)在common.h頭文件中語(yǔ)句定義的:
    #define ApplicationAddress 0x08020000
    也可以定義在其他0x08020000地址后的任何位置,只要保證應(yīng)用程序大小不超過(guò)所用處理器Flash的容量。在platform_config.h頭文件中有定義Flash的語(yǔ)句:
    #define PAGE_SIZE(0x400) //Flash頁(yè)大小為1 KB
    #define FLASH_SIZE(0x20000)//Flash容量為128 KB
    STM32F10x處理器有2種Flash頁(yè)的大?。? KB和2 KB。通過(guò)以上語(yǔ)句即可定義頁(yè)大小。
    在platform_config.h頭文件中還定義了進(jìn)入IAP功能選擇按鍵映射引腳:
   

    IAP驅(qū)動(dòng)在Keil中編譯、鏈接后,利用ARM公司的RealView ULINK2仿真器將生成的HEX文件燒寫(xiě)到Flash中。此時(shí)Keil自帶的Flash燒寫(xiě)工具要設(shè)置Flash的起始地址為0x08000000。在應(yīng)用程序中,定義向量表的函數(shù)NVIC_SetVectorTabl(NVIC_VectTab_FLASH,0x2000)中的第2個(gè)參數(shù),即Flash的偏移量一定要設(shè)置成0x2000或更大的數(shù)值。同時(shí),F(xiàn)lash燒寫(xiě)工具也要做相對(duì)應(yīng)的設(shè)置。將系統(tǒng)的串口與PC機(jī)串口相連,打開(kāi)已經(jīng)設(shè)置好參數(shù)的超級(jí)終端。將BOOT0跳線為0,BOOT1為0或1都可以。按住IAP功能選擇按鍵,給系統(tǒng)上電。此時(shí),在超級(jí)終端就會(huì)顯示IAP功能主界面,如圖7所示。

 

    在鍵盤(pán)上按1選擇待載入二進(jìn)制文件,界面上會(huì)出現(xiàn)提示語(yǔ)。在“傳送”菜單中選擇傳送文件后,只需幾秒鐘可以將6 KB左右的文件燒寫(xiě)到Flash。下載完后,在鍵盤(pán)上按2或復(fù)位就可以直接執(zhí)行應(yīng)用程序了,如圖8所示。雖然IAP功能使用的是USART1口,但進(jìn)入應(yīng)用程序后就可以正常使用USART1口。隨時(shí)可以通過(guò)復(fù)位后按住IAP功能選擇鍵來(lái)進(jìn)行IAP方式燒寫(xiě)應(yīng)用程序。 

結(jié) 語(yǔ)
    STM32F10x處理器性能出眾,已被廣泛應(yīng)用于各種場(chǎng)合。其IAP功能給用戶帶來(lái)了極大方便,使得產(chǎn)品的固件更新快捷、簡(jiǎn)單。本文闡述了IAP的基本原理,并詳細(xì)描述了如何在STM32F10x處理器平臺(tái)中實(shí)現(xiàn)IAP功能,并在所設(shè)計(jì)的系統(tǒng)中進(jìn)行了IAP實(shí)驗(yàn)。實(shí)驗(yàn)證明,該款處理器的IAP功能可靠、快捷。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉