PPI通信協議是一種主從式的通信協議,上位機即PC機為主,PLC為從。通信開始由計算機發起,PLC予以響應。
1)、計算機按通信任務,用一定格式,向PLC發送通信命令。
2)、PLC收到命令后,進行命令校驗,如無誤,則向計算機發送數據E5H或F9H,作出初步應答。
3)、計算機收到初步應答后,再向PLC發送SD DA SA FCFCS ED確認命令。
這里,SD為起始字符,為10H;DA為目的,即PLC地址02H;SA為數據源,即計算機地址00H;FC為功能碼,取5CH;FCS為SA、DA、FC和的256余數,為5EH;末字節ED為結束符,也是16H。如按以上設定的計算機及PLC地址,則發送10、02、00、5C、5E、及16,6個字節的十六進制數據,以確認所發命令。
4)、PLC收到此確認后,執行計算機所發送的通信命令,并向計算機返回相應數據。它的通信過程要往復兩次才完成一次的通信,比較麻煩,但較嚴謹,不易出錯。
SD LE LER SD DA SA FC DASP SSAP DU FCS ED
SD:(Start Delimiter)開始定界符,占1字節,為68H
LE:(Length)報文數據長度,占1字節,標明報文以字節計,從DA到DU的長度;
LER:(Repeated Length)重復數據長度,同LE
SD: (Start Delimiter)開始定界符(68H)
DA:(DestinationAddress)目標地址,占1字節,指PLC在PPI上地址,一臺PLC時,一般為02,多臺PLC時,則各有各的地址;
SA:(Source Address)源地址,占1字節,指計算機在PPI上地址,一般為00;
FC:(Function Code)功能碼,占1字節,6CH一般為讀數據,7CH一般為寫數據
DSAP:(Destination Service Access Point)目的服務存取點,占多個字節
SSAP:(Source Service Access Point)源服務存取點,占多個字節
DU:(Data Unit)數據單元,占多個字節
FCS:(Frame CheckSequence)占1字節,從DA到DU之間的校驗和的256余數;
ED:(End Delimiter)結束分界符,占1字節,為16H
命令類型
1)讀命令 讀命令長度都是33個字節。字節0~21,都是相同的,為:“68 1B 1B 68 02 00 6C 32 01 00 00 00 00 00 0E 00 00 04 01 12 0A 10”。而從字節22開始,將根據讀取數據的軟器件類型及地址的不同而不同。
字節22,表示讀取數據的單位。為01時,1bit;為02時,1字節;為04時,1字;為06時,雙字。
字節23,恒0。
字節24,表示數據個數。01,表示一次讀一個數據。如為讀字節,最多可讀208個字節,即可設為DEH。
字節25,恒0.
字節26,表示軟器件類型。為01時,V存儲器;為00時,其它。
字節27,也表示軟器件類型。為04時,S;為05時,SM;為06時,AI;為07時AQ;為1E時,C;為81時,I;為82時,Q;為83時,M;為84時,V;為1F時,T。
字節28、29及30,軟器件偏移量指針(存儲器地址乘8),如:VB100,存儲器地址為100,偏移量為800,轉換成十六進制就是320H,則字節28到30這三個字節就是00、03、及20.
字節31、32為FCS和ED。
返回數據 與發送命令格式數據相同,但包含一條數據。具體是:
SD LE LER SD DA SA FC DASP SSAP DU FCS ED
SD LE LER SD DA SA FC DASP SSAP DU FCS ED
這里的SD、LE、Ler、SD、SA及FC與命令含義相同。但SD為PLC地址,DA為計算機地址。此外:
字節16:數據塊占用的字節數,即從字節21到校驗和前的字節數。一條數據時:字,為06;雙字,為08;其它為05.
字節22:數據類型,讀字節為04.
字節23、24:讀字節時,為數據個數,單位以位計,1個字節為08;2個字節為10(16進制計),余類推。
字節25及其后至校驗和之前,為返回所讀值。
如讀VB100開始3個字節,其命令碼為:
68 1B 1B 68 02 00 6C 32 01 00 0000 00 00 0E 00 00 04 01 12 0A 10 02 00 03 00 01 84 00 03 20 8D 16(紅色02為字節為單位,03為讀3個字節)
68 1B 1B 68 02 00 6C 3201 00 00 00 00 00 0E 00 00 04 01 12 0A 10 04 00 01 00 01 84 00 0D 08 84 16
返回碼:
68 18 18 68 00 02 08 32 03 00 0000 00 00 02 00 07 00 00 04 01 FF 04 00 18 99 34 568B 16
(這里紅色99、34、56分別為VB100、VB101、VB102的值)
2)寫命令 寫一個字節,命令長為38個字節,字節0~字節21為:
68 20 2068 02 00 6C 32 01 00 00 00 00 00 0E 00 00 04 01 12 0A 10
寫一個字,命令長為39個字節,字節0~字節21為:
68 21 2168 02 00 6C 32 01 00 00 00 00 00 0E 00 00 04 01 12 0A 10
寫一個雙字數據,命令長為41個字節,字節0~21為:
68 23 23 68 02 00 6C 32 01 00 0000 00 00 0E 00 00 04 01 12 0A 10
字節22~字節30,為寫入數據的長、存儲器類型、存儲器類型、存儲器偏移量。這些與讀數據的命令相同。字節32如果是寫入的是位數據,這一字節為03,,其它則為04.
字節34寫入數據的位數:01:1位,08:1字節,10H:1字,20H:1雙字。
字節35~字節40為校驗碼、結束符。
如果寫入的是位、字節數據,字節35就是寫入的值,字節36為00,字節37為校驗碼,字節38為16H、結束碼。如果寫入的是字數據(雙字節),字節35、字節36就是寫入的值,字節37為校驗碼,字節38為16H、結束碼.如果寫入的是雙字數據(4字節),字節35~字節38就是寫入的值,字節39為校驗碼,字節40為16H、結束碼。
如寫入QB0=FF,其命令為:
68 20 20 68 02 00 7C 32 01 00 0000 00 00 0E 00 05 05 01 12 0A 1002 00 01 00 00 82 00 00 0000 04 00 08 FF 86 16
如寫入VB100=12,其命令如下:
68 20 20 68 02 00 7C 32 01 00 0000 00 00 0E 00 05 05 01 12 0A 1002 00 01 00 01 84 00 03 200004 00 08 12 BF16
PLC返回數據 E5 后,確認寫入命令,發送以下數據:
10 02 00 5C 5E 16
PLC返回數據 E5 后,寫入成功。
如寫入VW100=1234,其命令如下:
68 21 21 68 02 00 7C 32 01 00 0000 00 00 0E 00 06 05 01 12 0A 1004 00 01 00 01 84 00 03 20 00 040010 12 34 FE 16
PLC返回數據 E5 后,確認寫入命令,發送以下數據:
10 02 00 5C 5E 16
PLC返回數據 E5 后,寫入成功。
請注意以上紅體字的含義。
以上命令如執行成功,則返回
68 12 12 68 00 02 08 32 03 00 0000 00 00 02 00 01 00 00 05 01 FF 47 16
否則返回:
68 0F 0F 68 00 02 08 32 02 00 0000 00 00 00 00 00 85 00 C3 16
3)STOP命令 stop命令使得S7-200CPU從run狀態轉換到stop狀態(此時cpu模塊上的模式開關應處于run或term位置)。計算機發出如下命令:
68 1D 1D 68 02 00 6C 32 01 00 0000 00 00 10 00 00 29 00 00 00 00 00 09 50 5F 50 52 4F 47 52 41 4D AA 16
PLC返回:E5,同時PLC即轉為stop狀態。
但計算機再發確認報文(10 02 00 5C 5E 16)
PLC將返回:68 10 10 68 00 02 08 32 03 00 00 00 00 00 01 00 00 00 00 29 69 16
到此,才算完成這個通信過程。
4)RUN命令 run命令使得S7-200 cpu從stop狀態轉換到run狀態(此時cpu模塊上的模式開關應處于run或term位置)。PC機發出如下命令:
68 21 21 68 02 00 6C 32 01 00 0000 00 00 14 00 00 28 00 00 00 00 00 00 FD 00 00 09 50 5F 50 52 4F 47 52 41 4DAA 16
PLC返回:E5,同時PLC即轉為RUN狀態。
但計算機再發確認報文(10 02 00 5C 5E 16)
PLC將返回:68 10 10 68 00 02 08 32 03 00 00 00 00 00 01 00 00 00 00 29 69 16
至此,才算完成這個通信過程。
注:以上介紹的不是西門子發布的正式通信協議,還有其它內容。
建議結合些通信的例子來進行測試。
PC與PLC采用主從方式通訊,PC按如下文的格式發讀寫指令,PLC作出接收正確的響應(返回應答數據E5H或F9H見下文分析),上位機接到此響應則發出確認命令(1002 5C 5E 16),PLC再返回給上位機相應數據。一般上位機要連接PLC就要先發送如下尋呼數據10 02 00 49 4B 16 同志們吶!我們可都是有血、有肉、有思想、有靈感的高級動物啊,面對這么多枯燥、無味、復雜、混亂的機器數字你怎么記呢?反正我是記不住。。╚_^開始洗腦)這時你可以閉上眼睛,安靜、靜、再靜。。。。。。想一想戰爭時期的戰地對講機通話模式,那么這個指令(1002 00 49 4B 16)就可以理解為:00呼叫02,聽到請回答。 10起始符 02是上位機要聯系的下位級的地址站號,就是要找的人 00就是上位級本本身自己的站號49尋呼指令 16終止符 其中4B為校驗碼,是這樣得來的:02+00+49的最后兩位就是校驗碼,這就是所說的偶校驗或稱和校驗也稱余校驗,因為取的是余數。計算器在16進制計算時公式(02+00+49)mod100得出的數就是校驗碼,你計算一下是不是等于4B!其他的所有PPI協議校驗都是如此。假如02站號的PLC收到尋呼信號那么會回答: 10 00 02 0002 16 意思是:報告00 ,02收到,請指示 這樣的解釋是不是有意思!你有更好的解釋嗎?接下來呢,找到了要尋呼的人PC就是司令啦就可以發號施令了,發號施令后PLC正確接收后就會發送E5 字符,意思是:“02洞兩明白”。其實啊,說到這里PLC只說他明白,他已經明白了上位機PC的指示,但并沒有執行命令,那么要怎么他才執行命令呢?就是上位機PC發出確認命令后才執行。這時上位機會發出(1002 5C 5E 16),意思是:“請立即執行”。然后PLC就干他應當干的工作了!原來PLC也不容易啊,怪不得叫下位機呢!
說了這么多亂不亂吶!目的就是要理清上下級關系、主從關系,指令的順序,用一個好的記憶方法記住枯燥無味的機器碼。
讀命令分析:一次讀一條數據
SD LE LER SD DA SA FC DASP SSAP DU FCS ED
SD:(Start Delimiter)開始定界符(68H)
LE:(Length)報文數據長度
LER:(Repeated Length)重復數據長度
SD: (Start Delimiter)開始定界符(68H)
SA:(Source Address)目標地址,指該地址的值,就是PLC的地址
DA:(Destination Address)本地地址,指該地址的指針,就是上位機自己的地址
FC:(Function Code)功能碼,5CH為交替周期觸發,6CH為首次信息周期觸發,7CH為交替周期觸發。
DSAP:(Destination Service Access Point)目的服務存取點
SSAP:(Source Service Access Point)源服務存取點
DU:(Data Unit)數據單元
FCS:(Frame Check Sequence)校驗碼
ED:(End Delimiter)結束分界符(16H)
報文數據長度和重復數據長度為自DA至DU的數據長度,校驗碼為DA至DU數據的和校驗,只取其中的末字節值關于這個校驗碼的計算方法同上面說明。
在讀寫PLC的變量數據中,讀數據的功能碼為 6CH,寫數據的功能碼為 7CH。
對于一次讀取一個數據,讀命令都是33個字節。前面的0—21字節是相同的,為