新聞中心

EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 基于PCI總線通用DSP信號(hào)處理系統(tǒng)的設(shè)計(jì)

基于PCI總線通用DSP信號(hào)處理系統(tǒng)的設(shè)計(jì)

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

由于時(shí)鐘高達(dá)33MHz,信號(hào)線應(yīng)按微波傳輸線對(duì)待,再加上接口邏輯本身的復(fù)雜性,設(shè)計(jì)難度很大。實(shí)現(xiàn)接口的辦法:(1)用可編程邏輯器件EPLD或FPGA和用EPLD或FPGA實(shí)現(xiàn)。PCI接口的優(yōu)點(diǎn)在于其靈活的可編程性。首先PCI接口可以依據(jù)插卡功能進(jìn)行最優(yōu)化,而不必實(shí)現(xiàn)所有的PCI功能,這樣可以節(jié)約系統(tǒng)的邏輯資源;其次可以將PCI插卡上的其他用戶邏輯與PCI接口邏輯集成在一個(gè)芯片上,實(shí)現(xiàn)緊湊的系統(tǒng)設(shè)計(jì);再者當(dāng)系統(tǒng)升級(jí)時(shí),只需對(duì)可編程器件重新進(jìn)行邏輯設(shè)計(jì)而無(wú)需更新PCB版圖。(2)用專用PCI接口芯片實(shí)現(xiàn)。專用PCI接口芯片可以實(shí)現(xiàn)完整的PCI主控模塊和目標(biāo)模塊接口功能,將復(fù)雜的接口轉(zhuǎn)換為相對(duì)簡(jiǎn)單的用戶接口。廠商對(duì)接口進(jìn)行了嚴(yán)格的測(cè)試,用戶只要設(shè)計(jì)轉(zhuǎn)換后的總線接口即可。從某種意義上講,PCI接口完成的是PCI總線和插卡上的從屬處理器之間的消息傳遞。

由于以上原因,再考慮到系統(tǒng)開(kāi)發(fā)的成本和周期,用專用接口芯片來(lái)實(shí)現(xiàn)PCI總線的接口較理想。接口芯片選用的是TI公司的PCI2040。PCI2040 是專門(mén)用來(lái)和54X或6X橋接的芯片,可以實(shí)現(xiàn)與TMS320VC5402的無(wú)縫接口 ;可以對(duì)端口進(jìn)行訪問(wèn)讀寫(xiě)。PCI2040提供了一個(gè)由PCI總線至插卡總線的直通通路(pass-thru)。PCI2040通過(guò)這些數(shù)據(jù)通路將復(fù)雜的PCI接口轉(zhuǎn)換為相對(duì)簡(jiǎn)單的插卡總線接口。在本系統(tǒng)中,中的資源映射到PC機(jī)的內(nèi)存D9008000~D9008FFF和D9000000~ D9007FFF,中斷請(qǐng)求為11。

PCI2040通過(guò)HPI接口與通信,通信流程如下:PCI總線向PCI2040讀寫(xiě)數(shù)據(jù),PCI2040會(huì)根據(jù)這些命令在HPI口上發(fā)起相應(yīng)的要求,這個(gè)通信過(guò)程可以通過(guò)編程首先初始化HPI控制寄存器HPIC以及主機(jī)地址寄存器HPIA,然后再?gòu)闹鳈C(jī)數(shù)據(jù)寄存器HPID中讀/寫(xiě)數(shù)據(jù)來(lái)完成。具體的接口電路如圖4所示:一塊PCI2040最多可以掛接4片 ,以用于多DSP系統(tǒng)。

3.2 擴(kuò)展空間

