分享:弄了几天ppi协议的经验 点击:5013 | 回复:86



沉睡

    
  • 精华:1帖
  • 求助:0帖
  • 帖子:23帖 | 82回
  • 年度积分:0
  • 历史总积分:208
  • 注册:2004年11月22日
发表于:2005-11-01 14:22:00
楼主
   弄了几天的PPI协议,有点经验与大家分享.
________________________________________________________________________________
西门子PPI通讯协议!看看吧!
S7-200 PLC之PPI协议 
    通过硬件和软件侦听的方法,分析PLC内部固有的PPI通讯协议,然后上位机采用VB编程,遵循PPI通讯协议,读写PLC数据,实现人机操作任务。这种通讯方法,与一般的自由通讯协议相比,省略了PLC的通讯程序编写,只需编写上位机的通讯程序资源

S7-226的编程口物理层为RS-485结构,SIEMENS提供MicroWin软件,采用的是PPI(Point to Point)协议,可以用来传输、调试PLC程序。在现场应用中,当需要PLC与上位机通讯时,较多的使用自定义协议与上位机通讯。在这种通讯方式中,需要编程者首先定义自己的自由通讯格式,在PLC中编写代码,利用中断方式控制通讯端口的数据收发。采用这种方式,PLC编程调试较为烦琐,占用PLC的软件中断和代码资源,而且当PLC的通讯口定义为自由通讯口时,PLC的编程软件无法对PLC进行监控,给PLC程序调试带来不便。
SIEMENS S7-200PLC的编程通讯接口,内部固化的通讯协议为PPI协议,如果上位机遵循PPI协议来读写PLC,就可以省略编写PLC的通讯代码。如何获得PPI协议?可以在PLC的编程软件读写PLC数据时,利用第三个串口侦听PLC的通讯数据,或者利用软件方法,截取已经打开且正在通讯的端口的数据,然后归纳总结,解析出PPI协议的数据读写报文。这样,上位机遵循PPI协议,就可以便利的读写PLC内部的数据,实现上位机的人机操作功能。
软件设计
 系统中测控任务由SIEMENS S7-226PLC完成,PLC采用循环扫描方式工作,当定时时间到时,执行数据采集或PID控制任务,完成现场的信号控制。计算机的监控软件采用VB编制,利用MSComm控件完成串口数据通讯,通讯遵循的协议为PPI协议。
 PPI协议
西门子的PPI(Point to Point)通讯协议采用主从式的通讯方式,一次读写操作的步骤包括:首先上位机发出读写命令,PLC作出接收正确的响应,上位机接到此响应则发出确认申请命令,PLC则完成正确的读写响应,回应给上位机数据。这样收发两次数据,完成一次数据的读写[5]。
其通讯数据报文格式大致有以下几类:
1、读写申请的数据格式如下:
 
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)源地址,指该地址的指针,为地址值乘以8
DA:(Destination Address)目标地址,指该地址的指针,为地址值乘以8
FC:(Function Code)功能码
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。
2、PLC接收到读写命令,校验后正确,返回的数据格式为 E5H
3、确认读写命令的数据格式为:
 
SD SA DA FC FCS ED  
其中SD为起始符,为10H
SA为数据源地址
DA为目的地址
FC为功能码,取5CH
FCS为SA+DA+FC的和的末字节
ED为结束符,取16H
PPI协议的软件编制
 在采用上位机与PLC通讯时,上位机采用VB编程,计算机采用PPI电缆或普通的485串口卡与PLC的编程口连接,通讯系统采用主从结构,上位机遵循PPI协议格式,发出读写申请,PLC返回相应的数据。程序实现如下:
 1、串口初始化程序:
    MSComm1.CommPort = 1
    MSComm1.Settings = "9600,e,8,1"
    MSComm1.InputLen = 0
    MSComm1.RThreshold = 1
