西门子博途: MODBUSPN说明

描述

MODBUSPN 说明

说明

该 MODBUSPN 指令允许在带有集成 PN 接口的 CPU 和支持 Modbus/TCP 协议的伙伴之间进行通信。支持功能代码 1、2、3、4、5、6、15 和 16。根据参数分配,该指令可用作客户端(S7 为客户端),也可用作服务器(S7 为服务器)。使用 MODBUSPN 指令在通信伙伴之间建立连接以传送数据并控制连接终止。

数据传输期间执行以下操作:

发送时,生成 MODBUS 特定的消息帧报头

接收时,检查 MODBUS 特定的消息帧报头

检查由客户端寻址的数据区是否存在

发生错误时,生成异常消息帧(仅限 S7 为服务器时)

与组态的数据块进行数据传输

还将对建立连接、终止连接以及数据接收所使用的时间进行监视。

“MODBUSPN”指令 V2.0 可用于 S7-300 及 S7-400。通过本地 CPU 接口进行连接。使用该指令时,无需其它任何硬件模块。

指令的工作原理

初始化

在“Init”输入中有上升沿时初始化指令 MODBUSPN。  

必须根据设备组态分配初始化参数。 

初始化参数将应用于背景 DB。

启动过程中不会评估运行时参数。

将检查参数数据块中数据的有效性。

如果在 Init 参数中检测到上升沿,则执行上述操作。如果检查完成后没有错误,则重置 Init,Init_Error 和 Init_Status 显示 0。

如果在检查期间出现错误,则会显示在输出 Init_Error 和 Init_Status 中。只要存在 Init 错误,就不能通过此块进行 Modbus/TCP 通信。必须首先更正 Init 错误。

循环模式

循环模式下,将在 OB1 或循环中断 OB 中调用 MODBUSPN。

将根据运行时参数激活块功能。

处理作业期间不会评估运行时参数的更改。

只要未执行初始化,就不会评估初始化参数。

处理连接

Modbus客户端主动建立连接。从参数数据块中的连接参数读取所需数据。

连接参数块中的参数 (active_est) 指定 PN CPU 将作为主动通信伙伴还是被动通信伙伴。

对于两种连接类型(主动和被动),在运行时均会通过 TCON 指令打开一个到链接伙伴的通信通道。

通过参数数据块中的 connect_at_startup 参数指定连接建立的时间。

通过 MODBUSPN 指令中的 DISCONNECT 参数终止连接。

“S7 为客户端”的作业初始化或“S7 为服务器”的指令激活

输出参数为动态显示,因此未决状态仅持续 1 个 CPU 周期。也就是说,必须将其复制到其它存储区,才能进一步处理或在监视表中显示。

S7 为客户端:作业初始化

作业通过触发输入 ENQ_ENR 的上升沿变化激活。根据输入参数 UNIT、DATA_TYPE、START_ADDRESS、LENGTH 和 WRITE_READ,会生成 MODBUS 请求帧,并通过 TCP/IP 连接发送到伙伴站。客户端等待服务器响应的组态时间 RECV_TIMEOUT。

如果发生超时(服务器没有响应),则激活的作业将正常结束。可启动新作业。

接收到响应消息后将执行有效性检查。如果检查成功,将执行所需动作,且作业成功执行未出现错误;输出 DONE_NDR 置位。如果在检查期间检测到错误,则作业正常结束,置位位 ERROR,并在 STATUS 中显示错误编号。

S7 为服务器:指令激活

指令已准备好在触发输入 ENQ_ENR 的上升沿接收来自客户端的请求消息。在这种情况下,服务器处于被动状态,并等待来自客户端的消息帧。将检查接收到的消息帧。如果检查成功,则对请求消息做出应答。DONE_NDR 位置位时,即通知用户消息通信已完成。此时,已执行的函数会显示在输出 UNIT、DATA_TYPE、START_ADDRESS、LENGTH 和 WRITE_READ 中。

