《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 業(yè)界動態(tài) > C6202 ROM引導(dǎo)裝載方式的研究

C6202 ROM引導(dǎo)裝載方式的研究

2008-10-06
作者:王麗敏 王工藝 趙 宏

??? 摘? 要: 通過使用DMA方式訪問程序存儲區(qū)并實現(xiàn)程序的搬移,克服C6000指令系統(tǒng)的缺陷;并對C6000的C語言運行環(huán)境和仿真器變量初始化過程進行研究,采用自編程自初始化的方法,確保程序加載" title="加載">加載后能正常運行。?

??? 關(guān)鍵詞: 引導(dǎo)裝載? DMA? DSP

?

??? DSP系統(tǒng)的引導(dǎo)裝載(Bootload)是指系統(tǒng)加電時,DSP將一段存儲在外部的非易失性存儲器的代碼搬移到內(nèi)部的高速存儲器單元中執(zhí)行。這樣既利用了外部的存儲單元擴展DSP本身有限的ROM資源,又充分發(fā)揮了DSP內(nèi)部資源的效能。盡管用戶代碼可直接掩膜到內(nèi)部ROM中,但一方面受容量和價格的限制,另一方面則不具有擴展性和不易升級。FLASH是一種高密度、非易失性的電可擦寫存儲器,十分適合低功耗、小尺寸和高性能的便攜式系統(tǒng)。除了可以采用專用的硬件編程器把代碼灌入FLASH中,也可以利用現(xiàn)成的DSP通過軟件編程實現(xiàn)同樣的功能,因此對整個系統(tǒng)的軟件升級很方便。?

??? TMS320C6000系列是TMS320系列產(chǎn)品中的新一代高性能DSPs芯片。由于其結(jié)構(gòu)上(如圖1)的特殊性,與C54系列的引導(dǎo)方式有很大差別。本文以C6202為例,介紹如何實現(xiàn)DSP正常的ROM引導(dǎo)。?

?

?

1 C6202的ROM引導(dǎo)模式?

??? C6202有兩種存儲器映射方式MAP0和MAP1。通過擴展總線的XD[4:0]利用上拉/下拉電阻進行復(fù)位時的芯片啟動模式設(shè)置。本文將存儲器映射方式設(shè)置為MAP1,即地址0處的存儲器在內(nèi)部,芯片自加載方式為8bit ROM方式,如圖2的硬件連接。?

?

?

??? 設(shè)置完芯片加載方式后,ROM加載的具體過程是:位于外部CE1空間的ROM(即圖2中的FLASH)中的程序首先通過DMA[2]搬入地址0處,盡管加載過程是在芯片復(fù)位信號被釋放后才開始的,但是當芯片開始復(fù)位時,就開始準備上述傳輸了。用DMA進行的這一加載過程是一個單幀的數(shù)據(jù)塊傳輸,數(shù)據(jù)塊的大小為64KB。EMIF[2]會根據(jù)芯片自加載方式的設(shè)置將相鄰的8bit或16bit數(shù)據(jù)合為32bit指令。傳輸完成后,CPU退出復(fù)位狀態(tài),開始執(zhí)行地址0處的指令。?

2 硬件設(shè)計?

??? 本文僅給出DSP(TMS320C6202)與一片F(xiàn)LASH(AMD29VF040)的連接圖,如圖2。由DSP的相關(guān)輸出管腳控制FLASH的擦除和讀寫。C6202的EMIF含有四個CE空間寄存器,由于ROM加載程序是從CE1空間搬入的,因此DSP的/CE1與FLASH的片選/CE相連。圖2中只用到DSP的低8位數(shù)據(jù)線,如果自加載方式設(shè)置為16位或32位,可以通過DSP最低兩位EA1和EA0的譯碼BE[3:0]片選,或者選用16bit或32bit的FLASH。?

3 軟件設(shè)計?

