




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
雙核DSP片TMS320VC5421的并行引導(dǎo)方案
摘要:介紹了利用雙核DSP芯片TMS320VC5421的片內(nèi)Bootloader程序?qū)崿F(xiàn)并行引導(dǎo)的設(shè)計(jì)方案,給出了其軟件及硬件的具體實(shí)現(xiàn)方法。關(guān)鍵詞:TMS320VC5421;Bootloader;并行引導(dǎo);Boot表;FLASH;CPLD
1引言
TMS320VC54211、2是TI公司推出的一款雙核定點(diǎn)DSP芯片,它擁有兩個(gè)DSP子系統(tǒng),每個(gè)子系統(tǒng)都有一個(gè)DSP核,并且均有獨(dú)立的數(shù)據(jù)和程序存儲(chǔ)空間,可以進(jìn)行兩核之間的通信,并且兩個(gè)子系統(tǒng)共享一套片外總線。此外,每個(gè)子系統(tǒng)各自擁有2k16bit字的片內(nèi)ROM,并存儲(chǔ)有Bootloader程序。當(dāng)DSP芯片上電或復(fù)位時(shí),兩個(gè)DSP核可分別啟動(dòng)自身獨(dú)立的Bootloader程序,以實(shí)現(xiàn)用戶程序的上電自舉。
雙核DSP自啟動(dòng)和單核DSP自啟動(dòng)的實(shí)現(xiàn)方法有較大的差別,這一點(diǎn)在DSP系統(tǒng)設(shè)計(jì)中需要特別注意。本文對(duì)雙核DSP芯片VC5421的引導(dǎo)模式進(jìn)行了深入的分析和研究,給出了使用16位并行引導(dǎo)模式進(jìn)行雙核DSP引導(dǎo)的實(shí)現(xiàn)方案。
2TMS320VC5421的Boot模式
VC5421可提供16位并行引導(dǎo)、8位并行引導(dǎo)和串行EEPROM引導(dǎo)等三種Boot模式來實(shí)現(xiàn)用戶程序的上電自舉。
其中16位并行引導(dǎo)模式是通過片外存儲(chǔ)器接口以DMA方式將代碼從16-bit字寬的片外數(shù)據(jù)存儲(chǔ)器搬移到片內(nèi)程序存儲(chǔ)空間;
8位并行引導(dǎo)模式則是通過片外存儲(chǔ)器接口以DMA方式將代碼從8-bit字寬的片外數(shù)據(jù)存儲(chǔ)器搬移到片內(nèi)的程序存儲(chǔ)空間;
而串行EEPROM引導(dǎo)模式主要是通過多通道緩沖串口2從主設(shè)備中搬移代碼并實(shí)現(xiàn)上電自舉。
和54系列中其它芯片不同的是,VC5421片內(nèi)ROM中的Bootloader程序并不支持HPI、并行I/O和標(biāo)準(zhǔn)串口模式的自啟動(dòng)方式。在其所支持的三種boot模式中,16位并行引導(dǎo)模式是最常用的。本文對(duì)這種模式進(jìn)行了深入分析,給出了使用該模式進(jìn)行雙核DSP程序引導(dǎo)的方案,并通過實(shí)驗(yàn)驗(yàn)證了該方案的正確性。
2.1并行引導(dǎo)模式的選擇
VC5421的兩個(gè)DSP核在DSP芯片上電或復(fù)位時(shí),到底以哪種模式實(shí)現(xiàn)上電自舉,主要由兩個(gè)核的公共引腳XIO和各自的GPIO0/ROMEN、GPIO1引腳決定。當(dāng)XIO為0時(shí),將不從ROM引導(dǎo),也就是說,將不使用VC5421片內(nèi)ROM中的Bootloader程序?qū)崿F(xiàn)上電引導(dǎo),而是用HPI模式實(shí)現(xiàn)上電自舉;當(dāng)XIO為1,GPIO0/ROMEN為0時(shí),將使用片外存儲(chǔ)器中用戶自己編寫的Bootloader程序?qū)崿F(xiàn)上電自舉;當(dāng)XIO為1GPIO/ROMEN為1GPIO1為0或1時(shí),將分別使用并行或者串行引導(dǎo)模式實(shí)現(xiàn)上電自舉。因此,在實(shí)施相應(yīng)的上電自舉前,必須將引腳狀態(tài)設(shè)置正確,以保證Bootloader程序按預(yù)定的模式執(zhí)行。Bootloader模式的選擇流程見圖1。
當(dāng)Bootloader程序檢測(cè)到并行引導(dǎo)模式時(shí),程序?qū)⒁裕模停练绞綇钠鈹?shù)據(jù)存儲(chǔ)區(qū)的0000h單元取出模式選擇字來進(jìn)一步?jīng)Q定是8位還是16位的并行引導(dǎo)模式。10AAh意味著選擇了16位并行引導(dǎo)模式,而如果選擇8位并行引導(dǎo)模式,取出的兩個(gè)字節(jié)將是08h和AAh。之后,程序?qū)凑眨拢铮铮舯磉M(jìn)行加載。圖2是并行引導(dǎo)模式的選擇流程。
2.216位并行引導(dǎo)模式的Boot表
Bootloader程序要搬移的代碼必須組織成一定的格式,這就是Boot表。16位并行引導(dǎo)模式的Boot表如表1所列。
表116位并行導(dǎo)模式Boot表DMA外部數(shù)據(jù)存儲(chǔ)地址數(shù)據(jù)內(nèi)容含義0000h10AAh16位并行引導(dǎo)標(biāo)志0001h7FFFhSWWSR0002hF000hBSCR0003h0000h程序入門XPC0004h5000h程序入口地址0005h002Ch代碼長度0006h0000h目的XPC0007h5000h目的地址0008h7761h程序代碼…………程序代碼…………程序代碼0034h0000hBoot表結(jié)束
此外,需要注意的是,由于在多數(shù)程序中都有跳轉(zhuǎn)指令或循環(huán)指令,所以,Boot表中的程序入口地址必須和程序的cmd文件中分配的地址保持一致,也就是說,當(dāng)在CCS中進(jìn)行調(diào)試時(shí),如果程序Load到5000h,Boot表中的程序入口地址就應(yīng)該是5000h。
2.3Boot表的生成
Boot表可由hex500格式轉(zhuǎn)換工具生成,也可以自己編寫一個(gè)文件格式轉(zhuǎn)換程序來把.out文件轉(zhuǎn)換成所需的文件格式。本設(shè)計(jì)通過編寫一個(gè)C++程序來將.out文件轉(zhuǎn)換成.hex文件,然后再在文件的開始處增加相應(yīng)的標(biāo)志位和寄存器設(shè)置字,從而形成完整的Boot表。
3VC5421片外
總線沖突的解決方案
由于VC5421是雙核DSP,每個(gè)核有各自的存儲(chǔ)空間和Bootloader程序,但兩核共享一套片外總線和一個(gè)XIO引腳。這樣,當(dāng)兩核的復(fù)位引腳A_RS和B_RS同時(shí)收到復(fù)位低電平信號(hào)時(shí),將同時(shí)申請(qǐng)片外總線的控制權(quán)。這就造成了申請(qǐng)片外總線的沖突。而且Bootloader程序總是檢查該核有沒有片外總線的控制權(quán),如果沒有,將循環(huán)檢查直到取得片外總線的控制權(quán)。為了避免這種情況的發(fā)生,應(yīng)該以合理的順序給兩個(gè)核上電。
由于VC5421中A核帶有用來控制時(shí)鐘頻率的鎖相環(huán)電路,所以應(yīng)該先對(duì)A核進(jìn)行復(fù)位,再啟動(dòng)A核,然后利用A核的用戶程序來控制B核的復(fù)位,以實(shí)現(xiàn)兩個(gè)核的啟動(dòng)。
根據(jù)系統(tǒng)需要,本設(shè)計(jì)使用Altera公司的CPLD芯片來產(chǎn)生各種控制信號(hào)。其電路連接示意圖如圖3所示。A核的復(fù)位信號(hào)A_RS由CPLD芯片直接給出,并在系統(tǒng)上電或復(fù)位的同時(shí)對(duì)A核進(jìn)行復(fù)位。而B核的復(fù)位信號(hào)B_RS則通過CPLD映射到DSP的I/O空間0000h地址單元的第6位:B核復(fù)位控制位如圖4所示。在A核啟動(dòng)后,通過用戶程序?qū)懀拢撸遥游豢蔀椋潞颂峁?fù)位信號(hào)。
4VC5421的并行引導(dǎo)自啟動(dòng)操作
4.1用戶程序的搬移
兩個(gè)DSP核要完成各自的功能,執(zhí)行的用戶程序是不盡相同的,而且A核的用戶程序還要控制B核的復(fù)位,因此兩個(gè)DSP核的Boot表內(nèi)容是不同的。由DMA方式內(nèi)部存儲(chǔ)器圖可知,程序空間的第0頁和第1頁屬于A核,第2頁和第3頁屬于B核。因此,需要注意的是,當(dāng)Bootloader程序搬移用戶程序時(shí),A核的用戶程序要被搬移到內(nèi)部程序空間的第0頁上,而B核的用戶程序則要被搬移到第2頁上。于是B核Boot表中的程序入口XPC和目的XPC應(yīng)被設(shè)置成0002h。
4.2Boot表的放置
本系統(tǒng)用4MbitFLASH器件SST39VF400A作為片外數(shù)據(jù)存儲(chǔ)器。頁選信號(hào)由DSP通過CPLD給出,并且映射到DSP中I/O空間的0000h地址單元的低5位。如圖4所示。另外,此地址單元的第5位是控制FLASH映射的配置位。當(dāng)CFG為0時(shí),FLASH被映射到DMA片外數(shù)據(jù)空間的0000h,此時(shí),Bootloader程序可以以DMA方式從FLASH中搬移數(shù)據(jù)并進(jìn)行自啟動(dòng);當(dāng)CFG為1時(shí),FLASH被映射到CPU片外數(shù)據(jù)空間的8000h,在這種情況下,可以通過程序向FLASH中燒寫數(shù)據(jù)。因此,這一位在系統(tǒng)上電或復(fù)位后將被設(shè)置成0,以使A核能夠順利啟動(dòng)。
由于兩個(gè)DSP核的Boot表內(nèi)容不同,故應(yīng)視Boot表的大小,將兩個(gè)Boot表放到FLASH的不同頁上,以便對(duì)兩個(gè)核分別實(shí)行引導(dǎo)。本設(shè)計(jì)將A核的Boot表放到第0頁,將B核的Boot表放到第1頁。
4.3外總線控制權(quán)的釋放
如圖5所示,在GPIO控制寄存器中,XIO_GRANT位為1代表相應(yīng)的DSP核取得了片外總線的控制權(quán);而在還沒有取得控制權(quán)但在申請(qǐng)片外總線的控制權(quán)時(shí),相應(yīng)的XIO_REQ位應(yīng)置為1;CORE_SEL位用于表示程序在哪個(gè)核上運(yùn)行,當(dāng)在CPUA上運(yùn)行時(shí),讀A核的GPIO控制寄存器的CORE_SEL位將返回到“0”,而當(dāng)同一個(gè)程序在CPUB上運(yùn)行時(shí),讀B核的GPIO控制寄存器的CORE_SEL位將返回到“1”。有關(guān)GPIO控制寄存器的其它相關(guān)位,設(shè)計(jì)時(shí)可查閱有關(guān)的參考文獻(xiàn)1。
4.4FLASH的燒寫
筆者根據(jù)SST39VF400A的資料編寫了一個(gè)DSP程序,該程序可同時(shí)將A核的Boot表燒寫到FLASH的第0頁,而將B核的Boot表燒寫到第1頁。
在系統(tǒng)上電或復(fù)位后,A核首先運(yùn)行它的Boot-loader程序,A核啟動(dòng)后執(zhí)行用戶程序。用戶程序首先將頁選設(shè)置成第1頁,這樣,FLASH的第一頁將被映射到DMA片外數(shù)據(jù)空間的0000h;然后,A核釋放片外總線控制權(quán),并給B核發(fā)出復(fù)位信號(hào),此時(shí)由于只有B核復(fù)位,且A核已釋放片外總線的控制權(quán),因此,B核將申請(qǐng)到片外總線控制權(quán),同時(shí)執(zhí)行Bootloader程序的啟動(dòng)以完成整個(gè)DSP引導(dǎo)。完整的啟動(dòng)過程流程圖如圖6所示,下面是A核的啟動(dòng)測(cè)試程序代碼
·mmregs
·titlc″testLEDA″
·globalbegin
·text
.............
beginstm#0x000,0x0061;設(shè)置頁選信號(hào)
portwox0061,00h
callwait
andm#0xffcf,3ch;釋放片外總線
callwait;控制權(quán)
stm#0x00410x0061;給B核復(fù)位信號(hào)
portw0x0061,00h
callwait
stm#0x0001,0x0061
portw0x0061,00h
flash:rsbs1,xf;發(fā)光二極管亮
callwait
ssbx1,xf;發(fā)光二極管滅
callwait
bflash
;----Subroutinetowaitforsometime----
wait:stm#80,ar6
loop0:st
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度醫(yī)療健康股權(quán)分配與產(chǎn)業(yè)布局協(xié)議
- 二零二五年度酒店員工勞動(dòng)合同與員工培訓(xùn)及職業(yè)素養(yǎng)提升合同
- 2025年度金融控股集團(tuán)間戰(zhàn)略資金借款合同
- 二零二五年度高空作業(yè)安全協(xié)議責(zé)任書(高空設(shè)備檢修安全協(xié)議)
- 二零二五年度鮮魚養(yǎng)殖與品牌營銷合作合同
- 二零二五年度電子商務(wù)平臺(tái)技術(shù)支持合同范本
- 二零二五年度汽車租賃代駕保險(xiǎn)保障合同
- 2025年度餐廳門面租賃與地方旅游發(fā)展合作合同
- 安徽省2025年度非全日制用工勞動(dòng)合同書解除與終止協(xié)議
- 數(shù)據(jù)安全保障與服務(wù)合作合同
- CJJ 82-2012 園林綠化工程施工及驗(yàn)收規(guī)范
- 數(shù)據(jù)庫原理及應(yīng)用(第3版)
- 預(yù)防流感健康知識(shí)講座總結(jié)
- 國際標(biāo)準(zhǔn)《風(fēng)險(xiǎn)管理指南》(ISO31000)的中文版
- 幼兒園中班語言《猜燈謎》
- 煙花爆竹經(jīng)營
- 射頻同軸電纜簡介
- 2023-2024全球及中國企業(yè)組織活力報(bào)告(中文版)
- 現(xiàn)代自來水廠自動(dòng)化控制系統(tǒng)
- 2024年長沙衛(wèi)生職業(yè)學(xué)院高職單招(英語/數(shù)學(xué)/語文)筆試歷年參考題庫含答案解析
- 2024年南京信息職業(yè)技術(shù)學(xué)院高職單招(英語/數(shù)學(xué)/語文)筆試歷年參考題庫含答案解析
評(píng)論
0/150
提交評(píng)論