PROFI BUS-DP/MODBUS的網關結構設計
引 言
??? 作為我國第一個工業通信領域現場總線技術國家標準的PROFIBUS現場總線,其應用范圍已經相當廣泛,占有很大的市場份額。在PROFIBUS家族中,PROFIBUS-DP總線的應用最為廣泛。
??? 國內的一些廠商都在開發并相繼推出自己的現場總線系列產品。但是其FCS系列產品在快速接入主流現場總線系統中有一些阻力,所占市場份額比較小,其提供的系統設計方案大多還是在主推DCS系統。為了能夠快速接入主流現場總線,結合國家863課題,中國四聯儀器儀表集團有限公司與本教研室共同研發PROFIBUS-DP/MODBUS網關,以期實現其FCS系列輸入/輸出從站設備快速無縫接入PROFIBUS-DP網絡,并借此來提高其自動化設備的應用范圍。
1 系統的總體設計
??? MODBUS總線采用單主多從、查詢一回應的工作方式,具有結構簡單、可靠性高、受干擾的概率低、傳輸實時性能較好等優點;但是MODBUS總線沒有路由器、網關等網絡互聯設備,網絡規模有限,大型組網能力和網絡處理能力較差。
??? 本系統使采用MODBUS協議的現場設備無縫接入PROFIBUS-DP現場總線系統,以此來提高現場設備選擇的靈活性。這樣做不僅僅擴展了MODBUS網絡和PROFIBUS-DP網絡的互聯性,還大大降低了系統升級和更新換代所需要的費用。
??? 系統總體結構如圖1所示。其關鍵部分是智能網關,它實現了協議之間的相互轉換,無縫鏈接PROFIBUS-DP現場總線系統與MODBUS總線系統,使同一系統內同時存在PROFIBUS-DP總線和MODBUS總線的設備,已經存在和使用的設備不必做任何改變就能夠直接接入PROFIBUS-DP網絡。
??? 其中,微控制器為中國四聯集團開發的主控制器,本智能網關在設計上為其預留了一個用于和主控制器進行通信的通信接口。底層的I/O模塊實現工業現場信號的檢測或控制執行設備的運行。
2 PROFIBUS-DP/MODBUS網關結構設計
??? PROFIBUS-DP/MODBUS嵌入式網關硬件結構如圖2所示。按照功能模塊劃分,網關可以分為電源管理模塊、中央處理器模塊、PROFIBUS-DP從站模塊和RS485通信模塊。
??? 本硬件設計要求串行口速率能夠達到921.6 kbps。基于此要求,硬件平臺選用Philips公司的ARM7TDMI核的微處理器。電源管理模塊負責整套系統的電源供給。系統的穩定運行和電源模塊的穩定性能關系密切,此處設計的電源模塊兼有熱插拔和電壓轉換的功能。PROFIBUS-DP從站模塊的核心功能由協議芯片(VPC3+C)來實現,從站單元的配置和管理則由中央處理器模塊來完成。
?中央處理器模塊除了實現對PROFIBUS-DP從站模塊的配置和管理外,還要完成MODBUS協議的實現以及兩種協議數據交換協議棧的實現。為了提高系統的抗干擾能力,和外界進行通信的部分需要和系統在物理接口上進行電氣隔離,此處的3個通信接口都需要進行隔離。根據通信速度要求的不同,選擇磁耦芯片模塊完成PROFIBUS-DP通信的隔離兼物理層電平轉換功能;用雙通道磁耦隔離芯片來完成另外兩路串行口通信的隔離。這兩款芯片都采用了最新的基于芯片尺寸的變壓器隔離技術的磁耦。和傳統的光耦比較,其轉換速度、瞬態共模抑制能力、功耗、尺寸及成本等方面均有很明顯的優勢。
3 系統的軟件設計
3.1 軟件總體結構設計
??? 一般情況下,現場總線協議之間的轉換器可分為物理層的中繼器、MAC層的網橋及應用層的網關等幾種形式。中繼器方式需要更改底層硬件,網橋方式對應MAC層的協議轉換復雜,而網關的形式則使得原有網段的協議不需做任何改變,實現起來最為簡單。
??? 本系統采用了網關形式,軟件總體流程如圖3所示,主要實現了PROFIBUS-DP協議芯片VPC3+C的驅動程序和MODBUS協議,同時在應用層實現了PROFIBUS-DP總線和MODBUS總線協議數據幀的轉換。MODB-US協議只是定義了消息域的格局和內容的公共格式,具體的物理層及應用層可以由用戶根據需要定義。本網關MODBUS通信部分物理層采用標準的RS485總線,MAC協議是由軟件實現的。
??? CPU通過驅動VPC3+C來實現對PROFIBUS熔一DP通信過程的控制,包括通信接口檢查、正常和發生故障情況下診斷數據的發送及數據交換等過程;通過MODBUS協議實現對下掛的輸入/輸出從站模塊的查詢操作;通過對輸入/輸出模塊的應答幀(或通信超時)進行分析來判斷模塊的狀態以及模塊的通道狀態;根據模塊狀態信息填充PROFIBUS-DP的診斷域的數據,并以此為依據來對網關狀態(正常通信、報告錯誤或警告信息)進行控制。
3.2 網關協議棧設計
??? 網關協議棧為MODBUS輸入/輸出模塊和PROFI-BUS-DP通信的橋梁。協議棧采用分層結構:PROFIBUS-DP通信層、協議映射層和MODDBUs I/O通信層。協議棧結構及報文處理流程如圖4所示。
??? (1)PROFIBUS-DP通信層
??? 負責對VPC3+C通信狀態的監控管理,按照一定的規則將PROFIBUS-DP總線通信收到的數據映射到CPU內部的存儲器,供I/O通信層調用,完成輸出數據的更新;把I/O通信層的輸入數據按照一定的規則映射到CPU內部的寄存器,在適當的時候寫入VPC3+C的輸入數據緩沖區,以完成輸入數據的更新。
(2)協議數據映射層
??? 負責將I/O模塊映射為標準PROFIBUS-DP I/O模塊的工作,包括對下掛的I/O模塊類型和通信接口控制字的檢查;各輸入模塊通道輸入數據在PROFIBUS-DP輸入數據中起始位置及所占長度的管理;PROFIBUS-DP輸出數據向各輸出模塊通道輸出數據上的映射關系管理。
??? (3)MODBUS通信層
??? 負責完成和下掛MODBUS從站I/O模塊的所有通信,包括讀取I/O模塊類型、讀取通道輸出值、設定通道輸出值和參數設置等工作;根據映射層提供的輸出數據映射關系,將PROFIBUS-DP的輸出數據在CPU存儲器里的映射數據更新到輸出模塊的相應通道上;讀取各輸入模塊的通道輸入值,給映射層提供輸入數據資源。
3.3 PROFIBUS-DP總線驅動
??? 此網關PROFIBUS-DP部分采用協議芯片VPC3+C,其內部含有4KB RAM,用戶可根據需要對其進行設置;有兩種微處理器接口,數據/地址總線復用或單獨操作。因為ARM核對外部RAM操作的速度較快,時序不能滿足VPC3+C的操作時序,因此這里不采用數據/地址總線復用的方式,而是用ARM的GPIO口來模擬VPC3+C的操作時序。在這里模擬的是其在Intel模式下內部寄存器的讀寫時序。此驅動主要提供了以下功能:nxp_vpc3_read、nxp_vpc3_write、nxp_vpc3_init、nxp_vpc3_reset、nxp_vpc3_isr。這些函數分別向上層應用提供了讀寫VPC3+C寄存器、對其初始化、復位操作及中斷的處理功能。其中對寄存器的讀寫操作是關鍵部分,函數原型如下:
??? unsigned char nxp_vpc3_read(unsigned int addr);
??? void nxp_vpc3_write(unsigned int addr,unsigned char data);
??? 其中,addr為要讀寫的寄存器地址,data為要寫入的數據。
3.4 MODBUS協議的實現
??? 為增加信號傳輸的距離并提高抗干擾能力,MODB-US物理層采用標準的RS485通信。MODBUS協議實現軟件的流程如圖5所示。
??? 為了提高協議處理報文的效率,并提供良好的擴展性能,定義了函數指針數組,用于MODBUS應用層的數據處理。函數指針數組指針按照模塊類型進行信息處理的導向。
3.5 協議數據的映射處理
??? 此網關的主要任務是完成PROFIBUS-DP的數據和MODB-實現的流程US數據的相互轉換,為了保證數據的實時性采用單緩沖區技術來實現信息的及時更新。所謂“單緩沖區”,即不管是PROFIBUS-DP還是MODBUS中待轉換的數據,只保留當前最新的一幀。考慮到現場通信的數據主要是數據的采集或模擬量的輸出,采用單個緩沖區不僅僅大大降低了對內存的需求,而且可以保證通信的實時性。因為PROFIBUS-DP的正常通信需要組態的軟件和下掛模塊的硬件一致,才能保證系統的可靠運行。因此如何將MODBUS從站模塊合理地映射成PROFIBUS-DP的標準模塊很關鍵。這里根據模塊特點(類型、數字量/模擬量、通道數量等)定義了不同的通信接口控制字(CFG_DAT)。系統上電后,網關通過MODBUS功能碼0x11對下掛從站模塊進行類型及狀態查詢,并根據類型得到對應不同模塊的CFG_DAT。在PROFIBUS-DP進行通信接口配置(CFG_CHK)的過程中檢查下掛模塊的CFG_DAT和對主站硬件組態的模塊對應的CFG_DAT,并根據此來填充診斷數據。如果檢查通過,控制PROFIBUS-DP從站協議芯片進入數據交換狀態;否則主站在進行診斷數據請求(DIAG-REQ)的時候,將診斷數據報告給主站。此網關判斷的診斷信息包括:對應CFG_DAT錯誤的模塊地址、模擬量輸入MODBUS模塊的通道斷線標志。
3.6 關鍵技術研究
??? (1)緩沖區數據映射——保證實時性
??? 網關在對兩種協議的數據進行映射的過程中,采用了一次性內存拷貝技術和單緩沖區技術來盡快完成數據的處理且保證是最新數據,以此來保證數據傳輸在經過網關時的實時性。
??? 一次性內存拷貝技術是指,網關從協議芯片內部讀取到PROFIBUS-DP的輸出數據后,直接將存到的數據填充到MODBUS輸出幀內;從MODBUS輸入模塊得到的數據直接填入到PROFIBUS-DP協議芯片的輸入緩沖區。這樣的方式可減少內存拷貝過程中所耗費的時間。如上所述,網關單緩沖區技術也是為了保證數據是最新采用的。此網關連接的兩種設備的正常數據通信都是周期性的,且周期一般是固定不變的。如果MODBUS數據交換的周期小于PROFIBUS-DP的數據交換周期,則網關的緩存中只有1幀有效數據;如果MODBUS數據交換周期大于PROFIBUS-DP的數據交換周期,若采用鏈表保存PRO-FIBUS-DP的幀數據,則不管緩沖區的大小有多少,肯定導致緩沖區溢出,從而使PROFIBUS-DP的輸出數據不能即時更新到MODBUS從站的通道上進而影響系統的實時性。
??? (2)實時模塊通信檢查——保證可靠性
??? 系統除了在上電之后對下掛的MODBUS模塊進行類型查詢并和PROFIBUS-DP主站組態模塊類型進行比較外,在進入正常數據交換之后,也會對模塊的狀態進行查詢,判斷模塊是否發生錯誤。錯誤標志是在網關和MODB-US從站進行通信過程中根據從站的回應幀來判斷的。在逐個檢查模塊錯誤標志后,如果沒有錯誤標識被置位,繼續正常通信過程;如果發現有錯誤標識被置位,則控制PRO-FIBUS-DP協議芯片離開數據交換狀態,并且填充診斷信息。在此之后,不斷查詢MODBUS模塊類型,直至模塊類型和對PROFIBUS-DP主站組態數據一致為止,再控制PROFIBUS-DP協議芯片進入數據交換狀態。這樣采用實時查詢模塊是否出錯狀態的方式來保證軟件組態數據和硬件類型相一致,防止出現輸入/輸出數據的錯誤。
??? 此網關系統中MODBUS協議是由軟件來實現的,考慮到需要定時器等保證通信的可靠性,為了防止兩種協議通信的相互影響,對PROFIBUS-DP輸出數據的讀取采用查詢的方式而非中斷方式進行。這樣在PROFIBUS-DP的數據到來后不會打斷正在進行的MODBUS通信,尤其是在PROFIBUS-DP通信速率較高的情況下,這種設計的可靠性更加明顯。如果采用中斷的方式,在PRO-FIBUS-DP通信速率超過一定值,其勢必影響網關和MODBUS從站之間的通信(詳見下面性能分析部分),嚴重時會導致MODBUS幀傳輸的不完整性,從而導致網關對MODBUS模塊通信狀態的誤判,進而影響系統的穩定性。
4 網關測試結果
??? 在規定的條件下,對通信次數進行計數,程序的每個掃描周期進行一次MODBUS數據輸入/輸出的更新;PROFIBUS-DP輸入/輸出數據的更新,則是在VPC3+C收到PROFIBUS-DP的輸出數據標志位置位后進行。對這兩種數據更新的次數進行計數,分別為Cmidbus和Cdp在PROFIBUS-DP通信速率(λdp)變化的情況下,實際測試數據如表1所列。
??? 從表中可以看出,λdp=187.5 kbps時,Cdp=Cmodbus,實際上,此時已經出現了PROFIBUS-DP丟包現象。這也解釋了上邊所提到的如果λdp超過一定值,若采用中斷方式處理PROFIBUS-DP的輸出數據,勢必影響正在進行的MODBUS的通信。
5 結 論
??? 將中國四聯集團采用MODBUS協議的輸入/輸出從站設備無縫接入PROFIBUS-DP網絡的智能通信網關的實現方案,有效地拓寬了其應用范圍。在硬件設計上,采用電源管理模塊實現網關的熱插拔功能;采用專用芯片解析PROFIBUS-DP協議;采用磁耦隔離代替傳統的光耦隔離,提高了系統的性能和可靠性。軟件方面,采用單緩沖區設計、一次性內存拷貝技術、實時模塊狀態查詢方式以及合理的中斷應用來保證系統的實時性和可靠性,還對網關的性能進行了測試和簡單計算,給出了保證不丟包所需要滿足的公式。為其他工業通信網關的設計提供了參考。
評論
查看更多