最近在支持客戶的時(shí)候遇到這樣一個(gè)問題:客戶在做自己的二級boot loader,并且在使用LPC54608 IAP功能,編程sector0中的page0時(shí)候總是失?。ǚ祷?x21錯(cuò)誤碼),但是編程任何其他page的時(shí)候,都沒有問題(客戶的代碼在最后一個(gè)sector里,不編程)。
問題乍一看比較詭異,因?yàn)橹挥衟age0會(huì)出問題,對其他page的操作都是沒有問題的,并且擦除page/sector也沒有問題,只有編程操作會(huì)出錯(cuò)。
經(jīng)過了一段短暫的討論,最后把問題鎖定在了LPC中斷向量表的check sum校驗(yàn)機(jī)制上:LPC(除比較新的LPC5500系列外)基本都需要在中斷向量表的第8個(gè)位置上填入前7個(gè)中斷向量的校驗(yàn)和,關(guān)于校驗(yàn)和的具體內(nèi)容可以參考開篇提到的文章。
在Keil編譯出來的.bin文件中,默認(rèn)并沒有自動(dòng)添加這個(gè)校驗(yàn)和,所以每當(dāng)調(diào)用IAP變成page0的時(shí)候,IAP程序內(nèi)部都會(huì)檢查這個(gè)校驗(yàn)和,一旦校驗(yàn)和錯(cuò)誤(比如全0) 就會(huì)返回失敗。
解決方法也很簡單,就是在每次編程page0的時(shí)候都計(jì)算下校驗(yàn)和即可,這里直接給出計(jì)算校驗(yàn)和的代碼:
adr為編程地址,當(dāng)adr為0時(shí)既編程page0區(qū)域,紅框內(nèi)的代碼就是計(jì)算校驗(yàn)和,并且把校驗(yàn)和填到中斷向量表的第8個(gè)位置上。
加上這段計(jì)算校驗(yàn)和代碼后,問題迎刃而解。這個(gè)問題普遍存在于除LPC5500系列外幾乎所有老的LPC型號上,希望本文章對大家開發(fā)LPC MCU有所幫助!
編輯:jq
-
LPC
+關(guān)注
關(guān)注
8文章
137瀏覽量
78109 -
IAP
+關(guān)注
關(guān)注
2文章
164瀏覽量
24742 -
代碼
+關(guān)注
關(guān)注
30文章
4880瀏覽量
69998 -
編譯
+關(guān)注
關(guān)注
0文章
674瀏覽量
33602
發(fā)布評論請先 登錄
相關(guān)推薦
評論