Conversion_IP_Address_to_CoDeSys_Address.pdf
56 KB
Ever wondered how to setup an online service to read an IP Address from a PLC? This example shows both the Automation Platform code and the code on the PLC.
PLCs in the CODESYS network use their own addressing mechanism (e.g. [053D.0001]) which is independent from the actual physical connection. These CODESYS addresses were necessary to allow communication between PLCs with different physical connections (e.g. USB, COM, Ethernet, etc). If you want to learn more about CODESYS addresses, they are explained in the documentation of the runtime system. To get an idea on how the CODESYS Address is related to the IP Address, check out the attached PDF.
As there is no way to reverse-engineer the IP address from the CODESYS address, there is no way to know the IP address of a PLC that responded in a network scan via UDP. However, by building a custom component in the runtime system and creating a matching online service in a plugin, an OEM can read the IP address directly from the PLC. This example contains both the code needed in the Automation Platform as well as the code for the runtime system.
⇒ There will be a popup showing the example address "192.168.101.72" (or an error message).
The returned IP address is just an example and not the actual one. If you want to get the real IP address, use the attached code "RtsServiceHandler.c" for the runtime project "CmpTemplate" (part of the runtime delivery). You can use this as a starting point to dynamically read the IP address from your system (e.g. by calling "SysSockGetFirstAdapterInfo"). But this is not in the scope of the Automation Platform anymore.
56 KB
5 KB
3 KB
421 KB