How to Transfer Data from Modbus to Modbus

How to Transfer Data from Modbus to Modbus

Open Automation Software can be used to transfer data between two Modbus devices using Modbus TCP, Modbus RTU, and Modbus ASCII locally or over a network. This guide walks you through downloading and installing OAS, configuring a data source and data destination Modbus connector and one tag for each to represent a data transfer.

This guide uses the Data Route feature of OAS to transfer a Tag's value to another Tag's value using the Tag-to-Tag method.

For this guide on how to transfer data between two Modbus devices you will need:

  • One or more Modbus devices or simulators connected to your workstation

1 - Download and Install OAS

If you have not already done so, you will need to download and install the OAS platform.

Fully functional trial versions of the software are available for Windows, Windows IoT Core, Linux, Raspberry Pi and Docker on our downloads page.

On Windows, run the downloaded setup.exe file to install the Open Automation Software platform. For a default installation, Agree to the End User License Agreement and then click the Next button on each of the installation steps until it has completed.

If you'd like to customize your installation or learn more, use the following instructions:

The OAS Service Control application will appear when the installation finishes on Windows.

OAS Service Control

Click on each START SERVICE button to start each of the three OAS services.

2 - Configure OAS

Configure OAS is the main application used to configure local and remote OAS instances.

OAS Logo

  1. From your operating system start menu, open the Configure OAS application.

  2. Select the Configure > Tags screen.

    Important

    If this is the first time you have installed OAS, the AdminCreate utility will run when you select a screen in the Configure menu. This will ask you to create a username and password for the admin user. This user will have full permissions in the OAS platform.

    For further information see Getting Started - Security.

  3. If this is the first time you are logging in, you will see the AdminCreate utility. Follow the prompts to set up your admin account. Otherwise, select the Log In menu button and provide the Network Node, username and password.

    Log In Menu

    Log In Dialog

Info

In this guide you will use the Configure OAS application to configure the local Network Node which by default is localhost.

If you have installed OAS on a remote instance you can also connect to the remote instance by setting the relevant IP address or host name in the Network Node field.

3 - Configure Modbus Data Source

In the following steps you will create and configure a Modbus Connector to act as a data source. This will use a Master connection type and an Ethernet TCP connection. It assumes that your device is using the default port 502.

  1. Select Configure > Drivers from the top menu.

    Configure drivers menu

  2. Enter a meaningful Driver Interface Name to give this driver interface instance a unique name.

  3. Ensure the following parameters are configured:

    • Driver: Modbus
    • Type: Master
    • Connection: Ethernet
    • Ethernet Type: TCP
    • Port: 502
  4. Specify the device IP in the IP Address field.

    Modbus connection configuration

  5. Click on the ADD DRIVER button on the left hand side to add this driver configuration. Once added, the driver interface name should appear in the list of drivers.

    Add Modbus driver button

4 - Add Data Source Tag

In this section you will create a Tag to represent your data point in the field (for example a temperature sensor). This can then be transferred your desired destination.

  1. Select Configure > Tags from the top menu.

    Configure tags menu

  2. If you want to add a Tag to the root Tags group make sure the Tags node is selected in the tag list and click on the ADD TAG button.

    Add tag button

    If you want to add a Tag to a Tag Group, select the Tag Group first and then click on the ADD TAG button.

    You can also add Tag Groups by using the ADD GROUP button.

  3. Provide a Tag Name such as TemperatureSensor and click the OK button.

    Add tag to root node dialog

5 - Assign Modbus as Tag Data Source

You will now set the Tag's data source to the Modbus driver interface that you created previously to act as a data source.

  1. Select the Tag that will be associated with the Modbus data source.

    Tag

  2. Set the Data Source to Modbus.

  3. Set the Select Driver Interface drop-down to the ModbusSource interface created previously.

  4. Configure the Modbus parameters accordingly based on your device requirements.

    • Device Address: The Modbus station number [default: 1]
    • Memory Type: The Modbus data model table type [Coil Status, Input Status, Input Register, Holding Register]
    • Address: The register to read/write based on the address offset
    • Modbus Data Type: The Input and Holding Register data type
    • Zero Based Address: Whether the Address starts at 0 or 1 [default: true]
    • Word Swap & Byte Swap: Adjust as required for your controller type [default: false]
  5. Set the polling rate in seconds by setting the Polling Rate property [default: 1 second].

    Modbus tag configuration

  6. Click on the Apply Changes button to apply the changes.

  7. Check that the quality status is Good Quality and the data in the Value field is as expected.

    Modbus tag quality

6 - Configure Modbus Data Destination