错误的请求消息或导致错误消息。置位位 ERROR,在 STATUS 中显示错误编号,并且不处理客户端的请求。将根据错误情况向客户端发送异常消息帧。

参数

下表列出了指令“MODBUSPN”的参数:

参数 声明 数据类型 说明 取值范围 Init
id Input WORD 连接 ID 必须与参数 DB 中相关的 id 参数相同。 1 到 4095
W#16#1 到 W#16#FFF
db_param Input BLOCK_DB 参数 DB 的编号,包含此 Modbus 块实例的所有连接和 Modbus 数据 取决于 CPU
REG_KEY_DB Input BLOCK_DB 具有可用于授权的注册表项的数据块 取决于 CPU
RECV_TIMEOUT Input TIME 链接伙伴接收数据的监视时间
可以设置的最短时间为 20 ms。
T#20ms 到 T#+24d20h31m23s647ms
CONN_TIMEOUT Input TIME 建立或终止连接的监视时间
可以设置的最短时间为 100 ms。
T#100ms 到 T#+24d20h31m23s647ms
DISCONNECT Input BOOL 通过该参数,可以控制与 Modbus服务器建立和终止连接:
S7 为客户端:
TRUE:接收到响应消息后将立即建立连接。
S7 为服务器:
TRUE:如果 ENQ_ENR = FALSE,连接将终止。
TRUE
FALSE
ENQ_ENR Input BOOL S7 为客户端:
在上升沿启动作业
在服务器作出响应或输出错误消息之前,对输入参数所做的更改不会生效。
如果在 Modbus 请求期间再次设置了参数 ENQ_ENR,此后将不会进行任何其它传输。
S7 为服务器:
准备接收 TRUE 信号
TRUE
FALSE
LICENSED Output BOOL 块的授权状态
块已授权
块未授权

TRUE
FALSE
CONN_ESTABLISHED Output BOOL 与链接伙伴的连接已建立
与链接伙伴的连接已终止
TRUE
FALSE
BUSY Output BOOL 编辑 T 函数(TCON、TDISCON、TSEND 或 TRCV)的状态
T 函数正在进行中
T 函数未在进行中

TRUE
FALSE
DONE_NDR Output BOOL S7 为客户端:
TRUE:激活作业完成,且未出现错误。
S7 为服务器:
TRUE:已执行来自客户端的请求且已发送响应
TRUE
FALSE
ERROR Output BOOL FALSE:无错误
TRUE:出错。出错原因由 STATUS 参数指示。
FALSE
TRUE
STATUS Output WORD 错误编号或状态信息 0 到 FFFF
STATUS_FUNC Output STRING[8] 引起 STATUS 中出现的错误的指令名称 字符
IDENT_CODE Output STRING[18] 授权的标识号
可以使用该代码请求许可证的注册密钥REG_KEY。
字符
Init_Error Output BOOL TRUE:初始化期间出现错误。 TRUE/FALSE
Init_Status Output WORD 初始化状态 0 到 FFFF
UNIT InOut BYTE 单元标识符
(INPUT 用于客户端功能,OUTPUT 用于服务器功能)
0 到 255
B#16#0 到 B#16#FF
DATA_TYPE InOut BYTE 要编辑的数据类型:
(客户端功能的 INPUT、服务器功能的 OUTPUT)
线圈
输入
保持寄存器
输入寄存器
1
2
3
4
START_ADDRESS InOut WORD MODBUS 起始地址
(客户端功能的 INPUT、服务器功能的 OUTPUT)
0 到 65535
W#16#0000 到 W#16#FFFF
LENGTH InOut WORD 待处理值的数目(INPUT 用于客户端功能,OUTPUT 用于服务器功能)
线圈
读取功能
写入功能
输入
读取功能
保持寄存器
读取功能
写入功能
输入寄存器
读取功能

1 到 2000
1 到 1968 

1 到 2000 

1 到 125
1 到 123 

