資料介紹
隨著數(shù)字信號(hào)處理技術(shù)的快速發(fā)展,數(shù)字信號(hào)處理器(DSP)越來(lái)越廣泛地應(yīng)用于各種實(shí)時(shí)嵌入式系統(tǒng)中。當(dāng)系統(tǒng)調(diào)試完畢,想脫離仿真環(huán)境并在上電復(fù)位后自動(dòng)啟動(dòng)程序代碼運(yùn)行時(shí),必須將程序代碼存儲(chǔ)在非易失性存儲(chǔ)器中。Flash存儲(chǔ)器以其大容量和可在線編程等特點(diǎn)已成為DSP系統(tǒng)的一個(gè)基本配置。在系統(tǒng)上電復(fù)位后,DSP芯片內(nèi)部固化的引導(dǎo)裝載器(Bootloader)把應(yīng)用程序從Flash引導(dǎo)到DSP芯片內(nèi)高速 RAM中執(zhí)行。這樣既利用了外部存儲(chǔ)器擴(kuò)展DSP有限的ROM資源,又可以充分保證用戶程序的全速運(yùn)行[1-2]。
本文采用德州儀器公司的16位定點(diǎn)DSP芯片TMS320VC5509A(以下簡(jiǎn)稱5509A),其PGE封裝形式只有14根地址總線(A0~A13),最大只能尋址16KB的Flash存儲(chǔ)器[3]。若要尋址更大地址空間,就需要控制Flash存儲(chǔ)器的高位地址線。常見(jiàn)的解決方案是采用DSP的通用輸入輸出GPIO(General Purpose Input/Output)引腳來(lái)控制Flash的高位地址線,從而實(shí)現(xiàn)Flash存儲(chǔ)器的分頁(yè)訪問(wèn)[5-6]。然而,對(duì)于較大容量的Flash存儲(chǔ)器,如本文采用的Am29LV800的容量為512K×16bit,有19根地址線[4],如果采用上述方法,硬件連接雖然簡(jiǎn)單,但會(huì)占用較多的GPIO引腳,而且以后的系統(tǒng)擴(kuò)展也不方便。本文介紹了一種基于CPLD快速譯碼的DSP二次引導(dǎo)方法,利用CPLD的時(shí)序嚴(yán)格、譯碼速度快、可在線編程等特點(diǎn),在 DSP的外部存儲(chǔ)器接口EMIF(Exteral Memory Interface)的CE2空間模擬了一個(gè)Flash換頁(yè)寄存器FPR(Flash Page Register),在上電復(fù)位后控制Flash的高位地址線,從而實(shí)現(xiàn)Flash的分頁(yè)訪問(wèn)。因此,可通過(guò)二次bootloader程序修改FPR的值,控制Flash的高位地址線,將最終的應(yīng)用程序加載到RAM中運(yùn)行。
1 TMS320VC5509A的并行引導(dǎo)模式
1.1 5509A的引導(dǎo)模式
5509A的引導(dǎo)模式選擇是通過(guò)4個(gè)模式選擇引腳BOOTM[3:0]來(lái)配置的,BOOTM3~0引腳分別與GPIO0、3、2、1相連。5509A提供了六種引導(dǎo)模式,即EHPI引導(dǎo)模式、8位/16位并行EMIF引導(dǎo)模式、8位/16位標(biāo)準(zhǔn)串行口引導(dǎo)模式、SPI EEPROM引導(dǎo)模式、USB引導(dǎo)模式以及I2C E2PROM引導(dǎo)模式。本文采用16位并行EMIF引導(dǎo)模式,將BOOTM[3:0]設(shè)置為1011即可。
在16位并行EMIF引導(dǎo)模式下,DSP芯片內(nèi)部固化的Bootloader程序上電復(fù)位后,首先從CE1空間首地址0x200000h處開(kāi)始讀取程序代碼,并加載到RAM中運(yùn)行。
1.2 5509A的引導(dǎo)表格式
程序代碼以引導(dǎo)表的格式存儲(chǔ)在Flash存儲(chǔ)器中。引導(dǎo)表是獨(dú)立于所選引導(dǎo)模式的一種特定的格式,包含了用戶程序的代碼段、數(shù)據(jù)段、段在RAM中的目標(biāo)地址以及程序入口地址等其他相關(guān)信息。5509A引導(dǎo)表結(jié)構(gòu)如表1所示。
![CPLD譯碼的DSP二次Bootloader方法簡(jiǎn)析](/uploads/allimg/171024/2362486-1G024095205357.png)
DSP芯片內(nèi)部固化的Bootloader的主要功能是將Flash中存儲(chǔ)的引導(dǎo)表按一定順序加載到 RAM中,然后跳轉(zhuǎn)到32位程序入口地址開(kāi)始執(zhí)行。引導(dǎo)表文件可以通過(guò)TI公司提供的16進(jìn)制轉(zhuǎn)換工具生成,一般是hex格式,然后將此hex文件燒寫(xiě)到 Flash存儲(chǔ)器中供Bootloader加載。
2 DSP二次Bootloader的原理及實(shí)現(xiàn)
由上述分析可知,DSP用戶程序的并行加載過(guò)程是由DSP內(nèi)固化的Bootloader實(shí)現(xiàn)的。由于5509A的PGE封裝只有14根地址線,最多只能訪問(wèn)到16K×16bit地址空間。對(duì)于超過(guò)16KB的用戶代碼,Bootloader將不能加載全部的引導(dǎo)表文件。因此若要加載超過(guò)16K的用戶代碼,必須進(jìn)行二次Bootloader。
二次Bootloader的原理是由用戶自行編寫(xiě)一個(gè)代碼長(zhǎng)度小于16KB的引導(dǎo)程序(以下簡(jiǎn)稱 uboot),其功能與DSP內(nèi)固化的Bootloader相同,用于加載最終的用戶代碼。在uboot程序中控制Flash存儲(chǔ)器的高位地址線來(lái)訪問(wèn) Flash的其他存儲(chǔ)內(nèi)容。這樣,DSP上電復(fù)位后,Bootloader首先加載uboot并運(yùn)行,然后uboot又加載最終用戶代碼,實(shí)現(xiàn)了大于 16K代碼的二次引導(dǎo)。
2.1 DSP與Flash及CPLD的硬件接口
本文采用AMD的 Am29LV800作為DSP的外部存儲(chǔ)器擴(kuò)展。Am29LV800按8位方式訪問(wèn),容量為1M字;按16位方式訪問(wèn),容量為512K字。DSP外圍電路邏輯譯碼及Flash高位地址線模擬由CPLD實(shí)現(xiàn)。Xilinx公司的XC9572XL是一款高性能的CPLD芯片,最高主頻可達(dá)178MHz,包含了 72個(gè)宏單元,1 600個(gè)可用門(mén)電路,其TQFP封裝有72個(gè)可用I/O引腳[7]。圖1是5509A與CPLD及Flash之間的硬件接口設(shè)計(jì)原理圖。
![CPLD譯碼的DSP二次Bootloader方法簡(jiǎn)析](/uploads/allimg/171024/2362486-1G024095213603.png)
如圖1所示,5509A的地址線A[13:1]與Flash的地址線A[12:0],A0未用。Flash存儲(chǔ)器被映射到DSP的CE1空間,由片選線CE1經(jīng)CPLD譯碼后選通。其中DSP的地址線A13和A[3:1]與CPLD接口,用于換頁(yè)寄存器FPR的模擬。Flash存儲(chǔ)器的BYTE引腳經(jīng)上拉后接高電平,即按16位方式訪問(wèn)。
本文采用德州儀器公司的16位定點(diǎn)DSP芯片TMS320VC5509A(以下簡(jiǎn)稱5509A),其PGE封裝形式只有14根地址總線(A0~A13),最大只能尋址16KB的Flash存儲(chǔ)器[3]。若要尋址更大地址空間,就需要控制Flash存儲(chǔ)器的高位地址線。常見(jiàn)的解決方案是采用DSP的通用輸入輸出GPIO(General Purpose Input/Output)引腳來(lái)控制Flash的高位地址線,從而實(shí)現(xiàn)Flash存儲(chǔ)器的分頁(yè)訪問(wèn)[5-6]。然而,對(duì)于較大容量的Flash存儲(chǔ)器,如本文采用的Am29LV800的容量為512K×16bit,有19根地址線[4],如果采用上述方法,硬件連接雖然簡(jiǎn)單,但會(huì)占用較多的GPIO引腳,而且以后的系統(tǒng)擴(kuò)展也不方便。本文介紹了一種基于CPLD快速譯碼的DSP二次引導(dǎo)方法,利用CPLD的時(shí)序嚴(yán)格、譯碼速度快、可在線編程等特點(diǎn),在 DSP的外部存儲(chǔ)器接口EMIF(Exteral Memory Interface)的CE2空間模擬了一個(gè)Flash換頁(yè)寄存器FPR(Flash Page Register),在上電復(fù)位后控制Flash的高位地址線,從而實(shí)現(xiàn)Flash的分頁(yè)訪問(wèn)。因此,可通過(guò)二次bootloader程序修改FPR的值,控制Flash的高位地址線,將最終的應(yīng)用程序加載到RAM中運(yùn)行。
1 TMS320VC5509A的并行引導(dǎo)模式
1.1 5509A的引導(dǎo)模式
5509A的引導(dǎo)模式選擇是通過(guò)4個(gè)模式選擇引腳BOOTM[3:0]來(lái)配置的,BOOTM3~0引腳分別與GPIO0、3、2、1相連。5509A提供了六種引導(dǎo)模式,即EHPI引導(dǎo)模式、8位/16位并行EMIF引導(dǎo)模式、8位/16位標(biāo)準(zhǔn)串行口引導(dǎo)模式、SPI EEPROM引導(dǎo)模式、USB引導(dǎo)模式以及I2C E2PROM引導(dǎo)模式。本文采用16位并行EMIF引導(dǎo)模式,將BOOTM[3:0]設(shè)置為1011即可。
在16位并行EMIF引導(dǎo)模式下,DSP芯片內(nèi)部固化的Bootloader程序上電復(fù)位后,首先從CE1空間首地址0x200000h處開(kāi)始讀取程序代碼,并加載到RAM中運(yùn)行。
1.2 5509A的引導(dǎo)表格式
程序代碼以引導(dǎo)表的格式存儲(chǔ)在Flash存儲(chǔ)器中。引導(dǎo)表是獨(dú)立于所選引導(dǎo)模式的一種特定的格式,包含了用戶程序的代碼段、數(shù)據(jù)段、段在RAM中的目標(biāo)地址以及程序入口地址等其他相關(guān)信息。5509A引導(dǎo)表結(jié)構(gòu)如表1所示。
![CPLD譯碼的DSP二次Bootloader方法簡(jiǎn)析](/uploads/allimg/171024/2362486-1G024095205357.png)
DSP芯片內(nèi)部固化的Bootloader的主要功能是將Flash中存儲(chǔ)的引導(dǎo)表按一定順序加載到 RAM中,然后跳轉(zhuǎn)到32位程序入口地址開(kāi)始執(zhí)行。引導(dǎo)表文件可以通過(guò)TI公司提供的16進(jìn)制轉(zhuǎn)換工具生成,一般是hex格式,然后將此hex文件燒寫(xiě)到 Flash存儲(chǔ)器中供Bootloader加載。
2 DSP二次Bootloader的原理及實(shí)現(xiàn)
由上述分析可知,DSP用戶程序的并行加載過(guò)程是由DSP內(nèi)固化的Bootloader實(shí)現(xiàn)的。由于5509A的PGE封裝只有14根地址線,最多只能訪問(wèn)到16K×16bit地址空間。對(duì)于超過(guò)16KB的用戶代碼,Bootloader將不能加載全部的引導(dǎo)表文件。因此若要加載超過(guò)16K的用戶代碼,必須進(jìn)行二次Bootloader。
二次Bootloader的原理是由用戶自行編寫(xiě)一個(gè)代碼長(zhǎng)度小于16KB的引導(dǎo)程序(以下簡(jiǎn)稱 uboot),其功能與DSP內(nèi)固化的Bootloader相同,用于加載最終的用戶代碼。在uboot程序中控制Flash存儲(chǔ)器的高位地址線來(lái)訪問(wèn) Flash的其他存儲(chǔ)內(nèi)容。這樣,DSP上電復(fù)位后,Bootloader首先加載uboot并運(yùn)行,然后uboot又加載最終用戶代碼,實(shí)現(xiàn)了大于 16K代碼的二次引導(dǎo)。
2.1 DSP與Flash及CPLD的硬件接口
本文采用AMD的 Am29LV800作為DSP的外部存儲(chǔ)器擴(kuò)展。Am29LV800按8位方式訪問(wèn),容量為1M字;按16位方式訪問(wèn),容量為512K字。DSP外圍電路邏輯譯碼及Flash高位地址線模擬由CPLD實(shí)現(xiàn)。Xilinx公司的XC9572XL是一款高性能的CPLD芯片,最高主頻可達(dá)178MHz,包含了 72個(gè)宏單元,1 600個(gè)可用門(mén)電路,其TQFP封裝有72個(gè)可用I/O引腳[7]。圖1是5509A與CPLD及Flash之間的硬件接口設(shè)計(jì)原理圖。
![CPLD譯碼的DSP二次Bootloader方法簡(jiǎn)析](/uploads/allimg/171024/2362486-1G024095213603.png)
如圖1所示,5509A的地址線A[13:1]與Flash的地址線A[12:0],A0未用。Flash存儲(chǔ)器被映射到DSP的CE1空間,由片選線CE1經(jīng)CPLD譯碼后選通。其中DSP的地址線A13和A[3:1]與CPLD接口,用于換頁(yè)寄存器FPR的模擬。Flash存儲(chǔ)器的BYTE引腳經(jīng)上拉后接高電平,即按16位方式訪問(wèn)。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- DCDC二次電源輻射特性研究
- 基于光華逼近函數(shù)的求解凸二次規(guī)劃方法 3次下載
- 簡(jiǎn)析獲取單片機(jī)代碼運(yùn)行時(shí)間的方法資料下載
- 變壓器的一次繞組和二次繞組的檢測(cè)方法資料下載
- 一種雙向隔離DC-DC變換器二次紋波電壓抑制方法 7次下載
- 針對(duì)二次再熱機(jī)組DEH建模分析 0次下載
- 通信用二次電源的網(wǎng)上設(shè)計(jì)方法 3次下載
- 基于馬氏距離的二次電源狀態(tài)判析方法_王鳳茹 0次下載
- 基于二次特征壓縮技術(shù)的油液監(jiān)測(cè)方法研究_劉學(xué)工 0次下載
- LED路燈的二次光學(xué)設(shè)計(jì) 4次下載
- AutoCAD VBA二次開(kāi)發(fā)教程 0次下載
- 新型二次電池材料
- 二次電池的特性和應(yīng)用
- 基于CPLD的計(jì)數(shù)及LED譯碼電路
- 面向?qū)ο蟮膮?shù)化CAD二次開(kāi)發(fā)方法研究
- 電力系統(tǒng)一次設(shè)備和二次設(shè)備區(qū)別,二次回路的分類 3130次閱讀
- 關(guān)于二次回路工作的安全規(guī)定 4612次閱讀
- 二次回路簡(jiǎn)述 821次閱讀
- 氮化鎵中鉻含量的二次離子質(zhì)譜分析方法研究 687次閱讀
- 二次回路識(shí)圖方法講解(附案例) 3224次閱讀
- 電流互感器二次側(cè)接地的方法 2.1w次閱讀
- 電流互感器二次側(cè)接地原因 2.5w次閱讀
- 二次回路的作用 9299次閱讀
- 什么是二次設(shè)備?二次設(shè)備有哪些 5.4w次閱讀
- 電氣二次常見(jiàn)問(wèn)題有哪些_40個(gè)電氣二次常見(jiàn)問(wèn)題盤(pán)點(diǎn) 5408次閱讀
- 電流互感器二次側(cè)是什么意思_電流互感器二次側(cè)為什么不能開(kāi)路 8.3w次閱讀
- 二次電池是什么_二次電池有哪些_二次電池充放電方程式 2.3w次閱讀
- 什么是一次電流_什么是二次電流_計(jì)算公式是怎樣的 5.2w次閱讀
- mapreduce二次排序_ mapreduce二次排序原理 6297次閱讀
- 基于TDD-LTE終端二次諧波的抑制應(yīng)用設(shè)計(jì) 3194次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費(fèi)下載
- 0.00 MB | 1489次下載 | 免費(fèi)
- 2單片機(jī)典型實(shí)例介紹
- 18.19 MB | 91次下載 | 1 積分
- 3S7-200PLC編程實(shí)例詳細(xì)資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識(shí)別和講解說(shuō)明
- 4.28 MB | 18次下載 | 4 積分
- 5開(kāi)關(guān)電源原理及各功能電路詳解
- 0.38 MB | 9次下載 | 免費(fèi)
- 6基于AT89C2051/4051單片機(jī)編程器的實(shí)驗(yàn)
- 0.11 MB | 4次下載 | 免費(fèi)
- 7基于單片機(jī)和 SG3525的程控開(kāi)關(guān)電源設(shè)計(jì)
- 0.23 MB | 3次下載 | 免費(fèi)
- 8基于單片機(jī)的紅外風(fēng)扇遙控
- 0.23 MB | 3次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費(fèi)
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費(fèi)
- 4LabView 8.0 專業(yè)版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費(fèi)
- 5555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33562次下載 | 免費(fèi)
- 6接口電路圖大全
- 未知 | 30319次下載 | 免費(fèi)
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費(fèi)
- 8開(kāi)關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21539次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537791次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233045次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191183次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183277次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138039次下載 | 免費(fèi)
評(píng)論