會飛的怪獸
自信 自立 自強(qiáng)
級別: 工控俠客
精華主題: 0
發(fā)帖數(shù)量: 301 個
工控威望: 2110 點
下載積分: 4588 分
在線時間: 667(小時)
注冊時間: 2013-01-17
最后登錄: 2024-12-07
查看會飛的怪獸的 主題 / 回貼
樓主  發(fā)表于: 2013-01-17 12:30
西門子自由口通訊程序(注釋很詳細(xì),有興趣的可以參考一下)
S7-200可編程控制器與微機(jī)通信之設(shè)計和實現(xiàn)
介紹了S7-222 通信方式,著重闡述了自由口通信 參數(shù)設(shè)定、協(xié)議規(guī)劃和通信程序設(shè)計。
  可編程控制器(PLC)作為一種高性能 工業(yè)現(xiàn)場控制裝置,已廣泛地用于工業(yè)控制 各個領(lǐng)域。目前,工業(yè)自動控制對PLC 網(wǎng)絡(luò)通信能力要求越來越高, PLC與上位機(jī)之間、PLC與PLC之間都要能夠進(jìn)行數(shù)據(jù)共享和控制。
  飛剪控制系統(tǒng)要求 遠(yuǎn)離PLC 控制室里,實時監(jiān)控電機(jī)、供紙、刀輥等設(shè)備。上位機(jī)為普通PC機(jī),下位機(jī)為 SIEMENS S7-222 PLC。 實際開發(fā)中,采用自由口通信模式,自定義 PC與 PLC 通信協(xié)議,用Step7編寫PLC端 通信程序,而  PC端用VC6.0實現(xiàn)串行通信的控制和監(jiān)控界面的顯示。
2.通信方式及原理
  S7-200系列PLC通信方式有三種:一種是點對點(PPI)方式,用于與西門子公司 PLC編程器或其它產(chǎn)品通信,其通信協(xié)議是不公開 。另一種為DP方式,這種方式使 PLC可通過Profibus DP通信接口接入現(xiàn)場總線網(wǎng)絡(luò), 擴(kuò)大PLC 使用范圍。最后一種方式是自由口(FreePort)通信方式,由用戶定義通信協(xié)議,實現(xiàn)PLC與外設(shè) 通信。本系統(tǒng)中采用自由口通信方式。它是S7-200系列PLC一個很有特色 功能。這種方式不需要增加投資,具有較好 靈活性,適合小規(guī)模控制系統(tǒng)。自由口通信 物理接口上要求雙方都使用RS485接口,波特率最高為38400bps。雖然PC機(jī) 標(biāo)準(zhǔn)串口為RS232,但西門子公司提供 PC/PPI電纜帶有RS232 /RS485電平轉(zhuǎn)換器,因此在不增加任何硬件 情況下,可以很方便地將PLC和PC機(jī)互聯(lián)。
  2.1自由口模式的初始化
  PLC 自由口模式通信編程首先是對串口初始化。對S7-200PLC 初始化是通過對特殊存儲字節(jié)SMB30(端口0)寫入通信控制字,來設(shè)置通信的波特率、奇偶校驗、停止位和數(shù)據(jù)位數(shù)。顯然,這些設(shè)定必須與上位機(jī)設(shè)定值相一致。另外還可選擇通信模式和主從站模式,各具體存儲位內(nèi)容可參考SIMATIC S7-200系統(tǒng)手冊。
  2.2自由口模式下收發(fā)數(shù)據(jù)
  初始化自由端口通信模式后,就可以進(jìn)行數(shù)據(jù)的收發(fā)。
 。1) 發(fā)送數(shù)據(jù)指令 XMT
  格式:XMT Table,Port。可以用 XMT指令發(fā)送數(shù)據(jù),XMT指令激活發(fā)送緩沖區(qū)(從Table開始 變量存儲區(qū))中的數(shù)據(jù)。數(shù)據(jù)緩沖區(qū) 第一個數(shù)據(jù)指明了要發(fā)送 字節(jié)數(shù),Port指明了用于發(fā)送 端口,緩沖區(qū)最多可以有255個字符。在發(fā)完緩沖區(qū) 最后一個字符時,會產(chǎn)生一個中斷 (對端口 0為中斷事件9)。本例 XMT緩沖區(qū) 格式如表1。其中,狀態(tài)字節(jié)表示PLC是否正確接收了上位機(jī)所傳數(shù)據(jù);上傳數(shù)據(jù)為PLC上傳給PC 數(shù)據(jù),需將9字節(jié) 16進(jìn)制數(shù)編碼為18字節(jié) ASIIC碼,所以字節(jié)數(shù)為18;BCC為上傳數(shù)據(jù) 異或和,同樣將16進(jìn)制數(shù)編碼為ASIIC碼;結(jié)束字符的值為26。
  