1 到 125 
WRITE_READ InOut BOOL 写入访问或
读取访问
(INPUT 用于客户端功能,OUTPUT 用于服务器功能)
TRUE
FALSE
Init InOut BOOL 在上升沿进行初始化 TRUE/FALSE

Modbus 地址的解释

MODBUS 数据模型包括以下区域:

线圈

输入

保持寄存器

输入寄存器

部分系统(例如 MODICON PLC)会通过寄存器地址或位地址区分这些存储器。 例如,偏移量为 0 的保持寄存器被称为寄存器 40001(存储器类型 4xxxx,Reference 0001)。

这往往会引起混淆,因为一些手册中描述或表示的是 Application Layers 的寄存器地址,而其它手册使用的是协议中实际传送的寄存器地址/位地址。

MODBUSPN 在其 start、end 和 START_ADDRESS 参数中使用的是实际传送的 Modbus 地址。 也就是说,可通过各个功能代码传送从 0000H 到 FFFFH 的寄存器地址/位地址。

实例

在参数 DB 中可以按十进制或十六进制格式指定 Modbus 地址。

参数 十进制表示法 十六进制表示法 含义
data_type 3 B#16#3 保持寄存器
db 11 W#16#B DB 11
start 0 W#16#0 起始地址: 0
end 499 W#16#1F3 结束地址:        499
data_type 3 B#16#3 保持寄存器
db 12 W#16#C DB 12
start 720 W#16#2D0 起始地址: 720
end 900 W#16#384 结束地址:        900

下图显示了 SIMATIC 存储区与按寄存器划分和按位划分的 Modbus 设备存储器分配的对比。 分配基于上述参数分配。

在 Modbus 设备中:

以黑色显示的 Modbus 地址表示Data Link Layer;以灰色显示的地址表示Applikation Layer。

在 SIMATIC 中:

第一列中的 SIMATIC 地址是 DB 中的偏移量。 Modbus 寄存器编号显示在括号中。

  S7-400

Modbus 通信的参数分配

无需在网络编辑器中为使用 CPU 的集成 PN 接口的通信组态连接。将利用 TCON 和 TDISCON 指令建立和终止连接。

参数数据块

建立连接和处理 Modbus 消息所需的数据在 PLC 数据类型 MB_PN_PARAM 中定义。此 PLC 数据类型包含连接专用的数据结构和 Modbus 参数结构。 

数据块中每个与通信伙伴的连接都需要一个 PLC 数据类型的实例;可以在其中定义连接参数和 Modbus 参数。可以为各个附加连接扩展数据块,也可以创建新数据块。

该数据块或这些数据块仅用于连接和 Modbus 参数;请勿用其保存任何其它参数。

“MODBUSPN”指令的每个实例都需要一个唯一的连接。为该指令的每个实例创建一个单独的连接描述结构。

S7-400

Param_DB 结构

“Connection settings”结构中的连接参数

在第一个结构“Connection settings”中,定义连接专用的参数,例如,通信伙伴的本地硬件接口和 IP 地址。指令 TCON 和 TDISCON 使用这些参数来建立或终止连接。

必须严格遵守连接参数块的数据结构,否则无法建立连接。

“Modbus settings”结构中的 Modbus 参数

第二个结构“Modbus settings”中存储操作模式和地址引用所需的数据,例如,数据块中映射的 Modbus 区域和作为 Modbus 服务器或 Modbus 客户端的 S7 的操作模式。必须遵守 Modbus 参数的数据结构,否则将无法正确处理。

组态

有两种组态连接和 Modbus 参数的方式可供选择。

选项:
创建新的全局数据库并将其打开。添加参数并为该参数选择数据类型 MB_PN_PARAM。如果下拉列表中未显示该数据类型,可手动输入。
对于该方式,可在一个数据块中插入多个实例。

选项:
通过“添加新块”(Add new block) 创建新的数据块,并将“类型”(Type) 选择为 MB_PN_PARAM。带有已插入连接和 Modbus 结构的新数据块将打开。

