<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 手機與無(wú)線(xiàn)通信 > 設計應用 > 大容量無(wú)線(xiàn)傳輸技術(shù)中高性能DSP 的啟動(dòng)方法

大容量無(wú)線(xiàn)傳輸技術(shù)中高性能DSP 的啟動(dòng)方法

作者: 時(shí)間:2010-06-07 來(lái)源:網(wǎng)絡(luò ) 收藏

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

本文引用地址:http://dyxdggzs.com/article/157380.htm

如果DSP 的程序小于1K 字節,那么上述ROM 啟動(dòng)機制已經(jīng)可以完成程序的加載。然而事實(shí)上大部分DSP 的程序會(huì )大于1K字節,這時(shí)就需要創(chuàng )建一個(gè)特定啟動(dòng)程序來(lái)完成更多代 碼的加載。該特定啟動(dòng)程序又被稱(chēng)作二級bootloader[2]。
在需要二級bootloader 的程序中,這段特定啟動(dòng)代碼通常駐留在ROM 存儲器的起始位 置以便在DSP 復位后能自動(dòng)被加載到內存地址0 處。當1K字節代碼被加載完畢后,CPU 開(kāi)始從地址0 處執行,也就是執行二級bootloader 的內容。二級bootloader 的功能就是將程序的剩余部分拷貝到內存中。
2 啟動(dòng)的設計與實(shí)現
采用二級bootloader 的DSP 啟動(dòng)的實(shí)現大體分為四步:配置存儲器;編寫(xiě) secondary bootloader
代碼;編譯程序,轉換目標文件的格式;將程序燒寫(xiě)進(jìn)Flash。圖1 為實(shí)施該啟動(dòng)的硬件平臺示意圖,其中DSP 的型號選擇C6416,Flash 的型號選擇 AM29LV800B。

2.1 配置存儲器
2.1.1 定義存儲器分區
為了實(shí)現使用二級bootloader 的ROM 啟動(dòng),需要將Flash 劃分為FLASH_BOOT, FLASH_REST
兩個(gè)區。這兩個(gè)區分別存儲由on-chip bootloader 拷貝的程序段和由secondary bootloader 拷貝的程序段。對于BIOS 程序,Memory 段的定義在MEM(Memory Section Manager)對象里。對于非BIOS 程序,Memory 段定義在linker command file 中。一個(gè)C6416 的Memory 段定義的例子如下所示:

2.1.2 COFF 段的定位
DSP 程序是以COFF 段的形式在內存中存放的。一個(gè)COFF 段就是一個(gè)代碼或數據塊, 它在內存中占據連續空間。COFF 段分為自定義段,初始化段和未初始化段三種。COFF 段可 以有各種屬性,其中load 屬性和run 屬性跟DSP 啟動(dòng)有密切關(guān)系。Load 屬性指明段的存儲地址,run 屬性指明段的執行地址。二級bootloader 負責將所有的段從load 地址拷貝到run 地址。例如:
.text: LOAD= FLASH, RUN= IRAM
表示代碼段.text 被存儲在flash 中,DSP 啟動(dòng)時(shí)二級bootloader 將該段拷貝到IRAM 中。
2.2 編寫(xiě)Secondary Bootloader 代碼
對于C6416,外部存儲器接口(EMIF)需要正確配置以后才可以訪(fǎng)問(wèn)外部存儲器件。在這 項工作完成后,二級bootloader 應該將所有的初始化段從它們的load 地址拷貝到run 地址, 之后再跳轉到_c_int00,也即是程序入口點(diǎn)。Secondary Bootloader 用匯編語(yǔ)言編寫(xiě),因 為此時(shí)C 環(huán)境尚未建立。
二級bootloader 必須知道所有初始化段的大小,在Flash 中存儲的位置以及應該被加載到何處才能進(jìn)行正確的拷貝。事實(shí)上,二級bootloader 通過(guò)讀取段拷貝表獲得上述信息。本文第三部分詳細說(shuō)明了有關(guān)段拷貝表的內容。完成二級bootloader 代碼的編寫(xiě)后,應將它添加入工程,與工程的其他代碼一同編譯鏈接生成.out 文件。
2.3 轉換目標文件的格式
編譯鏈接生成的是.out 格式文件,然而Flash 一般接收的是ASCII 格式的文件[3]。CCS 附帶的工具hex conversion utility 可將.out 文件轉換為ASCII 格式的.hex 文件,Hex6x 以命令行文件的形式執行。Hex
命令行文件中,首先指明輸入文件(.out),輸出文件的格式和ROM 的大小及類(lèi)型,以及哪些段需要被放在ROM 中。一個(gè)Hex 命令行文件的例子如下所示(注釋內容用“/*”和“*/”括起):

2.4 將程序燒寫(xiě)進(jìn)Flash
將2.3 節生成的ASCII 文件燒寫(xiě)進(jìn)Flash 可以使用CCS 自帶的FlashBurn 工具。 FlashBurn
是一個(gè)帶圖形界面的軟件,它首先將一個(gè)稱(chēng)作FlashBurn Target Component (FBTC) 的程序下載到DSP 內存中,通過(guò)與FBTC 的實(shí)時(shí)數據完成對Flash 的擦除編程等操作。 針對不同的硬件(DSP,Flash 型號)修改FBTC 是該方法的關(guān)鍵。所需修改處包括Flash 的基地址,大小,及讀寫(xiě)命令字等。
3 段拷貝表
二級bootloader 使用一個(gè)段拷貝表(section copy table)進(jìn)行段的拷貝。段拷貝表包含每個(gè)需要拷貝的段的必要信息,如段的load 地址,段的run 地址,段的大小。段拷貝表被插入在secondary bootloader 的末尾。
生成段拷貝表的方法有兩種: 1) 使用 hex conversion utility 的-boot 選項 在2.3 節中我們討論了程序文件格式的轉換和hex 命令行文件,事實(shí)上Code Composer Studio 自帶的工具hex conversion utility 提供了一種更為方便的生成段拷貝表的方法,只要在hex 命令行文件中使用一些特殊的選項即可。特殊的選項有Cboot, ?bootorg 和 Cbootsection,這三個(gè)選項的含義分別如下:
-boot 使用該選項時(shí)hex conversion utility 將自動(dòng)轉換所有初始化段的格式
-bootorg 指明段拷貝表的地址
-bootsection 指明二級bootloader 所在的段的名稱(chēng)
2) 使用 linker 選項(LOAD_START,RUN_START,SIZE)
涉及段拷貝表的生成的有三個(gè)選項:LOAD_START,RUN_START 和SIZE,可分別獲得一個(gè)段的駐留地址,運行地址和大小。例如下列代碼可獲得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 結束語(yǔ)
本文針對在極低譜密度,高頻譜利用率的研究中C6000 系列DSP 的應用程序大于1K 字節的情況,提出了一種使用二級bootloader 從Flash 啟動(dòng)DSP 的方法。 該方法可應用于采用了C6000 系列DSP 的嵌入式系統中,不需要額外的Flash 編程器,具有 廣泛的適用性。
本文作者創(chuàng )新點(diǎn):在二級bootloader 中引入段拷貝表用以控制程序加載過(guò)程,并利用 CCS 自身的編譯功能獲取段拷貝表的內容,該方法可提高效率且準確性高。


評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>