引 言
DevICeNet是一種基于CAN總線技術的符合全球工業(yè)標準的開放型現(xiàn)場總線通信網(wǎng)絡,它用于控制,配置和數(shù)據(jù)采集等方面。CAN 總線具有布線簡單、典型的總線型結構、穩(wěn)定可靠、實時、抗干擾能力強、傳輸距離遠、布線成本低等特點。由于具備了這些特點,Devi-ceNet總線被廣泛應用于工業(yè)自動化控制,它不僅可以接入更多,更復雜的設備,還可以為上層提供更多的信息和服務。在很多歐美國家,越來越多的系統(tǒng)方案設計采用DeviceNet來實現(xiàn)。
ModBus協(xié)議是應用于電子控制器上的一種通用語言,是全球第一個真正用于工業(yè)現(xiàn)場的總線協(xié)議,由于該協(xié)議的產生,使控制器之間、控制器經(jīng)由網(wǎng)絡和其他設備之間實現(xiàn)相互通信。ModBus協(xié)議現(xiàn)在已經(jīng)成為一種通用的工業(yè)標準,應用該協(xié)議技術可以使不同廠商生產的控制設備連成一個工業(yè)網(wǎng)絡,進行集中監(jiān)控管理。此協(xié)議定義了一個控制器能認識使用的消息結構體,從而使用戶不需要關心它們使用哪種網(wǎng)絡進行通信。它描述了一個控制器請求訪問其他設備的過程,如何回應來自其他設備的請求,以及怎樣偵測錯誤并記錄。它制定了消息域格局和內容的公共格式。
本文主要解決DeviceNet 與ModBus 之間的協(xié)議轉換問題。標準的ModBus口是使用RS-232C兼容串行接口,它定義了連接口的針腳、電纜、信號位、傳輸波特率、奇偶校驗。控制器能直接或經(jīng)由Modem 組網(wǎng)。基于DeviceNet 的嵌入式I/O 模塊通過I/O 口發(fā)送和接收數(shù)據(jù),ModBus通過串口與嵌入式I/O模塊進行通信。通過此過程完成DeviceNet與ModBus之間的協(xié)議轉換問題。
1 嵌入式I/O模塊的設計與實現(xiàn)
DeviceNet是一種上層的應用層協(xié)議,其物理層和數(shù)據(jù)鏈路層采用CAN總線技術,ModBus協(xié)議只是用于數(shù)據(jù)鏈路層上的協(xié)議[1].這兩種現(xiàn)場總線是異構的,因此要實現(xiàn)兩種協(xié)議之間的通信,必須要進行協(xié)議轉換。協(xié)議轉換的轉換過程是分層次進行的。首先把總線設備發(fā)送過來的設備逐層解包,得到需要的數(shù)據(jù),然后再把數(shù)據(jù)按另一協(xié)議所需的方式打包,發(fā)送到相應的設備上。
DeviceNet與ModBus協(xié)議都采用主從通信模式,所以它們之間的通信只能是單向的,主站發(fā)送命令報文而從站被動接收命令報文。本設計中的嵌入式I/O模塊既是De-viceNet從站,又是ModBus的主站。通過該模塊可以實現(xiàn)DeviceNet主站的數(shù)據(jù)與ModBus從站的數(shù)據(jù)進行傳輸。
嵌入式I/O模塊的功能是把DeviceNet格式的報文轉換為ModBus的報文命令,再傳給底層的ModBus設備,設備在接收到ModBus命令之后,會向報文轉換模塊發(fā)送ModBus格式的響應報文,最后經(jīng)協(xié)議轉換模塊將報文轉換為DeviceNet格式的報文傳輸給DeviceNet主站。本嵌入式I/O模塊既是DeviceNet的從站實現(xiàn)接收主站報文并做出響應的功能,同時又可以作為ModBus的主站向其他ModBus設備發(fā)送報文并接收響應報文。
本設計采用的處理器為LPC2129,硬件結構如圖1所示。它是NXP 公司的32 位工業(yè)級ARM7 處理器,其內部集成了兩個CAN 控制器,在一片處理器內首先將主站端的DeviceNet協(xié)議數(shù)據(jù)轉換成中間協(xié)議數(shù)據(jù),之后轉換成ModBus可以識別的協(xié)議數(shù)據(jù)。
撥碼開關用來設置DeviceNet 端的波特率及MAC地址,其中波特率的開關為3 位,分別代表125 Kb/s,250 Kb/s,500 Kb/s;MAC地址的開關為6位,地址為0~63.
RS 232 既可作為程序下載接口,也可作為通用的RS 232串口實現(xiàn)與上位機的通信。系統(tǒng)的供電電源采用24 V的直流供電,并在內部將24 V電源轉化為模塊需要的5 V,3.3 V及1.8 V電壓電源。
2 DeviceNet 和ModBus 協(xié)議介紹
2.1 DeviceNet協(xié)議規(guī)范
DeviceNetTM規(guī)范由Rockwell 公司開發(fā),并將其作為一個基于CAN協(xié)議的開放式現(xiàn)場總線標準而公布。與其他現(xiàn)場總線相比,它具有突出的高可靠性、實時性和靈活性。其主要技術特點可歸納為:
(1)采用CAN物理層和數(shù)據(jù)鏈路層規(guī)約,使用CAN規(guī)約芯片,從而有強大的支持。
(2)可以容納64個節(jié)點地址,每個節(jié)點支持無限個的I/O口;
(3)網(wǎng)絡拓撲結構,節(jié)點設備配電方式靈活,可網(wǎng)絡統(tǒng)一配電或自行供電;
(4)網(wǎng)絡速度可選125 Kb/s,250 Kb/s 和500 Kb/s;有誤接線保護功能;
(5)數(shù)據(jù)傳送方式多樣,支持選通、輪詢、循環(huán)、狀態(tài)變化等方式;
(6)采用逐位仲裁機制實現(xiàn)按優(yōu)先級發(fā)送信息;
(7)支持輪詢或狀態(tài)改變(基于事件),多主站和主從,支持從設備的即用即拔,無需網(wǎng)絡斷電。
DeviceNet是面向連接服務的網(wǎng)絡,任意兩個節(jié)點的通信必須建立在邏輯連接的基礎上。建立連接時與連接相關的傳送會分配一個11位連接標識符(Connec-tion ID,CID),連接標識符由設備媒體訪問控制標識符(MAC ID)和信息標識符(Message ID)兩部分組成。連接建立后設備可通過發(fā)送釋放連接或刪除連接請求服務來斷開連接。在某個特定的連接上長時間沒有進行通信,這個通信將自動斷開以釋放資源。其中,MAC ID可通過硬件設定,也可通過軟件來配置。標識符分為四組,如圖2所示。DeviceNet連接分為顯式信息連接和I/O連接。
2.2 DeviceNet與CAN
DeviceNet總線協(xié)議是基于CAN總線技術的。它的數(shù)據(jù)鏈路層完全遵循CAN 規(guī)范的定義,并通過CAN 控制器芯片實現(xiàn)。它只使用CAN 2.0A 中的定義,不支持CAN 2.0B中的擴展報文格式。DeviceNet只用125 Kb/s,250 Kb/s,500 Kb/s 三種可選速率,達不到CAN 的最高通信速率1 Mb/s.DeviceNet 只使用數(shù)據(jù)幀,錯誤幀和超載幀三種幀表示和控制,并未使用CAN 中定義的遠程幀。
DeviceNet 在CAN 總線的基礎上又增加了面向對象、基于連接的現(xiàn)代通信技術理念,并開發(fā)了應用層。
其應用層規(guī)定了CAN 數(shù)據(jù)幀的使用方法、重復節(jié)點地址檢測機制、對象模型及設備的標準化。使DeviceNet的應用更廣泛,安全性更好。
2.3 ModBus協(xié)議介紹
ModBus 是一種應用于工業(yè)控制器的網(wǎng)絡通信協(xié)議,它是由MoDICon 公司開發(fā)的,主要應用于電子控制器方面,現(xiàn)已成為一種通用工業(yè)標準。該協(xié)議支持傳統(tǒng)的RS 232,RS 422,RS 485和以太網(wǎng)設備。它定義了一個控制器能認識使用的消息結構,使用者不需要關心它們內部的網(wǎng)絡通信方式。控制器與控制器,控制器與其他設備之間(通過網(wǎng)絡)的通信都要通過ModBus協(xié)議來實現(xiàn)。ModBus 協(xié)議制定了消息域格局和內容的公共格式,并詳細描述了一個控制器請求訪問其他設備的過程以及如何回應其他設備的請求,以及偵測錯誤并記錄的過程。當使用ModBus網(wǎng)絡進行通信時,按照此協(xié)議的規(guī)定,每個控制器需要知道它們的設備地址,并能識別按地址發(fā)來的消息,根據(jù)這些信息決定要產生的動作。
ModBus協(xié)議的消息也能在其他網(wǎng)絡上進行傳輸,只需要將消息轉換為適用于其他網(wǎng)絡上使用的幀或包結構即可。
ModBus分為兩種傳輸模式,ASCII和RTU模式。本文采用RTU模式進行說明。控制器使用主/從技術進行通信,能直接或經(jīng)由調制解調器(Modem)組網(wǎng)。網(wǎng)絡上的每個從站必須有惟一的地址。地址范圍為1~247.
從站地址用于尋址從站設備。ModBus通信由主節(jié)點發(fā)起,即僅主設備能發(fā)起數(shù)據(jù)傳輸(即查詢),從設備根據(jù)主設備查詢提供的數(shù)據(jù)做出回應信息或響應動作。主設備以單播或廣播模式與從設備通信。在單播模式下,從設備返回消息作為回應,在廣播模式下,不作任何回應(地址0作為廣播地址)。ModBus協(xié)議建立了主設備查詢的格式:設備(或廣播)地址、功能代碼、所有要發(fā)送的數(shù)據(jù)、錯誤檢測域,具體的ModBus 協(xié)議通信過程如圖3所示。
從設備回應消息也由ModBus協(xié)議構成,包括確認要行動的域、要返回的數(shù)據(jù)、和錯誤檢測域。如果在消息接收過程中發(fā)生錯誤,或從設備不能執(zhí)行其命令,從設備將建立錯誤消息并把它作為回應發(fā)送出去。
對于ModBus通信協(xié)議,信息傳輸為異步方式,以字節(jié)為單位傳送。報文的信息幀格式分為獨立的信息頭和發(fā)送的編碼數(shù)據(jù)兩部分,其報文結構如圖4所示,下面分別介紹。
地址碼為通信傳送的第一個字節(jié)。每個從機都有具有惟一的地址碼,響應回送以各自的地址碼開始。主機發(fā)送的地址碼表明將發(fā)送到的從機地址,而從機發(fā)送的地址碼表明回送的從機地址。
功能碼為通信傳送的第二個字節(jié)。ModBus通信規(guī)約定義功能號為1~127.作為主機請求發(fā)送,通過功能碼告訴從機執(zhí)行什么動作。作為從機響應,從機發(fā)送的功能碼與從主機發(fā)送來的功能碼一樣,并表明從機已響應主機進行操作。
數(shù)據(jù)區(qū)是根據(jù)不同的功能碼而不同。數(shù)據(jù)區(qū)可以是實際數(shù)值、設置點、主機發(fā)送給從機或從機發(fā)送給主機的地址。CRC碼為字節(jié)的錯誤檢測碼。
當通信命令發(fā)送給