《電子技術應用》
您所在的位置:首頁 > 通信與網絡 > 設計應用 > 大容量無線傳輸技術中高性能DSP 的啟動方法
大容量無線傳輸技術中高性能DSP 的啟動方法
來源:中電網
摘要: 在極低譜密度,高頻譜利用率的大容量無線傳輸技術中,高速實時信號處理成為技術的關鍵。目前市場上,能滿足對高速實時信號處理的需要有具有良好的可編程性的器件主要有DSP 和FPGA。 TMS320C6000 系列DSP 是TI 公司推出的一種高性能的數字信號處理器,包含定點和浮點兩個系列,其中定點系列包括TMS320C62xx和TMS320C64xx,浮點系列包括TMS320C67xx。 C6000 系列DSP 有三種啟動方式......
Abstract:
Key words :

1 引言
在極低譜密度,高頻譜利用率的大容量無線傳輸技術中,高速實時信號處理成為技術的關鍵。目前市場上,能滿足對高速實時信號處理的需要有具有良好的可編程性的器件主要有DSP 和FPGA。
TMS320C6000 系列DSP 是TI 公司推出的一種高性能的數字信號處理器,包含定點和浮點兩個系列,其中定點系列包括TMS320C62xx和TMS320C64xx,浮點系列包括TMS320C67xx。 C6000 系列DSP 有三種啟動方式:
(1) 主機啟動
如果選擇主機啟動模式,在復位信號結束后,DSP 的CPU 被內部“阻塞”而其他部分都被釋放。在此期間,一個外部的主機在必要時可以通過主機接口初始化CPU的內存空間,包括配置與啟動相關的內部寄存器。一旦主機完成了所有必須的初始化,它必須將HPIC 寄存 器的DSPINT位置“1”來完成啟動過程。在程序加載完后,CPU 被從“阻塞”中喚醒,然后從地址0 處執行指令。在CPU 被喚醒后,CPU 需要將DSPINT 位清零[1]。
(2) ROM 啟動
如果采用ROM 啟動模式,則C6000 系列的DSP(C621x/C671x/C64x)復位后自動從CE1 空間的起始處拷貝1K字節的代碼到內存空間。該拷貝過程由EDMA 完成,使用默認的Rom 時鐘。在此過程中CPU 一直處于“阻塞”狀態,直到拷貝完成后才被被喚醒,然后從地址0處開始執行程序[1]。
(3) 無啟動
如果選擇無啟動模式,CPU 復位后直接從地址0 處開始執行指令。 C6000 系列DSP 的器件配置情況決定了選擇的啟動方式。具體來說就是DSP 的啟動模式管腳(boot mode pins)接上拉還是下拉電阻。以C6416為例,BEA[19:18]是啟動模式管腳,它們取不同的值(上拉電阻代表“1”,下拉電阻代表“0”)代表的含義如表1-1 所示:

 
如果DSP 的程序小于1K 字節,那么上述ROM 啟動機制已經可以完成程序的加載。然而事實上大部分DSP 的程序會大于1K字節,這時就需要創建一個特定啟動程序來完成更多代 碼的加載。該特定啟動程序又被稱作二級bootloader[2]。
在需要二級bootloader 的程序中,這段特定啟動代碼通常駐留在ROM 存儲器的起始位 置以便在DSP 復位后能自動被加載到內存地址0 處。當1K字節代碼被加載完畢后,CPU 開始從地址0 處執行,也就是執行二級bootloader 的內容。二級bootloader 的功能就是將程序的剩余部分拷貝到內存中。
2 啟動方法的設計與實現
采用二級bootloader 的DSP 啟動方法的實現大體分為四步:配置存儲器;編寫 secondary bootloader
代碼;編譯程序,轉換目標文件的格式;將程序燒寫進Flash。圖1 為實施該啟動方法的硬件平臺示意圖,其中DSP 的型號選擇C6416,Flash 的型號選擇 AM29LV800B。
 
