下图显示了功能块 FB_SendRecvMsg 的引脚图:
功能块 FB_SendRecvMsg 可发送和接收自定义消息。它会在串行线路上发送消息,然后等待响应。另外,它也可以发送消息但不等待响应,或者仅接收消息而不发送消息。此功能应与 ASCII 管理器配合使用。
下表描述了 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 |
已接收对象的数量 |