MSComm1.InputMode = comInputModeBinary
PPI协议定义串口为以二进制形式收发数据,这样报文的通讯效率比ASCII码高。
2、串口读取数据程序,以读取VB100数据单元为例:
Dim Str_Read(0 To 32) ‘定义发送的数据为字节为元素的数组。
Str_ Read (32) = &H16 ‘相应的数组元素赋值,按照以下格式:
Str_ Read (29) = (100*8) \ 256  ‘地址为指针值,先取高位地址指针
Str_ Read (30) = (100*8) Mod 256 ‘取低位地址指针
Str_ Read (24) = 1     ‘读取的数据长度(Byte的个数)
For I=4 to 30
   Temp_FCS = Temp_FCS + Str_Read(i)
Next I
Str_Read(31)= Temp_FCS Mod 256 ‘计算FCS校验码,其它数组元素赋值省略。
68 1B 1B 68 2 0 6C 32 1 0 0 0 0 0 E 0 0 4 1 12 A 10 2 0 1 0 1 84 0 3 20 8B 16 
PLC返回数据 E5 后,确认读取命令,发送以下数据:
10 2 0 5C 5E 16
然后上位机VB程序接受到以下数据:
68 16 16 68 0 2 8 32 3 0 0 0 0 0 2 0 5 0 0 4 1 FF 4 0 8 22 78 16
首先识别目标地址和源地址,确认是这次申请的返回数据,然后经过校验检查,正确后解析出第26号数据(&H22)即为VB100字节的数据。
 3、串口写入数据程序,以写VB100数据单元为例:
Dim Str_Write(0 To 37) ‘定义发送的数据为字节为元素的数组。
Str_Writ



飞彩流星

  • 精华:0帖
  • 求助:0帖
  • 帖子:2帖 | 10回
  • 年度积分:0
  • 历史总积分:16
  • 注册:2003年11月29日
发表于:2005-11-16 10:22:00
41楼
好帖!很有帮助多谢!

成都一茶

  • 精华:0帖
  • 求助:0帖
  • 帖子:6帖 | 101回
  • 年度积分:0
  • 历史总积分:218
  • 注册:2004年11月10日
发表于:2005-11-16 11:56:00
42楼
好文章,我喜欢,我也做过。

王晟磊

  • 精华:12帖
  • 求助:0帖
  • 帖子:70帖 | 687回
  • 年度积分:0
  • 历史总积分:1173
  • 注册:2004年2月11日
发表于:2005-11-16 20:21:00
43楼
PPI其实是西门子profibus协议的精简版,大家如果想了解更多,可以下载一个profibus的协议看看

llyyttmx

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 4回
  • 年度积分:0
  • 历史总积分:34
  • 注册:2005年11月16日
发表于:2005-11-18 17:21:00
44楼
能否发给资料PPI通讯协议格式和上位机VB程序,我用OMRON程序交换
llyyttzj@163.com

Taoyi

  • 精华:0帖
  • 求助:0帖
  • 帖子:5帖 | 16回
  • 年度积分:0
  • 历史总积分:75
  • 注册:2005年9月25日
发表于:2005-11-19 10:40:00
45楼
我是草脚请多原谅,这样多烦,直接用SIEMENS提供MicroWin软件通信,多方便

xian78600

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 1回
  • 年度积分:0
  • 历史总积分:1
  • 注册:2005年11月26日
发表于:2005-11-26 10:37:00
46楼
xian78600@163.com  多谢!

boyonxiang

  • 精华:1帖
  • 求助:0帖
  • 帖子:24帖 | 923回
  • 年度积分:0
  • 历史总积分:1188
  • 注册:2005年4月09日
发表于:2005-11-28 10:44:00
47楼
你好!请给我也发一封。
boyonxiang@yahoo.com.cn
谢谢!!!

司空见笑

  • 精华:1帖
  • 求助:0帖
  • 帖子:28帖 | 304回
  • 年度积分:0
  • 历史总积分:574
  • 注册:2004年1月04日
发表于:2005-11-28 11:14:00
48楼
扯蛋,抄袭别人的,这个东西网上很早很早之前就有了.在百度里搜一下PPI,就可以找到,一模一样从别人那抄来的,还说自己搞的,真无耻!