2.1 配置存儲器
2.1.1 定義存儲器分區
為了實現使用二級bootloader 的ROM 啟動,需要將Flash 劃分為FLASH_BOOT, FLASH_REST
兩個區。這兩個區分別存儲由on-chip bootloader 拷貝的程序段和由secondary bootloader 拷貝的程序段。對于BIOS 程序,Memory 段的定義在MEM(Memory Section Manager)對象里。對于非BIOS 程序,Memory 段定義在linker command file 中。一個C6416 的Memory 段定義的例子如下所示:
 
2.1.2 COFF 段的定位
DSP 程序是以COFF 段的形式在內存中存放的。一個COFF 段就是一個代碼或數據塊, 它在內存中占據連續空間。COFF 段分為自定義段,初始化段和未初始化段三種。COFF 段可 以有各種屬性,其中load 屬性和run 屬性跟DSP 啟動有密切關系。Load 屬性指明段的存儲地址,run 屬性指明段的執行地址。二級bootloader 負責將所有的段從load 地址拷貝到run 地址。例如:
.text: LOAD= FLASH, RUN= IRAM
表示代碼段.text 被存儲在flash 中,DSP 啟動時二級bootloader 將該段拷貝到IRAM 中。
2.2 編寫Secondary Bootloader 代碼
對于C6416,外部存儲器接口(EMIF)需要正確配置以后才可以訪問外部存儲器件。在這 項工作完成后,二級bootloader 應該將所有的初始化段從它們的load 地址拷貝到run 地址, 之后再跳轉到_c_int00,也即是程序入口點。Secondary Bootloader 用匯編語言編寫,因 為此時C 環境尚未建立。
二級bootloader 必須知道所有初始化段的大小,在Flash 中存儲的位置以及應該被加載到何處才能進行正確的拷貝。事實上,二級bootloader 通過讀取段拷貝表獲得上述信息。本文第三部分詳細說明了有關段拷貝表的內容。完成二級bootloader 代碼的編寫后,應將它添加入工程,與工程的其他代碼一同編譯鏈接生成.out 文件。
2.3 轉換目標文件的格式
編譯鏈接生成的是.out 格式文件,然而Flash 一般接收的是ASCII 格式的文件[3]。CCS 附帶的工具hex conversion utility 可將.out 文件轉換為ASCII 格式的.hex 文件,Hex6x 以命令行文件的形式執行。Hex
命令行文件中,首先指明輸入文件(.out),輸出文件的格式和ROM 的大小及類型,以及哪些段需要被放在ROM 中。一個Hex 命令行文件的例子如下所示(注釋內容用“/*”和“*/”括起):
 