??? 由于C6000的特殊結(jié)構(gòu),可以實現(xiàn)8條并行指令同時執(zhí)行,除非對硬件結(jié)構(gòu)非常了解的專業(yè)人員,才能充分利用硬件資源,將匯編語言的高效率發(fā)揮出來。若對實時性要求不是很高,采用C語言編程完全可以滿足需要,且C6000的優(yōu)化器優(yōu)化效率很高。這樣可以降低編程工作量,縮短開發(fā)周期,可移植性好。本文以通用的C語言編程為例,介紹DSP對FLASH編程以實現(xiàn)正常的ROM引導(dǎo)。?

3.1 系統(tǒng)初始化?

??? 在運行C語言前,必須建立C運行時間環(huán)境[3](C runtime environment),確保C程序的正常運行。運行時間支持源程序庫(runtime-support source library)rts.src包含一個boot.asm模塊可以實現(xiàn)此功能。在連接器命令中使用-c或-cr選項,且將rts6200.lib作為其中一個連接文件,連接器自動調(diào)用boot.asm模塊產(chǎn)生c_int00函數(shù)。在硬件復(fù)位中斷產(chǎn)生以及系統(tǒng)工作時,先執(zhí)行此函數(shù)。?

??? 函數(shù)c_int00完成下面三個初始化任務(wù):?

??? (1)建立堆棧并初始化堆棧指針;?

??? (2)初始化全局變量;?

??? (3)運行主函數(shù)。?

3.2 初始化變量?

??? 在程序運行前,全局變量必須初始化。編譯器建立了.cinit段用來初始化全局變量和靜態(tài)變量。?

3.2.1 .cinit段?

??? 在.cinit段內(nèi)有不同長度的初始化記錄,每一個必須初始化的變量在.cinit段內(nèi)都有一個對應(yīng)的記錄。如圖3。?

?

?

??? 每個記錄包含三部分:需要被初始化的變量的長度、變量的地址和變量初始值。?

3.2.2 運行時初始化變量?

??? 若在連接器中使用-c選項,則在程序開始運行時,函數(shù)c_int00初始化變量。具體過程如下:仿真器加載程序時,根據(jù).cmd文件的定位,將.cinit段拷貝到C6202的程序存儲區(qū)或數(shù)據(jù)存儲" title="數(shù)據(jù)存儲">數(shù)據(jù)存儲區(qū),并且用指針指向加載后的初始化表的首地址。當程序開始運行時,函數(shù)c_int00中的引導(dǎo)程序自動識別初始化表中的數(shù)據(jù)格式,初始化.bss段中對應(yīng)的變量,完成初始化過程。如圖4。

?

?

3.2.3 加載時初始化變量?

??? 若在連接器中使用-cr選項,連接器在.cinit段首設(shè)置STYP_COPY位。當仿真器加載程序時,加載器會判斷這一位,識別目標文件中.cinit內(nèi)的初始化記錄格式并初始化.bss中的變量,而不是先將.cinit段拷貝到DSP的內(nèi)存區(qū)域。如圖5。?

?

?

3.3 燒寫" title="燒寫">燒寫FLASH?

??? 要想實現(xiàn)DSP ROM的正常加載,必須將程序存儲區(qū)中的指令數(shù)據(jù)正確地寫到FLASH里。圖1中可以看出,訪問片內(nèi)程序存儲器" title="程序存儲器">程序存儲器只有兩個途徑:CPU訪問和DMA訪問。CPU訪問片內(nèi)程序存儲器是通過程序取指單元實現(xiàn)的,然后完成指令分配和指令譯碼。C6000沒有提供任何對片內(nèi)程序存儲器操作的指令,因此不可能直接使用指令取出程序區(qū)的內(nèi)容或者將數(shù)據(jù)寫入程序區(qū)中。但是DMA可以訪問片內(nèi)數(shù)據(jù)存儲區(qū)、片內(nèi)程序存儲區(qū)、片內(nèi)集成外設(shè)、外接存儲器等,可以在沒有CPU參與的情況下完成映射存儲空間中數(shù)據(jù)的搬移。因此,可以編寫一個燒寫FLASH的程序。在數(shù)據(jù)存儲區(qū)開辟一個緩存區(qū),使用DMA方式將程序區(qū)的內(nèi)容讀到這個緩存區(qū),然后再使用指令將緩存區(qū)的內(nèi)容燒寫到FLASH內(nèi)(具體的命令字和程序與C54類似)。如圖6。?

