FB_SendRecvMsg:发送和接收消息功能块

概述

下图显示了功能块 FB_SendRecvMsg 的引脚图:

G-SE-0047230.1.gif-high.gif

 

 

功能块 FB_SendRecvMsg 可发送和接收自定义消息。它会在串行线路上发送消息,然后等待响应。另外,它也可以发送消息但不等待响应,或者仅接收消息而不发送消息。此功能应与 ASCII 管理器配合使用。

I/O 变量描述

下表描述了 TwidoEmulationSupport 库中功能块的输入变量:

输入

数据类型

描述

i_xExecute

BOOL

此功能在此输入的上升沿上执行。

注意: 如果在冷复位或热复位后的第一个运行模式下的任务循环中将 i_xExecute 设置为“真”,则检测不到上升沿。

i_xAbort

BOOL

停止上升沿上正在执行的操作。

i_iLink

INT

指示用于通讯的端口:

o1 = 串行端口 1

o2 = 串行端口 2

i_iTimeout

INT

设置接收响应须等待的最长时间。指定时以毫秒作为单位。0 值表示没有强制执行超时。

i_iQuantityToSend

INT

要发送的对象的数量。

i_pbyBufferToSend

POINTER TO BYTE

用来存储要发送的对象值的缓冲区的地址。前 2 个字是控制字。

i_iSizeRecvBuffer

INT

要接收的对象的数量。

i_pbyBufferToRecv

POINTER TO BYTE

接收对象值存储所在的缓冲区的地址。

下表描述了 TwidoEmulationSupport 库中功能块的输出变量:

输出

数据类型

描述

q_xDone

BOOL

如果功能成功完成,q_xDone 将设置为“真”。

q_xBusy

BOOL

如果功能正在执行,q_xBusy 将设置为“真”。

q_Aborted

BOOL

如果使用 i_xAbort 输入中止功能,q_Aborted 将设置为“真”。

q_xError

BOOL

如果功能由于检测到错误而停止,q_xError 将设置为“真”。

q_etCommError

SEN.CommunicationErrorCodes

q_etCommError 包含了通讯错误代码 SEN.CommunicationErrorCodes 的值。

q_etOperError

SEN.OperationErrorCodes

q_etOperError 包含了操作错误代码 SEN.OperationErrorCodes 的值。

q_iQuantiyRecv

INT

已接收对象的数量