自动化网论坛 » PLC技术论坛 » 西门子PPI通讯协议!看看吧! 转到动态网页
--> 本页主题: 西门子PPI通讯协议!看看吧! 加为IE收藏 | 收藏主题 | 上一主题 | 下一主题

mym


级别: 总版主
精华: 41
发帖: 4024
威望: 10025 点
金钱: 15421 Gold
贡献值: 661 点
朋友圈: ifix技术群
在线时间:584(小时)
注册时间:2005-02-02


西门子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_Write (37) = &H16  ‘相应的数组元素赋值,按照以下格式
Str_Write (35) = &H10  ‘要写入的数据值(*************有误)
68 20 20 68 2 0 7C 32 1 0 0 0 0 0 E 0 5 5 1 12 A 10 2 0 1 0 1 84 0 3 20 0 4 0 8 C B9 16
PLC返回数据 E5 后,确认写入命令,发送以下数据:
10 2 0 5C 5E 16
然后上位机VB程序接受到以下数据:
68 12 12 68 0 2 8 32 3 0 0 0 0 0 2 0 1 0 0 5 1 FF 47 16
这是PLC正确接收并写入信息的返回数据。
4、串口接收程序:
在数据接收程序中,利用VB中MSComm控件,一次接收缓冲区中的全部数据,存放到数组形式的暂存单元中,然后分析每个元素的值,得到读写的数据。
Dim RCV_Array() As Byte
Dim Dis_Array As String
Dim RCV_Len As Long
RCV_Array = MSComm1.Input ‘取出串口接收缓冲器的数据。
RCV_Len = UBound(RCV_Array)
ReDim Temp(0 To UBound(RCV_Array))
For i = 0 To RCV_Len
Dis_Array = Dis_Array & Hex(RCV_Array (i)) & " "
Next i
Text1.Text = Dis_Array ‘接收到的数据送显示。
在程序的读写过程中,一次最大可以读写222个字节,目前给出的数据读写为整数格式。

数据类型 Str_ Read(27)   
S 04H   
SM 05H   
I 81H   
Q 82H   
M 83H   
V 84H 
以上程序,是以读写PLC的V变量区为例,利用PPI协议还可以读写S7-200PLC中的各种类型数据,包括I、Q、SM、M、V、T、C、S等数据类型,能够直接读出以上变量中的位、字节、字、双字等,其中读位变量时,是读取该位所在的字节值,然后上位机自动识别出该位的值。按照读写的数据类型,其中Str_ Read(27)的值各不同:
在控制系统中,PLC与上位计算机的通讯,采用了PPI通讯协议,上位机每0.5秒循环读写一次PLC。PLC编程时,将要读取的检测值、输出值等数据,存放在PLC的一个连续的变量区中,当上位机读取PLC的数据时,就可以一次读出这组连续的数据,减少数据的分次频繁读取。当修改设定值等数据时,进行写数据的通讯操作。
________________________________________________________________________________
校验码是从SA至DU做和校验 ,而不是DA至DU
另外,Str_Write (35) = &H10 因改成Str_Write (35) = &H12
通过几天的试验,达到了VB,VW,VD等数据区域的读写.
但是对协议中I,Q,S,M,SM等的数据格式不知道怎么存储
希望有知道PPI协议的帮指点下
另外动动脑筋,我们战在巨人肩膀上,把数据格式转化下不就能实现了吗?
同样我用简单的方法实现了I,Q等数据的通讯,有这方面经验的大侠们交流下
想看我原始VB程序的,多多留言........


本文引用的地址为http://home.51.com/home/vip_showdiarys.php?user=conchchl&go=2&diary_id=10011417

顶端 Posted:2007-12-14 22:35 | [楼 主]
guest



级别: *
精华: *
发帖: *
威望: * 点
金钱: * Gold
贡献值: * 点
在线时间:(小时)
注册时间:*



你好!
        请看看我写的程序,是向VB7990、VB7991、VB7992发送9、9、8(两次间隔两秒),但我不知为什么s7200收不到数据。
      谢谢
等待您的回复……

