《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 設(shè)計應(yīng)用 > TMS320C6000 DSP系統(tǒng)的引導(dǎo)設(shè)計
TMS320C6000 DSP系統(tǒng)的引導(dǎo)設(shè)計
陸侃蕓 宋 瑩 季曉勇
摘要: 在分析比較了TMS320C6000的三種自舉模式后,針對原來DSP自舉模式的利弊提出了一種可行的系統(tǒng)引導(dǎo)解決方案,并以基于TMS320C6202的圖像處理系統(tǒng)的引導(dǎo)實現(xiàn)為例進行了詳細介紹。
關(guān)鍵詞: DSP 自舉模式 Flash TMS320C6000 TI
Abstract:
Key words :

  摘  要: 在分析比較了title="TMS320C6000">TMS320C6000的三種自舉模式后,針對原來DSP自舉模式的利弊提出了一種可行的系統(tǒng)引導(dǎo)解決方案,并以基于TMS320C6202的圖像處理系統(tǒng)的引導(dǎo)實現(xiàn)為例進行了詳細介紹。

  關(guān)鍵詞: 自舉模式  數(shù)字信號處理  Flash芯片

 

  在數(shù)字信號處理(DSP)系統(tǒng)設(shè)計中,通常不把程序固化在DSP內(nèi),而是將程序先保存在片外存儲器內(nèi),在系統(tǒng)上電后利用DSP自舉引導(dǎo)功能將片外程序調(diào)入片內(nèi)程序空間后運行程序。要設(shè)計好系統(tǒng)的自舉,首先要了解DSP的自舉流程;其次要清楚DSP程序的結(jié)構(gòu)以及存儲空間的分配;然后根據(jù)實際系統(tǒng)的需要實現(xiàn)自己系統(tǒng)的自舉。下面針對TI的TMS320C6000系列DSP,介紹一種可行的系統(tǒng)引導(dǎo)解決方案,并以基于TMS320C6202(以下簡稱C6202)的圖像處理系統(tǒng)的引導(dǎo)為例進行詳細說明。

1  系統(tǒng)引導(dǎo)設(shè)計

1.1 各類自舉模式的比較選擇

  TI公司的TMS320C6000系列DSP有三類自舉模式:主機(HPI)引導(dǎo)模式、不加載模式和ROM加載模式。

  在主機引導(dǎo)模式下,外部主機在DSP處于復(fù)位狀態(tài)、硬件其他部分保持正常狀態(tài)期間通過主機口將程序?qū)懭隓SP的內(nèi)部存儲空間;然后將主機口控制寄存器中的DSPINT位設(shè)置為1,使DSP退出復(fù)位狀態(tài),開始執(zhí)行0地址處指令。該模式下DSP無法自己完成初始化,需有一主機控制。所以主機引導(dǎo)模式不適用于一般的基于DSP的系統(tǒng)。

  在不加載模式下,C6000直接從0地址處執(zhí)行程序指令,這時0地址處的存儲器可以為SDRAM、SBSRAM、32位異步器件、DSP內(nèi)部RAM空間的一個。顯然,只有0地址為32位Flash(或ROM)時才能實現(xiàn)系統(tǒng)上電后的正常運行。然而,當前的Flash多為8位或者16位,所以至少需2片16位的Flash才能在該模式下實現(xiàn)系統(tǒng)的自引導(dǎo),而用多片F(xiàn)lash就會增加系統(tǒng)的負擔(dān)和成本。所以這個模式在C6000中也不是最好的。

  C6000整個外部程序空間分為CE0~CE3四個空間。在ROM加載模式下,DSP上電后首先通過DMA/EDMA將CE1空間的64KB(C6201/C6202/C6701)或1KB(C6211/C6711)數(shù)據(jù)復(fù)制到0地址處,然后開始執(zhí)行地址0處的指令。該模式下CE1空間可以是8位、16位或32位ROM/Flash,EMIF會自動將相鄰8/16位數(shù)據(jù)合成為32位的指令。所以采用這種加載方式的接口設(shè)計簡單,DSP的EMIF可以與Flash實現(xiàn)無縫連接,而且只需一片F(xiàn)lash即可。

  縱觀上述三種自舉模式可知,ROM加載模式是最方便有效的。然而當系統(tǒng)DSP運算較為復(fù)雜、運算量較大,程序空間大于64KB(C6201/C6202/C6701)或1KB(C6211/C6711)時,在上電后系統(tǒng)就無法把所有的程序放入DSP內(nèi)存儲,從而無法正確實現(xiàn)系統(tǒng)的自引導(dǎo)。另一方面,由于C6x0x系列的DSP采用哈佛結(jié)構(gòu),程序空間和數(shù)據(jù)空間完全分開,不能通用,而DSP0地址開始的64KB為程序空間,所以在64KB程序復(fù)制到0地址后數(shù)據(jù)常量空間也需要被導(dǎo)入數(shù)據(jù)空間,否則系統(tǒng)同樣無法實現(xiàn)自引導(dǎo)。

