新聞中心

        EEPW首頁 > 手機與無線通信 > 設計應用 > 基于CAN核的四冗余通信板設計與仿真

        基于CAN核的四冗余通信板設計與仿真

        作者: 時間:2010-02-02 來源:網絡 收藏
        隨著電子技術、計算機應用技術和EDA技術的不斷發展,利用FPGA進行數字系統的開發已被廣泛應用于、航天、醫療電子、工業控制等領域,FPGA成為當今硬件的首選方式之一。PC/104是一種專門為嵌入式控制而定義的工業控制總線,以其獨特的堆棧式結構、低功率等優點,得到了廣泛的應用。作為主流的現場總線,工業控制局域網(Controller Area Network)總線抗干擾能力強,易于組網,具有非常廣闊的應用前景。獨特的PC/104總線與總線的結合,進一步拓寬了總線的應用領域。

        1FPGA的CAN核

        采用了Altera公司的Cyclone III系列FPGA EP3C25,開發平臺采用了Altera公司的Quartus II軟件。CAN核的設計以SJA1000功能結構為基礎。

        CAN核的功能框圖如圖1所示。該CAN總線控制器IP核,遵循CANbus 2.0標準,其功能和寄存器操作與SJA1000兼容。IP核采用VHDL編碼,并采用容錯設計,可抑制存儲性器件的數據位翻轉,大大提高了IP核的可靠性。CAN核可在FPGA中實現,也可以實現為ASIC。其中包含3個主要模塊:寄存器組(can_registers),位時序邏輯(can_btl),位流處理器(can_bsp)。


        寄存器組(CAN Register):外部微處理器可以通過地址直接訪問這些寄存器。發送數據時,微處理器將要發送的數據寫入發送緩沖器,置位命令寄存器的發送請求位來啟動發送。接收到數據后,核心控制器將其存在接收緩沖器,并通知位控制器將其取走。同時,CAN寄存器中還有1個64字節的接收FIFO,可以1次存儲至少2個數據幀。

        位時序邏輯(BTL):用來監視CAN總線并處理與CAN總線相關的位時序。在消息的開始處,當位時序邏輯檢測到總線上由隱性位(recessive)到顯性位(dominant)的跳變時,就會將其內部邏輯同步到位流,稱之為硬同步;隨后,在接收消息的過程中,檢測到隱性位到顯性位的跳變時,便會重同步到位流,稱之為軟同步。位時序邏輯還要根據總線定時寄存器0和總線定時寄存器1的值來決定每個位周期采樣點的位置,以補償傳輸延遲和相位漂移所造成的誤差;同時,根據總線定時寄存器1的設置采取相應的采樣模式(單次采樣或3次)對總線上的數據采樣。

        位流處理器(BSP):根據其實現的功能分為3個模塊:數據接收模塊、數據發送模塊和錯誤處理模塊。數據接收模塊將從位時序邏輯送過來的采樣數據去除位填充后送到移位寄存器進行串并轉換,之后對并行數據進行CRC校驗,在消息接收完時發送應答信號,表示接收無誤。最后將接收到的消息的特征碼與驗收屏蔽寄存器的內容進行比較,以決定是否將接收的消息寫入接收FIFO。數據接收模塊將要發送的數據組成幀并進行CRC計算,之后送入移位寄存器進行并串轉換,然后將串行數據編碼(位填充)后送到總線上。錯誤監視模塊根據協議規范中描述的錯誤監視機制檢測系統錯誤,并設置相應的寄存器,通知設備控制器。模塊根據協議描述的12種錯誤監視規則,在適當情況下對計數器進行加、減或清除。控制器根據這兩個計數器的值以及錯誤限制寄存器的值來決定自己的故障狀態:錯誤激活(Error Active),錯誤認可(Error Passire)或總線關閉(Bus off On)。

        2硬件電路設計

        根據系統的總體設計方案,因為現有的CAN總線收發器最大的工作頻率為1 MHz,在提高CAN的速度后,現有的CAN總線收發器就不能滿足需要了,因此改用RS485收發器。由于RS485收發器是差分傳輸,不能完成卡的自發自收功能,因此需要外置的CAN Hub。另外,要進行光纖傳輸,要完成光的邏輯總線結構,也需要外置Hub。因此,本硬件設計分為CAN通信板的設計和CAN Hub的設計兩部分。

        上一頁 1 2 3 下一頁

        關鍵詞: 仿真 設計 通信 CAN 基于

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 桂东县| 理塘县| 天水市| 武清区| 察隅县| 中牟县| 桃园市| 芦溪县| 澳门| 姜堰市| 彝良县| 罗源县| 城口县| 天津市| 凤山县| 通江县| 江陵县| 安远县| 邹平县| 白城市| 霍州市| 西和县| 荔浦县| 周宁县| 合山市| 霍邱县| 乌海市| 绵竹市| 枣强县| 石阡县| 肃宁县| 光山县| 仁布县| 平定县| 封丘县| 西乌珠穆沁旗| 汽车| 东平县| 盐城市| 墨脱县| 仁寿县|