司空见笑

  • 精华:1帖
  • 求助:0帖
  • 帖子:28帖 | 304回
  • 年度积分:0
  • 历史总积分:574
  • 注册:2004年1月04日
发表于:2005-11-28 11:18:00
49楼
   还煞有介事的说搞了几天,更扯淡,要是知道怎么搞,一个小时就够了,哪用几天!蒙人都不会!
   

司空见笑

  • 精华:1帖
  • 求助:0帖
  • 帖子:28帖 | 304回
  • 年度积分:0
  • 历史总积分:574
  • 注册:2004年1月04日
发表于:2005-11-28 11:22:00
50楼
   而且原作者分析PPI的时候也没有分析彻底,有一些地方是不对的!
譬如6C与7C并不是简单的读与写,不同情况下不一样的!
   就算抄袭别人,也没有认真测试,错误的东西也照搬过来蒙大家,真可恶!

司空见笑

  • 精华:1帖
  • 求助:0帖
  • 帖子:28帖 | 304回
  • 年度积分:0
  • 历史总积分:574
  • 注册:2004年1月04日
发表于:2005-11-28 11:24:00
51楼
斑竹不加分辨,居然还加精,失职!

司空见笑

  • 精华:1帖
  • 求助:0帖
  • 帖子:28帖 | 304回
  • 年度积分:0
  • 历史总积分:574
  • 注册:2004年1月04日
发表于:2005-11-28 11:34:00
52楼
王晟磊:
    您好!看得出来,您应该是PPI协议比较了解的!
    我一直也有这种感觉,总觉得两者有相似之处!
    我些问题想跟您请教.我的QQ:535279196 

sztaoyanbin

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 141回
  • 年度积分:0
  • 历史总积分:270
  • 注册:2003年12月04日
发表于:2005-11-28 13:26:00
53楼
这中东东也能评“精”,斑主的水平也够“精”的了。
虎宝宝,帮我看看,这里是不是都是SB!

司空见笑

  • 精华:1帖
  • 求助:0帖
  • 帖子:28帖 | 304回
  • 年度积分:0
  • 历史总积分:574
  • 注册:2004年1月04日
发表于:2005-11-28 15:20:00
54楼
原创光荣!

转载有理!

抄袭可耻!

爱工

  • 精华:1帖
  • 求助:0帖
  • 帖子:6帖 | 8回
  • 年度积分:0
  • 历史总积分:71
  • 注册:2005年11月28日
发表于:2005-11-30 17:00:00
55楼
好,不错,你是个好人,有机会咱们好好交流交流。我也是一个工控爱好者,这两天刚好把C200H的VB通信程序高度通过了。不知道你的这个好不好用?

爱工

  • 精华:1帖
  • 求助:0帖
  • 帖子:6帖 | 8回
  • 年度积分:0
  • 历史总积分:71
  • 注册:2005年11月28日
发表于:2005-11-30 17:02:00
56楼
好,不错,你是个好人,有机会咱们好好交流交流。我也是一个工控爱好者,这两天刚好把C200H的VB通信程序高度通过了。不知道你的这个好不好用?

爱工

  • 精华:1帖
  • 求助:0帖
  • 帖子:6帖 | 8回
  • 年度积分:0
  • 历史总积分:71
  • 注册:2005年11月28日
发表于:2005-11-30 20:10:00
57楼
不错

精神食粮

  • 精华:0帖
  • 求助:0帖
  • 帖子:7帖 | 65回
  • 年度积分:0
  • 历史总积分:123
  • 注册:2005年5月03日
发表于:2005-12-14 10:52:00
58楼
看不懂。

司空见笑

  • 精华:1帖
  • 求助:0帖
  • 帖子:28帖 | 304回
  • 年度积分:0
  • 历史总积分:574
  • 注册:2004年1月04日
发表于:2005-12-14 14:39:00
59楼
抄袭别人东西,无耻!

狗不理包子

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 1回
  • 年度积分:0
  • 历史总积分:1
  • 注册:2005年12月18日
发表于:2005-12-18 17:05:00
60楼
高,真高。俺也要一份!谢谢了!

热门招聘
相关主题

官方公众号

智造工程师