1.2 ROM加載模式下的系統(tǒng)引導(dǎo)設(shè)計

  經(jīng)過分析,在原來ROM加載模式基礎(chǔ)上設(shè)計了如下的一種系統(tǒng)引導(dǎo)方式,從而解決了程序較大、數(shù)據(jù)空間不能初始化等問題。

  首先,自行編制一引導(dǎo)程序(稱為loadprogram)。該程序可將存放于CE1空間內(nèi)的系統(tǒng)目標程序和常量數(shù)據(jù)分別調(diào)入DSP程序和數(shù)據(jù)空間。loadprogram程序的起始地址為0,數(shù)據(jù)常量地址為CE1空間的某固定地址。之后,將loadprogram程序代碼固化在CE1空間的首地址,其數(shù)據(jù)常量固化在loadprogram定義的CE1空間。

  如圖1所示,在ROM加載時,DSP自動將CE1空間的loadprogram導(dǎo)入DSP0地址處,而數(shù)據(jù)常量也已經(jīng)存在于loadprogram定義的數(shù)據(jù)空間中。這樣在ROM加載結(jié)束后DSP自動運行0地址程序,即loadprogram程序,從而進行系統(tǒng)的第二次加載,即將系統(tǒng)目標程序和數(shù)據(jù)加載到DSP內(nèi),然后運行系統(tǒng)目標程序。這樣就最終實現(xiàn)了系統(tǒng)的正確引導(dǎo)。

 

1.3 設(shè)計實現(xiàn)中的問題

  在實現(xiàn)這個系統(tǒng)自舉設(shè)計中有二個需要注意的問題。

  (1)loadprogram和系統(tǒng)目標程序都是在DSP內(nèi)部空間運行的,所以要合理分配二個程序在DSP內(nèi)的程序空間和數(shù)據(jù)空間。系統(tǒng)目標程序在DSP內(nèi)的存儲空間不能和loadprogram的存儲空間重合,否則在loadprogram的運行過程中,loadprogram內(nèi)容會被改寫,從而使整個系統(tǒng)引導(dǎo)的過程出錯。

  (2)loadprogram和系統(tǒng)目標程序以及它們的一些數(shù)據(jù)常量都要固化在Flash/ROM內(nèi),所以必須得到它們的程序和數(shù)據(jù)代碼,并且合理安排它們在Flash/ROM的排放,最終方便有效地實現(xiàn)系統(tǒng)的引導(dǎo)。

2  實  例

  本實例用TMS320C6202來實現(xiàn)視頻圖像的編碼。系統(tǒng)的自引導(dǎo)主要由C6202和256KB的16位Flash(SST39VF400A)實現(xiàn)。

2.1 系統(tǒng)目標程序

  系統(tǒng)的編碼程序由匯編和C語言編寫實現(xiàn),經(jīng)過編譯得到目標執(zhí)行文件program.out,它由表1所示各段組成。其中.vector和.text段為程序代碼段;.cinit為C編譯后產(chǎn)生的變量初值表,在程序開始的時候系統(tǒng)會將.cinit中的初值寫入C中定義的各需要賦初值的變量空間中;.const和.data分別為C和匯編中的常量段;其他各段為系統(tǒng)的變量、堆棧等無需初值的數(shù)據(jù)段。所以loadprogram就是要將.vector、.text、.cinit、.const、.data寫入相應(yīng)的DSP內(nèi)部空間中。

 

  目標程序要做的就是把執(zhí)行文件program.out轉(zhuǎn)化為代碼,燒寫入Flash,以防被loadprogram讀取寫入DSP內(nèi)。這里,首先用hex6x.exe將program.out轉(zhuǎn)化為16進制文件,然后利用自編的程序?qū)ζ溥M行整理,得到3個隊列:

  short pg[]={0xA02A,0x01DD,……};   /*程序代碼隊列,包括程序和數(shù)據(jù)代碼*/

  unsigned int addarray[]={0x0,0x0d00,0x80003968,0x80004310,0x8001a358};

                         /*代碼地址隊列*/

  int sectlen[]={512,56288,176,5666,64};    /*代碼長度隊列,各起始地址開始的代碼長度*/

  也就是說,pg[]由地址分別為addarray[0]、addarray[1]、addarray[2]、addarray[3]、addarray[4],長度分別為sectlen[0]、sectlen[1]、sectlen[2]、sectlen[3]、sectlen[4]的五段代碼組成。

  將pg[]燒入Flash內(nèi)的空間。

