《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 可編程邏輯 > 業(yè)界動態(tài) > 使用IAP在應(yīng)用編程輕松更新固件

使用IAP在應(yīng)用編程輕松更新固件

2018-08-21
關(guān)鍵詞: IAP 應(yīng)用編程

  在電子產(chǎn)品出廠前,可以通過離線燒錄器,燒錄夾具,或者用在線燒錄器通過預(yù)留的燒錄接口輕松將應(yīng)用代碼下載到MCU中。但是,如果產(chǎn)品已售出或不在研發(fā)端,又要怎樣升級程序呢?今天,這里就給大家介紹通過IAP的在線升級方法。

  先來理解兩個(gè)概念I(lǐng)SP和IAP:

  1、ISP(In-System Programming)在系統(tǒng)可編程,指電路板上的空白器件可以編程寫入最終用戶代碼, 而不需要從電路板上取下器件,已經(jīng)編程的器件也可以用ISP方式擦除或再編程;

  2、IAP(In-Application Programming) 指MCU可以在系統(tǒng)中獲取新代碼并對自己重新編程,即可用程序來改變程序。

1(553).png1(553).png

  IAP編程的實(shí)現(xiàn)辦法

  實(shí)現(xiàn)IAP功能,需要在設(shè)計(jì)產(chǎn)品的時(shí)候編寫兩個(gè)程序,第一部分程序是不執(zhí)行正常的功能的,只是通過某種通信方式(如USB、Uart)接收固件或新的應(yīng)用程序,執(zhí)行對第二部分代碼的更新,我們稱之為Bootloader;第二部分代碼是用戶的應(yīng)用代碼,實(shí)現(xiàn)產(chǎn)品的真正功能。第一部分代碼必須事先燒寫(通過燒錄器或仿真器)到單片機(jī)內(nèi),第二部分代碼可以通過燒錄器或仿真器燒錄,也可以使用第一部分的IAP功能燒錄。當(dāng)芯片上電后,首先運(yùn)行第一部分代碼,如果不需要更新,則跳轉(zhuǎn)到第二部分代碼執(zhí)行;如果檢測到需要更新,則執(zhí)行更新程序,更新完成后跳轉(zhuǎn)到第二部分代碼執(zhí)行。以STM32為例,如下圖:

2(367).png

  如上圖例子,Bootloader的起始地址存放在0x08000000(也是STM32芯片F(xiàn)lash的起始地址),程序由此執(zhí)行后,跳轉(zhuǎn)至復(fù)位中斷入口向量地址,隨后跳轉(zhuǎn)到Bootloader的main函數(shù)入口, 當(dāng)檢測到需要升級程序,執(zhí)行更新第二部分應(yīng)用程序代碼到地址為0x08000000 + N的Flash區(qū)域,更新完成后,跳轉(zhuǎn)至第二部分應(yīng)用程序的復(fù)位中斷向量地址(0x08000004 + N +M), 隨后跳轉(zhuǎn)至第二部分應(yīng)用程序的main函數(shù),在main函數(shù)的運(yùn)行過程中,如果CPU遇到一個(gè)中斷請求,PC指針強(qiáng)制跳轉(zhuǎn)至Bootloader的中斷向量表(上圖中0x08000004),而不是第二部分的中斷向量表,程序再根據(jù)我們設(shè)置的中斷向量表偏移量,跳轉(zhuǎn)到對應(yīng)中斷源新的中斷服務(wù)程序中執(zhí)行,執(zhí)行完成后返回第二部分應(yīng)用程序的main函數(shù)。

  需要注意的地方是:第一部分程序(Bootloader)跳轉(zhuǎn)的地址和第二部分應(yīng)用程序的起始地址必須要保持一致,相應(yīng)的中斷向量表也要修改,否則程序無法正確運(yùn)行。

  通過IAP在應(yīng)用編程,在一些產(chǎn)品發(fā)布后可以方便地通過預(yù)留的通信口(如USB,串口,網(wǎng)絡(luò)端口或無線傳輸)對產(chǎn)品中的固件程序進(jìn)行更新升級。在使用IAP功能之前,芯片必須先通過燒錄工具將實(shí)現(xiàn)IAP功能的Bootloader燒錄到單片機(jī)內(nèi)。如果Bootloader程序被破壞,產(chǎn)品必須返廠才能重新燒寫程序,這是很麻煩并且非常耗費(fèi)時(shí)間和金錢的。針對這樣的需求,STM32在對Flash區(qū)域?qū)嵭凶x保護(hù)的同時(shí),自動地對用戶Flash區(qū)的開始4頁設(shè)置為寫保護(hù),這樣可以有效地保證IAP程序區(qū)域不會被意外地破壞。

  ZLG致遠(yuǎn)電子的P800isp是一款多通道在線脫機(jī)燒錄器,用戶只需將產(chǎn)品的燒錄接口預(yù)留出來,使用P800isp即可輕松對程序進(jìn)行一次燒錄、二次更新,即使產(chǎn)品Bootloader被破壞,也能輕松解決更新問題


本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點(diǎn)。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問題,請及時(shí)通過電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟(jì)損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。