表1 發(fā)送緩沖區(qū)

表2 接收緩沖區(qū)
  RCV Table,Port。用 RCV指令接收最多為255個字符的數(shù)據(jù),這些字符存儲 緩沖區(qū)中。在接收到結(jié)束字符時,會產(chǎn)生一個中斷(對端口 0為中斷事件23)。本例的RCV緩沖區(qū) 格式如表2。其中,命令類型表示上位機(jī)讓PLC 執(zhí)行什么操作,如讀或?qū)?目標(biāo)站號是分配給PLC 一個代號;起始地址是PLC要進(jìn)行讀寫的存儲區(qū)的起始地址;讀寫字節(jié)數(shù)是PLC接到命令后,對存儲區(qū)進(jìn)行讀寫的字節(jié)數(shù),本例中最多寫入16字節(jié)、讀出9字節(jié);寫入數(shù)據(jù)是上位機(jī)要寫入PLC的數(shù)據(jù), 讀命令不起作用;BCC是從命令類型開始到寫入數(shù)據(jù)為止的43字節(jié)數(shù)據(jù) 異或和。從目標(biāo)站號到BCC這幾項內(nèi)容,都是把16進(jìn)制數(shù)編碼為ASIIC碼來表示的。
3.自由口通信程序設(shè)計
  通信程序 設(shè)計需遵循一定的規(guī)則,如中斷通信處理程序要短小精悍、要避免XMT與RCV指令同時在一個端口執(zhí)行等。整個PLC通信程序包括主程序、通信初始化子程序、校驗子程序、讀寫數(shù)據(jù)子程序和發(fā)送完成、接收完成中斷服務(wù)程序。
  3.1主程序
  通信主程序是PLC實現(xiàn)接收、發(fā)送功能 主框架。其主要流程為查詢接收是否完成,校驗,再根據(jù)類型執(zhí)行讀、寫等操作。它的用是控制程序的流程,校驗、讀寫等具體工作由相應(yīng)的程序完成。流程如圖1。
  3.2通信初始化程序
  通信初始化子程序設(shè)置自由口通信的關(guān)參數(shù),對接收信息控制寄存器SMB87寫入控制字,定義起始字符、結(jié)束字符和接收超時。設(shè)好自由口模式的些參數(shù)后,還要連接中斷事件和中斷服務(wù)程序,并打開中斷。最后,把接收、發(fā)送緩沖區(qū)寫入初值即可。
  3.3校驗子程序
  每次PLC接收完1幀數(shù)據(jù),就調(diào)用此子程序進(jìn)行校驗。進(jìn)入子程序后,先清除接收完成標(biāo)志位,再計算所接收數(shù)據(jù) 校驗和BCC。如果正確,還要檢驗結(jié)束字符是否為‘G’。不是的話,說明數(shù)據(jù)報文長度不對或傳輸過程中發(fā)生了錯誤,需要向上位機(jī)返回相應(yīng) 出錯信息。流程如圖2。
  
圖1 主程序流程圖

圖2 校驗子程序流程圖
  3.4讀、寫數(shù)據(jù)子程序
  這2個子程序 任務(wù)是把PLC存儲區(qū)中 數(shù)據(jù)發(fā)給上位機(jī)或把上位機(jī)傳來 數(shù)據(jù)寫入PLC存儲區(qū)。二者 流程相似,只是數(shù)據(jù)流向不同。進(jìn)入子程序后,先停止接收,然后完成數(shù)據(jù)傳輸,最后發(fā)送應(yīng)答報文。不同之處就是應(yīng)答報文中的狀態(tài)字節(jié):讀操作時是1、寫操作時是2。
  3.5接收、發(fā)送完成中斷服務(wù)程序
  當(dāng)PLC接收到結(jié)束字符后產(chǎn)生中斷(事件號9)或數(shù)據(jù)發(fā)送結(jié)束后產(chǎn)生中斷(事件號23),這兩個服務(wù)程序被執(zhí)行。接收完,先把接收完標(biāo)志置1,然后再次啟動接收。發(fā)送完,先清除校驗正確標(biāo)志,再把接收緩沖區(qū)中的結(jié)束字符和計算出的接收BCC結(jié)果清零,最后再次啟動接收。
  由于是半雙工通信,因此PLC無論是發(fā)送和接收完數(shù)據(jù)后,都必須將通信口設(shè)置成接收狀態(tài)。否則,PLC就接收不到任何數(shù)據(jù)了。
