下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
TMS320F2812片內(nèi)Flash在線燒寫技術(shù)
TMS320F2812(以下簡稱F2812)是美國德州儀器公司(TI)新一代32位定點數(shù)字信號處理器(DSP),主要應(yīng)用于逆變器控制、電機控制等領(lǐng)域,并擁有工作頻率高達(dá)150MHz的32位DSP內(nèi)核處理器,可以高效可靠地實現(xiàn)自適應(yīng)控制和狀態(tài)控制等。因此,TMS320F28X系列DSP已成為自動控制領(lǐng)域的首選控制器件。F2812片內(nèi)擁有高達(dá)128KBx16位的F1ash程序存儲器,可以滿足大多數(shù)程序存儲需要。在研究基于JTAG接口的兩種常用Flash燒寫技術(shù)(CCS插件燒寫技術(shù)和Flash281x_API函數(shù)庫燒寫技術(shù))的基礎(chǔ)上,提出了一種利用RS485與PC機的串行通訊實現(xiàn)Flash燒寫的方法。
F2812片內(nèi)Flash簡介TMS320F2812原理與開發(fā)
F2812帶有128KBxl6位的片內(nèi)Flash存儲器,分為4個8KBxl6位和6個16KBxl6位的扇區(qū),用戶可以單獨擦除、編程和驗證Flash的一個扇區(qū)而不會影響其他扇區(qū),但不能用F1ash的一個扇區(qū)執(zhí)行Flash的算法對其他扇區(qū)擦除或編程。F1ash還可映射到程序數(shù)據(jù)空間,因此它既可用于執(zhí)行代碼,也可存儲數(shù)據(jù)信息。
TI代碼產(chǎn)生工具所產(chǎn)生的目標(biāo)文件是一種模塊化文件格式一一COFF格式,即.out文件。程序中的代碼和數(shù)據(jù)在COFF格式文件中以段形式形成,不同的段存放不同類型的內(nèi)容.應(yīng)用中通過編寫連接器命令文件(.cmd)將這些段正確地分配到DSP的地址空間,DSP集成開發(fā)環(huán)境CCS經(jīng)編譯鏈接之后。生成.out文件和.map文件。.map文件詳細(xì)描述了.cmd文件中定義的各段起始地址以及使用長度。而out文件為COFF格式,DSP能夠識別,但不能直接燒寫到Flash,必須將.out文件轉(zhuǎn)換為Flash能識別的數(shù)據(jù)格式,即.hex的數(shù)據(jù)文件。利用CCS轉(zhuǎn)換和.hex轉(zhuǎn)換工具HEX2000進(jìn)行轉(zhuǎn)換。
基于JTAG的燒寫技術(shù)3.1CCS插件燒寫技術(shù)
利用燒寫插件完成Flash的燒寫無需數(shù)據(jù)轉(zhuǎn)換,只需通過程序調(diào)試生成.out文件即可。由于調(diào)試階段程序的.cmd文件存放在F2812的RAM,而燒寫階段程序則存放在Flash,即調(diào)試階段程序的重新定位不能在CCS環(huán)境下運行,需要編寫兩個不同的.cmd文件。3.2Flash281x_API函數(shù)燒寫技術(shù)
F1ash281xAPI函數(shù)庫燒寫技術(shù)是利用TI公司的編程算法.該算法定義良好,操作簡單,而且可以脫離燒寫插件,真正實現(xiàn)在線燒寫。
編程算法中函數(shù)定義如下:(1)擦除扇區(qū)的函數(shù)為Uintl6F1ash2812Erase(SectorMask,&FStatus),其中,SectorMask為擦除指定扇區(qū);&Fstatus為狀態(tài)值,判斷操作是否成功。(2)燒寫程序到F1ash函數(shù)為Uintl6Flash2812_Program(&FlashAddr,&BuffAddr,Length,&FStatus),其中&FlashAddr為程序在Flash中燒寫的起始地址;&BuffAddr為程序當(dāng)前存放在內(nèi)存空間的首地址:Length為程序長度;&Fstatus為狀態(tài)值,判斷操作是否成功。(3)校驗燒寫到Flash中的程序為Uintl6Flash2812_Verifv(&FlashAddr,&BuffAddr,Length,&FStatus)。
Flash28x_API函數(shù)燒寫步驟如下:
(1)先將.hex格式數(shù)據(jù)下載到F2812的內(nèi)存.在CCS環(huán)境下完成File→Data→Load,并存放地址和數(shù)據(jù)長度兩個參數(shù),其中數(shù)據(jù)長度可以通過HEX轉(zhuǎn)換為.map文件獲得。
(2)編寫基于Flash281x_API函數(shù)的燒寫程序。先擦除相應(yīng)的Flash扇區(qū),通過Flash2812_Erase函數(shù)完成;將數(shù)據(jù)的起始地址和數(shù)據(jù)長度兩個參數(shù)分別賦給&FlashAddr和Length變量,然后調(diào)用Flash2812_Program函數(shù)開始燒寫,最后調(diào)用Flash2812_Verify函數(shù)確定燒寫是否成功。
FlashAPI與用戶工程建立關(guān)聯(lián)后,目標(biāo)代碼通過調(diào)用API函數(shù),實現(xiàn)對Flash的擦除、燒寫和校驗等操作,F(xiàn)lash的密碼保護(hù)值不全為0,否則Flash將被鎖死導(dǎo)使無法解鎖。串口燒寫FlaSh技術(shù)
基于JTAG的燒寫技術(shù)必須在CCS環(huán)境下通過JTAG接口實現(xiàn)。雖然基于JTAG接口的兩種燒寫方法易于操作,方便調(diào)試,但常常受空間和傳輸距離限制。比如一臺DSP系統(tǒng)安裝在復(fù)雜、封閉的環(huán)境下,當(dāng)程序需要更新或升級時,利用JTAG接口難以實現(xiàn)Flash的在線燒寫。而通過串口燒寫技術(shù)采用“程序”燒寫“程序”的方法則不受限制。前一個“程序”指已固化程序,用于實現(xiàn)串口燒寫的時機判斷、數(shù)據(jù)接收及燒寫的具體實施等,該程序使用了Flash281x_API庫編程算法;而后一個“程序”是用戶的應(yīng)用目標(biāo)代碼。
實現(xiàn)串口燒寫技術(shù)軟件分為PC機內(nèi)用于數(shù)據(jù)發(fā)送的頂層軟件和目標(biāo)機內(nèi)的底層軟件。頂層軟件可實現(xiàn)用戶程序的解析等;而底層軟件可實現(xiàn)由串口發(fā)送的數(shù)據(jù)燒寫至Flash。F2812DSP每次上電復(fù)位,先運行底層軟件,判斷是否需要重新燒寫Flash。若需要,則將串口發(fā)送的目標(biāo)代碼燒寫至F2812片內(nèi)Flash指定扇區(qū);否則將繼續(xù)執(zhí)行原有的用戶目標(biāo)代碼。4.1頂層軟件
頂層軟件可實現(xiàn)用戶程序的解析等工作。其用戶程序為.oul文件,頂層軟件主要完成.hex文件的解析,并將解析后的有用數(shù)據(jù)發(fā)送至目標(biāo)DSP。.hex文件的組織格式嚴(yán)格,只要提取數(shù)據(jù)在內(nèi)存中的存放地址和數(shù)據(jù)長度就可以按照要求將數(shù)據(jù)發(fā)送給目標(biāo)DSP。如果用戶程序很大而目標(biāo)DSP的內(nèi)存空間不足時,該過程還可以分段進(jìn)行。頂層軟件可以使用VC++或者LabVIEW等實現(xiàn)。4.2底層軟件
底層軟件用于實現(xiàn)將串口發(fā)來的數(shù)據(jù)燒寫至Flash.涉及到用戶程序的正確定位和復(fù)位后的啟動過程,是整個軟件設(shè)計的重點。底層軟件主要實現(xiàn)以下功能:
(1)燒寫程序搬移功能。由于F2812片上Flash不支持在其中一個扇區(qū)運行程序去擦除或燒寫其他扇區(qū),故完成接收數(shù)據(jù)和燒寫Flash工作的這部分程序需搬移至片內(nèi)RAM或片外RAM上運行。實現(xiàn)程序搬移的函數(shù)為:
其中,SourceAddr為Flash中程序的起始地址,即源程序開始地址;SourceEndAddr為Flash中程序的結(jié)束地址,即源程結(jié)束序地址;DestAddr為搬移至內(nèi)存的首地址。
(2)上電復(fù)位查詢功能。上電復(fù)位后查詢一個通用I/O端口的狀態(tài)以確定是否需要燒寫程序。這個通用I/O端口可由用戶自行確定,但I(xiàn)/O端口占用后其特殊功能便不可用,上電復(fù)位后保證其確定狀態(tài),否則會不間斷燒寫程序或者不能正確跳轉(zhuǎn)到用戶應(yīng)用程序。
(3)接收PC機發(fā)送的數(shù)據(jù)并保存到目標(biāo)DSP內(nèi)存。這是在串口接收中斷服務(wù)子程序中完成的,并確定用于數(shù)據(jù)保存的這部分內(nèi)存未占用。
(4)接收結(jié)束后將內(nèi)存中的數(shù)據(jù)燒寫至指定Flash扇區(qū),這由Flash28lx_APl庫函數(shù)完成。圖1為底層應(yīng)用軟件流程圖。4.3底層軟件的定位
電復(fù)位后,XMP/MC引腳為低電平.目標(biāo)DSP處于計算機模式,CPU將從內(nèi)部BootRom獲得復(fù)位向量。復(fù)位向量指向BootRom并執(zhí)行其內(nèi)部的Bootloader程序,執(zhí)行完畢后確定從內(nèi)部Flash啟動.程序指針跳轉(zhuǎn)到Flash的Ox3F7FF6處.這個地址是同定的,因此底層軟件程序必須燒寫在以這個地址為起始地址的空間內(nèi),或者在0x3F7FF6燒寫一條跳轉(zhuǎn)指令,上電復(fù)位后通過跳轉(zhuǎn)指令跳轉(zhuǎn)到底層軟件程序。4.4用戶應(yīng)用程序的定位
用戶應(yīng)用程序從main函數(shù)開始,但DSP首先必須調(diào)用_c_int00函數(shù)建立C語言的運行環(huán)境,主要包括:建立初始化系統(tǒng)堆棧,把.cinit段中的數(shù)據(jù)表拷貝到.bss段。對全局和靜態(tài)變量初始化等。_c_int00執(zhí)行結(jié)束后調(diào)用main函數(shù)開始運行用戶應(yīng)用程序。因此_c_int00函數(shù)的首地址才是整個程序的入口點。底層軟件程序執(zhí)行結(jié)束后應(yīng)該調(diào)用_c_int00函數(shù),而不是main函數(shù),可用跳轉(zhuǎn)指令實現(xiàn),參考程序如下:
討論的Flash三種在線燒寫技術(shù)在實際工程中均得到實際運用。采用TMS320F2812作為控制器的數(shù)據(jù)采集系統(tǒng).利用F
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 廣告宣傳合同廣告合同協(xié)議書
- 設(shè)備維保的預(yù)測性維護(hù)與故障預(yù)測技術(shù)
- 數(shù)字經(jīng)濟(jì)助力“雙碳”目標(biāo)的內(nèi)在機理及路徑
- 機電事故案例匯編
- 基于水下感應(yīng)耦合原理的數(shù)據(jù)傳輸系統(tǒng)優(yōu)化研究
- 基于人體姿態(tài)的人物交互檢測算法研究
- 高光譜微波輻射探測關(guān)鍵技術(shù)研究
- 高速公路隧道維修工程招標(biāo)合同三篇
- 消息驅(qū)動跳頻通信抗干擾技術(shù)研究
- 2025年西師新版選修歷史下冊階段測試試卷
- 標(biāo)準(zhǔn)作文稿紙模板(A4紙)
- 中小學(xué)校園突發(fā)事件應(yīng)急與急救處理課件
- 2024年山東省普通高中學(xué)業(yè)水平等級考試生物真題試卷(含答案)
- 2024年青海省西寧市選調(diào)生考試(公共基礎(chǔ)知識)綜合能力題庫匯編
- 2024年湖南高速鐵路職業(yè)技術(shù)學(xué)院單招職業(yè)技能測試題庫及答案解析
- 廣州綠色金融發(fā)展現(xiàn)狀及對策的研究
- 《近現(xiàn)代史》義和團(tuán)運動
- 時間的重要性英文版
- 2024老舊小區(qū)停車設(shè)施改造案例
- 灰壩施工組織設(shè)計
- 韓國《寄生蟲》電影鑒賞解讀
評論
0/150
提交評論