資料介紹
引言
嵌入式系統的開發最終需要將編譯好的代碼下載到具體的微控制器芯片上,而不同廠家的微控制器芯片有不同的下載方式。隨著技術的發展和應用需求的更新,用戶程序加載趨向于在線編程的方式,越來越多的芯片公司提供和開放了用戶更新程序的接口與方式,以提高整個系統的可靠性和可維護性。ST公司基于CortexM3內核的STM32系列產品得到了廣泛應用,在許多基于STM32系列產品的開發過程中不可避免要進行用戶程序的加載。本文在介紹IAP技術原理基礎上,詳細論述使用該技術在STM32F103ZE芯片上實現用戶在線更新功能的方法,并具體分析其中可能發生異常的原因。
1 背景綜述
1.1 主要程序更新方式
目前,除了直接通過仿真器或燒錄器進行程序更新方式外,主要有Bootloader技術、ISP技術以及IAP技術3種更新程序的方法。
(1) Bootloader技術
引導加載程序,是指系統加電時,控制器將一段存儲在外部非易失性存儲器中的代碼載入到內部高速存儲器單元(如片內RAM)中執行的過程。
(2) ISP(In System Programming)技術
MCU內部自帶Bootloader,通過指定的方式激活,通過通信接口下載或擦除用戶代碼。需要有外部介入,靜態的,在用戶代碼沒有運行時進行下載。
(3) IAP(In Application Programing)技術
單片機內部具有一些可擦寫的非易失存儲器,如Flash。在微控制器獨立運行時,用戶利用自己編寫的燒寫程序通過通信下載或擦除自己的代碼。注意不具備IAP功能的單片機并不能對Flash的數據進行修改。無需外部介入,動態的,在用戶代碼運行時進行下載。
1.2 STM32系列簡介
STM32系列微控制器基于CortexM3內核,并在其架構上進行了多項改進,包括在提升性能的同時提高了代碼密度的Thumb2指令集,以及大幅度提高中斷響應的緊耦合嵌套向量中斷控制器,從而大大提高了處理速度,降低了系統功耗。使用新內核的Thumb2指令集,設計人員可以把代碼容量降低45%,幾乎把應用軟件所需內存容量降低了一半。此外,STM32提供豐富的外圍接口,目前廣泛應用到工業用及家用安全設備、消防和暖氣通風空調系統等,以及家電、消費電子、低功耗的可便攜式設備等。本文以STM32F103ZE為例來研究及使用IAP技術。
2 IAP技術
2.1 IAP技術原理
首先人為設定單片機內部存儲區分為兩塊:其中一塊稱為Boot區,用于存儲IAP功能程序代碼;另外一塊稱為常態存儲區,用于存儲除IAP功能外的所有程序代碼。IAP技術指的是, MCU在運行的狀態下,通過程序(PC)指針不斷讀取需要執行的程序指令。正常情況下,PC指針只在常態存儲區內移動,并讀取指令,如圖1所示。當用戶需要更新或升級程序時,程序指令會將PC指針跳轉至Boot區。這段存儲區的指令代碼的功能是,通過通信等方式接收用戶需要更新的程序數據,并通過校驗確認接收到的程序數據正確后,根據約定的方式寫入常態存儲區,如圖2所示。當完成用戶程序更新后,PC指針再跳回到常態存儲區,開始執行存儲在其上的用戶程序,這樣便實現了IAP功能。
![IAP技術在STM32程序實現用戶在線更新的方法](/uploads/allimg/171019/2362486-1G019111619622.png)
圖1 通過PC指針讀取程序指令 圖2 更新存儲區代碼
2.2 IAP技術關鍵點
通過研究IAP技術實現用戶程序更新的過程,不難發現,在更新過程中必須保證PC指針在Boot區移動,而不能隨意跳轉至常態存儲區。基于這個要求,結合微控制器原理可以得出需要特別注意的幾個關鍵點。
(1) 禁止中斷
毫無疑問,中斷會使得PC指針跳轉至中斷服務程序入口地址,因此,在進入Boot區前需要禁止所有中斷。
(2) 禁用底層外圍接口
對于有些外圍接口,比如當采用ADC+DMA的方式進行多通道A/D采樣時,采樣過程會按照預先設置的通道順序進行A/D采樣。若在PC指針跳轉至Boot區前沒有禁用,則更新完程序跳回常態存儲區時,其存儲A/D通道值就可能發生錯位的情況。
(3) 使用實時操作系統
如果使用具有搶占式RTOS(即硬實時操作系統),則需要禁止所有任務,并且屏蔽所有的信號量及郵箱,以防止激活某個任務,導致PC指針跳轉至常態存儲區。
(4) 使用看門狗
在考慮導致PC指針跳轉的原因時,看門狗很容易被忽略,而且很多芯片的看門狗一旦使能就不能禁用,所以不能通過禁用的方法達到目的。最安全的方法是,在Boot區中也加入看門狗的喂狗指令。特別要注意的是,當需要擦除、寫入大量Flash數據時,需要對其過程所需時間進行定量的估計,有必要時可以在這個過程中多次喂狗。
(5) 存儲空間分配
Boot區以及常態存儲區的大小可以人為分配,一般而言,盡可能使常態存儲區最大化,因為產品的功能是在該區域得到體現;而Boot區盡可能使其代碼簡潔,避免使用中斷以及復雜的底層驅動及算法。
2.3 IAP技術實現
(1) 關閉相關中斷及禁用相關外圍接口
如定時器中斷、SysTick中斷、A/D中斷、外部I/O中斷等。
(2) 設定跳轉地址
typedef void (*pFunction)(void);
INT32U JumpAddress;//定義IAP入口地址pFunction Jump_To_Application;//定義指向IAP入口地址程序的函數指針
JumpAddress=*(vu32*)(IAP_ADDR + 4);
Jump_To_Application=(pFunction) JumpAddress;
(3) 喂狗并執行跳轉
IWDG_ReloadCounter();//喂狗
__set_MSP(*(__IO uint32_t*) IAP_ADDR);//初始化用戶應用程序的堆棧指針
Jump_To_Application();
(4) IAP代碼(Boot區代碼)
只需要驅動用到的底層接口,盡量不使用中斷,盡可能少地占用存儲空間,同時需要適時地喂狗。另外對該系列Flash操作會有所不同,比如STM32F103ZE執行擦除操作時,一頁為2 KB,而SMT32F103VC6等芯片一頁為1 KB,使用其他型號芯片時需要具體查閱相關數據手冊。
3 總結
本文從分析IAP技術原理入手,詳細論述了利用IAP技術實現用戶程序更新的要點。另外,可以想象,如果Boot區加入TCP/IP協議連入互聯網,即可借助網絡對產品進行在線升級,既可提高系統的可維護性,又可降低產品的維護成本,必將在未來得到更為廣泛的應用。
?
嵌入式系統的開發最終需要將編譯好的代碼下載到具體的微控制器芯片上,而不同廠家的微控制器芯片有不同的下載方式。隨著技術的發展和應用需求的更新,用戶程序加載趨向于在線編程的方式,越來越多的芯片公司提供和開放了用戶更新程序的接口與方式,以提高整個系統的可靠性和可維護性。ST公司基于CortexM3內核的STM32系列產品得到了廣泛應用,在許多基于STM32系列產品的開發過程中不可避免要進行用戶程序的加載。本文在介紹IAP技術原理基礎上,詳細論述使用該技術在STM32F103ZE芯片上實現用戶在線更新功能的方法,并具體分析其中可能發生異常的原因。
1 背景綜述
1.1 主要程序更新方式
目前,除了直接通過仿真器或燒錄器進行程序更新方式外,主要有Bootloader技術、ISP技術以及IAP技術3種更新程序的方法。
(1) Bootloader技術
引導加載程序,是指系統加電時,控制器將一段存儲在外部非易失性存儲器中的代碼載入到內部高速存儲器單元(如片內RAM)中執行的過程。
(2) ISP(In System Programming)技術
MCU內部自帶Bootloader,通過指定的方式激活,通過通信接口下載或擦除用戶代碼。需要有外部介入,靜態的,在用戶代碼沒有運行時進行下載。
(3) IAP(In Application Programing)技術
單片機內部具有一些可擦寫的非易失存儲器,如Flash。在微控制器獨立運行時,用戶利用自己編寫的燒寫程序通過通信下載或擦除自己的代碼。注意不具備IAP功能的單片機并不能對Flash的數據進行修改。無需外部介入,動態的,在用戶代碼運行時進行下載。
1.2 STM32系列簡介
STM32系列微控制器基于CortexM3內核,并在其架構上進行了多項改進,包括在提升性能的同時提高了代碼密度的Thumb2指令集,以及大幅度提高中斷響應的緊耦合嵌套向量中斷控制器,從而大大提高了處理速度,降低了系統功耗。使用新內核的Thumb2指令集,設計人員可以把代碼容量降低45%,幾乎把應用軟件所需內存容量降低了一半。此外,STM32提供豐富的外圍接口,目前廣泛應用到工業用及家用安全設備、消防和暖氣通風空調系統等,以及家電、消費電子、低功耗的可便攜式設備等。本文以STM32F103ZE為例來研究及使用IAP技術。
2 IAP技術
2.1 IAP技術原理
首先人為設定單片機內部存儲區分為兩塊:其中一塊稱為Boot區,用于存儲IAP功能程序代碼;另外一塊稱為常態存儲區,用于存儲除IAP功能外的所有程序代碼。IAP技術指的是, MCU在運行的狀態下,通過程序(PC)指針不斷讀取需要執行的程序指令。正常情況下,PC指針只在常態存儲區內移動,并讀取指令,如圖1所示。當用戶需要更新或升級程序時,程序指令會將PC指針跳轉至Boot區。這段存儲區的指令代碼的功能是,通過通信等方式接收用戶需要更新的程序數據,并通過校驗確認接收到的程序數據正確后,根據約定的方式寫入常態存儲區,如圖2所示。當完成用戶程序更新后,PC指針再跳回到常態存儲區,開始執行存儲在其上的用戶程序,這樣便實現了IAP功能。
![IAP技術在STM32程序實現用戶在線更新的方法](/uploads/allimg/171019/2362486-1G019111619622.png)
圖1 通過PC指針讀取程序指令 圖2 更新存儲區代碼
2.2 IAP技術關鍵點
通過研究IAP技術實現用戶程序更新的過程,不難發現,在更新過程中必須保證PC指針在Boot區移動,而不能隨意跳轉至常態存儲區。基于這個要求,結合微控制器原理可以得出需要特別注意的幾個關鍵點。
(1) 禁止中斷
毫無疑問,中斷會使得PC指針跳轉至中斷服務程序入口地址,因此,在進入Boot區前需要禁止所有中斷。
(2) 禁用底層外圍接口
對于有些外圍接口,比如當采用ADC+DMA的方式進行多通道A/D采樣時,采樣過程會按照預先設置的通道順序進行A/D采樣。若在PC指針跳轉至Boot區前沒有禁用,則更新完程序跳回常態存儲區時,其存儲A/D通道值就可能發生錯位的情況。
(3) 使用實時操作系統
如果使用具有搶占式RTOS(即硬實時操作系統),則需要禁止所有任務,并且屏蔽所有的信號量及郵箱,以防止激活某個任務,導致PC指針跳轉至常態存儲區。
(4) 使用看門狗
在考慮導致PC指針跳轉的原因時,看門狗很容易被忽略,而且很多芯片的看門狗一旦使能就不能禁用,所以不能通過禁用的方法達到目的。最安全的方法是,在Boot區中也加入看門狗的喂狗指令。特別要注意的是,當需要擦除、寫入大量Flash數據時,需要對其過程所需時間進行定量的估計,有必要時可以在這個過程中多次喂狗。
(5) 存儲空間分配
Boot區以及常態存儲區的大小可以人為分配,一般而言,盡可能使常態存儲區最大化,因為產品的功能是在該區域得到體現;而Boot區盡可能使其代碼簡潔,避免使用中斷以及復雜的底層驅動及算法。
2.3 IAP技術實現
(1) 關閉相關中斷及禁用相關外圍接口
如定時器中斷、SysTick中斷、A/D中斷、外部I/O中斷等。
(2) 設定跳轉地址
typedef void (*pFunction)(void);
INT32U JumpAddress;//定義IAP入口地址pFunction Jump_To_Application;//定義指向IAP入口地址程序的函數指針
JumpAddress=*(vu32*)(IAP_ADDR + 4);
Jump_To_Application=(pFunction) JumpAddress;
(3) 喂狗并執行跳轉
IWDG_ReloadCounter();//喂狗
__set_MSP(*(__IO uint32_t*) IAP_ADDR);//初始化用戶應用程序的堆棧指針
Jump_To_Application();
(4) IAP代碼(Boot區代碼)
只需要驅動用到的底層接口,盡量不使用中斷,盡可能少地占用存儲空間,同時需要適時地喂狗。另外對該系列Flash操作會有所不同,比如STM32F103ZE執行擦除操作時,一頁為2 KB,而SMT32F103VC6等芯片一頁為1 KB,使用其他型號芯片時需要具體查閱相關數據手冊。
3 總結
本文從分析IAP技術原理入手,詳細論述了利用IAP技術實現用戶程序更新的要點。另外,可以想象,如果Boot區加入TCP/IP協議連入互聯網,即可借助網絡對產品進行在線升級,既可提高系統的可維護性,又可降低產品的維護成本,必將在未來得到更為廣泛的應用。
?
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 在洗碗機中設計和實現用戶界面的新方法
- 應用筆記-在 CW32F030 上實現 IAP 功能
- 淺談STM32在應用中編程(IAP)的應用(俗稱在線更新程序)
- STM32實現IAP功能的學習筆記
- 4.STM32在應用更新程序IAP
- STM32應用IAP進行程序更新詳解及實例
- STM32的IAP升級APP
- STM32軟件-IAP遠程固件升級
- 使用IAP技術實現STM32芯片的更新技術 12次下載
- 使用STM32F103單片機設計實現IAP的資料說明
- 使用STM32單片機實現IAP的詳細資料說明
- 使用USART實現對STM32F3xx系列微控制器的在線編程IAP 9次下載
- STM32 在程序中編程方案(IAP) 10次下載
- STM32三種啟動模式以及IAP在線升級 16次下載
- STM32的IAP技術入門提高 5次下載
- STM32單片機實現固件在線升級(IAP) 5552次閱讀
- 基于STM32的串口環形隊列IAP調試 1639次閱讀
- 什么是IAP? 1.6w次閱讀
- AT32 USB MSD IAP簡介及功能特點 1749次閱讀
- 關于在線升級IAP的基礎知識 2710次閱讀
- 基于IAP流程的兩片Flash拼接的Flash控制器方案設計 2429次閱讀
- 以Flash控制器為核心的FPGA在線更新功能實現設計流程介紹 3398次閱讀
- 微處理器IAP技術中是如何融合rfid技術的 1176次閱讀
- STM32 IAP的使用關鍵點 1697次閱讀
- 如何采用STM32單片機實現IAP功能 4053次閱讀
- 基于STM32的IAP升級程序分享 7980次閱讀
- STM32F030之IAP代碼編寫 1.1w次閱讀
- STM32_IAP詳解(有代碼,有上位機) 3.6w次閱讀
- 介紹通過IAP的在線升級方法 1.6w次閱讀
- 介紹如何通過意法的STM32 MCU實現用DMA完成多通道的AD采樣功能 1.5w次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 2開關電源基礎知識
- 5.73 MB | 6次下載 | 免費
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設計
- 0.60 MB | 3次下載 | 免費
- 5基于FPGA的光纖通信系統的設計與實現
- 0.61 MB | 2次下載 | 免費
- 6基于FPGA的C8051F單片機開發板設計
- 0.70 MB | 2次下載 | 免費
- 751單片機窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費
- 8基于51單片機的RGB調色燈程序仿真
- 0.86 MB | 2次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應用800例(新編版)
- 0.00 MB | 33564次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關電源設計實例指南
- 未知 | 21548次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數字電路基礎pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅動電路設計》 溫德爾著
- 0.00 MB | 6653次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537796次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191185次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183278次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論