MODBUS_MASTER_B (196)


MODBUS_MASTER_B (196)

ID                          196

 

   

 

Application:

PLC

 

Group: I/O

 

Short description:

Function that exchanges the indicated registers via the modbus protocol with the selected slave device on the RS485 bus.

 

Inputs (6):

no.

type

impulse

mark

notes

1

B

no

exe

High state activates data exchange  

2 I - func Available functions:
01 - ReadCoils
03 - ReadHoldingRegisters
05 - WriteSingleCoil
06 - WriteSingleRegister 
15 - WriteMultipleCoils
16 - WriteMultipleRegisters 
3 I - addr Starting number of modbus register
4 I - num Starting register number
5 I - size Number of registers to send / read
6 I - slave Modbus slave device ID


Outputs (3):

no.

type

impulse

mark

notes

1

B

no

busy

Data exchange in progress

2

B

yes (0->1)

error

Error signal

3

I

-

error_id

Error ID

 

Settings: none

 

Description:

The MODBUS_MASTER function communicates with external devices via the Modbus protocol. There are 6 functions in the block that can be used to send or receive data.
 

Function 01 - ReadCoils reads any markers of the slave device. The block can operate in two configurations. The first is to impulse the block. If 1 appears at the input of the block, the block sends a query to the slave device for selected markers, after receiving the answer, the registers are copied to the selected controller markers. If another impulse appears at the input of the block, the block will be executed if the previous communication has been completed or the time for response has expired. The second configuration is to set 1 to the block input permanently. The block in this configuration works similarly to the above one, the only difference is that the block starts the next data reading cycle automatically at the end of the previous one.

Function 03 - ReadHoldingRegisters reads any registers of the slave device. The block can operate in two configurations. The first is to impulse the block. If 1 appears at the input of the block, the block sends a query to the slave device for selected registers, after receiving the answer, the registers are copied to the selected controller registers. If another impulse appears at the input of the block, the block will be executed if the previous communication has been completed or the time for response has expired. The second configuration is to set 1 to the block input permanently. The block in this configuration works similarly to the above one, the only difference is that the block starts the next data reading cycle automatically at the end of the previous one.

Function 05 - WriteSingleCoil enables writing a single marker to a slave device, the number of markers in this case will always be equal to 1. The block can operate in two configurations. The first is to impulse the block. If 1 appears at the input of the block, the block sends a query to the slave device for selected markers, after receiving the answer, the registers are copied to the selected controller markers. If another impulse appears at the input of the block, the block will be executed if the previous communication has been completed or the time for response has expired. The second configuration is to set 1 to the block input permanently. The block in this configuration works similarly to the above one, the only difference is that the block starts the next data reading cycle automatically at the end of the previous one.

Function 06 - WriteSingleRegister enables writing a single register to a slave device, the number of registers in this case will always be equal to 1. The block can operate in two configurations. The first is to impulse the block. If 1 appears at the input of the block, the block sends a query to the slave device for selected registers, after receiving the answer, the registers are copied to the selected controller registers. If another impulse appears at the input of the block, the block will be executed if the previous communication has been completed or the time for response has expired. The second configuration is to set 1 to the block input permanently. The block in this configuration works similarly to the above one, the only difference is that the block starts the next data reading cycle automatically at the end of the previous one.

Function 15 - WriteMultipleCoils is designed to send any number of markers. The block can operate in two configurations. The first is to impulse the block. If 1 appears at the input of the block, the block sends a query to the slave device for selected markers, after receiving the answer, the registers are copied to the selected controller markers. If another impulse appears at the input of the block, the block will be executed if the previous communication has been completed or the time for response has expired. The second configuration is to set 1 to the block input permanently. The block in this configuration works similarly to the above one, the only difference is that the block starts the next data reading cycle automatically at the end of the previous one.

Function  16 - WriteMultipleRegisters is designed to send any number of registers. The block can operate in two configurations. The first is to impulse the block. If 1 appears at the input of the block, the block sends a query to the slave device for selected registers, after receiving the answer, the registers are copied to the selected controller registers. If another impulse appears at the input of the block, the block will be executed if the previous communication has been completed or the time for response has expired. The second configuration is to set 1 to the block input permanently. The block in this configuration works similarly to the above one, the only difference is that the block starts the next data reading cycle automatically at the end of the previous one.

During the communication, the busy output is turned on. The error and err_id outputs are activated when errors occur. The table style="width:100%" class="table table-bordered" with the description of the errors is presented below:

 

Err_id

Description

0 No error
1 No function to execute
2 Invalid data from slave had been received
3 Invalid data had been sent to slave
4 Invalid slave ID
5 Incorrect number of registers
6 Incorrect modbus register no.
7 -
8 Incorrect controller register no.
9 Incorrect controller register range

 

Notes:

 

R registers and M markers used:

The block uses user-defined registers in the block settings.