使用STR730開(kāi)發(fā)產(chǎn)品實(shí)現(xiàn)串口ISP在線編程的設(shè)計(jì)方案
出處:電子產(chǎn)品世界 發(fā)布于:2020-03-03 13:55:33
1 、硬件連接
ISP方案的硬件連接如圖1所示。RS232轉(zhuǎn)接板用來(lái)將RS232電平轉(zhuǎn)換為T(mén)TL電平,并通過(guò)ISP_EN引腳給ARM開(kāi)發(fā)板提供信號(hào),讓其進(jìn)入ISP狀態(tài)。PC機(jī)上運(yùn)行用VC語(yǔ)言編寫(xiě)的ISP.exe,該程序把需要燒錄到F1ash里的.bin文件加密后發(fā)送到ARM開(kāi)發(fā)板,同時(shí)把燒錄的進(jìn)度提示顯示給用戶。圖1中的陰影部分具有固定的程序。
2.1 存儲(chǔ)器分配
STR730是意法半導(dǎo)體生產(chǎn)的基于ARM7TDMI的微控制器芯片,內(nèi)置16 KB RAM(0xa0000000~Oxa0003fff)和256 KB Flash(Ox80000000~Ox8003ffff)。內(nèi)置256 KB Flash的分配情況如圖2所示。按照?qǐng)D2中存儲(chǔ)器的分配編寫(xiě)Scatter文件,在生成可執(zhí)行文件時(shí)鏈接器會(huì)根據(jù)Scatter文件的內(nèi)容把相關(guān)代碼段定位到特定的地址上。該例中,程序從Flash啟動(dòng),且沒(méi)有使用存儲(chǔ)器重映射,因此中斷向量必須定位到Flash的起始位置。
使用STR730開(kāi)發(fā)產(chǎn)品實(shí)現(xiàn)串口ISP在線編程的設(shè)計(jì)方案
扇區(qū)O的內(nèi)容需要事先通過(guò)JTAG口燒入,此后就可以利用扇區(qū)O中的燒錄程序Programrher.o通過(guò)串口進(jìn)行ISP。在整個(gè)ISP過(guò)程中扇區(qū)0的內(nèi)容是保持不變的,這樣就可以防止ISP過(guò)程中出現(xiàn)掉電之類的意外,導(dǎo)致初始化代碼Startup或燒錄程序Programmer受到損壞而無(wú)法再進(jìn)行ISP。
無(wú)論對(duì)嵌入式產(chǎn)品添加新功能還是修改原有的軟件BUG,涉及的都只是用戶應(yīng)用程序的改動(dòng),初始化代碼Startup.s是無(wú)需改動(dòng)的,所以扇區(qū)O的內(nèi)容在ISP過(guò)程中可否保持不變,關(guān)鍵是能否使首次編譯生成的Vector.0始終與以后多次編譯的App.o相匹配。
需要特別指出的是,當(dāng)用戶應(yīng)用程序發(fā)生改變時(shí),實(shí)際的中斷服務(wù)函數(shù)(一般是C語(yǔ)言函數(shù))很可能發(fā)生了改變,或者是實(shí)際的中斷服務(wù)函數(shù)的入口地址發(fā)生了改變,怎么通過(guò)固定不變的中斷向量Vector.o找到變化的中斷服務(wù)函數(shù)的入口呢?只要這個(gè)問(wèn)題解決了,就可以使首次編譯生成的Vector.o始終和以后多次編譯的App.o相匹配,這是該方案可行性的關(guān)鍵所在。為解決這個(gè)問(wèn)題,筆者在Flash的固定位置(0x80002000~0x800020ff)做了一個(gè)中斷映射表,實(shí)際上里面存放的是一條條跳轉(zhuǎn)指令。由于中斷映射表INTMap.s和用戶應(yīng)用程序App.c是一同編譯、鏈接的,里面的跳轉(zhuǎn)指令當(dāng)然可以準(zhǔn)確找到實(shí)際的中斷服務(wù)程序入口;而位于扇區(qū)O的中斷向量Vector.s雖然不和用戶應(yīng)用程序一起編譯,但中斷向量里的跳轉(zhuǎn)指令是跳轉(zhuǎn)到固定的中斷映射表區(qū)域。這樣通過(guò)2次跳轉(zhuǎn)就可以準(zhǔn)確找到中斷服務(wù)程序的入口。
可以通過(guò)圖3看出快中斷的處理流程(其他的中斷處理流程類似)。
2.2 ISP執(zhí)行的步驟
筆者把起到燒錄Flash作用的程序單獨(dú)作為一個(gè)工程編譯、鏈接,生成.bin文件;然后把.bin文件轉(zhuǎn)化成一個(gè)unsigned char型的數(shù)組,并把該數(shù)組放在一個(gè)單獨(dú)的文件Programmet.c中;利用Scatter文件把Programmer.o定位在固定的地址空間(0x80001000~Ox80001fff,如圖2所示)。這樣一來(lái),就可以編寫(xiě)匯編程序,把燒錄程序Pro—grammer.o拷貝到RAM中,并讓PC指針跳轉(zhuǎn)到RAM中執(zhí)行燒錄。由于STR730沒(méi)有外部Flash,要燒錄Flash程序必須在RAM中運(yùn)行,所以拷貝Programmer.o到RAM中是必需的。以下代碼摘取自Startup.s。
CMP r1,#1
燒錄程序Programmet的軟件流程如圖4所示。
需要說(shuō)明的是:
?、俨脸鼺lash并不是完全擦除,而是擦除扇區(qū)0之外的其他扇區(qū);
?、跀?shù)據(jù)緩沖區(qū)有限,每次只接收指定大小的數(shù)據(jù),這樣接收和燒錄就可以并行進(jìn)行,提高了ISP的速度;
?、蹫榱颂岣哕浖陌踩?,原始的.bin文件是經(jīng)過(guò)加密的,在燒錄前需要將原始數(shù)據(jù)解密。
3、結(jié) 語(yǔ)
本文闡述的這種通過(guò)串口ISP的方法已經(jīng)在實(shí)際的開(kāi)發(fā)生產(chǎn)過(guò)程中使用。實(shí)踐證明,相比其他燒錄Flash的方法有很多優(yōu)勢(shì),比如成本低、硬件連接簡(jiǎn)單、操作方便、增強(qiáng)軟件的安全性等。筆者使用的MCU是STR730,稍做改動(dòng)也可以把這種ISP方法推廣到其他ARM體系結(jié)構(gòu)的MCU上去。
版權(quán)與免責(zé)聲明
凡本網(wǎng)注明“出處:維庫(kù)電子市場(chǎng)網(wǎng)”的所有作品,版權(quán)均屬于維庫(kù)電子市場(chǎng)網(wǎng),轉(zhuǎn)載請(qǐng)必須注明維庫(kù)電子市場(chǎng)網(wǎng),http://www.udpf.com.cn,違反者本網(wǎng)將追究相關(guān)法律責(zé)任。
本網(wǎng)轉(zhuǎn)載并注明自其它出處的作品,目的在于傳遞更多信息,并不代表本網(wǎng)贊同其觀點(diǎn)或證實(shí)其內(nèi)容的真實(shí)性,不承擔(dān)此類作品侵權(quán)行為的直接責(zé)任及連帶責(zé)任。其他媒體、網(wǎng)站或個(gè)人從本網(wǎng)轉(zhuǎn)載時(shí),必須保留本網(wǎng)注明的作品出處,并自負(fù)版權(quán)等法律責(zé)任。
如涉及作品內(nèi)容、版權(quán)等問(wèn)題,請(qǐng)?jiān)谧髌钒l(fā)表之日起一周內(nèi)與本網(wǎng)聯(lián)系,否則視為放棄相關(guān)權(quán)利。
- 簡(jiǎn)述計(jì)算機(jī)總線的分類2025/9/4 17:12:23
- 深度剖析三進(jìn)線兩母聯(lián)供電系統(tǒng)設(shè)計(jì)方案2025/9/3 10:37:39
- 匯流排是什么匯流排好還是線接好2025/8/28 17:13:00
- 安森美 USB - C 電池充電器解決方案2025/8/28 15:45:10
- I2C 總線加上拉電阻的必要性2025/8/25 16:42:09