基于FPGA的PXA270外設(shè)時序轉(zhuǎn)換接口設(shè)計方案_第1頁
基于FPGA的PXA270外設(shè)時序轉(zhuǎn)換接口設(shè)計方案_第2頁
基于FPGA的PXA270外設(shè)時序轉(zhuǎn)換接口設(shè)計方案_第3頁
基于FPGA的PXA270外設(shè)時序轉(zhuǎn)換接口設(shè)計方案_第4頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、    基于FPGA的PXA270外設(shè)時序轉(zhuǎn)換接口設(shè)計方案1引言ARCNET協(xié)議應(yīng)用于高速動車組列車通信網(wǎng)絡(luò)時,產(chǎn)生中央控制單元處理器PXA270與專用協(xié)議控制器件COM20020相連的時序不匹配問題,若用通用數(shù)字電路模塊進(jìn)行時序轉(zhuǎn)換,PXA270需占用PXA270專門的資源(CPU時間片)對COM20020的寄存器、數(shù)據(jù)包緩沖區(qū)進(jìn)行低速讀寫訪問(對COM20020的相鄰兩次讀操作相隔至少300ns),這樣將增加處理器的負(fù)擔(dān)。基于這種現(xiàn)狀,提出一種基于FPGA的PXA270外設(shè)時序轉(zhuǎn)換接口設(shè)計方案,以FPGA為橋梁進(jìn)行時序轉(zhuǎn)換1 引言ARCNET協(xié)議應(yīng)用

2、于高速動車組列車通信網(wǎng)絡(luò)時,產(chǎn)生中央控制單元處理器PXA270與專用協(xié)議控制器件COM20020相連的時序不匹配問題,若用通用數(shù)字電路模塊進(jìn)行時序轉(zhuǎn)換,PXA270需占用PXA270專門的資源(CPU時間片)對 COM20020的寄存器、數(shù)據(jù)包緩沖區(qū)進(jìn)行低速讀寫訪問(對COM20020的相鄰兩次讀操作相隔至少300ns),這樣將增加處理器的負(fù)擔(dān)?;谶@種現(xiàn)狀,提出一種基于FPGA的PXA270外設(shè)時序轉(zhuǎn)換接口設(shè)計方案,以FPGA為橋梁進(jìn)行時序轉(zhuǎn)換,并增加存儲器直接訪問DMA(Direct Memory Aeeess)功能,即FPGA自動完成數(shù)據(jù)包的收發(fā)工作,PXA270則只需高速讀寫訪問FPG

3、A中的同步雙口RAM。2 時序轉(zhuǎn)換接口整體設(shè)計2.1 FPGA對外接白采用FPGA連接PXA270處理器與外設(shè)以解決PXA270處理器與外設(shè)直接連接時的時序不匹配問題。如圖1所示,F(xiàn)PGA從PXA270處理器獲得地址總線(ADDRBUS17.14, ADDRBUS9.0),片選信號(SYSCS5),讀允許(SYSOE),寫允許(SYSWE),并提供雙向數(shù)據(jù)端口DATABUS7.0 (可根據(jù)實(shí)際應(yīng)用修改為32位或16位等),中斷(interrupt);同時,F(xiàn)PGA向COM20020提供特定的總線接口,包括 COM20020_DS,COM20020_CS,COM20020_DIR,COM2002

4、0_DATABUS 7.0,COM20020_ADDRBUS2.0等。2.2 內(nèi)部功能實(shí)現(xiàn)PXA270和外設(shè)之間的連接是將FPGA中的雙口RAM作為數(shù)據(jù)中轉(zhuǎn)站,以此間接相連。該設(shè)計由以下4個功能模塊組成。(1)PXA270對外設(shè)指定寄存器單次寫操作PXA270先將所要寫的數(shù)據(jù)送人雙口RAM,然后PXA270向FPGA的命令寄存器寫入對該外設(shè)指定寄存器的單次寫指令,然后FP-GA根據(jù)接收到的命令將RAM中的數(shù)據(jù)輸出到外設(shè)數(shù)據(jù)總線,同時給出對外設(shè)的寫時序。(2)PXA270對外設(shè)指定寄存器單次讀操作PXA270先向FPGA的命令寄存器寫入對該外設(shè)指定寄存器的單次讀指令,此時,F(xiàn)PGA給出對外設(shè)的讀

5、時序,并驅(qū)動RAM的地址總線、寫時鐘等信號,將外設(shè)數(shù)據(jù)總線上的數(shù)據(jù)傳送到RAM中。再延時1s,PXA270從RAM中讀出數(shù)據(jù)。(3)PXA270對外設(shè)批數(shù)據(jù)寫操作與單次寫操作不同的是,PXA270需先將所要寫入的數(shù)據(jù)存儲到RAM的連續(xù)空間,然后向FPGA的命令寄存器寫入批數(shù)據(jù)寫操作指令,F(xiàn)P-GA根據(jù)接收到的命令將RAM中的數(shù)據(jù)分次送至外設(shè)數(shù)據(jù)總線,且需保證向COM20020的寫時序與之同步。(4)PXA270對外設(shè)批數(shù)據(jù)讀操作 由FPGA給出對外設(shè)的連續(xù)多次讀時序?qū)⑼庠O(shè)中的數(shù)據(jù)送人RAM,完成存儲工作。PXA270等待批數(shù)據(jù)讀完成中斷發(fā)生后對RAM進(jìn)行連續(xù)讀。3 功能模塊設(shè)計3.1 時序發(fā)生