對(duì)來(lái)講,DSP芯片所帶的資源常常不能滿足要求。這包括兩個(gè)方面,一是程序空間,二是數(shù)據(jù)空間。對(duì)程序空間,可以選擇不同的自舉方式,充分利用PC機(jī)的資源。對(duì)數(shù)據(jù)空間有下面幾種解決方法:(1)選擇資源多的芯片,但這會(huì)引起成本的上升;(2)改進(jìn)算法,邊讀取數(shù)據(jù)邊處理;(3)用一個(gè)鎖存器保存高位地址,自己擴(kuò)展數(shù)據(jù)空間。這 里采用的方法是在用算法進(jìn)行邊讀數(shù)據(jù)邊處理的同時(shí),用SRAM對(duì)數(shù)據(jù)空間進(jìn)行了擴(kuò)展??紤]到時(shí)序關(guān)系,以及TMS320VC5402只能與異步的存儲(chǔ)器連接等因素。選用了TPS73HD318。它是 3.3V,1M×16大小的靜態(tài)RAM,高低位字節(jié)可選,其讀寫(xiě)速度達(dá)到12ns,能夠與DSP的讀寫(xiě)速度相匹配,無(wú)須另加接口時(shí)序。對(duì)于等待時(shí)間的產(chǎn)生,可以用軟件的方法,對(duì)等待狀態(tài)寄存器(SWWSR)進(jìn)行設(shè)置。而產(chǎn)生的時(shí)延在調(diào)試時(shí)可以對(duì)DSP的時(shí)延寄存器進(jìn)行設(shè)置, 以達(dá)到最大速度。硬件接口如圖5所示。

4 DSP系統(tǒng)的自舉

所謂自舉(Bootload),就是在上電時(shí)從外部加載并執(zhí)行用戶的程序代碼。加載的途徑有:(1)從一個(gè)外部的EPROM或FLASH加載;(2)從主機(jī)通過(guò)HPI總線、并行I/O口、任何一個(gè)串行口、用戶定義的地址熱自舉等方式加載。因?yàn)樾盘?hào)處理的程序一般都比較大,為了保證這個(gè)的通用性和可移植性,需把程序保存在主機(jī)中,用HPI總線自舉。HPI是一個(gè)8位的并行口,PC機(jī)和'5402通過(guò)共享的片內(nèi)存儲(chǔ)器交換信息。選用HPI自舉方式,需要把HINT和INT2引腳連在一起。復(fù)位時(shí),Bootload使HINT置位,從而使 INT2置位。BootloaD讀出中斷標(biāo)志寄存器(IFR)的bit2位后,即能從HPI口進(jìn)行自舉。與別的54X系列一個(gè)很重要的不同是:5402要檢查數(shù)據(jù)存儲(chǔ)器的OX7FH位以決定程序的入口地址,用戶程序也要在復(fù)位完成后才能加載到HPI的RAM中。

5 驅(qū)動(dòng)程序

因?yàn)镻CI2040擴(kuò)展了配置空間,所以,要通過(guò) HPI口實(shí)現(xiàn)與DSP的通信,需要驅(qū)動(dòng)程序。如果直接使用DDK來(lái)編寫(xiě)PCI設(shè)備的驅(qū)動(dòng)程序,需要大量的Windows底層的知識(shí),難度比較大。因此可以使用別的驅(qū)動(dòng)程序的編寫(xiě)工具,如Vtools和 WinDrive。我們選用了WinDrive 。Jungo公司的WinDrive與其他驅(qū)動(dòng)程序開(kāi)發(fā)工具的最大不同是它可以在編程者不太了解Windows內(nèi)核的情況下編寫(xiě)驅(qū)動(dòng)程序。這樣,可以把精力主要放在功能的實(shí)行上,同時(shí)用WinDrive寫(xiě)成的驅(qū)動(dòng)程序只需作很少的修改就能很方便地適用于各種操作系統(tǒng),如Win dows 9x, Window 2000,Windows NT以及Linux等。編寫(xiě)過(guò)程如下:(1)用WinDrive 的Drive Wiz ard 工具查找所要編寫(xiě)驅(qū)動(dòng)程序的PCI卡,并用CREATING INF FILE 產(chǎn)生INF 文件,然后添加新硬件;(2)對(duì)PCI卡上的配置寄存器,I/O空間,內(nèi)存范圍,中斷,片內(nèi)寄存器進(jìn)行設(shè)置;(3)生成源代碼,對(duì)它進(jìn)行功能添加,主要是實(shí)現(xiàn)對(duì)DSP 片內(nèi)SRAM的訪問(wèn)。


上一頁(yè) 1 2 下一頁(yè)

評(píng)論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