ModbusASCII Master e
ModbusASCII Master e
Manual
1 2 3 4 5 6 7
SIMATIC Loadable Driver for CP341 Modbus Protocol ASCII Format with 32-Bit Extensions S7 is Master
Manual
Transmission Protocol Interface CPU - CP Diagnostics Driver Application Example Appendices Wiring Diagrams Multipoint Literature List Glossary
A B
Edition 1.0
This manual contains warnings, which you should note for your own safety as well as for the
prevention of damage to property. These warnings are indicated by means of a triangle and displayed as follows in accordance with the level of danger:
_____________________________________________________________________
Danger
indicates that death, severe personal injury or substantial damage will result if proper precautions are not taken.
_____________________________________________________________________ _____________________________________________________________________
Warning
! !
indicates that death, severe personal injury or substantial damage can result if proper precautions are not taken.
_____________________________________________________________________ _____________________________________________________________________
Caution indicates that minor personal injury or property damage can result if proper precautions are not taken.
_____________________________________________________________________ _____________________________________________________________________
Notice draws your attention to particularly important information on the product, handling the product, or to a particular part of the documentation.
_____________________________________________________________________
Qualified Personnel The equipment may be commissioned and put into operation by qualified personnel only. For the purpose of safety relevant warnings of this manual a qualified person is one who is authorized to commission, ground and tag devices, systems and circuits. Please note the following: ____________________________________________________________________________
Correct Usage
Warning This device and its components may only be used for the applications described in the catalog or the technical description, and only in connection with devices or components from other manufacturers which have been approved or recommended by Siemens. This product can only function correctly and safely if it is transported, stored, set up, and installed correctly, and operated and maintained as recommended.
Trademarks
SIMATIC and SINEC are registered trademarks of SIEMENS AG. The other brand names in this manual may be trademarks use of which by third parties for their purposes may infringe the proprietors rights.
Disclaimer of Liability
We have checked the contents of this manual for agreement with the hardware and software described. Since deviations cannot be precluded entirely, we cannot guarantee full agreement. However, the data in this manual are reviewed regularly and any necessary corrections included in subsequent editions. Suggestions for improvement are welcome.
Siemens AG 2006
Subject to change without prior notice.
Preface
Preface
Purpose of this Manual Required Basic Knowledge The information in this manual will enable you to establish and commission a data link between a CP 341 and a Modbus capable control system. You require a general knowledge in the field of automation engineering to be able to understand this manual. In addition, you should know how to use computers or devices with similar functions (e.g. programming devices) under Windows 95/98/2000/NT or XP operating systems. Since loadable driver are based on the STEP 7 software, you should also know how to operate it. This is provided in the manual "Programming with STEP 7 V5.2".
This manual describes the loadable driver functions and how to create a link to the hardware and software of communication processor CP 341. The manual contains the following subjects: Product Description / Installation Commissioning the Driver / Installation / Parameterization Interface CPU-CP Transmission Protocol Diagnostics Driver Application Example
This manual Issue is valid for the following software package: Product Loadable Driver for CP 341 Modbus ASCII Master Identification No. 6ES7870-1CA00-0YA0 from Version 1.0
Note This manual contains the driver description as is valid at the time of publication.
To enable you to access the information in this manual more easily, we would like to draw your attention to the following: The next few pages contain a complete list of contents.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
Preface
Any further information regarding CP 341 (installation, commissioning etc.) can be found in the following manual: SIEMENS SIMATIC CP341 Point to Point Communication Installation and Parameter Assignment Manual C79000-G7076-C341-.. Further information regarding STEP7 can be found in the following manuals: SIEMENS SIMATIC Software Standard Software for S7 and M7 STEP7 User Manual C79000-G7000-C502-.. SIEMENS SIMATIC Software System Software for S7-300/400 System- and Standard Functions Reference Manual C79000-G7000-C503-..
Queries
Should you have any queries regarding the use of the driver described in this manual, which are not answered in this documentation please contact the relevant person at Siemens who supplied you with this driver. This documentation uses the terms CP or CP341. The driver described in this manual serves as a loadable protocol for CP341, which may be used instead of Standard Protocols 3964R, RK512, and ASCII. Note With this driver, modifications or expansions to the sequences between CP and CPU are possible. These modifications and expansions may apply in particular to event classes or event numbers available for diagnostic purposes. Furthermore please note that this manual only describes the modifications and expansions as against the standard functions. Basic information may be found in the manuals mentioned in chapter Further Sources of Information. In order to ensure safe use of the driver, detailed knowledge of the functionality of CP341 is a pre-requisite.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
ii
Contents
Contents
1 Product Description....................................................................................................... 1-1 1.1 1.2 1.3 2 Usage Possibilities............................................................................................ 1-1 Hardware and Software Prerequisites.............................................................. 1-2 Summary of the Modbus Protocol .................................................................... 1-2
Installation ...................................................................................................................... 2-1 2.1 2.2 Use of the Dongle ............................................................................................. 2-1 Interface Connection......................................................................................... 2-1
Commissioning the Driver ............................................................................................ 3-1 3.1 3.2 3.3 3.4 3.5 3.6 3.6.1 3.6.2 3.6.3 3.7 3.8 Installation of the Driver on the STEP7-PG/-PC............................................... 3-1 Uninstalling the Driver....................................................................................... 3-2 Configuring a Data Link CP in Step7................................................................ 3-2 Assigning Parameters to the CP ...................................................................... 3-3 Loading the Driver to the CP ............................................................................ 3-4 Assigning Parameters to the Loadable Driver .................................................. 3-4 Modbus ASCII Protocol .................................................................................... 3-5 RS422/485 (X27) Interface ............................................................................... 3-7 RS232 Secondary Signals................................................................................ 3-8 Loading the Configuration and Parameter Assignment Data ........................... 3-9 Start-up Characteristics of CP341 .................................................................... 3-9
Transmission Protocol .................................................................................................. 4-1 4.1 4.2 4.3 Message Structure............................................................................................ 4-1 Exception Responses ....................................................................................... 4-5 RS 232C Secondary Signals ............................................................................ 4-6
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
iii
Contents
Function Codes .............................................................................................................. 5-1 5.1 5.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 5.10 5.11 5.12 5.13 5.14 5.15 Function Code 01 Read Coils........................................................................ 5-2 Function Code 02 Read Discrete Input ......................................................... 5-3 Function Code 03 Read Holding Registers ................................................... 5-5 Function Code 03 Read 32-Bit Holding Registers......................................... 5-6 Function Code 04 Read Input Registers ....................................................... 5-7 Function Code 05 Write Single Coil............................................................... 5-8 Function Code 06 Write Single Register ....................................................... 5-9 Function Code 06 Write Single 32-Bit Register........................................... 5-10 Function Code 07 - Read Exception Status .................................................. 5-11 Function Code 08 Diagnostics (Loop Back Test) ....................................... 5-12 Function Code 11 Get Comm Event Counter.............................................. 5-13 Function Code 12 Get Comm Event Log...................................................... 5-14 Function Code 15 Write Multiple Coils ........................................................ 5-15 Function Code 16 Write Multiple Registers ................................................. 5-16 Function Code 16 Write Multiple 32-Bit Registers....................................... 5-17
CPU CP Interface......................................................................................................... 6-1 6.1.1 6.1.2 Data Transfer from CPU to CP with P_SND_RK ............................................. 6-1 Data Transfer from CPU to CP with P_RCV_RK ............................................. 6-4
Diagnostics of the Driver............................................................................................... 7-1 7.1 7.2 7.3 7.3.1 7.3.2 7.3.3 Diagnostics via Display Elements (LEDs) ........................................................ 7-1 Diagnostic Messages of the Function Blocks ................................................... 7-2 Table of Errors / Events .................................................................................... 7-3 Error Codes for CPU Job Errors .................................................................... 7-3 Error Codes for Receive Errors...................................................................... 7-4 Error Codes for General Processing Errors ................................................... 7-6
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
iv
Contents
Application Example...................................................................................................... 8-1 8.1 8.1.1 8.1.2 Used Blocks...................................................................................................... 8-1 Program Description ......................................................................................... 8-3 Programming Example ..................................................................................... 8-4
A B
Glossary ....................................................................................................................................... 1
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
Product Description
1
1.1
Product Description
Usage Possibilities
The driver described here is a software product for communication processor CP341. CP341 can be used in automation systems S7-300 and can establish serial communication links to partner systems. This driver enables you to establish a communication link between communication module CP341 and Modbus capable slaves. The transmission protocol used is the Modbus Protocol in ASCII Format. In addition, de-facto standard 32-bit extensions are supported for accessing floating point and double-word registers in compatible slaves. Data transmission is carried out in accordance with the Master-Slave principle. The Master (SIMATIC S7) has the initiative during the transmission. Function codes 01, 02, 03, 04, 05, 06, 07, 08, 11, 12, 15, and 16 can be used for communication between the CP and the slaves.
You can use this driver on a CP341 having a RS232, TTY, or RS422/485 (X27) interface. With this driver, it is possible to use the RS422/485 (X27) interface submodule in both 2-wire operation and 4-wire operation. In 2-wire operation. It is possible to connect up to 32 slaves to one master in half-duplex operation, thus creating a multipoint connection (network).
PSU
CPU
CP341
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
1-1
Product Description
1.2
Useable Module
Dongle
Loading of drivers is possible with STEP 7 from issue level 4.04. An installed version of the Parameter Assignment Tool CP: Point-to-Point Communication, Parameter Assignment V4.1 or higher is required. We recommend to use STEP 7 V5.1 or higher and Parameter Assignment Tool V5.1 or higher.
Data Structures
Prior to project configuration of your S7 data structures, you should ensure that they are compatible with the user programs of the Modbus Slave systems (clarify which function codes and which Modbus addresses will be used).
1.3
Function Codes
Data Exchange
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
1-2
Product Description
Data Areas
As a rule, the individual FCs operates in accordance with the table below: Function Code 01, 05, 15 02 03, 06, 16 04 Data Coil (output) status Input Status Holding Register Input Register Type of Data Bit Bit Register 16 or 32 bit Register 16 or 32 bit Output Input Output Register Input Register Access read/write read only read/write read only
Address Representation
Analogous to the partitioning into read/write and read-only areas, data at user level can be represented as shown in the table below: Function Code 01, 05, 15 02 04 03, 06, 16 Type of Data Example: Address Representation at User Level (Decimal) 0xxxx 1xxxx 3xxxx 4xxxx
In the transmission messages on the serial transmission line, the addresses used in the Modbus user system are referenced to 0. In the Modbus user system itself, these addresses are counted beginning with 1. Example: If the first holding register in the user system is represented as register 40001, in the transmission message the value 0000 Hex is transmitted as the register address when FC 03, 06, or 16 is used to access register 40001 If the 127th coil is represented as coil 00127 in the user system, it is assigned the coil address 007E Hex in the transmission message. Note: The CP341 driver only deals with the transmitted or received zero-based PDU addresses. Any translation from the user level address must be handled in the application program in the S7 PLC or the associated HMI.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
1-3
Installation
2
2.1
Installation
Use of the Dongle
In order to run the CP with loadable drivers, you require a dongle. When the dongle is plugged in, drivers can be loaded. Before you can plug in the dongle, you must take the CP out of the rack. At the back of the CP, above the plugs for the backplane bus, there is a slot into which the dongle can be inserted.
Introduction
2.2
TTY
Interface Connection
A point-to-point connection to one slave can be realized. Further notes to the interface connection please find in the manual CP341 Point to Point Communication.
RS232C
A point-to-point connection to one slave can be realized. It is possible to use RS232 auxiliary signals for, e.g., modem control. Further notes to the interface connection please find in the manual CP341 Point to Point Communication.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
2-1
Installation
X27 (2-wire)
A multipoint connection (network) connecting up to 32 slaves to one Master can be created directly. The driver of the CP performs the switchover of the receive-2-wire line between transmit and receive. Schematic connection: 1 Master system, 1 slave at the bus
S IM A T IC C P 3 4 1 M O D B U S M a s te r
M O D B U S S la ve
T /R (A ) T /R (B ) GND C h a s s is s h ie ld
R (A ) R (B ) GND
4 11 8
C h a s s is s h ie ld
Further notes to the interface connection please find in the manual CP341 Point to Point Communication.
X27 (4-wire)
A Point-to-Point connection to one slave can be created. The direct construction of a multipoint connection (network) connecting more than one slave is not possible. Schematic connection: 1 Master system, 1 Slave
S IM A T IC C P 3 4 1 M O D B U S M a s te r
T (A ) T (B ) R (A ) 2 9 4
M O D B U S S la v e
R (A ) R (B ) T (A ) T (B ) GND C h a s s is s h ie ld
R (B ) 1 1 GND 8
C h a s s is s h ie ld
Further notes to interface connection please find in the manual Point-to-Point Data Link CP341.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
2-2
Commissioning Driver
General Information
3.1
Prerequisites
Installation
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
3-1
Commissioning Driver
3.2
3.3
Introduction
S7-Project
Project Components
Hardware Configuration
The configuration of the hardware comprises defining the hardware components themselves, and also their properties. To start the hardware configuration, select the SIMATIC 300 Station and doubleclick Hardware (or select the menu command Edit Open Object). Use the menu command Insert Hardware Components to insert a RACK- 300, a PS300, a CPU-300 from SIMATIC 300, and the CP PtP from CP-300 with the appropriate part number. A detailed description of how to configure S7-300 modules can be found in the User Manual for STEP 7.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
3-2
Commissioning Driver
3.4
Clicking the Parameter button along the bottom opens the protocol selection interface Parameter Assignment of Point-to-Point Connection. Here you can select the required driver protocol, Modbus ASCII Master, from the drop-down menu. After selecting the Protocol, you can carry out the Parameter Assignment of the Driver (start by double-clicking the envelope symbol labeled Protocol). A detailed description of how to select the protocol and assign parameters to the dialog boxes for the loadable driver can be found in the section Assigning Parameters to the Loadable Driver. After parameter assignment is complete, you return to the Properties - CP dialog box. 2) Properties - CP341 Addresses
No settings are required in the Addresses tab (Properties - CP dialog box). 3) Properties - CP341 General
No settings are required in the General tab (Properties - CP dialog box). You can complete the parameter assignment of the CP by clicking OK in the Properties - CP dialog box. You then return to the Hardware Configuration dialog box. Save the parameter assignment and close the Hardware Configuration dialog box. You return to the basic menu of the STEP 7 project.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
3-3
Commissioning Driver
3.5
The error Module rejected driver download may occur, when the driver files are destroyed. In that case a re-installation of the driver is necessary.
3.6
Protocol Selection
Driver-Specific Parameters
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
3-4
Commissioning Driver
Bit per character Amount of stop bits amount of data bits is completed to an even number amount of data bits is completed to an odd number no parity bit transferred
7 1 even
Transmission Rate
The transmission rate is the speed of data transmission in bits per second (bps). The amount of data bits describes how many bits represent a character to be transmitted. With Modbus ASCII 7 data bits are mandatory. The amount of stop bits defines the smallest possible distance between two characters to be transferred. With even or odd parity 1 stop bit is pre-defined. None parity effects two stop bits. The parity bit is for data safety; depending on parameter assignment, it completes the amount of transmitted data bits to either an even or an odd number. If no parity is selected, no parity bit is transmitted. This reduces the safety of data transmission.
Data Bits
Stop Bits
Parity
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
3-5
Commissioning Driver
Protocol Parameters Parameter Character delay time Response time-out Turnaround delay Operating mode Description Time period used to monitor the incoming characters within a message Time to monitor the start of the reply from the slave Waiting time after sending a broadcast message Normal Operation Interference Suppression Registers can also imply 32-bit values Normal Interference Suppression not selected selected Normal Value range 1 to 6500 milliseconds in 1ms intervals 5 to 65500 milliseconds in 1ms intervals Default value 1000ms
2000
32-Bit mode
not selected
When receiving a message the quiet time between characters is measured. If the quiet time exceed the the character delay time, the message is ignored and an error is reported. The reply monitoring time is the time the master spends waiting for a reply message from the slave after output of a request message. If the start character is not received within the response timeout, the message is ignored and an error is reported. When a broadcast request is sent, no response is returned from the slaves. Nevertheless a delay is respected by the Master in order to allow any slave to process
the current request before sending a new one. This delay is called turnaround delay. The turnaround delay should be shorter than the response timeout.
Response Timeout
Turnaround Delay
After the CP has sent the last character of a broadcast message it waits the turnaround delay before the send job is completed. If the turnaround delay is set to 0, the CP completes the send job immediately after sending the last character of the request. Reply Monitoring Time The reply monitoring time is the time the master spends waiting for a reply message from the slave after output of a request message. If the slave doesnt send a start character during the reply monitoring time the send job is finished with error.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
3-6
Commissioning Driver
Normal Operation
In this operating mode, all recognized transmission errors and/or BREAK before and after receive messages from the slave result in an appropriate error message. If BREAK is recognized on the receiving line at the start of the receive message, or if the CP interface block notices transmission errors before the message, no error is reported. The start of the receive message from the slave is recognized by means of the correctly-received start character. Transmission errors and/or BREAK are also ignored when they occur after the end of the receive message.
Interference Suppression
32-Bit Mode
Normally registers are 16-bit values. When choosing 32-bit mode, registers can also imply 32-bit values when supported in the addressed slave.
X27-Operation Via the transmission line T(A), mode T(B) data are sent, via the receiving line R(A), R(B) data are received. The receiving line R(A),R(B) is changed-over from send to receive operation. "Full-duplex / fourwire-operation
Full-duplex / four-wireoperation
In this operating mode, data are sent via the transmission line T(A),T(B) and received via the receiving line R(A),R(B). Error handling is carried out in accordance with the function set at the Driver Operating Mode parameter (Normal or Interference Suppression). In this operating mode, the driver switches the 2-wire receiving line R(A),R(B) of the interface from send to receive operation. In this operating mode, all recognized transmission errors and/or BREAK before and after receive messages are ignored. BREAK level during message pauses is also ignored. The beginning of the receive message from the slave is recognized by means of the correctlyreceived colon character. The setting R(A) 0V, R(B) 5V (High) is recommended as the preset for the receiving line.
"Halfduplex / twowire-operation
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
3-7
Commissioning Driver
None (Float) The two-wire-line R(A),R(B) is not preset. In this instance the link partner should carry out assignment. Presetting R(A) 5V, R(B) 0V (BREAK) The two-wire-line R(A),R(B) is preset by the CP as follows: R(A) --> +5V, R(B) --> 0V (VA - VB +0,3V). This means that BREAK level occurs on the CP in the event of a line break. Presetting R(A) 0V, R(B) 5V (High) The two-wire-line R(A),R(B) is preset by the CP as follows: R(A) --> 0V, R(B) --> +5V (VA - VB -0,3V). This means that HIGH level occurs on the CP in the event of a line break (and / or when it is running idle, i.e. no slave is transmitting). Line status BREAK cannot be recognized.
Default value no
Automatic use RS232 secondary signals are of RS232 enabled signals Time to RTS OFF Data output waiting time Automatic Use of RS232 Signals
Time to elapse after the transmission before the CP sets the RTS line to OFF Delay before the CP starts sending of a telegram
1s
1s
With this parameter you can choose whether RS 232 C secondary signals are used or not. If no secondary signals are parameterized, the CP neither sets nor checks these signals. The description of the used secondary signal please find in Chapter 4 of this manual.
After output of a request the CP waits the defined time to set the RTS line to OFF. The data output waiting time is the time that the CP 341 is to wait for the communication partner to set CTS to ON after setting the RTS line to ON and before starting the transmission.
Selecting Parameters
Select the parameters required for your data link and exit the individual dialog boxes by clicking OK. 3-8
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
Commissioning Driver
3.7
Data Management
Further Information
Please refer to the User Manual for STEP7 for detailed description on: how to save the configuration and the parameters. how to load the configuration and the parameters into the CPU. how to read, change, copy and print the configuration and the parameters.
3.8
Introduction
Initialization
Parameter Assignment
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
3-9
Transmission Protocol
Transmission Protocol
The procedure in use is asynchronous and half-duplex. Data transmission is carried out without handshake. The CP initiates the transmission (= Master), and after outputting a request message it waits for a reply message from the slave for the duration of the parameter reply monitoring time . When devices are setup to communicate on a Modbus serial line using ASCII mode, each 8bit byte in a message is sent as two ASCII characters. The allowable characters transmitted for all fields except the start character and end characters are hexadecimal 09, AF (ASCII coded). Example: The byte 0X5B is encoded as two characters: 0x35 and 0x42 (0x35 ="5", and 0x42 ="B" in ASCII ).
ASCII-Mode
4.1
Message Structure
The data exchange Master-Slave and/or Slave-Master begins with the Start Character, followed by Slave Address and Function Code. Then the data are transferred. The structure of the data field depends on the function code used. The LRC check is transmitted at the end of the message, followed by the End Characters. START 1 char colon ADDRESS FUNCTION 2 chars 2 chars DATA 0 up to 2x252 char(s) LRC 2 chars END 2 chars CR, LF
Message Structure
Start Character : Modbus Slave Address Modbus Function Code Data: Byte_Count, Coil_Number, Data Message Checksum End Characters CR, LF
The start character is a colon (0x3A). The devices monitor the bus continuously for the colon character. When this character is received, each device decodes the next character until it detects the End Characters (CR,LF). The slave address can be within the range 1 to 255. The address is used to address a defined slave on the bus.
Slave Address
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
4-1
Transmission Protocol
Broadcast Message
The master uses slave address zero to address all slaves on the bus. Broadcast Messages are only permitted in conjunction with writing Function Codes 05, 06, 15, and 16. A Broadcast Message is not followed by a reply message from the slave. After a broadcast message the CP waits for a time determined by the turnaround delay parameter before the send job is finished.
Function Code
The function code defines the meaning as well as the structure of a message. The following function codes are supported by the driver: Function Code 01 02 03 04 05 06 07 08 11 12 15 16 Function in Accordance with Modbus Specification Read Coils Read Discrete Inputs Read Holding Registers Read Input Registers Write Single Coil Preset Single Register Read Exception Status Loop Back Diagnostic Test Fetch Communications Event Counter Fetch Communications Event Log Write Multiple Coils Write Multiple Registers
The data field DATA is used to transfer the function code-specific data such as: Bytecount, Coil_Start Address, Register_Start Address; Number_of_Coils, Number_of_Registers, ... . See also Chapter Function Codes. The data field contains up to 2x252 ASCII characters.
LRC
The Longitudinal Redundancy Checking (LRC) field is one byte, containing an 8 bit binary value. The LRC value is calculated by the transmitting device, which appends the LRC to the message. The device that receives recalculates an LRC during receipt of the message, and compares the calculated value to the actual value it received in the LRC field. If the two values are not equal, an error results. The LRC is calculated by adding together successive 8bit bytes in the message, discarding any carries, and then twos complementing the result. The LRC is an 8bit field, therefore each new addition of a character that would result in a value higher than 255 decimal simply rolls over the fields value through zero. Because there is no ninth bit, the carry is discarded automatically.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
4-2
Transmission Protocol
A procedure for generating an LRC is: 1. Add all bytes in the message, excluding the starting colon and ending CRLF. Add them into an 8bit field, so that carries will be discarded. 2. Build the twoscomplement. 3. Convert the LRC to ASCII. Placing the LRC into the Message When the 8bit LRC (2 ASCII characters) is transmitted in the message, the highorder character will be transmitted first, followed by the loworder character. For example, if the LRC value is 61 hex (0110 0001): LRC high 0x36 LRC low 0x31 Message End Telegram Example The end of the message is defined by the characters CR and LF. The Modbus serial line PDU is describes as follows: 05H 08H 00H 00H A5H C3H xxH Slave Address Function Code Diagnostic Code High Diagnostic Code Low Test Value High Test Value Low LRC
In ASCII transmission mode the following data is transferred on the line: 3AH 30H 35H 30H 38H 30H 30H 30H 30H 41H 35H 43H 33J xxH xxH 0DH 0AH Start Character Slave Address Function Code Diagnostic Code High Diagnostic Code Low Test Value High Test Value Low LRC Code High LRC Code Low CR LF
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
4-3
Transmission Protocol
Error Handling
If BREAK is recognized on the receiving line by the CP during output of a message, the triggered P_SND_RK job is completed with error. Reception during transmission is ignored. If any of the errors listed below is recognized by the CP during reception of the reply message, the received data string is rejected, an error is reported and the triggered Send job is completed with error. reply monitoring time elapsed wrong start character received character is no ASCII character overrun of the receive buffer received LRC incorrect transmission error in a character (parity, framing or overrun error) character delay time elapsed BREAK (line break or DSR or CTS not asserted)
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
4-4
Transmission Protocol
4.2
Exception Responses
On recognition of an error in the request message from the master (for example, register address illegal), the slave sets the highest value bit in the function code of the reply message. This is followed by transmission of one byte of error code (Exception Code), which describes the reason for the error. A detailed description of the meaning of the above-mentioned parameters can be found in the Modbus Application Protocol Specification.
Exception Responses
The error code reply message from the slave has the following structure: for example, slave address 5, function code 5, exception code 2 Reply Message from Slave EXCEPTION_CODE_xx: 05H 85H 02H xxH Slave Address Function Code Exception Code (1 to 7) LRC
On receipt of an error code reply message by the driver, the current job is completed with error. An error number corresponding to the received error code (Exception Code 1-7) is also entered in the STATUS area. No entry is made in a P_RCV_RK destination data block. The following error codes are defined in accordance with the Modbus Specification: Exception Meaning in accordance with Cause Short Description * Code Modbus Specification 01 02 03 04 05 06 07 Illegal Function Illegal Data Address Illegal Data Value Failure in Associated Device Acknowledge Busy, Rejected Message Negative Acknowledgement Illegal function code Slave has illegal data address Slave has illegal data value Slave has internal error Function is carried out Slave is not ready to receive Function cannot be carried out
* Check slave for further details.Not all are supported by driver. See Modbus spec for detailed descriptions.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
4-5
Transmission Protocol
4.3
Available Signals
DCD
(input)
Data carrier detect; Data carrier detected Data terminal ready; CP ready for operation Data set ready; Communication partner ready for operation Request to send; CP ready to send Clear to send; Communication partner can receive data from the CP (response to RTS = ON of the CP) Ring indicator; Indication of an incoming call
DTR
(output)
DSR
(input)
RTS
(output)
CTS
(input)
RI
(input)
When the CP is switched on, the output signals are in the OFF state (inactive). You can parameterize the way in which the DTR/DSR and RTS/CTS control signals are used with the CP 341: Point-to-Point Communication, Parameter Assignment parameterization interface or control them by means of function calls (FBs) in the user program. Using the RS 232C Secondary Signals The RS 232C secondary signals can be used as follows: When the automatic use of all RS 232C secondary signals is parameterized By means of the V24_STAT and V24_SET functions (FBs)
Note When automatic use of the RS 232C secondary signals is parameterized, neither RTS/CTS data flow control nor RTS and DTR control by means of the V24_SET FB are possible. On the other hand, it is always possible to read all RS 232C secondary signals by means of the V24_STAT FB. The sections that follow describe how the control and evaluation of the RS 232C secondary signals is handled.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
4-6
Transmission Protocol
The automatic use of the RS 232C secondary signals on the CP is implemented as follows: As soon as the CP is switched by means of parameterization to an operating mode with automatic use of the RS 232C secondary signals, it switches the RTS line to OFF and the DTR line to ON (CP ready for use). Message frames cannot be sent and received until the DTR line is set to ON. As long as DTR remains set to OFF, no data is received via the RS 232C interface. If a send request is made, it is aborted with an error message. When a send request is made, RTS is set to ON and the parameterized data output waiting time starts. When the data output time elapses and CTS = ON, the data is sent via the RS 232C interface. If the CTS line is not set to ON within the data output time so that data can be sent, or if CTS changes to OFF during transmission, the send request is aborted and an error message generated. After the data is sent, the RTS line is set to OFF after the parameterized time to RTS OFF has elapsed. The CP does not wait for CTS to change to OFF. Data can be received via the RS 232C interface as soon as the DSR line is set to ON. If the receive buffer of the CP threatens to overflow, the CP does not respond. A send request or data receipt is aborted with an error message if DSR changes from ON to OFF. The message "DSR = OFF (automatic use of V24 signals)" is entered in the diagnostics buffer of the CP.
Note When automatic use of the RS 232C secondary signals is parameterized, neither RTS/CTS data flow control nor RTS and DTR control by means of the V24_SET FB are not possible. Note The "time to RTS OFF" must be set in the parameterization interface so that the communication partner can receive the last characters of the message frame in their entirety before RTS, and thus the send request, is taken away. The "data out put waiting time" must be set so that the communication partner can be ready to receive before the time elapses.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
4-7
Transmission Protocol
Time Diagram
Figure 4-1 Time Diagram for Automatic Use of the RS 232C Secondary Signals
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
4-8
Function Codes
Function Codes
All telegram examples for the different function codes refer to Modbus serial line PDU format. The register oriented function codes 3, 6, 16 can also handle 32-bit registers. If Protocol Parameter for Modbus-Master With 32-bit Registers is set the driver is prepared to handle registers with the length of 4 byte. The decision whether the send job refers to 16-bit or 32-bit registers is done via the second byte of the send data block. The second byte of the send data block determines the Modbus Function Code sent in the message. If bit 26 (the bit to the right of the most significant bit) is set, the send job refers to 32-bit registers. Bit 26 doesnt affect the function code actually sent, it is just information for the master CP for what to expect in the response from the slave when reading or what to send when writing. The register(s) accessed in the slave when bit 26 is set must be within a 32-bit register address range defined in the slave such that 4 bytes per register is returned in the read response or 4 bytes per register are expected in a write request. If bit 26 is set and a normal 2 bytes per register range is read in the slave, 2 bytes per register is returned by the slave. As the master expects more data, the activated send job is finished with error. Likewise, bit 26 is not set and a 4 bytes per register range is read in the slave, 4 bytes per register is returned by the slave. The master receives more data than expected and the activated send job is finished with error. If bit 26 is set and a normal 2 bytes per register range is written to the slave, 4 bytes per register are sent by the master and the slave should returned an exception response to the master. Likewise, if bit 26 is not set and a 4 bytes per register range is written to the slave, 2 bytes per register are sent by the master and the slave should returned an exception response to the master.
General
32-Bit Registers
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-1
Function Codes
5.1
Amount of Bits Any value between 1 and 2008 is permitted as the amount of bits (number of coils). SEND Source DB Structure of SEND Source Area:
Address +0.0 +1.0 +2.0 +4.0 Name address function bit_startadr bit_count Type BYTE BYTE WORD INT Start value B#16#5 B#16#1 W#16#0040 15 Comment Slave Address Function Code Bit Start Address Amount of Bits
Example
Request Message FUNCTION 01: 05H 01H 00H 40H 00H 0FH xxH Slave Address Function Code Bit Start Address High Bit Start Address Low Amount of Bits High Amount of Bits Low LRC
Reply Message from Slave FUNCTION 01: 05H 01H 02H 01H F7H xxH Slave Address Function Code Byte Counter <Data> Coil 47H..40H <Data> Coil 4EH..48H LRC
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-2
Function Codes
RCV Destination DB
The driver enters the data of the reply message into the destination DB wordby-word. The 1st received byte is entered as the Low Byte of the 1st word data[1], the 2nd received byte is entered as the High Byte of the 1st word data[1], and the 3rd received byte as the Low Byte of the 2nd word data[2], etc. If an odd number of bytes are returned, the value 00H is entered into the High Byte of the last word. Any unaccessed bits in the last received byte are masked to zero in the destination byte regardless of the received value.
5.2
Amount of Bits
Any value between 1 and 2008 is permitted as the amount of bits (number of DIs) Structure of SEND Source Area:
Address +0.0 +1.0 +2.0 +4.0 Name address function bit_startadr bit_count Type BYTE BYTE WORD INT Start value B#16#5 B#16#2 W#16#0120 24 Comment Slave Address Function Code Bit Start Address Amount of Bits
SEND Source DB
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-3
Function Codes
Example
Request Message FUNCTION 02: 05H 02H 01H 20H 00H 18H xxH Slave Address Function Code Bit Start Address High Bit Start Address Low Amount of Bits High Amount of Bits Low LRC
Reply Message from Slave FUNCTION 02: 05H 02H 03H 04H 26H C8H xxH RCV Destination DB Slave Address Function Code Byte Counter <Data> DI 127H..120H <Data> DI 12FH..128H <Data> DI 137H..130H LRC
The driver enters the data of the reply message into the destination DB word-byword. The 1st received byte is entered as the Low Byte of the 1st word data[1], the 2nd received byte is entered as the High Byte of the 1st word data[1], and the 3rd received byte as the Low Byte of the 2nd word data[2], etc. If an odd number of bytes are returned, the value 00H is entered into the High Byte of the last word. Any unaccessed bits in the last received byte are masked to zero in the destination byte regardless of the received value
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-4
Function Codes
5.3
Example
Request Message FUNCTION 03: 05H 03H 00H 40H 00H 02H xxH Slave Address Function Code Register Start Address High Register Start Address Low Amount of Register High Amount of Register Low LRC
Reply Message from Slave FUNCTION 03: 05H 03H 04H 21H 23H 25H 27H xxH RCV Destination DB Slave Address Function Code Byte Counter Register Address 40H Data High Register Address 40H Data Low Register Address 41H Data High Register Address 41H Data Low LRC
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-5
Function Codes
5.4
Request Message FUNCTION 03: Example 05H 03H 00H 40H 00H 02H xxH Slave Address Function Code Register Start Address High Register Start Address Low Amount of Register High Amount of Register Low LRC
Reply Message from Slave FUNCTION 03: 05H 03H 08H 21H 22H 23H 24H 25H 26H 27H 28H xxH RCV Destination DB Slave Address Function Code Byte Counter Register Address 40H Data Byte 1 Register Address 40H Data Byte 2 Register Address 40H Data Byte 3 Register Address 40H Data Byte 4 Register Address 41H Data Byte 1 Register Address 41H Data Byte 2 Register Address 41H Data Byte 3 Register Address 41H Data Byte 4 LRC
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-6
Function Codes
5.5
Example
Request Message FUNCTION 04: 05H 04H 00H 50H 00H 03H xxH Slave Address Function Code Register Start Address High Register Start Address Low Amount of Register High Amount of Register Low LRC
Reply Message from Slave FUNCTION 04: 05H 04H 04H 31H 32H 33H 34H 35H 36H xxH RCV Destination DB Slave Address Function Code Byte Counter Register Address 50H Data High Register Address 50H Data Low Register Address 51H Data High Register Address 51H Data Low Register Address 52H Data High Register Address 52H Data Low LRC
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-7
Function Codes
5.6
Bit Status
The following two values are valid as the Bit Status: FF00H set bit to logical 1 0000H reset bit to logical 0. Structure of SEND Source Area:
Address +0.0 +1.0 +2.0 +4.0 Name address function bit_address bit_state Type BYTE BYTE WORD WORD Start value B#16#5 B#16#5 W#16#0019 W#16#FF00 Comment Slave Address Function Code Bit Address Bit Status
SEND Source DB
Example
Request Message FUNCTION 05: 05H 05H 00H 19H FFH 00H xxH Slave Address Function Code Bit Address High Bit Address Low Set Bit LRC
Reply Message from Slave FUNCTION 05: 05H 05H 00H 19H FFH 00H xxH Slave Address Function Code Bit Address High Bit Address Low Bit Status High Bit Status Low LRC
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-8
Function Codes
5.7
Example
Request Message FUNCTION 06: 05H 06H 01H 80H 3EH 7FH xxH Slave Address Function Code Register Address High Register Address Low Register Value High Register Value Low LRC
Reply Message from Slave FUNCTION 06: 05H 06H 01H 80H 3EH 7FH xxH Slave Address Function Code Register Address High Register Address Low Register Value High Register Value Low LRC
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-9
Function Codes
5.8
Example
Request Message FUNCTION 06: 05H 06H 01H 80H 11H 22H 33H 44H xxH Slave Address Function Code Register Address High Register Address Low Register Value Byte 1 Register Value Byte 2 Register Value Byte 3 Register Value Byte 4 LRC
Reply Message from Slave FUNCTION 06: 05H 06H 01H 80H 11H 22H 33H 44H xxH Slave Address Function Code Register Address High Register Address Low Register Value Byte 1 Register Value Byte 2 Register Value Byte 3 Register Value Byte 4 LRC
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-10
Function Codes
5.9
Function
SEND Source DB
Example
Request Message FUNCTION 07: 05H 07H xxH Slave Address Function Code LRC
Reply Message from Slave FUNCTION 07: 05H 07H 3EH xxH RCV Destination DB Slave Address Function Code <Data> LRC
The driver enters the individual bits of the reply message into the High Byte in the destination DB data[1]. The Low Byte of data[1] remains unchanged. Value 1 is displayed as the length in parameter LEN of P_RCV_RK.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-11
Function Codes
Example
Request Message FUNCTION 08: 05H 08H 00H 00H A5H C3H xxH Slave Address Function Code Diagnostic Code High Diagnostic Code Low Test Value High Test Value Low LRC
Reply Message from Slave FUNCTION 08: 05H 08H 00H 00H A5H C3H xxH Slave Address Function Code Diagnostic Code High Diagnostic Code Low Test Value High Test Value Low LRC
The slave must return the request message to the master unchanged (echo). The reply message is not entered into an RCV DB.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-12
Function Codes
SEND Source DB
Example
Request Message FUNCTION 11: 05H 0BH xxH Slave Address Function Code LRC
Reply Message from Slave FUNCTION 11: 05H 0BH FEH DCH 01H 08H xxH RCV Destination DB Slave Address Function Code Status Word High Status Word Low Event Counter High Event Counter Low LRC
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-13
Function Codes
SEND Source DB
Example
Request Message FUNCTION 12: 05H 0CH xxH Slave Address Function Code LRC
Reply Message from Slave FUNCTION 12: 05H 0CH 46H 87H 65H 01H 08H 02H 20H 01H 12H C2H D2H xxH RCV Destination DB Slave Address Function Code Byte Counter Status Word High Status Word Low Event Counter High Event Counter Low Message Counter High Message Counter Low Event Byte 1 Event Byte 2 Event Byte 63 Event Byte 64 LRC
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-14
Function Codes
Amount of Bits
SEND Source DB
Example
Request Message FUNCTION 15: 05H 0FH 00H 50H 00H 0AH 02H CDH EFH xxH Slave Address Function Code Bit Address High Bit Address Low Amount of Bits High Amount of Bits Low Byte Counter Status Coil 57H ..50H Status Coil 59H ..58H LRC
Reply Message from Slave FUNCTION 15: 05H 0FH 00H 50H 00H 0AH xxH Slave Address Function Code Bit Address High Bit Address Low Amount of Bits High Amount of Bits Low LRC
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
5-15
Function Codes
Start Address
Amount of Registers
Example
Request Message FUNCTION 16: 05H 10H 00H 60H 00H 03H 06H 41H A1H 42H A2H 43H A3H xxH Slave Address Function Code Register Address High Register Address Low Amount of Registers High Amount of Registers Low Byte Counter <reg_data[1]> High <reg_data[1]> Low <reg_data[2]> High <reg_data[2]> Low <reg_data[3]> High <reg_data[3]> Low LRC
Reply Message from Slave FUNCTION 16: 05H 10H 00H 60H 00H 03H xxH Slave Address Function Code Register Address High Register Address Low Amount of Registers High Amount of Registers Low LRC 5-16
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
Function Codes
Start Address
Amount of Registers
SEND Source DB
Example
Request Message FUNCTION 16: 05H 10H 01H 20H 00H 02H 08H 51H A1H 52H A2H 53H A3H 54H A4H xxH Slave Address Function Code Register Address High Register Address Low Amount of Registers High Amount of Registers Low Byte Counter <reg_data[1]> Byte 1 <reg_data[1]> Byte 2 <reg_data[1]> Byte 3 <reg_data[1]> Byte 4 <reg_data[2]> Byte 1 <reg_data[2]> Byte 2 <reg_data[2]> Byte 3 <reg_data[2]> Byte 4 LRC
Reply Message from Slave FUNCTION 16: 05H 10H 01H 20H 00H 02H xxH Slave Address Function Code Register Address High Register Address Low Amount of Registers High Amount of Registers Low LRC 5-17
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
CPU CP Interface
CPU CP Interface
Data transfer between CP and CPU is carried out by means of FBs P_SND_RK (FB8) and P_RCV_RK (FB7). FB P_SND_RK is activated by an edge at input REQ, when data output is required. FB P_RCV_RK is made ready to receive by EN_R=1. A P_RCV_RK is required for all reading function codes.
Used SFBs
At a given time, only one FB P_SND_RK and one FB P_RCV_RK can be called for each CP 341 in the user program.
Activation
Execution of a Modbus function code is activated by means of an SFB P_SND_RK with an edge at input REQ. Enter S for SEND at the SF parameter. The logical module address is entered at LADDR. You must enter X for expanded data block as the area type of the partner CPU. No values must be specified for the other parameters of the partner CPU (R_...). This ensures transfer to the driver of the function codes required for the execution.
Data Source
When P_SND_RK is activated, the source data area specified with the parameters DB_NO and DBB_NO is transferred to the CP with the length LEN.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
6-1
CPU CP Interface
Length Indication
The length LEN depends on the function code used. Function Code 01 02 03 04 05 06 16-Bit Register 06 32-Bit Register 07 08 11 12 15 16 16-Bit Register 16 32-Bit Register Length LEN in Byte 6 6 6 6 6 6 8 2 6 2 2 >=8 >=8 >=10
If the transferred data quantities differ from those listed above for the individual function codes, the job is not carried out and P_SND_RK rejects it with an edge at output ERROR. The data length LEN may exceed the required amount of data for the activated function. The driver checks the data length according to function code and amount of bits/registers. If less data than necessary are transferred to the CP, the send job is finished with error. So it is not necessary to calculate LEN for each send job, when the maximum length is used. But it takes some more time for data transfer CPU CP because more data than needed are transferred. SEND Source DB The parameters required for the execution of a function code must be entered as user data in the source data area. A detailed description of each P_SND_RK source DB can be found in the chapter Function Codes.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
6-2
CPU CP Interface
Generation of Messages
The request messages to the slave are generated in accordance with the transferred P_SND_RK source data and sent by the CP. First of all the driver checks if the length LEN specified at P_SND_RK corresponds to the length for this function code. If it does not, the job is not carried out and it is completed with an edge at output ERROR of the P_SND_RK. When using function codes other than those listed, the activated job is not carried out either and is completed with ERROR at P_SND_RK. The elements byte counter and LRC in the request message are generated by the CP; an entry in the P_SND_RK source DB is not required.
For writing function codes, the activated P_SND_RK is completed after a reply message is received without error. This is communicated to the SIMATIC user program by means of an edge at output DONE of the P_SND_RK. If errors were recognized during the message exchange, or if the slave sends an error code reply message, this is reported by an edge at output ERROR.
For reading functions, the activated P_SND_RK is completed after the reply message is received without error and complete transfer of the received data to the CPU. This is communicated to the SIMATIC user program by means of an edge at output DONE of the P_SND_RK. This means that the received data are already available on the CPU. If errors were recognized during the message exchange, or if the slave sends an error code reply message, this is reported by an edge at output ERROR. In this case no receive data are transferred to the CPU.
For those instances when a job is completed with ERROR at P_SND_RK, an additional error code is entered in the STATUS parameter. The exact cause for the error can be determined with this error code.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
6-3
CPU CP Interface
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
6-4
Diagnostics Functions
The display elements provide information on the operating status and/or a possible error status of the CP. The display elements give a first overview of internal or external errors, as well as interface-specific errors. Each function block has a STATUS output for error diagnostics purposes. Reading this STATUS output enables the user to obtain information on errors which occurred during communication. The STATUS parameter can be evaluated in the user program. All errors / events described in Section 7.3 are also entered in the diagnostic buffer of the CP. The manual for the CP describes how you can read the diagnostic buffer.
7.1
Introduction
- SF (red) Error occurred or new parameters assigned Special Displays Send active; lights up when the CP 341 sends user data via the interface Receive active; lights up when the CP 341 receives user data via the interface
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
7-1
The group error display SF always lights up after power-on and goes out after initialization is complete. If parameter assignment data were created for the CP 341, the SF LED lights up again briefly when new parameters are loaded. The group error display SF lights up, when the following errors have occurred: Hardware error Firmware error Parameter assignment error BREAK (Receiving line between CP 341 and communication partner is interrupted or CTS or DSR signals not asserted at the connector.)
7.2
Introduction
The following figure shows the structure of the STATUS parameter. Bit-No. 15 13 12 8 7 0
Reserve
Event Class
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
7-2
7.3
Event Classes
Described in
CP Manual CP Manual CP Manual CP Manual CP Manual, Driver Manual CP Manual CP Manual Driver Manual Not used Not used Driver Manual
Event Text
Remedy
24
Transmission length during transmission is too large (> 4 Kbytes), or transmission length for SEND is too small.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
7-3
Event Text
Remedy
Eliminate error in partner device or interference on the transmission line or increase the value of the Character Delay Time parameter. Check for interference which could influence the transmission line. If required, change system structure and/or cable laying. Check whether the protocol parameters transmission rate, amount of data bits, parity, and amount of stop bits have the same settings for the CP and the link partner. Establish connection between the devices or switch on partner device. Make sure CTS and DSR are asserted at the CP connector. For use with TTY operation, check line current at idle state. For use with an RS422/485 (X27) connection, check and, if required, change the connector pin assignment of the 2-wire receiving line R(A), R(B). The partner has switched the DSR or CTS signal to OFF before or during a transmission. Check the partners control of the RS 232C secondary signals.
08 0CH
Transmission error (parity error, overflow error, stop bit error (frame)) recognized in a character.
08 0DH
08 18H
24
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
7-4
Event Class 8 (08H) CPU Receive Errors 08 30H 48 A request message has been sent and the reply monitoring time has elapsed without the start of a reply message being recognized. Check if transmission line is interrupted (interface analyzer may be required). Check if the protocol parameters transmission rate, amount of data bits, parity, and amount of stop bits have the same settings in CP and the link partner. Check if the value for the Response Time-out parameter is big enough. Check if the specified slave address exists.
08 32H 08 33H
50 51
Overflow of receive buffer in CP during Check protocol settings for the slave. reception of the reply message. A wrong start character was received. Check protocol settings for the slave. The start character was not a colon (3AH). A start character was received within a telegram. The first part of the telegram is discarded and reception starts again with the second start character. Check if transmission line is interrupted (interface analyzer may be required). This does not in itself fail the send job. The error only appears in the CP diagnostic buffer.
08 34H
52
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
7-5
Event Text
Remedy
1 2 3
Error during initialization of the driver-specific SCC process Error during initialization of the driver-specific SCC process Error during startup of driver: Wrong data transfer process active (interface to SFBs). The driver cannot function with this data transfer process. Error during startup of driver: Illegal interface submodule. The driver cannot run with the parameterized interface submodule. Error with driver dongle: No dongle plugged in, or inserted dongle is faulty. The driver is not ready to run. Error with driver dongle: The dongle has no valid contents. The driver is not ready to run. Internal error procedure: default branch in procedure automatic device. Internal error procedure: default branch for procedure status Send / Receive. Internal error active automatic device: default branch. Internal error passive automatic device: default branch.
Reassign parameters of driver and reload. Reassign parameters of driver and reload. Reassign parameters of driver and reload.
0E 04H
Check and correct parameter assignment. Check if a driver dongle is plugged into the CP. If the inserted dongle is faulty, replace it with a correct dongle. Obtain a correct dongle from the Siemens office which supplied you with the driver. Restart CP (Mains_ON) Restart CP (Mains_ON)
0E 05H
0E 06H
0E 10H 0E 11H
16 17
0E 12H 0E 13H
18 19
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
7-6
Event Class E (0EH) Loadable Driver General Processing Errors <Parameter Assignment> Event Class/ No. (Hex) 0E 20H Event Number
(Decimal)
Event Text
Remedy
32
For this data link, the amount of data bits must be set to 7. The driver is not ready to run. The Character Delay Time parameter is not within the range of 1 to 6500 milliseconds. The driver is operating with a default value of 1000 milliseconds The operating mode set for the driver is illegal. Normal operation or Interference Suppression must be specified. The driver is not ready to run. An illegal value for parameter Response Timeout has been set: Valid values are 5 to 65500ms. The driver is operating with a default value of 2000 milliseconds. An error occurred when reading the interface parameter file. The driver is not ready to run.
Correct parameter assignment of the driver. Load driver parameters. Correct parameter assignment of the driver. Load driver parameters Correct parameter assignment of the driver. Load driver parameters. Correct parameter assignment of the driver. Load driver parameters.
0E 21H
33
0E 22H
34
0E 23H
35
0E 2EH
46
Restart CP (Mains_ON)
Event Class 5 (05H) Loadable Driver General Processing Errors <CPU - CP> Event Class/ No. (Hex) 0E 30H 0E 31H 0E 32H Event Number
(Decimal)
Event Text
Remedy
48 49 50
Internal error during data transfer to CPU: Unexpected acknowledgment Passive. Timeout during data transfer to CPU. Error occurred during data transfer to CPU with RCV: Exact failure reason (detailed error) is in diagnostic buffer before this entry.
Can be ignored if it happens intermittently. Check CP-CPU interface. Check CP-CPU interface.
0E 33H
51
Internal error during data transfer to CPU: Illegal Check CP-CPU interface. status of automatic device.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
7-7
Event Class 5 (05H) Loadable Driver General Processing Errors <Processing of a Send Job> Event Class/ No. (Hex) 0E 40H 0E 41H Event Number
(Decimal)
Event Text
Remedy
64 65
Value specified for parameter LEN at SFB SEND too small. Value specified for parameter LEN at SFB SEND too small. A greater length is required for the transferred function code. Transferred function code is illegal.
Minimum length is 2 bytes. The minimum length for this function code is 6 bytes. The only function codes which are permitted are those listed in the chapter Function Codes. Only use Slave Address 0 for the suitable function codes. Correct your source DB Correct your source DB
0E 42H
66
67 68 69
Slave Address 0 (= Broadcast) not permitted with this function code. The value of the transferred parameter Amount of Bits is not within the range 1 to 2008. The value of the transferred parameter Amount of Registers is not within the range 1 to 125 or, for 32-bit registers, 1 to 62. Function codes 15 or 16: The values of the transferred parameters Amount of Bits and/or Amount of Registers are not within the range 1 to 1976 and/or 1 to 123 and/or, for 32-bit registers, 1 to 61. Function codes 15 or 16: The parameter LEN for SFB SEND does not correspond to the transferred parameters Amount of Bits and/or Amount of Registers. Parameter LEN is too small.
0E 46H
70
0E 47H
71
Increase parameter LEN for SEND until a sufficient amount of user data is transferred to the CP. A larger amount of user data must be transferred to the CP because of the Amount of Bits and/or Amount of Registers. Correct your source DB. Only the value FF00H or 0000H are allowed for writing a coil. The only permitted code is Diagnostic Code 0000H. Correct your source DB.
0E 48H
72
0E 49H
73
0E 4AH
74
Function code 5: The code specified in SEND source DB for Set Bit (FF00H) or Delete Bit (0000H) is wrong. Function code 8: The code specified in SEND source DB for Diagnostic Code is wrong. Access to 32-bit registers is only allowed with function code 03, 06, 16. (Bit 26 of function code in source DB is set.) The R_TYP specified for SFB SEND RK is illegal with this driver.
0E 4FH
79
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
7-8
Event Class E (0EH) Loadable Driver General Processing Errors <Receive Evaluation> Event Class/ No. (Hex) 0E 50H Event Number
(Decimal)
Event Text
Remedy
80
Slave address incorrect: The received slave address is different from the sent slave address. Function code incorrect: The function code received in the reply message is different from the sent function code. Byte Underflow: Amount of characters received is less than should have resulted from the byte counter of the reply message, or is less than expected with this function code. Byte Overflow: Amount of characters received is more than should have resulted from the byte counter of the reply message, or is more than expected with this function code. Byte counter wrong: The byte counter received in the reply message is too small. Byte counter wrong: The byte counter received in the reply message is wrong. Echo wrong: The data of the reply message (amount of bits, ...) echoed from the slave are different from the data sent in the request message. LRC incorrect: An error has occurred on checking the LRC of the reply message from the slave. A received character within the reply message is not an ASCII character (0-9, A-F)
The wrong slave has replied. Check if the transmission line is interrupted (interface analyzer may be required). Check slave device.
0E 51H
81
0E 52H
82
Check slave device. If working with 32-bit registers, check accessed address of the slave whether it belongs to the expected memory area (16/32-bit). Check slave device. If working with 32-bit registers, check accessed address of the slave whether it belongs to the expected memory area (16/32-bit). Check slave device.
0E 53H
83
0E 54H
84
0E 55H
85
0E 56H
86
0E 57H
87
0E 58H
88
Check slave device. Make sure it is in ASCII mode and not RTU.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
7-9
Event Class 5 (05H) CPU Job Errors Event Class/ No. (Hex) 0E 61H 0E 62H 0E 63H 0E 64H 0E 65H 0E 66H 0E 67H Event Number
(Decimal)
Event Text
Remedy
Reply message with Modbus Exception Code 01: Illegal Function Reply message with Modbus Exception Code 02: Illegal Data Address Reply message with Modbus Exception Code 03: Illegal Data Value Reply message with Modbus Exception Code 04: Failure in associated device Reply message with Modbus Exception Code 05: Acknowledge Reply message with Modbus Exception Code 06: Busy, Rejected message Reply message with Modbus Exception Code 07: Negative Acknowledgment
See manual for slave device or Modbus Protocol Specification See manual for slave device or Modbus Protocol Specification See manual for slave device or Modbus Protocol Specification See manual for slave device or Modbus Protocol Specification See manual for slave device or Modbus Protocol Specification See manual for slave device or Modbus Protocol Specification See manual for slave device or Modbus Protocol Specification
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
7-10
Application Example
Application Example
The following simple programming example illustrates the use of FBs P_SND_RK and P_RCV_RK. When the Modbus master is installed, the application example is stored in the STEP 7 directory EXAMPLES under the name MB_ASCII. The S7 program is for information purposes only and is not to be understood as a solution for a customer-specific installation configuration. In order to illustrate the basic structure, we intentionally kept it simple and avoided symbolic display.
General Information
8.1
Used Blocks
The following blocks are used in the programming example. Block OB 1 OB 100 FC 10 FC 21 FC 22 DB50 DB70 DB40 DB41 DB42 DB43 Symbol Cycle Execution Complete Restart Initiation Execute Send Jobs Execute Receive Jobs IDB_P_SND_RK I_DB_P_RCV_RK Work DB Send Work DB Receive SOURCE_DB DESTINATION_DB Comment Cyclic program processing Startup OB for Restart FC for Startup OB FC Calling P_SND_RK FC Calling FB P_RCV_RK Instance DB for P_SND_RK Instance DB for P_RCV_RK Work DB for FC21 and P_SND_RK Work DB for FC23 and P_RCV_RK P_SND_RK Source DB with send data P_RCV_RK Destination DB for receive data
Used Blocks
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
8-1
Application Example
Used Data
The following operands (memory bits, data bits, or data words) are used in the programming example. Operand M 120.7 DB40.DBX.0.0 DB40.DBX.0.1 DB40.DBX.0.4 Symbol Comment Trigger bit for the execution of a P_SND_RK job Control parameter REQuest: for activating a P_SND_RK Control parameter Reset: for aborting current P_SND_RK Status parameter DONE: Indicates that current P_SND_RK was completed without error Status parameter ERROR: Indicates that current P_SND_RK was completed with error Success counter for P_SND_RK Success counter for P_SND_RK Error counter for P_SND_RK Length LEN of P_SND_RK source data area to be transferred to the CP in bytes STATUS display in P_SND_RK Stored P_SND_RK STATUS display Control parameter EN_R: P_RCV_RK ready to receive Status parameter NDR: Indicates that current P_RCV_RK has received new data from the CP Status parameter ERROR: Indicates that current P_RCV_RK has been completed with error Stored length LEN of P_RCV_RK Success counter for P_RCV_RK Error counter for P_RCV_RK Length LEN of P_RCV_RK destination data area received by the CP in bytes STATUS display in P_RCV_RK Stored P_RCV_RK STATUS display
DB40.DBX.0.5
DB41.DBX.0.5
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
8-2
Application Example
The parameters for the programmed system function blocks P_SND_RK, P_RCV_RK are stored in the work DBs DB40 and DB41. The send data (SEND source area) are contained in DB42. Data received from the link partner are entered into DB43 (RCV destination area). P_SND_RK Job A P_SND_RK job can be activated in the cyclic part of the program by setting memory bit M 120.7 (for example, by CONTROL VARIABLE). The data with length LEN contained in the P_SND_RK source area DB42 are transferred to the CP. Memory bit M 120.7 is reset immediately. After completion of the P_SND_RK job without error, a success counter is incremented; after completion with error, an error counter is incremented. P_RCV_RK Job An SFB P_RCV_RK is programmed in FC23, where the Receive Enable is always 1, in order to receive data from the link partner. The receive data are entered into the P_RCV_RK destination area, the amount of entered data is displayed in parameter LEN. On taking on data without error, the success counter is incremented; on completion with error, the error counter is incremented. For the P_SND_RK and P_RCV_RK jobs, the output parameter STATUS is stored when a value other than 0 is reported.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
8-3
Application Example
Program Startup OB100 L T T UC Start-Up-OB 272 DB40.DBW DB41.DBW FC 10 //logical address //for SEND /and RCV //Call of FC for Initiation
16 16
FC10
Initiation
//-----------------------------------------------Reset Control Bits //-----------------------------------------------L B#16#0 T DB40.DBB 0 T DB41.DBB 0 //-----------------------------------------------Reset counters/STATUS //-----------------------------------------------L W#16#0 T DB40DBW 6 T DB40DBW 8 T DB40DBW 12 T DB40DBW 14 T DB41DBW 6 T DB41DBW 8 T DB41DBW 12 T DB41DBW 14
//SEND- Work-DB
//RCV- Work-DB
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
8-4
Application Example
OB1 UC UC
FC21 // // //
Execute SEND-Jobs -----------------------------------------------Interlockings for SEND -----------------------------------------------U M 120.7 U N DB40.DBX U N DB40.DBX U N DB40.DBX R M 120.7 S DB40.DBX -----------------------Generate edge SEND_REQ -----------------------U( O DB40.DBX O DB40.DBX ) U DB40.DBX R DB40.DBX -----------------------Supply LEN -----------------------L W#16#20 T DB40.DBW -----------------------SEND with Instance-DB -----------------------CALL FB 8, DB50 SF:= REQ :=DB40.DBX0.0 R :=DB40.DBX0.1 LADDR :=DB40.DBW16 DB_NO :=42 DBB_NO:=10 LEN :=DB40.DBW10 R_CPU_NO:= R_TYP:='x' R_NO:= R_OFFSET:= R_CF_BYT:= R_CF_BIT:= DONE :=DB40.DBX0.4 ERROR :=DB40.DBX0.5 STATUS:=DB40.DBW12 0.0 0.4 0.5 0.0 //Trigger SEND //SEND_REQ //SEND_DONE //SEND_ERROR //Reset Trigger SEND //Set SEND_REQ
// // //
// // //
10
// // //
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
8-5
Application Example
//
// //
-------------------------------------------Check Complete without error -------------------------------------------U DB40.DBX 0.4 SPBN CON1 L DB40.DBW 6 //DONE ? //if NO //Complete without //error //increment counter // : //further user // functions // :
+1 T DB40.DBW 6 : : : : SPA LEAV // -------------------------------------------// Check Complete with error // -------------------------------------------CON1: U DB40.DBX 0.5 SPBN CON2 L DB40.DBW 8 +1 T DB40.DBW 8 : : : L 0 L DB40.DBW 12 ==I SPB LEAV T DB40.DBW 14 SPA LEAV // -------------------------------------------// Check Error in STATUS // -------------------------------------------CON2: L 0 L DB40.DBW 12 ==I SPB LEAV T DB40.DBW 14 : : : LEAV: CLR
//ERROR ? //if NO //Complete with error // increment counter // : //Error-Handling // : //if STATUS <>0
//save STATUS
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
8-6
Application Example
FC23 // // //
Carry out RCV-Receive --------------------------------------------Enable Receive Data --------------------------------------------SET = DB41.DBX 0.0 --------------------------------------------RCV with Instance-DB --------------------------------------------CALL FB 7, DB70 EN_R :=DB41.DBX0.0 R:= LADDR:=DB41.DBW16 DB_NO:=43 DBB_NO:=0 L_TYP:= L_NO:= L_OFFSET:= L_CF_BYT:= L_CF_BIT:= NDR :=DB41.DBX0.4 ERROR :=DB41.DBX0.5 LEN :=DB41.DBW10 STATUS :=DB41.DBW12 --------------------------------------------Check Receive without error --------------------------------------------U DB41.DBX 0.4 SPBN CON1 L DB41.DBW 6
// // //
// // //
+1 T DB41.DBW 6 L DB41.DBW 10 T DB41.DBW 4 SPA LEAV // --------------------------------------------// Check Receive with error // --------------------------------------------CON1: U DB41.DBX 0.5 SPBN CON2 L DB41.DBW 8 +1 T DB41.DBW 8 L 0 L DB41.DBW 12 ==I SPB LEAV T DB41.DBW 14 SPA LEAV // --------------------------------------------// Check Error in STATUS // --------------------------------------------CON2: L 0 L DB41.DBW 12 ==I SPB LEAV T DB41.DBW 14 LEAV: CLR
//NDR ? //if NO //Receive without //error //increment counter //save //Receive-Length LEN
//save STATUS
//save STATUS
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
8-7
Caution In the RS422 mode CP341 can only be used as a Master because the transmitter (Sender) always drives the line and never goes to the high-impedance Tri State mode!
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
A-1
The following applies: GND (PIN 8 must always be connected on both sides The casing shield must be installed everywhere A terminating resistor of approx. 330 is to be soldered into the connector on the last receiver of a node sequence Recommended cable type: LIYCY 3 x 2 x 0,14 R(A)/R(B) and T(A)/T(B) twisted pairs. For additional information see the Cables section of the Modbus over Serial Line Specification and Implementation Guide available at www.modbus.org. A wiring with Stub is not allowed
Wiring diagram RS232 Point to Point (Modbus RS232) Please refer to Section B.1 of the CP 341 Point to Point Communication Manual.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
A-2
Literature List
Literature List
Modbus over Serial Line Specification & Implementation Guide V1.0 12/02/02 Modbus Application Protocol Specification V1.1a 6/4/04 http://www.modbus.org
Modbus Protocol
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
B-1
Glossary
Glossary
Address
The address identifies a physical storage location and enables the user to directly access the operand store there.
Block
Blocks are elements of the user program which are defined by their function, structure, or purpose. With STEP 7 there are _ Code blocks (FB, FC, OB, SFB, SFC) _ Data blocks (DB, SDB) _ User-defined data types (UDT) A block call occurs when program processing branches to the called block Block parameters are wildcards within multiple-use blocks, which are replaced with current values when the relevant block is called.
Block Call
Block Parameter
Communications processors are modules for point-to-point connections and bus connections. The configuration is the setup of individual modules of the PLC in the configuration table. Central processing unit of the S7 programmable controller with control and arithmetic unit, memory, operating system, and interfaces to I/O modules. Cyclic Redundancy-Check = Checksum which guaranteed accuracy of error recognition. The cycle time is the time the CPU needs to scan the user program once. In cyclic program processing, the user program is executed in a constantly-repeating program loop, called a cycle.
CPU
CRC
Cycle Time
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
Glossary - 1
Glossary
These are blocks containing data and parameters with which the user program works. Unlike all other blocks, data blocks do not contain instructions. They are subdivided into global data blocks and instance data blocks. The data held in the data blocks can be accessed absolutely or symbolically. Complex data can be stored in structured form. Data types allow users to define how the value of a variable or constant is to be used in the user program. They are subdivided into elementary and structured data types. The default setting is a practical basic setting, which is always used if no other value is specified. Every CPU has a diagnostic buffer, in which detailed information on diagnostic events is stored in the order in which they occur. Diagnostic events are, for example, errors on a module or system errors in the CPU, which may be caused by a program error or by operating? mode transitions. The diagnostics functions cover the entire system diagnosis and include detection, analysis and reporting of errors within the PLC. Downloading means loading load objects (e.g. code blocks) from the programming device into the load memory of the CPU.
Data Type
Default Setting
Diagnostic Buffer
Diagnostic Event
Diagnostics Functions
Download
Function blocks are components of the user program and, in accordance with the IEC standard, are blocks with memory. The memory for the function block is an assigned data block of the instance data block. Function blocks can be assigned parameters, or they can be used without parameters.
Hardware
Hardware is the term given to all the physical and technical equipment of a PLC.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
Glossary - 2
Glossary
I
Instance Data Block An instance data block is a block assigned to a function block and contains data for this particular function block. Interface Submodule The CP 441-2 interface submodule is responsible for the physical conversion of signals. By changing the interface submodule, you can make the communications processor compatible with the communications partner. An interrupt occurs when program processing in the processor of a PLC is interrupted by an external alarm.
Interrupt
Module
Modules are pluggable printed circuit boards for programmable controllers. Module parameters are used to set the module reactions. A distinction is made between static and dynamic module parameters.
Module Parameter
Online/Offline
Online means that a data circuit exists between PLC and programming device. Offline means that no such data circuit exists. STEP 7 allows you to display contextual help texts on the screen while you are working with the programming software. An operand is part of a STEP 7 instruction and states with what the processor is to do something. It can be both absolutely and symbolically addressed. The SIMATIC S7 programmable controllers have three different operating modes: STOP, RESTART and RUN. The functionality of the CPUs varies in the individual operating modes. The operating system of the CPU organizes all functions and operations of the CPU which are not connected to a specific control task.
Online Help
Operand
Operating Mode
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
Glossary - 3
Glossary
Parameter
Parameters are values that can be assigned. A distinction is made between block parameters and module parameters. Parameter assignment means setting the behavior of a module. The CP Point-to-Point Communication, Parameter Assignment Tool is used to assign parameters to the interface submodule of the communications processor and to set the driver-specific parameters. The standard range is expanded for each loadable driver.
Parameter Assignment Parameter Assignment Tool CP: Point-to-Point Communication, Parameter Assignment Point-to-Point Connection Procedure
In a point-to-point connection the communications processor forms the interface between a PLC and a communications partner. The execution of a data interchange operation according to a specific protocol is called a procedure. The process image is a special memory area in the PLC. At the beginning of the cyclic program, the signal states of the input modules are transferred to the process image input table. At the end of the cyclic program, the process image output table is transferred to the output modules as signal state. Programmable controllers (PLCs) are electronic control devices consisting of at least one central processing unit, various input/output modules, and operator control and monitoring devices. Project configuration of data link is the term given to the allocation of a Connection ID in the system function block. The Connection ID enables the system function blocks to communicate between two communication terminal points. The communications partners involved in a data interchange must abide by fixed rules for handling and implementing the data traffic. These rules are called protocols.
Process Image
Programmable Controller
Protocol
Rack RESTART
A rack is the rail containing slots for mounting modules. On transition from the STOP to the RUN mode, the PLC goes through the RESTART mode.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
Glossary - 4
Glossary
Software
Software is the term given to all programs used on a computer system. These include the operating system and the user programs. The standard mode of Modbus ASCII slave driver means, that the parameter with 32-Bit registers is not set. In this mode all registers imply 16-bit values. This is the programming software for SIMATIC S7 programmable controllers. System blocks differ from the other blocks in that they are already integrated into the S7-300/400 system and are available for already defined system functions. They are subdivided into system data blocks, system functions, and system function blocks. System functions are modules without memory which are already integrated into the operating system of the CPU and can be called up by the user as required. System function blocks are modules with memory which are already integrated into the operating system of the CPU and can be called up by the user as required.
Standard Mode
STEP 7
System Block
Upload
Uploading means loading load objects (e.g. code blocks) from the load memory of the CPU into the programming device. The user program contains all instructions and declarations for signal processing, by means of which a system or a process can be controlled. The user program for SIMATIC S7 is structured and is divided into smaller units called blocks.
User Program
Variable
A variable is an operand (e.g. E 1.0), which can have a symbolic name and can therefore also be addressed symbolically.
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
Glossary - 5
Glossary
When choosing with 32-Bit Register mode, holding registers can imply 32-bit values (integer and floating point) as well as 16-bit values when accessed by a master. The work memory is a RAM on the CPU, which the processor accesses while processing the user program.
Work Memory
Loadable Driver CP341: Modbus ASCII Master with 32-Bit Extensions 6ES7870-1CA00-0YA0; Manual Edition 1.0
Glossary - 6