新聞中心

        EEPW首頁 > 手機與無線通信 > 設計應用 > 基于CPCI接口的SpaceWire總線通訊模塊設計

        基于CPCI接口的SpaceWire總線通訊模塊設計

        ——
        作者:彭杰 董文岳 蔣曉華 代威威 時間:2014-05-27 來源:電子產品世界 收藏
        編者按:本文在對SpaceWire總線協議、SpaceWire節點的總體框架進行深入分析的基礎上,設計了支持熱插拔的基于CPCI接口的高速SpaceWire數據總線的節點通訊板卡的硬件系統,重點介紹了支持熱插拔的CPCI接口電源電路分析、FPGA與PCI9056接口模塊時序分析和在Windriver軟件環境下的驅動程序的開發,為SpaceWire上位機底層驅動接口的開發以及今后SpaceWire總線在其它任務中的應用打下了良好的基礎。

          的引腳BD_SEL#是接口中最小的插針之一,BD_SEL#連接LTC1643L的使能引腳,低電平時有效開啟LTC1643L工作并同時給板卡供電。R10是一個0.018歐姆,0.5W,精度為1%的精密電阻,用于過流保護的電壓檢測電阻。當板卡發生故障導致電流超過額定值之后,R10兩端的壓差將增大,SENSE引腳將此過流信息反饋至LTC1643L電源管理器,同時切斷電源供應,起到電源過流保護的功能。

        本文引用地址:http://www.104case.com/article/247468.htm

          4 PCI橋接電路分析

          在總線節點終端系統與航電計算機系統之間實現PCI通訊大致有兩個方式,其一就是采用可編程器件作為一個獨立的模塊實現PCI協議,另一種方式就是采用專用PCI協議芯片。本系統的設計出于性能穩定性和結構簡易性方面的考慮,選擇用PLX公司生產的集成芯片,該芯片可以設置成多種傳輸模式,完成總線節點與航電設備之間的通信橋接功能。

          在與本地FPGA之間的通信分為直接主模式(Direct Master Mode)、直接從模式(Direct Slave Mode)和DMA模式。由于PCI通信要求達到總線網絡的2Mbit/s至400Mbit/s通訊速率(本板卡實現了200Mbit/s),這里采用的芯片時鐘頻率為66MHz,傳輸模式為直接從模式,工作時序如圖3所示,PCI9056為主芯片,FPGA為從芯片。

          為了與PCI9056進行高效的數據通信,FPGA內部劃出了一部分內存以配置成雙口RAM的形式完成PCI9056對SpaceWire數據的收發以及相應控制寄存器的控制傳輸。

          5 Windriver軟件的驅動生產

          通過PLXMON軟件對PCI9056的配置芯片進行配置后,可以利用Windows操作系統中WinDriver自動生成PCI驅動程序,步驟如下:首先啟動WinDriver Wizard,從開始菜單,選擇“程序 | WinDriver | Driver Wizard”;然后在Driver Wizard 菜單, 單擊“File New Project”菜單來新建一個工程,從即插即用列表中選擇顯示卡,通過生產商的名字來選定。單擊“Memory”標簽。該顯示卡的三個內存范圍顯示出來。內存范圍中的BAR2映射的是FPGA內的RAM緩存塊和專用寄存器,根據FPGA內核對這些緩存塊和寄存器的可讀寫定義,可以在BAR2映射的區域里進行讀寫,若寫進去的數值跟讀出來的數值一致,表面接口通信正常。最后一步為生成驅動代碼:單擊“Build | Generate code”菜單, Driver Wizard 將產生操作硬件資源的函數,可以在用戶模式下在應用程序中直接使用這些函數,這個向導還會產生一個樣本程序來使用這些函數操作硬件,上層界面的開發可以直接調用這些API函數。

          6 總結

          本文是珠海歐比特公司為面向我國航天應用研發的一款SpaceWire總線節點終端板卡的一個實際應用設計方案,并根據此方案完成了對每個功能模塊的結構和功能分析,歐比特公司此已經對方案設計申請了專利保護。此方案對今后SpaceWire總線在其它任務中的應用具有重要的借鑒意義。

        dc相關文章:dc是什么


        數字通信相關文章:數字通信原理


        通信相關文章:通信原理



        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 涟水县| 和顺县| 青岛市| 济阳县| 新昌县| 怀宁县| 镇巴县| 霍林郭勒市| 乃东县| 清苑县| 绵竹市| 毕节市| 葵青区| 托克托县| 西畴县| 富顺县| 廉江市| 忻城县| 马山县| 沂水县| 铜陵市| 土默特左旗| 五莲县| 宁晋县| 浪卡子县| 易门县| 郯城县| 二连浩特市| 曲阳县| 青川县| 交口县| 和政县| 东宁县| 益阳市| 满城县| 松溪县| 荔浦县| 应城市| 甘孜县| 长武县| 晋城|