该块为只读。无法添加任何其它参数。可以编辑现有参数。

更改值

不可在运行期间更改参数数据块中的值。更改参数后,必须通过 Init = TRUE 重新初始化块。

“Connection settings”连接参数

参数 说明
block_length 该参数定义连接参数的长度,且无法更改。
固定值:                             W#16#40
id 为每个逻辑连接分配一个新连接 ID。此 ID 在整个 CPU 中必须是唯一的。调用 MODBUSPN 时指定 ID;该 ID 将用于 T 块(TCON、TSEND、TRCV 和TDISCON)的内部调用。
值范围:                           W#16#1 到 W#16#FFF
connection_type 建立连接的连接类型通过 TCON 指令定义。CPU 决定必须要设置的值。
TCP(兼容模式):     
B#16#01 针对 CPU 315 或 317 <= FW V2.3
TCP:                                       
B#16#11 针对 CPU 315 或 317 >= FW V2.4、IM 151-8 PN/DP CPU、CPU314C、CPU319、CPU412、CPU414 和 CPU416
该信息可能因固件不同而有所不同。
active_est 该参数表示连接建立类型,主动或被动。Modbus 客户端负责建立主动连接而 Modbus 服务器负责建立被动连接。
主动连接的建立:      TRUE
被动连接的建立:FALSE
local_device_id local_device_id 定义所用 PN CPU 的 IE 接口。根据不同的 PN CPU 类型,需要不同的设置。
IM 151-8 PN/DP CPU:  
CPU 314C、315 或 317:                            
CPU 319:                                                         
CPU 412、414 或 CPU 416                                          
B#16#1
B#16#2
B#16#3
B#16#5
local_tsap_id_len 参数 local_tsap_id(= 本地端口号)的长度是特定的。
主动连接的建立:      0
被动连接建立:   2
rem_subnet_id_len 目前尚未使用此参数,必须将其分配为 B#16#0。
rem_staddr_len 指定 rem_staddr 参数的长度,该参数为通信伙伴的 IP 地址。如果要通过未指定的连接进行通信,则不为伙伴指定 IP 地址。
未指定的连接:     B#16#0
指定的连接:          B#16#4
rem_tsap_id_len 此参数指示参数 rem_tsap_id 的长度和远程通信伙伴的端口号。
主动连接的建立:      2
被动连接建立:   0
next_staddr_len 在此处定义参数 next_staddr 的长度。
对于 PN 接口:     B#16#0
local_tsap_id 使用该参数设置本地端口号。表示类型会因 connection_type 参数不同而有所不同。CPU 决定值范围。端口号在 CPU 中必须唯一。
对于 connection_type B#16#01:
local_tsap_id[1]            
local_tsap_id[2]             
local_tsap_id[3-16]      
对于 connection_type B#16#11:
local_tsap_id[1]            
local_tsap_id[2]             
local_tsap_id[3-16]      

用十六进制格式表示的端口号low byte
用十六进制格式表示的端口号high byte
B#16#00

用十六进制表示的端口号high byte
用十六进制格式表示的端口号low byte
B#16#00
rem_subnet_id 目前尚未使用此参数,必须将其分配为 0。
rem_staddr 在此字节数组中输入远程通信伙伴的 IP 地址。使用未指定的连接时,不输入 IP 地址。表示类型取决于 connection_type 参数。示例:IP 地址 192.168.0.1:
对于 connection_type B#16#01:
rem_staddr[1] =
rem_staddr[2] =
rem_staddr[3] =          
rem_staddr[4] =
rem_staddr[5-6]=
对于 connection_type B#16#11:
rem_staddr[1] =
rem_staddr[2] =
rem_staddr[3] =
rem_staddr[4] =           
rem_staddr[5-6]=        

B#16#01 (1)
B#16#00 (0)
B#16#A8 (168)
B#16#C0 (192)
B#16#00(保留)

