新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > SDH中E1接口分接復用器VHDL設計及FPGA實現

        SDH中E1接口分接復用器VHDL設計及FPGA實現

        作者: 時間:2012-03-17 來源:網絡 收藏

        3 分接復用器的VHDL及狀態轉移圖設計

        3.1 分接復用器頂層VHDL建模Top level及系統功能仿真
        1 系統發送頂層建模的VHDL端口描述
        Library IEEE
        Use IEEE.STd_LOGIC_1164.all
        --引用庫說明;
        EnTIty TRAN_TOP is
        Port RESET IN STD_LOGIC
        --system 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.048MHz
        Output clock
        ROUT OUT STD_LOGIC_VECTOR 6 downto 0
        --2.048MHz7route
        --output data ;
        end TRAN_TOP 
        2 系統發送頂層建模的VHDL仿真波形
        如圖3所示,

        送來的10M二進制的一幀數據DATAIN為"1100010001幀頭1111111111 11111111111111111111111111111000000001幀尾"。把它分接為7路2M的數據如下:
        ROUT0 00111111110插入的SYNC10111110每7bit固定插入'0'10111... 空閑碼
        ROUT1 00111111110插入的SYNC10111110每7bit固定插入'0'10111... 空閑碼
        ROUT2 00111111110插入的SYNC01111110每7bit固定插入'0'10111... 空閑碼
        ROUT3 00111111110插入的SYNC01111110每7bit固定插入'0'10111... 空閑碼
        ROUT4 00111111110插入的SYNC01111110每7bit固定插入'0'00111... 空閑碼
        ROUT5 00111111110插入的SYNC11111110每7bit固定插入'0'01111... 空閑碼
        ROUT6 00111111110插入的SYNC01111110每7bit固定插入'0'0 1111... 空閑碼
        這樣,從仿真波形可知電路完成了每幀二進制10M數據分接為7路2M數據時在每路2M數據中插入SYNC 0111111110、每7bit固定插入'0'以及在10M數據每幀分接完后插入全1空閑碼的操作。
        3 系統接收頂層建模的VHDL端口描述
        Library IEEE
        UseIEEE.std_logic_1164.all --引用庫說明;
        Entity RCV_TOP is
        port (RESET IN STD_LOGIC

        --system reset signal
        XCLK IN STD_LOGIC
        --14.336MHz input high clock
        CLKIN  IN STD_LOGIC_VECTOR 6
        DOWNTO 0 
        --2.048MHz 7 rout input clock
        DATAIN IN STD_LOGIC_ VECTOR6
        DOWNTO 0 
        -- 2.048MHz 7 rout input data
        CLK_OUT OUT STD_LOGIC
        --12.544MHz output clock
        DATAOUT OUT STD_LOGIC
        --12.544MHz output data

        end RCV_TOP
        4 系統接收頂層建模的VHDL仿真波形
        如圖4所示

        7路包含有SYNC0111111110及每7bit插入'0'的兩幀2M數據通過接收系統被正確地 復接為10M數據。HEAD_FLAG和END_FLAG分別為復接幀數據的幀頭幀尾指示信號。
        這里的7路仿真數據相互之間的延遲不同,其中第DATAIN0延遲最大8bit,通過系統仿真可以證明7路2M數據間的延遲差最大可到125bit,遠遠超過技術要求的1~6bit。這樣,從系統上確保了設計的可行性。

        3.2 狀態轉移圖設計方法

        為去除毛刺,本設計中的計數器全部采用格雷碼計數器。因為格雷碼計數器從前一個狀態到后一個狀態的變化同時只有一位矢量發生狀態反轉如:對于一個8位計數器它的計數狀態變化是:000→001→011→010→110→111→101→100,故對它譯碼時可以防止競爭冒險現象,從而消除了電路在譯碼時可能產生的毛刺。對于有大量狀態轉移的電路,采用狀態轉換圖輸入法方便、直觀;在FOUNDATION工具中,狀態圖輸入又可以轉化為VHDL語言,這又大大提高了電路設計的靈活性。

        4 功能仿真、后仿真和實現

        本設計采用自頂向下(top-down)的設計方法。但為確保設計的可行性,對于每一個子模塊都進行了功能仿真和后仿真。用foundation 工具做功能仿真時,電路中沒有器件延時和線延遲,只能從電路的功能上驗證設計的正確性;而后仿真能模擬實際電路中的器件延時和線延時,從而能進一步驗證設計在實際工作中的正確性。最后本設計在上(Xilinx Spartan XCS30TQ144)實現,其工作頻率可達到20MHz,并在SDH系統的光纖環網上通過了測試。

        5 驗證及問題討論
        (1)FPGA驗證時的7路2M數據間的延遲差
        為了驗證7路數據在傳輸中有不同延時,分接復用器依然能正常工作,就需要模擬出7路不同的延時來。有三種不同的實現方法來完成:
        ·這7路不同的延時可以在FPGA內部用不同的非門串起來實現;
        ·可以采用74系列器件在FPGA外部完成不同延時的模擬;
        ·在FPGA內部用不同級數的D觸發器來模擬7路不同的延時。
        在本設計中采用的是第三種。該方法的好處是易于控制不同路的延時,只要改變不同路中D觸發器的級數就可以改變7路不同的延時。
        (2)為提高分接復用器的傳輸效率,可采用不固定插"0"法,例如HDLC中的插"0"法。
        (3)可以通過在綜合時進一步加約束來提高分接復用器的工作頻率。

        本文中的分接復用器為系統通信提供了靈活的速率選擇,可根據不同需要,以2Mbps為基數來配置各種數據速率。本設計中采用VHDL輸入法及狀態圖輸入法,大大縮短了設計周期,提高了設計的可靠性,并且大大增加了設計的可移植性。該設計的成功表明硬件描述高級語言VHDL是硬件設計的一種十分有效的手段。


        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 宁河县| 栾川县| 碌曲县| 化德县| 新田县| 那曲县| 北海市| 石林| 肥西县| 旺苍县| 甘谷县| 清水河县| 嵊泗县| 浏阳市| 贵溪市| 河池市| 揭西县| 武平县| 吉林省| 麻阳| 禄丰县| 孝昌县| 阳信县| 平泉县| 仁怀市| 铜梁县| 宜黄县| 侯马市| 金川县| 漳州市| 加查县| 确山县| 施秉县| 潜山县| 黎城县| 天门市| 普宁市| 宜宾市| 遵义市| 丽江市| 永寿县|