4.上位機(jī) 通信編程
  上位機(jī)通過RS232口與PLC進(jìn)行通信,Windows環(huán)境串口通信程序利用VC6編寫。VC6編寫串口通信程序通常有MSCOMM控件和通信API兩種方法。二者各有優(yōu)缺點。MSCOMM控件封裝了微機(jī)串口通信的基本功能,使用者只需設(shè)置一些基本參數(shù),就可以 串口收發(fā)數(shù)據(jù)了。這種方法簡單,易于編程人員使用,現(xiàn) 已有很多例子供參考。用通信API編寫串口程序相對復(fù)雜一些。開發(fā)者要直接使用Windows提供 一組API函數(shù)來完成上述控件封裝好 功能。 使用API編程比使用控件更復(fù)雜,但同時也更靈活。通信控件已經(jīng)封裝好 功能是無法改變 ,而使用API就能針對通信協(xié)議編寫效率更高的代碼。
   飛剪控制系統(tǒng)的上位機(jī)程序中,使用通信API編寫了串口讀寫的模塊。接收時,程序要查找起始字符‘g’,以確定1幀數(shù)據(jù) 開始;再根據(jù)下一個狀態(tài)字節(jié)判斷通信的正確性;最后,把長度為23字節(jié) 數(shù)據(jù)幀接收好,并準(zhǔn)備接收下一幀。發(fā)送過程不用判斷數(shù)據(jù)內(nèi)容,執(zhí)行發(fā)送函數(shù)即可。需要注意的是:由于 PLC通信口是半雙工的,所以在PLC向上位機(jī)上傳數(shù)據(jù)時,上位機(jī)要等1幀數(shù)據(jù)接收完畢,再執(zhí)行發(fā)送操作,以避免收發(fā)沖突。
  
圖3 上位機(jī)串口通信流程圖
  本系統(tǒng)取PC機(jī)和PLC各自的特點,實現(xiàn)了對飛剪系統(tǒng) 實時監(jiān)控。 利用PLC(下位機(jī) )的自由口通信協(xié)議和上位機(jī)的VC開發(fā)工具,可以方便地開發(fā)出PC機(jī)和PLC通信應(yīng)用軟件。這種方法節(jié)省投資,對小規(guī)模 系統(tǒng)極具現(xiàn)實意義。系統(tǒng)具有實時性好、速度快、可靠性高、操作方便等優(yōu)點,達(dá)到了預(yù)期 效果。經(jīng)現(xiàn)場調(diào)試及運行表明,該系統(tǒng)適合于飛剪系統(tǒng)的實時監(jiān)控。
[ 此帖被liusenedc在2013-01-17 12:45重新編輯 ]
附件: 自由口通訊.zip (5 K) 下載次數(shù):4055
網(wǎng)站提示: 請不要用迅雷下載附件,容易出錯
本帖最近評分記錄:
  • 下載積分:+1(15039070327)
  • 下載積分:+1(wzb2015) 謝謝樓主的分享!
  • 下載積分:+5(ysz0377) 好人!
  • 下載積分:+2(jxycomliu) 感謝!
  • 熟悉三菱、信捷、臺達(dá)、歐姆龍等多種PLC編程,威綸、三菱、顯控等觸摸屏設(shè)計和自動化系統(tǒng)設(shè)計, 承接各種非標(biāo)自動化設(shè)備的PLC程序開發(fā),長期為客戶提供整套自動化方案,深圳或珠三角地區(qū),歡迎加QQ 908643454
    ludehui
    級別: 論壇先鋒
    精華主題: 0
    發(fā)帖數(shù)量: 154 個
    工控威望: 1360 點
    下載積分: 2646 分
    在線時間: 242(小時)
    注冊時間: 2010-09-05
    最后登錄: 2024-12-24
    查看ludehui的 主題 / 回貼
    1樓  發(fā)表于: 2013-06-06 12:49
    謝謝  學(xué)習(xí)了
    ludehui
    級別: 論壇先鋒
    精華主題: 0
    發(fā)帖數(shù)量: 154 個
    工控威望: 1360 點
    下載積分: 2646 分
    在線時間: 242(小時)
    注冊時間: 2010-09-05
    最后登錄: 2024-12-24
    查看ludehui的 主題 / 回貼
    2樓  發(fā)表于: 2013-06-14 08:12
    不錯的