Private Sub Timer1_Tick(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Timer1.Tick
        Timer1.Interval += 1
        If Timer1.Interval = 1001 Then
            TextBox1.Text = "发送  1"
        End If
        If Timer1.Interval = 1004 Then
            TextBox1.Text += "  2"
        End If
        If Timer1.Interval = 1005 Then
            'System.Threading.Thread.Sleep(2000)
            Try
                'Dim n As Integer = sp.BytesToRead
                Dim buffer(38) As Byte
                sp.ReadTimeout = 500
                sp.Read(buffer, 0, buffer.Length)
                Dim str As String = ""
                For i = 0 To 38
                    If (i + 1) Mod 4 = 0 Then
                        str += Hex(buffer(i))
                        str += Hex(buffer(i)) + ","
                    Else
                        str += Hex(buffer(i))
                        str += Hex(buffer(i)) + " "
                    End If
                Next
                TextBox2.Text = str
            Catch ex As Exception
                TextBox2.Text = ex.Message
            Finally
                sp.Close()
                Timer1.Enabled = False
            End Try
        End If
        If Timer1.Interval = 1001 Or Timer1.Interval = 1004 Then
            Dim temp As VariantType
            Dim aStrB(38) As Byte
            aStrB(0) = &H68
            aStrB(1) = &H21
            aStrB(2) = &H21
            aStrB(3) = &H68
            aStrB(4) = &H2
            aStrB(5) = &H0
            aStrB(6) = &H7C
            aStrB(7) = &H32
            aStrB(8) = &H1
            aStrB(9) = &H0
            aStrB(10) = &H0
            aStrB(11) = &H0
            aStrB(12) = &H0
            aStrB(13) = &H0
            aStrB(14) = &HE
            aStrB(15) = &H0
            aStrB(16) = &H0
            aStrB(17) = &H5
            aStrB(18) = &H1
            aStrB(19) = &H12
            aStrB(20) = &HA
            aStrB(21) = &H10  ''前21项通用
            aStrB(22) = &H2  ''数据长度02
            aStrB(23) = &H0  ''00
            aStrB(24) = &H1  ''01
            aStrB(25) = &H0  ''00
            aStrB(26) = &H1  ''存储器类型01
            aStrB(27) = &H84  ''存储器类型84
            aStrB(28) = &H0  ''存储器偏移量00
            Dim str1 As String = "&H" + Hex(100 * 8 \ 256)
            aStrB(29) = str1  ''存储器偏移量高八位
            Dim str2 As String = "&H" + Hex(100 * 8 Mod 256)
            aStrB(30) = str2  ''存储器偏移量低八位
            aStrB(31) = &H0  ''00
            aStrB(32) = &H4  ''写入的是字节数据04
            aStrB(33) = &H0  ''00
            aStrB(34) = &H8  ''写入数据位数08
            aStrB(35) = &H9  ''写入的值9
            aStrB(36) = &H0  ''00
            For i = 5 To 36
                temp = temp + aStrB(i)
            Next
            Dim at As String = "&H" + Hex(temp Mod 256)
            aStrB(37) = at    ''校验码
            aStrB(38) = &H16  ''结束
            sp.Write(aStrB, 0, aStrB.Length) ''''''''''''''''''''写入VB7900=9


            Dim str3 As String = "&H" + Hex(100 * 8 \ 256)
            aStrB(29) = str3
            Dim str4 As String = "&H" + Hex(100 * 8 Mod 256)
            aStrB(30) = str4
            aStrB(35) = &H9
            For i = 4 To 36
                temp = temp + aStrB(i)
            Next
            Dim at2 As String = "&H" + Hex(temp Mod 256)
            aStrB(37) = at2
            sp.Write(aStrB, 0, aStrB.Length) ''''''''''''''''''''写入VB7991=9

            Dim str5 As String = "&H" + Hex(7992 * 8 \ 256)
            aStrB(29) = str5
            Dim str6 As String = "&H" + Hex(7992 * 8 Mod 256)
            aStrB(30) = str6
            aStrB(35) = &H8
            For i = 4 To 36
                temp = temp + aStrB(i)
            Next
            Dim at3 As String = "&H" + Hex(temp Mod 256)
            aStrB(37) = at3
            sp.Write(aStrB, 0, aStrB.Length) ''''''''''''''''''''写入VB7992=8
        End If
        Try
            Dim rarray(0) As Byte
            sp.Read(rarray, 0, 1)
            If rarray(0) = &HE5 Then
                Dim sval(4) As Byte
                sval(0) = &H10
                sval(1) = &H2
                sval(2) = &H0
                sval(3) = &H5C
                sval(4) = &H5E
                sp.Write(sval, 0, sval.Length)
            End If
        Catch ex As Exception
            MessageBox.Show(ex.Message)
        End Try
    End Sub

顶端 Posted:2008-02-26 10:03 | 1 楼

 自动化网论坛 -> PLC技术论坛
快速发帖 顶端
内容
HTML 代码不可用

使用签名
Wind Code自动转换

字数检查 恢复数据
 认证码:  
按 Ctrl+Enter 直接提交
表情 [更多]


Powered by PHPWind v5.3 Code © 2003-05 PHPWind
This is html template view this page faster