B#16#C0 (192)
B#16#A8 (168)
B#16#00 (0)
B#16#01 (1)
B#16#00(保留)
rem_tsap_id 使用该参数设置remote端口号。表示类型会因 connection_type 参数不同而有所不同。CPU 决定值范围。
对于 connection_type B#16#01:
rem_tsap_id[1]             
rem_tsap_id[2]            
rem_tsap_id[3-16]      
对于 connection_type B#16#11:
rem_tsap_id[1]
rem_tsap_id[2]            
rem_tsap_id[3-16]      

用十六进制表示的端口号low byte
用十六进制表示的端口号low byte
B#16#00

用十六进制表示的端口号high byte
用十六进制表示的端口号low byte
B#16#00
next_staddr 该参数定义所用 CP 的机架和插槽编号。使用 CPU 的集成 PN 接口时,必须将该参数设置为 0。
next_staddr[1-6]           B#16#00
spare 未使用此参数,必须将其设设置为默认值 0。

“Modbus settings”Modbus 参数

参数 说明
server_client TRUE:              S7 是服务器
FALSE:            S7 是客户端
single_write 在“S7 为客户端”操作模式下,如果参数 single_write = TRUE ,则功能代码 5 和 6 用于执行长度为 1 的写入作业。
如果 single_write = FALSE,则功能代码 15 和 16 用于所有写入作业。
connect_at_startup 指定连接建立的时间。
如果将 connect_at_startup 设置为 TRUE,将在 CPU 重新启动后立即建立连接。此种情况下,只有正确建立连接 (CONN_ESTABLISHED = TRUE) 后才能启动数据请求,否则将在 ERROR 和 STATUS 中显示相应的错误。
FALSE:            如果 ENQ_ENR,则连接建立
设置为TRUE:              重新启动后立即建立连接
八个数据区 S7 存储器中有八个可以用于映射 MODBUS 地址的数据区。必须至少定义第一个数据区,其余七个数据区可选择性定义。根据作业类型,将从数据区读取数据或向其中写入数据。
任何作业都只能从一个 DB 读取数据或向一个 DB 写入数据。访问寄存器或位于多个 DB 中的位值时,即使编号连续无间隔,也将分为两个作业。组态时请务必注意。
一个数据块中可以映射的 Modbus 区(寄存器或位值)数目比一个消息帧可以处理的数目多。
data_type data_type 参数指定该数据块中映射的 MODBUS 数据类型。如果在 data_type 中输入值 0,则不使用相应的区域。
标识符
0
1
2
3
4
数据类型
未使用区域
线圈
输入
保持寄存器
输入寄存器
数据宽度

Bit
Bit
Word
Word
db db 参数指定映射 MODBUS寄存器或下面定义的位值的数据块。DB 编号 0 为系统保留,不允许使用。
DB 编号                             1 到 65535(W#16#0001 到 W#16#FFFF)

数据块必须比已组态数据所需的长度多两个字节。最后的两个字节供内部使用。
start
end
start 指定 DB 的数据字 0 中映射的第一个 Modbus 地址。end 参数定义最后一个 MODBUS 地址。
对于寄存器访问,带有最后一个 Modbus 地址输入的 S7 DB 中的数据字编号如下计算:
DBW 编号 = (end – start) * 2
对于位访问,带有最后一个 Modbus 地址输入的 S7 DB 中的数据字节编号如下计算:
DBB 编号 = (end – start + 7) / 8
定义的数据区不得重叠。end 参数不得小于 start。如果发生错误,指令启动将中止并提示错误。如果两个值相同,则将分配一个 Modbus 地址(1 个寄存器或 1 个位值)。
在 S7 存储器区域映射 MODBUS 地址的示例。
MODBUS 地址                   0 到 65535(W#16#0000 到 W#16#FFFF)
internal_send_buffer 该数组用于发送数据的指令中。不允许访问或更改该区域。
internal_recv_buffer 该数组用于接收数据的指令中。不允许访问或更改该区域。






审核编辑:刘清

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分