As an Ignition Premier Integrator, DMC works on dozens of SCADA projects every year for clients across a wide range of industries.
As plants expand and grow, we are frequently asked to integrate more and more devices. Luckily, Ignition has pre-made OPC UA device drivers for many of the most widely used PLCs such as Siemens and Allen Bradley processors that are OPC UA ready. Yet there are still several—both new and legacy—that rely on common protocols like Modbus TCP.
In this blog, I will walk you through setting up and using Ignition’s OPC UA Modbus TCP Driver, as well as how to configure an Address Map to allow OPC tags to be browsable.
Adding the Device to the Ignition Gateway
Assuming the IP Address is set and known for the Modbus TCP device, and it is properly networked to the Ignition gateway, we can begin to configure the Modbus TCP driver through Address Mapping.
Navigate to the Gateway Webpage (Use a web browser or navigate to the webpage through the Designer Launcher).
data:image/s3,"s3://crabby-images/ece4c/ece4c1f80d4ab909df80a9e007590e79119e91d0" alt="Ignition designer launcher gateway"
Once inside the Ignition Gateway, go to “Config” à “OPC UA” à “Device Connections” and select “Create new device.”
data:image/s3,"s3://crabby-images/d2bbb/d2bbbcc37aa32fca2cc810d8bb40583322e0a763" alt="ignition gateway new device"
data:image/s3,"s3://crabby-images/52949/52949b002038883b2e1c163db187b2e3f969ea19" alt="ignition gateway create new device"
Select the “Modbus TCP” driver and click “Next >” at the bottom of the screen .
data:image/s3,"s3://crabby-images/397cb/397cb5f81e53dce3fe73143f8957e33d36217b19" alt="Ignition gateqay select modbus tcp"
Give the device a name and add the new IP address (The default port is 502).
data:image/s3,"s3://crabby-images/8428d/8428d509e097e823eebbb69c5138d82ba5563893" alt="Ignition gateway new IP address"
Adding an Address Map
After creating the Modbus TCP device, go to “More” à “Addresses” to add the data requests with Ignition’s Modbus Address Map. By creating a Map developers can avoid setting up each Ignition tag on a case-by-case basis by pointing at a Modbus register, grouping Modbus registers in common blocks, and customizing the naming or number scheme of Modbus blocks (Inductive Automation Docs, Modbus Address Mapping).
data:image/s3,"s3://crabby-images/559dc/559dce7a09ee64a37e86f6cfdb55f9e586c11004" alt="Ignition gateway add data requests"
Now go to the device’s manual, which should display the Modbus Registry addresses for your desired tags. The following screenshots are an example from the manual for an Allen-Bradley PowerMonitor1408-EM3A-ENT.
data:image/s3,"s3://crabby-images/8bde1/8bde1b200b31bbef4dfd9666a0766dd0e34d5603" alt="device manual example"
data:image/s3,"s3://crabby-images/6c750/6c750341389d63cc60a66cf13b875e58a2d83397" alt="device manual example"
From these tables we will need the “Data Type” and “Modbus Address” to configure the Modbus addresses you are interested in. The Ignition table is pictured below (Click “Add Row” at the bottom of the screen to add an address).
data:image/s3,"s3://crabby-images/8c45c/8c45c74f8e6bd2bef1b140facf39569e308bc54e" alt="add addresses to ignition"
“Prefix” will name the group of addresses that you are pulling.
“Modbus type” and “Modbus Address” will correspond to the Modbus address from the manual. “Input Register” signifies addresses in the “3XXXX” range, “(Float)’ signifies the data type and the Modbus Address selects the specific point. The table below shows Modbus register prefixes based on data type.
data:image/s3,"s3://crabby-images/4c479/4c4792e8d72d414d170621bd88b2c45cfe10fddc" alt="Modbus register prefixes"
“Unit ID” is the Modbus Address of the device (The default is 64 in this case but can also be found in the devices manual).
“Start” and “End” give the range of data points to pull. “Start” can be any number you want and will only affect the naming convention of the tag within the gateway (The actual Modbus start address is decided by “Modbus Address”). The range between “Start” and “End” will determine how many tags are pulled. This will pull the number of bytes necessary for the datatype. (Ex “Start” = 1 and “End” = 3 for an input register with type “float” at address 201 will pull 201-2, 203-4, and 205-6. “Start” = 0 and “End” = 2 will pull the same addresses but will concatenate 0-2 instead of 1-3 to the Prefix for each tag name).
NOTE: If multiple devices are added to the same gateway, the new address will need to be added to EACH INSTANCE of the device. This can be done quickly through the Import/Export Configuration feature.
Adding tags to the Ignition Designer
You can add tags to the Designer by either creating a tag directly or creating a UDT for the device. This example uses UDTs for ease of replication.
Begin by opening the UDT editor. Double click on the tag as shown below. Then create a folder for the new variable (labeled “Energy” in this example). Within this folder, create an OPC tag.
data:image/s3,"s3://crabby-images/c39cf/c39cff3791b65c6b599b23f6b77ed923129b90ef" alt="Ignition UDT editor"
Add the Name, Data Type, OPC Server, and OPC Item Path (Browse for the path with the PLC icon on the right).
data:image/s3,"s3://crabby-images/96921/969218e642a36d50d0c4b93ab9a9c9cd5e2e7aba" alt="Add name to ignition udt editor"
Optionally, to make the path dynamic (for use of multiple devices) create a parameter called “OPCRootPath”. Then replace the first half of the “OPC Item Path” with {OPCRootPath} as shown. This will reflect the dynamic path specified in the instance’s “OPCRootPath” Parameter.
data:image/s3,"s3://crabby-images/25528/25528bd60ade8dbb7261ee0ac048da3a9d4067cb" alt="create opc item path in udt editor"
data:image/s3,"s3://crabby-images/21e32/21e32ea264fe259db7c0bec498c595372449e457" alt="create path in udt editor"
data:image/s3,"s3://crabby-images/fd2c1/fd2c14e433d4359c1047663bcdd91b2f34a148aa" alt="create path in udt editor"
Now create a tag instance (Tags Tab à “+” à ”Data Type Instance” à **UDT Name**) and give the tag an appropriate name.
data:image/s3,"s3://crabby-images/d39d7/d39d7e6a3d932d33ad5b202a8d457179febc1ff8" alt="create a tag instance in udt editor"
Under the same plus sign as above, go to “Browse Devices…” and find the appropriate device. Right click on the device and select “Copy Item Path."
data:image/s3,"s3://crabby-images/7087a/7087a6796d5f71bdc8abb28906dd76802ae8edf9" alt="udt editor copy item path"
Then, select your new tag instance of the PM1000, and go to the “Parameters” tab. Copy the OPC item path into the OPCRootPath Parameter.
data:image/s3,"s3://crabby-images/ed5e9/ed5e9bf6f1e11f2e6ab6329a6e3bac7114d62edf" alt="copy opc item path"
Now the tags should be loaded into the designer as expected!
Learn more about DMC’s Ignition programming expertise and contact us today for your next project.