深入談?wù)処AP升級
最近做過(guò)51_IAP和ARM_IAP升級,感覺(jué)到他們的相同點(diǎn)和不同點(diǎn),特記錄如下:
本文引用地址:http://dyxdggzs.com/article/148074.htm共同點(diǎn):
做好IAP的關(guān)鍵都是中斷向量的映射(REMAP)問(wèn)題
一般都分為bootloader區和用戶(hù)區
不同點(diǎn):
單片機的中斷向量位置是固定的,位于0x0000的底部。
ARM的中斷向量也一般是在0x0000的底部,但有的ARM可以中斷向量的映射機制,可以將RAM或其他地址的FLASH映射到0x0000底部
單片機沒(méi)有中斷向量管理機制。一般0x0000-0x0002是一個(gè)3個(gè)字節的LJMP指令(該指令跳轉到用戶(hù)程序,注意不一定是main函數,可能是包括一些堆棧,寄存器初始化的匯編的初始化部分,然后跳轉到main函數),后面是各種具體中斷的跳轉函數的入口地址,例如串口,I2C等等。
ARM有中斷管理機制。(cortex-M3內核又不一樣)
在A(yíng)RM體系中,異常中斷向量表的大小為32字節,其中每個(gè)異常中斷占據4個(gè)字節大小,保留了4個(gè)字節空間
0x00 復位
0x04 未定義的指令
0x08 軟件中斷
0x0C 指令預取終止
0x10 數據訪(fǎng)問(wèn)終止
0x14 保留 未使用
0x18 IRQ模式 這個(gè)就是我們常用各種中斷(串口,i2c等)的一個(gè)總中斷入口,后面再根據中斷其他寄存器進(jìn)行判斷處理
0x1C FIQ模式
中斷向量從0x0000000--0x00000001C共4*8=32個(gè)字節,還應包括后面到0x00000040之前的代碼都應該映射,因為后面包括具體跳轉的地址。(所以要映射從0x0000000----0x000003F共64個(gè)字節,自己看匯編覺(jué)得)
對于下載的程序,必須要在KEIL設置好Ro_Base地址,然后將生成好的bin文件下載到R0_Base地址處。原因是絕對地址不同造成,也就是說(shuō)對某個(gè)bin文件并不是想下載到哪個(gè)地方都可以運行。
值得注意:
1.MC51設置R0_Base, 只表示用戶(hù)代碼的存放區,R0_Base這個(gè)地址并不存放中斷向量表,也不是main的入口地址
2.ARM設置R0_Base, R0_Base開(kāi)始處就是中斷向量表
MC51設置Ro_Base位置在于BL51 Locate--》Code Range
ARM設置ro_base位置在于target-->IROM
做過(guò)升級的例子:
(1)C8051F02*將用戶(hù)的中斷向量復制到0x0003之后,同時(shí)0x000-0x0002保留bootloader跳轉地址,另外找個(gè)地方保存用戶(hù)跳轉地址,用于從bootloader區跳轉到用戶(hù)區。值得注意:bootloader區由于其他中斷向量表被用戶(hù)中斷向量表占用,bootloader代碼中不能出現中斷函數。
(2) STR912 內部有bank0,bank1的映射功能,即可將bank0映射到0x0000,亦可將bank1映射到0x0000,這樣就可以將一個(gè)bank作為bootloader ,另一個(gè)作為用戶(hù)程序
(3) 2410 中斷向量表位于底部,沒(méi)有重映射機制。采用將中斷向量二次映射的方法,將中斷向量映射到指定的RAM區,然后在RAM寫(xiě)入用戶(hù)的中斷向量表。
(4) ADU7020 中斷向量表位于底部,有重新映射機制,REMAP寄存器,可以將中斷向量映射到FLASH或RAM選擇,可以將用戶(hù)的中斷向量拷貝到RAM區,然后選擇將中斷向量映射到RAM,然后跳轉
(5) STM32 支持中斷向量表映射。cortex-M3核有專(zhuān)門(mén)的向量偏移寄存器,該寄存器決定:
1. 向量表是位于FLASH還是RAM,向量表的基址
2. 向量表的偏移量
注:
一個(gè)優(yōu)秀的IAP升級程序,必須做好升級中出現故障等異常的處理。保證系統不會(huì )崩潰
(1) 接收到升級命令,準備升級
(2) 接收升級數據完成,每個(gè)包最好有包序號和校驗
(3) 整個(gè)數據接收完,進(jìn)行總的校驗
(4) 試運行剛升級的版本,發(fā)送讀取版本信息或其他指令測試當前版本是否工作正常,如果不正常,外界通過(guò)對外專(zhuān)門(mén)的RESET引腳,恢復到原版本
(5) 接收到版本確認命令,將升級版本作為當前運行版本,并將原版本進(jìn)行保存
另外:
(1)要保證升級過(guò)程中任何時(shí)候掉電,下次上電后,系統能正常工作。例如新的程序正在搬運到運行區時(shí)候掉電,下次上電要實(shí)現自動(dòng)搬運
(2)正常情況下,系統一般由bootloader區跳轉到用戶(hù)區。如果用戶(hù)區程序有問(wèn)題的話(huà),就玩OVER了,因此一定要在跳轉之前加一定延時(shí),可以響應升級命令
(3)執行bootloader區和用戶(hù)區跳轉指令,由于只是PC指針的跳轉,寄存器并未恢復到默認值,因此對bootloader和用戶(hù)區代碼中的寄存器初始化要小心。
說(shuō)到底最重要的還是bootloader程序一定要寫(xiě)好,這個(gè)畢竟是出廠(chǎng)前固化在FLASH中
給手機升級,主板升級,其中強調的就是不能中途掉電,否則就要。。。這個(gè)應該就是沒(méi)做好升級處理吧
評論