ModBus通信系統(tǒng)協(xié)議
ModBus通信系統(tǒng)協(xié)議
ModBus網(wǎng)絡(luò)是一個工業(yè)通信系統(tǒng),由帶智能終端的可編程序控制器和計算機通過公用線路或局部專用線路連接而成。其系統(tǒng)結(jié)構(gòu)既包括硬件、亦包括軟件。它可應(yīng)用于各種數(shù)據(jù)采集和過程監(jiān)控。下表1是ModBus的功能碼定義。
表1 ModBus功能碼
功能碼 | 名稱 | 作用 |
01 | 讀取線圈狀態(tài) | 取得一組邏輯線圈的當(dāng)前狀態(tài)(ON/OFF) |
02 | 讀取輸入狀態(tài) | 取得一組開關(guān)輸入的當(dāng)前狀態(tài)(ON/OFF) |
03 | 讀取保持寄存器 | 在一個或多個保持寄存器中取得當(dāng)前的二進制值 |
04 | 讀取輸入寄存器 | 在一個或多個輸入寄存器中取得當(dāng)前的二進制值 |
05 | 強置單線圈 | 強置一個邏輯線圈的通斷狀態(tài) |
06 | 預(yù)置單寄存器 | 把具體二進值裝入一個保持寄存器 |
07 | 讀取異常狀態(tài) | 取得8個內(nèi)部線圈的通斷狀態(tài),這8個線圈的地址由控制器決定,用戶邏輯可以將這些線圈定義,以說明從機狀態(tài),短報文適宜于迅速讀取狀態(tài) |
08 | 回送診斷校驗 | 把診斷校驗報文送從機,以對通信處理進行評鑒 |
09 | 編程(只用于484) | 使主機模擬編程器作用,修改PC從機邏輯 |
10 | 控詢(只用于484) | 可使主機與一臺正在執(zhí)行長程序任務(wù)從機通信,探詢該從機是否已完成其操作任務(wù),僅在含有功能碼9的報文發(fā)送后,本功能碼才發(fā)送 |
11 | 讀取事件計數(shù) | 可使主機發(fā)出單詢問,并隨即判定操作是否成功,尤其是該命令或其他應(yīng)答產(chǎn)生通信錯誤時 |
12 | 讀取通信事件記錄 | 可是主機檢索每臺從機的ModBus事務(wù)處理通信事件記錄。如果某項事務(wù)處理完成,記錄會給出有關(guān)錯誤 |
13 | 編程(184/384 484 584) | 可使主機模擬編程器功能修改PC從機邏輯 |
14 | 探詢(184/384 484 584) | 可使主機與正在執(zhí)行任務(wù)的從機通信,定期控詢該從機是否已完成其程序操作,僅在含有功能13的報文發(fā)送后,本功能碼才得發(fā)送 |
15 | 強置多線圈 | 強置一串連續(xù)邏輯線圈的通斷 |
16 | 預(yù)置多寄存器 | 把具體的二進制值裝入一串連續(xù)的保持寄存器 |
17 | 報告從機標(biāo)識 | 可使主機判斷編址從機的類型及該從機運行指示燈的狀態(tài) |
18 | (884和MICRO 84) | 可使主機模擬編程功能,修改PC狀態(tài)邏輯 |
19 | 重置通信鏈路 | 發(fā)生非可修改錯誤后,是從機復(fù)位于已知狀態(tài),可重置順序字節(jié) |
20 | 讀取通用參數(shù)(584L) | 顯示擴展存儲器文件中的數(shù)據(jù)信息 |
21 | 寫入通用參數(shù)(584L) | 把通用參數(shù)寫入擴展存儲文件,或修改之 |
22~64 | 保留作擴展功能備用 | |
65~72 | 保留以備用戶功能所用 | 留作用戶功能的擴展編碼 |
73~119 | 非法功能 | |
120~127 | 保留 | 留作內(nèi)部作用 |
128~255 | 保留 | 用于異常應(yīng)答 |
ModBus網(wǎng)絡(luò)只是一個主機,所有通信都由他發(fā)出。網(wǎng)絡(luò)可支持247個之多的遠程從屬控制器,但實際所支持的從機數(shù)要由所用通信設(shè)備決定。采用這個系統(tǒng),各PC可以和中心主機交換信息而不影響各PC執(zhí)行本身的控制任務(wù)。表2是ModBus各功能碼對應(yīng)的數(shù)據(jù)類型。
表2 ModBus功能碼與數(shù)據(jù)類型對應(yīng)表
代碼 | 功能 | 數(shù)據(jù)類型 |
01 | 讀 | 位 |
02 | 讀 | 位 |
03 | 讀 | 整型、字符型、狀態(tài)字、浮點型 |
04 | 讀 | 整型、狀態(tài)字、浮點型 |
05 | 寫 | 位 |
06 | 寫 | 整型、字符型、狀態(tài)字、浮點型 |
08 | N/A | 重復(fù)“回路反饋”信息 |
15 | 寫 | 位 |
16 | 寫 | 整型、字符型、狀態(tài)字、浮點型 |
17 | 讀 | 字符型 |
(1)ModBus的傳輸方式
在ModBus系統(tǒng)中有2種傳輸模式可選擇。這2種傳輸模式與從機PC通信的能力是同等的。選擇時應(yīng)視所用ModBus主機而定,每個ModBus系統(tǒng)只能使用一種模式,不允許2種模式混用。一種模式是ASCII(美國信息交換碼),另一種模式是RTU(遠程終端設(shè)備)這兩種模式的定義見表3
表3 ASCII和RTU傳輸模式的特性
特性 | ASCII(7位) | RTU(8位) | |
編碼系統(tǒng) | 十六進制(使用ASCII可打印字符:0~9,A~F) | 二進制 | |
每一個字符的位數(shù) | 開始位 | 1位 | 1位 |
數(shù)據(jù)位(有效位*) | 7位 | 8位 | |
奇偶校驗(任選) | 1位(此位用于奇偶校驗,無校應(yīng)則無該位) | 1位(此位用于奇偶校驗,無校應(yīng)則無該位) | |
停止位 | 1或2位 | 1或2位 | |
錯誤校驗 | LRC(即縱向冗余校驗) | CRC(即循環(huán)冗余校驗) |
ASCII可打印字符便于故障檢測,而且對于用高級語言(如Fortan)編程的主計算機及主PC很適宜。RTU則適用于機器語言編程的計算機和PC主機。
用RTU模式傳輸?shù)臄?shù)據(jù)是8位二進制字符。如欲轉(zhuǎn)換為ASCII模式,則每個RTU字符首先應(yīng)分為高位和低位兩部分,這兩部分各含4位,然后轉(zhuǎn)換成十六進制等量值。用以構(gòu)成報文的ASCII字符都是十六進制字符。ASCII模式使用的字符雖是RTU模式的兩倍,但ASCII數(shù)據(jù)的譯瑪和處理更為容易一些,此外,用RTU模式時報文字符必須以連續(xù)數(shù)據(jù)流的形式傳送,用ASCII模式,字符之間可產(chǎn)生長達1s的間隔,以適應(yīng)速度較快的機器。
表4給出了以RTU方式讀取整數(shù)據(jù)的例子
以RTU方式讀取整數(shù)據(jù)的例子
主機請求 | ||||||
地址 | 功能碼 | 第一個寄存器的高位地址 | 第一個寄存器的低位地址 | 寄存器的數(shù)量的高位 | 寄存器的數(shù)量的底位 | 錯誤校驗 |
01 | 03 | 00 | 38 | 00 | 01 | XX |
從機應(yīng)答 | |||||
地址 | 功能碼 | 字節(jié)數(shù) | 數(shù)據(jù)高字節(jié) | 數(shù)據(jù)低字節(jié) | 錯誤校驗 |
01 | 03 | 2 | 41 | 24 | XX |
十六進制數(shù)4124表示的十進制整數(shù)為16676,錯誤校驗值要根據(jù)傳輸方式而定。 |
(2)ModBus的數(shù)據(jù)校驗方式
CRC-16(循環(huán)冗余錯誤校驗)
CRC-16錯誤校驗程序如下:報文(此處只涉及數(shù)據(jù)位,不指起始位、停止位和任選的奇偶校驗位)被看作是一個連續(xù)的二進制,其最高有效位(MSB)發(fā)送。報文先與X↑16相乘(左移16位),然后看X↑16+X↑15+X↑2+1除,X↑16+X↑15+X↑2+1可以表示為二進制數(shù)11000000000000101。整數(shù)商位忽略不記,16位余數(shù)加入該報文(MSB先發(fā)送),成為2個CRC校驗字節(jié)。余數(shù)中的1全部初始化,以免所有的零成為一條報文被接收。經(jīng)上述處理而含有CRC字節(jié)的報文,若無錯誤,到接收設(shè)備后再被同一多項式(X↑16+X↑15+X↑2+1)除,會得到一個零余數(shù)(接收設(shè)備核驗這個CRC字節(jié),并將其與被傳送的CRC比較)。全部運算以2為模(無進位)。
習(xí)慣于成串發(fā)送數(shù)據(jù)的設(shè)備會送出字符的最右位(LSB有效位)。而在生成CRC情況下,發(fā)送應(yīng)是被除數(shù)的最高有效位MSB。由于在運算中不用進位,為便于操作起見,計算CRC時設(shè)MSB在最右位。生成多項式的位序也必須反過來,以保持一致。多項式的MSB略去不記,因其只對商有影響而不影響余數(shù)。
生成CRC-16校驗字節(jié)的步驟如下:
①裝如一個16位寄存器,所有數(shù)位均為1。
②該16位寄存器的高位字節(jié)與開始8位字節(jié)進行“異或”運算。運算結(jié)果放入這個16位寄存器。
③把這個16寄存器向右移一位。
④若向右(標(biāo)記位)移出的數(shù)位是1,則生成多項式1010000000000001和這個寄存器進行“異或”運算;若向右移出的數(shù)位是0,則返回③。
⑤重復(fù)③和④,直至移出8位。
⑥另外8位與該十六位寄存器進行“異或”運算。
⑦重復(fù)③~⑥,直至該報文所有字節(jié)均與16位寄存器進行“異或”運算,并移位8次。
⑧這個16位寄存器的內(nèi)容即2字節(jié)CRC錯誤校驗,被加到報文的最高有效位。
另外,在某些非ModBus通信協(xié)議中也經(jīng)常使用CRC16作為校驗手段,而且產(chǎn)生了一些CRC16的變種,他們是使用CRC16多項式X↑16+X↑15+X↑2+1,單裝入的16位寄存器為0000;使用CRC16的反序X↑16+X↑14+X↑1+1,裝入寄存器值為0000或FFFFH。
LRC(縱向冗余錯誤校驗)
LRC錯誤校驗用于ASCII模式。這個錯誤校驗是一個8位二進制數(shù),可作為2個ASCII十六進制字節(jié)傳送。把十六進制字符轉(zhuǎn)換成二進制,加上無循環(huán)進位的二進制字符和二進制補碼結(jié)果生成LRC錯誤校驗(參見圖)。這個LRC在接收設(shè)備進行核驗,并與被傳送的LRC進行比較,冒號(:)、回車符號(CR)、換行字符(LF)和置入的其他任何非ASCII十六進制字符在運算時忽略不計。
表5 LRC生成范例--讀取02號從機的前8個線圈
| 二進制 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|