2.4 將程序燒寫進Flash
將2.3 節生成的ASCII 文件燒寫進Flash 可以使用CCS 自帶的FlashBurn 工具。 FlashBurn
是一個帶圖形界面的軟件,它首先將一個稱作FlashBurn Target Component (FBTC) 的程序下載到DSP 內存中,通過與FBTC 的實時數據交換完成對Flash 的擦除編程等操作。 針對不同的硬件(DSP,Flash 型號)修改FBTC 是該方法的關鍵。所需修改處包括Flash 的基地址,大小,及讀寫命令字等。
3 段拷貝表
二級bootloader 使用一個段拷貝表(section copy table)進行段的拷貝。段拷貝表包含每個需要拷貝的段的必要信息,如段的load 地址,段的run 地址,段的大小。段拷貝表被插入在secondary bootloader 的末尾。
生成段拷貝表的方法有兩種: 1) 使用 hex conversion utility 的-boot 選項 在2.3 節中我們討論了程序文件格式的轉換和hex 命令行文件,事實上Code Composer Studio 自帶的工具hex conversion utility 提供了一種更為方便的生成段拷貝表的方法,只要在hex 命令行文件中使用一些特殊的選項即可。特殊的選項有–boot, ?bootorg 和 –bootsection,這三個選項的含義分別如下:
-boot 使用該選項時hex conversion utility 將自動轉換所有初始化段的格式
-bootorg 指明段拷貝表的地址
-bootsection 指明二級bootloader 所在的段的名稱
2) 使用 linker 選項(LOAD_START,RUN_START,SIZE)
涉及段拷貝表的生成的有三個選項:LOAD_START,RUN_START 和SIZE,可分別獲得一個段的駐留地址,運行地址和大小。例如下列代碼可獲得text 段的駐留地址(存于_text_ld_start 中),運行地址(_text_rn_start)和段的大小(存于_text_size)
.text : load = FLASH_REST, run = IRAM
LOAD_START(_text_ld_start),
RUN_START(_text_rn_start),
SIZE(_text_size)
4 結束語
本文針對在極低譜密度,高頻譜利用率的大容量無線傳輸技術研究中C6000 系列DSP 的應用程序大于1K 字節的情況,提出了一種使用二級bootloader 從Flash 啟動DSP 的方法。 該方法可應用于采用了C6000 系列DSP 的嵌入式系統中,不需要額外的Flash 編程器,具有 廣泛的適用性。
本文作者創新點:在二級bootloader 中引入段拷貝表用以控制程序加載過程,并利用 CCS 自身的編譯功能獲取段拷貝表的內容,該方法可提高效率且準確性高。
此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
日韩一区二区免费高清| 91久久久久久| 亚洲第一区在线观看| 国产欧美短视频| 欧美亚一区二区| 欧美日韩国产美女| 欧美伦理91| 欧美日韩高清在线| 欧美日韩大片| 欧美日韩亚洲三区| 欧美日韩和欧美的一区二区| 欧美寡妇偷汉性猛交| 暖暖成人免费视频| 欧美成人dvd在线视频| 免费成人小视频| 欧美大尺度在线观看| 欧美成人黑人xx视频免费观看 | 99视频精品| 99热免费精品| 亚洲一级在线观看| 午夜精品久久久久99热蜜桃导演| 亚洲欧美日本在线| 午夜视频在线观看一区二区三区| 午夜精品区一区二区三| 欧美一区二区三区免费在线看| 欧美有码在线视频| 久久久久久电影| 久久综合精品一区| 欧美激情精品久久久久久大尺度 | 欧美高清视频在线 | 99视频精品免费观看| 在线亚洲精品福利网址导航| 亚洲一二三区精品| 欧美一区二区三区视频免费| 久久精品一本| 亚洲免费观看| 亚洲一区二区综合| 久久国产精品黑丝| 久久综合色88| 欧美日韩日本网| 国产人久久人人人人爽| 亚洲第一精品夜夜躁人人爽| 亚洲精品午夜| 亚洲伊人网站| 亚洲国产女人aaa毛片在线| 99伊人成综合| 羞羞漫画18久久大片| 久久躁日日躁aaaaxxxx| 欧美日本一道本| 国产伦精品一区二区三| 亚洲第一在线| 亚洲性感激情| 最新国产精品拍自在线播放| 亚洲视频大全| 久久久综合免费视频| 欧美日韩国产成人在线观看| 国产欧美一区二区白浆黑人| 亚洲国产日日夜夜| 亚洲欧美一区二区三区极速播放| 亚洲韩日在线| 欧美一区二区三区播放老司机| 欧美成人精品福利| 国产精品欧美精品| 1204国产成人精品视频| 亚洲尤物影院| 亚洲精品四区| 久久精品视频免费播放| 欧美日韩国产综合新一区| 国产日韩一区二区三区在线播放 | 亚洲欧洲精品一区二区精品久久久| 亚洲午夜电影| 免费欧美在线视频| 国产精品实拍| 亚洲人成网站精品片在线观看 | 亚洲精品乱码久久久久久| 午夜在线播放视频欧美| 一本久道久久久| 蜜臀va亚洲va欧美va天堂| 国产农村妇女精品一二区| 亚洲激情综合| 久久精品毛片| 欧美一区二区在线观看| 欧美色视频在线| 亚洲国产欧美精品| 久久国产精品99国产精| 亚洲欧美经典视频| 欧美精品自拍| 亚洲二区视频| 欧美专区亚洲专区| 香蕉久久精品日日躁夜夜躁| 欧美久久久久免费| 亚洲国产成人在线| 亚洲国产成人91精品| 欧美在线网址| 国产精品久久久久aaaa| 日韩视频欧美视频| 亚洲肉体裸体xxxx137| 久久久中精品2020中文| 国产日韩欧美不卡| 亚洲一区二区三区在线看| 这里只有精品在线播放| 欧美国产日韩视频| 在线免费观看成人网| 久久精品视频在线播放| 午夜精品福利电影| 国产精品久久久久久久app| 日韩一区二区免费高清| 日韩午夜视频在线观看| 免费国产一区二区| 亚洲第一中文字幕在线观看| 亚洲国产成人午夜在线一区| 久久久久一区二区三区| 国产深夜精品| 午夜精品网站| 久久久国产成人精品| 国产日韩欧美精品综合| 亚洲欧美成人| 欧美在线网站| 国产一区二区久久精品| 欧美一区视频| 久久久久久亚洲精品中文字幕| 国产午夜精品理论片a级探花 | 亚洲韩国青草视频| 亚洲精品五月天| 欧美日本中文| 制服丝袜激情欧洲亚洲| 亚洲欧美日韩精品久久亚洲区| 欧美视频在线一区二区三区| 中文日韩欧美| 午夜精品成人在线视频| 国产农村妇女毛片精品久久麻豆 | 在线视频欧美日韩| 亚洲一区二区综合| 国产精品一区二区三区乱码 | 国产一区二区三区久久 | 久久综合狠狠综合久久综合88| 国语自产精品视频在线看抢先版结局| 午夜精品久久久久久久久| 欧美在线影院| 狠狠色伊人亚洲综合网站色 | 日韩午夜高潮| 欧美性片在线观看| 亚洲欧美国产77777| 久久av红桃一区二区小说| 国产色视频一区| 亚洲国产女人aaa毛片在线| 欧美剧在线观看| 亚洲午夜在线观看视频在线| 久久九九精品| 亚洲精品国产拍免费91在线| 亚洲影视综合| 国产一区视频观看| 亚洲乱码一区二区| 国产精品久久久久久久第一福利 | 国产精品国产三级国产专区53| 午夜精品视频网站| 免费成人小视频| 一区二区高清视频| 久久精品久久综合| 亚洲欧洲在线视频| 性欧美大战久久久久久久免费观看 | 亚洲一区二区三区在线播放| 久久久蜜桃一区二区人| 亚洲日本欧美天堂| 欧美一级视频| 亚洲国产精品一区二区三区| 亚洲一级在线观看| 精品51国产黑色丝袜高跟鞋| 这里只有精品视频在线| 国产午夜精品在线| 99日韩精品| 国产一区二区精品久久| 一区二区三区产品免费精品久久75| 国产精品制服诱惑| 日韩视频亚洲视频| 国产日韩av在线播放| 99riav久久精品riav| 国产欧美亚洲日本| 在线视频精品一区| 狠狠色狠狠色综合人人| 亚洲影院污污.| 在线精品一区二区| 欧美一区二区三区在线播放| 亚洲国产精品成人综合色在线婷婷 | 久久国产精品久久精品国产| 欧美日韩综合视频| 亚洲精品1区| 国产亚洲免费的视频看| 中文一区在线| 在线观看一区| 欧美在线免费| 一区二区欧美视频| 欧美黑人国产人伦爽爽爽| 亚洲欧美另类在线观看| 欧美日韩午夜在线视频| 亚洲国产日韩精品| 国产偷国产偷亚洲高清97cao| 亚洲一区二区在线免费观看| 亚洲成人资源网| 久久精品国产第一区二区三区最新章节 |