In the following steps you will create and configure a Modbus Connector to act as a data destination. This will use a Master connection type and an Ethernet TCP connection. It assumes that your device is using the default port 502.

  1. Select Configure > Drivers from the top menu.

    Configure drivers menu

  2. Enter a meaningful Driver Interface Name to give this driver interface instance a unique name.

  3. Ensure the following parameters are configured:

    • Driver: Modbus
    • Type: Master
    • Connection: Ethernet
    • Ethernet Type: TCP
    • Port: 502
  4. Specify the device IP in the IP Address field.

    Modbus connection configuration

  5. Click on the ADD DRIVER button on the left hand side to add this driver configuration. Once added, the driver interface name should appear in the list of drivers.

    Add Modbus driver button

7 - Add Data Destination Tag

In this section you will create a Tag to represent a data point that you want to write to.

  1. Select Configure > Tags from the top menu.

    Configure tags menu

  2. If you want to add a Tag to the root Tags group make sure the Tags node is selected in the tag list and click on the ADD TAG button.

    Add tag button

    If you want to add a Tag to a Tag Group, select the Tag Group first and then click on the ADD TAG button.

    You can also add Tag Groups by using the ADD GROUP button.

  3. Provide a Tag Name such as TemperatureOutput and click the OK button.

    Add tag to root node dialog

8 - Assign Modbus as Tag Data Destination

You will now set the Tag's data source to the Modbus driver interface that you created previously to act as a data destination.

  1. Select the Tag that will be associated with the Modbus destination.

    Tag

  2. Set the Data Source to Modbus.

  3. Set the Select Driver Interface drop-down to the ModbusDestination interface created previously.

  4. Configure the Modbus parameters accordingly based on your device requirements.

    • Device Address: The Modbus station number [default: 1]
    • Memory Type: The Modbus data model table type [Coil Status, Input Status, Input Register, Holding Register]
    • Address: The register to read/write based on the address offset
    • Modbus Data Type: The Input and Holding Register data type
    • Zero Based Address: Whether the Address starts at 0 or 1 [default: true]
    • Word Swap & Byte Swap: Adjust as required for your controller type [default: false]
  5. Set the polling rate in seconds by setting the Polling Rate property [default: 1 second].

    Modbus tag configuration

  6. Click on the Apply Changes button to apply the changes.

  7. Check that the quality status is Good Quality and the data in the Value field is as expected. If the PLC does not hold any value in the given register then the value will remain zero.

9 - Configure Tag-To-Tag Data Route

In this section you will configure the Target of the source Tag to be the destination Tag value. This means whenever the source Tag value is updated, the destination Tag value will also be updated. This will cause a write operation on any associated driver if it is supported.

  1. Select the source data Tag.

    Select temperature sensor Tag

  2. Select the Target tab.

    Select Target tab

  3. Enable the Enable Write to Target option.

    Enable Tag Target

  4. Click on the BROWSE button to select the destination tag.

    Select destination Tag

  5. Optionally, configure the Deadband property or enable Write Continuously to configure a continuous writing frequency.

    Complete Tag Target Configuration

  6. Click on the Apply Changes button to apply the configuration.

  7. To verify that your data transfer is working correctly, select the destination Tag and check that the Tag value matches the Tag value of the source Tag.

    Temperature Output Tag

    You should also verify that the Tag value has been written to your destination device. Depending on your configuration in step 5 above, this destination value should be updated whenever the source value changes or at the given frequency.

10 - Modbus Troubleshooting

  • Check your device address and register address and if the device is using Zero Based Addressing.
  • Ensure the data types for the Tag and the Modbus Data Type match and if they are boolean or numeric values.
  • Check your IP addresses and ports and any firewalls that might be enabled in the operating system.
  • Enable Log Modbus Communications in the Configure > Options > System Logging screen and check the log files for any errors.
  • Use tools such as Wire Shark to troubleshoot deeper connection and protocol issues.

11 - Save Changes

Once you have successfully configured your OAS instances, make sure you save your configuration.

On each configuration page, click on the Save button.

If this is the first time you are saving the configuration, or if you are changing the name of the configuration file, OAS will ask you if you want to change the default configuration file.

If you select Yes then OAS will make this configuration file the default and if the OAS service is restarted then this file will be loaded on start-up.

If you select No then OAS will still save your configuration file, but it will not be the default file that is loaded on start-up.

Change Default Configuration Files dialog

Important

Each configuration screen has an independent configuration file except for the Tags and Drivers configurations, which share the same configuration file. It is still important to click on the Save button whenever you make any changes.

For more information see: Save and Load Configuration

Info

  • On Windows the configuration files are stored in C:\ProgramData\OpenAutomationSoftware\ConfigFiles.
  • On Linux the configuration files are stored in the ConfigFiles subfolder of the OAS installation path.