<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 基于FPGA的高速數(shù)據(jù)采集系統(tǒng)接口設計

          基于FPGA的高速數(shù)據(jù)采集系統(tǒng)接口設計

          ——
          作者:西安交通大學 黃偉,羅新民 時間:2007-01-26 來源:《單片機與嵌入式系統(tǒng)應用》 收藏

          引言

          當前,越來越多的通信系統(tǒng)工作在很寬的頻帶上,對于保密和抗干擾有很高要求的某些無線通信更是如此,隨著信號處理器件的處理速度越來越快,數(shù)據(jù)采樣的速率也變得越來越高,在某些電子信息領域,要求處理的頻帶要盡可能的寬、動態(tài)范圍要盡可能的大,以便得到更寬的頻率搜索范圍,獲取更多的信息量。因此,通信系統(tǒng)對信號處理前端的a/d采樣電路提出了更高的要求,即希望a/d轉(zhuǎn)換速度快而采樣精度高,以便滿足系統(tǒng)處理的要求。

          可編程門陣列fpga的出現(xiàn)已經(jīng)顯著改變了數(shù)字系統(tǒng)的設計方式。應用可編程門陣列fpga,可使數(shù)字系統(tǒng)設計具有高度的靈活性,因此fpga的應用越來越廣泛,而新一代fpga--virtex ⅱ-pro的出現(xiàn)使fpga的功能更加強大,但隨之而來的是要求提高數(shù)據(jù)的傳輸速率,過去人們總是關(guān)心如何提高處理器運行速度,而現(xiàn)在關(guān)心的是怎樣才能更快地將數(shù)據(jù)從一個芯片傳輸?shù)搅硪粋€芯片??梢姡咚贁?shù)據(jù)采集系統(tǒng)的輸入輸出接口設計就顯得尤為重要。

          1 高速采集系統(tǒng)介紹

          數(shù)據(jù)采集系統(tǒng)原理框圖如圖1所示,輸入的中頻信號經(jīng)a/d采樣電路采樣后,轉(zhuǎn)換成lvds信號送入fpga中,或通過fpga的端口rocketio從高速接口輸出,或通過fpga的端口lvds循環(huán)存儲于高速緩存中,再由低速接口輸出。其中,fpga主要完成對外接口管理、高速緩存的控制和管理。時鐘控制電路對a/d數(shù)據(jù)轉(zhuǎn)換器和可編程門陣列fpga起同步和均衡作用。

          本文引用地址:http://www.ex-cimer.com/article/21081.htm

          2 輸入輸出接口研究

          virtex ⅱ-pro系列是在virtex ⅱ系列fpga的基礎上,嵌入了高速i/o接口和ibm powerpc處理器,它能實現(xiàn)超高帶寬的系統(tǒng)芯片設計,支持lvds,lvpecl等多種差分接口,適應性很強。其中高速串行(mgt)技術(shù)采用了rocketio技術(shù),在可編程邏輯器件中內(nèi)嵌了速率為3.125gb/s的多端串行通信接口,該技術(shù)包括千mb以太網(wǎng)、10千以太網(wǎng)、3gio、serialata、infiniband和fibre channel,為高性能接口提供了完成的解決方案。lvds(low voltage differential signaling)信號標準是一種小振幅差分信號技術(shù),如圖2所示,它使用非常低的幅度信號(100-450mv),通過一對平行的pcb走線或平衡電纜傳輸數(shù)據(jù)。在兩條平行的差分信號線上流經(jīng)的電流方向相反,噪聲信號同時耦合到兩條線上,而接收端只關(guān)心兩信號的差值,于是噪聲被抵消。由于兩條信號線周圍的電磁場也互相抵消,故差分信號傳輸比單線信號傳輸電磁輻射小很多,從而提高了傳輸效率并降低了功耗。

          在高速數(shù)據(jù)采集系統(tǒng)中,使用了最新的a/d芯片max104a。該芯片是maxim公司的最新產(chǎn)品,采樣頻率可以達到1ghz,采樣精度為8位。芯片輸出是pecl(positive emitter-coupled logic)電平輸出。pecl信號的擺幅相對ecl要小,適合于高速數(shù)據(jù)的串行或并行連接。pecl的輸出電路結(jié)構(gòu)如圖3所示。該電路包含一個差分對管和一對射隨器。輸出射隨器工作在正電壓范圍內(nèi),無信號時電流始終存在,這樣有利于提高開關(guān)速度,標準的輸出負載接50ω電阻至vcco-2v的電平上,如圖3所示,在這種負載條件下,out+與out-的靜態(tài)電平典型值為ucco-1.3v,out+與out-輸出電流為14ma。pecl結(jié)構(gòu)的輸出阻抗很低,典型值為4-5ω,這表明它有很強的驅(qū)動能力。但當負載與pecl的輸出端之間有一段傳輸線時,低阻抗造成的失配將導致信號時域波形的振鈴現(xiàn)象。

          3 rocketio設計

          xilinx公司的virtex ⅱ-pro fpga采用具有時鐘恢復功能的全雙工串行i/o收發(fā)器,可高效地實施每通道帶寬達到3.125gb/s的不同協(xié)議設計。收發(fā)器支持高達到每通道3.125gb/s的數(shù)據(jù)速率,并可利用通道捆綁功能滿足各種應用不斷增長的數(shù)據(jù)傳輸速率的要求,virtex ⅱ-pro的收發(fā)模塊由物理編碼子層(pcs)和物理介質(zhì)接入(pma)構(gòu)成,其中物理編碼子層提供與fpga邏輯內(nèi)的數(shù)字接口,內(nèi)部包括:循環(huán)冗余碼校驗crc、8b/10b編解碼器、先進先出緩沖器fifo;物理介質(zhì)接入提供與外部媒體的模擬接口,其中包括:20倍時鐘倍頻器、發(fā)送端時鐘生成器、發(fā)送緩沖器、串化器、接收端的時鐘恢復電路,接收緩沖器、解串器、可變速率的全雙工收發(fā)器、可編程的五級差分輸出幅度(擺率)控制和可編程的四級輸出預加重模塊。rocketio的原始設計是比較復雜的,但幸運的是,xilinx公司提供了大量成熟的和高效的ip(intellectual property)核來使用。如果能夠很好地掌握該工具的使用,將會極大地縮短設計的進度,減少開發(fā)和調(diào)試時間,由于ip核是根據(jù)xilinx fpga器件的特點和結(jié)構(gòu)設計的,直接用xilinx fpga底層硬件原語進行描述,可充分地將fpga的性能開發(fā)出來,其實現(xiàn)結(jié)果在面積和速度上都能達到令人滿意的效果。在設計中,還要考慮到以下方面。

          (1)參考時鐘

          高性能的通信質(zhì)量要求有高穩(wěn)定性和高精度的時鐘源。抖動和頻偏是衡量時鐘源的兩個重要指標。頻偏是指時鐘標稱頻率與實際頻率的偏差,主要是受晶體精度的影響,由于rocketio模塊內(nèi)部將輸入?yún)⒖紩r鐘20倍頻,而rocketio模塊可容忍的輸入?yún)⒖紩r鐘抖動公差為40ps,可見參考時鐘的抖動對其性能有直接影響,所以必須選擇性能優(yōu)良的參考時鐘。抖動一般是指一個實際情況下的周期信號每個周期的圖樣相對于該信號理想情況下一個周期圖樣的偏差。抖動產(chǎn)生的原因包括:時鐘晶體本身的機械振動、器件的熱噪聲和電源串入噪聲等。抖動可以分為確定性抖動和隨機抖動,確定性抖動包括信號在傳輸中煤質(zhì)損耗、碼間串擾(isi)等周期性因素導致的抖動;隨機抖動是由半導體器件熱噪聲、電源波動等共模隨機噪聲源導致的。在virtex ⅱ-pro系列fpga中,rocketio模塊集中分布在上、下4個通道中,當rocketio工作在2.0 gbaud以上時,參考時鐘應采用差分輸入方式(如lvds、lvpech),由上述4個通道的專用差分時鐘引腳輸入,至相同時鐘信號引入不必要的抖動,在2.0 gbaud速率以下應用時,不要用fpga內(nèi)部的dcm來生成rocketio的輸入時鐘,因為經(jīng)dcm倍頻的時鐘會引入較大的抖動,使rocketio的接收鎖相環(huán)無法穩(wěn)定地鎖定發(fā)送時鐘,致使系統(tǒng)無法正常工作。

          (2)復位

          在virtex ⅱ-pro系列fpga中,rocketio模塊的復位引腳分為發(fā)送(tx_reset)和接收(rx_reset)兩部分。由于dcm在輸出時鐘鎖定在設定值前,輸出時鐘處于不穩(wěn)定狀態(tài),不能用作內(nèi)部邏輯電路時鐘,所以要在dcm時鐘輸出鎖定有效,并經(jīng)過適當延遲后才可將片內(nèi)邏輯復位。rocketio模塊要求復位輸入至少保持2個usrclk時鐘周期來完成內(nèi)部fifo的初始化。

          (3)pcb設計

          在pcb的設計中,應使差分線對內(nèi)的長度相互匹配,以減少信號扭曲。為使設計傳輸速率達到2.0 gbaud,在差分線對內(nèi)部每個走線區(qū)間內(nèi)的實際布線公差應控制在5 mil內(nèi)。差分線對內(nèi)兩條線之間的距離應盡可能小,以使外部干擾為共模特征。差分線對間的距離應盡可能保持一致,以降低差分阻抗分布的不連續(xù)性。采用電源層作為差分線的信號回路,因為電源平面有最小的傳輸阻抗,從而減少噪聲,由于每個過孔可帶來0.5-1.0db的損耗,應盡量減少過孔數(shù)目。過孔的通孔和焊盤應有盡量小的物理尺寸,并且在通孔穿越的未連接不加焊盤,差分對內(nèi)的過孔不僅在數(shù)量上要匹配,而且在放置的位置上也要接近,以使阻抗分布盡量一致,避免導致阻抗不連續(xù)的90°走線,而要用圓弧或45°折線來代替。走線時應使向左、向右折角的數(shù)量接近,這樣可減少信號經(jīng)差分線傳輸引起的扭曲。在模擬數(shù)字混合系統(tǒng)設計中,首先,應在電源和地線之間加上去耦電容;其次,盡量加寬電源和地線寬度,最好是地線比電源線寬,使得地線寬度>電源線寬度>信號線寬度;第三,使用統(tǒng)一地,而將pcb分區(qū)為模擬部分和數(shù)字部分,模擬信號在電路板所有層的模擬區(qū)內(nèi)布線,而數(shù)字信號在數(shù)字電路區(qū)內(nèi)布線,在這種情況下,數(shù)字信號返回電流不會流入到模擬信號的地。經(jīng)過以上設計,噪聲影響明顯降低。

          4 接口解決方案

          隨著高速數(shù)據(jù)傳輸業(yè)務需求的增加,如何高質(zhì)量地解決高速ic芯片的相互連接變得越來越重要,低功耗及高的信噪比是有待解決的主要問題。本文所介紹的高速采集系統(tǒng)中芯片間有兩種接口:pecl和lvds,如何進行兩接口相互連接就成為一個影響系統(tǒng)性能的關(guān)鍵因素,lvds的輸入與輸出都是內(nèi)匹配的,所以lvds間的連接可采用圖4所示的直接連接,在fpga內(nèi),需對差分輸入時鐘緩沖器(ibufds),差分輸入的全局時鐘緩沖區(qū)(ibufgds)和差分輸出時鐘緩沖器(obufds)例化,在本項目的應用中,發(fā)送及接收fifo的設計用了雙口塊內(nèi)存(block ram),時鐘倍頻器用了延遲鎖定環(huán)(dll),幀解碼器由30位并行數(shù)據(jù)產(chǎn)生器、同步字檢測陣列和接收狀態(tài)機組成。

          fpga的部分代碼如下:

          pecl間的連接一般常用直流耦合。在直流耦合情況下,pecl輸出設計驅(qū)動50ω負載至(vcc-2v),電路如圖5所示。

          fpga的部分代碼如下:

          經(jīng)實際測試,輸入輸出指標均符號系統(tǒng)要求,在硬件電路設計中,由于lvds信號的偏置電壓為1.25v,電壓擺幅只有350mv,傳輸速率≥100mb/s;因此,電路板制作至關(guān)重要,要求至少使用四層板。為使干擾信號以共模方式加到差分線對上(不影響數(shù)據(jù)正確性),要求差分線對間的距離盡可能小。電源方面,fpga芯片上電時要求有大于500ma的驅(qū)動電流,同時,由于多個輸出引腳的電位速度變化,要求每對電源和地引腳都要良好旁路。

          5 結(jié)論

          本文給出了基于fpga高速數(shù)據(jù)采集系統(tǒng)中的輸入輸出接口的實現(xiàn),介紹了高速傳輸系統(tǒng)中rocketio設計以及l(fā)vds接口、lvpecl接口電路結(jié)構(gòu)及連接方式,并在我們設計的高速數(shù)傳系統(tǒng)中得到應用。rocketio傳輸速度可以達到2.5gbaud,lvds總線上的傳輸速率可以達到120mb/s,系統(tǒng)性能穩(wěn)定。




          關(guān)鍵詞:

          評論


          相關(guān)推薦

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

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();