NetToPLCsim Manual en
NetToPLCsim Manual en
NetToPLCsim supports most of the functions which are supported by S7-Plcsim, like:
• All communication functions which are programmed via the T-Blocks (TCON, TSEND, etc.) or
configured via NetPro are not supported
• NetToPLCsim supports other system state lists (SSL/SZL) as a real CPU, and they contain
different values
• You can’t use programming functions using TIA-Portal with a S7-300/400 simulation, because
TIA-Portal checks the compatibility of the CPU you want to upload the program to. With Step7
V5.x this is no problem, as it’s more tolerant uploading the program into a different type of CPU
• The Plcsim/NetToPLCsim CPU will not be visible if you are using "Display Accessible Nodes" in
Step 7. This method uses the LLDP protocol on MAC layer. On a PC with installed Simatic
software, your PC will always be listed as "PC-Station". Furthermore the communication
behaviour of S7-Plcsim/NetToPLCsim is slightly different to a real CPU.
A test with NetToPLCsim does not substitute the test on the real hardware.
Plcsim for 1200/1500 has no interface like S7ProSim. Due to this limitations, all following versions
are using the so called S7online-interface.
1
S7online-interface
The S7online-interface represents the OSI layers 1 to 4 for all applications inside the Simatic
universe. If a Simatic application communicates to a PLC, the data goes always through the
S7online-interface. The functions of the S7online-interface are accessible through the program
library s7onlinx.dll inside the windows system directory.
The S7online-interface passes the data from the application to the underlying transport layer, like
TCP/IP, MPI or Profibus. The transport layer which S7online is using, is configured in the dialog "Set
PG/PC interface" from the Simatic application or the Windows control panel. Also the
communication to Plcsim runs through this interface. The data running through this interface are
already S7-communication. Thus the job of NetToPLCsim is to represent the IP/IsoOnTcp transport
layer, and pass the payload into the S7online-interface and back. The main problem with the
S7online-interface is that it’s not official documented, which was the main problem using this
interface with NetToPLCsim.
Operation Manual
Quickstart
Plcsim with S7-300/S7-400 (Step 7 V5.5, TIA-Portal)
Use the following steps to setup a network accessible Plcsim simulation using NetToPLCsim. The
description is valid for Plcsim with Step 7 V5.5.
3. Start Plcsim, upload the program including system data into Plcsim. You need a CPU with a
ethernet network device (PN-CPU or CPU plus Ethernet CP)
4. Start NetToPLCsim with administrative rights (these are neccessary to stop a Siemens service)
7. In the station configuration dialog, click on "…" next to the text field "Network IP Address". You
get a list with all IP addresses of the existing network devices of your computer. Choose the
address on which Plcsim should be accessible
8. Next to the text field "Plcsim IP Address" click on "…". You should see the Plcsim CPU you have
uploaded. Select the device and click "OK"
12. Your Plcsim simulation is now reachable at the IP address shown under "Network IP address"
2
Plcsim with S7-1200/S7-1500 (TIA-Portal)
To use NetToPLCsim with TIA-Plcsim, it’s required to set the correct PG/PC interface settings. In the
Windows Control Panel you open the "Set PG/PC interface" program, and set the access point for
S7ONLINE to "PLCSIM S7-1200/S7-1500(TCP/IP)".
Since TIA Portal Version V14 you have to set the access point to "PLCSIM.TCPIP.1"
General operation
Neccessary requirement
You need Step 7 Plcsim with V5.4 or later, or Plcsim for TIA-Portal.
In your Step 7 hardware configuration you must have an Ethernet device (PN-CPU or CPU plus
Ethernet CP).
Main window
2. Buttons to start and stop the server for the configured stations
4. Result of the port-check which is done on start of NetToPLCsim. You can use NetToPLCsim only
with status OK.
3
Station dialog
1. Unique Name
4. Rack/Slot position of the CPU. This setting is only relevant if you set the option TSAP-check. If
you enable this option, your client application needs to use the correct TSAP corresponding to
the rack/slot combination. NetToPLCsim accepts as connection ressource 1=PG, 2=OP and
3=Step7Basic.
Protocolmonitor
If you have started the NetToPLCsim server, you can start the protocolmonitor via context menu
(right mouse-click) of the station you want to monitor. If you select "Start monitoring", a new
window with the protocolmomitor opens.
At this time only S7 communication for S7-300/400 is shown, and only some parts of the S7 protocol
are dissected. Only incoming telegrams using variable services (reading and writingdata areas in
the S7) and SSL-(SZL)-Requests are decoded.
With mouseclick on the statusbar, you can pause and resume the capture output. The
communication is not stopped when you pause the output.
If you want to see all details of the S7 protocol, you can use the network protocol analyzer
Wireshark. Since Wireshark version 2.0 the S7 protocol is integrated. On older versions you need a
plugin-dll for the S7 communication, you can download from the link below.
http://sourceforge.net/projects/s7commwireshark
4
Figure 3. NetToPLCsim Protocolmonitor
Command-line arguments
Option Description
-f=config.ini Loads this station configuration file
-s=Option Autostop control of the S7DOS Help
Service. Options: YES=Stop the service,
NO=Don’t stop the service, ASK=ask
-autostart If a valid configuration-file is loaded,
the servers for the stations in the file
are automatically started
Example:
Further it’s possible to Drag&Drop a configuration file on the NetToPLCsim.exe file. Then
NetToPLCsim starts and loads this configuration.
Further informations
5
Multiple Plcsim-Instances
The following example demonstrates how to realize three network reachable Plcsim instances with
NetToPLCsim. The main principle could be extended to a arbitrary number of additional instances
(tested with 6 Plcsim instances).
Each Plcsim instance needs it’s own IP address, under which it’s later reachable from your network.
One option is that you’ve got more than one network interface in your computer. The other option
is to add one or more IP addresses to the existing network interface.
In the following screenshot, it is shown how to add an additional IP address to your network
interface under Windows 7 (german).
6
Figure 5. Adding an IP address to a network interface (Windows 7)
To avoid later network problems, you should delete the additional IP-addresses
when finished with testing.
You can start a new Plcsim instance after you started the first instance, using the menu "File" →
"New Plc" in Plcsim. When the new Plcsim instance has started, upload the PLC program including
system data into Plcsim. Only with uploaded system data the simulation has the configured
"virtual" IP address.
The setup of the stations in NetToPLCsim is done in the same way as described for a single station.
For the simulation overview shown above the following setup in NetToPLCsim is needed:
If you have Step 7 installed on your system, you’ve got a service called "SIMATIC S7DOS Help
Service" (old name was "SIMATIC IEPG Helper"). This service listens on all available network
7
interfaces for incoming connections on TCP port 102. Thus as long this service is running, it’s not
possible to start an server from another application like NetToPLCsim using this port.
Since Step 7 V5.5 SP2 unter 64 bit Windows, it’s no longer possible to simply stop the service, as this
affects other Siemens program functions.
For that reason the function "Get Port 102" from Tools-Menu, and the automatic service-stop
function when you start NetToPLCsim (since version 1.1.0) starts the following sequence:
3. Start the service "SIMATIC S7DOS Help Service". As TCP port is now not available for the service,
it cannot reserve it
5. Check if TCP port 102 is now available If the last check succeeded, port 102 is now available for
using with NetToPLCsim.
NetToPLCsim remembers when you have stopped the Siemens service on program start. If you
close NetToPLCsim, you can optional restart the Siemens service (recommended).
If you want to program a real S7-PLC after testing with NetToPLCsim, it’s
recommended to restart the computer!
Version history
Version 0.9.0
• First version using the S7online interface
Version 0.9.1
• added optional monitoring of the data-exchange
Version 0.9.2
• Fixed: Data exchange with Plcsim doesn’t hang up any more, when packets of some special PDU
sized occur
• Added Command-line Arguments, and the possibility to Drag&Drop a configuration file on the
NetToPLCsim.exe
Version 0.9.3
• Temporary fix: Implemented own response for SZL-ID 0x0131 index 3 request, to force clients
8
not to use the cyclic data exchange mechanism, which causes sometimes communication
failures
Version 0.9.4
• NetToPLCsim answers a client that only one single request at time can be handled
(MaxAmQCalling/MaxAmQCalled)
• Added optional setting for rack/slot combination of CPU (maybe possible to connect to TIAPortal
Plcsim)
• Added option for TSAP check corresponding to entered rack/slot. Connection ressources 1, 2 or 3
are valid (1=PG, 2=OP, 3=S7basic)
Version 0.9.5
• Adding Tool "Get Port 102" in Menu Tools, which helps to get NetToPLCsim working under Step
7 V5.5 SP2 and Windows 64 Bit
Version 1.0.0
• Redesign of handling the S7online interface. NetToPLCsim supports now the full functionality of
Plcsim. Programming functions like up- and downloading of program blocks and online
diagnostics are possible. Also block-specific messages like ALARM_S, ALARM_8 and cyclic
variable services are supported.
• Added own response telegram to SZL-ID 16#0x74, used to get the LED state of the CPU.
Independent of the operating mode, the response is always RUN-LED on, and all other LEDs off.
Version 1.1.0
• Fixed: if many ISO packets were sent in a single TCP telegram, this may have caused an
exception and disconnect (for V.1.0.0)
• Function "Get Port 102" from tools-menu is now executed on program start to stop the Siemens
service
• Monitor window: With mouseclick on statusbar the capturing can be paused and resumed
Version 1.2.0
• Fixed: Handling of the station-name used in the function to browse the reachable Plcsim
9
partners. Fixes the problem that sometimes no Plc was found, or an exception occured.
• Increased the timeout to stop the S7DOS service and added an optional second try, to prevent
that a timeout occurs on slow machines.
Version 1.2.1
• Fixed: Reading multiple TPDUs from TCP-stream corrected. Data from client applications which
used to send more than one unacked PDU are now processed without problems.
Version 1.2.2
• Fixed: Received ISO packets with a length less than 5 bytes were not transferred to Plcsim. This
is possible in fragmented ISO packets.
Version 1.2.3
• Fixed: Fixed memory leak, which may lead to a crash of NetToPLCsim with "Out of memory".
Version 1.2.4
• Improvement: Take the negotiated TPDU size into account for all further packets.
• User interface: Improved dialog to browse and show the available IP addresses of the network
interfaces.
License
NetToPLCsim is free software: you can redistribute it and/or modify it under the terms of the GNU
Lesser General Public License as published by the Free Software Foundation, either version 3 of the
License, or (at your option) any later version.
NetToPLCsim is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License along with
NetToPLCsim. If not, see http://www.gnu.org/licenses/.
10