《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > TMS320C6000 DSP系統的引導設計
TMS320C6000 DSP系統的引導設計
陸侃蕓 宋 瑩 季曉勇
摘要: 在分析比較了TMS320C6000的三種自舉模式后,針對原來DSP自舉模式的利弊提出了一種可行的系統引導解決方案,并以基于TMS320C6202的圖像處理系統的引導實現為例進行了詳細介紹。
Abstract:
Key words :

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

  關鍵詞: 自舉模式  數字信號處理  Flash芯片

 

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

1  系統引導設計

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

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

  在主機引導模式下,外部主機在DSP處于復位狀態、硬件其他部分保持正常狀態期間通過主機口將程序寫入DSP的內部存儲空間;然后將主機口控制寄存器中的DSPINT位設置為1,使DSP退出復位狀態,開始執行0地址處指令。該模式下DSP無法自己完成初始化,需有一主機控制。所以主機引導模式不適用于一般的基于DSP的系統。

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

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

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

1.2 ROM加載模式下的系統引導設計

  經過分析,在原來ROM加載模式基礎上設計了如下的一種系統引導方式,從而解決了程序較大、數據空間不能初始化等問題。

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

  如圖1所示,在ROM加載時,DSP自動將CE1空間的loadprogram導入DSP0地址處,而數據常量也已經存在于loadprogram定義的數據空間中。這樣在ROM加載結束后DSP自動運行0地址程序,即loadprogram程序,從而進行系統的第二次加載,即將系統目標程序和數據加載到DSP內,然后運行系統目標程序。這樣就最終實現了系統的正確引導。

 

1.3 設計實現中的問題

  在實現這個系統自舉設計中有二個需要注意的問題。

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

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

2  實  例

  本實例用TMS320C6202來實現視頻圖像的編碼。系統的自引導主要由C6202和256KB的16位Flash(SST39VF400A)實現。

2.1 系統目標程序

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

 

  目標程序要做的就是把執行文件program.out轉化為代碼,燒寫入Flash,以防被loadprogram讀取寫入DSP內。這里,首先用hex6x.exe將program.out轉化為16進制文件,然后利用自編的程序對其進行整理,得到3個隊列:

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

  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內的空間。

2.2 loadprogram程序

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

  

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

 

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

2.3 Flash與DSP的空間分配

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

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

系統目標程序的代碼是由loadprogram讀入的。只要在loadprogram中明確目標代碼的位置和長度,就可以正確地把Flash內的代碼導入。所以把目標程序代碼的4個段連續放在Flash內的固定地址。

 

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

  根據Flash的分配方案,把二個程序的代碼燒入Flash內,設置好控制DSP的自舉模式的五個管腳BOOTMODE[4:0],這里設為10101,即ROM加載模式、16位Flash,就可以正確地實現系統的自引導了。

上述引導過程已經通過實踐,并證實可行。

 

參考文獻