2.2 loadprogram程序

  如上所述,loadprogram就是要將上述五個代碼段寫入相應(yīng)的addarray[0]、addarray[1]、addarray[2]、addarray[3]、addarray[4]地址中。由于C6202的程序空間只能通過DMA方式訪問,所以采用DMA方式進行系統(tǒng)程序的引導(dǎo)。關(guān)鍵代碼如下:

  

  整個loadprogram編譯后的組成如表2所示。

 

  同目標程序一樣,也可以得到pg[]、addarray[]、sectlen[]三個隊列。

2.3 Flash與DSP的空間分配

  如圖2所示,圖中標號1表示loadprogram程序內(nèi)容,標號2表示目標程序內(nèi)容。由于Flash即CE1空間的64KB代碼將會直接加載到DSP內(nèi)運行,所以loadprogram在Flash和DSP內(nèi)的地址是一一對應(yīng)的,而loadprogram的

.cinit空間始終是CE1多余的某部分空間。這樣就避免了ROM加載后.cinit空間沒有被初始化而導(dǎo)致系統(tǒng)出錯的問題。

系統(tǒng)目標程序的代碼是由loadprogram讀入的。只要在loadprogram中明確目標代碼的位置和長度,就可以正確地把Flash內(nèi)的代碼導(dǎo)入。所以把目標程序代碼的4個段連續(xù)放在Flash內(nèi)的固定地址。

 

  從DSP內(nèi)存空間分配圖中可以發(fā)現(xiàn),loadprogram和目標程序的中斷矢量表.vector是重疊的,但這并不影響自舉功能的實現(xiàn)。DSP上電后loadprogram(包括其vector1程序)被拷貝到DSP內(nèi),然后DSP運行0地址程序,也就是vector1首句程序——跳轉(zhuǎn)指令,跳轉(zhuǎn)到loadprogram起始地址開始運行。loadprogram運行時會將program的vector2程序覆蓋到原0地址開始的vector1。由于loadprogram已不再用到原vector1,所以覆蓋并不影響整個boot過程,這進一步方便了程序設(shè)計。而二個程序的.text段(見表1、表2及圖2)是完全不重復(fù)的,這種分配保證了.text1運行完之前不會被.text2覆蓋而導(dǎo)致程序出錯。

  根據(jù)Flash的分配方案,把二個程序的代碼燒入Flash內(nèi),設(shè)置好控制DSP的自舉模式的五個管腳BOOTMODE[4:0],這里設(shè)為10101,即ROM加載模式、16位Flash,就可以正確地實現(xiàn)系統(tǒng)的自引導(dǎo)了。

上述引導(dǎo)過程已經(jīng)通過實踐,并證實可行。

 

參考文獻

1  仁麗香,馬淑芬.TMS320C6000系列DSPs的原理與應(yīng)用.北京:電子工業(yè)出版社,2000

2  Texas Instruments Inc.TMS320C6000 Peripherals Reference Guide,1999

3  Texas Instruments Inc.TMS320C6000 Optimizing C Compiler User′s Guide,1999

