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

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 基于VHDL和發(fā)接復用器的SDH系統(tǒng)設計及FPGA仿真

          基于VHDL和發(fā)接復用器的SDH系統(tǒng)設計及FPGA仿真

          作者: 時間:2010-09-07 來源:網(wǎng)絡 收藏

            針對目前國內(nèi)中還沒有一個專門的E1分接復用芯征,本文介紹一種用高級硬件描述語言及狀態(tài)轉(zhuǎn)移圖完成該發(fā)接的新型方法及其實現(xiàn)。并給出了用Xilinx FoundaTIon tools EDA軟件的電路波形及Spartan XCS30XL完成實現(xiàn)的結(jié)果。

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

            1 數(shù)字分接結(jié)構(gòu)原理

            本數(shù)字分接的功能是:在發(fā)送端把12Mbps經(jīng)過編碼的有幀結(jié)構(gòu)的Ethernet(以太網(wǎng))碼流分接為7路標準E1接口速率數(shù)據(jù)流, 設備再把這7路數(shù)據(jù)映射到155Mbps的速率去通過光纖傳輸?shù)较乱粋€設備;在接收端由SDH設備從155Mbps的數(shù)據(jù)流中取出7路標準E1速率數(shù)據(jù)正確恢復為原來的12Mbps的Ethernet(以太網(wǎng))碼流。

            發(fā)送端12Mbps有幀結(jié)構(gòu)數(shù)據(jù)幀間由全1空閑碼填充。從數(shù)字分接復用器發(fā)送輸出的7路E1數(shù)據(jù)由于傳輸處理過程中路中不同,必然會造成7路E1數(shù)據(jù)在傳輸過中的各路時延不一致,這就使得各路數(shù)據(jù)不同步。在設計中如何在接收端使得7路E1數(shù)據(jù)同步,從而正確恢復原發(fā)送端12Mbps數(shù)據(jù)就成了一個難題。針對這一問題制定出了如下的解決方案。

            1.1 數(shù)字分接器原理框圖及說明

            如圖1所示,把數(shù)字分接器從總體上劃分為:時鐘產(chǎn)生、幀頭/幀尾檢測、串并變換、固定插零、FIFO插入SYNC五個模塊。

            

          數(shù)字分接器原理框圖


            在發(fā)送端,分接器的時鐘產(chǎn)生電路把14Mbps時鐘XCLK轉(zhuǎn)變?yōu)?2Mbps時鐘,用這一時鐘對端口來的12Mbps成幀數(shù)據(jù)DATAIM做幀頭(1100010001)/幀尾(1000000001)檢測,檢測出幀頭后再做串/并變換操作,這樣就初步完成了分接器的功能。但是,為了使數(shù)字復接器能正確復接就需要在分接器輸出的7路數(shù)據(jù)中分別插入同步頭SYNC(0111111110)。為了使數(shù)據(jù)和插入的SYNC區(qū)別開來,須要在7路數(shù)據(jù)中每隔 7bit就固定地插入“0”。這樣,就保證了插入的SYNC不會與正常的掌握相混淆,從而也使得分接出的7路數(shù)據(jù)變?yōu)闃藴实腅1數(shù)據(jù)。

            1.2 數(shù)字復接器原理框圖及說明

            數(shù)字復接器原理框圖如圖2所示。與分接器相呼應,可把復接器從總體上劃分為:SYNC檢測、SYNC扣除、并/串轉(zhuǎn)換、扣除零、幀頭/幀尾檢測5個模塊。

            

            在接收端,復接口的SYNC檢測模塊在7路E1數(shù)據(jù)流中分別檢測出7個SYNC。通過SYNC扣除模塊扣除在分接器中插入的SYNC,并使得7路 E1數(shù)據(jù)同步。之后,就可以對這7路E1數(shù)據(jù)進行并/串轉(zhuǎn)換了。對于轉(zhuǎn)換后的14Mbps數(shù)據(jù)還需要扣除在分接器中固定插入的零。根據(jù)要求對于 12Mbps的數(shù)據(jù)再一次做幀頭/幀尾檢測以便在兩幀數(shù)據(jù)之間插入全“1”的空閑碼。這樣的就正確恢復出發(fā)送端的12Mbps碼流。

            在發(fā)送端和接收端所有SYNC的處理都用FIFO技術(shù)來實現(xiàn)。電路設計采用硬件高級描述語言和狀態(tài)機來完成,用驗證實現(xiàn)。為提高電路的可實現(xiàn)性,設計全部采用D觸發(fā)器和邏輯門來實現(xiàn),并且綜合約束工具來控制FPGA內(nèi)部電路的路徑延時。

            2 語言設計相對于傳統(tǒng)設計的優(yōu)點

            (1)采用自頂向上(Top Down)的設計方法

            與傳統(tǒng)的硬件設計從具體的設計單元開始不同,VHDL設計是從系統(tǒng)的總體要求出發(fā),先進行系統(tǒng)建模,通過后再利用VHDL層次化、結(jié)構(gòu)化及行為化的描述方法將各個模塊模型用可實現(xiàn)的VHDL電路描述替換。這對于一個非常大的硬件系統(tǒng)設計從總體上把握設計的可行性是非常重要的。

            (2)采用系統(tǒng)的早期仿真

            通過對系統(tǒng)建模的早期仿真便于在系統(tǒng)設計的早期發(fā)現(xiàn)設計中潛在的問題,與傳統(tǒng)的自下而上設計的后期仿真相比可大大縮短系統(tǒng)設計的周期。

            (3)降低了硬件電路的設計難度

            不需要象傳統(tǒng)的設計方法在設計前就要寫出電路的邏輯表達式、真值表及卡諾圖化簡,VHDL在設計計數(shù)器的時候只關心計數(shù)器的狀態(tài)就可以了。這樣也大大縮短系統(tǒng)設計的周期。這對于時間效益的現(xiàn)代社會是非常重要的。

            (4)VHDL設計文檔的靈活性

            用VHDL設計硬件電路,主要的設計文件是用VHDL編寫的源程序。如果需要也可以利用EDA軟件轉(zhuǎn)化為原理圖。另外,它資源量小,便于保存,可以方便地被其它設計所利用,可繼承性好,在源文件中可方便地加入注釋,可讀性好。

            3 分接復用器的VHDL及狀態(tài)轉(zhuǎn)移圖設計

            3.1 分接復用器頂層VHDL建模(Top level)及系統(tǒng)功能仿真

            (1)系統(tǒng)發(fā)送頂層建模的VHDL端口描述

            Library IEEE;

            Use IEEE.std_logic_1164.all;--引用庫說明;

            EnTIty TRAN_TOP is

            Port (RESET : IN STD_LOGIC;--ststem reset signal;

            XCLK_IN : IN STD_LOGIC;--14.336MHz input high clock;

            DATAIN : IN STD_LOGIC;--12.544MHz input data;

            CLK12M :OUT STD_LOGIC;--12.544MHz input clock;

            READCLK_OUT:OUT STD_LOGIC;--2.048 MHz output clock;

            ROUT:OUT STD_LOGIC_VECTOR(6 downto 0)-2.048 MHz 7 route -output data;

            );

            end TRAN_TOP;

            (2)系統(tǒng)發(fā)送頂層建模的VHDL仿真波形

            


          上一頁 1 2 下一頁

          評論


          相關推薦

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

          關閉
          看屁屁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); })();