1  仁麗香,馬淑芬.TMS320C6000系列DSPs的原理與應用.北京:電子工業出版社,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

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲主播在线观看| 亚洲精选一区| 亚洲精品欧美专区| 精品成人在线视频| 国产日韩在线播放| 国产九九精品| 国产精品亚洲人在线观看| 欧美日韩亚洲一区二区| 欧美精品偷拍| 欧美国产一区视频在线观看| 久久这里只精品最新地址| 久久九九热re6这里有精品| 久久本道综合色狠狠五月| 午夜精品网站| 午夜电影亚洲| 欧美一区二区三区久久精品茉莉花| 亚洲欧美另类久久久精品2019| 亚洲一区二区三区四区五区午夜| 中文精品一区二区三区| 亚洲无玛一区| 亚洲欧美日本日韩| 欧美亚洲综合网| 久久爱www久久做| 久久免费高清| 激情五月婷婷综合| 韩国三级在线一区| 欧美午夜视频网站| 国产精品白丝jk黑袜喷水| 国产精品国内视频| 国产裸体写真av一区二区 | 免费日韩av片| 欧美激情精品久久久六区热门| 欧美日韩卡一卡二| 国产精品久久久久久久9999| 国产精品亚洲а∨天堂免在线| 国产精品视频精品视频| 国产一区二区三区不卡在线观看| 黑人巨大精品欧美一区二区小视频| 伊人成综合网伊人222| 亚洲黄色有码视频| 99亚洲伊人久久精品影院红桃| 亚洲小视频在线观看| 性感少妇一区| 亚洲欧洲日本在线| 亚洲一区自拍| 久久久.com| 欧美日韩精品不卡| 国产欧美一区二区三区沐欲| 伊大人香蕉综合8在线视| 亚洲精品日韩综合观看成人91| 亚洲一区二区成人| 亚洲国产成人在线播放| 在线视频你懂得一区| 欧美一区二区三区婷婷月色| 另类专区欧美制服同性| 欧美日韩蜜桃| 国产在线不卡视频| 亚洲久色影视| 久久国产免费看| 中文在线资源观看网站视频免费不卡 | 美女尤物久久精品| 欧美视频二区| 黄色亚洲精品| 中文av字幕一区| 亚洲第一综合天堂另类专| 这里只有精品在线播放| 久久国产视频网| 欧美日韩成人在线视频| 国产午夜精品在线| 亚洲另类一区二区| 欧美成人免费网站| 国产精品亚洲аv天堂网| 国产日产欧产精品推荐色 | 亚洲欧美在线一区| 亚洲毛片av在线| 欧美在线观看网站| 欧美日韩国内| 永久域名在线精品| 亚洲欧美日韩精品久久久久| 日韩小视频在线观看| 久久电影一区| 欧美性做爰毛片| 亚洲激情在线| 亚洲第一级黄色片| 亚洲欧美激情视频在线观看一区二区三区| 久久天天躁狠狠躁夜夜av| 国产精品欧美久久久久无广告| 91久久久国产精品| 久久高清福利视频| 欧美一区二区三区四区夜夜大片| 欧美日韩精品综合| 亚洲国产高清视频| 欧美一区二区三区四区在线观看| 亚洲一区二区综合| 欧美精品成人91久久久久久久| 国产一区二区三区高清播放| 一区二区三区 在线观看视频 | 久久国产高清| 国产精品成人免费精品自在线观看| 亚洲二区在线视频| 久久精品人人做人人爽电影蜜月| 亚洲欧美日本日韩| 欧美色中文字幕| 夜夜嗨av一区二区三区中文字幕| 亚洲人成亚洲人成在线观看| 久久尤物视频| 国产婷婷一区二区| 亚洲欧美综合国产精品一区| 亚洲男人的天堂在线| 欧美日韩亚洲另类| 99热这里只有精品8| 99视频超级精品| 欧美精品在线看| 亚洲国产一区二区三区青草影视 | 亚洲欧洲在线免费| 麻豆精品一区二区综合av| 国内精品久久久久久影视8| 亚洲欧美在线网| 久久精品国产亚洲精品 | 一区二区三区成人| 亚洲天堂免费观看| 欧美三区美女| 亚洲视频精品| 亚洲电影在线免费观看| 日韩一区二区精品在线观看| 亚洲欧美国产日韩中文字幕| 午夜欧美不卡精品aaaaa| 国产精品视频成人| 亚洲男人第一网站| 久久精品动漫| 国产在线精品一区二区夜色| 久久精品国产在热久久 | 国产精品美女黄网| 欧美一区二区三区日韩| 久久久欧美一区二区| 一区二区在线观看视频在线观看| 久久精品国产亚洲精品| 欧美成在线观看| 亚洲伦理在线观看| 亚洲欧美日本在线| 国产亚洲精品久| 亚洲国语精品自产拍在线观看| 欧美大胆人体视频| 一区二区三区精品国产| 午夜精品免费在线| 韩国欧美一区| 日韩一级不卡| 国产精品美女久久| 久久精品盗摄| 欧美男人的天堂| 亚洲一区二区精品在线| 久久精品国产久精国产爱| 亚洲高清免费在线| 亚洲一区二区在线免费观看视频 | 欧美日韩一区二区欧美激情| 亚洲无限乱码一二三四麻| 久久精品日产第一区二区三区| 精品91在线| 一区二区三区四区国产精品| 国产欧美日韩一区二区三区在线 | 欧美一区视频| 亚洲国产欧美日韩另类综合| 亚洲主播在线| 狠狠色狠色综合曰曰| 在线视频亚洲| 国产一区二区三区四区| 日韩午夜电影av| 国产欧美日韩视频一区二区三区| 亚洲欧洲美洲综合色网| 国产精品久久久久aaaa樱花| 久久精品国产亚洲aⅴ| 欧美日韩一区二区视频在线| 欧美在线|欧美| 欧美日韩在线观看一区二区三区| 欧美一区二区三区久久精品茉莉花 | av成人免费在线观看| 国产午夜精品理论片a级大结局| 亚洲毛片av在线| 国产伦精品一区二区三区照片91 | 久久久噜噜噜久噜久久| 在线综合+亚洲+欧美中文字幕| 国产乱码精品一区二区三区五月婷| 亚洲国内自拍| 国产精品在线看| 99re在线精品| 狠狠狠色丁香婷婷综合激情| 亚洲小说区图片区| 亚洲成人在线视频播放| 先锋影音国产精品| 亚洲欧洲美洲综合色网| 久久精品伊人| 亚洲图片自拍偷拍| 欧美精品一区二区在线观看| 欧美亚洲免费在线| 欧美日韩综合精品| 亚洲精品欧美极品| 国内免费精品永久在线视频| 亚洲欧美一区二区原创| 亚洲精品美女久久7777777| 久久久综合视频|