Description Profibus DP Protocol
Description Profibus DP Protocol
Description Profibus DP Protocol
Contents
1 Application..............................................................................................................3 2 Device Planning (GSD file*) ......................................................................................3 3 General information on the protocol used ...............................................................4 3.1 Blocks and registers ............................................................................................................ 4 3.1.1 Appearance of Request and Response Package................................................................. 5 3.1.2 Error handling: .......................................................................................................... 11
HB Profibus-Protokollbeschreibung 12.01 E
Application
The Profibus-DP-Protocol is an optionaly usage in following protection relais CSP2-FxxxPWx CSP2-FxxxPFx CSP2-LxxxPWx CSP2-LxxxPFx
PROFIBUS devices feature different power characteristics. They differ with regard to the available functionality (e.g. number of I/O signals, diagnose messages) or possible bus parameters such as Baud rate and time supervision. These parameters vary for each type of device and its manufacturer. They are normally documented in the manual of the device. In order to achieve a simple plug-and-play configuration for the PROFIBUS, electronic-device data sheets (GSD files) for the communication characteristics of the devices have been established. GSD files are provided by all PROFIBUS manufacturers. The GSD files extend open communication right down to the operating level. All modern project planning tools permit reading in of the GSD files during configuration. This way integration of devices by different manufacturers into the PROFIBUS System becomes easy and user-friendly. The master files describe the characteristics of a device model clearly and completely in a precisely fixed format. The device manufacturer prepares the GSD data individually for each device type and provides them to the user in the form of a special GSD file for this device. Thanks to the fixed file format, the project planning system can easily read in the master device data of any PROFIBUS device and take them into account when the bus system is configured. The project planning system is already able during the planning phase to automatically carry out checks for faulty entries and on the consistency of the entered data in relation to the overall system. The device master data are divided into: General fixed data This section contains information on manufacturer's and device name, hardware and software versions as well as on the supporting Baud rates, the possible time periods for supervision times and the signal assignment on the bus plug. Slave-related data Here we find all slave-related information such as e.g. the number and type of I/O channels, fixing of diagnose texts as well as information on the modules available in the case of modular devices.
HB Profibus-Protokollbeschreibung 12.01 E
The CSP uses a protocol superimposed on level 2 of the Profibus DP in order to be able to offer the device functionality clearly structured at the communication interface. The data traffic between Profibus-DP Master and CSP (Profibus Slave) takes place via two different data packages. In this context we distinguish between the following data packages: Request package Packages of this type must be transmitted from the external Profibus Master to the CSP Slave. Packages of this type are transmitted from the CSP Slave to the Master.
Response package
Request- and Response package have a constant length, independent of the respective device function required. Package Request-Package Response-Package Size in Bytes 8 32 Remarks refer Fig 3.1 refer Fig 3.2
The principle rule for using the superimposed protocol can be described as follows: The master transmits a request package to the slave which is coded with the required data and/or function. The slave replies with a response package which contains the required data and/or acknowledgement of a function it has carried out. The request- and response-packet have to be acessed consistent.
3.1
The present profile distinguishes between the terms Block and Register. All slave data relevant to the Profibus are provided either in a block or in a register, and with the following distinction: (Time-variable) data which the master can read but not change are always assigned to a certain block and must be selected by the master by choosing a Block Index. The measured values of the slave, for example, are all available in blocks. Other, typically not time-variable data, which can be read or possibly also written, are provided by the slave in so-called registers. In order to select a register, the master not only has to choose the Register Index but must also define the required function (reading or writing) in a command. The only readable registers are indicated by a suffix R and the writable registers are indicated by a W. The master has to use the toggle bit CTGL for read and write block and register commands. The block respectively register index is shown in hexadecimal code.
HB Profibus-Protokollbeschreibung 12.01 E
3.1.1
Fig. 3.1 shows the structure of the Request Packages. All elements of the Request Packages bear the suffix R in their name in order to clearly assign them to the Request Package. The individual elements of this package have the following functions:
VR
VR3 VR4 RR1
RR
RR2
CR 6 7
BR 8
Element BR RR
serves for selecting the Block Index. The Master must determine the required Block No. by means of BR. contains the Register No. required by the Master. The Register Number must be entered in RR1 with the higher value byte and analogously to that in the RR2 with the lower-value byte. via this element the Master must determine the required command (read or write). The information to be saved in the CR element by the Master is bit-coded and explained in more detail in Fig. 3.3. In this element the Master must enter the data to be written while writing in a Register. If there is to be no writing in a Register, the Slave will ignore this element. The format in which the data are to be entered into the VR element always depends on the chosen Register (refer to element RR) and is explained in more detail in the Device-Profile.
CR VR
This means that two parallel functions can be carried out by means of one single Request package. Via Element BR the Data Block can be chosen which is to be provided by the Slave. Via the Elements CR and RR a register-based function of the unit (reading or writing into a Slave Register) can be carried out.
HB Profibus-Protokollbeschreibung 12.01 E
Element
VS1 VS2
VS
VS3 VS4
RS
RS1 RS2
ACK 6 DB 7
BS 8
Byte
2 DA
Element
DA1 DA2
DA3
DA4
DB1
DB2
DB3
DB4
Byte
10
11 DC
12
13
14 DD
15
16
Element
DC1 DC2
DC3
DC4
DD1
DD2
DD3
DD4
Byte
17
18
19 DE
20
21
22 DF
23
24
Element
DE1 DE2
DE3
DE4
DF1
DF2
DF3
DF4
Byte
25
26
27
28
29
30
31
32
The Response package always consists of two parts and incorporates, in addition to the response elements which can be directly assigned to the relevant elements of the Request package, a data block of 24 Byte length. All elements of the Response package for which a corresponding analogue element exists in the Request package are marked with the suffix S. The individual elements of the Response Telegram are treated by the Slave as follows: Element BS RS
ACK
The Slave sets this element onto the requested Block No. which was specified by the Master in the BR element of the Request package processed by the Slave. The Slave assigns the Register No. to the element as it has been specified by the Master in the RR element of the Request package. The Slave enters the Register No. in the RS1 with the higher-value Byte and in the RS2 with the lower-value Byte.. This element contains information about the execution of the functions contained in the corresponding Request package. This means, it contains the reaction of the Slave to the instructions given by the Master in the data sections CR and BR.
The information saved in this element by the Slave is bit-coded and explained in more detail in Fig. 3.4.
VS
This element contains the read data of a Register The format in which the data are to be entered in the VS element always depends on the chosen Register (refer to Element RS) and is explained in more detail in the Device-Profile
HB Profibus-Protokollbeschreibung 12.01 E
X
X3 X4 CTGL CMD1
CMD
CMD2 CMD3
Bit
Explanation Element X is reserved. The Bit COMMAND_TOGGLE is explained in more detail in the following CMD_ZERO: Slave does ignore the Elements RR and VR CMD_READ: read out RR Register at Slave CMD_WRITE: writes VR value into the RR Register at the Slave if the Bit CTGL has been inverted with the command in hand.
Table 3.3
The remaining elements: This element selects the required Data Block which is transmitted by the Slave in the elements DA to DF of the Response package. If the Master does not wish to select a Data Block, it must use the ZERO Block 00h. The Slave then sets the elements DA to DF in the corresponding Response Telegram to 0. By way of this element the Master must choose a Register to which the Command in element CR is to be applied. If the special value CMD_ZERO is used in CR, it is not necessary to provide an RR value. This element must only be assigned a value by the Master if the value CMD_WRITE is used in the CR element. In this case the Master wishes to write into a Register in the Slave and must consequently enter the value to be written into the element VR. The data format of the VR element depends on the required Register RR. Details can be found in the Device Profile.
BR
RR
VR
HB Profibus-Protokollbeschreibung 12.01 E
Response Package
Element
CA1
CA
CA2 BA1
BA
BA2 CTGL CMD1
CMD
CMD2 CMD3
Bit
4 4
BA CTGL CMD
Table 3.4:
Possible value 01b 10b 00b 01b 10b 0 or 1 see CR, Bit section CMD
Explanation CMD_ACK: Execution of command successful. CMD_ERR: Execution of command not successful CMD_NO No execution of command BL_ACK: Block was supplied BL_ERR: Block could not be supplied The Bit COMMAND TOGGLE is described in more detail in the following The value supplied by the Slave in this Bit element is only of significance if CA is not equal to CMD_ZERO
Explanations on bit-coded elements: In case of bit-coded elements it must be ensured that the individual bits are correctly oriented. In all related graphs the individual bits are marked with the numbers 1 8. Numerically interpreted, the bit numbers correspond to the following value rating: Bit Number 1 2 3 4 5 6 7 8
Table 3.5:
Value 7 2 6 2 5 2 2 3 2 2 2 2 0 2
1 4
The tables also show some binary values. All of these are characterised by the suffix b. They must be entered into the bit elements as specified in the tables.
The behaviour of the CTGL Bit (COMMAND TOGGLE) in the CMD section The Profibus Slave described herein replies to a Request Telegram sent by the Master with a Response Telegram. The Profibus ensures continuous transmission of the assigned input and output data sections between Master and Slave in which the Request and Response Telegrams are filed.
HB Profibus-Protokollbeschreibung 12.01 E
This continuous transmission of data between Master and Slave which is typical for the Profibus is problematic particularly when writing onto Registers of the Slave: If the Master wishes to write onto a Register of the Slave, it must set up an appropriate Request Package in its output data section. This Request Package would now be continuously transmitted to the Slave until the Master changes the data in its output data section again. It would therefore be feasible that the Slave processes the Request Telegram, which is continuously being sent to it, several times without any new information being transmitted. Since, as a rule, writing onto Registers of the Slave has a modifying effect on the status of the device, unintentional multiple transmission of such telegrams is definitely not desirable. Since the Profibus does not have the possibility to recognise such multiple telegrams, the present telegram focuses especially on this issue. For this reason the CTGL Bit in the CMD section was introduced in the Request and Response Telegram. The Slave processes the Bit CTGL as follows: When the Slave processes a Response Telegram, it copies the CTGL Bit of the Request Package into the CTGL Bit of the Response Package. In addition the Slave memorises the value of the CTGL Bit of the respective Request Package last processed. The Slave will only carry out the requested function if the CTGL Bit of the Request Package has actually been inverted in relation to the Request Package last processed. If, however, the CTGL Bit has not changed compared to the Request Package processed last, no function will be carried out by the Slave side, i.e. outdated Response Packages will be sent to the Master. On the side of the Master the CTGL Bit is used as follows: If the Master wishes to read a Block or a Register, it prepares the relevant Request Telegram which will then be sent to the Slave via the Profibus. In this case the Master has to invert the CTGL Bit for every new Request Package. It can then trigger to change of the CTGL Bit in the Response Package and thus has a simple criterion for recognising a new Response Package being processed by the Slave. It is essential that the CTGL Bit is inverted in order to achieve processing of the Request Package in the Slave. The Master can recognise the slave processing the command on the CTGL Bit in the Response Package.
HB Profibus-Protokollbeschreibung 12.01 E
Example The Slave provides the value 62 in hexa-decimal form for the element ACK. In binary writing this is equivalent to 01100010b.
Element Bit
0
CA1
1
CA2 BA1
1
BA2
0 4 4
0
CTGL
0
CMD1
1
CMD2 CMD3
0 8
This results in the following individual values for the individual Bit Elements: CA = CMD_ACK BA = BL_ERR CMD = CMD_WRITE (01b) (10b) (0010b)
The remaining elements of the Response Package are: In this element the Slave supplies the index of the required Data Block. Consequently the value is a copy of the element BR of the appertaining Request package.
BS
RS
In this element the Slave supplies the Register index of the executed Register function. Consequently the value is a copy of the element RR of the appertaining Request package. In this element the Slave saves Register values. If the Master reads a Register successfully (CMD equals CMD_READ and Bit section CA in the element ACK equals CMD_ACK), the Slave saves the momentary value of the Register requested by the Master in the element VS. But if the Master writes onto a Register, the value written into the Slave will be copied into element VS. In all other cases VS contains a copy of element VR from the appertaining Request package. The data format of element VS depends on the required Register RS. Details can be found in the Device Profile. The elements DA to DF contain the data of one block as supplied by the Slave. DA-DF will only contain valid values if the Slave has been able to supply the required data block (Bit section BA in Element ACK equal to BL_ACK) The data format of the elements DA-DF depends on the required Block BS. Details can be found in the Device Profile.
VS
Dx
10
HB Profibus-Protokollbeschreibung 12.01 E
Error handling: Special attention should be paid to those Response packages where the sections BA and CA signal faults in the ACK element. In detail, these cases mean: Bit-Element BA Error status 10b (BL_ERR) Meaning: For some reason, the Slave was unable to supply the required Data Block. In this case the elements DA to DF contain invalid values which must not be used for evaluation. Register access was denied for some reason. In this case the element VS4 of the Response package contains more detailed information about the cause for the error. In such a case the elements VS1 to VS3 are set to 00h by the Slave.
CA
10b (CMD_ERR)
Table 3.6:
Detailed list of the error code (when CA is equal to CMD_ERR): The error code E supplied in element VS4 in case of an error is bit-coded. In detail it should be interpreted like in Fig. 3.6.
Element Bit
(-r
d (EX) -- )
EI
EW
EC
ER
4 5
Error code E Bit-Element a set Bit means EX is reserved for future extensions. The Master must not evaluate the respective Bits at this time. EI EW EC ER ERROR_INT: The Slave was unable to process a command on account of an internal error. ERROR_WRITE: The Master has tried to describe a "read only" Register. Since the respective Register can only be read, the writing process was not carried out. ERROR_CMD: The Master has sent a Request package with an undefined Command to the Slave ERROR_REG: The Master has entered a command for a Register not contained in the Slave. The Slave has not processed this command for this reason.
HB Profibus-Protokollbeschreibung 12.01 E
11
Practical examples for using the Protocol from the Master's view: 1. The Master wants to read a Data Block. It sends a Request Package with BR equalling 01h. Since the Master does not want to carry out a Register Command, it uses the value 0h for CR (== ZERO_CMD).
Element Byte
00h
VR1
00h
VR2
00h (any)
VR3
00h
VR4
00h
RR1
00h (any)
RR2
00h
CR
01h
BR
Element Byte
00h
VS1
00h
VS2
00h
VS3
00h
VS4
00h
RS1
00h
RS2
10h
ACK
01h
BS
2 (Value A) Value
6 (Value B)
Element
DA1 DA2
DA3
DA4
DB1
DB2
DB3
DB4
Byte
10
11 (Value C)
12
13
14 (Value D)
15
16
Element
DC1 DC2
DC3
DC4
DD1
DD2
DD3
DD4
Byte
17
18
19 (Value E)
20
21
22 (Value F)
23
24
Element
DE1 DE2
DE3
DE4
DF1
DF2
DF3
DF4
Byte
25
26
27
28
29
30
31
32
In the above example the meaning of Element ACK is as follows: Element ACK Bit Element CA BA CMD
Table 3.8:
12
HB Profibus-Protokollbeschreibung 12.01 E
The Master wants to read Register 1234h. It is not interested in any special Data Block, so it uses the ZERO Block (00h).
00h
VR1
Element Byte
00h
VR2
00h (any)
VR3
00h
VR4
12h
RR1
34h
RR2
01h
CR
00h
BR
1
Fig. 3.9: Request Package Example 2
Element Byte
00h
VS1
00h
VS2
00h
VS3
00h
VS4
12h
RS1
34h
RS2
51h
ACK
01h
BS
1
00h
DA1
2
00h
DA2
3
00h
DA3
4
00h
DA4
5
00h
DB1
6
00h
DB2
7
00h
DB3
8
00h
DB4
Element Byte
9
00h
DC1
10
00h
DC2
11
00h
DC3
12
00h
DC4
13
00h
DD1
14
00h
DD2
15
00h
DD3
16
00h
DD4
Element Byte
17
00h
DE1
18
00h
DE2
19
00h
DE3
20
00h
DE4
21
00h
DF1
22
00h
DF2
23
00h
DF3
24
00h
DF4
Element Byte
25
26
27
28
29
30
31
32
The meaning of Element ACK in the above example is as follows: Element ACK Bit-Element CA BA CMD
Table 3.9:
HB Profibus-Protokollbeschreibung 12.01 E
13
The Master wants to write the value 0x12345678 in Register 4218h and simultaneously read Data Block 02h.
Element Byte
12h
VR1
34h
VR2
56h
VR3
78h
VR4
42h
RR1
18h
RR2
02h
CR
02h
BR
Element Byte
12h
VS1
34h
VS2
56h
VS3
78h
VS4
42h
RS1
18h
RS2
52h
ACK
02h
BS
2
(Value A)
6 (Value B)
DA3
DA4
DB1
DB2
DB3
DB4
10
11 (Value C)
12
13
14 (Value D)
15
16
DC3
DC4
DD1
DD2
DD3
DD4
17
18
19 (Value E)
20
21
22 (Value F)
23
24
DE3
DE4
DF1
DF2
DF3
DF4
25
26
27
28
29
30
31
32
The meaning of Element ACK in the above example is as follows: Element ACK Bit-Element Value Explanation CA BA CMD
Table 3.10:
14
HB Profibus-Protokollbeschreibung 12.01 E
HB Profibus-Protokollbeschreibung 12.01 E
15
Woodward SEG GmbH & Co. KG Krefelder Weg 47 D 47906 Kempen (Germany) Postfach 10 07 55 (P.O.Box) D 47884 Kempen (Germany) Phone: +49 (0) 21 52 145 1 Internet Homepage http://www.woodward-seg.com Documentation http://doc.seg-pp.com Sales Phone: +49 (0) 21 52 145 635 Telefax: +49 (0) 21 52 145 354 e-mail: [email protected] Service Phone: +49 (0) 21 52 145 614 Telefax: +49 (0) 21 52 145 455 e-mail: [email protected]