以文本方式查看主題

-  曙海教育集團論壇  (http://www.scb-ycwb.com/bbs/index.asp)
--  DSP6000系統開發  (http://www.scb-ycwb.com/bbs/list.asp?boardid=29)
----  大容量無線傳輸技術中高性能DSP的啟動方法  (http://www.scb-ycwb.com/bbs/dispbbs.asp?boardid=29&id=1637)

--  作者:wangxinxin
--  發布時間:2010-11-22 14:35:36
--  大容量無線傳輸技術中高性能DSP的啟動方法

摘要:大容量無線傳輸技術的實現依賴高性能數字信號處理器(DSP)。大多數C6000 系列 DSP 采用ROM (FLASH) 啟動方式。采用ROM 啟動方式時,C6000 系列DSP 在上電后會自動拷 貝存儲于FLASH 中的1K 字節代碼到內存中。然而DSP 的程序往往大于1K 字節,這時就需設 計一個二級bootloader 來輔助完成程序的加載。本文設計并實現了一種C6000 系列DSP 的 啟動方法,重點研究了二級bootloader 的設計,如何將程序編譯生成的目標文件轉換成基 于FLASH 格式的文件,以及如何將基于FLASH 格式文件燒寫入FLASH。實踐證明,該方法性 能穩定,可移植性好,具有較大的工程應用價值。

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 段定義的例子如下所示:

 


主站蜘蛛池模板: 欧美精品亚洲精品日韩专区 | 亚洲乱码日产精品BD在线观看| 久久精品二三区| 天天久久影视色香综合网| canopen永久| 精品国产品香蕉在线观看| 成人永久免费福利视频网站| 国产亚洲一区二区三区在线| 啊灬啊灬啊灬快灬深用力| 中文精品久久久久国产网址| 91制片厂天美传媒鲸鱼传媒| 永久看一二三四线| 国产精品自产拍在线观看花钱看| 亚洲成a人片在线不卡| 18禁裸男晨勃露j毛免费观看| 欧美国产精品不卡在线观看| 国产精品久久免费视频| 亚洲av中文无码乱人伦在线观看 | 忘忧草日本在线播放www| 制服丝袜一区在线| eeuss在线播放| 欧美激情一区二区三区免费观看| 小h片在线播放| 人人妻人人澡人人爽人人dvd | 精品福利一区3d动漫| 性生活片免费看| 国产女人18一级毛片视频| 久久九九热视频| 精品欧美一区二区三区四区| 奇米影视7777久久精品| 亚洲精品乱码久久久久久| 青青草原视频在线观看| 日本高清一二三| 可以看的黄色软件| 99久久精品日本一区二区免费| 欧美成人中文字幕dvd| 国产女人爽的流水毛片| 中文乱码人妻系列一区二区| 风间由美在线亚洲一区| 成人区人妻精品一区二区不卡网站| 伊人久久精品线影院|