當(dāng)前位置:首頁 > 通信技術(shù) > 通信技術(shù)
[導(dǎo)讀]ICP是一種在實(shí)際的目標(biāo)電路板上燒寫和擦除芯片的方法,無需從目標(biāo)板上將芯片卸下來再編程實(shí)現(xiàn)用戶程序的修改。這種方法適用于產(chǎn)品開發(fā)和代碼升級(jí)。目前市面上很多芯片(如Philips公司的P89C51、P89V51和LPC932A1,STC

ICP是一種在實(shí)際的目標(biāo)電路板上燒寫和擦除芯片的方法,無需從目標(biāo)板上將芯片卸下來再編程實(shí)現(xiàn)用戶程序的修改。這種方法適用于產(chǎn)品開發(fā)和代碼升級(jí)。目前市面上很多芯片(如Philips公司的P89C51、P89V51和LPC932A1,STC89C51和STC89L516RD+,以及AVR公司的ATmega8系列等)都支持串口ICP方式。本文采用USB接口的ICP方法,燒寫速度快,無需專用的電平轉(zhuǎn)換芯片,硬件通過微處理器JB8的USB接口與計(jì)算機(jī)USB口連接即可。

  1 底層軟件實(shí)現(xiàn)方法

  1.1 Flash配置

  為使用ICP通信連接的USB接口,必須修改JB8中的用戶代碼以識(shí)別預(yù)先為ICP定義的USB命令。因此在出廠前,必須將ICP代碼燒入JB8中。JB8的Flash配置如圖1所示。

  

 

  圖1中,用戶Flash區(qū)范圍為$DC00~$FBFF,用戶Flash向量區(qū)是從$FFFO到$FFFF。ICP的配置中:ICP的代碼是從$F800到 $FBFF。用戶Flash向量區(qū)在ICP操作中是不能再編程的,這兩個(gè)區(qū)是JB8事先寫入的,ICP操作可以對(duì)$DCOO~$F7FF的Flash區(qū)(圖1中陰影區(qū))進(jìn)行擦除和燒寫。

  1.2 向量重定位

  因?yàn)镮CP的操作只能對(duì)用戶代碼進(jìn)行編程和燒寫,不能擦除用戶Flash向量,且用戶F1ash向量是固定的,因此在用戶代碼中的中斷服務(wù)子程序地址必須重新定位到合適的地址。這種重新定位是通過“假”向量來實(shí)現(xiàn)的,3字節(jié)的假向量包括JMP指令和在用戶代碼中的中斷服務(wù)子程序的絕對(duì)地址。圖2中指出了假向量是如何重定位的。只有復(fù)位向量沒有重新定位,總是指向$F800(ICP代碼的入口地址)。

  

 

  表1列出了中斷向量地址和重定位“假”向量地址。

  

1.3 安全密鑰防止非法訪問

 

  $FFF6~$FFFD的8字節(jié)內(nèi)容用于進(jìn)入JB8的監(jiān)控模式。監(jiān)控軟件能完全訪問F1ash區(qū),正常情況下,8字節(jié)的安全密鑰是不可能被猜出的,因?yàn)檫@些中斷服務(wù)程序的起始地址是被固化到用戶代碼區(qū)中的。

  1.4 在ICP期間防止掉電的措施

  配置ICP時(shí)必須考慮到ICP子程序運(yùn)行過程中有可能掉電,系統(tǒng)必須能夠恢復(fù)和完成ICP程序。ICP_FLAG字的設(shè)計(jì)正是基于此目的。復(fù)位后讀ICP_FLAG字,決定JB8是進(jìn)入正常的工作模式還是ICP模式。該字地址是$F7FE,在用戶代碼區(qū)的最后2個(gè)字節(jié)。復(fù)位之后,復(fù)位向量地址$FFFE~$FFFF指向ICP程序入口地址$F800,一旦初始化完成,檢查進(jìn)入ICP模式或用戶模式的條件。在以下2種情況下JB8進(jìn)入ICP模式:

 ?、?ldquo;假”向量的高字節(jié)$FF7C是無效的,即不在$DC和$F7之間;

  ②ICP_FLAG字不等于校驗(yàn)和。否則,JB8進(jìn)入正常的工作模式。

  1.5 ICP編程

  ICP編程流程圖如圖3所示。

  

 

  一旦用戶代碼被燒入芯片,而“假”向量的高字節(jié)在無效的范圍($DC~$F7),同時(shí)ICP_FLAG被寫入校驗(yàn)和(不能是$0000),則在插撥USB設(shè)備后,ICP代碼跳轉(zhuǎn)到正常操作的用戶模式。

  進(jìn)入JB8 ICP模式有2種方式:ICP_FLAG被寫入$0000,或者PTA0被下拉成低電平。用戶代碼包括特別的命令來編寫ICP_FLAG,一旦ICP_FLAG被寫入零,則再次插撥上電后,JB8進(jìn)入ICP模式。ICP指令支持有限的USB標(biāo)準(zhǔn)協(xié)議,如讀取描述符和狀態(tài)字,設(shè)置地址和配置字,以及清特征字。

  本文使用了一些必要的擦除、編程、校驗(yàn)Flash命令,如表2所列。

  

 

  在使用讀取狀態(tài)命令后,程序返回1字節(jié)的應(yīng)答命令來表示Program Row(行編程命令)、Erase Block(塊擦除命令)和Verify Row(行校驗(yàn)命令)命令是否成功。字節(jié)$01表示命令執(zhí)行成功,字節(jié)$04表示命令執(zhí)行失敗。

  1.6 ICP_FLAG的編程

  由于JB8是為HID應(yīng)用設(shè)計(jì)的,最好使用HID命令來編寫ICP_FLAG,這樣可以無需額外的驅(qū)動(dòng)。本文使用8字節(jié)的Set_Feature指令來設(shè)置ICP_FLAG,使用8字節(jié)的Get_Ack指令(只有1字節(jié)是有用的)來校驗(yàn)設(shè)置是否正確(響應(yīng)為$0O表示命令成功,為$01表示命令失敗)。設(shè)置8字節(jié)足出于安全的考慮,如果這8字節(jié)與JB8中$FFE6~$FFED的8字節(jié)相匹配,那么命令才是有效的。只有命令有效,ICP_FLAG才會(huì)被寫入0。指令使用格式如表3所列。

  

2 應(yīng)用軟件

 

  USB ICP驅(qū)動(dòng)程序的安裝與普通的硬件驅(qū)動(dòng)程序安裝一樣,需要安裝USB ICP.SYS文件和注冊(cè)表文件USBICP.INF。USB ICP的Windows運(yùn)行界面如圖4所示。

  

 

  選擇燒寫文件(.SX格式),擦除Flash(Erase Flash)后執(zhí)行空檢查(Blank Check),然后選擇燒寫(Program)芯片,最后執(zhí)行校驗(yàn)(Verify)。

  結(jié)語

  本文采用集成USBl.1協(xié)議的MC68HC908JB8,擴(kuò)展了ICP在串行口的應(yīng)用方式用于開發(fā),調(diào)試方便,實(shí)際運(yùn)行效果很好,有一定的應(yīng)用價(jià)值。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