6、模塊設(shè)計COM20020有80xx-like和68xx-like兩種總線訪問方式。這里中實(shí)現(xiàn)68xx-like訪問方式,圖2為其讀寫訪問時序。讀寫時序的共同要求為:片選信號CS必須先于DS至少5 ns,并且只允許在DS無效之后CS才能恢復(fù)為高電平;讀寫方向信號DIR應(yīng)在DS有效前至少10 ns建立;DS高電平寬度不小于20 ns。兩者的不同要求:寫時序的地址總線先于操作脈沖DS至少15ns建立,DS低電平不小于20 ns,數(shù)據(jù)總線有效數(shù)據(jù)必須在DS變高之前至少30 ns建立,保持至DS變高后至少10 ns;而讀時序的地址總線先于片選信號至少15 ns建立,DS低電平不小于60 ns,DS變低到

7、數(shù)據(jù)總線數(shù)據(jù)有效的間隔最大為40ns,DS變高到數(shù)據(jù)總線高阻抗的間隔最大為20 ns,這是COM20020作為數(shù)據(jù)輸出方給訪問設(shè)備提供的特性。針對以上讀寫時序的要求,具體設(shè)計如下:DIR在一次操作中只有高或低電平一種可能,通過命令寄存器在操作前事先給出,而后給出使能信號,DS在CS有效之后變低,而在CS無效之前變高,以便數(shù)據(jù)可靠鎖存。圖3為COM20020的時序原理圖,從時序分析可得出如下設(shè)計方案:DIR用于指示操作是讀還是寫,DIR=1為讀,否則為寫。在操作前先對DIR 賦值;在EN有效時選擇CS,CLK的下一次上升沿變?yōu)橛行?。這樣是給寫操作對COM20020數(shù)據(jù)總線準(zhǔn)備數(shù)據(jù)之用,不影響讀操

8、作;DS選擇在CS有效的下一個CLK上升沿變?yōu)橛行?,但在CS無效前兩個時鐘周期給出上升沿,以滿足“片選信號CS必須先于DS至少5 ns,并且只能在DS無效之后恢復(fù)為高電平”,并且DS中間應(yīng)有至少60ns的時鐘寬度,因而保持3個CLK周期有效。圖4為CommandGenerator時序仿真圖。采用計數(shù)器進(jìn)行時序同步。以下給出VHDL源代碼。 圖5為批數(shù)據(jù)從WRRAM向外設(shè)傳送的連續(xù)時鐘產(chǎn)生和自動地址生成原理圖。其中,lpm_counter0為帶有異步清零和進(jìn)位信號的增計數(shù); AutoAccessDataNumsOnce在EN='1'時,產(chǎn)生一次批傳送時鐘,根據(jù)COM20

9、020的長短數(shù)據(jù)包傳送要求,在CCESSTYPE =1時傳送長數(shù)據(jù)包(512B),否則傳送短數(shù)據(jù)包(256B)。FRE信號同時提供WRRAM的rdclock和lpm_counter0的clock信號。圖6為一次批數(shù)據(jù)向RAM中寫,而后啟動DMA傳輸,將數(shù)據(jù)從RAM送至COM20020的時序仿真。在WRCLOCK上升沿時,RAM將datain總線上的數(shù)據(jù)存儲到WR_AD-DRESS所指向的字節(jié)地址空間,WRCLOCK信號是由PXA270的WE信號與分配給RAM的片選信號(高電平有效)相與而得。對RAM進(jìn)行模擬寫時必須確保AUTOWREN無效(低電平);在檢驗數(shù)據(jù)DMA傳輸?shù)腞AM輸出環(huán)節(jié),WRC

10、LOCK應(yīng)不再出現(xiàn)上升沿信號,以防RAM同時讀寫造成輸出不定值。此外,每個數(shù)據(jù)從outputdata端口輸出時,CS、DS在一定延時后(1個CLK時鐘周期)給時序產(chǎn)生留足夠時間。需說明:COM20020內(nèi)部有2 K字節(jié)的RAM空間,用于存放待發(fā)送或已接收的數(shù)據(jù)包,在向RAM中寫數(shù)據(jù)包前,指定該數(shù)據(jù)包的存放位置,然后將COM20020中的指針自動移動位置 1,則只需連續(xù)的向該RAM中寫數(shù)據(jù),而不必給出地址信號。3.3 對外設(shè)指定寄存器操作對外設(shè)指定寄存器操作比批數(shù)據(jù)傳送實(shí)現(xiàn)簡單,只需將操作次數(shù)降為1次,并對 COM20020的A2A0提供相應(yīng)的地址即可。指定寄存器操作將數(shù)據(jù)存儲在RAM的高512字節(jié)空間,并且只占用其中低8個字節(jié),在PXA270編程時,需確保PXA270送入RAM的地址與命令寄存器中的RAM存儲地址COMMANDBYTE2.0相對應(yīng)。4 結(jié)論本設(shè)計解決ARCNET協(xié)議專用器件應(yīng)用于列車通信網(wǎng)絡(luò)中的時序匹配問題,實(shí)現(xiàn)了PXA270處

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論