?

?

??? 為了保證DSP ROM加載后C運行環(huán)境正常,全局變量或者靜態(tài)變量必須初始化。這比使用仿真器加載程序要復(fù)雜。解決這個問題,最簡單的方法就是:將燒寫FALSH的程序(不能含有全局變量和靜態(tài)變量)和主程序" title="主程序">主程序編在一起,在連接器中選擇-cr選項,用仿真器加載編譯連接后的程序會自動初始化主程序中的變量。將DSP的PC指針直接跳轉(zhuǎn)到燒寫FALSH程序處,按照前面的方法使用DMA方式把主程序燒寫到FLASH內(nèi)部,再把已經(jīng)初始化的變量燒寫到FLASH的其他位置,不能覆蓋已經(jīng)寫入的數(shù)據(jù)。另外,在主程序內(nèi)要自己編寫一個自加載函數(shù),完成加載器的功能,即把固化在FLASH內(nèi)部的變量值讀入.cmd文件所定位的.bss中,實現(xiàn)脫機運行時變量的初始化。?

??? 筆者在實驗中遇到了C6202 ROM加載的問題,通過對DSP內(nèi)部功能單元的研究,發(fā)現(xiàn)采用DMA方式訪問程序存儲區(qū),實現(xiàn)了程序塊的搬移,克服了C6000指令系統(tǒng)的缺陷;對C6000的C語言運行環(huán)境進行研究,發(fā)現(xiàn)仿真器進行變量初始化的過程,采用自編程自初始化的方法,確保程序加載后能正常運行。?

參考文獻?

1 Texas Instruments.TMS320C6000 CPU and Instruction Set?Reference Guide. 2000?

2 Texas Instruments. TMS320C6000 Peripherals Reference?Guide.2001?

3 Texas Instruments. TMS320C6000 Optimizing C Compiler?User's Guide. 2001?

4 任麗香,馬淑芬,李方慧.TMS320C6000系列DSps的原理與應(yīng)用.北京:電子工業(yè)出版社,2001?

5 趙訓(xùn)威.基于TMS320C6200系列DSP芯片的應(yīng)用與開發(fā).北京:人民郵電出版社,2002

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經(jīng)濟損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
主站蜘蛛池模板: 国产一精品一aⅴ一免费| 天堂久久久久久中文字幕| 久久综合久久鬼| 欧美精品videossex欧美性| 内地女星风流艳史肉之| 西西人体44rt大胆高清日韩| 国产真实乱子伦精品视| 69性欧美高清影院| 在线观看视频免费123| 一区二区三区杨幂在线观看| 揄拍成人国产精品视频| 久久精品亚洲欧美日韩久久| 欧洲成人爽视频在线观看 | 国产羞羞视频在线播放| japanese色国产在线看免费| 强开小婷嫩苞又嫩又紧视频韩国| 久久久久成人精品无码| 日韩伦理一区二区| 久夜色精品国产一区二区三区| 欧美一级免费看| 亚洲国产日韩在线| 欧美日韩高清性色生活片| 亚洲精品自在线拍| 牛牛影院毛片大全免费看| 免费a级毛片无码专区| 精品一区二区三区在线视频| 厨房切底征服麻麻| 美女**毛片一级视频| 国产91最新在线| 草草影院私人免费入口| 国产亚洲蜜芽精品久久| 久久大香香蕉国产| 极品唯美女同互摸互添| 亚洲中字慕日产2021| 欧美人七十二式性视频教程一| 亚洲国产精品无码久久久蜜芽 | 国产成人午夜福利在线播放| 黄+色+性+人免费| 国产成人综合久久久久久| 国产一区在线mmai| 国产成人啪精品视频免费网|