4  Texas Instruments Inc.TMS320C6000 DMA Example Applications,2002

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
午夜一级久久| 亚洲午夜久久久久久尤物| 日韩午夜在线播放| 亚洲国产欧美日韩另类综合| 好吊妞这里只有精品| 国产欧美一区在线| 国产精品日韩精品欧美在线 | 欧美午夜精品伦理| 欧美午夜片在线观看| 欧美视频手机在线| 欧美日韩精品一区二区在线播放 | 国产精品久久激情| 国产精品成人一区二区三区吃奶 | 亚洲午夜视频在线观看| 在线午夜精品| 亚洲视频大全| 亚洲中字在线| 亚洲男同1069视频| 小黄鸭视频精品导航| 性做久久久久久免费观看欧美| 亚洲欧美一区二区视频| 香港久久久电影| 欧美在线一二三区| 亚洲国产精品第一区二区三区| 亚洲国内在线| 亚洲精品在线视频| 一本色道久久精品| 亚洲欧美日韩成人高清在线一区| 亚洲在线电影| 欧美中文字幕第一页| 久久久噜噜噜久久中文字免| 久久精品国内一区二区三区| 久久中文字幕一区| 欧美极品aⅴ影院| 国产精品videosex极品| 国产日韩精品一区二区三区在线| 国产一区日韩欧美| 亚洲国产高清自拍| 99视频+国产日韩欧美| 亚洲午夜影视影院在线观看| 午夜精品www| 亚洲国产老妈| 亚洲少妇最新在线视频| 欧美在线观看www| 鲁大师成人一区二区三区 | 国内激情久久| 亚洲三级影院| 亚洲欧美激情视频| 亚洲激情亚洲| 亚洲午夜小视频| 久久理论片午夜琪琪电影网| 欧美激情精品久久久久久大尺度 | 欧美一区二区三区四区在线| 久久激情视频久久| 亚洲最新在线| 久久激情综合| 欧美日韩1区2区3区| 国产精品自在欧美一区| 亚洲国产精品传媒在线观看| 一级成人国产| 亚洲黄色大片| 亚洲欧美国产精品va在线观看 | 欧美成人首页| 国产精品揄拍500视频| 亚洲国产婷婷| 午夜久久美女| 一区二区三区四区五区视频 | 欧美精品一区二区久久婷婷| 国产欧美午夜| 亚洲精品视频免费观看| 午夜精品视频网站| 一本久久综合亚洲鲁鲁| 久久久久久久久蜜桃| 欧美日韩一区精品| 黑人巨大精品欧美一区二区小视频| 日韩亚洲不卡在线| 亚洲风情亚aⅴ在线发布| 亚洲自拍电影| 欧美激情一区二区三区成人| 国产欧美日韩一区二区三区在线 | 亚洲视频一二区| 久久综合九色综合欧美狠狠| 国产精品jvid在线观看蜜臀| 亚洲大片精品永久免费| 亚洲欧美成aⅴ人在线观看| 日韩一区二区精品视频| 欧美自拍偷拍| 欧美亚一区二区| 亚洲精品乱码久久久久久久久| 久久aⅴ乱码一区二区三区| 亚洲欧美一区在线| 欧美美女视频| 91久久久亚洲精品| 久久精品国产99| 欧美尤物一区| 国产精品日韩久久久| 洋洋av久久久久久久一区| 亚洲国产天堂网精品网站| 久久国产精品久久w女人spa| 欧美日韩一区二区在线| 亚洲区一区二区三区| 91久久夜色精品国产九色| 久久婷婷久久一区二区三区| 国产伦精品一区二区三区高清| 亚洲美女中文字幕| 日韩午夜精品视频| 欧美激情一区二区三区在线视频观看 | 日韩视频免费观看高清完整版| 麻豆精品在线播放| 狠狠色狠狠色综合日日五| 欧美亚洲视频| 欧美在线免费观看| 国产美女扒开尿口久久久| 亚洲一区日韩| 午夜视频精品| 国产毛片一区二区| 亚洲欧美一区二区原创| 欧美在线观看日本一区| 国产视频一区在线观看| 午夜精品免费在线| 久久久久久久久一区二区| 国产综合色产在线精品| 欧美中文字幕在线视频| 久久久久久自在自线| 国内精品久久久久久| 久久精品一区二区三区不卡| 免费欧美日韩| 亚洲激情一区| 一区二区三区四区国产精品| 国产精品成人播放| 亚洲在线成人精品| 久久精品国产69国产精品亚洲| 国产亚洲在线观看| 亚洲高清不卡av| 欧美大片免费看| 日韩视频免费大全中文字幕| 亚洲午夜极品| 国产精品视区| 久久国产欧美精品| 欧美不卡福利| 亚洲精品乱码久久久久久按摩观 | 亚洲性人人天天夜夜摸| 欧美一区二区三区在线看| 国产在线乱码一区二区三区| 亚洲国产精品视频| 欧美理论片在线观看| av成人老司机| 欧美一区二区三区日韩| 狠狠色综合色区| 99热免费精品| 国产精品久久久91| 欧美在线地址| 欧美电影在线观看完整版| 艳妇臀荡乳欲伦亚洲一区| 欧美一区二区三区在| 伊人久久久大香线蕉综合直播| 99国产精品久久久| 国产精品欧美一区喷水| 欧美影院视频| 欧美日本一道本| 亚洲欧美视频在线观看视频| 乱码第一页成人| 一本一本大道香蕉久在线精品| 久久精品国产一区二区三区| 亚洲国产婷婷| 欧美在线观看一区二区三区| 亚洲第一毛片| 亚洲欧美中文日韩在线| 在线免费观看成人网| 亚洲影视中文字幕| 激情婷婷欧美| 亚洲一区不卡| 永久555www成人免费| 亚洲一区二区三区免费视频| 狠狠操狠狠色综合网| 亚洲午夜在线观看| 国产在线拍揄自揄视频不卡99| 一区二区三欧美| 国产一区二区黄色| 一区二区三区视频在线| 国产综合色在线| 亚洲天堂av在线免费| 黄色av成人| 亚洲永久免费视频| 亚洲国产精品成人精品| 久久爱www久久做| 亚洲精品一区二区三区蜜桃久| 久久国产精品毛片| 日韩一区二区精品视频| 老司机免费视频一区二区| 亚洲私拍自拍| 欧美搞黄网站| 久久国产视频网站| 国产精品www994| 亚洲巨乳在线| 国产视频欧美| 亚洲在线一区| 亚洲精品久久久久久下一站| 久久久7777| 亚洲一区欧美一区|