# **SIEMENS**

|                                      | Preface, Contents                                |    |
|--------------------------------------|--------------------------------------------------|----|
|                                      | Introduction                                     | 1  |
|                                      | User Program                                     | 2  |
| SIMATIC S5                           | Program Execution                                | 3  |
|                                      | Operating Modes and Program<br>Processing Levels | 4  |
| S5-135U<br>CPU 928B - Version -3UB21 | Interrupt and Error Handling                     | 5  |
|                                      | Integrated Special Functions                     | 6  |
| Programming Guide                    | Extended Data Block DX 0                         | 7  |
|                                      | Memory Assignment and Memory Organization        | 8  |
|                                      | Memory Access Using Absolute<br>Addresses        | 9  |
|                                      | Multiprocessor Mode and Communication            | 10 |
|                                      | PG Interfaces and Functions                      | 11 |
|                                      | Appendix                                         | Α  |
|                                      | Further Reading                                  | B  |
|                                      | List of Abbreviations                            | С  |
|                                      | Glossary, Index                                  | _  |

The CPU 928/CPU 928B/CPU 948, List of Operations, order no. 6ES5 997-3UA23, Rel. 01 is included with this manual.

#### **Safety Guidelines**

This manual contains notices which you should observe to ensure your own personal safety, as well as to protect the product and connected equipment. These notices are highlighted in the manual by a warning triangle and are marked as follows according to the level of danger:



#### Danger

indicates that death, severe personal injury or substantial property damage will result if proper precautions are not taken.



#### Warning

indicates that death, severe personal injury or substantial property 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.

| Ν | 01 | te |
|---|----|----|
|   |    |    |

draws your attention to particularly important information on the product, handling the product, or to a particular part of the documentation.

Qualified Personnel The device/system may only be set up and operated in conjunction with this manual.

Only **qualified personnel** should be allowed to install and work on this equipment. Qualified persons are defined as persons who are authorized to commission, to ground, and to tag circuits, equipment, and systems in accordance with established safety practices and standards.

**Correct Usage** 

#### Note the following:

 $\triangle$ 

#### 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.

Third parties using for their own purposes any other names in this document which refer to trademarks might infringe upon the rights of the trademark owners.

#### Copyright © Siemens AG 1996 All rights reserved

The reproduction, transmission or use of this document or its contents is not permitted without express written authority. Offenders will be liable for damages. All rights, including rights created by patent grant or registration of a utility model or design, are reserved.

Siemens AG Automation Group Industrial Automation Systems Postfach 4848, D-90327 Nürnberg

#### **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 welcomed.

© Siemens AG 1996 Technical data subject to change.

Siemens Aktiengesellschaft

6ES5998-2PR22

## Preface

Scope of the<br/>ManualThis programming guide describes the CPU 928B-3UB21 and its system<br/>software.

| Overview of the<br>Chapters | <b>Chapter 1</b> informs you about the areas of application of the S5-135U programmable controller with the CPU 928B and its device structure. It explains the typical mode of operation of the CPU and illustrates how a CPU program is structured.                                      |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | The chapter also contains suggestions about how to tackle programming and which characteristics of the CPU 928B-3UB21 are important for programming.                                                                                                                                      |
|                             | If you have already worked with the CPU 928B-3UB12 and want to know the differences between this CPU and the CPU 928B-3UB21 you will find this information in this chapter.                                                                                                               |
|                             | <b><u>Chapter 2</u></b> explains the components of a STEP 5 user program and how the program can be structured.                                                                                                                                                                           |
|                             | <b>Chapter 3</b> is intended for readers who do not yet have much experience of using the STEP 5 programming language. It therefore deals with the basics of STEP 5 programming and explains the STEP 5 operations in detail (with examples).                                             |
|                             | Experienced readers who may find that the information about specific operations in the pocket guide is inadequate, can use Section 3.5 as a reference section.                                                                                                                            |
|                             | <b>Chapter 4</b> provides an overview of the modes and program execution levels of the CPU 928B. It provides you with detailed information about various start-up modes and the associated organization blocks in which you can program your routines for differrent start-up situations. |
|                             | The chapter also explains the differences between the program execution levels "cyclic processing", "time-controlled processing" and "interrupt-driven processing" and which blocks are available for your user program.                                                                  |
|                             | <b><u>Chapter 5</u></b> informs you about errors to be avoided when planning and writing your STEP 5 programs.                                                                                                                                                                            |
|                             | The chapter tells you about the help you can obtain from the system program for<br>diagnosing errors and which reactions can be expected and informs you about the<br>blocks in which you can program reactions to certain errors.                                                        |
|                             | <b>Chapter 6</b> covers the special functions integrated in the system program. It tells you how to use the special functions and how to call and assign parameters to the special function OBs.                                                                                          |
|                             | The chapter also explains how to recognize and deal with errors in the processing of a special function.                                                                                                                                                                                  |
|                             |                                                                                                                                                                                                                                                                                           |

<u>Chapter 7</u> describes the use of data block DX 0 and its structure. The chapter informs you of the significance of the various DX 0 parameters. Based on examples, you will learn how to create data block DX 0 or how to assign the parameters in a screen form.

<u>Chapter 8</u> is a reference section for experienced system users. It provides information about the memory organization of the CPU 928B and certain system data words which contain information that can be called up by the user.

You will also learn how you can switch software protection for your CPU on and off via a system data word.

**<u>Chapter 9</u>** is also for experienced system users. The chapter explains how to address data in certain memory areas using absolute addresses.

<u>Chapter 10</u> lists a number of points about using multiprocessor operation and the possibility of using it to exchange data between CPUs and CPs.

The chapter provides information about programming for multiprocessor operation.

The remainder of the chapter provides detailed information and application examples for exchanging larger amounts of data in the multiprocessor mode (multiprocessor communication).

<u>Chapter 11</u> tells you how to connect your CPU to a PG and the functions provided by the PG software to test your STEP 5 program.

<u>Appendix A</u> contains an overview of the characteristic technical data of the CPUs 928A, 928B und 948 for camparison purposes.

Appendix B lists documentation for further reading.

<u>Appendix C</u> is intended to help you find themes quickly and contains a list of abbreviations and a list of keywords.

*Conventions used in the text* 

#### Second-level section numbering

Larger sub-chapters (e.g. 4.3) with second-level numbers start at the top of a new page with a bold heading and appear in the list of contents.

#### **Block labels**

Bold headings (block labels) appear in the margin on the left of the page to make it easier for you to find technical information.

#### <u>Notes</u>

**Note** Important information is indicated in this format.

#### Tables for reference

Table 3-2 Binary logic operations

| Operation | Operand        | Function                                           |
|-----------|----------------|----------------------------------------------------|
| А         |                | AND logic operation with scan for signal state "1" |
| 0         |                | OR logic operation with scan for signal state "1"  |
|           | I 0.0 to 127.7 | of an input in the PII<br>                         |

#### Examples

Examples, some of which cover several pages, are highlighted by a gray frame. When the examples cover more than one page this is clearly indicated.

Example 1: Calling and assigning parameters to a function block in the methods of representation STL and LAD/CSF in a program block

Method of representation STL

• • • • • •

## Contents

| 1   | Introduction 1-1                                          |                                                                                                                                                                                          |
|-----|-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.1 | Area of Application for the S5-135U with the CPU 928B 1-2 |                                                                                                                                                                                          |
| 1.2 | Typical Mode of Operation of a CPU 1-3                    |                                                                                                                                                                                          |
| 1.3 | The Pro<br>1.3.1<br>1.3.2                                 | ograms in a CPU1-5System Program1-5User Program1-7                                                                                                                                       |
| 1.4 | Which                                                     | Operands are available to the User Program? 1-9                                                                                                                                          |
| 1.5 | Accessi                                                   | ing Operand Areas and Memory Areas 1-12                                                                                                                                                  |
| 1.6 | How to                                                    | Tackle Programming    1-13                                                                                                                                                               |
| 1.7 | Program                                                   | nming Tools 1-16                                                                                                                                                                         |
| 1.8 | What is                                                   | s New with the CPU 928B (-3UB21)? 1-17                                                                                                                                                   |
| 2   | User P                                                    | rogram                                                                                                                                                                                   |
| 2.1 | STEP 5<br>2.1.1<br>2.1.2<br>2.1.3<br>2.1.4<br>2.1.5       | 5 Programming Language2-2The LAD, CSF, STL Methods of Representation2-2Structured Programming2-4STEP 5 Operations2-5Number Representation2-6STEP 5 Blocks and Storing them in Memory2-10 |
| 2.2 | Program<br>2.2.1<br>2.2.2                                 | n, Organization and Sequence Blocks                                                                                                                                                      |
| 2.3 | Function<br>2.3.1<br>2.3.2<br>2.3.3<br>2.3.4              | on Blocks2-21Structure of Function Blocks2-22Programming Function Blocks2-24Calling Function Blocks and Assigning Parameters to them2-26Special Function Blocks2-31                      |
| 2.4 | Data B<br>2.4.1<br>2.4.2<br>2.4.3                         | locks2-33Creating Data Blocks2-35Opening Data Blocks2-36Special Data Blocks2-39                                                                                                          |

| 3   | Program                                             | m Execution                                                                                                                                                                                                                                                 |
|-----|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3.1 | Principle of Program Execution 3-2                  |                                                                                                                                                                                                                                                             |
| 3.2 | Program                                             | a Organization                                                                                                                                                                                                                                              |
| 3.3 | Storing                                             | Program and Data Blocks                                                                                                                                                                                                                                     |
| 3.4 | Process<br>3.4.1                                    | ing the User Program                                                                                                                                                                                                                                        |
| 3.5 | STEP 5<br>3.5.1<br>3.5.2<br>3.5.3<br>3.5.4<br>3.5.5 | Operations with Examples3-13Basic Operations3-17Programming Examples in the STL, LAD and CSF Methods of Representation3-32Supplementary Operations3-47Executive Operations3-54Semaphore Operations3-67                                                      |
| 4   | Operat                                              | ing Modes and Program Processing Levels 4-1                                                                                                                                                                                                                 |
| 4.1 | Introdu                                             | ction and Overview                                                                                                                                                                                                                                          |
| 4.2 | Program                                             | n Processing Levels                                                                                                                                                                                                                                         |
| 4.3 | STOP N                                              | Mode                                                                                                                                                                                                                                                        |
|     | 4.3.1<br>4.3.2                                      | Characteristics and Indication of the Operating Mode                                                                                                                                                                                                        |
| 4.4 | RESTA<br>4.4.1<br>4.4.2<br>4.4.3<br>4.4.4<br>4.4.5  | RT Mode4-15MANUAL and AUTOMATIC COLD RESTART4-16MANUAL and AUTOMATIC WARM RESTART4-16Comparison of the Different Restart Types4-18User Interfaces for Restart4-19Interruptions in the RESTART Mode4-22                                                      |
| 4.1 | RUN M                                               | Iode                                                                                                                                                                                                                                                        |
|     | 4.1.1<br>4.1.2<br>4.1.3<br>4.1.4<br>4.1.5           | Cyclic Program Execution4-26Time-Driven Program Execution4-28CLOSED LOOP CONTROLLER INTERRUPT: Processing Closed Loop Controllers4-35PROCESS INTERRUPT: Interrupt-Driven Program Execution4-36Nested Interrupt-Driven and Time-Driven Program Execution4-39 |
| 5   | Interru                                             | pt and Error Handling 5-1                                                                                                                                                                                                                                   |
| 5.1 | Frequent Errors in the User Program 5-2             |                                                                                                                                                                                                                                                             |
| 5.2 | Error Information                                   |                                                                                                                                                                                                                                                             |
| 5.3 | Control<br>5.3.1<br>5.3.2<br>5.3.3                  | Bits and Interrupt Stack5-7Control Bits5-8ISTACK Content.5-13Example of Error Diagnosis using the ISTACK5-19                                                                                                                                                |
| 5.4 | Error H                                             | Iandling using Organization Blocks    5-22                                                                                                                                                                                                                  |

| 5.5  | Errors during RESTART 5-25                                                                                     |
|------|----------------------------------------------------------------------------------------------------------------|
|      | 5.5.1 DB0-FE (DB 0 Errors) 5-26                                                                                |
|      | 5.5.2 DB1-FE (DB 1 Errors)                                                                                     |
|      | 5.5.3 DB2-FE (DB 2 Errors)                                                                                     |
|      | 5.5.4       DX0-FE (DX 0 or DX 2 Errors)       5-29         5.5.5       MOD-FE (Memory Card Errors)       5-31 |
|      |                                                                                                                |
| 5.6  | Errors in RUN and in RESTART                                                                                   |
|      | 5.6.1 BCF (Operation Code Errors)                                                                              |
|      | 5.6.2       LZF (Runtime Errors)       5-37         5.6.3       ADF (Addressing Error)       5-45              |
|      | 5.6.3       ADF (Addressing Error)       5-45         5.6.4       QVZ (Timeout Error)       5-46               |
|      | 5.6.5 ZYK (Cycle Time Exceeded Error)                                                                          |
|      | 5.6.6 WECK-FE (Collision of Time Interrupts)                                                                   |
|      | 5.6.7 REG-FE (Controller Error) 5-50                                                                           |
|      | 5.6.8 ABBR (Abort) 5-52                                                                                        |
|      | 5.6.9 Communication Errors (FE-3) 5-53                                                                         |
| 6    | Integrated Special Functions                                                                                   |
|      | Introduction                                                                                                   |
| 6.1  |                                                                                                                |
| 6.2  | OB 110: Accessing the Condition Code Byte                                                                      |
| 6.3  | OB 111: Clear ACCUs 1, 2, 3 and 4 6-9                                                                          |
| 6.4  | OB 112/113: Roll Up ACCU and Roll Down ACCU                                                                    |
| 6.5  | OB 120: Enabling/Disabling of Interrupts 6-11                                                                  |
| 6.6  | OB 121: Enable/Disable Individual Time-Driven Interrupts                                                       |
| 6.7  | OB 122: Enable/Disable "Delay of All Interrupts"                                                               |
| 6.8  | OB 123: Enable/Disable "Delay of Individual Time-Driven Interrupts"                                            |
| 6.9  | OB 134, 135, 136 and 139 6-22                                                                                  |
| 6.10 | Setting/Reading the System Time (OB 150)                                                                       |
| 6.11 | OB 151: Setting/Reading the Time for Clock-Driven Interrupts                                                   |
| 6.12 | OB 152: Cycle Statistics                                                                                       |
| 6.13 | OB 153: Set/Read Time for Delay Interrupt                                                                      |
| 6.14 | OB 160 to 163: Loop Counters                                                                                   |
| 6.15 | OB 170: Read Block Stack (BSTACK)                                                                              |
| 6.16 | OB 180: Accessing Variable Data Blocks                                                                         |
| 6.17 | OB 181: Testing Data Blocks (DB/DX) 6-56                                                                       |
| 6.18 | OB 182: Copying a Data Area                                                                                    |
| 6.19 | OB 185: Setting Write Protection                                                                               |
| 6.20 | OB 186: Compressing Memory 6-62                                                                                |
| 6.21 | OB 190/OB 192: Transferring Flags to a Data Block                                                              |
| 6.22 | OB 191/OB 193: Transferring Data Fields to a Flag Area                                                         |
| 6.23 | OB 200 and OB 202 to 205: Multiprocessor Communication                                                         |

| 6.24 | OB 216 to 218: Page Access       6-71         6.24.1       OB 216: Writing to a Page       6-74         6.24.2       OB 217: Reading from a Page       6-76         6.24.3       OB 218: Reserving a Page       6-78         6.24.4       Program Example       6-80 |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 6.25 | OB 220: Sign Extension                                                                                                                                                                                                                                               |  |
| 6.26 | OB 221: Setting the Cycle Monitoring Time                                                                                                                                                                                                                            |  |
| 6.27 | OB 222: Restarting the Cycle Monitoring Time                                                                                                                                                                                                                         |  |
| 6.28 | OB 223: Comparing Restart Types                                                                                                                                                                                                                                      |  |
| 6.29 | OB 224: Transferring Blocks of Interprocessor Communication Flags                                                                                                                                                                                                    |  |
| 6.30 | OB 226, OB 227                                                                                                                                                                                                                                                       |  |
| 6.31 | OB 228: Reading Status Information of a Program Processing Level                                                                                                                                                                                                     |  |
| 6.32 | OB 230 to 237: Functions for Standard Function Blocks                                                                                                                                                                                                                |  |
| 6.33 | OB 240 to 242: Special Functions for Shift Registers                                                                                                                                                                                                                 |  |
| 6.34 | OB 240: Initializing Shift Registers                                                                                                                                                                                                                                 |  |
| 6.35 | OB 241: Processing Shift Registers                                                                                                                                                                                                                                   |  |
| 6.36 | OB 242: Deleting a Shift Register                                                                                                                                                                                                                                    |  |
| 6.37 | OB 250/251: Closed-Loop Control/ PID Algorithm.6-996.37.1 Functional Description of the PID Controller6-996.37.2 PID Algorithm6-101                                                                                                                                  |  |
| 6.38 | OB 250: Initializing the PID Algorithm                                                                                                                                                                                                                               |  |
| 6.39 | OB 251: Processing the PID Algorithm                                                                                                                                                                                                                                 |  |
| 6.40 | OB 254, OB 255: Transferring a Data Block to the DB-RAM                                                                                                                                                                                                              |  |
| 7    | Extended Data Block DX 0 7-1                                                                                                                                                                                                                                         |  |
| 7.1  | Application 7-2                                                                                                                                                                                                                                                      |  |
| 7.2  | Structure of DX 0                                                                                                                                                                                                                                                    |  |
| 7.3  | Parameters for DX 0                                                                                                                                                                                                                                                  |  |
| 7.4  | Examples of Parameter Assignment                                                                                                                                                                                                                                     |  |
| 8    | Memory Assignment and Organization                                                                                                                                                                                                                                   |  |
| 8.1  | Structure of the Memory Area                                                                                                                                                                                                                                         |  |
| 8.2  | Address Distribution in the CPU 928B-3UB21 8-3                                                                                                                                                                                                                       |  |
|      | 8.2.1Address Distribution.8-48.2.2Address Distribution of the Peripherals.8-5                                                                                                                                                                                        |  |
| 8.3  | User Memory Organization in the CPU 928B-3UB21                                                                                                                                                                                                                       |  |
| 0.5  | 8.3.1       Block Headers in the User Memory       8-8                                                                                                                                                                                                               |  |
|      | 8.3.2 Block Address Lists in Data Block DB 0 8-9                                                                                                                                                                                                                     |  |
|      | 8.3.3       RI / RJ Area       8-12         8.3.4       RS / RT Area       8-13                                                                                                                                                                                      |  |
|      | 8.3.5 Bit Assignment of the System Data Words                                                                                                                                                                                                                        |  |

| 9    | Memory Access using Absolute Addresses 9-1                            |                                                                                                                                                                                      | . 9-1                                              |
|------|-----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|
| 9.1  | Introduction                                                          |                                                                                                                                                                                      | . 9-2                                              |
| 9.2  | 9.2.1 LI                                                              | ing the Address in ACCU 1<br>IR/TIR: Loading to or Transferring from a 16-Bit Memory Area Indirectly<br>xamples of using the Registers                                               | . 9-7                                              |
| 9.3  |                                                                       | ng Fields of Memory                                                                                                                                                                  |                                                    |
| 9.4  | 9.4.1 O<br>9.4.2 A<br>9.4.3 A                                         | s with the Base Address Register (BR Register)<br>perations for Transfer between Registers<br>accessing the Local Memory<br>accessing the Global Memory<br>accessing the Page Memory | 9-25<br>9-27<br>9-28                               |
| 10   | Multiproc                                                             | cessor Mode and Communication                                                                                                                                                        | . 10-1                                             |
| 10.1 | 10.1.1 Ez<br>10.1.2 I/0                                               | essor Mode<br>xchanging Data via IPC Flags<br>O Flag Assignment and IPC Flag Assignment in Multiprocessor Mode (DB 1)<br>low to Create Data Block DB 1                               | . 10-4<br>. 10-8                                   |
| 10.2 | 10.2.1 H<br>10.2.2 W<br>10.2.3 H<br>10.2.4 Sy<br>10.2.5 C<br>10.2.6 H | essor Communication                                                                                                                                                                  | 10-15<br>10-16<br>10-17<br>10-20<br>10-21<br>10-22 |
| 10.3 | Runtimes                                                              | of the Communication OBs                                                                                                                                                             | 10-29                                              |
| 10.4 | 10.4.1 Fu<br>10.4.2 C<br>10.4.3 In                                    | ZE Function (OB 200)<br>unction<br>Call Parameters<br>uput Parameters<br>Dutput Parameters                                                                                           | 10-30<br>10-32<br>10-33                            |
| 10.5 | 10.5.1 Fr<br>10.5.2 C<br>10.5.3 In                                    | nction (OB 202)<br>function<br>Call Parameters<br>nput Parameters<br>Dutput Parameters                                                                                               | 10-38<br>10-39                                     |
| 10.6 | 10.6.1 Fr<br>10.6.2 C<br>10.6.3 In                                    | EST Function (OB 203)         Sunction         Call Parameters         nput Parameters         Output Parameters                                                                     | 10-43<br>10-43<br>10-43                            |
| 10.7 | 10.7.1 Fr<br>10.7.2 C<br>10.7.3 In                                    | E Function (OB 204)<br>Function<br>Call Parameters<br>nput Parameters<br>Dutput Parameters                                                                                           | 10-45<br>10-45<br>10-45                            |

| 10.8        | RECEI<br>10.8.1<br>10.8.2<br>10.8.3<br>10.8.4                           | VE TEST Function (OB 205)       10-48         Function       10-48         Call Parameters       10-48         Input Parameters       10-48         Output Parameters       10-48 |
|-------------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10.9        |                                                                         | tions                                                                                                                                                                             |
| 11          | PG Int                                                                  | erfaces and Functions 11-1                                                                                                                                                        |
| 11.1        | Overvie                                                                 | ew                                                                                                                                                                                |
| 11.2        | 11.2.1<br>11.2.2                                                        | Inctions11-3Information11-5Memory Functions and Transfer Functions11-5Program Test11-7                                                                                            |
| 11.3        | Activiti                                                                | es at Checkpoints 11-15                                                                                                                                                           |
| 11.4        | Serial L                                                                | ink PG - PLC via 1st or 2nd Serial Interface 11-16                                                                                                                                |
| 11.5        | Parallel<br>11.5.1<br>11.5.2<br>11.5.3                                  | Operation of Two Serial PG Interfaces11-17Installation11-19Operation11-19Sequence in Certain Operating Situations11-21                                                            |
| Α           | Append                                                                  | dix A-1                                                                                                                                                                           |
| <b>A.</b> 1 | Runtime Comparison between CPU 928-3UA21, CPU 928B-3UB21 and CPU 948A-2 |                                                                                                                                                                                   |
| A.2         | Error Identifiers                                                       |                                                                                                                                                                                   |
| A.3         | STEP 5 Operations not Contained in the CPU 928B A-12                    |                                                                                                                                                                                   |
| A.4         | Identifiers for the Program Processing Levels                           |                                                                                                                                                                                   |
| A.5         | Example "ISTACK Evaluation"                                             |                                                                                                                                                                                   |
| В           | Further reading                                                         |                                                                                                                                                                                   |
| С           | List of Abbreviations                                                   |                                                                                                                                                                                   |

# 1

### Introduction

## Contents of the chapter

This chapter explains how to use the manual and deals with the areas of application of the S5-135U programmable controller with the CPU 928B and its structure. The chapter explains the typical mode of operation of a CPU and the structure of the CPU program.

You will also find a few suggestions about how to tackle programming and will learn some of the features of the CPU 928B (-3UB21) which are important for programming.

If you have already worked with the CPU 928B (-3UB11 or -3UB12) and would like to know the differences between these modules and the CPU 928B (-3UB21), refer to Section 1.8.

## Overview of the chapter

| Section | Description                                           | Page |
|---------|-------------------------------------------------------|------|
| 1.1     | Area of Application for the S5-135U with the CPU 928B | 1-2  |
| 1.2     | Typical Mode of Operation of a CPU                    | 1-3  |
| 1.3     | The Programs in a CPU                                 | 1-5  |
| 1.3.1   | System Program                                        | 1-5  |
| 1.3.2   | User Program                                          | 1-7  |
| 1.4     | Which Operands are available to the User Program?     | 1-9  |
| 1.5     | Accessing Operand Areas and Memory Areas              | 1-12 |
| 1.6     | How to Tackle Programming?                            | 1-13 |
| 1.7     | Programming Tools                                     | 1-16 |
| 1.8     | What is New with the CPU 928B (-3UB21)?               | 1-17 |

### 1.1 Area of Application for the S5-135U with the CPU 928B

| Introduction to<br>the SIMATIC S5<br>family | The S5-135U programmable controller belongs to the family of SIMATIC S5 programmable controllers. With the CPU 928B, it is the most powerful multiprocessor unit for process automation (open and closed loop control, signalling, monitoring, logging).<br>Owing to its modularity and high performance, it can be used for medium to extremely large control systems as well as for complex automation tasks at the plant and process supervision level. |
|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Suitability                                 | The S5-135U with the CPU 928B is particularly suitable for the following:                                                                                                                                                                                                                                                                                                                                                                                  |
|                                             | • Tasks requiring fast bit and word-oriented processing and fast reaction times, i.e. with extremely fast open and closed loop controls.                                                                                                                                                                                                                                                                                                                   |
|                                             | Examples of this are fast processes in mechanical engineering (bottling plant, packing machines or similar systems) and in the automobile industry.                                                                                                                                                                                                                                                                                                        |
|                                             | • Tasks requiring an extremely high storage capacity and fast access times, e.g. in the automobile industry, process and plant engineering.                                                                                                                                                                                                                                                                                                                |
|                                             | • Tasks requiring fast communication with other CPUs installed in the PLC and operating in the multiprocessor mode and with CP modules (e.g. when connected to bus systems, host computers, for visualization, operation and monitoring).                                                                                                                                                                                                                  |
|                                             | • Complex tasks which can be handled efficiently and clearly using the high level languages C and SCL.                                                                                                                                                                                                                                                                                                                                                     |

#### **Typical Mode of Operation of a CPU** 1.2

Mode of The following modes of operation are possible in a CPU: operation of a CPU



Cyclic processing

Phase

1



This is the main part of all activities in the CPU. As the name already says, the same operations are repeated in an endless cycle.

| Cyclic processing can be                                                                                                                                         | divided into three main phases             |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|
| Sequence                                                                                                                                                         | СРИ                                        |
| All the input modules assigned to the CPU<br>are scanned by the system program and the<br>values read in are stored in the process<br>image of the inputs (PII). | Read in process image<br>of the inputs     |
| The values contained in the PII are<br>processed by the user program and the                                                                                     | Evaluate input signals, set output signals |

s, as follows:

Input I 1.4 Input I 1.5 2 ssed by the user program and the values to be output are entered in the process image of the outputs (PIQ). 1 1.3 Q 3.1 The values contained in the process image Output Q 2.0 Output process image of the outputs 3 of the outputs are output by the system Output Q 3.1 program to the output modules assigned to Output Q 4.7 the CPU.

Process

Input I 1.3

## Time-controlled processing

In addition to the cyclic processing, **time-controlled** processing is also available for processes requiring control signals at constant intervals, e.g. non-time critical monitoring functions performed every second.



## Interrupt-driven processing



If the reaction to a particular process signal must be particularly fast, this should be handled with **interrupt-driven** processing. With, for example, a process interrupt, triggered via an interrupt generating module, you can activate a special processing section within your program.

#### Processing according to priority

 $\bigcirc_{\nabla}$ 

The types of processing listed above are handled by the CPU according to their priority.

Since a fast reaction is required to a time or interrupt event, the CPU interrupts cyclic processing to handle a time or interrupt event. Cyclic processing therefore has the lowest priority.

#### 1.3 The Programs in a CPU

Introduction The program existing on every CPU is divided into the following:

• the system program

and

• the user program.

#### 1.3.1 System Program

**Overview** The system program organizes all the functions and sequences of the CPU which do not involve a specific control task (refer to Fig. 1-1).



Fig. 1-1 Tasks of the system program

| Tasks                      | The tasks include the following: <sup>1)</sup>                                                                                                                                                                                                                       |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | • cold and warm restart,                                                                                                                                                                                                                                             |
|                            | • updating the process image of the inputs and outputting the process image of the outputs,                                                                                                                                                                          |
|                            | • calling the cyclic, time-controlled and interrupt-driven programs,                                                                                                                                                                                                 |
|                            | • detection and handling of errors,                                                                                                                                                                                                                                  |
|                            | • memory management,                                                                                                                                                                                                                                                 |
|                            | • communication with the programmer (PG).                                                                                                                                                                                                                            |
|                            |                                                                                                                                                                                                                                                                      |
| User interfaces            | As the user, you can influence the reaction of the CPU to particular situations<br>and errors via special interfaces to the system program.                                                                                                                          |
| Default system<br>reaction | The following chapters, except for Chapter 7, describe the <b>default system reaction</b> to process events or errors. Depending on the defaults, the CPU changes to the stop mode if an operation code error occurs and the error organization block is not loaded. |
| Modifying the defaults     | You can modify the system response by assigning parameters for the data block DX 0.                                                                                                                                                                                  |
|                            | Chapter 7 describes the system response following modification.                                                                                                                                                                                                      |
|                            | <sup>1)</sup> When operating with several CPUs (multiprocessing) further tasks are involved.                                                                                                                                                                         |

#### 1.3.2 User Program

*Structure* Figure 1-2 shows the general structure of a STEP 5 user program.

|                                                      | User pro                                        | ogram                                                                                                                                                                                                      |                                                                                  |
|------------------------------------------------------|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
|                                                      | Code blo                                        | ocks                                                                                                                                                                                                       |                                                                                  |
| Organization<br>blocks<br>OB<br>STEP 5<br>operations | Program<br>blocks<br>PB<br>STEP 5<br>operations | Function<br>blocks<br>FB/FX<br>STEP 5<br>operations<br>FB 8<br>SEGMENT 1<br>NAME ::TRANS<br>0005 :L IB 3<br>0006 :T FW 200<br>0007 :C DB 5<br>0008 :DO FW 200<br>0009 :L DW 0<br>0000A :T QW 6<br>000B :BE | Sequence<br>blocks<br>SB<br>STEP 5<br>operations                                 |
|                                                      | Data block                                      | (S                                                                                                                                                                                                         |                                                                                  |
| DB<br>static or dynami<br>(bits, bytes, wor          |                                                 | 1:<br>2:<br>3:<br>4:<br>5:                                                                                                                                                                                 | KH = 0101;<br>KF = +120;<br>KS = xy;<br>KY = 4.5;<br>KG =<br>KM =                |
| DX<br>static or dynami<br>(bits, bytes, wor          | c data<br>ds, double words)                     | 1:<br>2:<br>3:<br>4:<br>5:<br>6:                                                                                                                                                                           | KH = FFFF;<br>KH = FFFF;<br>KH = FFFF;<br>KH = FFFF;<br>KH = FFFF;<br>KH = FFFF; |

Fig. 1-2 Structure of a STEP 5 user program

**Tasks**The user program contains all the functions required for processing a specific<br/>control task. In general terms, these functions can be assigned to the interface<br/>provided by the system program for the various types of processing, as follows:

| Type of processing          | Task                                                                                                                                                                                                                              |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Cold and warm restart       | To provide the conditions under which the other<br>processing functions can start from a defined status<br>following a cold or warm restart of the control system<br>(e.g. assigning specific values to signals).                 |
| Cyclic processing           | Constantly repeated signal processing (e.g. logic<br>operations on binary signals, reading in and analyzing<br>analog values, specifying binary signals for output,<br>outputting analog values).                                 |
| Time-controlled processing  | <ul> <li>Time-dependent processing with the following time conditions:</li> <li>faster than the average cycle,</li> <li>at a time interval greater than the average cycle time,</li> <li>at a specified point in time.</li> </ul> |
| Interrupt-driven processing | Fast reactions to certain process signals.                                                                                                                                                                                        |
| Error reaction              | Handling problems within the normal sequence of the program.                                                                                                                                                                      |

Storing the user program
The CPU 928B has two areas for storing blocks:
User memory: max. 64 Kbytes
The user memory is located on the main board (CPU).
Data block RAM (DB RAM): max. 46 Kbytes
The DB RAM makes up an additional memory area for storing data blocks and is located on the main board (CPU).

*Interfaces to the* **Organization** blocks are available as interfaces to the system program for the special types of processing.

#### 1.4 Which Operands are available to the User Program?

Overview

The CPU 928B provides the following operand areas for programming:

- process image and I/Os
- flags (F flags and S flags)
- timers/counters
- data blocks

Process image of the inputs and outputs PII/PIQ

| Characteristics                                                                                                                                             | Size                                           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
| The user program can access the following data types in the process<br>image extremely quickly:<br>- single bits,<br>- bytes,<br>- words,<br>- double words | 128 bytes<br>each for<br>inputs and<br>outputs |

#### I/O area (P area)

| Characteristics                                                      | Size                  |
|----------------------------------------------------------------------|-----------------------|
| The user program can access the I/O modules directly via the S5 bus. | 256 bytes<br>each for |
| The following data types are possible:<br>- bytes,<br>- words.       | inputs and<br>outputs |

#### Extended I/O area (O area)

| Characteristics                                                                                                            | Size                                           |
|----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
| The user program can access the I/O modules directly via the S5 bus.<br>The following data types are possible:<br>- bytes, | 256 bytes<br>each for<br>inputs and<br>outputs |
| - words.                                                                                                                   | 1                                              |

#### F flags

| Characteristics                                                                                                                                                            | Size                     |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| The flag area is a memory area which the user program can access<br>extremely quickly with certain operations.                                                             | 2048 bits<br>(256 bytes) |
| The flag area should be used ideally for working data required often.                                                                                                      |                          |
| The following data types can be accessed:<br>- single bits,<br>- bytes,<br>- words,<br>- double words.                                                                     |                          |
| Single flag bytes can be used as <b>interprocessor communication flags</b> (IPC flags) to exchange data between the CPUs in the multiprocessor mode (refer to Chapter 10). |                          |
| IPC flags are updated by the system program at the end of the cycle via a buffer in the coordinator or CP/IP.                                                              |                          |

# S flags (extended flag area)

| Characteristics                                                                                                                                                                                                                     | Size                      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| The CPU 928B also contains an additional flag area, the S flag area.<br>The user program can also access this area extremely quickly as with<br>the F flags.                                                                        | 8192 bits<br>(1024 bytes) |
| S flags <b>cannot</b> however by used as <b>actual operands</b> with function block calls nor as <b>IPC flags</b> for data exchange between the CPUs. The bit test operations of the CPU 948 can also not be used with the S flags. |                           |
| These flags can only be used with the PG system software "S5-DOS" from version 3.0 upwards or "S5-DOS/MT" from version 1.0 upwards.                                                                                                 |                           |

#### Timers (T)

| Characteristics                                                                                                                                                                                                     | Size               |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| The user program loads timer cells with a time value between 10 ms and 9990 s and by means of a start operation, decrements the timer from this value at the preselected intervals until it reaches the value zero. | 256 timer<br>cells |

#### Counters (C)

| Characteristics                                                                                            | Size         |  |
|------------------------------------------------------------------------------------------------------------|--------------|--|
| The user program loads counter cells with a start value (max. 999) and then increments or decrements them. | 256 counters |  |

# Data words in the current data block

| Characteristics                                                                                                                                                                                                                                                                                                                                          | Size            |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| <ul> <li>A data block contains constants and/or variables in the byte, word or double word format. With STEP 5 operations, you can always access the "current" data block (refer to Section 2.4).</li> <li>The following data types can be accessed: <ul> <li>single bits,</li> <li>bytes,</li> <li>words,</li> <li>double words.</li> </ul> </li> </ul> | 256 words<br>1) |

<sup>1)</sup> In data blocks with a length greater than 256 words, you can only access data words with the numbers > 255 with operations for absolute memory access (refer to Chapter 9) or with OB 180 (refer to Chapter 6).

### 1.5 Accessing Operand Areas and Memory Areas

| Introduction           | STEP 5 operations use two different mechanisms for accessing operand areas and the entire memory:                                                                                                                                                                                                                                                                                                                                             |  |  |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                        | • relative adressing                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|                        | • absolute addressing                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| Relative<br>addressing | The majority of STEP 5 operations address a memory location relative to the beginning of the operand area. If these operations are used exclusively, code and data areas of the user program are protected against unintentional overwriting. At the same time, the user program is dependent on the CPU as long as the CPU has an appropriate operand area.                                                                                  |  |  |
| Absolute<br>addressing | Some STEP 5 operations work with absolute addresses. These operations can be used to access the entire memory area. They can only be used in function blocks and should only be used with great care due to the danger of data corruption. These operations are dependent on the CPU used.                                                                                                                                                    |  |  |
| Current data<br>block  | Data blocks are loaded into the user memory or the DB-RAM by the system<br>program. Their location depends on the memory space available in each case.<br>The lengths of the individual data blocks can vary and are set when<br>programming the data blocks.                                                                                                                                                                                 |  |  |
|                        | The current data block is the data block whose starting address and length are<br>entered in special registers. This entry is made via a special STEP 5 operation for<br>calling or "opening" a data block (like the page of book). Unless operations with<br>absolute addressing are used, the user program can only access the current data<br>block. The following data types are possible: single bits, bytes, words and double<br>words. |  |  |

### 1.6 How to Tackle Programming

| Introduction                  | If you are an experienced user, you have probably found the most suitable<br>method for creating programs for yourself and you can skip this section.                                |  |  |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                               | Less experienced readers will find tips for designing, programming, testing and starting up the STEP 5 program.                                                                      |  |  |
| Implementation<br>stages      | The implementation of the STEP 5 control program can be divided into three stages:                                                                                                   |  |  |
|                               | 1. determining the technological task                                                                                                                                                |  |  |
|                               | 2. designing the program                                                                                                                                                             |  |  |
|                               | 3. creating, testing and starting the program                                                                                                                                        |  |  |
| <i>Recursive</i><br>procedure | In practice, you will recognize that certain steps must be repeated (recursive procedure), e.g. when you realize that more signals are required to improve the handling of the task. |  |  |
| Implementation<br>stage 1     | Determining the technological task                                                                                                                                                   |  |  |
| Slaye I                       | This stage can be divided into three steps:                                                                                                                                          |  |  |
|                               | 1. creating a general block diagram outlining the control tasks of your process                                                                                                      |  |  |
|                               | 2. creating a list of the input and output signals required for the task                                                                                                             |  |  |
|                               | 3. improving the block diagram by assigning the signals and any particular time conditions and/or counter statuses to the individual blocks                                          |  |  |

| Implementation stage 2 | Designing the program                                                                                                                                                                         |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        | We recommend you proceed as follows:                                                                                                                                                          |
|                        | 1. Based on the improved block diagram, decide on the types of processing required of your program (cyclic processing, time-controlled processing etc.) and select the OBs required for this. |
|                        | 2. Divide the types of processing into technological and/or functional units.                                                                                                                 |
|                        | 3. Check whether the units can be assigned to a program or function block and select the blocks you require (PB x, FB y etc.)                                                                 |
|                        | 4. Find out which timers, counters and data or results memory you require.                                                                                                                    |

5. Specify the tasks for each of the proposed code blocks and the data for flags and data blocks which may be required. Create flow diagrams for the code blocks.

#### Notes on the scope of cyclic processing:

When deciding on the types of processing, keep the following conditions in mind:

- The cycle must run through quickly enough. The process statuses must not change more quickly than the CPU can react. Otherwise the process can get out of control.
- The maximum reaction time should be taken as twice the cycle time.

The cycle time is determined by the cyclic processing of the system program and the type and scope of the user program. It is often not constant, since the cyclic user program may be interrupted when time and interrupt-driven program sections are called.

#### Implementation Creating, testing and starting up the program

stage 3

This stage should consist of the following steps:

1. Decide on the type of representation for the code blocks (LAD, CSF or STL, refer to Chapter 2).

Remember that function blocks can only be created in the STL method of representation.

- 2. Program all code and data blocks (please refer to your STEP 5 manual).
- 3. Start up the blocks one after the other (you may have to program a different OB for each individual step, to call the code blocks):
  - load the block(s)
  - test the block(s)

(For more detailed information please refer to your STEP 5 manual and Chapter 11).

4. When you are certain that all the code blocks run correctly and all the data can be correctly calculated and stored, you can start up your whole program.

#### Note on test strategies:

When you actually start up your program for the first time in genuine process operation, i.e. with real input and more importantly output signals, is a decision that must be left up to yourself or to a team of experts.

The more complex the process, the greater the risk and therefore the greater the care required when starting up.

### 1.7 Programming Tools

| Suitable PGs      | The following programmers are available for creating your user program, PG 685, PG 710, PG 730, PG 750 and PG 770.                                                                                                       |  |  |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                   | You can check on the performance and characteristics of these devices in the catalog ST 59.                                                                                                                              |  |  |  |
|                   | Note<br>Enter the CPU ID for CPU 922 (0010B) in system data word<br>RS 29 (see Chapter 8) in order to be able to use a PG 615 or a CP 3xx.<br>In this case, you cannot use S flags.                                      |  |  |  |
|                   | If you do not change the ID, this will lead to erroneous indicators, e.g. in the case of ISTACK output, or to the loss of some debugging aids.                                                                           |  |  |  |
|                   | In all programmers, the <b>STATUS test function</b> operates without restriction only at scan times of $\leq 2.5$ s. This value is halved in the case of parallel operation of 2 programmer interfaces (see Chapter 11). |  |  |  |
| Suitable software | You can create user programs for SIMATIC S5 programmable controllers as follows:                                                                                                                                         |  |  |  |
|                   | • In the <b>STEP 5</b> programming language,                                                                                                                                                                             |  |  |  |
|                   | Here you require the STEP 5 programming package along with the system software STEP 5/ST or STEP 5/MT (description, refer to /3/ in Chapter 13),                                                                         |  |  |  |
|                   | or                                                                                                                                                                                                                       |  |  |  |
|                   | • In a higher programming language:                                                                                                                                                                                      |  |  |  |
|                   | If you are familiar with programming in higher programming languages, you can also formulate your STEP 5 program for the CPU 928B as follows:                                                                            |  |  |  |
|                   | <ul> <li>SCL (refer to /12/ in Further Reading, the SCL compiler is contained in<br/>the PG software "S5-DOS/MT" from version 6 upwards.)</li> </ul>                                                                     |  |  |  |
|                   | You can also create <b>programs for sequence control systems</b> in a graphic representation using the <b>GRAPH 5</b> programming package (description, refer to /4/ in Further Reading).                                |  |  |  |
|                   | Depending on the task, you can also incorporate "off-the-shelf" standard function blocks in your user program. The performance and characteristics of these blocks are described in the catalog ST5 7/11/.               |  |  |  |
|                   |                                                                                                                                                                                                                          |  |  |  |

#### 1.8 What is New with the CPU 928B (-3UB21)?

*Introduction* The CPU 928B (-3UB21) offers you the following new functions and characteristics compared to the CPU 928B (-3UB12).

|                                                        | CPU 928B (-3UB21)                                                                                                                                                                                                                                                                    | CPU 928B (-3UB12)                                              |  |
|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|--|
| Slot assignment                                        | The CPU requires only one slot                                                                                                                                                                                                                                                       | The CPU requires two slots                                     |  |
| Integrated RAM                                         | RAM (internal RAM) integrated in the CPU with a capacity of 64 Kbytes                                                                                                                                                                                                                | Pluggable RAM submodules with different memory capacities      |  |
| Memory card                                            | SIMATIC memory card (Flash EPROM)                                                                                                                                                                                                                                                    | Pluggable EPROM submodules                                     |  |
|                                                        | The user program is copied from the<br>memory card to the internal RAM for<br>processing and is then read-only                                                                                                                                                                       | The user program remains on the EPROM submodule for processing |  |
| DB 0 structure                                         | Only after overall reset of CPU                                                                                                                                                                                                                                                      | After power on or overall reset of CPU                         |  |
| Floating point math                                    | Mantissa with 24 bits                                                                                                                                                                                                                                                                | Mantissa with 16 or 24 bits                                    |  |
| Extended cycle<br>statistics<br>Software<br>protection | The functions of the cycle statistics (OB 152) have been extended compared to the -3UB12 version, to include higher resolutions of the timers.<br>Via RS 139, a password can be assigned with which you can prevent unauthorized reading and editing of the user program in the CPU. |                                                                |  |
| Programming the memory card                            | A PG 7xx with S5-DOS from V6.x onwards is required to program the Flash EPROM memory cards. A program on an old memory submodule can be reprogrammed to a memory card.                                                                                                               |                                                                |  |
| Reloading the memory card                              | If a Flash EPROM memory card is plugged when an overall reset is performed, the operating system copies the contents to the internal RAM and creates DB 0. The memory card is no longer required for operation.                                                                      |                                                                |  |
| EPROM mode                                             | Once the memory card has been reloaded (via overall reset), the user memory                                                                                                                                                                                                          |                                                                |  |

**EPROM mode** Once the memory card has been reloaded (via overall reset), the user memory (address 0000H to 7FFFH) is write-protected for PG access and for write access by the user program. This corresponds to the behavior of a CPU 928B when an EPROM submodule is plugged.

| Influencing the<br>write protection<br>(RS 138) (OB 185)                | <ul> <li>The write protection can be set or removed specifically using two methods:</li> <li>by setting/resetting RS 138 before a cold restart of the CPU is completed (e-valuated at the end of OB 20)</li> <li>by calling OB 185 in OB 20 (only possible here), the write protection is activated/deactivated immediately.</li> </ul> |
|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>Compressing<br/>memory by<br/>means of user<br/>program (OB 186)</i> | By calling OB 186, the PG function "compress memory" can be started by the user program. As the function may then collide with active PG jobs, OB 186 and PG functions are each blocked if the other is active.                                                                                                                         |
| Cycle time<br>statistics<br>(OB 152)                                    | <ul> <li>The cycle time statistics are no longer linked to the cycle time monitoring, which means that there is no influence caused by restarting cycle time monitoring.</li> <li>As an alternative to the 1-ms resolution, the resolution can now be increased to 10 ms by means of a new function number.</li> </ul>                  |
| Accessing the<br>condition code<br>byte OB 110                          | OB 110 can be used more frequently as the condition codes are no longer partly overwritten by the block call as they were previously.                                                                                                                                                                                                   |
| EPROM memory<br>check                                                   | The operating system now always run an EPROM memory check during power<br>on. This means the OB 226 (read operating system word) and OB 227 (read<br>checksum) have become superfluous. The blocks are still available for<br>compatibility reasons, but both return the value 0.                                                       |
| <i>New special<br/>function OBs</i>                                     | <ul> <li>The CPU 928B-3UB21 has the following new special functions:</li> <li>OB 134 for the *D operation</li> <li>OB 135 for the /D operation</li> <li>OB 136 for the MOD operation</li> <li>OB 139 for the PUSH operation</li> </ul>                                                                                                  |

# 2

## **User Program**

Contents of the<br/>chapterThe following chapter explains the components that make up a STEP 5 user<br/>program for the CPU 928B and how it can be structured.

## Overview of the chapter

| Section | Description                                              | Page |
|---------|----------------------------------------------------------|------|
| 2.1     | STEP 5 Programming Language                              | 2-2  |
| 2.1.1   | The LAD, CSF, STL Methods of Representation              | 2-2  |
| 2.1.2   | Structured Programming                                   | 2-4  |
| 2.1.3   | STEP 5 Operations                                        | 2-5  |
| 2.1.4   | Number Representation                                    | 2-6  |
| 2.1.5   | STEP 5 Blocks and Storing them in Memory                 | 2-10 |
| 2.2     | Program, Organization and Sequence Blocks                | 2-14 |
| 2.2.1   | Organization Blocks as User Interfaces                   | 2-16 |
| 2.2.2   | Organization Blocks for Special Functions                | 2-19 |
| 2.3     | Function Blocks                                          | 2-21 |
| 2.3.1   | Structure of Function Blocks                             | 2-22 |
| 2.3.2   | Programming Function Blocks                              | 2-24 |
| 2.3.3   | Calling Function Blocks and Assigning Parameters to them | 2-26 |
| 2.3.4   | Special Function Blocks                                  | 2-31 |
| 2.4     | Data Blocks                                              | 2-33 |
| 2.4.1   | Creating Data Blocks                                     | 2-35 |
| 2.4.2   | Opening Data Blocks                                      | 2-36 |
| 2.4.3   | Special Data Blocks                                      | 2-39 |

#### 2.1 STEP 5 Programming Language

Introduction With the STEP 5 programming language, you convert automation tasks into programs that run on SIMATIC S5 programmable controllers. You can program simple binary functions, complex digital functions and arithmetic operations including floating point arithmetic using STEP 5. Types of The operations of the STEP 5 programming language are divided into the operation following groups: **Basic operations:** you can use these operations in all code blocks methods of representation: ladder diagram (LAD), control system flowchart (CSF), statement list (STL). Supplementary operations and system operations: can only be used in function blocks only statement list (STL) method of representation

system operations: only experienced STEP 5 programmers should use system operations

#### 2.1.1 The LAD, CSF, STL Methods of Representation

Overview

When programming in STEP 5, you can choose between the three methods of representation ladder diagram (LAD), control system flowchart (CSF) and statement list (STL) for each individual code block. You can choose the method of representation that best suits your particular application.

The machine code MC5 that the programmers (PGs) generate is the same for all three methods of representation.

If you follow certain rules when programming in STEP 5 (see /3/ in Chapter 13), the programmer can translate your user program from one method of representation into any other.

# GraphicWhile the ladderrepresentation orrepresentation representation represents STEP

While the ladder diagram (LAD) and control system flowchart (CSF) methods of representation represent your STEP 5 program graphically, statement list (STL) represents STEP 5 operations individually as mnemonic abbreviations.

| Ladder diagram                                                | Statement list                                                         | Control system flowchart                                           |  |
|---------------------------------------------------------------|------------------------------------------------------------------------|--------------------------------------------------------------------|--|
| Programming with<br>graphic symbols<br>like a circuit diagram | Programming with<br>mnemonic abbreviations<br>of function designations | Programming with graphic symbols                                   |  |
| complies with<br>DIN 19239                                    | complies with<br>DIN 19239                                             | complies with<br>IEC 117-15<br>DIN 40700<br>DIN 40719<br>DIN 19239 |  |
|                                                               | STL<br>A I<br>AN I<br>A I<br>ON I<br>O I<br>= Q                        | CSF<br>> = 1<br>> = 1<br>                                          |  |

Fig. 2-1 Methods of representation in the STEP 5 programming language

GraphicGRAPH 5 is a programming language for graphic representation of sequential<br/>controls. It is at a higher level than the LAD, CSF, STL methods of<br/>representation. A program written in GRAPH 5 as a graphic representation is<br/>automatically converted to a STEP 5 program by the PG.

#### 2.1.2 Structured Programming

**Overview** Using STEP 5, you can structure your program by dividing it into self-contained program sections (blocks).

This division of your program clarifies the essential program structures making it easy to recognize the system parts that are related within the software.

Advantages Structured programming offers you the following advantages:

- simple and clear creation of programs, even large ones
- standardization of program parts
- simple program organization
- easy program changes
- simple, section by section program test
- simple system start-up
- What is a block?A block is a part of the user program that is distinguished by its function,<br/>structure or application. You can differentiate between blocks that contain<br/>statements (code) i.e. organization blocks, program blocks, function blocks or<br/>sequence blocks, and blocks that contain data (data blocks).

#### 2.1.3 STEP 5 Operations

**Definition** A STEP 5 operation is the smallest independent unit of the user program. It is the work specification for the CPU. A STEP 5 operation consists of an operation and an operand as shown in the following example:

| Example                              | Operation code Parameter<br>:O F 54.1<br>Operation Operand<br>(what is to be done?) Operand<br>(with what is the operation to be done?)                                               |  |  |
|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Absolute and<br>symbolic<br>operands | You can enter the operand <b>absolutely</b> or <b>symbolically</b> (using an assignment list) as shown in the following example:                                                      |  |  |
|                                      | Absolute representation: :A I 1.4                                                                                                                                                     |  |  |
|                                      | Symbolic representation: :A -Motor1                                                                                                                                                   |  |  |
|                                      | For more information on absolute and symbolic programming, refer to your STEP 5 manual.                                                                                               |  |  |
| Application of<br>STEP 5 operations  | The STEP 5 operation set enables you to do the following:                                                                                                                             |  |  |
| •                                    | • set or reset and combine binary values logically                                                                                                                                    |  |  |
|                                      | load and transfer values                                                                                                                                                              |  |  |
|                                      | • compare values and process them arithmetically                                                                                                                                      |  |  |
|                                      | • specify timer and counter values                                                                                                                                                    |  |  |
| convert number representations       |                                                                                                                                                                                       |  |  |
|                                      | <ul> <li>call blocks and execute jumps within a block<br/>and</li> </ul>                                                                                                              |  |  |
|                                      | • influence program execution                                                                                                                                                         |  |  |
| Result of logic operation RLO        | The central bit for controlling the program is the result of logic operation RLO.<br>This is obtained as a result of binary logic operations and is influenced by some<br>operations. |  |  |
|                                      | Section 3.5 describes the whole STEP 5 operation set and explains how the RLO is obtained. This section also includes programming examples for individual STEP 5 operations.          |  |  |

#### 2.1.4 Number Representation

| Overview                     |                                                                                                                                                                                                                                                                                                                | To allow the CPU to logically combine, modify or compare numerical values, these values must be located in the accumulators (working registers of the CPU) as binary numbers. |  |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                              | Depending on the operations to be carried out, the following number representations are permitted in STEP 5:                                                                                                                                                                                                   |                                                                                                                                                                               |  |
|                              | • Binary numbers:                                                                                                                                                                                                                                                                                              | 16-bit fixed point numbers                                                                                                                                                    |  |
|                              |                                                                                                                                                                                                                                                                                                                | 32-bit fixed point numbers                                                                                                                                                    |  |
|                              |                                                                                                                                                                                                                                                                                                                | 32-bit floating point numbers (with a 24-bit mantissa)                                                                                                                        |  |
|                              | • Decimal numbers:                                                                                                                                                                                                                                                                                             | BCD-coded numbers (sign and 3 digits)                                                                                                                                         |  |
| Numerical input<br>on the PG | When you use a programmer to input or display number values, you set the data format on the programmer (e.g. KF or fixed point) in which you intend to enter or display the values. The programmer converts the internal representation into the form you have requested.                                      |                                                                                                                                                                               |  |
| Permitted<br>operations      | You can carry out <b>all arithmetic operations</b> with the 16-bit fixed point numb<br>and floating point numbers, including comparison, addition, subtraction,<br>multiplication and division.<br>Note<br>Do not use BCD-coded numbers for arithmetical operations, since this leads<br>to incorrect results. |                                                                                                                                                                               |  |
|                              |                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                               |  |
|                              | Use 32-bit fixed point numbers to execute comparison operations. These are also necessary as an intermediate level when converting numbers in BCD code to floating point numbers. With the operations +D and -D they can also be used for addition and subtraction.                                            |                                                                                                                                                                               |  |
|                              | The STEP 5 programming language also has <b>conversion operations</b> that enable you to convert numbers directly to the most important of the other numerical representations.                                                                                                                                |                                                                                                                                                                               |  |

## *16-bit and 32-bit fixed point numbers*

Fixed point numbers are whole binary numbers with a sign.

#### Coding of fixed point numbers

Fixed point numbers are 16 bit (= 1 word) or 32 bit (= 2 words) in binary representation. Bit 15 or bit 31 contains the sign.

- '0' = positive number
- '1' = negative number

The two's complement representation is used for negative numbers.

#### **PG** input

| 16-bit fixed point number | KF |
|---------------------------|----|
| 32-bit fixed point number | DH |

#### Permitted numerical range

| 16-bit fixed point number | -32768 to +32767           |
|---------------------------|----------------------------|
| 32-bit fixed point number | -2147483648 to +2147483647 |

#### Using fixed point numbers

Use fixed point numbers for simple calculations and for comparing number values. Since fixed point numbers are always whole numbers, remember that the result of dividing two fixed point numbers is also a fixed point number without decimal places.

#### **Floating point numbers**

Floating point numbers are positive and negative fractions. They always occupy a double word (32 bits). A floating point number is represented as an exponential number.

In the CPU 928B, the default mantissa is 24 bits long (bits 0 to 23) for adding, subtracting, multiplying and dividing.

The exponent is 8 bits long and indicates the order of magnitude of the floating point number. The sign of the exponent tells you whether the value of the floating point number is greater or less than 0.1.

#### Using floating point numbers

Use floating point numbers for solving extensive calculations, especially for multiplication and division or when you are working with very large or very small numbers!

#### Accuracy

The mantissa indicates the accuracy of the floating point number as follows:

• Accuracy with a 24-bit mantissa:

 $2^{-24} = 0.00000059604$  (corresponds to 7 decimal places)

If the sign of the mantissa is "0" the number is positive; if the sign is "1" it is a negative number in its two's complement representation.

The **floating point value '0'** is represented as the binary value **80000000H** (32 bits, see below).

#### **Coding floating point numbers**

A floating point number is coded as follows:



Specification of the data format for floating point numbers at the PG: KG

#### Permissible numerical range

 $\pm 0.1469368 \ge 10^{-38}$  to  $\pm 0.1701412 \ge 10^{39}$ 

#### Input/output on PG

a) in a code block:

You want to load the number N = 12.34567 as a floating point number.

Input:

#### :LKG1234567+2

Mantissa with sign

PG display after you enter the line:

Exponent (base 10) with sign

Value of the number input:  $+0.1234567 \times 10^{+2} = 12.34567$ 

b) in a data block:

You want to define the number N = -0.005 as a floating point constant.

Input:

6: KG = -5000000 - 02

PG display after you enter the line:

| 6: KG =- 5000000 - 02      |                                 |
|----------------------------|---------------------------------|
| Mantissa with sign         | Exponent (base 10)<br>with sign |
| Value of the number input: | $-0.5 \ge 10^{-2} = 0.005$      |

Numbers in BCD code

Decimal numbers are represented as numbers in BCD code. With their sign and three digits, they occupy 16 bits (1 word) in an accumulator as shown in the following example:

| 15 |   |   | 12 | 11       | 8 7 | 4    | 3    | 0 |
|----|---|---|----|----------|-----|------|------|---|
| v  | v | v | V  | hundreds |     | tens | ones |   |

The individual digits are positive 4-bit binary numbers between 0000 and 1001 (0 and 9 decimal).

The left bits are reserved for the sign as follows:

| Sign for a positive number: | 0000 |
|-----------------------------|------|
| Sign for a negative number: | 1111 |

#### Permissible numerical range

-999 to +999

#### 2.1.5 STEP 5 Blocks and Storing them in Memory

| Identifier  | A block is identified as follows:                                                                                                                                                                                                                                                   |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | • the block type (OB, PB, SB, FB, FX, DB, DX)                                                                                                                                                                                                                                       |
|             | and                                                                                                                                                                                                                                                                                 |
|             | • the block number (number between 0 and 255).                                                                                                                                                                                                                                      |
| Block types | The STEP 5 programming language differentiates between the following block types:                                                                                                                                                                                                   |
|             | Organization blocks (OB)                                                                                                                                                                                                                                                            |
|             | Organization blocks are the interface between the system program and the user program. They can be divided into two groups as follows:                                                                                                                                              |
|             | <ul> <li>With OB 1 to OB 39, you can control program execution, the restart<br/>procedure of the CPU and the reaction in the event of an error. You<br/>program these blocks yourself according to your automation task. These<br/>OBs are called by the system program.</li> </ul> |
|             | <ul> <li>OBs 40 to 255 contain special functions of the system program. You can<br/>call these blocks, if required, in your user program.</li> </ul>                                                                                                                                |
|             | • Program blocks (PB)                                                                                                                                                                                                                                                               |
|             | You require program blocks to structure your program. They contain program<br>parts divided according to technological and functional criteria. Program<br>blocks represent the heart of the user program.                                                                          |
|             | • Sequence blocks (SB)                                                                                                                                                                                                                                                              |
|             | Sequence blocks were originally special program blocks for step by step processing of sequencers. In the meantime, however, sequencers can be programmed with GRAPH 5. Sequence blocks have therefore lost their original significance in STEP 5.                                   |
|             | Sequence blocks now represent an extension of the program blocks and are used as program blocks.                                                                                                                                                                                    |
|             | • Function blocks (FB/FX)                                                                                                                                                                                                                                                           |
|             | You use function blocks to program frequently recurring and/or complex functions (e.g. digital functions, sequence control systems, closed loop controls and signalling functions).                                                                                                 |
|             | A function block can be called several times by higher order blocks and supplied with new operands (assigned parameters) at each call.                                                                                                                                              |
|             | Using block type FX increases the maximum number of possible function blocks from 256 to 512.                                                                                                                                                                                       |

|                                   | • Data blocks (DB/DX)<br>Data blocks contain the (fixed or variable) data with which the user program<br>works. This type of block contains no STEP 5 statements and has a distinctly<br>different function from the other blocks. Using block type DX doubles the<br>number of possible data blocks.                                                                                                                                |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Formal structure<br>of the blocks | <ul> <li>All blocks consist of the following two parts:</li> <li>a block header<br/>and</li> <li>a block body</li> </ul>                                                                                                                                                                                                                                                                                                             |
| Block header                      | The <b>block header</b> is always 5 words long and contains information for block management in the PG and data for the system program.                                                                                                                                                                                                                                                                                              |
| Block body                        | <ul> <li>Depending on the block type, the block body contains the following:</li> <li>STEP 5 operations (in OB, PB, SB, FB, FX),</li> <li>variable or constant data (in DB, DX)<br/>and</li> <li>a formal operand list (in FB, FX).</li> </ul>                                                                                                                                                                                       |
| Block preheader                   | The programmer also generates a <b>block preheader</b> (DV, DXV, FV, FXV) for<br>block types DB, DX, FB and FX. These block preheaders contain information<br>about the data format (for DB and DX) or the jump labels (for FB and FX). Only<br>the PG can evaluate this information. Consequently the block preheaders are not<br>transferred to the CPU memory. You cannot influence the contents of the block<br>header directly. |
| Maximum length                    | A STEP 5 block can occupy a maximum of 4096 words in the program memory of the CPU (1 word corresponds to 16 bits).                                                                                                                                                                                                                                                                                                                  |

| Available blocks | You can pro | gram the following block types:    |
|------------------|-------------|------------------------------------|
|                  | OB          | 1 to 39                            |
|                  | FB          | 0 to 255                           |
|                  | FX          | 0 to 255<br>0 to 255 $-$ total 512 |
|                  | PB          | 0 to 255                           |
|                  | SB          | 0 to 255                           |
|                  | DB          | 3 to 255<br>3 to 255 total 506     |
|                  | DX          | - total 506                        |

Data blocks DB 0, DB 1, DB2, DX 0, DX 1 and DX 2 contain parameters. These are reserved for specific functions and you cannot use them as normal data blocks.

**Block storage** The programmer stores all programmed blocks in the program memory in the order in which they are transferred (Fig. 2-2). The programmer function "Transfer data blocks B" transfers first the code blocks then the data blocks to the PLC. In RAM mode, the user memory is first to be filled with data blocks after transfer of the code blocks and then the remaining data blocks are written into internal DB RAM.

The start addresses of all stored blocks are placed in data block DB 0.



Fig. 2-2 Example of block storage in the user memory

| Alternative<br>loading (only in<br>the case of CPU<br>928B-3UB12) | By setting bit 0 in system data word RS 144, you can load data blocks first into internal DB RAM first (i.e. as long as space is available) ("Alternative loading" - see Chapter 8/RS 144). Data blocks are transferred to the user memory only when the DB RAM has been filled.                                          |
|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Correcting and deleting blocks                                    | When you <b>correct</b> blocks in "RAM mode", the old block is declared invalid in<br>the memory and a new block is entered.<br>Similarly, when blocks are <b>deleted</b> , they are not really deleted, instead they are<br>declared invalid. Deleted and corrected blocks therefore continue to use up<br>memory space. |
|                                                                   | <b>Note</b><br>You can use the COMPRESS MEMORY online function to make space for<br>new blocks. This function optimizes the utilization of the memory by<br>deleting blocks marked as invalid and shifting valid blocks together.<br>Compression is handled separately according to user memory and internal              |

DB-RAM (see Section 11.2.2).

#### 2.2 Program, Organization and Sequence Blocks

*Introduction* Program blocks (PBs), organization blocks (OBs) and sequence blocks (SBs) are the same with respect to programming and calling. You can program all three types in the LAD, CSF and STL methods of representation.

- **Programming** When programming organization, program and sequence blocks, proceed as follows:
  - 1. First indicate the type of block and then the number of the block that you want to program.

The following numbers are available for the type of block listed:

| <ul> <li>program blocks</li> </ul>      | 0 to 255 |
|-----------------------------------------|----------|
| <ul> <li>organization blocks</li> </ul> | 1 to 39  |
| <ul> <li>sequence blocks</li> </ul>     | 0 to 255 |

2. Enter your program in the STEP 5 programming language.

When programming PBs, OBs and SBs, you can only use the STEP 5 basic operations!

A STEP 5 block should always be a self-contained program section. Logic operations must always be completed within a block.

3. Complete your program input with the block end operation "BE".

**Block calls** With the exception of OB 1 to OB 39 you must call the blocks to process them. Use the special STEP 5 block call operations to call the blocks.

You can program block calls inside an organization, program, function or sequence block. They can be compared with jumps to a subroutine. Each jump causes a block change. The return address within the calling block is buffered by the system.

#### Unconditional and conditional block calls

Block calls can be unconditional or conditional as follows:

#### • Unconditional call

The "JU" statement belongs to the unconditional operations. It has no effect on the RLO. The RLO is carried along with the jump to the new block. Within the new block, it can be evaluated but no longer combined logically.

The addressed block is processed **regardless** of the previous result of logic operation (RLO - see Section 3.4).

Example: JU PB 100

#### • Conditional call

The JC statement belongs to the conditional operations. The addressed block is processed only if the previous RLO = 1. If the RLO = 0, the jump is not executed.

Example: JC PB 100

#### Note

After the conditional jump operation is executed, the RLO is set to "1" regardless of whether or not the jump to the block is executed.



Fig. 2-3 Block calls that enable processing of a program block

| Effect of the BE statement | After the "BE" statement (block end), the CPU continues the user program in the block in which the block call was programmed. Program execution continues at the STEP 5 statement following the block call.                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | The "BE" statement is executed regardless of the RLO. After "BE", the RLO can<br>no longer be combined logically. However, the RLO or arithmetic result<br>occurring directly before execution of the BE operation is transferred to the<br>block where the call originated and can be evaluated there. When program<br>execution returns from the block that has been called, the contents of ACCU 1,<br>ACCU 2, ACCU 3 and ACCU 4, the condition codes CC 0 and CC 1 and the<br>RLO are not changed. (Refer to Section 3.5 for more detailed information about<br>the ACCUs, CC0/CC1 and RLO). |

#### 2.2.1 Organization Blocks as User Interfaces

Introduction Organization blocks form the interfaces between the system program and the user program. Organization blocks OB 1 to OB 39 belong to your user program just as program blocks. By programming these OBs, you can influence the behavior of the CPU during start-up, program execution and in the event of an error. The organization blocks are effective as soon as they are loaded in the PLC memory. This is also possible while the PLC is in the run mode.

Once the system program has called a specific organization block, the user program it contains is executed.

#### Note

You can program blocks OB 1 to OB 39 as user interfaces and they are called automatically by the system program as a reaction to certain events.

For **test purposes**, you can also call these organization blocks from the user program (JC/JU OB xxx). It is, however, not possible to trigger a COLD RESTART, e.g. by calling OB 20.

The following table provides you with an overview of the user interfaces (OBs).

## OBs for program execution

Table 2-1Overview of the organization blocks for program execution

| Organization blocks for controlling program execution |                                                                                                               |  |  |
|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--|--|
| Block                                                 | Block Function and call criterion                                                                             |  |  |
| OB 1                                                  | Organization of cyclic program execution; first call after a start-up, then cyclic call                       |  |  |
| OB 2                                                  | Organization of interrupt-driven program execution;<br>Call by interrupt signal of S5 bus (process interrupt) |  |  |
| OB 3 to OB 5                                          | Not used with the CPU 928B                                                                                    |  |  |
| OB 6                                                  | Delay interrupt (from Version -3UB12)                                                                         |  |  |
| OB 7, OB 8                                            | Not used with the CPU 928B                                                                                    |  |  |
| OB 9                                                  | Processing clock-controlled time interrupts                                                                   |  |  |
|                                                       | Time interrupts with fixed intervals:                                                                         |  |  |
| OB 10                                                 | call every 10 ms                                                                                              |  |  |
| OB 11                                                 | call every 20 ms                                                                                              |  |  |
| OB 12                                                 | call every 50 ms                                                                                              |  |  |
| OB 13                                                 | call every 100 ms                                                                                             |  |  |
| OB 14                                                 | call every 200 ms                                                                                             |  |  |
| OB 15                                                 | call every 500 ms                                                                                             |  |  |
| OB 16                                                 | call every 1 s                                                                                                |  |  |
| OB 17                                                 | call every 2 s                                                                                                |  |  |
| OB 18                                                 | call every 5 s                                                                                                |  |  |

#### OBs for start-up

 Table 2-2
 Overview of the organization blocks for start-up

| Organization blocks to control the start-up procedure |                                                                   |
|-------------------------------------------------------|-------------------------------------------------------------------|
| Block                                                 | Function and call criterion                                       |
| OB 20                                                 | Call on request for COLD RESTART (manual and automatic)           |
| OB 21                                                 | Call on request for MANUAL WARM RESTART/RETENTIVE COLD RESTART    |
| OB 22                                                 | Call on request for AUTOMATIC WARM RESTART/RETENTIVE COLD RESTART |

#### OBs for error handling

 Table 2-3
 Overview of the organization blocks for error handling

| Organization blocks for reactions to device or program errors <sup>1)</sup> |                                                                                                   |  |
|-----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|--|
| Block                                                                       | Function and call criterion                                                                       |  |
| OB 19                                                                       | Runtime error (LZF): called block not loaded                                                      |  |
| OB 23                                                                       | Timeout (QVZ) in user program (during direct access to I/O modules or other S5 bus addresses)     |  |
| OB 24                                                                       | Timeout (QVZ) when updating the process image and transferring interprocessor communication flags |  |
| OB 25                                                                       | Addressing error (ADF)                                                                            |  |
| OB 26                                                                       | Cycle time exceeded (ZYK)                                                                         |  |
| OB 27                                                                       | Op. code error (BCF): code not permitted                                                          |  |
| OB 28                                                                       | STOP by PG function/stop switch/S5 bus <sup>2)</sup>                                              |  |
| OB 29                                                                       | Op. code error (BCF): code not permitted                                                          |  |
| OB 30                                                                       | Op. code error (BCF): parameter not permitted                                                     |  |
| OB 31                                                                       | Other runtime errors (LZF)                                                                        |  |
| OB 32                                                                       | Runtime error (LZF): load and transfer error with data blocks                                     |  |
| OB 33                                                                       | Collision of time interrupts (WECK-FE)                                                            |  |
| OB 34                                                                       | Error in closed loop controller processing (REG-FE)                                               |  |
| OB 35                                                                       | Communication error on the second serial interface (FE-3)                                         |  |
| OB 36 to OB 39                                                              | do not exist for the CPU 928B                                                                     |  |

<sup>1)</sup> If the OB is not programmed, the CPU changes to the STOP mode in the event of an error.

EXCEPTION: if OB 23, OB 24 and OB 35 do not exist, there is no reaction.

<sup>2)</sup> OB28 is called before the CPU changes to the STOP mode. The CPU stops regardless of whether and how OB 28 is programmed.

EXCEPTION: OB28 is not called if the power is switched off.

#### 2.2.2 Organization Blocks for Special Functions

*Introduction* The following organization blocks contain special functions of the system program. You **cannot** program these blocks, but simply call them (this applies to all OBs with numbers between 40 and 255). They do not contain a STEP 5 program. Special function OBs can be called in all code blocks.

#### Overview

 Table 2-4
 Overview of organization blocks for special functions

| Integral organization blocks with special functions |                                                                                                                                                          |  |
|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Block:                                              | Block function:                                                                                                                                          |  |
| OB 110<br>OB 111<br>OB 112<br>OB 113                | Access to the status (condition code) byte<br>Clear ACCU 1, 2, 3 and 4<br>ACCU roll up<br>ACCU roll down                                                 |  |
| OB 120<br>OB 121<br>OB 122<br>OB 123                | "Block all interrupts" on/off<br>"Block individual time interrupts" on/off<br>"Delay all interrupts" on/off<br>"Delay individual time interrupts" on/off |  |
| OB 134<br>OB 135<br>OB 136<br>OB 139                | *D<br>/D<br>MOD<br>PUSH                                                                                                                                  |  |
| OB 150                                              | Set/read system time                                                                                                                                     |  |
| OB 151                                              | Set/read time for clock-controlled time interrupt                                                                                                        |  |
| OB 152                                              | Cycle statistics                                                                                                                                         |  |
| OB 153                                              | Set/read time for delay interrupt                                                                                                                        |  |
| OB 160-163                                          | Counter loops                                                                                                                                            |  |
| OB 170                                              | Read block stack (BSTACK)                                                                                                                                |  |
| OB 180<br>OB 181<br>OB 182                          | Variable data block access<br>Test data blocks DB/DX<br>Copy data area                                                                                   |  |
| OB 185<br>OB 186                                    | Influence write protection<br>Compressing memory by means of user program                                                                                |  |
| OB 190, 192<br>OB 191, 193                          | Transfer flags to data block<br>Transfer data fields to flag area                                                                                        |  |
| OB 200, 202-205                                     | Multiprocessor communication                                                                                                                             |  |
| OB 216-218                                          | Access to "pages" (CPs and some IPs)                                                                                                                     |  |
| OB 220                                              | Sign extension                                                                                                                                           |  |
| OB 221                                              | Set cycle monitoring time                                                                                                                                |  |
| OB 222                                              | Restart cycle monitoring time                                                                                                                            |  |
| OB 223                                              | Compare restart type                                                                                                                                     |  |
| OB 224                                              | Transfer blocks of IPC flags                                                                                                                             |  |
| OB 226                                              | Read word from the system program                                                                                                                        |  |

| Integral organization blocks with special functions |                                                          |  |  |
|-----------------------------------------------------|----------------------------------------------------------|--|--|
| Block: Block function:                              |                                                          |  |  |
| Table 2-4 continued:                                |                                                          |  |  |
| OB 227                                              | Read checksum of the system program memory               |  |  |
| OB 228                                              | Read status information of a program execution level     |  |  |
| OB 230-237                                          | Functions for standard function blocks (handling blocks) |  |  |
| OB 240                                              | Initialize shift register                                |  |  |
| OB 241                                              | Process shift register                                   |  |  |
| OB 242                                              | Clear shift register                                     |  |  |
| OB 250                                              | Initialize PID controller algorithm                      |  |  |
| OB 251                                              | Process PID controller algorithm                         |  |  |
| OB 254, 255                                         | Transfer data block to the DB-RAM                        |  |  |

These special functions are described in detail in Chapter 6.

#### 2.3 Function Blocks

*Introduction* Function blocks (FB/FX) are also parts of the user program just like program blocks. FX function blocks have the same structure as FB function blocks and are programmed in the same way.

You use function blocks to implement frequently recurring or very complex functions. In the user program, each function block represents a complex complete function. You can obtain function blocks as follows:

• as a software product from SIEMENS (standard function blocks on diskette - see /5/); with these function blocks you can generate user programs for fast and simple open loop control, signalling, closed loop control and logging;

or

• you can program function blocks yourself.

## Differences to other code blocks

Compared with organization, program and sequence blocks, function blocks have the following four essential **differences**:

|    | OB, PB, SB                                     | FB/FX                                                                                                           |  |  |  |
|----|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--|--|--|
| 1. | Range of operations                            |                                                                                                                 |  |  |  |
|    | only basic operations                          | <ul><li>basic operations,</li><li>supplementary operations</li><li>system operations</li></ul>                  |  |  |  |
| 2. | Method of representation                       |                                                                                                                 |  |  |  |
|    | programming and call in STL, LAD, CSF          | programming only in STL                                                                                         |  |  |  |
| 3. | Name                                           |                                                                                                                 |  |  |  |
|    | name environment not possible<br>(only number) | in addition to the number a name with max. 8 chars. can be assigned                                             |  |  |  |
| 4. | Operands                                       |                                                                                                                 |  |  |  |
|    | none                                           | formal operands (block parameters).<br>When the block is called formal<br>operands are assigned actual operands |  |  |  |

#### 2.3.1 Structure of Function Blocks

| Block header                        | The <b>block header</b> (five words) of a function block has the same structure as the headers of the other STEP 5 block types.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Block body                          | The <b>block body</b> on the other hand, has a different structure from the bodies of<br>the other block types. The block body contains the function to be executed in the<br>form of a statement list in the STEP 5 programming language. Between the block<br>header and the STEP 5 statements, the function block needs additional memory<br>space for its name and for a list of formal operands. Since this list contains no<br>statements for the CPU, it is skipped with an unconditional jump that the<br>programmer generates automatically. This jump statement is not displayed when<br>the function block is displayed on the PG! When a function block is called, only<br>the block body is processed. |  |
| Absolute or<br>symbolic<br>operands | You can enter operands in a function block in absolute form (e.g. F 2.5) or symbolically (e.g. MOTOR1). You must store the assignment of the symbolic operands in an <b>assignment list</b> before you enter the operands in a function block (see $/3/$ ).                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |

## Function block in<br/>the PLC memoryFig. 2-4 shows the structure of a function block in the memory of a<br/>programmable controller.



Fig. 2-4 Structure of a function block (FB/FX)

The memory contains all the information that the programmer needs to represent the function block graphically when it is called and to check the operands during parameter assignment and programming of the function block. The programmer rejects incorrect input.

When handling function blocks, distinguish between the following procedures:

Distinction: "programming" – "calling and assigning parameters"

- programming FB/FX

and

- calling FB/FX and then assigning actual values to the parameters.

#### **Programming**

When **programming**, you specify the function of the block. You must decide which input operands the function requires and which output results it should transfer to the calling program. You define the input operands and output results as formal operands. These function as tokens.

#### **Calling and assigning parameters**

When a block is **called** by a higher order block (OB, PB, SB, FB, FX), the formal operands (block parameters) are replaced by actual operands; i.e. **parameters** are assigned to the function block.

#### How to program

| IF                                                                                | THEN                                                                                                                                                                                                                                                                                                      |
|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| You want to program a function block<br>"directly", i.e. without formal operands. | Program it as you would a program or sequence block.                                                                                                                                                                                                                                                      |
| You want to use formal operands in a function block.                              | Proceed as explained on the following<br>pages.<br>Doing so, make sure you keep to the<br>required order:<br>First program the FB/FX with the formal<br>operands and keep it on the PG (offline)<br>or in the CPU memory (online).<br>Then program the block(s) to be called<br>with the actual operands. |

Procedure

#### 2.3.2 Programming Function Blocks

You can program a function block only in the "**statement list**" method of representation. When entering a function block at a programmer, perform the following steps:

1. Enter the **block type** (FB/FX) and the **number** of the function block.

Number your function blocks in descending order starting with FB 255, so that they do not collide with the standard function blocks. The standard function blocks are numbered from FB 1 to FB 199.

2. Enter the **name** of the function block.

The name can have a maximum of eight characters and must start with a letter.

3. If the function block is to process formal operands: Enter the formal operands you require in the block as block parameters.

Enter the following information for each formal operand:

- the name of the block parameter (maximum 4 characters),
- the type and (if applicable) the data type of the block parameter

You can define a maximum of 40 formal operands.

4. Enter your STEP 5 program in the form of a statement list (STL).

The formal operands are preceded by an equality sign (e.g. A = X1). They can also be referenced more than once at various positions in the function block.

5. Terminate your program input with the block end operation "BE".

#### Note

If you change the **order** or the **number** of formal operands in the formal operand list, you must also update all STEP 5 statements in the function block that reference a **formal operand** and also the block parameter list in the calling block!

Program or change function blocks only on diskette or hard disk and then transfer them to your CPU!

#### Formal operands

The following parameter and data types are permitted as the formal operands of a function block (also known as **block parameters**):

| Parameter type                                  | Data type                          |
|-------------------------------------------------|------------------------------------|
| I = input parameter<br>Q = output parameter     | BI/BY/W/D                          |
| D = data                                        | KM/KH/KY/KS/KF/<br>KT/KC/KG        |
| B = block operation<br>T = timer<br>C = counter | none<br>(no type can be specified) |

 Table 2-5
 Permitted formal operands for function blocks

I, D, B, T or C are parameters that are indicated to the left of the function symbol in graphic representation.

Parameters labelled with **Q** are indicated on the **right** of the function symbol.

The data type indicates whether you are working with bits, bytes, words or double words for I and Q parameters and which data format applies to D parameters (e.g. bit pattern or hexadecimal pattern).

#### 2.3.3 Calling Function Blocks and Assigning Parameters to them

*Introduction* You can call every function block as often as you want anywhere in your STEP 5 program. You can call function blocks in a statement list or in one of the graphic methods of representation (CSF or LAD).

**Procedure** To call a function block and assign parameters to it, perform the following steps:

- 1. Make sure that the called function block exists either in the PG memory (offline) or in the CPU memory (online).
- 2. Enter the call statement for the function block in the block where the call is to originate.

You can program a function block call in an organization, program or sequence block or in another function block.

#### **Reaction on PG:**

can be evaluated there.

After you enter the call statement (e.g. JU FB200), the name of the relevant function block and the formal operand list appear automatically.

3. Assign the **actual** operand relevant to this call to each of the formal operands, i.e. you assign **parameters** to the function block.

These actual operands can be different for separate calls (e.g. inputs and outputs for the first call of FB 200, flags for the second call). Using the formal operand list, you assign the required actual operands for each function block call.

#### Unconditional/ conditional call

| Unconditional call                                                                                                                                                                               | Conditional call                                                                                                                                                                                                                                                                                                                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| "JU FBn" for FB function blocks or<br>"DOU FXn" for FX extended function<br>blocks: the referenced function block is<br>processed regardless of the previous result<br>of logic operation (RLO). | <ul> <li>"JC FBn" for FB function blocks or</li> <li>"DOC FXn" for FX extended function blocks:</li> <li>the referenced function block is only processed when the result of logic operation RLO = 1.</li> <li>If RLO = 0 the block call is not executed. Regardless of whether the block call is executed or not, the RLO is alsways set to "1".</li> </ul> |
| After the unconditional or conditional call, t logically. However, it is carried over to the o                                                                                                   | e                                                                                                                                                                                                                                                                                                                                                           |

CPU 928B-3UB21 Programming Guide C79000-G8576-C870-01

## Permitted actual<br/>operandsWhich operands can be assigned as actual operands is shown in the<br/>following table.

| Parameter<br>type |              | Data type                                                                                                                |                                                                                        | A                                                        | actual operands permitted                                                                                                                                                                                                                                     |
|-------------------|--------------|--------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I, Q              | BI           | for an operand<br>with bit address                                                                                       | I<br>Q<br>F                                                                            | n.m<br>n.m<br>n.m                                        | input<br>output<br>flag                                                                                                                                                                                                                                       |
|                   | BY<br>W<br>D | for an operand<br>with byte address<br>for an operand<br>with word address<br>for an operand<br>with double word address | IB<br>QB<br>FY<br>DL<br>DR<br>PY<br>OY<br>IW<br>QW<br>FW<br>DW<br>FW<br>DW<br>PW<br>OW | n<br>n<br>n<br>n<br>n<br>n<br>n<br>n<br>n<br>n<br>n<br>n | input byte<br>output byte<br>flag byte<br>data byte left<br>data byte right<br>peripheral byte<br>byte from extended periphery<br>input word<br>output word<br>flag word<br>data word<br>peripheral word<br>word from extended periphery<br>input double word |
|                   |              |                                                                                                                          | QD<br>FD<br>DD                                                                         | n<br>n<br>n                                              | output double word<br>flag double word<br>data double word                                                                                                                                                                                                    |
| D                 | КМ           | for a binary pattern (16 bits)                                                                                           | Cons                                                                                   | tants                                                    |                                                                                                                                                                                                                                                               |
|                   | КҮ           | for two absolute numbers,<br>one byte each,<br>each in the range from 0 to 255                                           |                                                                                        |                                                          |                                                                                                                                                                                                                                                               |
|                   | кн           | for a hexadecimal pattern with a maximum of four digits                                                                  |                                                                                        |                                                          |                                                                                                                                                                                                                                                               |
|                   | KS           | for two alphanumeric characters                                                                                          |                                                                                        |                                                          |                                                                                                                                                                                                                                                               |
|                   | КТ           | for timer value (BCD-coded) units<br>.0 to .3 and values 0 to 999                                                        |                                                                                        |                                                          |                                                                                                                                                                                                                                                               |
|                   | кс           | for a counter value 0 to 999                                                                                             |                                                                                        |                                                          |                                                                                                                                                                                                                                                               |
|                   | KF           | for a fixed point number<br>-32768 to +32767                                                                             |                                                                                        |                                                          |                                                                                                                                                                                                                                                               |
|                   | KG           | for a floating point number<br>±0.1469368 x $10^{-38}$ to<br>±0.1701412 x $10^{39}$                                      |                                                                                        |                                                          |                                                                                                                                                                                                                                                               |

Table 2-6Permitted actual operands for function blocks

| Parameter<br>type | Data type                          |     | P      | Actual operands permitted                                                             |
|-------------------|------------------------------------|-----|--------|---------------------------------------------------------------------------------------|
| Table 2-6 contin  | ued:                               |     |        |                                                                                       |
| В                 | Data type designation not possible | DB  | n      | Data block; the operation<br>C DB n is executed                                       |
|                   |                                    | FB  | n      | Function block (permitted<br>only without parameters)<br>called unconditionally (JUn) |
|                   |                                    | OB  | n      | Organization block called unconditionally (JUn)                                       |
|                   |                                    | PB  | n      | Program blocks - called unconditionally (JUn)                                         |
|                   |                                    | SB  | n      | Sequence blocks - called unconditionally (JUn)                                        |
| Т                 | Data type designation not possible | т 0 | to 255 | Timer                                                                                 |
| С                 | Data type designation not possible | C 0 | to 255 | Counter                                                                               |

#### Note

S flags are **not** permitted as actual operands for function blocks.

After the jump to a function block, the actual operands from the block then called are used in the function block program instead of the formal operands. This feature of programmable function blocks allow them to be used for a wide variety of purposes in your user program. Examples

```
Example 1: the following (complete) example is intended to further
            clarify the programming and calling of a function block
            and the assignment of parameters to it. You yourself
            can easily try out the example.
Programming the function block FB 202:
FB 202
SEGMENT 1
NAME EXAMPLE
DECL : INP1
             I/Q/D/B/T/C: I BI/BY/W/D: BI
                                                      Formal
DECL : INP2
              I/O/D/B/T/C: I
                                 BI/BY/W/D: BI
                                                      operand
DECL : OUT1
              I/Q/D/B/T/C: Q
                                 BI/BY/W/D: BI
                                                      list
     :A= INP1
     :A= INP2
     :== OUT1
                                                      STEP 5
     :
                                                      state-
     : BE
                                                      ments
          Formal
                        Parameter
                                     Data
          operands
                                     type
                        type
Function block FB 202 is called and has parameters assigned
to it in program block PB 25:
STL method of representation
                                   CSF/LAD method of representation
PB 25
SEGMENT 1
    : JU FB 202
                                    FB 202
                                      EXAMPLE
NAME : EXAMPLE
                                                             Q 23.0
                        I 13.5 -
INP1 : I 13.5
                                    INP1
                                             OUT1
INP2 : F 17.7
                        F 17.7_
                                    INP2
                                                          :BE
OUT1 : Q 23.0
    : BE
 Formal
             Actual
 operands
             operands
The following operations are executed after the jump to FB 202
: A I 13.5
: A F 17.7
: = Q 23.0
:BE
```

```
Example 2: calling a function block and assigning parameters to it with
            the STL and CSF/LAD methods of representation in a program block.
STL method of representation
PB 25
SEGMENT 1
     :
     : C DB 5
     :
     : JU
            FB 201
NAME : REQUEST
DATA :
            DW
                  1
RST :
            Ι
                  3.5
            F
                  2.5
SET
    :
MTIM :
            т
                  2
            KT 010.1
TIME :
TRAN :
            DW
                  2
                  2.3
BEC :
            Q
LOOP :
                  6.0
            Q
    : BE
 Formal
              Actual
 operands
              operands
CSF/LAD method of representation
PB 25
SEGMENT 1
               FB 201
                    REQUEST
DW 1
               DATA
                             TRAN
                                          DW
                                               2
I 3.5
               RST
                                               2.3
                             BEC
                                          Q
F 2.5
               SET
                             LOOP
                                          Q
                                               6.0
т 2
               MTIM
                                          :BE
KT 010.1
                  TIME
```

#### 2.3.4 Special Function Blocks

IntroductionApart from the function blocks that you program yourself, you can order<br/>standard function blocks as a finished software product. These contain standard<br/>functions for general use (e.g. signalling functions and sequence control).<br/>Standard function blocks are assigned numbers FB 1 to FB 199.

If you order standard function blocks, remember the special instructions in the accompanying description (i.e. areas assigned and conventions etc.).

The standard function blocks for the S5-135U are listed in catalog ST 57.

#### Example

Floating point root extractor RAD:GP FB 6 The function block RAD:GP extracts the root of a floating point number (8-bit exponent and 24-bit mantissa). It forms the square root. The result is also a floating point number (8-bit exponent and 24-bit mantissa). The least significant bit of the mantissa is not rounded up or down. If applicable, for the rest of the processing, the function block sets the "radicand negative" identifier. Numerical range: Radicand - 0.1469368 Exp. -38 to +0.1701412 Exp. +39 Root +0.3833434 Exp. -19 to +0.1304384 Exp. +20 Function:  $Y = \sqrt{A}$ Y = SQRT; A = RADI Calling the function block FB 6: In the example, the root is extracted from a floating point number that is located in DD5 of DB 17 with an 8-bit exponent and a 24-bit mantissa. The result, another 32-bit floating point number, is written to DD 10. Prior to this, the appropriate data block must be opened. The parameter VZ (parameter type: Q, data type: BI) indicates the sign of the radicand: VZ = 1 for a negative radicand. Occupied flag words: FW 238 to FW 254. Continued on the next page



## **Using FB 0** If you have not programmed organization block OB 1, the system program calls FB 0 (provided it is loaded) cyclically instead of OB 1.

Since you have the total operation set of the STEP 5 programming language available in a function block, programming FB 0 instead of OB 1 can be an advantage, particularly when you wish to execute a short time-critical program.

#### Note

You should only use FB 0 for programming **cyclic** program execution (it must not contain parameters).

If both OB 1 and FB 0 are loaded, the system program will only call organization block **OB 1 cyclically**.

#### 2.4 Data Blocks

Introduction Data blocks (DB) or extended data blocks (DX) are used to store the fixed or variable data with which the user program works. No STEP 5 operations are processed in data blocks.

The data of a data block includes the following:

- various bit patterns (e.g. for status of a controlled process)
- numbers (hexadecimal, binary, decimal) for timer values or arithmetic results
- alphanumeric characters, e.g. for message texts.

Structure of a A data block (DB/DX) consists of the following parts: data block block preheader (DV, DXV), block header block body. Block preheader The block preheader is created automatically on the hard or floppy disk of the PG and not transferred to the CPU. It contains the data formats of the data words entered in the block body. You have no influence over the creation of the block preheader. Note When you transfer a data block from the PLC to diskette or hard disk, the corresponding block preheader can be deleted. For this reason, you must never modify a data block with different data formats in the PLC and then transfer it back to diskette, otherwise all the data words in the DB are automatically assigned the data format you selected in the presets screen form.

| Block header   | The block header occupies five words in the memory and contains the following:                                                                                                                                                      |  |  |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                | • the block identifier                                                                                                                                                                                                              |  |  |
|                | • the programmer identifier                                                                                                                                                                                                         |  |  |
|                | • the block type and the block number                                                                                                                                                                                               |  |  |
|                | • the library number                                                                                                                                                                                                                |  |  |
|                | • the block length (including the length of the block header).                                                                                                                                                                      |  |  |
| Block body     | The <b>block body</b> contains the data words with which the user program works. These data words are in ascending order in the block body, starting with data word DW 0. Each data word occupies one word (16 bits) in the memory. |  |  |
| Maximum length | A data block can occupy a total of maximum 32 767 words (including header) in<br>the CPU memory. When you use your programmer to enter and transfer data<br>blocks, remember the size of your CPU memory!                           |  |  |

#### 2.4.1 Creating Data Blocks

| Procedure                 | To create a data block, perform the following steps:                                                                                                                                                                                                    |                                        |                   |  |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|-------------------|--|
|                           | 1. Enter the block type (DB/DX) and data block <b>number</b> between 3 and 255.                                                                                                                                                                         |                                        |                   |  |
|                           | 2. Enter individual <b>data words</b> in the data format you require.                                                                                                                                                                                   |                                        |                   |  |
|                           | (Do not complete your input of the data words with a BE statement!)                                                                                                                                                                                     |                                        |                   |  |
| Permitted data<br>formats | Note         Data blocks DB 0, DB 1, DX 0, DX 1 and DX 2 are reserved for specific functions. You cannot use them freely for other functions (see Section 2.4.3)!         When creating a data block, you can use all of the data formats listed below. |                                        |                   |  |
|                           | Table 2-7                                                                                                                                                                                                                                               | Data formats permitted in a data block |                   |  |
|                           | Туре                                                                                                                                                                                                                                                    | Data format                            | Examples          |  |
|                           | KM                                                                                                                                                                                                                                                      | Bit pattern                            | 00100110 00111111 |  |

KH

KY

KF

KG

KS

KΤ

KC

Hexadecimal

Fixed point number

Floating point number

2 bytes

Character

Timer value

Counter value

263F

038,063

+09791

055.2

234

+1356123+12

?!ABCD123-+.,%

#### 2.4.2 Opening Data Blocks

*Introduction* You can only open a data block (DB/DX) **unconditionally**. This is possible within an organization, program, sequence or function block. You can open a specific data block more than once in a program.

To open a data block, perform the following steps:

| IF                                      | THEN                                 |
|-----------------------------------------|--------------------------------------|
| You want to open a <b>DB</b> data block | Type in the STEP 5 operation "C DB"  |
| You want to open a <b>DX</b> data block | Type in the STEP 5 operation "CX DX" |

# Validity of a dataAfter you open a data block, all statements that follow with the operand area 'D'blockrefer to the opened data block.The opened data block also remains valid when the program is continued in a

The opened data block also remains valid when the program is continued in a different block following a block call.

If a second data block is opened in this new block, the second data block is **only** valid in the newly called block from the point at which it is called. After program execution returns to the calling block, the old data block is once again valid.

## Access You can access the data stored in the opened data block during program execution using load or transfer operations (refer to Chapter 3 for more detailed information).

With a **binary operation**, the addressed data word bit is used to form the RLO. The content of the data word is not changed.

With a set/reset operation, the addressed data word bit is assigned the value of the RLO. The content of the data word may be changed.

A **load operation** transfers the contents of the referenced data word into ACCU 1. The contents of a data word are not changed.

A transfer operation transfers data from ACCU 1 to the referenced data word. The old contents of the data word are overwritten.

#### Note

Before accessing a data word, you must open the data block you require in your program. This is the only way that the CPU can find the correct data word.

The referenced data word must be contained in the opened block, otherwise the system program detects a load or transfer error.

With load and transfer operations, you can only access data word numbers up to 255!

An opened data block remains valid until one of the following events occur:

- a) a second data block is opened
- or
- b) the block, in which the data block was opened, is completed with 'BE', 'BEC' or 'BEU'.

#### Examples

#### **Example 1:** transferring data words

You want to transfer the contents of data word DW 1 from data block DB 10 to data word DW 1 of data block DB 20. Enter the following statements: :C DB 10 (open DB 10) :L DW 1 (load the contents of DW 1 into ACCU 1) : (open DB 20) DB 20 :C (transfer the contents of ACCU 1 :Т DW 1 to DW 1) : :



Fig. 2-5 Range of validity of an opened data block

| 2.4.3 | Special | Data | <b>Blocks</b> |
|-------|---------|------|---------------|
|-------|---------|------|---------------|

| Introduction | On the CPU 928B data blocks DB 0, DB 1, DX 0, DX 1 and DX 2 are reserved for special functions. They are managed by the system program and you cannot use them freely for other functions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DB 0         | Data block DB 0 (see Section 8.3)<br>Data block DB 0 contains the address list with the start addresses of all blocks<br>that are located in the data block RAM of the CPU. The system program<br>generates this address list during initialization (following each OVERALL<br>RESET) and it is updated automatically when you use a programmer to change<br>data blocks or generate a new data block.                                                                                                                                                                                                                                                                                                                         |
| DB 1         | <ul> <li>Data block DB 1 (see Section 10.1)</li> <li>Data block DB 1 contains the list of digital inputs/outputs (P peripheral with relative byte addresses from 0 to 127) and the interprocessor communication (IPC) flag inputs and outputs that are assigned to the CPU. If applicable, the block may also contain a timer field length.</li> <li>DB 1 can have parameters assigned and be loaded as follows: <ul> <li>to reduce the cycle time in single processor operation, since only the inputs, outputs or timers entered in DB1 are updated.</li> </ul> </li> <li>DB 1 must be assigned parameters and loaded as follows: <ul> <li>for multiprocessing</li> <li>when IPC flags exist with CPs</li> </ul> </li> </ul> |
| DB 2         | Data block DB 2 (see Section 4.5)<br>You use data block DB 2 to assign parameters to the closed loop controller<br>structure R64. The closed loop control function can be ordered as a software<br>product and operates supported by the system program.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| DX 0 | Data block DX 0 (see Chapter 7)                                                                                                                                                                                                        |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | If you assign parameters to data block DX 0 and load it, you can change the defaults of certain system program functions (e.g. the start-up procedure) and adapt the performance of the system program to your particular application. |
| DX 1 | Data block DX 1                                                                                                                                                                                                                        |
|      | Reserved.                                                                                                                                                                                                                              |
| DX 2 | Data block DX 2                                                                                                                                                                                                                        |
|      | Data block DX 2 is used to specify the communication via the second serial interface. See the "CPU 928B Communication" Manual for details of assigning parameters to this block (see /14/).                                            |

# 3

### **Program Execution**

## Contents of the chapter

This chapter is intended for readers who do not yet have any great experience in using the programming language. The chapter therefore deals with the basics of STEP 5 programming and explains in detail (with examples) the STEP 5 operations for the CPU 928B.

Experienced readers who require more information about a specific STEP 5 operation listed in the Pocket Guide /1/ can refer to the reference section in 3.5.

## Overview of the chapter

| Section | Description                                                               | Page |
|---------|---------------------------------------------------------------------------|------|
| 3.1     | Principle of Program Execution                                            | 3-2  |
| 3.2     | Program Organization                                                      | 3-3  |
| 3.3     | Storing Program and Data Blocks                                           | 3-8  |
| 3.4     | Processing the User Program                                               | 3-10 |
| 3.4.1   | Definition of Terms used in Program Execution                             | 3-11 |
| 3.5     | STEP 5 Operations with Examples                                           | 3-13 |
| 3.5.1   | Basic Operations                                                          | 3-17 |
| 3.5.2   | Programming Examples in the STL, LAD and CSF<br>Methods of Representation | 3-32 |
| 3.5.3   | Supplementary Operations                                                  | 3-47 |
| 3.5.4   | Executive Operations                                                      | 3-54 |
| 3.5.5   | Semaphore Operations                                                      | 3-67 |

#### 3.1 Principle of Program Execution

**Overview** You can process your STEP 5 user program in various ways.

Cyclic program execution is most common with programmable controllers (PLCs). The system program runs through a program loop (the cycle, refer to Section 3.4) and calls organization block OB 1 cyclically in each loop (refer to Fig. 3-1).



Fig. 3-1 Principle of cyclic program execution

#### 3.2 Program Organization

Introduction

Program organization allows you to specify which conditions affect the processing of your blocks and the order in which they are processed. Organize your program by programming organization blocks with conditional or unconditional calls for the blocks you require.

You can call additional program, function and sequence blocks in any combination in the program of individual organization, program, function and sequence blocks. You can call these one after another or nested in one another.

For maximum efficiency, you should organize your program to emphasise the most important program structures and in such a way that you can clearly recognize parts of the controlled system which are related in the software.

Figs. 3-2 and 3-3 are examples of a program structure.





#### *Nesting blocks* Fig. 3-4 shows the principle of nested block calls.



 $^{\star)}$  Operation to which the program returns

Fig. 3-4 Nested logic block calls

| Block addresses | A block start address specifies the location of a block in the user memory (or DB-RAM). For logic blocks, this is the address of the memory location containing the first STEP 5 operation (with FB and FX, the JU operation via the formal operand list); with data blocks, it is the address of the first data word.                                                                                                            |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                 | To enable the CPU to locate the called block in the memory, the start addresses<br>of all valid blocks are entered in the block address list in data block DB 0. DB 0<br>is managed by the system program, you cannot call it yourself.                                                                                                                                                                                           |  |  |  |
|                 | The CPU stores a <b>return address</b> every time a new block is called. After the new block has been processed, this return address enables the program to find the block from which the call originated. The return address is the address of the memory location containing the next STEP 5 statement after the block call. The CPU also stores the s <b>tart address and length of the data block</b> valid at this location. |  |  |  |
| Nesting depth   | You can only nest 62 blocks within one another. If more than 62 blocks are called, the CPU signals an error and goes to the stop mode.                                                                                                                                                                                                                                                                                            |  |  |  |

#### Example of nesting depth



#### 3.3 Storing Program and Data Blocks

| Introduction | You must load your user program and any data blocks into the program memory<br>so that the CPU can process it. As program memory, you can use the user<br>memory and the DB-RAM.<br>To load the code blocks and data blocks into the program memory, you can |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | proceed in different ways:                                                                                                                                                                                                                                   |
| RAM mode     | If no memory card (Flash EPROM) is plugged when an OVERALL RESET is performed on the CPU, the CPU goes into "RAM" mode.                                                                                                                                      |
|              | Code blocks and data blocks are loaded from the PG to the user memory or the DB-RAM of the CPU. They can be reloaded (replaced), edited or deleted by the PG at any time, which means the write protection is deactivated.                                   |
| EPROM mode   | Code blocks and data blocks are <b>copied from the memory card</b> to the user memory by the system program. The system program also sets a write protection ID.                                                                                             |
|              | This means that all <b>copied</b> blocks can <b>not</b> be reloaded, edited or deleted.                                                                                                                                                                      |
|              | To edit data in data blocks, you must ensure that the data blocks are copied to the DB-RAM.                                                                                                                                                                  |
|              | You can copy or move data blocks that are programmed in the memory card to the DB-RAM using OB 254/OB 255 (for example, startup OB). You can load other data blocks from the PG to the DB-RAM.                                                               |
|              | As soon as the data blocks are in the DB-RAM, you can reload, edit or delete them.                                                                                                                                                                           |
|              | Any changes to these data blocks are <b>not included in the memory card</b> . You must save their contents before the next overall reset.                                                                                                                    |
|              | After the overall reset, you can remove the memory card; the data are in the user memory and ready for use.                                                                                                                                                  |

#### Activating/deactivating write protection

If you want to make changes to blocks in EPROM mode, you can deactivate the write protection again by deleting the write protection ID (see Section 8.3, RS 138).

You can make blocks read-only again by setting the write protection ID again.

You can also assign write protection to a CPU without a memory card if you set the write protection ID.

#### **Displaying the memory configuration**

If you display information about the memory in EPROM mode using the PG function "memory configuration", the length of the memory is displayed as '0' and the end address of the user memory is displayed as '0EEEEH'.

#### Note

The memory card **can only be programmed on the PG**. You can use the PG software from version 6 to do this. When programming, you should select the PG operating mode "WORD" (see S5-DOS description /3/).

#### DB-RAM

Data blocks (DB/DX) are written to the DB-RAM by creating or copying them. When data blocks are transferred from the PG to the CPU, they are stored in the DB-RAM if the user memory is full or if "alternative loading" is set in **RAM mode** (see Section 8.3, RS 144).

#### 3.4 Processing the User Program

*Introduction* The complete software on the CPU (consisting of the system program and the STEP 5 user program) has the following tasks:

- CPU START-UP
- Controlling an automation process by continuously repeating operations (CYCLE).
- Controlling an automation process by reacting to events occurring sporadically or at certain times (interrupts) and reacting to errors.

For all three tasks, you can select special parts of your program to run on the CPU by programming user interfaces (organization blocks OB 1 to OB 35 - refer to Section 2.2).

**START-UP** Before the CPU can start cyclic program execution, an initialization must be performed to establish a defined initial status for cyclic program execution and, for example, to specify a time base for the execution of certain functions. The way in which this initialization is performed depends on the event that led to a START-UP and on settings that you can make on your CPU. For more detailed information, refer to Chapter 4.

You can influence the START-UP procedure of your CPU by programming organization blocks OB 20, OB 21 and OB 22 or by assigning parameters in DX 0 (refer to Chapter 7).

**CYCLE** Following the START-UP, the system program goes over to cyclic processing. It is responsible for background functions required for the automation tasks (refer to Fig. 3-1 at the beginning of this section). After the system functions have been executed at the beginning of a CYCLE, the system program calls organization block OB 1 or function block FB 0 as the cyclic user program. You program the STEP 5 operations for cyclic processing in this block.

| Reactions to<br>interrupts<br>and errors | To allow you to specify the reactions to interrupts or errors, special organization blocks (OB 2, OB6 and OB9 to OB 18 for interrupt servicing, OB 19 and OB 23 to OB 35 for reactions to errors) are available on the CPU 928B. You can store an appropriate STEP 5 program in these blocks.                                                                      |
|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                          | When interrupts or errors are to be processed, the system program activates the corresponding organization block during cyclic processing. This means that the cyclic processing is interrupted to service an interrupt or to react to an error. The nesting of the organization blocks has a fixed priority (for further information, refer to Chapters 4 and 5). |
|                                          | In addition to the organization blocks, you can also influence the reaction of the CPU to interrupt servicing by assigning parameters in data block DX 0.                                                                                                                                                                                                          |
|                                          | Organization blocks OB 1 to OB 39 can be called by the system program as soon as they are loaded in the program memory (also during operation).                                                                                                                                                                                                                    |
|                                          | If the OBs are not loaded, there is either no reaction from the CPU or (in the event of errors) it goes to the stop mode (refer also to Section 5.4).                                                                                                                                                                                                              |
|                                          | You can also load data block DX 0 into the program memory during operation like the organization blocks. <b>It is, however, only effective after the next COLD RESTART.</b> If DX 0 is not loaded, the standard settings apply (refer to Chapter 7).                                                                                                               |

#### 3.4.1 Definition of Terms used in Program Execution

## **Cycle time** The cycle begins when the cycle monitoring time is triggered and ends with the next trigger. The time that the CPU requires to execute the program between two triggers is called the cycle time. The cycle time consists of the runtime of the system program and the runtime of the user program.

The cycle time therefore includes the following:

- the time required to process the cyclic program (system and user program),
- the time required to process interrupts (e.g. time-controlled interrupt),
- the time required to process interruptions (errors).

Cycle timeThe CPU monitors the cycle time in case it exceeds a maximum value. Themonitoringstandard setting for this maximum value is 150 ms. You can set the cycle time<br/>monitoring yourself or restart it during user program execution (refer to<br/>DX 0/Chapter 7 and special function OB OB 221 and OB 222/Sections 6.23<br/>and 6.24).

| Process input<br>and output<br>image (PII and<br>PIQ) | The process image of the inputs and outputs is a memory area in the internal RAM. Before cyclic execution of the user program begins, the system program reads the signal states of the input peripheral modules and transfers them to the process input image. The user program evaluates the signal states in the process input image and then sets the appropriate signal states for the outputs in the process output image. After the user program has been processed, the system program transfers the signal states of the process output image to the output peripheral modules.<br>Buffering the I/O signals in the process image of the inputs and outputs avoids a change in a bit within a program cycle from causing the corresponding output to "flutter".<br>The process image is therefore a memory area whose contents are output to the peripherals and read in from the peripherals <b>once per cycle</b> .<br><b>Note</b><br>The process image only exists for input and output bytes of the "P" peripherals with byte addresses from 0 to 127! |  |  |  |  |  |
|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Interprocessor<br>communication<br>(IPC) flags        | IPC flags exchange data between individual CPUs (multiprocessing) or between the CPU and some communication processors.<br>The system program reads the input IPC flags of the CPU before cyclic execution of the user program begins. After the STEP 5 program is processed, the system program transfers the output IPC flags to the coordinator or to the communications processors.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|                                                       | You define the input and output IPC flags when you create data block DB 1 (refer to Section 10.1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| Interrupt events                                      | Cyclic program execution can be interrupted by the following:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|                                                       | • process interrupt-driven program processing,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|                                                       | • time-controlled program processing,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|                                                       | • delay interrupt,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|                                                       | • time interrupt clock-controlled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|                                                       | The cyclic program can be interrupted or even aborted completely by the following:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|                                                       | • a device hardware fault or program error,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|                                                       | • operator intervention (using the PC stop function, or setting the mode selector to "stop", multiprocessor stop MP-STP),                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|                                                       | • a stop operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |

#### 3.5 STEP 5 Operations with Examples

Introduction A STEP 5 operation consists of the operation and an operand. The operation specifies what the CPU is to do (operation). The operand specifies with what an operation is to be executed.

STEP 5 operations can be divided into the following groups:

- basic operations (can be used in all logic blocks),
- supplementary operations,
- executive operations (can only be used in FB/FX function blocks),
- semaphore operations (can only be used in FB/FX function blocks).

Accumulators as working registers The CPU 928B has four accumulators, ACCU 1 to ACCU 4. Most STEP 5 operations use two 32-bit registers (ACCU 1 and ACCU 2) as the source of operands and the destination for results.



<sup>1)</sup> The structure is analogous for ACCU 2 to ACCU 4

The STEP 5 operation to be carried out affects the accumulators, e.g.:

- ACCU 1 is always the destination in load operations. A load operation shifts the old contents of ACCU 1 to ACCU 2 (stack lift). Accumulators 3 and 4 are not changed by any load operations.
- Arithmetic operations combine the contents of ACCU 1 with those of ACCU 2, write the result to ACCU 1 and transfer the contents of ACCU 3 to ACCU 2 and the contents of ACCU 4 to ACCU 3 (stack drop). In 16-bit fixed point arithmetic, only the low word or ACCU 3 is transferred to the low word of ACCU 2 and the low word of ACCU 4 to the low word of ACCU 3.
- When a constant is added (ADD BF/KF/DH) to the contents of ACCU 1, the accumulators 2, 3 and 4 are not changed.

# **Condition codes** STEP 5 operations either set or evaluate condition codes. The condition codes are written to a condition code byte. Two groups of condition codes can be distinguished: condition codes of digital operations (word condition codes - bits 4 to 7 in the condition code byte) and condition codes from binary and executive operations (bit condition codes - bits 0 to 3 in the condition code byte). You can see how the various condition codes are influenced or evaluated by STEP 5 operations be referring to the operation list (see /1/ in Chapter 13).

You can display the condition code byte on a programmer using the "STATUS" online function (refer to Section 11.2.3). The byte has the following structure:

| W     | Word condition codes |    |    |    | Bit cond | lition codes |      |
|-------|----------------------|----|----|----|----------|--------------|------|
| CC 1  | CC 0                 | ov | OS | OR | STA      | RLO          | ERAB |
| Bit 7 | 6                    | 5  | 4  | 3  | 2        | 1            | 0    |

### Bit condition codes

#### **ERAB** First bit scan

A logic operation sequence containing binary operations always **begins** with the **first bit scan**, following which a **new** RLO is formed. The bit condition code ERAB = 1 is then set. While the remaining logic operations in the sequence are being performed, ERAB remains set to 1 and the RLO cannot be changed by these logic operations.

The active sequence of logic operations is **terminated** by a binary set/reset operation (e.g. S Q 5.0). The set/reset operation sets ERAB to 0; the RLO can be evaluated (e.g. by RLO-dependent operations) but can no longer be combined logically. The next binary logic operation following a binary set/reset operation is once again a first bit scan.

Example of ERAB

| : S  | Q  | 7.7   | Last operation of the pre-    |
|------|----|-------|-------------------------------|
|      |    |       | vious logic operation         |
|      |    |       | sequence                      |
| :A   | I  | 1.0   | <b>ERAB</b> is set to $'1'$ , |
| :    |    |       | the new RLO is formed by      |
| :    |    |       | an AND operation              |
| :0   | I  | 6.3   | The RLO is influenced by      |
| :    |    |       | an OR operation               |
| : AN | I  | 2.1   | The RLO is influenced by      |
| :    |    |       | an AND NOT operation.         |
| :S   | Q  | 2.4   | ERAB is set to '0',           |
| :    |    |       | the sequence is now complete  |
| :JC  | FE | 3 150 | The function block is called  |
| :    |    |       | dependent on the RLO.         |
| :    |    |       | -                             |

#### • RLO Result of logic operation

This is the result of bit logic operations. It is the truth statement for comparison operations (refer to operations list, binary logic operations or comparison operations).

• STA Status

Other bit

condition codes

For bit operations, this indicates the logical status of the bit just scanned or set. The status is updated in binary logic operations - except for A(, O(,), O and for set/reset operations.

• OR Or

Internal CPU bit for handling "AND before OR" logic operations.

Word condition codes • OV Overflow This indicates whether the permissible number range was exceeded during the arithmetic operation just completed.

• **OS** Stored overflow

It can be used in several arithmetic operations to indicate whether an overflow occurred at any point during the operations.

• CC 1 and CC 0

These are the result condition codes that you can interpret from table 3.1.

#### Note

To evaluate the condition codes directly, comparison and jump operations are available (refer to Sections 3.5.1 and 3.5.3).

|      | ord<br>on codes | Arithmetical<br>operations | Digital<br>logic<br>operations | <b>Comparison</b> operations | Shift<br>operations   | For<br>SED,<br>SEE                      | Jump<br>operations<br>executed |
|------|-----------------|----------------------------|--------------------------------|------------------------------|-----------------------|-----------------------------------------|--------------------------------|
| CC 1 | CC 0            | operations                 | operations                     | operations                   | operations            | SEE                                     | executed                       |
| 0    | 0               | Result<br>= 0              | Result<br>= 0                  | ACCU 2<br>=<br>ACCU 1        | Shifted<br>bit<br>= 0 | Semaphore<br>is<br>set                  | JZ                             |
| 0    | 1               | Result<br>< 0              | _                              | ACCU 2<br><<br>ACCU 1        | _                     | _                                       | JM<br>JN                       |
| 1    | 0               | Result<br>> 0              | Result<br>≠ 0                  | ACCU 2<br>><br>ACCU 1        | Shifted<br>bit<br>= 1 | Semaphore<br>is<br>set<br>or<br>enabled | JP<br>JN                       |
| 1    | 1               | Division<br>by 0           | _                              | -                            | _                     | _                                       | JN                             |

Table 3-1 Result condition codes of STEP 5 operations

#### Note

When a change of level takes place, e.g. servicing a timed interrupt, all accumulators and the bit and word condition codes (RLO etc.) are saved and loaded again when the interrupted level is resumed.

#### 3.5.1 Basic Operations

*Introduction* You can use the basic operations in **all** code blocks and all methods of representation (STL, LAD, CSF).

## Binary logic operations

| Operation     | Operand                                                                                                                                                                                                                                  | Function                                                                                                                                                                                                                              |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Α             |                                                                                                                                                                                                                                          | AND logic operation after scanning for signal state "1"                                                                                                                                                                               |
| 0             |                                                                                                                                                                                                                                          | OR logic operation after scanning for signal state "1"                                                                                                                                                                                |
|               | $ \begin{array}{cccc} I & 0.0 \mbox{ to } 127.7 \\ Q & 0.0 \mbox{ to } 127.7 \\ F & 0.0 \mbox{ to } 255.7 \\ S & 0.0 \mbox{ to } 4095.7 \\ D & 0.0 \mbox{ to } 215.15 \\ T & 0 \mbox{ to } 255 \\ C & 0 \mbox{ to } 255 \\ \end{array} $ | of an input in the PII<br>of an output in the PIQ<br>of a flag bit<br>of an S flag bit<br>of a data word bit<br>of a timer<br>of a counter                                                                                            |
| AN            |                                                                                                                                                                                                                                          | AND logic operation after scanning for signal state "0"                                                                                                                                                                               |
| ON            | I 0.0 to 127.7<br>Q 0.0 to 127.7<br>F 0.0 to 255.7<br>S 0.0 to 4095.7<br>D 0.0 to 255.15<br>T 0 to 255<br>C 0 to 255                                                                                                                     | OR logic operation after scanning for signal state "0"<br>of an input in the PII<br>of an output in the PIQ<br>of a flag bit<br>of an S flag bit<br>of a data word bit<br>of a timer<br>of a counter                                  |
| 0             | _                                                                                                                                                                                                                                        | Combine AND operations through logic OR                                                                                                                                                                                               |
| A(<br>O(<br>) | -                                                                                                                                                                                                                                        | <ul><li>ANDing of expressions in parentheses</li><li>ORing of expressions in parentheses</li><li>Close parenthesis (to complete the bracketed expression)</li><li>Maximum of 8 levels are permitted, i.e. 7 opened brackets</li></ul> |

| Table 3-2 Binary logic operation | ns |
|----------------------------------|----|
|----------------------------------|----|

#### **RLO formation**

The binary logic operations generate the result of logic operation (RLO). At the beginning of a logic sequence, the RLO only depends on the signal state scanned (first scan) and not on the type of logic operation (O = OR, A = AND).

Within a sequence of logic operations, the RLO is formed from the type of operation, previous RLO and the scanned signal state. A sequence of logic operations is <u>completed</u> by an operation (e.g. set/reset operations) which retains the RLO (ERAB = 0). Following this, the RLO can be evaluated but cannot be further combined.

#### **Example of RLO formation**

| Program                                              | Status | RLO                                                      | ERAB                                                                                                          |
|------------------------------------------------------|--------|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| $\begin{array}{rrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr$ |        | $\begin{pmatrix} 0 \\ 1 \\ 1 \\ 0 \\ 0 \\ \end{pmatrix}$ | 0 ← RLO retained<br>1 ← first bit scan<br>1 ← 1<br>0 RLO retained, end of<br>the logic operations<br>sequence |

## Set/reset operations

Table 3-3Set/reset operations

| Operation | Operand                                                                                  | Function                                                                                                               |
|-----------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|
| S<br>R    |                                                                                          | Set if RLO = 1<br>Reset if RLO = 1                                                                                     |
|           | I 0.0 to 127.7<br>Q 0.0 to 127.7<br>F 0.0 to 255.7<br>S 0.0 to 1023.7<br>D 0.0 to 255.15 | an input in the PII<br>an output in the PIQ<br>a flag<br>an S flag<br>a bit in the data word                           |
| =         | I 0.0 to 127.7<br>Q 0.0 to 127.7<br>F 0.0 to 255.7<br>S 0.0 to 1023.7<br>D 0.0 to 255.15 | The RLO is assigned to<br>an input in the PII<br>an output in the PIQ<br>a flag<br>an S flag<br>a bit in the data word |

#### Load and transfer operations

| Operation | Operand                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| L         |                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Load                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Т         |                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           | IB         0 to 127           IW         0 to 126           ID         0 to 124           QB         0 to 127           QW         0 to 127           QW         0 to 126           QD         0 to 124           FY         0 to 255           FW         0 to 252           SY         0 to 1023           SW         0 to 1020           DR         0 to 255           DL         0 to 255           DW         0 to 255           DD         0 to 255 | <ul> <li>an input byte from/to the PII</li> <li>an input word from/to the PII</li> <li>an output byte from/to the PIQ</li> <li>an output word from/to the PIQ</li> <li>an output double word from/to the PIQ</li> <li>an output double word from/to the PIQ</li> <li>a flag byte</li> <li>a flag word</li> <li>a flag double word</li> <li>an S flag byte</li> <li>an S flag byte</li> <li>an S flag double word</li> <li>the right byte of a data word from/to DB,DX</li> <li>the left byte of a data word from/to DB,DX</li> <li>a data word from/to DB, DX</li> <li>a data double word from/to DB, DX</li> </ul> |
|           | PY 0 to 127                                                                                                                                                                                                                                                                                                                                                                                                                                               | a peripheral byte of the digital inputs/outputs (P area)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           | PY 128 to 255                                                                                                                                                                                                                                                                                                                                                                                                                                             | a peripheral byte of the analog or digital inputs/outputs<br>(P area)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|           | <b>PW</b> 0 to 126                                                                                                                                                                                                                                                                                                                                                                                                                                        | a peripheral word of the digital inputs/outputs (P area)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           | PW 128 to 254                                                                                                                                                                                                                                                                                                                                                                                                                                             | a peripheral word of the analog or digital inputs/outputs (P area)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           | OY 0 to 255                                                                                                                                                                                                                                                                                                                                                                                                                                               | a byte of the extended I/O area (O area)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           | OW 0 to 254                                                                                                                                                                                                                                                                                                                                                                                                                                               | a word of the extended I/O area (O area)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           |                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

#### Table 3-4Load and transfer operations

| Operation          |                                                                    | Operand                                                                                                                                                                                 | Function                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Table 3-4 continue | ed:                                                                |                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                      |
| L                  | KB<br>KS<br>KF<br>KG<br>KH<br>DH<br>KM<br>KY<br>KT<br>KC<br>T<br>C | 0 to 255<br>2 ASCII<br>characters<br>-32768 to<br>+32767<br>1)<br>0 to FFFF<br>0 to<br>FFFF FFFF<br>16-bit pattern<br>0 to 255 for<br>each byte<br>0.0 to 999.3<br>0 to 255<br>0 to 255 | Load<br>a constant, 1 byte<br>a constant, 2 ASCII characters<br>a constant as fixed point number<br>a constant as floating point number<br>a constant as hexadecimal number<br>a double word constant as a hexadecimal number<br>a constant as bit pattern<br>a constant, 2 bytes<br>a constant timer value (in BCD)<br>a constant counter value<br>a timer, binary coded<br>a counter, binary coded |
| LC                 | T<br>C                                                             | 0 to 255<br>0 to 255                                                                                                                                                                    | Load<br>a timer<br>a counter<br>in BCD                                                                                                                                                                                                                                                                                                                                                               |

<sup>1)</sup> ±0,1469368 x 10<sup>-38</sup> to ±0,1701412 x 10<sup>39</sup>

#### Load operations

Load operations write the addressed value into ACCU 1. The former contents of ACCU 1 are saved in ACCU 2 (stack lift).

#### **Transfer operations**

Transfer operations write the contents of ACCU 1 to the addressed memory location.

Examples of load and transfer operations



| Example 2:                  |                                                                                                                      |                                          |  |  |  |  |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------|--|--|--|--|
|                             | Fig. 3-7 illustrates the loading/transfer of a byte, word or double word from/into a memory area organized in words. |                                          |  |  |  |  |
|                             |                                                                                                                      | te of data word i into ACCU-1-LL         |  |  |  |  |
| :L DW k lo                  | oad data word k                                                                                                      |                                          |  |  |  |  |
| L DD 1 1c                   | oad data words l                                                                                                     | and 1+1 into ACCU 1                      |  |  |  |  |
|                             | 15 0                                                                                                                 | 31 23 15 7 0<br>0 1) 0 1) 0 1) i ACCU 1  |  |  |  |  |
|                             |                                                                                                                      |                                          |  |  |  |  |
|                             | right byte<br>Data word                                                                                              | T DR i                                   |  |  |  |  |
| Addresses                   | Dala woru                                                                                                            | 31 23 15 7 0                             |  |  |  |  |
| ascending <b>v</b><br>order |                                                                                                                      | 0 <sup>1)</sup> 0 <sup>1)</sup> j ACCU 1 |  |  |  |  |
|                             | left byte                                                                                                            | ↓ L DL j<br>T DL j                       |  |  |  |  |
|                             | Data word j                                                                                                          | 31 15 0                                  |  |  |  |  |
|                             |                                                                                                                      | 0 <sup>1)</sup> k ACCU 1                 |  |  |  |  |
|                             | k                                                                                                                    | L DW k<br>T DW k                         |  |  |  |  |
|                             |                                                                                                                      | 31 15 0                                  |  |  |  |  |
|                             |                                                                                                                      |                                          |  |  |  |  |
|                             |                                                                                                                      |                                          |  |  |  |  |
|                             | l + 1                                                                                                                | <br> <br>                                |  |  |  |  |
|                             |                                                                                                                      | <sup>1</sup> )only with load operations  |  |  |  |  |
|                             |                                                                                                                      |                                          |  |  |  |  |
| Fig. 3-7 Load               | and transfer operations                                                                                              | in a word-oriented memory area           |  |  |  |  |

#### Note

Load operations do not affect the condition codes. Transfer operations clear the OS bit.

When a byte or word is loaded the extra bits are cleared in ACCU 1.

**Addressing I/Os** You can use load and transfer operations to address the I/O peripherals as follows:

#### • directly using the following operations:

L../T.. ..PY, ..PW, ..OY, ..OW

or

• using the process image with the following operations:

L../T.. ..IB, ..IW, ..ID, .QB, ..QW, ..QD

and with logic and set/reset operations

#### Note

If you use the transfer operations T PY 0 to 127 and T PW 0 to 126, the process output image is updated at the same time.

Note the following points about I/O peripherals:

- A process input/output image exists for 128 input and 128 output bytes of the P peripherals with byte addresses from 0 to 127.
- No process image exists for the entire area of the O peripherals and the P peripherals with relative byte addresses from 128 to 255. (For more information on address space allocation see Section 8.2.2).
- I/O modules with addresses of the O peripherals can only be plugged into expansion units (not in the central controller).
- In **one** expansion unit, you can use either only P peripherals or only O peripherals.



#### Caution

If you use relative addresses of the O peripherals in an expansion unit, you can no longer use these addresses for I/O modules in the central controller (this would result in double addressing).

| Timer and<br>counter<br>operations | To load a timer using a start operation or a counter using a set operation, you must first load the value in ACCU 1.<br>The following load operations are preferable: |  |  |
|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                    |                                                                                                                                                                       |  |  |
|                                    | For timers: L KT, L IW, L QW, L FW, L DW, L SW.                                                                                                                       |  |  |
|                                    | For counters: L KC, L IW, L QW, L FW, L DW, L SW.                                                                                                                     |  |  |
|                                    | Starting a timer with the selected timer value requires an RLO signal change.                                                                                         |  |  |

A **counter** is set or started with the selected counter value when a positive-going RLO signal edge is detected.

The following table indicates the signal edge change with corresponding arrows.

Table 3-5Timer and counter operations

| Operation                       | Operand                                                            | RLO<br>1)        | Function                                                                                                                                                                    |
|---------------------------------|--------------------------------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SP<br>SE<br>SD<br>SS<br>SF<br>R | $\begin{array}{cccccccccccccccccccccccccccccccccccc$               | ↑<br>↑<br>↓<br>1 | Start a timer as a pulse<br>Start a timer as extended pulse<br>Start a timer as ON delay<br>Start a timer as stored ON delay<br>Start a timer as OFF delay<br>Reset a timer |
| S<br>R<br>CU<br>CD              | C 0 to 255<br>C 0 to 255<br>C 0 to 255<br>C 0 to 255<br>C 0 to 255 | 1<br>1<br>1      | Set a counter (BCD number from 0 to 999)<br>Reset a counter<br>Count up<br>Count down                                                                                       |

<sup>1)</sup> positive-going edge (↑): signal change from '0' to '1' negative-going edge (↓): signal change from '1' to '0'

When executing the timer or counter operations SP T, SE T, SD T, SS T, SF T and S C the value in ACCU 1 is transferred to the timer or counter (as with the transfer operation) and the appropriate operation is started.

#### **Timer value**

With the operation L KT, you can load a **timer value** directly into ACCU 1 or indirectly from a flag or data word. The value must have the following structure (with L KT, you specify the time base after the period in the operand as shown below):





#### Note

The start of each timer is liable to an inaccuracy of 1 time base! When using timers, you should therefore select the smallest possible time base (time base < timer value):

#### **Example:**

| time value 4s | not: | 1 s x 4      | inaccuracy: 1 s    |
|---------------|------|--------------|--------------------|
|               | but: | 0.01 s x 400 | inaccuracy: 0.01 s |

#### Counter value

With the operation L KC, you can load a **counter value** directly in ACCU 1 or indirectly from a flag or a data word. The value must have the following structure:



These bits are irrelevant, (i.e. they are ignored when the counter is set)



In the timer or counter itself, the value is in binary code. If you want to scan the timer or counter, you can load the actual timer or counter value into ACCU 1 **directly** or **in BCD code**.

Further examples of timer and counter values









If you load values in BCD, status bits 14 and 15 of the timer or 12 to 15 of the counter are not loaded. They have the value 0 in ACCU 1. The value in the ACCU can now be processed further.

## Arithmetic operations

| Operation                | Operand | Function                                                                                                                                                                                                                                            |
|--------------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| + F<br>- F<br>x F<br>: F | _       | Add two fixed point numbers (16 bits)<br>Subtract one fixed point number from another (16 bits)<br>Multiply two fixed point numbers (16 bits)<br>Divide one fixed point number by another (16 bits):<br>quotient in ACCU-1-L, remainder in ACCU-1-H |
| + G<br>- G<br>x G<br>: G |         | Add two floating point numbers (32 bits)<br>Subtract one floating point number from another (32 bits)<br>Multiply two floating point numbers (32 bits)<br>Divide one floating point number by another (32 bits)                                     |

Table 3-6Arithmetic operations

Arithmetic operations logically combine the contents of ACCU 1 and ACCU 2 (e.g. ACCU 2 - ACCU 1). The result is then contained in ACCU 1. An arithmetic operation changes the arithmetic registers as follows (in fixed point operations only the low word):

|         | ACCU 1             | ACCU 2             | ACCU 3             | ACCU 4             |
|---------|--------------------|--------------------|--------------------|--------------------|
| before: | <accu 1=""></accu> | <accu 2=""></accu> | <accu 3=""></accu> | <accu 4=""></accu> |
| after:  | <result></result>  | <accu 3=""></accu> | <accu 4=""></accu> | <accu 4=""></accu> |

Note

Within the **supplementary operations**, there are operations for **subtraction** and **addition** of **double word fixed point numbers**.

In addition, you can use the **ENT** operation from the set of supplementary operations for loading ACCU 3 and ACCU 4 (see Section 3.5.3).

#### Comparison operations

| Table 3-7 | Comparison operations |
|-----------|-----------------------|
|-----------|-----------------------|

| Operation Operand             |   | Function                                                                                                                                                                                                                                                                                                                              |
|-------------------------------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ! = F<br>> F<br>> = G<br>< <= | _ | Compare for equal to<br>Compare for not equal to<br>Compare for greater than<br>Compare for greater than or equal to<br>Compare for less than<br>Compare for less than or equal to<br>F: compare two fixed point numbers (16 bits)<br>D: compare two fixed point numbers (32 bits)<br>G: compare two floating point numbers (32 bits) |

#### Block operations

| Table 3-8 | Block operations |
|-----------|------------------|
|-----------|------------------|

| Operation             |                            | Operand                                                                             | Function                                                                                                                                              |
|-----------------------|----------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| J C                   |                            |                                                                                     | Jump unconditionally<br>Jump conditionally (only when RLO = 1)                                                                                        |
|                       | OB<br>OB<br>PB<br>FB<br>SB | 1 to 39 <sup>1)</sup><br>110 to 255<br>0 to 255<br>0 to 255<br>0 to 255<br>0 to 255 | to an organization block<br>to a system program special function<br>to a program block<br>to an FB function block<br>to a sequence block              |
| DOU<br>DOC            |                            |                                                                                     | Jump unconditionally<br>Jump conditionally (only when RLO = 1)                                                                                        |
| B E<br>B E C<br>B E U | FX                         | 0 to 255<br>-                                                                       | to an FX function block<br>Block end<br>Block end, conditional (only when RLO = 1)<br>Block end, unconditional                                        |
| C<br>C X              | DB<br>DX                   | 3 to 255<br>3 to 255                                                                | Call a DB data block<br>Call a DX data block                                                                                                          |
| G<br>GX               | DB<br>DX                   | 3 to 255<br>3 to 255                                                                | Generate data block DB<br>Generate data block DX<br>(ACCU 1 must contain the number of data words<br>– maximum 4091 – that the new block is to have ) |

<sup>1)</sup> only for test purposes!

#### **G DB/GX DX** Generating a data block

The operation G DBx generates a DB data block with the number x  $(3 \le x \le 255)$  in the user memory of the CPU. The content of the data block is **not** assigned the value 0, i.e. the data words can have any contents.

Before programming this statement, you must store the number of data words that the new DB is to have in ACCU-1-L. The operation "G DB" or "GX DX" creates the block header. A data block generated in this way (**without** block header) can occupy a maximum of 4091 words. You can generate longer data blocks using OB 125.

If the data block already exists, the length of the DB is not permitted or there is not enough space in the DB-RAM, the system program calls **OB 31**. If this is not loaded, the CPU goes to the stop mode.

The GX DXx operation generates a DX data block in the DB-RAM and is otherwise the same as G DBx.

## NOP/display/stop operations

| Operation    | Operand  | Function                                                                                      |
|--------------|----------|-----------------------------------------------------------------------------------------------|
| NOP0<br>NOP1 | _        | No operation<br>No operation                                                                  |
| BLD          | 0 to 255 | Display generation operation for the PG:<br>the CPU handles the operation like a no operation |
| S T P        | _        | CPU changes to soft STOP.                                                                     |

Table 3-9NOP/display/stop operations

## 3.5.2 Programming Examples in the STL, LAD and CSF Methods of Representation

#### Logic operations

| Logical/circuit diagram          |                                      | STEP 5 representation |                                   |  |
|----------------------------------|--------------------------------------|-----------------------|-----------------------------------|--|
|                                  | Statement<br>list                    | Ladder<br>diagram     | Control system flowchart          |  |
| 11.1 1.3 1.7                     | A  1.1<br>A  1.3<br>A  1.7<br>= Q3.5 |                       | 1.1&<br>    1.3&<br>    1.7 Q 3.5 |  |
| Output Q 3.5 is "1" when all ir  | puts are "1" simultar                | heously               |                                   |  |
| Output Q 3.5 is "0" if any of th | e inputs has signal s                | state "0"             |                                   |  |









| Logical/circuit diagram                                                                                                | STEP 5 representation         |                   |      |                          |
|------------------------------------------------------------------------------------------------------------------------|-------------------------------|-------------------|------|--------------------------|
|                                                                                                                        | Statement<br>list             | Ladder<br>diagram |      | Control system flowchart |
| 11.5 11.6<br>11.5<br>11.5<br>11.5<br>11.6<br>Q 3.0<br>Q 3.0                                                            | A I 1.5<br>AN I 1.6<br>= Q3.0 |                   | 23.0 | 1.5&<br>  1.6 Q 3.0      |
| Output Q 3.0 is "1" only when input I<br>(normally open contact activated) an<br>state "0" (normally closed contact ac | d input I 1.6 has signa       |                   |      |                          |

#### Set/reset operations

| Logical/circuit diagram                                                                                                                                                                              |                                                          | STEP 5 representation                                                                                    |                             |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-----------------------------|--|
|                                                                                                                                                                                                      | Statement<br>list                                        | Ladder<br>diagram                                                                                        | Control system<br>flowchart |  |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                               | A   2.7<br>S Q 3.5<br>A   1.4<br>R Q 3.5                 | $\begin{vmatrix} 12.7 & Q3.5 \\ \hline & \hline & S \\ 11.4 \\ \hline & \hline & R & Q \\ \end{vmatrix}$ | )                           |  |
|                                                                                                                                                                                                      | es to "0", the<br>he signal is latched).<br>ne flip-flop |                                                                                                          |                             |  |
| If the signal state at input I 1.4 chang<br>state of Q 3.5 is retained.<br>When the set signal (input I 2.7) and<br>(input I 1.4) are applied at the same t<br>operation programmed last (in this ca | the reset signal<br>ime, the scan                        |                                                                                                          |                             |  |

| RS flip-flop with flags                                                                                                                                     |                                          |                                            |                                   |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|--------------------------------------------|-----------------------------------|
| Logical/circuit diagram                                                                                                                                     | STEP 5 representation                    |                                            |                                   |
|                                                                                                                                                             | Statement<br>list                        | Ladder<br>diagram                          | Control system<br>flowchart       |
| 1.3 12.6<br>R : S<br>1 : 1<br>1 : 0<br>F : 7<br>F : 7<br>F : 7<br>F : 7                                                                                     | A I 2.6<br>S F 1.7<br>A I 1.3<br>R F 1.7 | 12.6  F 1.7 $  11.3    1.3$ $  1.4    1.3$ | F 1.7<br>I 2.6 - S<br>I 1.3 - R Q |
| Signal state "1" at input I 2.6 sets t<br>f the signal state at input I 2.6 cha<br>signal state of the flag is retained, i                                  | nges to "0", the                         | atched.                                    |                                   |
| Signal state "1" at input I 1.3 resets                                                                                                                      | the flip-flop.                           |                                            |                                   |
| If the signal state at input I 1.3 cha<br>signal state of the flag is retained.                                                                             | nges to "0", the                         |                                            |                                   |
| When the set signal (input I 2.6) ar<br>(input I 1.3) are applied at the sam<br>operation last programmed (in this<br>in effect for the rest of the program | e time, the scan<br>case Al 1.3) rem     |                                            |                                   |



| Binary scaler (binary divider)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | STEP 5 representa                                     | tion                                                                                                                                                                                                                                                                                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Logical/circuit diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Statement<br>list                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Ladder<br>diagram                                     | Control system<br>flowchart                                                                                                                                                                                                                                                                                           |
| 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 		 11.0 | A         I         1.0           AN         F         1.0           =         F         1.1           A         F         1.0           AN         I         1.0           R         F         1.0           R         F         1.0           A         G         3.0           =         F         2.0           A         F         1.1           AN         Q         3.0           =         F         2.0           S         Q         3.0           A         F         2.0           S         Q         3.0           A         F         2.0           S         Q         3.0 | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | $ \begin{array}{c}     I1.0 & - & & \\     F1.0 & - & - & \\     F1.0 & - & - & \\     F1.1 & - & & \\     I1.0 & - & R & Q \\     F1.1 & - & & \\     Q3.0 & - & - & F2.0 \\     F1.1 & - & & \\     Q3.0 & - & & \\     F2.0 & - & & \\   \end{array} $ |
| The binary scaler (output Q 3.2) ch<br>each time input I 1.0 changes its sig<br>to 1 (leading edge). Therefore, only<br>frequency appears at the output of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | gnal state from<br>half the input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                       |                                                                                                                                                                                                                                                                                                                       |

#### Timer operations













|                                                                                                                                                                         |                                                           | STEP 5 representa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | tion                                                           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| Logical/circuit diagram                                                                                                                                                 | Statement<br>list                                         | Ladder<br>diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Control system flowchart                                       |
| $\begin{bmatrix} 1 4.2 \\ R & S & Cl \\ \hline $ | A I 4.0<br>CD C 2<br>A I 4.2<br>R C 2<br>A C 2<br>= Q 2.4 | $\begin{vmatrix} 14.0 & C2 \\ -CD \\ -CU \\ -S & Bi \\ 14.2 & CV & DE \\ -Q & 2.4 \\ -Q & -C \\ $ | C2<br>1 4.0 CD<br>- CU<br>- S BI<br>- CV DE<br>Q2<br>1 4.2 R Q |

|                                                                                                                                                                                                                                                                                                                           |                   | STEP 5 representa | tion                     |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------|--------------------------|--|--|
| Logical/circuit diagram                                                                                                                                                                                                                                                                                                   | Statement<br>list | Ladder<br>diagram | Control system flowchart |  |  |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                    |                   |                   |                          |  |  |
| The value of the addressed counter is incremented<br>by "1" to a maximum value of 999. The function CU<br>is only executed on a positive edge (from "0" to "1")<br>of the logic operation programmed before CU. The<br>flags necessary for edge evaluation of the counter<br>inputs are incorporated in the counter word. |                   |                   |                          |  |  |



#### Comparison operations

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | STEP 5 representation |                   |                          |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-------------------|--------------------------|--|--|
| Logical/circuit diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Statement<br>list     | Ladder<br>diagram | Control system flowchart |  |  |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                       |                   |                          |  |  |
| The first operand is compared with the second operand<br>by the comparison operation. The RLO of the comparison<br>is binary.<br>RLO = "1": comparison is satisfied if ACCU-1-L = ACCU-2-L<br>RLO = "0": comparison is not satisfied, when ACCU-1-L is<br>not equal to ACCU-2-L.<br>The condition codes CC1 and CC0 are set as described<br>in the list of operations.<br>ACCU-2-H and ACCU-1-H are not involved in the operation<br>for a 16-bit fixed point comparison.<br>In a 32-bit fixed point comparison (! = D) and floating point<br>comparison (! = G) the entire contents of ACCU 1 and<br>ACCU 2 (32 bits) are compared with each other.<br>During the comparison, the numerical representation of the<br>operands is taken into account, i.e. the contents of ACCU-1-L<br>and ACCU-2-L are interpreted here as a fixed point number. |                       |                   |                          |  |  |

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                         | STEP 5 representation                                                           |                                        |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|----------------------------------------|--|--|
| Logical/circuit diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Statement<br>list                                                                                                                                                                                                                                                                       | Ladder<br>diagram                                                               | Control system flowchart               |  |  |
| $ \begin{array}{c cccc} IB21 & DW3 \\                                    $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | L I B21<br>L DW3<br>>< F<br>= Q 3.1                                                                                                                                                                                                                                                     | IB21                                                                            | IB21 — V1 F<br>> <<br>DW3 — V2 Q — Q 3 |  |  |
| The first operand is compared<br>by the comparison operation.<br>The RLO of the comparison is<br>RLO = "1": comparison is satisf<br>equal to ACCU-2-L.<br>RLO = "0": comparison is not s<br>equals ACCU-2-L.<br>The condition codes CC1 and C<br>to the beginning of Section 3.5.<br>ACCU-2-H and ACCU-1-H are<br>for a 16-bit fixed point comparis<br>ACCU-2-H and ACCU-1-H are<br>point comparison and floating p<br>This information also applies to<br>greater than", "greater than or<br>less than or equal to" (see the<br>comparison, the numerical repu-<br>s taken into account, i.e. the ca<br>ACCU-2-L are interpreted here | binary.<br>fied if ACCU-1-L is r<br>atisfied if ACCU-1-L<br>CC0 are set as desc<br>not involved in the c<br>son.<br>involved in a 32-bit i<br>point comparison.<br>comparison operati<br>equal to", "less thar<br>operations list). Dur<br>resentation of the op<br>ontents of ACCU-1-I | ribed<br>operation<br>fixed<br>fons for<br>" and<br>ing the<br>perands<br>_ and |                                        |  |  |

#### 3.5.3 Supplementary Operations

| Introduction                              | You can use the supplementary operations set on the programmer only in function blocks (FB and FX). This means that the total operations set for function blocks consists of the basic operations and the supplementary operations. |
|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                           | The system operations also belong to the supplementary functions. You can use<br>the system operations, for example to overwrite the memory at optional locations<br>or to change the contents of the working registers of the CPU. |
|                                           | If you intend to use system operations, you should be familiar with Chapter 9.                                                                                                                                                      |
| $\wedge$                                  | Caution<br>Only experienced system programmers should use the system operations<br>and then only with caution.                                                                                                                      |
|                                           | You can only write operations in function blocks in STL. You cannot program function blocks in graphic form (LAD and CSF methods of representation).                                                                                |
|                                           | This section describes the supplementary operations and covers possible combinations of substitution operations with actual operands.                                                                                               |
| Identification<br>of system<br>operations | System operations are marked in the first column of the tables with <b>S</b>                                                                                                                                                        |
| Binary logic                              |                                                                                                                                                                                                                                     |

| Dinary logic |
|--------------|
| operations   |

| Operation | Operand | Function                                                                                                                                                                   |
|-----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A =       |         | AND operation, scan a formal operand for signal state '1'                                                                                                                  |
| AN =      |         | AND operation, scan a formal operand for signal state '0'                                                                                                                  |
| O =       |         | OR operation, scan a formal operand for signal state '1'                                                                                                                   |
| ON =      |         | OR operation, scan a formal operand for signal state '0'                                                                                                                   |
|           |         | Insert formal operand                                                                                                                                                      |
|           |         | Inputs, outputs, data and flags addressed in binary (parameter types: I, Q; data type BI) and timers and counters (parameter type: T, C) are permitted as actual operands. |

 Table 3-10
 Binary logic operations with formal operands

## Digital logic operations

| Table 3-11 Digital logic operation |
|------------------------------------|
|------------------------------------|

| Operation Operand Function |  | Function                                                        |
|----------------------------|--|-----------------------------------------------------------------|
| AW                         |  | AND operation on the contents of ACCU-1-L and ACCU-2-L          |
| ow                         |  | OR operation on the contents of ACCU-1-L and ACCU-2-L           |
| xow                        |  | Exclusive OR operation on the contents of ACCU-1-L and ACCU-2-L |

ACCUs 2, 3 and 4 are not affected, however, the condition codes CC 1 and CC 0 are affected (see word condition codes).

## Set/reset operations

| Table 3-12 | Set/reset on | erations with | formal | operands |
|------------|--------------|---------------|--------|----------|
| 14010 5 12 | Sel/reset op | vianons with  | Tounar | operanus |

| Opera | tion | Operand | Function                                                                                                               |
|-------|------|---------|------------------------------------------------------------------------------------------------------------------------|
| S     | =    |         | Set a formal operand (binary)                                                                                          |
| RB    | =    |         | Reset a formal operand (binary)                                                                                        |
| RD    | =    |         | Reset a formal operand (digital)<br>for timers and counters                                                            |
| =     | =    |         | Assign the value of the RLO to a<br>formal operand<br>Insert formal operand                                            |
|       |      |         | Inputs, outputs and F flags addressed in binary (parameter type: I, Q; data type BI) are permitted as actual operands. |

## *Timer and counter operations*

| Operation | Operand    | Function                                                                                                                                                                                                                                            |
|-----------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SP =      |            | Start timer specified by the formal operand as a pulse with the value stored in ACCU-1-L (parameter type T).                                                                                                                                        |
| SD =      |            | Start timer specified by the formal operand as ON delay with the value stored in ACCU-1-L (parameter type T).                                                                                                                                       |
| SEC =     |            | Start timer specified by the formal operand as extended pulse with the value stored in ACCU-1-L or set counter specified as formal operand with the counter value stored in ACCU-1-L (parameter type: T, C).                                        |
| SSU =     |            | Start timer specified by the formal operand as stored ON delay with the value stored in ACCU-1-L or increment a counter specified as formal operand (parameter type: T, C).                                                                         |
| SFD =     |            | Start timer specified by the formal operand as stored OFF delay with the value stored in ACCU-1-L or decrement a counter specified as formal operand (parameter type: D, C).                                                                        |
| FR=       |            | Enable formal operand (timer/counter) for cold restart (see FR T or FR R); (parameter type: T, C).<br>Insert formal operand                                                                                                                         |
| FR        | T 0 to 255 | Enable timer for cold restart:<br>The operation is <b>only</b> executed on the leading edge of the RLO (change<br>from 0 to 1). The timer is restarted if the RLO is 1 at the time of the<br>start operation. (See timing diagram below the table). |
|           | C 0 to 255 | Enable a counter for setting or resetting:<br>The operation is executed <b>only</b> on the leading edge of the RLO (change<br>from 0 to 1). The counter is only started if the RLO = 1 at the time of<br>the start operation.                       |

 Table 3-13
 Timer and counter operations with formal operands



#### Examples

|       | Functio | on block call | Program in the<br>function block | Program executed |
|-------|---------|---------------|----------------------------------|------------------|
| a)    |         |               |                                  |                  |
|       | :JU     | FB 203        |                                  |                  |
| NAME  | :EXAM   |               |                                  |                  |
| ANNA  | :       | I 10.3        | :A =ANNA                         | :A I 10.3        |
| BERT  | :       | т 17          | :L KT 010.2                      | :L KT 010.2      |
| JOHN  | :       | Q 18.4        | :SSU =BERT                       | :SS T 17         |
|       |         |               | :A =BERT                         | :A T 17          |
|       |         |               | := =JOHN                         | := Q 18.4        |
|       |         |               |                                  |                  |
| b)    |         |               |                                  |                  |
|       | :JU     | FB 204        |                                  |                  |
| NAME  | :EXAM   | PLE2          |                                  |                  |
| MAXI  | :       | I 10.5        | :A =MAXI                         | :A I 10.5        |
| I RMA | :       | I 10.6        | :SSU =DORA                       | :CU C 15         |
| EVA   | :       | I 10.7        | :A =IRMA                         | :A I 10.6        |
| DORA  | :       | C 15          | :SFD =DORA                       | :CD C 15         |
| EMMA  | :       | F 58.3        | :A =EVA                          | :A I 10.7        |
|       |         |               | :L KC 100                        | :L KC 100        |
|       |         |               | :SEC =DORA                       | :S C 15          |
|       |         |               | :AN =DORA                        | :AN C 15         |
|       |         |               | := =EMMA                         | := F 58.3        |
|       |         |               |                                  |                  |
| C)    |         |               |                                  |                  |
|       | :JU     | FB 205        |                                  |                  |
| NAME  | :EXAM   | PLE3          |                                  |                  |
| BILL  | :       | I 10.4        | :A =BILL                         | :A I 10.4        |
| JACK  |         | Т 18          | :L =EGON                         | :L IW 20         |
| EGON  |         | IW 20         | :SEC =JACK                       | :SE T 18         |
|       | :       | F 100.7       | :A =JACK                         | :A T 18          |
| YOGI  |         |               | := =YOGI                         | := F 100.7       |

#### Load and transfer operations

| Operation | Operand | Function                                                                                                                                                                      |
|-----------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L =       |         | Load a formal operand:<br>The value of the operand specified as a formal operand is loaded into the<br>ACCU (parameter type: I, T, C, Q; data type: BY, W, D).                |
| LCD =     |         | Load a formal operand in BCD code:<br>The value of the timer or counter specified as a formal operand is loaded<br>into the ACCU in BCD code (parameter type: T, C).          |
| LW =      |         | Load the bit pattern of a formal operand:<br>The bit pattern of a formal operand is loaded into the ACCU (parameter<br>type: D; data type: KF, KH, KM, KY, KS, KT, KC).       |
| LWD =     |         | Load the bit pattern of a formal operand:<br>The bit pattern of a formal operand is loaded into the ACCU (parameter type: D; data type: KG).                                  |
| T =       |         | Transfer to a formal operand:<br>The contents of the accumulator are transferred to the operand specified<br>as a formal operand (parameter type: I, Q; data type: BY, W, D). |
|           |         | Insert formal operand                                                                                                                                                         |

 Table 3-14
 Load and transfer operations with formal operands

Actual operands permitted include those of the corresponding basic operations **except for S flags**. For the "LW=" operation, permissible data types include a binary pattern (KM) or a hexadecimal pattern (KH), two absolute numbers of 1 byte each (KY), a character (KS), a fixed point number (KF), a timer value (KT) and a counter value (KC). For "LWD=" permissible data is a floating point number.

| Operation |    | Operand  | Function                                                                                |  |
|-----------|----|----------|-----------------------------------------------------------------------------------------|--|
| L         | RI | 0 to 255 | Load a word from the interface data area into ACCU 1 (RI area)                          |  |
|           | RJ | 0 to 255 | Load a word from the extended interface area into ACCU 1 (RJ area)                      |  |
| L         | RS | 0 to 255 | Load a word from the system data area into ACCU 1 (RS area)                             |  |
|           | RT | 0 to 255 | Load a word from the extended system data area into ACCU 1 (RT area)                    |  |
| Т         | RI | 0 to 255 | Transfer the contents of ACCU 1 to a word in the interface data area (RI area)          |  |
|           | RJ | 0 to 255 | Transfer the contents of ACCU 1 to a word in the extended interface data area (RJ area) |  |
| Т         | RS | 60 to 63 | Transfer the contents of ACCU 1 to a word in the system data area (RS area)             |  |
|           | RT | 0 to 255 | Transfer the contents of ACCU 1 to a word in the extended system data area (RT area)    |  |

 Table 3-15
 Load and transfer operations with special operands

In contrast to the RI, RJ and RT areas, you can only use words RS 60 to RS 63 of the RS area. Refer to Section 8.3.4 "RS/RT Area".

You can use the RT area in its complete length (RT 0 to RT 255) providing you do not use any standard function blocks.

## Arithmetic operations

| Table 3-16 | Arithmetic operation ENT |
|------------|--------------------------|
|------------|--------------------------|

| Operation | Operand | Function                                                            |  |
|-----------|---------|---------------------------------------------------------------------|--|
| ENT       | -       | This causes a stack lift into ACCUs 3 and 4:                        |  |
|           |         | <accu 4=""> := <accu 3=""></accu></accu>                            |  |
|           |         | <accu 3=""> := <accu 2=""></accu></accu>                            |  |
|           |         | <accu 2=""> := <accu 2=""></accu></accu>                            |  |
|           |         | <accu 1=""> := <accu 1=""></accu></accu>                            |  |
|           |         | ACCUs 1 and 2 are not changed. The old contents of ACCU 4 are lost. |  |

#### Example

| The following fraction must be calculated: $(30 + 3 * 4) / 6 = 7$        |        |        |             |        |  |  |
|--------------------------------------------------------------------------|--------|--------|-------------|--------|--|--|
|                                                                          | ACCU 1 | ACCU 2 | ACCU 3      | ACCU 4 |  |  |
| Contents of the ACCUs<br>before the sequence of<br>arithmetic operations | a      | b      | с           | d      |  |  |
| L KF +30                                                                 | 30     | a      | с           | d      |  |  |
| L KF +3                                                                  | 3      | 30     | c           | d      |  |  |
| ENT                                                                      | 3      | 30     | <b>▲</b> 30 | ▲ c    |  |  |
| L KF +4                                                                  | 4      | 3      | 30          | c      |  |  |
| x F                                                                      | 12     | 30 🔺   | c 🔺         | C      |  |  |
| + F                                                                      | 42     | c 🔺    | c 🔺         | с      |  |  |
| L KF +6                                                                  | 6      | 42     | c           | c      |  |  |
| : F                                                                      | 7      | c 🔺    | c 🔺         | С      |  |  |
|                                                                          |        |        |             |        |  |  |

Table 3-17Supplementary arithmetic operations

|   | Operation         |    | Operand                      | Function                                                                                                                                                                                |  |
|---|-------------------|----|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| S | ADD               | BN | -128 to<br>+127              | Add a byte constant (fixed point) to ACCU-1-L (includes sign change)/<br>the condition code in CC 0, CC 1, OV and OS are not affected! –<br>ACCU-1-H and ACCUs 2 to 4 remain unchanged. |  |
| S | ADD               | KF | -32 768 to<br>+32 767        | Add a fixed point constant (word) to ACCU-1-L/ the condition codes in CC 0, CC 1, OV and OS are not affected! – ACCU-1-H and ACCUs 2 to 4 remain unchanged.                             |  |
| S | ADD <sup>1)</sup> | DH | 0000 0000<br>to<br>FFFF FFFF | Add a double word fixed point constant to ACCU 1/the condition codes in CC 0, CC 1, OV and OS are not affected! – ACCUs 2 to 4 remain unchanged.                                        |  |
| S | +D <sup>1)</sup>  |    |                              | Add two double word fixed point constants (ACCU 2 + ACCU 1)/<br>the result can be evaluated in CC 0/CC 1. $^{2)}$                                                                       |  |
| S | -D <sup>1)</sup>  |    |                              | Subtract two double word fixed point constants (ACCU 2 - ACCU 1)/the result can be evaluated in CC 0/CC 1. <sup>2)</sup>                                                                |  |
| S | TAK               |    |                              | Swap the contents of ACCU 1 and ACCU 2                                                                                                                                                  |  |

<sup>1)</sup> Programming is dependent on the PG type and the release of the PG system software.

<sup>2)</sup> For changes in ACCU 2 and ACCU 3: see Section 3.5.1 "Basic Operations/Arithmetic Operations".

#### 3.5.4 Executive Operations

Introduction

The executive operations also include system operations.



**Caution** System operations should only be used with care and then only by experienced programmers familiar with the system.

System operations are indicated in the table by

by S

Jump operationsWhen you use the supplementary jump operations, you indicate the jump<br/>destination for unconditional jumps symbolically. The symbolic parameter of the<br/>jump operation is identical to the symbolic address of the destination statement.<br/>When programming, remember that the absolute jump distance should not<br/>exceed  $\pm 127$  words and a STEP 5 statement can consist of more than one word.<br/>You can only execute these jumps within a block; jumps over segment<br/>boundaries are not permitted ("segment" = structural element in PBs, SBs, FBs,<br/>FXs and OBs; see STEP 5 manual).

#### Note

The jump statement and jump destination (symbolic address) must be in the **same** segment. A symbolic address can only be used **once** per segment. Exception: this does not apply to the JUR jump for which you specify an absolute jump distance as the parameter.

| Table 3-18 | Jump operations |
|------------|-----------------|
|------------|-----------------|

| C | peration | Operand                                                     | Function                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---|----------|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | JU =     | addr                                                        | Jump unconditionally:<br>The jump is executed regardless of conditions                                                                                                                                                                                                                                                                                                                                                                |
|   | JC =     | (addr =symbolic<br>address with<br>maximum<br>4 characters) | Jump conditionally:<br>the conditional jump is executed only if the RLO is 1.<br>If the RLO is 0, the statement is not executed and the RLO is set to 1.                                                                                                                                                                                                                                                                              |
|   | JZ =     |                                                             | Jump if result is '0' :<br>the jump is executed only if CC 1 is 0 and CC 0 is 0.<br>The RLO is not changed.                                                                                                                                                                                                                                                                                                                           |
|   | JN =     | addr<br>(addr = symbolic                                    | Jump if result is not 0 :<br>the jump is executed only if CC1 is not equal to CC0.<br>The RLO is not changed.                                                                                                                                                                                                                                                                                                                         |
|   | JP =     | address with<br>maximum<br>4 characters)                    | Jump if result > '0':<br>the jump is only executed if CC 1 = 1 and CC 0 = 0.<br>The RLO is not changed.                                                                                                                                                                                                                                                                                                                               |
|   | JM =     |                                                             | Jump if result < '0':<br>the jump is only executed if CC 1 = 0 and CC 0 = 1.<br>The RLO is not changed.                                                                                                                                                                                                                                                                                                                               |
|   | JO =     |                                                             | Jump on overflow:<br>the jump is executed when the OV condition code is 1.<br>If there is no overflow (OV is 0), the jump is not executed. The RLO is<br>not changed.<br>An overflow occurs when an arithmetic operation exceeds the<br>permissible range for a given numerical representation.                                                                                                                                       |
|   | JOS =    |                                                             | Jump when the OS (stored overflow) condition code is set:<br>the jump is executed when the condition code OS is 1. If there is no<br>overflow (OS is 0), the jump is not executed. The RLO is not changed.<br>An overflow occurs when an arithmetic operation exceeds the<br>permissible range for a given numerical representation.                                                                                                  |
| S | JUR      | -32 768 to +32 767                                          | Relative jump within the user memory or within a function block (e.g. to<br>arrive in a different segment). The operation is always executed<br>regardless of conditions.<br>The operand is the number of words difference between the address of<br>the jump destination - the current destination. The jump is executed<br>either to a higher (positive operand) or lower (negative operand) address<br>than the current operation. |



#### Caution

If you use **JUR** incorrectly, undefined statuses can occur in the system. It should only be used by extremely experienced programmers with detailed knowledge of the system.

#### Shift operations

| Table 3-19 | Shift operations |
|------------|------------------|
|------------|------------------|

| Operation | Operand | Function (operation with ACCU 1)                                                                            |  |
|-----------|---------|-------------------------------------------------------------------------------------------------------------|--|
| SLW       | 0 to 15 | Shift a word to the left (vacant positions to the right are padded with zeros)                              |  |
| SRW       | 0 to 15 | Shift a word to the right (vacant position to the left are padded with zeros)                               |  |
| SLD       | 0 to 32 | Shift a double word to the left (vacant positions to the right are padded with zeros)                       |  |
| SSW       | 0 to 15 | Shift a word with sign to the right (vacant positions to the left are padded with the sign - bit 15)        |  |
| SSD       | 0 to 32 | Shift a double word with sign to the right (vacant positions to the left are padded with the sign - bit 31) |  |
| RLD       | 0 to 32 | Rotate to the left                                                                                          |  |
| RRD       | 0 to 32 | Rotate to the right                                                                                         |  |

Only ACCU 1 is involved in the execution of shift operations. The parameter part of these operations specifies the number of positions by which the accumulator contents should be shifted or rotated. For the SLW, SRW and SSW operations, only the low word of ACCU 1 is involved in the shift operations. For SLD, SSD, RLD and RRD operations, the entire contents of ACCU 1 (32 bits) are involved.

Shift operations are executed regardless of conditions.

You can use jump operations to scan the value of the last bits shifted out using CC 1/CC 0.

| Shift: last<br>bit shifted | CC 1 | CC 0 | Jump<br>operation |
|----------------------------|------|------|-------------------|
| 0                          | 0    | 0    | JZ=               |
| 1                          | 1    | 0    | JN=<br>JP=        |

#### Examples

1. You want to shift the contents of data word DW 52 four bits to the left and write them to data word DW 53. STEP 5 program: Contents of the data words: KH = 14AF:L DW 52 :SLW 4 :Т DW 53 KH = 4AFO2. You want to read the input double word ID 0, and shift the contents of ACCU 1 so that the bit positions of the input double word shown in bold face are retained and the remaining bit positions are set to defined values (OH or OFH). STEP 5 program: Contents of ACCU 1 (hexadecimal) ACCU-1-H: ACCU-1-L: ABCD ID 0 2348 :L 2348 BCD0 :SLW 4 **OBCD** :SRW 4 2348 :SLD 4 3480 BCD0 :SSW 4 3480 FBCD :SSD 4 0348 **OFBC** :RLD 4 3480 FBC0 0348 **OFBC** :RRD 4 3. Application: Multiplication by the 3rd power, e.g. new value = old value x 8FW 10 :L :SLW 3 FW 10 Caution: do not exceed the :Т positive area limit! 4. Application: Division by the 2nd power, e.g. new value = old value : 4 DB 5 :C :L DW 0 :SRW 2 :Т DW 0

## Conversion operations

| Table 3-20 Co | onversion op | perations |
|---------------|--------------|-----------|
|---------------|--------------|-----------|

| Operation | Function                                                                    |  |  |  |  |  |
|-----------|-----------------------------------------------------------------------------|--|--|--|--|--|
| CFW       | Form the 1's complement of ACCU-1-L (16 bits)                               |  |  |  |  |  |
| CSW       | Form the 2's complement of ACCU-1-L (16 bits)                               |  |  |  |  |  |
|           |                                                                             |  |  |  |  |  |
| CSD       | Form the 2's complement of ACCU 1 (32 bits)                                 |  |  |  |  |  |
| DEF       | Convert a fixed point number (16 bits) from BCD to binary                   |  |  |  |  |  |
| DUF       | Convert a fixed point number (16 bits) from binary to BCD                   |  |  |  |  |  |
| DED       | Convert a double word (32 bits) from BCD to binary                          |  |  |  |  |  |
| DUD       | Convert a double word (32 bits) from binary to BCD                          |  |  |  |  |  |
| FDG       | Convert a fixed point number (32 bits) to a floating point number (32 bits) |  |  |  |  |  |
| GFD       | Convert a floating point number to a fixed point number (32 bits)           |  |  |  |  |  |

DEF

The value in ACCU-1-L (bits 0 to 15) is interpreted as a BCD (binary-coded decimal) number. After the conversion, ACCU-1-L contains a 16-bit fixed point number.

DUF

The value in ACCU-1-L (bits 0 to 15) is interpreted as a 16-bit fixed point number. After the conversion, ACCU-1-L contains a BCD number.

| 15 14             |                              |       | 0    |
|-------------------|------------------------------|-------|------|
| S 2 <sup>14</sup> |                              |       |      |
| 15                | DUF ↓                        | DEF 1 | 0    |
| SSSS              | 10 <sup>2</sup>              | 10 1  | 10 0 |
|                   | 0 = positive<br>1 = negative |       |      |

| DEL | The value in ACCU 1 (bits 0 to 31) is interpreted as a BCD number. After the conversion, ACCU 1 contains a 32-bit fixed point number. |                              |     |                 |                 |                 |                                   |          |                  |
|-----|---------------------------------------------------------------------------------------------------------------------------------------|------------------------------|-----|-----------------|-----------------|-----------------|-----------------------------------|----------|------------------|
| DUI | ס                                                                                                                                     |                              |     |                 |                 |                 | rpreted as a 32<br>BCD number.    |          | oint number.     |
| 31  | 30                                                                                                                                    |                              |     |                 |                 |                 |                                   |          | 0                |
| S   | 2 <sup>30</sup>                                                                                                                       |                              |     |                 |                 |                 |                                   |          | 2 <sup>0</sup>   |
|     |                                                                                                                                       |                              | DUI | ⊃ ↓             |                 |                 | DED 1                             |          |                  |
| 31  |                                                                                                                                       |                              |     |                 |                 |                 |                                   |          | 0                |
| 5   | SSSS                                                                                                                                  | 10 <sup>6</sup>              | 10  | ) <sup>5</sup>  | 10 <sup>4</sup> | 10 <sup>3</sup> | 10 <sup>2</sup>                   | $10^{1}$ | 10 0             |
| s   | /                                                                                                                                     | 0 = positive<br>1 = negative |     |                 | •               |                 | •                                 |          |                  |
| FDC | 9                                                                                                                                     | Af                           |     | convers         |                 |                 | rpreted as a 32<br>floating point |          |                  |
| GFL | ס                                                                                                                                     |                              |     |                 |                 |                 | reted as a float<br>xed point num |          | mber. After      |
| 31  | 30                                                                                                                                    |                              |     |                 |                 |                 |                                   |          | 0                |
| s   | 2 <sup>30</sup>                                                                                                                       |                              |     |                 |                 |                 |                                   |          | 2 <sup>0</sup>   |
|     |                                                                                                                                       |                              |     |                 | FDG ↓           |                 | GFD ↑                             |          |                  |
| 31  | 30                                                                                                                                    | 24                           | 23  |                 |                 |                 |                                   |          | 0                |
| s   | 2 <sup>6</sup>                                                                                                                        | 2 <sup>0</sup>               | S   | 2 <sup>-1</sup> | •••             |                 |                                   |          | 2 <sup>-23</sup> |
|     |                                                                                                                                       | Exponent                     |     |                 |                 | Mai             | ntissa                            |          |                  |

The conversion is made by multiplying the (binary) mantissa by the value of the (binary) exponent by shifting the mantissa value to more significant bits past an imaginary decimal point by the value of the exponent (base 2). After the multiplication, remnants of the original mantissa remain to the right of the imaginary decimal point. These bit places are cut off from the whole result.

This conversion algorithm produces the following result classes:

- Floating point numbers ≥ 0 or ≤ -1 result in the next lower number.
- Floating point numbers < 0 and > -1 result in the value '0'.

| Conversion<br>examples | Floating point number | GFD           | 32-bit fixed point number |
|------------------------|-----------------------|---------------|---------------------------|
|                        | +5,7                  | $\rightarrow$ | 5                         |
|                        | -2,3                  | $\rightarrow$ | -3                        |
|                        | -0,6                  | $\rightarrow$ | 0                         |
|                        | +0,9                  | $\rightarrow$ | 0                         |
|                        |                       |               |                           |

| Examples of<br>CFW, CSW |                   | tents of data word DW 64<br>bit (reversed) and stored in                       |
|-------------------------|-------------------|--------------------------------------------------------------------------------|
|                         | STEP 5 program:   | Assignment of the data words:                                                  |
|                         | :LDW 64<br>:CFW   | KM = 0011111001011011                                                          |
|                         |                   | км = 1100000110100100                                                          |
|                         |                   |                                                                                |
|                         |                   | data word DW 207 are interpreted<br>number and stored in data<br>eversed sign. |
|                         | STEP 5 program:   | Assignment of the data words:                                                  |
|                         | :L DW 207<br>:CSW | KF = +51                                                                       |
|                         | • · ·             | KF = -51                                                                       |
|                         |                   |                                                                                |

#### Decrement/ increment

 Table 3-21
 Decrement/increment operation

| Operation Operand |          | Function                                                                              |  |  |  |  |
|-------------------|----------|---------------------------------------------------------------------------------------|--|--|--|--|
| D                 | 1 to 255 | Decrement the low byte (bits 0 to 7) of ACCU-1-L by the value of the operand $^{1)}$  |  |  |  |  |
| Ι                 | 1 to 255 | Increment the low byte (bits 0 to 7) of ACCU-1-L by the value of the operand $^{(1)}$ |  |  |  |  |

<sup>1)</sup> The contents of the low byte of ACCU-1-L are decremented or incremented by the number specified as the operand without a carry. The operation is executed regardless of conditions.

#### Example

| STEP 5   | program:<br>DW 7<br>16<br>DW 8<br>33<br>DW 9 | Assignment of the data words: |  |
|----------|----------------------------------------------|-------------------------------|--|
| :L       | DW 7                                         | кн = 1010                     |  |
| :I<br>:T | 16<br>DW 8                                   | КН = 1020                     |  |
| :D<br>:T | 33<br>DW 9                                   | KH = 10FF                     |  |
|          | _                                            |                               |  |

## Processing operations

| Table 3-22 | Processing | operations |
|------------|------------|------------|
|------------|------------|------------|

|   | Operation | eration Operand |                        | Function                                                                                                                                                                           |
|---|-----------|-----------------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | DO        | DW 01           | to 255                 | Process data word:<br>the following operation is combined with the parameter specified in<br>the address data word and executed.                                                   |
|   |           | FW 01           | to 254                 | Process flag word:<br>the following operation is combined with the parameter specified in<br>the addressed F flag and executed.                                                    |
|   | DO =      |                 |                        | Process formal operand (parameter type B):<br>Only C DB, JU PB, JU OB, JU FB, JU SB can be substituted.<br>Insert formal operand                                                   |
| S | DI        |                 | 1)                     | Indirect processing of a formal operand:<br>execute an operation whose operation code is stored in a formal operand.<br>The number of the formal operand must be stored in ACCU 1. |
|   | DO        | RS              | 60 to 63 <sup>1)</sup> | Execute an operation whose operation code is stored in the system data area (RS = free system data: RS 60 to 63). In 2-word operations the 2nd word must be loaded in RS $n + 1$ . |

<sup>1)</sup> The value in the formal operand or system data is interpreted as the operation code of a STEP 5 operation and is then executed.

Note Only the following operations can be combined with DO DW, or DO FW, DI or DO RS:
A..., AN..., O..., ON..., S..., R..., =... with areas I, Q, F, S,
FR T, R T, SF T, SD T, SP T, SS T, SE T,
FR C, R C, S C, CD C, CU C,
L..., T.. with areas P, O, I, Q, F, S, D, RI, RJ, RS, RT,
L T, L C,
LC T, LC C,
JU=, JC=, JZ=, JN=, JP=, JM=, JO=,
SLW, SRW,
D, I, SED, SEE,
C DB, JU..., JC..., G DB, GX DX, CX DX, DOC FX, DOU FX.

## Examples of DO<br/>operations• DO DW/DO FW<br/>Operand substitution

Using the statements "DO DW" and "DO FW" you can access data with a substitution, e.g. in a program loop. The substituted access consists of the statement DO DW/DO FW followed immediately by one of the STEP 5 operations listed above.

"Substituted" means that the operand for the operation is not programmed as a static value but is fixed during the course of the STEP 5 program.

Select the operand **type** from the range permitted for the operation when you write your program, e.g. **PB** for the operation "JU PB nn":

You must first load the operand **value** (**nn** in the example) in a data word or F flag word (parameter word) before the substituted access with DO DW/DO FW.

```
1. Principle of substitution:
               KF +120
          :L
               FW 14
                          load FW with the value "KF +120"
          :Т
          :DO FW 14
          :L
               IB 0
                          before the operation "L IB" is executed, the
                          operand value '0' is replaced by the value '120';
                          Operation executed: L IB 120
2. Data word as index register:
The contents of data words DW 20 to DW 100 are set to signal state '0'. The
index register for the parameter of the data words is DW 1.
             :L
                  KF +20
                               supply the index register
                  DW 1
             :Т
  M001
             :L
                  KF +0
                                reset
             :DO DW 1
             :Т
                  DW 0
                  DW 1
                               increment the index register
             :L
                  KF +1
             :L
             :+F
                  DW 1
             :T
                  KF +100
             :L
             :<=F
             :JC =M001
                                jump if the index is within the range
                                remaining STEP 5 program
             . . .
3. Jump distributor for subroutine techniques:
             :DO
                     FW 5
            : JU
                     =M001
                                Contents of flag word FW 5:
             : JU
                     =M002
+
Jump
             :JU
                     =M003
                                      jump distance
distance
            . : JU
                     =M004
                                      (maximum \pm 127)
             : JU
                     =M005
             : .
             : .
  M001
             : .
             : .
             : BEU
  M002
             : .
                                Advantage:
                                all program sections are
             : .
             : BEU
                                contained in one block.
  мооз
             : .
             : .
             : BEU
4. Jump distributor for block calls:
          :DO FW 10
                                             Contents of flag word FW 10:
          JU PB 0
                              → PB O
                             \rightarrow PB 1
                                             Block no. x
                              → PB 2
                              → PB 3
                               •
                              →.
                              → РВ х
```

#### Operand substitution with binary operations

For operand substitutions with binary operations you can use the following operand types: inputs, outputs, F flags, S flags, timers and counters. In this substitution, the structure of the F flag word or data word (parameter word) depends on the operation you are using.

#### Parameter word for inputs and outputs

| Bit no. | 15              | 11 | 10                   | 8 | 7 | 6 |                            | 0 |
|---------|-----------------|----|----------------------|---|---|---|----------------------------|---|
|         | no significance |    | Bit addr<br>from 0 t |   | 0 |   | Byte address from 0 to 127 |   |

Parameter word for F flags

| Bit no. | 15              | 11 | 10             | 8 | 7 |                            | 0 |
|---------|-----------------|----|----------------|---|---|----------------------------|---|
|         | no significance |    | Bit ac<br>from |   |   | Byte address from 0 to 255 |   |

Parameter word for S flags

| Bit no. | 15 | 14                         | 12 | 11                          | 0 |
|---------|----|----------------------------|----|-----------------------------|---|
|         | 0  | Bit address<br>from 0 to 7 |    | Byte address from 0 to 1023 |   |

#### Parameter word for timers and counters

| Bit no. | 15 8            | 7 0                                           |  |
|---------|-----------------|-----------------------------------------------|--|
|         | no significance | Number of timer or counter cell from 0 to 255 |  |

#### • Principle of the substitution with a binary operation



```
• Example of DI operation
```

```
In function block FB 1, STEP 5 operations are executed whose operation
codes were transferred
by a calling block as formal operands FW 10, FW 12 and FW 14.
Which of the operation codes is executed is written by the calling block
as a consecutive number in flag word FW 16.
The result of the executed operation is then entered in ACCU 1 and is
transferred to flag word FW 18.
FB<sub>1</sub>
NAME : TEST
DECL :FW10
                I/O/D/B/T/C: D KM/KH/KY/KS/KF/KT/KC/KG:
                                                              кн
DECL :FW12
                I/Q/D/B/T/C: D KM/KH/KY/KS/KF/KT/KC/KG:
                                                              КН
DECL :FW14
                I/Q/D/B/T/C: D KM/KH/KY/KS/KF/KT/KC/KG: KH
                            cons. number of formal operand
     :L
           FW 16
                            with required operation code
     :
                            transferred operation code is executed
     :DI
     :T
           FW 16
                            result from ACCU 1
     :BE
FB 2
     :
           KF +1
     :L
                            cons. no. of formal operand with operation code
     :Т
           FW 16
     : .TU
           =AUFR
     :
     :
AUFR :
     : JU
          FB 1
                            call FB TEST
NAME : TEST
                            op. code "L IB 90", formal operand 1
FW10 :
           KH 4A5A
FW12 :
           KH xxxx
                            other operation code, formal operand 2
FW14 :
           КН УУУУ
                            other operation code, formal operand 3
     :Т
           FW 18
                            ACCU 1 \rightarrow FW 18
     :BE
   List of actual operands in FB 2
                                                          Principle of sequence in FB 1
 FW 10
                 4A5AH
                                     FW 16
                                                    0001H
 FW 12
                 XXXXH
 FW 14
                 ууууН
                                                                   FW 16
                                                                :L
                                     ACCU 1
                                                     0001H
                                             (cons. no. of actual operand)
                :L IB 90
                                                              – |:DI
                                   Operation executed with "DI"
```

#### Disabling/enabling process interrupts

| Table 3-23 | Disabling/enabling process inte | rrupts |
|------------|---------------------------------|--------|
|------------|---------------------------------|--------|

| Operation | Operand | Function                                     |
|-----------|---------|----------------------------------------------|
| IA        |         | Disable external process interrupt servicing |
| RA        |         | Enable external process interrupt servicing  |

You can use operations "disable/enable process interrupts", for example to suppress external process interrupts when you are using time-driven processing. External process interrupt-driven processing is then no longer possible in the program section between the IA and RA operations. See also the special function OB 120 "disable interrupts", Section 6.5.

#### 3.5.5 Semaphore Operations

*Introduction* If two or more CPUs in one programmable controller (see Chapter 10) require access to the same global memory area (peripherals, CPs, IPs), there is a danger that one CPU will overwrite the data of another CPU or that one CPU could read invalid intermediate data statuses of another CPU and misinterpret them. You must therefore coordinate CPU accesses to the common memory areas.

You can coordinate the individual CPUs using the SED and SEE operations.

You can, for example, program the following coordination between two CPUs: a CPU involved in multiprocessing can only access the common memory area after it has successfully set a declared semaphore (SES). A semaphore xx can only be set by a single CPU. If a CPU fails to set (i.e. disable) the semaphore, it cannot access the memory area. In the same way, a CPU can no longer access the memory once it has released the semaphore again (SEE).

#### SED/SEE (non-system operations) disable/enable semaphore

| Operation | Operand | Function                                                   |
|-----------|---------|------------------------------------------------------------|
| SED       | 0 to 31 | Disable (set) a semaphore                                  |
| SEE       | 0 to 31 | Enable (release) a semaphore                               |
|           |         | evaluation of the result of the operation via CC 0/CC 1 $$ |

#### Note

The SED xx and SEE xx operations must be programmed **in all CPUs** that require synchronized access to a **common** global memory area.

Standard FBs, handling blocks and blocks for multiprocessor communication manage the coordination internally. If you use these blocks, you do not need to program the operations SEE xx and SED xx.

**Effect of SED/SEE** The CPU that executes the operation SED xx (disable semaphore) accesses a specific byte in the coordinator (**provided** that no other CPU has access to that byte already).

Once a CPU has reserved access, the other CPUs can no longer access the memory area protected by the semaphore (numbers 0 to 31). The area is therefore disabled for all other CPUs.

Make sure that the coordination functions correctly, all CPUs requiring access to the same area of global memory must use the same semaphore.

The SEE xx (enable semaphore) operation resets the byte on the coordinator. The protected memory area is then once again accessible to the other CPUs. A semaphore can only be enabled by the CPU that disabled it.

**Use of SED/SEE** Fig. 3-8 illustrates the basic sequence of coordinated access using a semaphore.



Fig. 3-8 Coordination of access to the global memory

Before disabling or enabling a particular semaphore, the SED and SEE operations scan the **status** of the semaphore. The condition codes CC 0 and CC 1 are affected as follows:

| CC 1 | CC 0 | Evaluation | Significance                                                          |
|------|------|------------|-----------------------------------------------------------------------|
| 0    | 0    | JZ         | Semaphore was disabled by another CPU and cannot be disabled/enabled. |
| 1    | 0    | JN, JP     | Semaphore was disabled/<br>enabled.                                   |

#### Note

The scanning of a particular semaphore (= read procedure) and the disabling or enabling of the semaphore (=write procedure) are **one unit**. No other CPU can access the semaphore during these procedures!

When using semaphores, remember the following points:

- A semaphore is a global variable, i.e. the semaphore with number 16 exists only **once** in the entire system, even if your controller is using three CPUs.
- All CPUs that require coordinated access to a common memory area must use the SED and SEE operations.
- All participating CPUs must execute the **same** start-up type. During a COLD RESTART, all the semaphores are cleared. During a manual or automatic warm restart, the semaphores are retained.
- Start-up in multiprocessor operation must be synchronized. For this reason, **no** test operation is allowed.

#### Application example for semaphores

#### Tasks:

Four CPUs are plugged into an S5-135U. They output status messages to a status signalling device via a common memory area of the O peripherals (OW 6). A CPU must output each status message for 10 seconds. Only after a 10 second output can a new message be output from the same CPU or a different CPU overwrite the first message. The use of peripheral word OW 6 (extended I/O area, no process image) is controlled by a semaphore. Only the CPU that was able to reserve this area for itself by disabling the assigned semaphore can write this message to OW 6. The semaphore remains disabled for 10 seconds at a time (TIMER T 10). The CPU re-enables the semaphore only after this timer has elapsed. After the semaphore has been re-enabled, the other CPUs can access the reserved area. The new message can then be written to OW 6. If one CPU attempts to disable a semaphore and the semaphore is already disabled by a second CPU, the first CPU waits until the next cycle. It then re-attempts to set the semaphore and output its message. Implementation: The following program can run in all four CPUs, each with a different message. The blocks shown below are loaded. FB 100: DISABLE SEMAPHORE **FB** 0: FB 10: FB 110: OUTPUT REPORT MAIN PROGRAM REPORT FB 101: **ENABLE SEMAPHORE** 5 flags are used as follows: F 10.0 = 1: a message was requested or is being processed F 10.1 = 1: the semaphore was disabled successfully F 10.2 = 1: the timer was started F 10.3 = 1: the message was transmitted F 10.4 = 1: the semaphore was re-enabled

Continued on next page

```
Semaphore application example continued:
FB 0
NAME :MAIN
     :A F 10.0
     :JC =M001
                     If no message is active,
     :
     :AN I 0.0
     : BEC
     :
     :L KH 2222
                     generate message and
     :T FW 12
     :AN F 10.0
     :S
        F 10.0
                     set "MESSAGE" flag.
     :
M001 :JU FB10
                     Call "REPORT" FB
NAME : REPORT
     :
     :BE
FB 10
NAME : REPORT
     :AN F 10.1 If no semaphore is disabled,
                      call "disable semaphore" FB.
     :JC FB 100
NAME :SEMADIS
     :
     :A
         F 10.1 If the semaphore is disabled
     :AN F 10.2
                     and the timer has not started,
        F 10.2
     :S
                     start the timer.
         KT010.2
     :L
     :SE T 10
     :
         F 10.2If the timer has startedF 10.3and no message is being transmitted,
     :A
     :AN F 10.3
     :JC FB 110
                     call "output message" FB.
NAME :MSGOUT
     :
         F 10.2 If the timer has started
     :A
                     and the semaphore is not enabled
     :AN F 10.4
                     and the timer has elapsed,
     :AN T 10
                     call "enable semaphore" FB.
     :JC FB 101
NAME : SEMAENAB
     :
     :AN F 10.4 If the semaphore is enabled,
     : BEC
     :
          кноооо
     :L
                     reset all flags.
     :Т
          FY10
     :BE
                              Continued on next page
```

```
Semaphore application example continued:
FB 100
NAME :SEMADIS
                       Disable semaphore no. 10
     :SED 10
     :JZ =M001
     :AN F 10.1 If the semaphore is disabled successfully,
:S F 10.1 set "SEMAPHORE-DISABLED" flag.
M001 :BE
FB 110
NAME : MSGOUT
         FW12
     :L
                       Transmit a message
     :T OW 6
                       to the peripherals
     :AN F 10.3
     :S F 10.3
                    Set "TRANSFER MESSAGE"
     :
                        flaq
     :BE
FB 101
NAME : SEMAENAB
     :SEE 10
                      Enable semaphore no. 10
     :JZ =M001
     :AN F 10.4
     :S F 10.4
                        Set "SEMAPHORE ENABLED"
     :
                        flag
M001 :BE
```

# 4

## **Operating Modes and Program Processing Levels**

## Contents of the chapter

This chapter provides an overview of the operating statuses and program execution levels of the CPU 928B-3UB21. It informs you in detail about various types of start-up and the organization blocks associated with them, in which you can program your own sequences for various situations when restarting.

You will also learn the characteristics of the program execution modes "cyclic processing", "time-controlled processing" and "interrupt-driven processing" and will see which blocks are available for your user program.

## Overview of the chapter

| Section | Description                                                             | Page |
|---------|-------------------------------------------------------------------------|------|
| 4.1     | Introduction and Overview                                               | 4-2  |
| 4.2     | Program Processing Levels                                               | 4-5  |
| 4.3     | STOP Mode                                                               | 4-11 |
| 4.3.1   | Characteristics and Indication of the Operating Mode                    | 4-11 |
| 4.3.2   | Requesting and Performing an OVERALL RESET                              | 4-13 |
| 4.4     | RESTART Mode                                                            | 4-15 |
| 4.4.1   | MANUAL and AUTOMATIC COLD RESTART                                       | 4-16 |
| 4.4.2   | MANUAL and AUTOMATIC WARM RESTART                                       | 4-16 |
| 4.4.3   | Comparison of the Different Restart Types                               | 4-18 |
| 4.4.4   | User Interfaces for Restart                                             | 4-19 |
| 4.4.5   | Interruptions in the RESTART Mode                                       | 4-22 |
| 4.5     | RUN Mode                                                                | 4-24 |
| 4.5.1   | Cyclic Program Execution                                                | 4-26 |
| 4.5.2   | Time-Driven Program Execution                                           | 4-28 |
| 4.5.3   | CLOSED LOOP CONTROLLER INTERRUPT:<br>Processing Closed Loop Controllers | 4-35 |
| 4.5.4   | PROCESS INTERRUPT: Interrupt-Driven Program<br>Execution                | 4-36 |
| 4.5.5   | Nested Interrupt-Driven and Time-Driven Program Execution               | 4-39 |

#### 4.1 Introduction and Overview

Introduction The CPU 928B has three operating modes:

- **STOP** mode
- **RESTART** mode
- RUN mode

In the RESTART and RUN modes, certain events can occur to which the system program has to react. In many cases, a specific organization block (a block from OB 1 to OB 35) is called as a reaction to an event and serves as the user interface.

The modes are displayed by LEDs on the front panel of the CPU. Some of the modes must be activated using the operating elements on the front panel of the CPU. The position of the LEDs and operating elements can be seen in Fig. 4-1.



Fig. 4-1 Front panel of the CPU 928B with display and operating elements

# LED display of<br/>modesVarious LEDs on the front panel of the CPU signal the current CPU mode. The<br/>following table shows you the relationship between the STOP and RUN LED<br/>displays and the mode they indicate.<br/>Other LEDs (BASP, ADF, OVZ, ZYK) provide more information.

LED LED Mode RUN STOP The CPU is in the RUN mode. ON OFF The CPU is in the STOP mode. OFF ON After a STOP request at the switch or from the PG, the STOP LED is lit continuously, because the STOP condition was requested by the user or, in multiprocessor operation, by another CPU and was not prompted by the CPU itself. OFF OFF The CPU is in the RESTART mode or the CPU is in the RESTART/RUN mode, the program test is active and the program has reached a breakpoint (wait state) or the CPU is in the RESTART/RUN mode, the program test is active and a breakpoint was eliminated again before it was reached (wait state) OFF flashing The CPU is in the STOP mode. slowly The CPU itself prompted the STOP condition (possibly also of the other CPUs). Typical causes: ADF, QVZ, LZF, BCF, CL controller error, interrupt collision, cycle time error, BSTACK overflow, stop command. If you switch the mode selector to STOP, the flashing stops and the LED is lit continuously. OFF flashing The CPU is in the STOP mode. quickly An overall reset has been requested. This request can be prompted by the CPU itself or by an operator input. ON ON Serious system error Remedy: - Overall Reset of CPU. - If error persists, switch voltage at PLC off and on again and perform Overall Reset of CPU. - If error persists, switch off voltage at PLC, remove and re-insert the CPU and perform Overall Reset of CPU. - If error persists, replace CPU or have it repaired.

Table 4-1 Meaning of the LEDs "RUN" and "STOP"

# Signalling and error LEDs

# **BASP LED**

This indicates whether the S5 bus signal BASP (disable command output) is active:

In the single processor mode, the CPU clears BASP when it changes to the RUN mode and sets BASP when it changes to the STOP mode. BASP is activated in the RESTART and in the STOP mode and in the first cycle following a warm restart.

In the multiprocessor mode, the conditions for BASP are identical with those in the single processor mode, provided the switch on the coordinator is set to RUN. (See your System Manual /2/ for more information on the "Test mode" special case.)

Note If BASP is active, all digital outputs are disabled.

If an AUTOMATIC or MANUAL WARM RESTART has been executed before the transition to the RUN mode, the BASP LED goes out only after the remaining cycle has been processed.

# "QVZ" LED

Timeout of an I/O module.

# "ADF" LED

Addressing error; the user program has accessed an address in the process image for which there is no module inserted in the I/Os.

### "ZYK" LED

Cycle error; cycle monitoring time has been exceeded.

The errors ADF and QVZ can only occur in RESTART and in RUN, the cycle error ZYK can only occur in RUN.

At the end of the program processing levels ADF, QVZ or ZYK, the error LED is cleared by the system program, if the CPU has not gone to the STOP mode.

# 4.2 Program Processing Levels

*Introduction* Fig. 4-2 gives an overview of the operating states and the processing levels in the CPU 928B (-3UB12). The explanations of the abbreviations are on the following page.



Fig. 4-2 Operating states and program processing levels

# Program processing levels in RESTART:

| MANUAL COLD I<br>MANUAL WARM<br>RETENTIVE MAN<br>RETENTIVE AUT<br>AUTOMATIC COL<br>AUTOMATIC WA                                                                     | RESTART<br>IUAL COLD I<br>OMATIC COI<br>LD RESTART | LD RESTART levels                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| BCF<br>LZF<br>ADF<br>QVZ<br>SSF                                                                                                                                     |                                                    | (operating code error)<br>(runtime error)Error<br>levels(addressing error)levels(timeout)<br>(interface error)                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                 |
| Program processir                                                                                                                                                   | ng levels in the                                   | e RUN mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ]               |
| CYCLE<br>TIMED JOB<br>TIME INT<br>TIME INT<br>TIME INT<br>TIME INT<br>TIME INT<br>TIME INT<br>TIME INT<br>TIME INT<br>CONTROLLER IN<br>DELAY INTERRU<br>PROCESS INT |                                                    | (cyclic program execution)<br>(time-driven program execution)<br>(collision of time interrupts)<br>(time-driven program execution)<br>(process interrupt-driven prog. execution) | Basic<br>levels |
| WECK-FE<br>REG-FE<br>ZYK<br>BCF<br>LZF<br>ADF                                                                                                                       |                                                    | (collision of time interrupts)<br>(CL controller error)<br>(cycle time error)<br>(operating code error)Error<br>levels<br>(addressing error)                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |

# Features of a program processing level

A program processing level is characterized by specific features which are explained below:

# • Nesting other levels

When an event occurs, which requires higher priority processing, the current level is interrupted by the system program and the higher priority level is activated.

This occurs in the following situations:

- at error levels and program processing levels at RESTART: always at operation boundaries,
- all other levels: at block or operation boundaries (depending on the setting in DX 0, refer to Chapter 7).
- Specific system program

Each program processing level has its special system program.

#### Example:

```
At the CYCLE processing level, the system program updates
the process image of the inputs and outputs, triggers the
cycle monitoring time and invokes management of the
programmer interface (system checkpoint).
```

### ISTACK

After the system program calls an organization block, the CPU executes the STEP 5 statements it contains. Previously, the current register record is saved in the ISTACK and **a new register record** is set up (register: ACCU 1 to 4, block stack pointer, block address register, data block start address, data block length, step address counter and the base address register).

If "normal" program execution is interrupted by the occurrence of an event, following the execution of the OB, the CPU continues the program execution at the point of interruption as long as no stop is programmed in the OB.



Fig. 4-3 Principle of level change and ISTACK

# Priority of processing



Program processing levels have a fixed priority. Depending on this priority, they can interrupt each other or can be nested within each other.

The warm restart and error levels differ from the basic levels in that they can always be nested at operation boundaries whenever the appropriate event occurs. They can be nested both in the basic levels and within each other. In the event of errors, the last to occur always has the highest priority.

A basic level on the other hand can be nested in a lower priority level only at block boundaries unless this default is changed by writing the appropriate program in DX 0 (see Chapter 7).

Priority of the "basic levels":

| CYCLE                         |
|-------------------------------|
| TIMED JOB                     |
| TIME INT 5 s                  |
| TIME INT 2 s                  |
| •                             |
| CONTROLLER INT<br>PROCESS INT |

ascending priority

### Example:

A process interrupt occurs during the processing of a time interrupt. Since the process interrupt has a higher priority, the processing of the time interrupt level is interrupted at the next block boundary and the PROCESS INTERRUPT program processing level is activated. If, for example, an addressing error is detected while the process interrupt is being serviced, the process interrupt is stopped immediately at the next operation boundary to activate the ADF level.

# Response to double error

Once an error level has been activated (ADF, BCF, LZF, QVZ, REG, ZYK) it cannot be activated again until it has been processed completely, not even if a different program processing level is nested within it. In this case, the PLC changes to the STOP mode owing to the double call of a program processing level (DOPP in the ISTACK). Collisions of time interrupts are an exception (refer to the relevant section). In the ISTACK, at depth "01", the DOPP identifier and the error level called twice are marked.



### Example 1:

During the processing of the ADF level (user interface OB 25) a further processing error occurs. Since the ADF level is still active, it cannot be called a second time; the CPU changes to STOP.



Fig. 4-4 Change of level as a result of a double call error



If an operation code error occurs in the LZF program processing level, the system program attempts to call the BCF level (user interface OB 29). This has, however, already been activated by the occurrence of a parameter error (user interface OB 30) and has not yet been completely processed. Calling the BCF level again at this point is not permitted; the CPU changes to STOP (see



Fig. 4-5 Double call of error level BCD

| Description of<br>the individual<br>levels | The individual program processing levels and the corresponding user interfaces<br>are described in more detail in the following sections:Section 4.4describes the program processing levels in RESTART.Section 4.5describes the program processing levels in RUN |                                                     |  |
|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|--|
|                                            | Section 4.4                                                                                                                                                                                                                                                      | describes the program processing levels in RESTART. |  |
|                                            | Section 4.5                                                                                                                                                                                                                                                      | describes the program processing levels in RUN      |  |
|                                            | Sections 5.5 and 5.6                                                                                                                                                                                                                                             | describe the error levels in RESTART and RUN.       |  |

# 4.3 STOP Mode

# 4.3.1 Characteristics and Indication of the Operating Mode

*Characteristics* The STOP mode is distinguished by the following features:

### • User program

The user program is not processed.

### • Retention of data

If program execution has already been active, the values of counters, timers, flags and process images are retained at the transition to the stop mode.

### • BASP signal

The BASP signal (disable command output) is active. This disables all digital outputs.

Exception: In multiprocessor mode the BASP signal is not active during the test mode of the coordinator - refer to your System Manual /2/ for more information.

### • ISTACK

If program execution was already active, there is an information field for each interrupted program processing level in the interrupt stack (ISTACK) that indicates the cause of the interrupt when the CPU is in the STOP mode (see Section 5.4).

*Indication* The current operating mode is indicated by LEDs on the front panel of the CPU.

| RUN LED:  | off                      |
|-----------|--------------------------|
| STOP LED: | on (steady or flashing)  |
| BASP LED: | on (except in test mode) |

The **STOP LED** indicates the possible causes of the current stop state. The following paragraphs describe a continuously lit or flashing STOP LED.

| STOP LED lit<br>continuously                               | The STOP mode was triggered by the following:                                                                                                                                                                      |  |  |  |  |
|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| -                                                          | • in the single processor mode                                                                                                                                                                                     |  |  |  |  |
|                                                            | - the mode selector was switched from RUN to STOP,                                                                                                                                                                 |  |  |  |  |
|                                                            | - the PLC STOP programmer function was activated,                                                                                                                                                                  |  |  |  |  |
|                                                            | - a device fault occurred (BAU, PEU),                                                                                                                                                                              |  |  |  |  |
|                                                            | - an OVERALL RESET was performed,                                                                                                                                                                                  |  |  |  |  |
|                                                            | <ul> <li>the END PROGRAM TEST programmer function was activated.</li> </ul>                                                                                                                                        |  |  |  |  |
|                                                            | • in the multiprocessor mode                                                                                                                                                                                       |  |  |  |  |
|                                                            | - by switching the mode selector on the coordinator to STOP,                                                                                                                                                       |  |  |  |  |
|                                                            | <ul> <li>by another CPU going into STOP as the result of a fault (a CPU not causing a fault is lit continuously).</li> </ul>                                                                                       |  |  |  |  |
|                                                            |                                                                                                                                                                                                                    |  |  |  |  |
| STOP LED<br>flashes slowly<br>(approximately<br>0.5 Hz)    | When the STOP LED flashes slowly, this normally indicates an error. In the multiprocessor mode, slow flashing indicates the CPU which caused the stop mode (owing to an error).                                    |  |  |  |  |
|                                                            | • The STOP LED flashes slowly in the following situations:                                                                                                                                                         |  |  |  |  |
|                                                            | – a stop operation was programmed in the user program                                                                                                                                                              |  |  |  |  |
|                                                            | <ul> <li>an operator error has occurred (e.g. DB 1 error, selection of an illegal start-up type, etc.)</li> </ul>                                                                                                  |  |  |  |  |
|                                                            | – programming or device errors (calling a block that is not loaded,                                                                                                                                                |  |  |  |  |
|                                                            | <ul> <li>addressing error, timeout, operation code error etc.); the following LEDs also light up to define the possible cause of error more exactly:</li> <li>ADF LED</li> <li>QVZ LED</li> <li>ZYK LED</li> </ul> |  |  |  |  |
|                                                            | <ul> <li>the END PROGRAM TEST programmer function was activated in this CPU.</li> </ul>                                                                                                                            |  |  |  |  |
| The STOP LED<br>flashes quickly<br>(approximately<br>2 Hz) | When the STOP LED flashes quickly, this is a warning that an OVERALL RESET is being requested.                                                                                                                     |  |  |  |  |

# 4.3.2 Requesting and Performing an OVERALL RESET

| Request by the system program | Each time you turn on the power and perform an overall reset, the CPU runs<br>through an initialization routine. If errors are detected during this initialization<br>the CPU changes to the STOP mode and the STOP LED flashes quickly.                                                                                         |  |  |  |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                               | Possible errors: Contents of the RAMs are not correct.<br>Remedy: overall reset on the CPU                                                                                                                                                                                                                                       |  |  |  |
|                               | Contents of the memory card are not correct<br>Remedy: insert correctly programmed memory card<br>and overall reset on the CPU                                                                                                                                                                                                   |  |  |  |
|                               | You must deal with the cause of the problem and then perform an overall reset<br>on the CPU again. OVERALL RESET is also requested if a CPU or system error<br>occurs. You can recognize this error by the fact that the request appears again<br>following an OVERALL RESET. In this case, call your SIEMENS<br>representative. |  |  |  |
| Operator request              | You request OVERALL RESET as follows:                                                                                                                                                                                                                                                                                            |  |  |  |
|                               | 1. Switch the mode selector from RUN to STOP.                                                                                                                                                                                                                                                                                    |  |  |  |
|                               | <b>Result:</b> the CPU is in the STOP mode. The STOP LED is lit continuously.                                                                                                                                                                                                                                                    |  |  |  |
|                               | 2. Hold the <b>momentary-contact</b> mode selector in the OVERALL RESET position; at the same time, switch the mode selector from STOP to RUN and back to STOP.                                                                                                                                                                  |  |  |  |
|                               | Result: you request an OVERALL RESET. The STOP LED flashes quickly.                                                                                                                                                                                                                                                              |  |  |  |
|                               | <b>Note</b><br>If you do not want the OVERALL RESET that you requested to be                                                                                                                                                                                                                                                     |  |  |  |

If you do not want the OVERALL RESET that you requested to be executed, perform a COLD RESTART or MANUAL WARM RESTART.

| Performing an<br>OVERALL RESET | Regardless of whether you yourself or the system program requested an overall reset, you perform the OVERALL RESET as follows:                                                                                                                                                                                                                                |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                | • Hold the reset switch in the OVERALL RESET position; at the same time, switch the mode selector from STOP to RUN and once again to STOP.                                                                                                                                                                                                                    |
|                                | <b>Result:</b> the OVERALL RESET is performed, the STOP LED is lit continuously.                                                                                                                                                                                                                                                                              |
|                                | or                                                                                                                                                                                                                                                                                                                                                            |
|                                | • Use the PG function OVERALL RESET<br>(If you perform an OVERALL RESET at the PG, the manual overall reset<br>request using the switches and selector can be omitted. The position of the<br>reset switch and mode selector are then irrelevant.)                                                                                                            |
|                                | <b>Result:</b> the OVERALL RESET is performed. The STOP LED is lit continuously.                                                                                                                                                                                                                                                                              |
| Checksum                       | When performing an overall reset, a checksum is formed via the system program and compared with the entry in the Flash EPROM. If the two do not match, a serious system error is present (see page 4-3).                                                                                                                                                      |
|                                | <b>Note</b><br>Once you have performed an OVERALL RESET, the only permitted<br>restart mode is a COLD RESTART.                                                                                                                                                                                                                                                |
| Loading the memory card        | If a memory card is inserted when performing an overall reset, all code blocks<br>and data blocks in the memory card are loaded into the user memory of the CPU.<br>The CPU is then in EPROM mode, meaning code blocks cannot be reloaded,<br>edited or deleted; data blocks in the DB-RAM can, however, be reloaded, edited<br>or deleted (see Section 3.3). |

# 4.4 RESTART Mode

**Special features** The RESTART mode is distinguished by the following features:

### Transition from STOP to RUN

The RESTART is the transition from the STOP mode to the RUN mode.

### Restart types

The CPU 928B has the following restart modes:

- COLD RESTART (manual or automatic)
- WARM RESTART (manual or automatic)
- RETENTIVE COLD RESTART (manual or automatic)

Following a **COLD RESTART**, the cyclic user program is processed from the beginning. Following a **WARM RESTART**, the cyclic user program is processed from the point at which it was interrupted.

### Organization blocks

The following organization blocks are called:

| for MANUAL or AUTOMATIC COLD RESTART:                    | OB 20 |
|----------------------------------------------------------|-------|
| for MANUAL WARM RESTART or<br>RETENTIVE COLD RESTART:    | OB 21 |
| for AUTOMATIC WARM RESTART or<br>RETENTIVE COLD RESTART: | OB 22 |

The length of the STEP 5 start-up program in the OBs is not restricted. The organization blocks are not time-monitored. Other blocks can be called in the start-up OBs.

• Data handling

In each start-up type, the values of counters, timers, flags and process images are handled differently.

• BASP signal

The BASP signal (disable command output) is active. This disables all digital outputs.

**Exception:** in the test mode, BASP is not activated! (Please see your System Manual /2/ for information on the test mode.)

### • LEDs on the front panel of the CPU

| RUN LED:  | off                      |
|-----------|--------------------------|
| STOP LED: | off                      |
| BASP LED: | on (except in test mode) |

# • Restart characteristics in multiprocessor mode

For information on the start-up procedure in the multiprocessor mode, refer to Section 10.1.7.

# 4.4.1 MANUAL and AUTOMATIC COLD RESTART

| <i>When is a COLD<br/>RESTART<br/>permitted?</i> | A COLD RESTART is always permitted provided the system is not requesting<br>an OVERALL RESET.                                                                                                                                                      |
|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MANUAL COLD<br>RESTART                           | You carry out a MANUAL COLD RESTART as follows:                                                                                                                                                                                                    |
|                                                  | • Hold the reset switch in the RESET position; at the same time, switch the mode selector from STOP to RUN.                                                                                                                                        |
|                                                  | or                                                                                                                                                                                                                                                 |
|                                                  | • Use the PC START programmer function (COLD RESTART).                                                                                                                                                                                             |
|                                                  | An AUTOMATIC COLD RESTART is triggered in the following case:                                                                                                                                                                                      |
| COLD RESTART                                     | After power failure/POWER OFF in RESTART or RUN followed by power restore/POWER ON, the CPU runs an initialization routing and then attempts to automatically execute a COLD RESTART as long as DX 0 is correctly parameterized (see Section 7.1). |
|                                                  | Prerequisite:                                                                                                                                                                                                                                      |
|                                                  | • The switches on all CPUs and on the coordinator must remain at RUN.                                                                                                                                                                              |
|                                                  | • There must have been no faults in the initialization run.                                                                                                                                                                                        |
|                                                  | • The CPU was not in the STOP mode when the power was switched off.                                                                                                                                                                                |
|                                                  | In the case of power failure in an expansion unit (PEU signal), the CPU goes to STOP. It remains in STOP until the PEU signal is switched inactive and then attempts to execute an AUTOMATIC COLD RESTART or an AUTOMATIC                          |

# 4.4.2 MANUAL and AUTOMATIC WARM RESTART

WARM RESTART.

*When is a WARM* A MANUAL WARM RESTART is **not** permitted in the following situations: *RESTART* not *permitted*?

• when the system is requesting OVERALL RESET

or

• after the following events:

| – d | ouble call of a program | processing level | (ISTACK: DOPP), |
|-----|-------------------------|------------------|-----------------|
|-----|-------------------------|------------------|-----------------|

- OVERALL RESET (control bits: URGELOE),
- start-up aborted (control bits: ANL-ABB),
- STOP after the END PROGRAM TEST programmer function,
- when compressing the memory in the STOP mode,
- stack overflow,
- when the user program has been modified in the STOP mode.

**MANUAL WARM** You carry out a MANUAL WARM RESTART as follows:

RESTART

• Switch the mode selector from STOP to RUN. The reset switch must be in the mid-position.

or

• Use the PLC START programmer function (WARM RESTART).

AUTOMATIC WARM RESTART If there is a power failure/POWER OFF during RESTART or RUN, when the power returns again/POWER ON, the CPU performs an initialization routine and then attempts to perform a WARM RESTART automatically, as long as DX 0 is correctly parameterized (see Chapter 7) or does not exist.

Conditions:

- The selectors on all the CPUs and on the coordinator remain set to RUN.
- No errors are detected during the initialization.
- The CPU was not in STOP before the power failure/POWER OFF.

If there is a power failure in an expansion unit (PEU signal), the CPU changes to STOP. It remains in this state until the PEU signal is cleared and then attempts to perform an AUTOMATIC WARM RESTART or AUTOMATIC COLD RESTART.

# **RETENTIVE COLD RESTART** If the parameter "Retentive cold restart" is stored in DX 0, the system program executes RETENTIVE COLD RESTART instead of WARM RESTART. See the following section to find out how this differs to a "normal" COLD RESTART.

# 4.4.3 Comparison of the Different Restart Types

| System program                           | COLD RESTART     |                  | WARM RESTART     |                  | RETENTIVE COLD<br>RESTART |                  |
|------------------------------------------|------------------|------------------|------------------|------------------|---------------------------|------------------|
| performs                                 | manual           | automatic        | manual           | automatic        | manual                    | automatic        |
| Evaluation of:                           |                  |                  |                  |                  |                           |                  |
| - DB 1                                   | yes              | yes              | no               | no               | no                        | no               |
| - DB 2                                   | yes              | yes              | no               | no               | no                        | no               |
| - DX 0                                   | yes              | yes              | no               | no               | no                        | no               |
| - DX2                                    | yes              | yes              | no               | no               | no                        | no               |
| Initialization of:                       | 1)               | 1)               | 1)               | 1)               | no <sup>1)</sup>          | 1)               |
| - DB 0                                   | no <sup>1)</sup> | no <sup>1)</sup> | no <sup>1)</sup> | no <sup>1)</sup> |                           | no <sup>1)</sup> |
| - 9th track                              | yes              | yes              | no               | no               | no                        | no               |
| - Disable/enable<br>interrupts           | yes              | yes              | no               | no               | yes                       | yes              |
| - Cycle statistics                       | yes              | yes              | no               | no               | no                        | no               |
| Deletion of:                             |                  |                  |                  |                  |                           |                  |
| - Timed job                              | yes              | yes              | no               | no               | no                        | no               |
| - Delay interrupt                        | yes              | yes              | yes              | yes              | yes                       | yes              |
| - ISTACK/                                | yes              | yes              | no               | no               | yes                       | yes              |
| BSTACK                                   | -                | -                |                  |                  | -                         | -                |
| - Process image                          | yes (com-        | yes (com-        | no               | no               | no                        | no               |
| of the inputs                            | pletely)         | pletely)         |                  |                  |                           |                  |
| - Process image                          | yes (com-        | yes (com-        | no               | no               | yes (acc. to              | yes (acc. to     |
| of the outputs/                          | pletely)         | pletely)         |                  |                  | 9th track)                | 9th track)       |
| digital I/O                              |                  |                  |                  |                  |                           |                  |
| - Analog I/O                             | yes              | yes              | no               | no               | no                        | no               |
| - IPC flags                              | yes              | yes              | no               | no               | no                        | no               |
| - Semaphores                             | yes              | yes              | no               | no               | no                        | no               |
| - F flags and                            | yes              | yes              | no               | no               | no                        | no               |
| S flags                                  |                  |                  |                  |                  |                           |                  |
| - Timers and counters                    | yes              | yes              | no               | no               | no                        | no               |
|                                          |                  |                  |                  |                  |                           |                  |
| Processing of                            |                  |                  |                  |                  |                           |                  |
| remaining cycle in                       |                  |                  |                  |                  |                           |                  |
| the case of active<br>BASP signal        | no               | no               | yes              | yes              | no                        | no               |
| Restart type                             | COLD             | COLD             | MANUAL           | AUTO.            | MANUAL                    | AUTO.            |
| determined by                            | RESTART          | RESTART          | WARM             | WARM             | WARM                      | WARM             |
| OB 223                                   |                  |                  | RESTART          | RESTART          | RESTART                   | RESTART          |
| Indication of the                        | NEUSTA           | NEUSTA +         | MWA              | AWA              | ANL-6 +                   | ANL-6 +          |
| restart type at the                      |                  | AWA              |                  |                  | MWA                       | AWA              |
| programmer in the<br>ISTACK control bits |                  |                  |                  |                  |                           |                  |
| User interface                           | OB 20            | OB 20            | OB 21            | OB 21            | OB 22                     | OB 22            |

 Table 4-2
 Comparison of the different restart types

<sup>1)</sup> DB 0 is only initialized after an OVERALL RESET

# Definition of the "9th track"

The "9th track" is a list of input and output bytes in the process image that acknowledged at the last COLD RESTART. If you program and load DB 1, then following a successful COLD RESTART, the 9th track contains only the input and output bytes listed in DB 1.

You cannot access the 9th track with STEP 5 operations.

# 4.4.4 User Interfaces for Restart

*Introduction* The organization blocks OB 20, OB 21 and OB 22 are used as user interfaces for the different restart types. You can store your STEP 5 program for each restart type in these blocks.

You can do the following in the RESTART OBs:

- set flags,
- start timers (the start is delayed by the system program until the user program enters the RUN mode),
- prepare the data traffic of the CPU with the I/O modules,
- execute synchronization of the CPs.

# **OB 20** COLD RESTART:

When the CPU executes a MANUAL or AUTOMATIC COLD RESTART, the system program calls OB 20 **once**. In OB 20, you can store a STEP 5 program that executes preparatory steps for **restarting** cyclic program execution:

After OB 20 is processed, the cyclic program execution begins by calling OB 1 or FB 0.

If OB 20 is not loaded, the CPU begins cyclic program execution immediately after the end of a COLD RESTART (following the system activities).

# **OB 21**MANUAL WARM RESTART or RETENTIVE MANUAL COLD<br/>RESTART:

When the CPU carries out a MANUAL WARM RESTART or RETENTIVE MANUAL COLD RESTART, the system program calls OB 21 once. In OB 21, you can store a STEP 5 program that carries out specific activities once before cyclic program execution is resumed.

# MANUAL WARM RESTART

After OB 21 is processed, for MANUAL WARM RESTART the cyclic program execution continues with the next statement after the point at which it was interrupted. The following conditions apply:

- The disable command output signal (BASP) remains active while the rest of the cycle is processed. It is only cleared at the beginning of the next (complete) cycle.
- The process output image is reset at the end of the remaining cycle.

If OB 21 is not loaded, then at the end of a MANUAL WARM RESTART and after performing system activities the CPU begins program execution again at the point at which the program was interrupted.

### Note

The CPU registers a power down (NAU or PEU) even when this occurs in the STOP mode. If you then trigger a MANUAL **WARM RESTART**, the CPU calls **OB 22** before OB 21.

If, instead, you trigger a MANUAL **COLD RESTART**, the previous events are ignored by the CPU and OB22 is **not** called.

### **RETENTIVE MANUAL COLD RESTART**

If the parameter "RETENTIVE COLD RESTART" is entered in the data block DX 0, after processing OB 21, the system program then goes through a **COLD RESTART** (the CPU resumes program execution with the **first STEP 5 statement in OB 1** or **FB 0**). The signal states of the flags, IPC flags, semaphore and the block address list (DB 0) **are retained**.

# **OB 22** AUTOMATIC WARM RESTART or RETENTIVE AUTOMATIC COLD RESTART:

When the CPU executes an AUTOMATIC WARM RESTART or a RETENTIVE AUTOMATIC COLD RESTART, the system program calls OB 22 once. Here you can store a STEP 5 program which executes specific actions once before restoration of program execution previously interrupted in RUN.

# **AUTOMATIC WARM RESTART**

When the power is restored, the CPU carries out the system functions mentioned above and attempts to continue the program from the point at which it was interrupted.

If it is loaded, OB 22 is called first. After OB 22 is processed, cyclic program execution resumes with the next statement after the point at which it was interrupted.

After a power failure and subsequent restoration of power, the following conditions apply:

- The BASP signal (disable command output) remains active while the remaining cycle is processed. It is cleared at the beginning of the next complete cycle.
- The process output image is reset at the end of the remaining cycle.

### **RETENTIVE AUTOMATIC COLD RESTART**

If the parameter "RETENTIVE COLD RESTART" is entered in the data block DX 0, after processing OB 22, the system program then goes through a RETENTIVE COLD RESTART (the CPU resumes program execution with the **first STEP 5 statement in OB 1** or **FB 0**). The signal states of the flags, IPC flags, semaphore and the block address list (DB 0) **are retained**.

# 4.4.5 Interruptions in the RESTART Mode

*Introduction* A start-up program can be interrupted by the following:

- NAU (power failure) or PEU (power failure in expansion unit),
- activating the stop switch, the stop operation, MP-STP or PG-STP,

or:

• program and device errors (see Section 5.6).

If you want to continue an interrupted RESTART with one of the possible restart types, please remember the following points:

**Power failure at**<br/>**RESTART**After power returns following a power failure you must distinguish between<br/>the situations listed in the following table:

#### Selected mode: AUTOMATIC WARM RESTART

The CPU is performing a COLD RESTART (OB 20):

following the return of power after power failure, the organization block OB 22 (AUTOMATIC WARM RESTART) is activated at the point of interruption in OB 20.

The CPU is performing a MANUAL WARM RESTART (OB 21):

following the return of power after a power failure, organization block OB 22 (AUTOMATIC WARM RESTART) is activated at the point of interruption in OB 21.

The CPU is already performing an AUTOMATIC WARM RESTART (OB 22):

following the return of power after a power failure, no second OB 22 is activated. The interrupted OB 22 is not continued after the return of power but is aborted and then called again and processed from the beginning.

#### Selected mode: AUTOMATIC COLD RESTART

The CPU is performing a MANUAL or AUTOMATIC COLD RESTART or a MANUAL WARM RESTART:

following the return of power after power failure, the interrupted OB 20 or OB 21 is not continued, but abandoned and the newly called OB 20 is processed.

The same rules apply to an AUTOMATIC WARM RESTART following a PEU signal.

| MANUAL WARM<br>RESTART after<br>aborting a<br>RESTART | If the CPU goes to the STOP mode during any RESTART (stop switch of ADF) and you then trigger a MANUAL WARM RESTART, the interrupted RESTART is continued from the point at which it was interrupted. OB 21 is not activated.                |
|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MANUAL COLD<br>RESTART after<br>aborting a<br>RESTART | If the CPU goes to the STOP mode during any RESTART and you then trigger a MANUAL COLD RESTART, the interrupted RESTART is aborted and a COLD RESTART is performed (if it exists, OB 20 is called).                                          |
| Aborting<br>RETENTIVE<br>COLD RESTART                 | RETENTIVE COLD RESTART is aborted by:                                                                                                                                                                                                        |
|                                                       | • Power failure in the central controller (NAU) or in the expansion unit (PEU),                                                                                                                                                              |
|                                                       | • Stop switch, stop command, MP-STP or PG-STP                                                                                                                                                                                                |
|                                                       | or                                                                                                                                                                                                                                           |
|                                                       | • Program errors and hardware faults (see Section 5.6).                                                                                                                                                                                      |
|                                                       | An aborted RETENTIVE COLD RESTART is <b>not</b> continued at warm restart.<br>Instead, a <b>new</b> RETENTIVE COLD RESTART is started.                                                                                                       |
|                                                       | Previous events and statuses are not taken into account in the selection of restart type. The following applies especially:                                                                                                                  |
|                                                       | • If a MANUAL or AUTOMATIC RETENTIVE COLD RESTART is aborted<br>by POWER OFF or power failure in the expansion unit, a RETENTIVE<br><b>AUTOMATIC</b> COLD RESTART always takes place at POWER ON if all<br>other restart conditions are met. |
|                                                       | • If a MANUAL or AUTOMATIC RETENTIVE COLD RESTART is initiated by one of the other abort types, a new RETENTIVE MANUAL COLD RESTART takes place.                                                                                             |

# 4.5 RUN Mode

**Special features** When the CPU has executed a RESTART (and only then) it changes to the **RUN** mode. This mode is characterized by the following Special features:

### • Execution of the user program

The user program in OB 1 or in FB 0 is executed cyclically and additional interrupt-driven program sections can be nested in it.

### • Timers, counters, process image

All the timers and counters started in the program are running, the **process image is updated cyclically**.

• BASP signal

The BASP signal (disable command output) is inactive. All the digital outputs are therefore enabled.

• IPC flags

The interprocessor communication (IPC) flags are updated cyclically (provided this is programmed in DB1).

### • LEDs on the front panel of the CPU

| RUN LED:  | on  |
|-----------|-----|
| STOP LED: | off |
| BASP LED: | off |

### Note

If an AUTOMATIC or MANUAL warm restart was executed before the CPU went into the RUN mode, the BASP LED remains lit until the rest of the cycle has been processed and the process image has been updated.

The RUN mode is only possible after the RESTART mode.

**Program** In the RUN mode there are 13 basic program processing levels, as follows:

# processing levels

• CYCLE:

The user program is executed cyclically.

# • TIMED JOB:

The user program is executed at fixed times you have programmed or once at a fixed time (clock-controlled time interrupt).

# • 9 TIME INTERRUPTS:

The user program is processed at fixed intervals specified by the system.

# • CONTROLLER INTERRUPT:

Time-driven processing of a preset number of closed loop controllers.

# • DELAY INTERRUPT

The user program is processed once after a preset delay time has elapsed.

# • **PROCESS INTERRUPT:**

Process interrupt-driven user program execution.

The processing levels differ from each other in the following aspects:

- they are triggered by different events
- the user interface for each program processing level is a different organization block or function block.

You can program all basic processing levels at the same time in a CPU 928B. The levels are called by the system program according to the current events and the default priority (see Section 4.2).

# 4.5.1 Cyclic Program Execution

### Introduction



Most functions of a programmable controller involve **cyclic program execution** (**CYCLE** program processing level). This cycle is known as a "free cycle", i.e. after reaching the end of the program, the next cycle is executed immediately (see Fig. 4-6).

**Triggering** If the CPU completes the restart program without errors, it begins cyclic program execution.

**Principle** The system program activities are as follows:



Fig. 4-6 Cyclic program execution

| User interface:<br>OB 1 or FB 0 | The system program calls organization block OB 1 or function block FB 0 as the user interface regularly during cyclic program execution. The system program processes the STEP 5 user program in OB 1 or FB 0 from the beginning through the various block calls you have programmed. Following the system activities, the CPU starts again with the first STEP 5 statement in OB 1 (or in FB 0). In OB 1, you program the calls for program, function and sequence blocks that are to be processed in your cyclic program. If you have a short time-critical user program in which you do not require structured programming, then program <b>FB 0</b> . Since you use the total STEP 5 operation set in this block, you do not require block calls and can reduce the runtime of your program. |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                 | <b>Note</b><br>If both OB 1 and FB 0 are programmed, only OB 1 is called by the system<br>program. If you use FB 0 as the user interface, it must not contain<br>parameters.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Interrupt points                | Cyclic program execution can be interrupted at <b>block boundaries</b> by the following:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                 | • process interrupt-driven program execution,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                 | • closed loop controller processing,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                 | • time-driven program execution.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                 | <b>Note</b><br>You can program DX 0 to enable these interruptions to occur at operation<br>boundaries (see Chapter 7).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                 | Cyclic program execution can be interrupted at <b>operation boundaries</b> or aborted completely as follows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                 | • if a device or program error occurs,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                 | • by operator intervention (PG function, stop switch, MP-STP),                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                 | • by the STOP operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| ACCUs as data<br>storage        | The arithmetic registers ACCU 1, 2, 3 and 4 of the CPU 928B can be used as data storage outside the cycle (from the end of one program cycle to the beginning of the next).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

# 4.5.2 Time-Driven Program Execution

### Introduction



Time-driven processing occurs when a time signal from a clock or internal clock pulse prompts the CPU to interrupt the current program and execute a specific program. After executing this program, the CPU returns to the point at which the previous program was interrupted and continues execution. This way, particular program sections can be inserted automatically into the cyclic program at a specified time.

You can trigger time-driven program execution in different ways, as follows:

- One-off triggering after a freely selectable delay time in the millisecond range, a "delay interrupt" (DELAY INTERRUPT program processing level). The OB 6 organization block is called via this interrupt.
- Triggering using a freely selected time base or once only at an absolute time, a "clock-driven time interrupt" (program processing level TIMED JOB). This interrupt calls organization block OB 9.
- Triggering in 9 different time bases with a range from 10 ms to 5 seconds by "time interrupts" (program processing levels TIME INTERRUPTS). An organization block (OB 10 to OB 18) is assigned to each time interrupt. These have a fixed cycle, i.e. the time between two program starts is fixed.
- **Delay interrupt** Small time intervals with a resolution of 1 ms can also be specified with the delay interrupt of the CPU 928B. When the set time has elapsed, the system program calls OB 6 **once**.
- **Triggering** A delay interrupt is generated by calling the special function organization block OB 153 (see Section 6.12). As soon as the delay time parameterized with OB 153 has elapsed, the system program interrupts the current program execution and calls OB 6. After this, program execution is resumed at the interrupt point.
- User interfaceIn the case of a delay interrupt, OB 6 is called as the user interface. In OB 6 youOB 6store a STEP 5 program to be executed in this case. If OB 6 has not been loaded,<br/>program execution will not be interrupted.

*Interrupt points* The execution of a clock-controlled time interrupt can be interrupted at **block boundaries**, or operation boundaries (if selected in DX 0) by the following:

• processing of a process interrupt.

The processing can be interrupted at **operation boundaries** or aborted completely by the following:

- the occurrence of a hardware fault or program error,
- operator intervention (PG function, stop switch, MP-STP),
- the stop operation.
- **Special features** A delay interrupt is only processed in the RUN mode.
  - A generated delayed alarm (= OB 153 call was processed) is **not** retained in the transition to the STOP mode and during POWER OFF.
  - A delay interrupt can be generated in the RESTART and in the RUN mode (calling of OB 153).
  - If you generate a new delay interrupt, i.e. call OB 153 with new parameters, a previously set delay interrupt is cancelled. A delay interrupt currently being processed is continued. This means that only **one** delay interrupt is valid at any one time.
  - If a delay interrupt occurs without the previous one being completely processed, the new interrupt is discarded. **Delayed interrupts are not checked for collisions!**
  - Note the special functions OB 122 and OB 142 with which you can disable or delay the servicing of delay interrupts.

Clock-driven<br/>time interruptsThe CPU 928B has a battery-backed clock (central back-up via the power supply<br/>of the central controller), which you can set and read out using a STEP 5<br/>program. Using this clock, you can execute a program section time-driven.

While the delay interrupt is used for high-speed jobs, the clock-driven time interrupt is especially suitable for processing one-off jobs or jobs occurring **periodically at large time intervals** such as hourly, daily or every Monday. When the set time is reached, the system program calls OB 9.

TriggeringA clock-driven time interrupt (timed job) is generated by calling the special<br/>function organization block OB 151 (see Section 6.10). Once the time transferred<br/>to OB 151 (time of day, date) has been reached, the timed job is processed. This<br/>can be programmed to occur once (absolute time) or be repeated (time base).<br/>Once a job becomes due for processing, the system program interrupts the<br/>current program and calls OB 9 (program processing level TIMED JOB).<br/>Following this, the program is resumed at the point at which it was interrupted.

#### Example:



| <i>User interface:<br/>OB 9</i> | OB 9 is called as the user interface for a clock-driven time interrupt. You store a STEP 5 program in OB 9 that is to be processed whenever it is called. If you do not load OB 9, program execution is not interrupted. |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Interrupt points                | The execution of a clock-controlled time interrupt can be interrupted at <b>block boundaries</b> , or operation boundaries (if selected in DX 0) by the following:                                                       |
|                                 | • processing of a process interrupt                                                                                                                                                                                      |
|                                 | • processing of a delay interrupt                                                                                                                                                                                        |
|                                 | • processing of a closed loop controller interrupt.                                                                                                                                                                      |
|                                 | The processing can be interrupted at <b>operation boundaries</b> or aborted completely by the following:                                                                                                                 |
|                                 | • the occurrence of a hardware fault or program error,                                                                                                                                                                   |
|                                 | • operator intervention (PG function, stop switch, MP-STP),                                                                                                                                                              |
|                                 | • the stop operation.                                                                                                                                                                                                    |
|                                 |                                                                                                                                                                                                                          |

| Special features | • A clock-driven time interrupt is only processed in the RUN mode.<br>Clock-driven time interrupts that occur in the STOP mode, when the power<br>has failed or during RESTART are discarded.                                                                                                     |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                  | • A clock-driven time interrupt generated following OVERALL RESET and COLD RESTART (= OB 151 call) is retained during a WARM RESTART and following POWER OFF/POWER ON, providing the trigger time did not occur during STOP (see above).                                                          |  |  |
|                  | • If you generate a new clock-controlled time interrupt, i.e. you call OB 151 with new timer values, an already existing clock-driven time interrupt is cancelled. A currently active clock-driven interrupt is continued. Only <b>one</b> clock-driven time interrupt is ever valid at one time. |  |  |
|                  | • If a clock-driven time interrupt occurs when a previous clock-driven time interrupt has not been processed or not been completely processed, the new time interrupt is discarded. Clock-driven time interrupts are not checked for collisions.                                                  |  |  |
|                  | • You can use the special functions OB 120 and OB 122, to disable or delay the processing of clock-driven time interrupts.                                                                                                                                                                        |  |  |
| Time interrupts  | Program execution in fixed time bases                                                                                                                                                                                                                                                             |  |  |
|                  | In the CPU 928B, you can execute up to 9 different time-driven programs, each program being called at a different time interval.                                                                                                                                                                  |  |  |
| Triggering       | A time interrupt is triggered automatically at a fixed time interval if the corresponding OB is programmed.                                                                                                                                                                                       |  |  |
| User interfaces  | When a particular time interrupt occurs, the corresponding organization block is activated as the user interface at the next block boundary (or operation boundary)                                                                                                                               |  |  |
|                  | Assignment of the time interrupt time to the OBs:                                                                                                                                                                                                                                                 |  |  |

| Time base                                                                        | Organization                                                                  | n block called   |
|----------------------------------------------------------------------------------|-------------------------------------------------------------------------------|------------------|
| 10 ms<br>20 ms<br>50 ms<br>100 ms<br>200 ms<br>500 ms<br>1 sec<br>2 sec<br>5 sec | OB 10<br>OB 11<br>OB 12<br>OB 13<br>OB 14<br>OB 15<br>OB 16<br>OB 17<br>OB 18 | Falling priority |

Table 4-3 Assignment "Time interrupt time - called OB"

|                                                    | For example, program the program section to be inserted into the cyclic program every 100 ms in OB 13.                                                                                                                                     |
|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                    | <b>Note</b><br>OBs with shorter time bases have a higher priority and can interrupt OBs<br>with longer time bases.                                                                                                                         |
| <i>Time since last<br/>interrupt<br/>processed</i> | Whenever a time interrupt OB is called (OB 10 to OB 18) ACCU 1 contains the number of time units that have occurred since the last time interrupt OB call, as follows:                                                                     |
|                                                    | ACCU 1 := number of time units - 1                                                                                                                                                                                                         |
|                                                    | If, for example, ACCU 1 contains the number "5" when OB 11 is called, this means that 120 ms (6 time units) have elapsed since OB 11 was last called. As long as there is no collision of time interrupts, a "0" is transferred in ACCU 1. |
|                                                    |                                                                                                                                                                                                                                            |
| Interrupt points                                   | Time-driven program execution can be interrupted either at <b>block boundaries</b> (default) or at <b>operation boundaries</b> (programmed in DX 0) by the following:                                                                      |
|                                                    | • processing of a process interrupt                                                                                                                                                                                                        |
|                                                    | • processing of a delay interrupt                                                                                                                                                                                                          |
|                                                    | • processing of a closed loop controller interrupt                                                                                                                                                                                         |
|                                                    | • renewed processing of a time interrupt                                                                                                                                                                                                   |
|                                                    | Processing can be interrupted at operation boundaries or aborted completely by the following:                                                                                                                                              |
|                                                    | • the occurrence of a hardware fault or program error                                                                                                                                                                                      |
|                                                    | • operator intervention (PG function, stop switch, MP-STP)                                                                                                                                                                                 |
|                                                    | • the stop operation STP.                                                                                                                                                                                                                  |
|                                                    | <b>Note</b><br>Time-driven program execution cannot be interrupted by the same time<br>interrupt (collision of time interrupts).                                                                                                           |

# Collision of time interrupts (WECK-FE)

If a time interrupt OB has not yet been completely processed and is called a second time, a collision occurs. A time interrupt collision also occurs if an OB is called a second time and the first call has not been processed. This is possible when the time interrupts can only interrupt the cyclic program at block limits, particularly if your STEP 5 program contains blocks with long runtimes. If a collision of time interrupts occurs, the error program processing level WECK-FE is activated and the system program calls **OB 33** as the user interface. In OB 33, you can program a specific reaction to this problem.

If OB 33 is not loaded, the CPU goes into Stop if an error occurs. Then WECK-FE is indicated on the programmer in the control bits "Output ISTACK" screen. The level ID of the relevant time interrupt (LEVEL) is indicated in the ISTACK.

When the system program calls OB 33, it transfers additional information to ACCU 1 and ACCU 2 which provides more detail about the first error to occur.

| Error identifier |          | Explanation                                      |
|------------------|----------|--------------------------------------------------|
| ACCU-1-L         | ACCU-2-L |                                                  |
| 1001H            | 001H     | Collision of time interrupts with OB 10 ( 10 ms) |
| 1001H            | 0014H    | Collision of time interrupts with OB 11 ( 20 ms) |
| 1001H            | 0010H    | Collision of time interrupts with OB 12 ( 50 ms) |
| 1001H            | 0010H    | Collision of time interrupts with OB 13 (100 ms) |
| 1001H            | 000EH    | Collision of time interrupts with OB 14 (200 ms) |
| 1001H            | 000CH    | Collision of time interrupts with OB 15 (500 ms) |
| 1001H            | 000AH    | Collision of time interrupts with OB 16 ( 1 sec) |
| 1001H            | 0008H    | Collision of time interrupts with OB 17 ( 2 sec) |
| 1001H            | 0006H    | Collision of time interrupts with OB 18 ( 5 sec) |
|                  |          |                                                  |

 Table 4-4
 Collision of time interrupt identifiers

The identifier in ACCU-2-L is the level identifier (see Section 5.4) of the time interrupt which caused the error.

Continuing program execution after collision of time interrupts If you require the program to continue if a collision of time interrupts occurs, either program the block end statement "BE" in OB 33 or change the default in DX 0 so that the program is continued if a collision occurs and OB 33 is not programmed.

After OB 33 is processed, the program is continued from the point at which it was interrupted.

# Note

With respect to time-driven program execution, remember the special functions **OB 120, OB 121, OB 122** and **OB 123** with which you can disable or delay the processing of time interrupts for a particular program section. (This is possible either for all programmed time interrupts or for individual time interrupts.)

The "faster" a time-driven program processing level is, the greater the danger of time interrupt collisions. If you have time interrupts with short time bases (e.g. the 10 ms and the 20 ms time interrupts) it is normally necessary to select interruption at operation boundaries. This means that the closed loop controller interrupt and the process interrupt must also be set to interrupt at operation boundaries (see Chapter 7, Assigning Parameters to DX 0).

# 4.5.3 CLOSED LOOP CONTROLLER INTERRUPT: Processing Closed Loop Controllers

| Introduction                                                                                  | In the CPU 928B, apart from cyclic, time and process interrupt program<br>execution, it is also possible to process closed loop controllers. You select<br>intervals (= sampling time) at which the cyclic or time-driven program execution<br>is interrupted and the controller is processed. Following this, the CPU returns to<br>the point at which the cyclic or time-driven program was interrupted and<br>continues execution.                                                                                                                                                                                                                      |
|-----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Triggering                                                                                    | A closed loop controller interrupt is triggered when the sampling time you have selected elapses.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                                                               | System program activities                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                               | • It manages the user interface for closed loop controller processing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                               | • It updates the controller process image.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| User interface:<br>standard<br>function block<br>"closed loop<br>controller<br>structure R64" | <ul> <li>When processing a controller, the R64 standard function block is called as the user interface. In conjunction with the controller parameter assignment block DB 2, this allows up to 64 controllers to be processed.</li> <li>You assign a specific data block for each controller. In data block DB 2, known as the "controller list" you specify which controllers are to be processed by the system program at which point in time. DB 2 is reserved for this task.</li> <li>(When assigning parameters, starting up and testing the R64 standard FB, you are supported by a special program package: "COMREG", see Catalog ST 59.)</li> </ul> |
| Interrupt points                                                                              | <ul> <li>Closed loop control processing can be interrupted either at block boundaries (default) or at operation boundaries (programmed in DX 0), by the following:</li> <li>processing of a process interrupt,</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                               | • processing of a delay interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                               | Processing can be interrupted at <b>operation boundaries</b> or aborted completely by the following:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                               | • the occurrence of a hardware fault or program error,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                               | • operator intervention (PG function, stop switch, MP-STP),                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                               | • the stop operation STP.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

# 4.5.4 PROCESS INTERRUPT: Interrupt-Driven Program Execution

| Introduction                   | Interrupt-driven program execution involves the S5 bus signal of an interrupt-capable digital input module (e.g. 6ES5 432-4UAxx) or a suitable IP module that causes the CPU to interrupt program execution and to process a specific program section. On completion of this program, the CPU returns to the point at which execution was interrupted and continues from there.<br>The evaluation of a process interrupt can be triggered either by a signal level or signal edge. You can write a program to either disable, delay or enable the interrupt. OB 2 can interrupt the current program either at <b>operation</b> or <b>block boundaries</b> (when you program DX 0). |
|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Triggering                     | The active state of an interrupt line on the S5 bus triggers the process interrupt.<br>Depending on the slot in the rack, each CPU is assigned one of the interrupt lines<br>(for more detailed information, refer to the System Manual).                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <i>User interface<br/>OB 2</i> | When a process interrupt occurs, OB 2 is called as the user interface. In OB 2, you program a specific program to be processed if a process interrupt occurs.<br>If OB 2 is <b>not</b> programmed, the cyclic program is not interrupted. No interrupt-driven program execution takes place.                                                                                                                                                                                                                                                                                                                                                                                       |
| Interrupt points               | <ul> <li>Process interrupt-driven program execution can only be interrupted by the following:</li> <li>a program or device error (at operation boundaries)</li> <li>operator intervention (PG function, stop switch, MP-STP),</li> <li>the stop operation.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                | NoteInterrupt-driven program execution cannot be interrupted by time-drivenprogram execution or by a further process interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Multiple<br>interrupts                        | If further process interrupts occur during the interrupt-driven program execution, these are <b>ignored</b> until OB 2 <b>has been completely processed</b> (including all the blocks called in OB 2). The CPU then returns to the point of interruption and executes the program until the next block or operation boundary. Only then is a new process interrupt accepted and OB 2 called again. This means that a permanently active interrupt cannot totally block cyclic program execution. |  |  |
|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Note<br>Multiple interrupts are not detected. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|                                               | OB 2 can also be called when the signal state of the interrupt line is passive again when the block boundary is reached.                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                                               | Edge-triggered process interrupts occurring during the execution of OB 2 and remaining active for a shorter time than OB 2 are not detected (if level triggered).                                                                                                                                                                                                                                                                                                                                |  |  |
|                                               | The signal state of the interrupt signal between its becoming active and the completion of OB 2 (BE operation) is irrelevant.                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Process interrupt<br>signal                   | In the default (DX 0), the process interrupt signal for the CPU 928B is level-triggered. i.e. the active state of the interrupt line sets a request which causes OB 2 to be processed at the next block or operation boundary (depending on the setting of DX 0).                                                                                                                                                                                                                                |  |  |
|                                               | Interrupt inactive                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|                                               | Process interrupt OB 2 OB 2 OB 2 OB 2 OB 2                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|                                               | Cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|                                               | block boundaries                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |

Fig. 4-7 Process interrupt, level triggered

When it is called, OB 2 is processed completely. If the interrupt signal is still active or active once again at the end of OB 2, a block is processed in the cyclic program and OB 2 is then called again. If the level is no longer active, OB 2 is only called again at the next change of signal state (from inactive to active).

Active interrupt signal states **before** processing the block end operation (BE) of OB 2 are irrelevant.

# Process interrupt signal: edge-triggered

You can select this setting by assigning parameters to DX 0. After OB 2 has been processed, a new process interrupt can only be triggered by a signal state change (from inactive to active). After processing the block end command (BE) of OB 2 an "inactive-active signal change" of the interrupt signal must follow to generate a process interrupt.



Fig. 4-8 Process interrupt, edge-triggered

Disabling interrupt-driven processing The system program inserts an interrupt-driven program into the cyclic program at a block boundary or at a STEP 5 operation boundary. An interruption of this type can have a negative effect if a cyclic program section has to be processed within a specific time (e.g. to achieve a specific response time) or if a sequence of operations should not be interrupted (e.g. when reading or writing related values).

If a section of the user program should **not** be interrupted by interrupt-driven processing, you can use the following program procedures:

- Program this section so that it does not contain a block change and retain the default in DX 0 (process interrupts at block limits). Program sections that do not contain block changes cannot be interrupted.
- Program the disable process interrupts (IA) operation. Enable interrupt processing with the enable interrupts (RA) operation. No process interrupt driven program execution can take place between these two operations. IA and RA are only allowed in function blocks (supplementary operation set).
- You can use the special functions OB 120 and OB 122 to disable or delay the processing of process interrupts for a particular program section.

#### 4.5.5 Nested Interrupt-Driven and Time-Driven Program Execution

Priorities for interrupt and time-driven program execution If a process interrupt occurs during time controlled program execution, the program is interrupted at the next interrupt point (block or operation boundary) and the process interrupt is processed. Following this, the time-controlled program is completed.

If a time interrupt occurs during interrupt-driven program execution, the interrupt-driven program execution is completed first before the time-driven program execution is started.

If a process interrupt and a time interrupt occur **simultaneously** the process interrupt is processed first at the next interrupt point. After this is completed, the pending time interrupt is then processed.

Fig. 4-9 is a schematic representation of how program execution is interrupted at block boundaries by time-controlled and program-controlled interrupt processing.



Fig. 4-9 Interrupt-driven program execution at block boundaries

**Response time** The response time to a time interrupt request corresponds to the processing time of a block or a STEP 5 operation (depending on the selected preset). If, however, process interrupts are still in the queue when cyclic program execution is interrupted, the time-driven program is only processed after all pending process interrupts have been completely processed.

The maximum response time between the occurrence and processing of a time interrupt is then increased by the processing time of the process interrupts. If you want to exclude as far as possible the chance of a collision for a particular time interrupt OB xy, remember the following rules:

- A + B + C< D where A = the sum of the processing times of all higher priority program processing levels (process, controller, time interrupt OBs)
  - B = processing time of the time interrupt OB xy
  - C = runtime of the longest block of all lower priority processing levels
  - D = time base of the time interrupt OB xy

#### Note

If you run your program not only cyclically but also time and interrupt-driven, you run the risk of overwriting flags. This can occur if you use flags as intermediate flags both in the cyclic and in the inserted time-driven or interrupt-driven programs and the cyclic program is interrupted by a time or interrupt-driven program.

For this reason, save the signal states of the flags in a data block at the beginning of time or interrupt-driven program execution and rewrite them into the (doubly assigned) flags at the end of the interrupt.

Four special organization blocks are available for this purpose: OB 190 and OB 192 "transfer flags to data block" and OB 191 and 193 "transfer data fields to flag area" (refer to the relevant section).

To avoid double assignment of flags, you can also use the S-flags for most applications. Special "saving procedures" for flags are then no longer necessary (there are enough S flags available).

# 5

# **Interrupt and Error Handling**

# Contents of the chapter

This chapter explains how to avoid errors when planning and programming your STEP 5 programs. You will see what help you can get from the system program and which blocks you can use to program reactions to errors.

# Overview of the chapter

| Section | Description                                 | Page |
|---------|---------------------------------------------|------|
| 5.1     | Frequent Errors in the User Program         | 5-2  |
| 5.2     | Error Information                           | 5-3  |
| 5.3     | Control Bits and Interrupt Stack            | 5-7  |
| 5.3.1   | Control Bits                                | 5-8  |
| 5.3.2   | ISTACK Content                              | 5-13 |
| 5.3.3   | Example of Error Diagnosis using the ISTACK | 5-19 |
| 5.4     | Error Handling using Organization Blocks    | 5-22 |
| 5.5     | Errors during RESTART                       | 5-25 |
| 5.5.1   | DB0-FE (DB 0 Errors)                        | 5-26 |
| 5.5.2   | DB1-FE (DB 1 Errors)                        | 5-26 |
| 5.5.3   | DB2-FE (DB 2 Errors)                        | 5-28 |
| 5.5.4   | DX0-FE (DX 0 or DX 2 Errors)                | 5-29 |
| 5.5.5   | MOD-FE (Memory Card Errors)                 | 5-31 |
| 5.6     | Errors in RUN and in RESTART                | 5-32 |
| 5.6.1   | BCF (Operation Code Errors)                 | 5-34 |
| 5.6.2   | LZF (Runtime Errors)                        | 5-37 |
| 5.6.3   | ADF (Addressing Error)                      | 5-45 |
| 5.6.4   | QVZ (Timeout Error)                         | 5-46 |
| 5.6.5   | ZYK (Cycle Time Exceeded Error)             | 5-48 |
| 5.6.6   | WECK-FE (Collision of Time Interrupts)      | 5-49 |
| 5.6.7   | REG-FE (Controller Error)                   | 5-50 |
| 5.6.8   | ABBR (Abort)                                | 5-52 |
| 5.6.9   | Communication Errors (FE-3)                 | 5-53 |

# 5.1 Frequent Errors in the User Program

*Introduction* The system program can detect faulty operation of the CPU, errors in the system program processing or the effect of user errors in the program.

**Overview** This section contains a list of errors most likely to occur when you first run your user program.

You can avoid these errors easily by remembering the following points when you write your STEP 5 program:

- When specifying byte addresses for I/Os, make sure that the corresponding modules are plugged into the central controller or the expansion unit.
- Make sure that you have provided correct parameters for all operands.
- Make sure that outputs, flags, timers and counters are not processed at different points in the program with operations that counteract each other.
- Make sure that all data blocks called in the program exist and are long enough.
- Check that all blocks called are actually in the memory.
- Be careful when changing existing function blocks. Check that the FBs/FXs are assigned the correct operands and that the actual operands are specified.
- Make sure that timers are scanned only once per cycle (e.g. A T1).
- Make sure that scratchpad flags (intermediate flags) are saved by interrupt and time-driven programs and are loaded again on completion of the inserted program when they are required by other blocks (e.g. standard FBs).

### 5.2 Error Information

**Overview** If an error occurs during system start-up or during cyclic execution of your program, there are various sources of information to help you find the problem, as follows:

- LEDs on the front panel of the CPU
- ISTACK interrupt stack and control bits
- system data RS 3, RS 4 and RS 80
- error identifiers in ACCU 1 and ACCU 2
- BSTACK block stack

The following sections describe how to evaluate the information provided by these sources and how to use the error information to analyze a problem.

#### LEDs on the front panel of the CPU

If the CPU goes over to the STOP mode when you do not want it to, check the LEDs on the front panel. They can indicate the cause of the problem.

| LED display               | Meaning                                        |  |
|---------------------------|------------------------------------------------|--|
| STOP LED lit continuously | The various states of                          |  |
| STOP LED flashes slowly   | the STOP LED indicate<br>specific causes of    |  |
| STOP LED flashes quickly  | interruptions and errors<br>(see section 4.1). |  |
| ADF LED lit continuously  | Addressing error                               |  |
| QVZ LED lit continuously  | Timeout error                                  |  |
| ZYK LED lit continuously  | Cycle time exceeded error                      |  |

#### OUTPUT ISTACK programmer online function

You can get information about the status of the control bits and the contents of the interrupt stack (= ISTACK) using the ISTACK programmer online function.

When the CPU goes over to the STOP mode, the system program enters the following information in the **ISTACK**. This information is required for a warm restart:

- register contents
- accumulator contents
- STEP 5 address counter SAC
  - and
- condition codes

These entries can be very helpful for error diagnosis.

|                                                                         | <b>bits</b> is displayed. The control bits me<br>characteristics of the CPU and the us<br>information on the cause of an error.<br>You can use the "Output ISTACK"<br>modes; however, in RESTART and<br>control bits and not via the contents | function in the STOP, RESTART and RUN<br>RUN you only get information via the<br>of the ISTACK.<br>the structure of the interrupt stack are                                                   |
|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>System data<br/>RS 3 and RS 4</i>                                    | the cause of the error is defined in gr<br>and RS 4 (see Section 5.5). These in<br>when it sets up the address list in DF                                                                                                                     | le owing to an error during the <b>RESTART</b> ,<br>reater detail in the system data words RS 3<br>ivolve errors detected by the system program<br>B 0 or evaluates DB 1, DB 2, DX 0 or DX 2. |
|                                                                         | system data word RS 3: KH                                                                                                                                                                                                                     | = EA03                                                                                                                                                                                        |
|                                                                         | system data word RS 4: KH                                                                                                                                                                                                                     | = EA04                                                                                                                                                                                        |
|                                                                         | occurred.                                                                                                                                                                                                                                     | word RS 3 tells you what type of error has                                                                                                                                                    |
|                                                                         | System data word RS 4 tells you wh                                                                                                                                                                                                            |                                                                                                                                                                                               |
|                                                                         | The error identifiers are in the KH d                                                                                                                                                                                                         | lata format.                                                                                                                                                                                  |
| Analyzing<br>system data<br>words RS 3 and<br>RS 4 on the<br>programmer |                                                                                                                                                                                                                                               | DRESS (KH = EA03 or EA04) you can read<br>lata words directly and discover the cause of                                                                                                       |
| System data<br>RS 80                                                    | the interrupt stack (see Section 5.3) a<br>data format KH in system data word<br>The system data word RS 80 has the                                                                                                                           |                                                                                                                                                                                               |

| Error identifiers<br>in ACCU 1 and<br>ACCU 2       | If errors occur in the STEP 5 program execution in <b>RESTART</b> or in the <b>CYCLE</b> for which there is a particular organization block as user interface, the system program automatically enters additional error information in the accumulators ACCU 1 and ACCU 2 when the organization block is called. These entries also define the cause of the error more exactly (see Section 5.6). |
|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                    | The error identifier in ACCU 1 tells you what type of error has occurred.                                                                                                                                                                                                                                                                                                                         |
|                                                    | The error identifier in ACCU 2 (if entered) tells you where the error occurred.                                                                                                                                                                                                                                                                                                                   |
|                                                    | The error identifiers are in the KH data format.                                                                                                                                                                                                                                                                                                                                                  |
| Analysis of                                        | Using the online function OUTPUT ISTACK, you can read the contents of the                                                                                                                                                                                                                                                                                                                         |
| ACCU 1 and<br>ACCU 2 on the<br>programmer          | two accumulators directly out of the ISTACK to find out the exact cause of the error.                                                                                                                                                                                                                                                                                                             |
| Analysis of<br>ACCU 1 and<br>ACCU 2 with<br>STEP 5 | Since the error identifiers are written to ACCU 1 and ACCU 2 automatically<br>when an error organization block is called, you can take these identifiers into<br>account when you program your error OB.<br>This allows you to program specific reactions to various errors in your<br>organization block depending on the error identifier transferrred to it.                                   |
|                                                    |                                                                                                                                                                                                                                                                                                                                                                                                   |
| OUTPUT<br>BSTACK online<br>function                | The PG online function OUTPUT BSTACK gives you information in STOP about the contents of the block stack (BSTACK - see Section 3.2 "Nesting blocks").                                                                                                                                                                                                                                             |
|                                                    | Starting from OB 1 or FB 0, the BSTACK contains a list of all blocks called in sequence and not completely processed when the CPU went into the STOP mode. Since the BSTACK is filled from the bottom, the block on the uppermost level of the BSTACK display contains the block that was last processed and in which the error occurred.                                                         |

# BSTACK information

The **top** line contains the following information:

| Information | Meaning                                                                                                                                                                                                                                                                                                     |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BLOCK NO    | Type and number of the block that called the faulty block                                                                                                                                                                                                                                                   |
| BLOCK ADDR  | Absolute start address of the calling block in the program memory                                                                                                                                                                                                                                           |
| RETURN ADDR | Absolute address of the first STEP 5 operation of this block in the user memory.                                                                                                                                                                                                                            |
| REL ADDR    | Relative address (= difference "RETURN<br>ADDR - BLOCK ADDR") of the next operation to be<br>processed in the calling block.<br>(You can display relative addresses on a programmer in the<br>mode "disable input"/key switch and with S5-DOS from<br>Stage IV upwards using the function key "addresses"). |
| DB NO       | Number of the last data block opened in the calling block                                                                                                                                                                                                                                                   |
| DB ADDR     | Absolute start address in the program memory of the last data block opened in the calling block (address of data word DW 0)                                                                                                                                                                                 |

#### Example:

| <b>BLOCK NO</b> | BLOCK ADDR | <b>RETURN ADDR</b> | REL ADDR | DB NO | DB ADDE |
|-----------------|------------|--------------------|----------|-------|---------|
| OB 23           | 0063       | 0064               | 0001     | 13    | 0078    |
| FB 5            | 006A       | 0072               | 0008     | 13    | 078     |
| FB 6            | 008A       | 0091               | 0007     | 100   | 098     |
| OB 1            | 009D       | 009E               | 0001     |       |         |

The data block DB 100 was opened in FB 6. When the CPU went into the stop mode, data block DB 13 was valid.

Data block DB 13 was opened in FB 5.

# 5.3 Control Bits and Interrupt Stack

| Introduction | Using the PLC INFO and OUTPUT ISTACK online programmer functions, you can analyze the operating status, the characteristics of the CPU and the user program and any possible causes of errors and interruptions.                                                    |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | Note<br>You can display the control bits in any mode. You can display the<br>ISTACK only in the STOP mode.                                                                                                                                                          |
| Overview     | Diagnosis data are displayed by control bits and the ISTACK.                                                                                                                                                                                                        |
|              | • Control bits:                                                                                                                                                                                                                                                     |
|              | The control bits indicate the current and previous operating status and the cause of the problem.<br>If several errors occurred, the control bits indicate <b>all</b> of them.                                                                                      |
|              | • ISTACK:                                                                                                                                                                                                                                                           |
|              | The <b>ISTACK</b> indicates the location of the interruption (addresses) with the current condition codes, the accumulator contents and the cause of the problem.<br>If several errors occurred, a <b>multiple level</b> interrupt stack is constructed as follows: |
|              | depth 01 = last cause of problem,                                                                                                                                                                                                                                   |
|              | depth $02 = next$ to last cause of problem etc.                                                                                                                                                                                                                     |
|              | If an ISTACK overflow occurs (more than 13 entries) the CPU goes into the STOP mode immediately. If this happens, you must perform a POWER OFF/POWER ON and a cold restart.                                                                                         |
|              | The meanings of the individual abbreviations in the control bits and in the ISTACK are described below.                                                                                                                                                             |
|              | Note                                                                                                                                                                                                                                                                |

The text on the screen of your programmer depends on the PG software used. It may differ from the screen represented here. Nevertheless, the description of the individual positions on the screen in these programming instructions is valid.

#### 5.3.1 Control Bits

**Display** When you display the ISTACK on the PG the statuses of the control bits are shown on the first screen page (see Fig. 5-1).

| <u> </u>     | NTROL   | BITS         |         |        |             |              |              |
|--------------|---------|--------------|---------|--------|-------------|--------------|--------------|
| 075          | 075 0   |              |         |        |             |              |              |
| >>STP<<      | STP-6   | FE-STP       | BARBEND | PG-STP | STP-SCH     | STP-BEF      | MP-STP       |
| >>ANL<<      | ANL-6   | NEUSTA<br>X  | MWA     | A W A  | ANL-2       | NEUZU<br>X   | MWA-ZUL<br>X |
| >>RUN<<<br>X | RUN-6   | EINPROZ<br>X | BARB    | OB1GEL | FB0GEL<br>X | OBPROZA      | OBWECKA      |
| 32KWRAM      | 16KWRAM | 8KWRAM<br>X  | EPROM   | KM-AUS | KM-EIN      | DIG-EIN<br>X | DIG-AUS<br>X |
| URGELOE      | URL-IA  | STP-VER      | ANL-ABB | UA-PG  | UA-SYS      | UA-PRFE      | UA-SCH       |
| DX0-FE       | FE-22   | MOF-FE       | RAM-FE  | DB0-FE | DB1-FE      | DB2-FE       | KOR-FE       |
| NAU          | PEU     | BAU          | STUE-FE | ΖΥΚ    | QVZ         | ADF          | WECK-FE      |
| BCF          | FE-6    | FE-5         | FE-4    | FE-3   | L Z F       | REG-FE       | DOPP-FE      |
|              |         |              |         |        |             |              |              |

Fig. 5-1 Example of the first screen form page "OUTPUT ISTACK": control bits

The control bits (>>STP<<, >>ANL<< and >>RUN<<) and the control bits in the first lines of the first screen page mark the current or previous status of the CPU and provide information about certain features of the CPU and your STEP 5 program.

You can display the control bits in all modes. You can, for example, make sure that organization block OB 2 is loaded and that interrupt control program execution is possible at any time.

### *Meaning* The following tables explain the meaning of the individual control bits.

| >>STP<< line (CONTROL BITS) |                                                                                                                                                                                                           |  |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Control bit                 | Meaning                                                                                                                                                                                                   |  |
| »STP«                       | CPU is in the STOP mode                                                                                                                                                                                   |  |
| STP-6                       | Not used                                                                                                                                                                                                  |  |
| FE-STP                      | Error stop: stop mode caused by NAU (power failure), PEU (peripherals<br>not ready), BAU (battery not ready), STUEB (BSTACK overflow),<br>STUEU (ISTACK overflow), DOPP (double call error) or CPU fault  |  |
| BARBEND                     | Program test end: stop mode after PROGRAM TEST END online<br>function (COLD RESTART required)<br>Is not set if the END PROGRAM TEST function was executed with the<br>CPU in the STOP mode.               |  |
| PG-STP                      | PG-STOP: stop mode due to command from PG                                                                                                                                                                 |  |
| STP-SCH                     | STOP switch: stop mode due to mode selector in position STOP                                                                                                                                              |  |
| STP-BEF                     | <ul> <li>Stop operation:</li> <li>stop mode caused by STEP 5 operation "STP"</li> <li>stop mode after stop command from system program, if error</li> <li>organization block is not programmed</li> </ul> |  |
| MP-STP                      | Multiprocessor STOP:<br>- reset switch on the coordinator in STOP position or<br>- different CPU in the STOP mode in multiprocessing                                                                      |  |

 Table 5-1
 Meaning of the control bits in the >>STP<< line</th>

Table 5-2Meaning of the control bits in the >>ANL<< line</th>

|                   | >>ANL<< line (CONTROL BITS)                                                                           |  |  |
|-------------------|-------------------------------------------------------------------------------------------------------|--|--|
| Control bit       | Meaning                                                                                               |  |  |
| »ANL«             | CPU is in the RESTART mode                                                                            |  |  |
| ANL-6<br>+<br>MWA | RETENTIVE MANUAL COLD RESTART                                                                         |  |  |
| ANL-6<br>+<br>AWA | RETENTIVE AUTOMATIC COLD RESTART                                                                      |  |  |
| NEUSTA            | MANUAL COLD RESTART requested (STOP) or was last RESTART type (RESTART/RUN)                           |  |  |
| MWA               | MANUAL WARM RESTART requested (STOP) or was last RESTART type (RESTART/RUN)                           |  |  |
| AWA               | AUTOMATIC WARM RESTART after power failure is requested (STOP) or was last RESTART type (RESTART/RUN) |  |  |
| MWA<br>+<br>AWA   | AUTOMATIC COLD RESTART was requested (STOP) or was last<br>RESTART type (RESTART/RUN)                 |  |  |

| >>ANL<< line (CONTROL BITS) |                                                                                                                                                                                                                                                                                                            |  |  |  |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Control bit                 | Meaning                                                                                                                                                                                                                                                                                                    |  |  |  |
| Table 5-2 continued:        |                                                                                                                                                                                                                                                                                                            |  |  |  |
| ANL-2                       | <ul> <li>Double function:</li> <li>is set after PROGRAM TEST END (in contrast to<br/>BARBEND in the first line, it is also set when<br/>PROGRAM TEST END is called in the STOP<br/>mode; prevents WARM RESTART)</li> <li>is set after "compressing in the STOP mode";<br/>prevents WARM RESTART</li> </ul> |  |  |  |
| NEUZU                       | COLD RESTART permitted (STOP) or COLD RESTART was<br>permitted when the last RESTART took place (RESTART/RUN)                                                                                                                                                                                              |  |  |  |
| MWA-ZUL                     | MANUAL WARM RESTART permitted (STOP) or COLD RESTART<br>was permitted when the last RESTART took place (RESTART/RUN)                                                                                                                                                                                       |  |  |  |

Table 5-3Meaning of the control bits in the >>RUN<< line</th>

| >>RUN<< line (CONTROL BITS) |                                                                                                                                                                                                       |  |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Control bit                 | Meaning                                                                                                                                                                                               |  |
| »RUN«                       | CPU is in the RUN mode (cyclic processing is active)                                                                                                                                                  |  |
| RUN-6                       | Not used                                                                                                                                                                                              |  |
| EINPROZ                     | Single processor mode                                                                                                                                                                                 |  |
| BARB                        | PROGRAM TEST online function is active                                                                                                                                                                |  |
| OB1GEL                      | Organization block OB 1 is loaded in the user memory. Cyclic program execution is determined by OB 1                                                                                                  |  |
| FB0GEL                      | Function block FB 0 is loaded in the user memory. Cyclic program execution is determined by FB 0 if no OB 1 is loaded. If FB 0 and OB 1 are both loaded, OB 1 determines the cyclic program execution |  |
| OBPROZA                     | Process interrupt organization block OB 2 is loaded, i.e. process interrupt-driven program execution is possible                                                                                      |  |
| OBWECK                      | Time interrupt organization block loaded, i.e. time-driven program execution is possible                                                                                                              |  |

| Lines 4 and 5 (CONTROL BITS) |                                                                                                                                                               |  |  |  |  |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Control bit                  | Meaning                                                                                                                                                       |  |  |  |  |
| 32KWRAM                      | Submodule is a RAM (with $32 \ge 2^{10}$ words)                                                                                                               |  |  |  |  |
| 16KWRAM                      | Irrelevant for the CPU 928B-3UB21                                                                                                                             |  |  |  |  |
| 8KWRAM                       | Irrelevant for the CPU 928B-3UB21                                                                                                                             |  |  |  |  |
| EPROM                        | Submodule is an EPROM (with $32 \times 2^{10}$ words)                                                                                                         |  |  |  |  |
| KM-AUS                       | Address list for IPC flag outputs from DB 1 exists                                                                                                            |  |  |  |  |
| KM-EIN                       | Address list for IPC flag inputs from DB 1 exists                                                                                                             |  |  |  |  |
| DIG-EIN                      | Address list for digital inputs exists                                                                                                                        |  |  |  |  |
| DIG-AUS                      | Address list for digital outputs exists                                                                                                                       |  |  |  |  |
| URGELOE                      | Overall reset performed on CPU (COLD RESTART required)                                                                                                        |  |  |  |  |
| URL-IA                       | Overall reset being performed on CPU                                                                                                                          |  |  |  |  |
| STP-VER                      | CPU caused CP stop                                                                                                                                            |  |  |  |  |
| ANL-ABB                      | RESTART aborted (COLD RESTART required)                                                                                                                       |  |  |  |  |
| UA-PG                        | PG has requested OVERALL RESET                                                                                                                                |  |  |  |  |
| UA-SYS                       | System program has requested OVERALL RESET (no RESTART possible); OVERALL RESET must be performed                                                             |  |  |  |  |
| UA-PRFE                      | OVERALL RESET requested owing to CPU error                                                                                                                    |  |  |  |  |
| UA-SCH                       | OVERALL RESET requested at hardware switch:<br>perform an OVERALL RESET or select a restart type if you do not want<br>to perform the requested OVERALL RESET |  |  |  |  |

Table 5-4Meaning of the control bits in lines 4 and 5

The control bits in the following table indicate errors that can occur in the RESTART (e.g. during an initial COLD RESTART) and RUN (e.g. during time-driven program execution) modes.

If several errors occur, **all** causes of interruptions that have occurred up to now (and have not yet been processed) are displayed in the last three lines of the control bits. **See also system data word RS 2**, this contains the ICMK (interrupt condition code group word, 16 bits), in which all errors not yet processed are also entered (Section 8.3.5).

| Lines 6 to 8 (CONTROL BITS) |                                                                                                                                                                                                                                                                                   |  |  |  |  |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Control bit                 | Meaning                                                                                                                                                                                                                                                                           |  |  |  |  |
| DX0-FE                      | Parameter assignment error in DX 0 or DX 2                                                                                                                                                                                                                                        |  |  |  |  |
| FE-22                       | Not used                                                                                                                                                                                                                                                                          |  |  |  |  |
| MOD-FE                      | Error in contents of memory card (OVERALL RESET required)                                                                                                                                                                                                                         |  |  |  |  |
| RAM-FE                      | Error in contents of user memory or of DB-RAM (OVERALL RESET required)                                                                                                                                                                                                            |  |  |  |  |
| DB0-FE                      | Structure of block address lists in DB 0 incorrect                                                                                                                                                                                                                                |  |  |  |  |
| DB1-FE                      | <ul> <li>Structure of the address lists in DB 1 for process image updating is incorrect:</li> <li>DB 1 not programmed and coordinator plugged in or multiprocessor operation required</li> <li>structure or contents of DB 1 incorrect</li> </ul>                                 |  |  |  |  |
| DB2-FE                      | Error evaluating the parameter assignment data block DB 2 of controller structure R64                                                                                                                                                                                             |  |  |  |  |
| KOR-FE                      | Error in data exchange with the coordinator                                                                                                                                                                                                                                       |  |  |  |  |
| NAU                         | Power failure in the central controller                                                                                                                                                                                                                                           |  |  |  |  |
| PEU                         | Peripherals not ready = power failure in expansion unit                                                                                                                                                                                                                           |  |  |  |  |
| BAU                         | Battery not ready = back-up battery failure in central controller                                                                                                                                                                                                                 |  |  |  |  |
| STUE-FE                     | Interrupt or block stack overflow (nesting depth too great; COLD RESTART required)                                                                                                                                                                                                |  |  |  |  |
| ZYK                         | Cycle monitoring time exceeded                                                                                                                                                                                                                                                    |  |  |  |  |
| QVZ                         | Timeout during data exchange with I/Os                                                                                                                                                                                                                                            |  |  |  |  |
| ADF                         | Addressing error with inputs or outputs:<br>error caused by accessing the process image, in which I/O modules<br>were addressed that were not plugged in, defect or not specified in<br>DB 1 at the last COLD RESTART                                                             |  |  |  |  |
| WECK-FE                     | Collision of time interrupts:<br>an attempt was made to call a particular time interrupt OB a second<br>time while or before first call was processed                                                                                                                             |  |  |  |  |
| BCF                         | <ul> <li>Operation code error:</li> <li>substitution error: processed STEP 5 operation cannot be substituted</li> <li>operation code error: processed STEP 5 operation is incorrect</li> <li>parameter error: parameter of the processed STEP 5 operation is incorrect</li> </ul> |  |  |  |  |
| FE-6                        | Not used                                                                                                                                                                                                                                                                          |  |  |  |  |
| FE-5                        | Indicates a serious system error, additional information in RS 80                                                                                                                                                                                                                 |  |  |  |  |
| FE-4                        | Power down error:<br>processing of a previous power failure (NAU) by the system program<br>did not run correctly; WARM RESTART is therefore not possible                                                                                                                          |  |  |  |  |
| FE-3                        | Interface error (SSF)                                                                                                                                                                                                                                                             |  |  |  |  |

Table 5-5Meaning of the control bits in lines 6 to 8

|                      | Lines 6 to 8 (CONTROL BITS)                                                                                                                              |  |  |  |  |  |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Control bit          | Meaning                                                                                                                                                  |  |  |  |  |  |
| Table 5-5 continued: |                                                                                                                                                          |  |  |  |  |  |
| LZF                  | Runtime error:<br>- called block not loaded<br>- load/transfer error with data blocks<br>- other runtime errors                                          |  |  |  |  |  |
| REG-FE               | Error processing the controller structure R64 in the CYCLE                                                                                               |  |  |  |  |  |
| DOPP-FE              | Double call error:<br>a still active error program processing level (ADF, BCF, LZF, QVZ,<br>REG, ZYK) is activated a second time (COLD RESTART required) |  |  |  |  |  |

#### 5.3.2 ISTACK Content

#### Introduction

If the CPU is in the stop state, you can display the content of the ISTACK on the screen after the control bit display by pressing the enter key. When the CPU goes into the STOP mode, the system program enters all the information it needs in this ISTACK for a warm restart.

You can use the entries in this ISTACK to see what kind of error occurred and where it occurred in the program.

If the stop state was caused by **a single** error, only **one** level of the ISTACK information is displayed. With **several** errors, the **corresponding number** of ISTACK levels are output (DEPTH 01, DEPTH 02, etc.). At all levels, only one error is marked as the CAUSE OF INTERRUPT.

If several errors have occurred DEPTH 01 marks the error detected immediately before the change to the stop state.

#### Display

Fig 5-2 is an example of a PG display of the ISTACK content.

| T STACK |                    |                                                                                                                                            |                                                                                                                                                                                   |                                                                                                                                                                                                               |                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 02      |                    |                                                                                                                                            |                                                                                                                                                                                   |                                                                                                                                                                                                               |                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| C70A    | SAC:               |                                                                                                                                            | 00F3                                                                                                                                                                              |                                                                                                                                                                                                               | DB-ADD:                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | BA-ADD:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0002    | FB-NO.:            |                                                                                                                                            | 226                                                                                                                                                                               |                                                                                                                                                                                                               | DB-NO.:                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | OB-NO.:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|         | REL-SAC:           |                                                                                                                                            | 0006                                                                                                                                                                              |                                                                                                                                                                                                               | DBL-REG                                                                                                                                                                                                                    | à.:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0004    | ICMK:              |                                                                                                                                            | 0200                                                                                                                                                                              |                                                                                                                                                                                                               | ICRW:                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0 C464  | ACCU2:             | 0000                                                                                                                                       | 00FF                                                                                                                                                                              |                                                                                                                                                                                                               | ACCU3:                                                                                                                                                                                                                     | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ACCU4:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0000 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| E1 111  | KE2 100            | KE3                                                                                                                                        | 111                                                                                                                                                                               |                                                                                                                                                                                                               |                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| DDE:    | CC1                | CC0                                                                                                                                        |                                                                                                                                                                                   | OVFL                                                                                                                                                                                                          | . 0                                                                                                                                                                                                                        | VFLS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ODER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ERA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | AB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|         |                    | X                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                                               |                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|         | STATUS<br>X        | VKE<br>X                                                                                                                                   |                                                                                                                                                                                   |                                                                                                                                                                                                               |                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ERR.:   | NAU                | PEU                                                                                                                                        |                                                                                                                                                                                   | BAU                                                                                                                                                                                                           | MF                                                                                                                                                                                                                         | PSTP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ZYK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | QVZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|         | ADF                | STP                                                                                                                                        |                                                                                                                                                                                   | BCF                                                                                                                                                                                                           | S                                                                                                                                                                                                                          | 3-6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | LZF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | G-FE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|         | X<br>STUEB         | STUE                                                                                                                                       |                                                                                                                                                                                   | WEC                                                                                                                                                                                                           |                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|         | 02<br>C70A<br>0002 | 02<br>C70A SAC:<br>0002 FB-NO.:<br>REL-SAC:<br>0004 ICMK:<br>0 C464 ACCU2:<br>E1 111 KE2 100<br>DDE: CC1<br>STATUS<br>X<br>NAU<br>ADF<br>X | 02<br>C70A SAC:<br>0002 FB-NO.:<br>REL-SAC:<br>0004 ICMK:<br>0 C464 ACCU2: 0000<br>E1 111 KE2 100 KE3<br>DDE: CC1 CC0<br>X<br>STATUS VKE<br>X X<br>rERR.: NAU PEU<br>ADF STP<br>X | 02<br>C70A SAC: 00F3<br>0002 FB-NO.: 226<br>REL-SAC: 0006<br>0004 ICMK: 0200<br>0 C464 ACCU2: 0000 00FF<br>E1 111 KE2 100 KE3 111<br>DDE: CC1 CC0<br>X<br>STATUS VKE<br>X X<br>TERR.: NAU PEU<br>ADF STP<br>X | 02<br>C70A SAC: 00F3<br>0002 FB-NO.: 226<br>REL-SAC: 0006<br>0004 ICMK: 0200<br>0 C464 ACCU2: 0000 00FF<br>E1 111 KE2 100 KE3 111<br>DDE: CC1 CC0 OVFL<br>X<br>STATUS VKE<br>X X<br>TERR.: NAU PEU BAU<br>ADF STP BCF<br>X | 02           C70A         SAC:         00F3         DB-ADD:           0002         FB-NO.:         226         DB-NO.:           REL-SAC:         0006         DBL-REG           0004         ICMK:         0200         ICRW:           0         C464         ACCU2:         0000         00FF         ACCU3:           E1         111         KE2         100         KE3         111           DDE:         CC1         CC0         OVFL         O           X         X         X         TERR.:         NAU         PEU         BAU         ME           ADF         STP         BCF         S         X         X | 02         C70A       SAC:       00F3       DB-ADD:         0002       FB-NO.:       226       DB-NO.:         REL-SAC:       0006       DBL-REG.:         0004       ICMK:       0200       ICRW:         0       C464       ACCU2:       0000       00FF       ACCU3:       0000         E1       111       KE2       100       KE3       111         DDE:       CC1       CC0       OVFL       OVFLS         X       X       X       X         TERR.:       NAU       PEU       BAU       MPSTP         ADF       STP       BCF       S-6 | 02         C70A       SAC:       00F3       DB-ADD:       0000         0002       FB-NO.:       226       DB-NO.:       0000         0004       ICMK:       0200       DBL-REG.:       0000         00 C464       ACCU2:       0000       00FF       ACCU3:       0000       0000         0 DE:       CC1       CC0       OVFL       OVFLS       ODER         X       X       X       X       X       X         TERR:       NAU       PEU       BAU       MPSTP       ZYK         ADF       X       STP       BCF       S-6       LZF | 02         C70A       SAC:       00F3       DB-ADD:       0000       BA-ADD:         0002       FB-NO.:       226       DB-NO.:       OB-NO.:       OB-NO.:         0004       ICMK:       0200       ICRW:       0000       OC         00       C464       ACCU2:       0000       00FF       ACCU3:       0000       0000       ACCU4:         E1       111       KE2       100       KE3       111       Image: CC1       CC0       OVFL       OVFLS       ODER       ER/         X       X       X       X       Image: CC1       CC0       OVFL       OVFLS       ODER       ER/         Y       X       X       X       X       Image: CC1       X       X       Image: CC1       CC0       OVFL       OVFLS       ODER       ER/         Y       X       X       X       X       Image: CC1       X       X       Image: CC1       X       X       X       Image: CC1       X       X       Image: CC1       X       X       X       Image: CC1       X       X       Image: CC1       X       X       X       Image: CC1       X       X       X       X |

Fig. 5-2 Example of the first screen page "OUTPUT ISTACK": contents

| Explanation of the ISTACK | DEPTH:                                                                                   |
|---------------------------|------------------------------------------------------------------------------------------|
| screen                    | Information level of the ISTACK when more than one error has occurred:                   |
|                           | DEPTH 01 = last cause of stop to occur<br>DEPTH 02 = next to last cause of stop to occur |
|                           | <br>DEPTH13 = (maximum depth)                                                            |

#### Information about the error

The following table contains information about the ISTACK IDs with which the statement in the user program can be found which caused the CPU to change to the STOP mode.

|           | Information about the error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| ISTACK ID | Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| OP-REG    | Operation register:<br>contains machine code (first word) of the instruction processed last in<br>an interrupted program processing level (see list of operations, list of<br>machine codes).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| BLK-STP   | Block stack pointer:<br>contains the number of elements entered in the block stack at the time<br>when the interruption of this processing level occurred                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| LEVEL Z   | Specifies the level of program processing that was interrupted<br>Z:0002: COLD RESTART<br>0004: CYCLE<br>0006: TIME INTERRUPT / 5 sec (OB 18)<br>0008: TIME INTERRUPT / 2 sec (OB 17)<br>000A: TIME INTERRUPT / 2 sec (OB 16)<br>000C: TIME INTERRUPT / 500 ms (OB 15)<br>000E: TIME INTERRUPT / 500 ms (OB 15)<br>001E: TIME INTERRUPT / 100 ms (OB 13)<br>0012: TIME INTERRUPT / 20 ms (OB 12)<br>0014: TIME INTERRUPT / 20 ms (OB 11)<br>0016: TIME INTERRUPT / 10 ms (OB 10)<br>0018: TIMED JOB<br>001A: not used<br>001C: CL CONTROLLER INTERRUPT<br>001E: not used<br>0022: DELAY INTERRUPT<br>0022: not used<br>0024: PROCESS INTERRUPT<br>0026: not used<br>0028: RETENTIVE MANUAL COLD RESTART<br>0024: RETENTIVE MANUAL COLD RESTART<br>0026: transition to stop mode after stop in multiprocessing,<br>stop switch or PG STOP<br>0021: interface error<br>0033: collision of time interrupts<br>0032: CL controller error<br>0034: cycle error<br>0034: cycle error<br>0035: not used<br>0038: operation code error<br>0034: cycle error<br>0034: cycle error<br>0035: not used<br>0038: operation code error<br>0034: cycle error<br>0034: ddressing error<br>0035: intence error<br>0034: mot used<br>0035: operation code error<br>0036: not used<br>0038: operation code error<br>0037: addressing error<br>0036: not used<br>0040: not used<br>0042: not used<br>0044: MANUAL WARM RESTART<br>0045: AUTOMATIC WARM RESTART |  |  |  |  |  |  |
| SAC       | <ul> <li>STEP address counter:</li> <li>contains the absolute address of the last operation of an interrupted program processing level to be processed in the program memory</li> <li>if an error occurs, SAC indicates the operation that caused it.</li> <li>before the first operation of a processing level is executed, SAC is set to "0"</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |

 Table 5-6
 Meaning of the ISTACK IDs concerning the point of error

| Information about the error |                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| ISTACK ID                   | Meaning                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| Table 5-6 cont              | inued:                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| NO.                         | Block type and number of the last block processed                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| REL-SAC                     | Relative STEP address counter:<br>contains the <b>relative</b> address (related to the block start address) of<br>the last operation to be executed in the last <b>block</b> processed (you can<br>display relative addresses on a programmer using the PG mode<br>"input disable"/key-switch or with S5-DOS from stage IV using a<br>function key or you can output the block on a printer) |  |  |  |  |
| ICMK                        | Interrupt condition code group word:<br>ICMK indicates all the causes of interruptions that have occurred up<br>to now and have not yet been completely processed (see "System Data<br>Memory Assignment", Section 8.3.5)                                                                                                                                                                    |  |  |  |  |
| ICRW                        | Interrupt condition code reset word (see "System Data Memory Assignment", Section 8.3.5)                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| DB-ADD                      | Absolute start address (DW 0) of the data block opened last in the program memory (DB-ADD = 0000, if no DB was opened)                                                                                                                                                                                                                                                                       |  |  |  |  |
| DB-NO.                      | Number of the data block opened last                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| DBL-REG                     | Length of the data block opened last                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| BA-ADD                      | Absolute address in the program memory of the operation to be processed next in the block last called                                                                                                                                                                                                                                                                                        |  |  |  |  |
| No.                         | Block type and number of the block last called                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| ACCU 14                     | Contents of the calculation registers at the time of interruption:<br>in the event of certain errors, the system program writes error<br>identifiers into ACCUs 1 and 2 when the interruption occurs.<br>These identifiers define the cause of the interruption more exactly.                                                                                                                |  |  |  |  |
| BRACKETS                    | Number of bracketed levels:<br>"KEx abc"<br>x = 1 to 7 levels<br>a = OR (OR see condition code bits)<br>b = RLO (result of logic operation, see condition code bits)<br>c = 1: A(<br>c = 0: O(                                                                                                                                                                                               |  |  |  |  |

#### **Condition code**

see Section 3.5

#### **Cause of interrupt**

The following abbreviations (ISTACK IDs) represent the most important causes of interruptions.

The only causes of interruptions that are marked are those that have occurred in the currently displayed program processing level (see LEVEL). The causes of interruptions represent the contents of the interrupt condition code group word (ICMK, 16 bits, see Section 8.3.5). Some of the entries here are identical to those in the control bits.

| Cause of interrupt |                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| ISTACK ID          | Meaning (called error OB)                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| NAU                | Power supply failure in central controller                                                                                                                                                                                                                                                                                         |  |  |  |  |
| PEU                | Peripherals not ready = power failure in expansion unit                                                                                                                                                                                                                                                                            |  |  |  |  |
| BAU                | Battery not ready = back-up battery failure (central controller)                                                                                                                                                                                                                                                                   |  |  |  |  |
| MPSTP              | Multiprocessor STOP:<br>- reset switch on the coordinator in STOP position or<br>- STOP at a different CPU in multiprocessor operation                                                                                                                                                                                             |  |  |  |  |
| ZYK                | Cycle monitoring time exceeded                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| QVZ                | Timeout during data exchange with I/O peripherals                                                                                                                                                                                                                                                                                  |  |  |  |  |
| ADF                | Addressing error for inputs and outputs with process I/O image                                                                                                                                                                                                                                                                     |  |  |  |  |
| STP                | <ul> <li>stop mode caused by setting the stop switch to STOP</li> <li>stop mode caused by command from PG</li> <li>stop mode after processing the STEP 5 operation "STP"</li> <li>stop mode after stop command from system program, if error organization block is not programmed</li> </ul>                                       |  |  |  |  |
| BCF                | <ul> <li>Operation code error: error detected during the operation decoding</li> <li>substitution error: processed STEP 5 operation cannot be substituted</li> <li>operation code error: processed STEP 5 operation is incorrect</li> <li>parameter error: parameter of the processed STEP 5 operation is not permitted</li> </ul> |  |  |  |  |
| S-6                | Interface error                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| LZF                | Runtime error: error detected during the execution of an operation: - called block not loaded - load/transfer error with data blocks - other runtime errors                                                                                                                                                                        |  |  |  |  |
| REG-FE             | Error processing the controller structure R64 in the CYCLE                                                                                                                                                                                                                                                                         |  |  |  |  |
| STUEB              | Block stack overflow:<br>nesting depth too great; required measure: COLD RESTART)                                                                                                                                                                                                                                                  |  |  |  |  |

Table 5-7 ISTACK IDs cause of interrupt

٦

|                      | Cause of interrupt                                                                                                                                      |  |  |  |  |  |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| ISTACK ID            | Meaning (called error OB)                                                                                                                               |  |  |  |  |  |
| Table 5-7 continued: |                                                                                                                                                         |  |  |  |  |  |
| STUEU                | Interrupt stack overflow:<br>nesting depth too great; required measure: COLD RESTART)                                                                   |  |  |  |  |  |
| WECK                 | Collision of time interrupts:<br>before or during the processing of a time interrupt OB, an attempt<br>was made to call the same OB a second time       |  |  |  |  |  |
| DOPP                 | Double call error<br>a still active error program processing level (ADF, BCF, LZF, QVZ,<br>REG, ZYK) is activated a second time (COLD RESTART required) |  |  |  |  |  |

#### 5.3.3 Example of Error Diagnosis using the ISTACK

#### Example 1:

Fig. 5-3 illustrates the structure of the ISTACK in conjunction with the interruptions that have occurred.

- The CYCLE program processing level (OB 1) is aborted owing to the occurrence of an interrupt.
- Following this, the program processing level TIME INTERRUPT is activated and OB 13 is processed.
- The TIME INTERRUPT level is exited owing to the occurrence of a process interrupt, the PROCESS INTERRUPT level is activated and OB 2 is processed.
- An incorrect addressing operation activates level ADF where OB 25 is processed. In the error handling program, the user has programmed a stop operation (STP); the CPU aborts program execution.



Fig. 5-3 Example 1 of evaluating the ISTACK

Before the CPU finally goes into the stop mode, a total of four different program processing levels have been interrupted. If you display the ISTACK, you obtain a four level ISTACK, first the ISTACK with depth 01, in which the identifier of the program processing level last interrupted (=ADF) is marked. You can now "page down" through the ISTACK until you reach the ISTACK with depth 04, that represents the CYCLE program processing level, that was interrupted first.



|                                                                       | TERRUPT S                                 | TACK                   |                                       |                                 |            |                    |            |
|-----------------------------------------------------------------------|-------------------------------------------|------------------------|---------------------------------------|---------------------------------|------------|--------------------|------------|
| DEP                                                                   | ΓH 01                                     |                        |                                       |                                 |            |                    |            |
| OP-F<br>BLK-                                                          | STP: 000                                  | D3 PB-NO.:<br>REL-SAC: | 1007<br>5<br>0007                     | DB-ADD:<br>DB-NO.:<br>DBL-REG.: | 16         | BA-ADD:<br>OB-NO.: | 0106<br>25 |
| ACCI                                                                  |                                           | 3C ICMK:               | 0300                                  | ICRW:                           | 0000       |                    |            |
| CON                                                                   | Dition Code:                              |                        |                                       |                                 |            |                    |            |
| CAUS                                                                  | SE OF INTERR.                             |                        |                                       |                                 |            |                    |            |
|                                                                       |                                           | •                      |                                       |                                 |            |                    |            |
|                                                                       |                                           |                        | STP<br>X                              |                                 |            |                    |            |
|                                                                       |                                           |                        | X                                     |                                 |            |                    |            |
|                                                                       | e 2 of evalua                             | ating the ISTAC        | X                                     | ACK level                       |            |                    |            |
|                                                                       |                                           | ating the ISTAC        | X                                     | ACK level                       |            |                    |            |
| INTEF<br>DEPTH<br>OP-REG:<br>BLK-STP:                                 | RRUPT STAC<br>02<br>A lx.y<br>0001        | ating the ISTAC        | X<br>2K: 1st IST<br>001A<br>1<br>000A | DB-ADD:<br>DB-NO.:<br>DBL-REG.: | 16         | BA-ADD:            | 00000      |
| INTEF<br>DEPTH<br>OP-REG:                                             | RRUPT STAC<br>02<br>A Ix.y                | ating the ISTAC        | <u>x</u><br>:K: 1st IST<br>001A<br>1  | DB-ADD:<br>DB-NO.:              | 16<br>0000 | BA-ADD:            | 0000       |
| INTEF<br>DEPTH<br>OP-REG:<br>BLK-STP:<br>LEVEL:<br>ACCU1:             | RRUPT STAC<br>02<br>A lx.y<br>0001        | ating the ISTAC        | X<br>2K: 1st IST<br>001A<br>1<br>000A | DB-ADD:<br>DB-NO.:<br>DBL-REG.: |            | BA-ADD:            | 0000       |
| INTEF<br>DEPTH<br>OP-REG:<br>BLK-STP:<br>LEVEL:<br>ACCU1:<br>CONDITIC | RUPT STAC<br>02<br>A lx.y<br>0001<br>0004 | ating the ISTAC        | X<br>2K: 1st IST<br>001A<br>1<br>000A | DB-ADD:<br>DB-NO.:<br>DBL-REG.: |            | BA-ADD:            | 00000      |

# 5.4 Error Handling using Organization Blocks

**Introduction** When the system program detects an error, it calls the appropriate organization block to handle it. You can determine how the CPU reacts by programming the relevant organization block. Depending on how you program the organization block, you can achieve the following reactions:

- normal program processing is continued
- the CPU goes to the STOP mode
  - and/or
- a special error handling program is run through.

Errors and the OBs called

| Cause of error                                                                                 | Organization<br>block called | Reaction of<br>CPU <sup>1)</sup> |
|------------------------------------------------------------------------------------------------|------------------------------|----------------------------------|
| Call of a block that is not loaded (LZF)                                                       | OB 19                        | STOP                             |
| Timeout in the user program during access to I/O modules (QVZ)                                 | OB 23                        | none                             |
| Timeout during update of the process image                                                     | OB 24                        | none                             |
| Addressing error (ADF)                                                                         | OB 25                        | STOP                             |
| Cycle time exceeded (ZYK)                                                                      | OB 26                        | STOP                             |
| Substitution error (SUF)                                                                       | OB 27                        | STOP                             |
| Mode selector set to STOP, PG function PC STOP,<br>STOP from S5 bus (multiprocessor operation) | OB 28                        | STOP                             |
| Operation code error (BCF)                                                                     | OB 29                        | STOP                             |
| Parameter error (BCF)                                                                          | OB 30                        | STOP                             |
| Other runtime errors (LZF)                                                                     | OB 31                        | STOP                             |
| Load/transfer error with data blocks (TRAF)                                                    | OB 32                        | STOP                             |
| Collision of time interrupts (WECK-FE)                                                         | OB 33                        | STOP                             |
| Error processing the controller structure R64 (REG-FE)                                         | OB 34                        | STOP                             |
| Communication error on the 2nd serial interface (FE-3)                                         | OB 35                        | none                             |

 Table 5-8
 The organization blocks called in case of errors

Organization blocks exist for the following causes of errors:

<sup>1)</sup> if OB is not programmed, with DX 0 defaults

#### Response of organization block not loaded

If the organization block is **not loaded** the response depends on the particular error:

#### • No interruption of cyclic program execution

If a timeout occurs and OB 23, OB 24 or OB 35 is not loaded, cyclic program execution is **not** interrupted. The CPU does not react.

If you want the CPU to go into the STOP mode when a timeout occurs, the organization block must contain a stop statement and be completed with the block end statement BE or DX 0 must have suitable parameters assigned.

Program for STOP:

```
:
:
:STP
:BE
```

#### • STOP mode

When any other error occurs, the CPU goes into the STOP mode immediately if you did not program the appropriate organization blocks.

If, in exceptional circumstances, (e.g. during system installation) you do not want one of these errors to interrupt cyclic program execution, a block end statement in the appropriate organization block is sufficient or assign suitable parameters to DX 0.

Program for uninterrupted operation:

```
:
:
:BE
```

#### Note

Organization block **OB 28** is an exception: here, the CPU always goes to the STOP mode regardless of whether you have loaded OB 28 or not.

If you do not want to program the corresponding organization block, you can prevent the transition to the STOP mode by assigning appropriate parameters to **data block DX 0**.

#### • Interruptions during processing of error organization blocks

After the system program calls the appropriate organization block, the user program in that block is processed.

If another error occurs while the first organization block is being processed, the program is interrupted at the next operation boundary and the appropriate second organization block is called, just as in cyclic program execution.

The organization blocks are processed in the order in which they are called. The nesting depth for error organization blocks depends on the following:

#### - The type of error

No organization blocks belonging to the same program processing level can be nested within each other. (See Chapter 6 for the assignment of error OBs to the program processing level).

When processing OB 27 (program processing level BCF) it is, for example, possible to nest OB 32 (program processing level LZF), however, OB 29 or OB 30 (also BCF) cannot be nested in OB 27.

If two blocks from the same program processing level are called, the CPU changes immediately to the STOP mode.

# The number of program processing levels currently active at any one time

For each activated program processing level, the system program requires extra memory space to set up the ISTACK when an interrupt occurs. If there is not enough memory left, an ISTACK overflow results.

If there is an ISTACK overflow, the CPU changes immediately to the STOP mode.

#### - The number of blocks called at any one time

If there is a BSTACK overflow, the CPU changes immediately to the STOP mode.

### 5.5 Errors during RESTART

*Introduction* During initialization and during a restart, causes of interruptions and errors can lead to the restart program being aborted and put the CPU into the STOP mode. Interruptions occurring during the restart program (organization blocks OB 20, 21 and 22) are handled just as in the CYCLE.

#### **Exception:**

if a STOP occurs during the restart, no organization block OB 28 is called.

Causes of interrupt and i causes of error

There is **no way of responding** via a user interface (error OB) to the causes of interrupt and causes of error listed in the table below.

| Control bit or ID<br>in ISTACK | Explanation                                                                                          |
|--------------------------------|------------------------------------------------------------------------------------------------------|
| STP                            | Stop command from system program (at FE-STP) or in the user program                                  |
| BAU                            | Failure of the back-up battery on the central controller                                             |
| NAU                            | Failure of the power supply in the central controller                                                |
| PEU                            | Failure of the power supply in an expansion unit                                                     |
| STUEU                          | Stack overflow in interrupt stack (ISTACK)                                                           |
| STEUB                          | Stack overflow in the block stack (BSTACK)                                                           |
| DOPP-FE                        | Double call of an error program processing level                                                     |
| RAM-FE                         | Error during initialization: the contents of the operation system<br>RAM or the DB RAM are incorrect |
| MOD-FE                         | Error during initialization: the contents of the memory card are not correct                         |
| DB0-FE <sup>1)</sup>           | Error setting up the block address list (DB 0)                                                       |
| DB1-FE <sup>1)</sup>           | Error evaluating DB 1 to set up the address list for updating the process image                      |
| DB2-FE <sup>1)</sup>           | Error evaluating DB 2 of the controller structure R64                                                |
| DX0-FE <sup>1)</sup>           | Error evaluating data block DX 0<br>or<br>Error evaluating data block DX 2                           |

Table 5-9 Causes of error and causes of interrupt in RESTART

1) for further explanations: see the following pages

#### 5.5.1 DB0-FE (DB 0 Errors)

*Introduction* Errors when setting up the block address list (data block DB 0).

DB 0 is set up by the system program following OVERALL RESET. If a DB 0 error occurs, you will find error identifiers in the system data words RS 3 and RS 4 that define the error in greater detail.

*Error identifiers* The identifiers for DB 0 errors are listed in the table below.

| Error identifier<br>RS 3 RS 4 |       | Explanation                                                                                                            |
|-------------------------------|-------|------------------------------------------------------------------------------------------------------------------------|
| 8001H                         | ууууН | Wrong block length<br>yyyy = address of the block with the wrong length                                                |
| 8002H                         | ууууН | Calculated end address of the block in the memory is wrong<br>yyyy = block address                                     |
| 8003H                         | ууууН | Invalid block identifier<br>yyyy = address of the block with the incorrect identifier                                  |
| 8004H                         | ууууН | Organization block number too high (permitted: OB 1 to OB 39)<br>yyyy = address of the block with the incorrect number |
| 8005H                         | ууууН | Data block number 0 (permitted: DB 1 to DB 255)<br>yyyy = address of the block with the incorrect number               |

Table 5-10 IDs for DB 0 errors

#### 5.5.2 DB1-FE (DB 1 Errors)

Introduction

Error evaluating DB 1 to set up the address list for updating the process image.

• DB 1 does not exist in multiprocessor operation,

or

• incorrect DB 1 address list during COLD RESTART.

#### Note

In multiprocessor operation, the system checks whether DB 1 exists in **all** types of restart. DB 1 parameters are, however, **only** evaluated during a COLD RESTART.

#### Error identifiers

The identifiers for DB 1 errors are listed in the table below.

| Error ide<br>RS 3 | entifier<br>RS 4 | Explanation                                                                                                                                                                                                                                                                           |  |  |
|-------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0410H             | ууууН            | <ul> <li>Illegal identifier:</li> <li>header identifier missing or incorrect (correct KC MASK01)</li> <li>identifier illegal (permitted KH DE00, DA00, CE00, CA00, BB00)</li> <li>end identifier missing or incorrect (correct KH EEEE)</li> <li>yyyy = illegal identifier</li> </ul> |  |  |
| 0411H             | ууууН            | "Digital inputs", number of addresses illegal (permitted 0128)<br>yyyy = illegal number of addresses                                                                                                                                                                                  |  |  |
| 0412H             | ууууН            | "Digital outputs", number of addresses illegal<br>(permitted 0128)<br>yyyy = illegal number of addresses                                                                                                                                                                              |  |  |
| 0413H             | ууууН            | "IPC flag inputs", number of addresses illegal<br>(permitted 0256)<br>yyyy = illegal number of addresses                                                                                                                                                                              |  |  |
| 0414H             | ууууН            | "IPC flag outputs", number of addresses illegal<br>(permitted 0256)<br>yyyy = illegal number of addresses                                                                                                                                                                             |  |  |
| 0415H             | ууууН            | Illegal number of timers (permitted: 256)<br>yyyy = illegal number of timers                                                                                                                                                                                                          |  |  |
| 0419H             | ууууН            | Timeout with digital inputs<br>yyyy = address of the unacknowledged input byte                                                                                                                                                                                                        |  |  |
| 041АНууууН        |                  | Timeout with digital outputs<br>yyyy = address of the unacknowledged output flag byte                                                                                                                                                                                                 |  |  |
| 041BHyy           | уууН             | Timeout with IPC flag input<br>yyyy = address of the unacknowledged IPC flag byte                                                                                                                                                                                                     |  |  |
| 041СНууууН        |                  | Timeout with IPC flag output<br>yyyy = address of the unacknowledged IPC flag byte                                                                                                                                                                                                    |  |  |

Table 5-11IDs for DB 1 errors

#### 5.5.3 DB2-FE (DB 2 Errors)

*Introduction* Errors in the evaluation of the parameter assignment data block DB 2 for controller structure R64 (controller initialization).

If a DB 2 error occurs, system data words RS 3 and RS 4 contain error identifiers that define the error in greater detail.

*Error identifiers* The identifiers for DB 2 errors are listed in the table below.

| Error identifier<br>RS 3 RS 4 |       | Explanation                                                                                                  |
|-------------------------------|-------|--------------------------------------------------------------------------------------------------------------|
| 0421H                         | DByyH | Data block not loaded<br>yyyy = number of the data block that is not loaded                                  |
| 0422H                         | FByyH | Function block not loaded<br>yyyy = number of the function block that is not loaded                          |
| 0423H                         | FByyH | Function block not recognized<br>yyyy = number of the unrecognized function block                            |
| 0424H                         | FByyH | Function block loaded with wrong PG software<br>yyyy =number of the function block                           |
| 0425H                         | DByyH | Wrong controller data block length<br>yyyy = number of the data block                                        |
| 0426H                         |       | There is not enough memory space in the DB-RAM to shift the controller DBs from the user EPROM to the DB-RAM |

Table 5-12IDs for DB 2 errors

#### 5.5.4 DX0-FE (DX 0 or DX 2 Errors)

Note

DX 0 and DX 2 errors have a common control bit (DX0-FE) in the control bit screen form.

*Errors evaluating* In the event of a DX 0 error you will find error identifiers in the system data words RS 3 and RS 4 that define the error in more detail.

 

 Error identifier RS 3
 Explanation

 0431H
 yyyyH

 Illegal identifier:

 header identifier missing or incorrect (correct KC MASKX0)

 field identifier illegal

 end identifier missing or incorrect (correct KH EEEE)

| Table 5-13 | IDs for DX 2 errors |
|------------|---------------------|
|------------|---------------------|

|       |       | <ul> <li>field identifier illegal</li> <li>end identifier missing or incorrect (correct KH EEEE)</li> <li>yyyy = illegal identifier</li> </ul> |
|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 0432H | ууууН | Illegal parameter<br>yyyy = illegal parameter                                                                                                  |
| 0433H | ууууН | Illegal number of timers (permitted: 0256)<br>yyyy = incorrect number of timers                                                                |
| 0434H | ууууН | Illegal cycle time monitoring (permitted: 1 ms to 13000 ms)<br>yyyy = incorrect time value                                                     |

Errors evaluating data block DX 2

Parameter assignment for the second serial interface.

Data block DX 2 is set up by the system program after a COLD RESTART. In the event of a DX 2 error, you will find error identifiers in the system data words RS 3 and RS 4 that define the error in more detail.

Table 5-14 IDs for DX 0 errors

| Error identifier<br>RS 3 RS 4 |       | Explanation                                                                                        |  |
|-------------------------------|-------|----------------------------------------------------------------------------------------------------|--|
| 0451H                         | _     | DX 2 length (without block header) < 4 words is not permitted                                      |  |
| 0452H                         | ууууН | DX 2 length (without block header) is too short for link type<br>yyyy = length DX 2                |  |
| 0453H                         | ууууН | Link type illegal<br>yyyy = link type                                                              |  |
| 0454H                         | xx00H | Data identifier for stat. parameter set illegal<br>(not equal to 44H, 58H)<br>xx = data identifier |  |
| 0455H                         | ххууН | Block for static parameter set illegal<br>xx = identifier / yy = DB number                         |  |
| 0456H                         | ххууН | Static parameter set does not exist<br>xx = identifier / yy = DB number                            |  |

| Error identifier<br>RS 3 RS 4 |            | Explanation                                                                                          |
|-------------------------------|------------|------------------------------------------------------------------------------------------------------|
| Table 5-14                    | continued: |                                                                                                      |
| 0457H                         | ууууН      | Static parameter set too short<br>yyyy = number of the non-existent DW                               |
| 0458H                         | xx00H      | Data identifier for dynamic parameter invalid (44H, 58H, 00H)<br>xxH = data identifier               |
| 0459H                         | ууууН      | Block for dynamic parameter set illegal<br>xx = identifier / yy = DB number                          |
| 045AH                         | xx00H      | Data identifier for send/job mailbox invalid (not equal to 44H,<br>58H, 00H)<br>xx = data identifier |
| 045BH                         | ххууН      | Block for send/job mailbox illegal<br>xx = identifier / yy = DB number                               |
| 045CH                         | xx00H      | Data identifier for receive mailbox invalid (not equal to 44H, 58H, 00H)<br>xx = data identifier     |
| 045DH                         | ххууН      | Block for receive mailbox illegal<br>xx = identifier / yy = DB number                                |
| 045EH                         | xx00H      | Data identifier for coordination bytes invalid (not equal to 44H, 58H, 4DH)<br>xx = data identifier  |
| 045FH                         | ххууН      | Block for coordination bytes illegal<br>xx = identifier / yy = DB number                             |
| 0460H                         | ххууН      | Block for coordination bytes does not exist<br>xx = identifier / yy = DB number                      |
| 0461H                         | ууууН      | DW for coordination bytes does not exist<br>yyyyH = number of the non-existent DW                    |

### 5.5.5 MOD-FE (Memory Card Errors)

*Introduction* When evaluating a memory card and copying blocks from the memory card, a number of checks are run. If an error is found, the control bit MOD-FE is entered in the control bits screen form and an additional error identifier entered in the system data word RS 3.

**Error identifiers** in system data word RS 3 irrelevant). If the above checks lead to an error, system data word RS 3 contains error identifiers which define the errors in greater detail (the contents of RS 4 are irrelevant).

| Error io<br>RS 3 | dentifier<br>RS 4 | Explanation                                 |
|------------------|-------------------|---------------------------------------------|
| 620EH            | _                 | Memory card: wrong access time class        |
| 6210H            | _                 | Memory card: wrong data width               |
| 6211H            | _                 | Memory card: wrong application (not STEP 5) |
| 6212H            | _                 | Memory card: wrong MLFB number              |
| 6213H            | _                 | Memory card: wrong class (not Flash)        |
| 6214H            | _                 | Block illegal                               |
| 6215H            | _                 | Block number illegal                        |
| 6216H            | _                 | Block type illegal                          |
| 6217H            | _                 | Block length illegal                        |
| 6218H            | _                 | Too many blocks                             |
| 6219H            | _                 | Too many blocks of one type                 |
| 621AH            |                   | No space in user memory                     |
| 621BH            |                   | Memory card content inconsistent            |

 Table 5-15
 IDs for memory card errors and errors when copying blocks

# 5.6 Errors in RUN and in RESTART

| Introduction                           | In the RUN mode, cyclic, time-driven or interrupt-driven program execution or<br>controller processing can be interrupted at operation boundaries by the<br>occurrence of certain errors or faults, e.g. power failure in the central controller<br>or block stack overflow.                               |
|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                        | Interruptions during initialization and in the RESTART mode cause the restart<br>program to be aborted and the CPU goes into the STOP mode or calls the<br>organization block intended for this error. Interruptions occurring during the<br>start-up program are handled in the same way as in the CYCLE. |
|                                        | A distinction is made between problems that cause the CPU to go directly to the STOP mode (e.g. STUEU) and problems that cause the system program to call certain organization blocks that you can program instead of the CPU going directly to the STOP mode (e.g. ADF).                                  |
|                                        | There is no way of responding via a user interface (error OB) to the causes of interrupt and causes of error listed in the table below.                                                                                                                                                                    |
| Errors which<br>lead direct to<br>STOP | If these errors occur, an ISTACK is created in which the interrupt is displayed.                                                                                                                                                                                                                           |

| Control bit or ID<br>in ISTACK | Explanation                                                                                                                         |  |  |  |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| STP                            | STOP caused by the system program (machine error), when an error OB is not loaded, or there is a stop operation in the user program |  |  |  |
| BAU                            | Failure of the back-up battery in the central controller                                                                            |  |  |  |
| NAU                            | Failure of the power supply to the central controller                                                                               |  |  |  |
| PEU                            | Failure of the power supply to one or more expansion units                                                                          |  |  |  |
| STUEU                          | Stack overflow in the interrupt stack (ISTACK), nesting depth too great                                                             |  |  |  |
| STUEB                          | Stack overflow in the block stack (BSTACK), nesting depth too great                                                                 |  |  |  |
| DOPP-FE                        | Double call of an error program processing level                                                                                    |  |  |  |

 Table 5-16
 Causes of error and causes of interrupt in RESTART and RUN, which lead direct to STOP

When these errors occur, an error OB will be called.

#### Errors which cause an error OB to be called

| Control bit or<br>ID in<br>ISTACK | Explanation                                                                                                    | OB no.                  |
|-----------------------------------|----------------------------------------------------------------------------------------------------------------|-------------------------|
| BCF                               | Operation code error:<br>- substitution error<br>- operation code error<br>- parameter error                   | OB 27<br>OB 29<br>OB 30 |
| LZF                               | Runtime error:<br>- call for a block that is not loaded<br>- transfer error with DBs<br>- other runtime errors | OB 19<br>OB 32<br>OB 31 |
| ADF                               | Addressing error:<br>- when accessing the process image                                                        | OB 25                   |
| QVZ                               | Timeout:<br>- in the user program when accessing I/O modules<br>- when updating the process image              | OB 23<br>OB 24          |
| ZYK                               | Cycle error<br>- the cycle monitoring time was exceeded                                                        | OB 26                   |
| WECK-FE                           | Collision of two time interrupts:<br>- error processing a time interrupt                                       | OB 33                   |
| REG-FE                            | Controller error:<br>- error processing a controller interrupt                                                 | OB 34                   |
| ABBR                              | Abort:<br>- (see 'ABBR' in this Section)                                                                       | OB 28                   |
| S-6                               | Communication error:<br>- during data exchange via the second serial interface                                 | OB 35                   |

Table 5-17Causes of error and causes of interrupt in RESTART and RUN, which<br/>cause an error OB to be called

The following sections describe each of these causes of errors in more detail.

### 5.6.1 BCF (Operation Code Errors)

| Introduction                  | An operation code error occurs when the CPU either cannot interpret or cannot execute a STEP 5 operation in the user program. All permissible operation codes are listed in the list of operations.                                                                                    |  |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                               | The operation that caused the operation code error is not executed. If the relevant BCF organization block is loaded, this is called, processed and the user program is then continued starting with the next operation. If the BCF-OB is not loaded, the CPU goes into the STOP mode. |  |
|                               | The following operation code errors can occur. In each case, the error OB named is called:                                                                                                                                                                                             |  |
| Substitution error<br>(OB 27) | If an operation with a formal operand is to be executed in a function block, the CPU replaces this formal operand with the actual operand contained in the function block call.                                                                                                        |  |
|                               | The CPU recognizes an illegal substitution. The system program interrupts the processing of the user program and calls organization block <b>OB 27</b> , if it is loaded.                                                                                                              |  |
|                               | ACCU 1 contains additional information that defines the error in more detail.                                                                                                                                                                                                          |  |

| Error identifier<br>ACCU-1-LACCU-2-L |   | Explanation                                                                    |
|--------------------------------------|---|--------------------------------------------------------------------------------|
| 1801H                                | — | Substitution error with the DO RS operation                                    |
| 1802H                                |   | Substitution error with the DO DW, DO FW operations                            |
| 1803H                                |   | Substitution error with the DO=, DI operations                                 |
| 1804H                                |   | Substitution error with the L=, T= operations                                  |
| 1805H                                | _ | Substitution error with the A=, AN=, O=, ON=, ==, S=<br>and RB= operations     |
| 1806H                                | — | Substitution error with the RD=, LD=, FR=, SFD=, SD=, SSU; and SEC= operations |

Table 5-18BCF substitution error

#### Operation code error (OB 29)

An operation code error is detected by the CPU during the execution of a STEP 5 program when an operation is programmed that does not belong to the STEP 5 set of operations for the CPU 928B (e.g. RU and SU operations can be programmed at the programmer but cannot be interpreted by the CPUs 928B, 928, 922 (R processor) and 921 (S processor) in the S5 135U).

If the CPU detects an illegal operation code, the execution of the user program is interrupted and organization block **OB 29** is called, if it is loaded

When OB 29 is called, ACCU 1 contains additional information that defines the error in greater detail.

| Error identifier<br>ACCU-1-LACCU-2-L |   | Explanation                                                                                                   |  |
|--------------------------------------|---|---------------------------------------------------------------------------------------------------------------|--|
| 1811H                                | _ | Operation with illegal OP code                                                                                |  |
| 1812H                                | — | Illegal OP code for an operation in which the high byte of<br>the first operation word contains the value 68H |  |
| 1813H                                | _ | Illegal OP code for an operation in which the high byte of<br>the first operation word contains the value 78H |  |
| 1814H                                | _ | Illegal OP code for an operation in which the high byte of<br>the first operation word contains the value 70H |  |
| 1815H                                | _ | Illegal OP code for an operation in which the high byte of<br>the first operation word contains the value 60H |  |

Table 5-19BCF operation code error



#### Caution

An operation code error should **not** be acknowledged: the CPU does not recognize whether the incorrect operation is a single word or multiword operation. Once the CPU has processed OB 29, it attempts to continue the program at the next operation word. If this is the second word of a multiword operation, it either detects a further operation code error or executes this word as a valid operation, which can cause a variety of **program errors**.

Parameter error (OB 30)

An illegal parameter occurs when an operation is programmed with a parameter that is not permitted for the particular CPU (e.g. calling a reserved data block), or when a non-existent special function is called.

If the CPU detects an illegal parameter, the system program interrupts the execution of the user program and calls organization block **OB 30**, if it is loaded.

When OB 30 is called, ACCU 1 contains additional information that defines the error in greater detail.

| Error identifier<br>ACCU-1-LACCU-2-L | Explanation                                                                             |  |  |
|--------------------------------------|-----------------------------------------------------------------------------------------|--|--|
| 1821H —                              | C DB 0, 1, 2                                                                            |  |  |
| 182BH —                              | JU(C) OB 0                                                                              |  |  |
| 182CH —                              | JU(C) OB > 39: special function does not exist                                          |  |  |
| 182DH —                              | CX DX 0, CX DX 1, CX DX 2                                                               |  |  |
| 182EH —                              | L FW/T FW/L PW/T PW/L OW/T OW/L DD/T<br>DD/DO FW 255                                    |  |  |
| 182FH —                              | L IW/T IW/L QW/T QW 127                                                                 |  |  |
| 1830H —                              | L FD/T FD 253, 254, 255                                                                 |  |  |
| 1831H —                              | L ID/T ID/L QD/T QD 125,<br>126, 127                                                    |  |  |
| 1832H —                              | RLD/RRD/SSD/SLD 33-255                                                                  |  |  |
| 1833H —                              | SLW/SRW/LIR/TIR 16-255                                                                  |  |  |
| 1834H —                              | SED/SEE 32-255                                                                          |  |  |
| 1835H —                              | A=/AN=/O=/ON=/S=/RB=/==/<br>RD=/FR=/SP=/SD=/SEC=/SSU=/<br>SFD=/L=/LD=/LW=/T= 0, 127-255 |  |  |
| 1836Н —                              | DO=/LWD= 0, 126-255                                                                     |  |  |
| 1837H —                              | A S/O S/S S/=S/AN S/ON S/R S<br>byte number > 1023                                      |  |  |
| 1838H —                              | A S/OS/S S/=S/AN S/ON S/RS<br>bit number > 7                                            |  |  |
| 1839Н —                              | L SY/T SY parameter>1023                                                                |  |  |
| 183AH —                              | L SW/T SW parameter > 1022                                                              |  |  |
| 183BH —                              | L SD/T SD parameter >1020                                                               |  |  |
| 183CH —                              | G DB/GX DX parameter 0, 1 or 2 (DB or DX 0, 1, 2 cannot be generated)                   |  |  |

Table 5-20BCF parameter error

## 5.6.2 LZF (Runtime Errors)

Introduction A runtime error occurs when the CPU detects an error during the execution of a STEP 5 operation. The operation that causes the runtime error is **not** executed. If there is an LZF organization block, this is called. The interrupted user program is then continued from the next operation after the operation that caused the error. If no LZF-OB is loaded, the CPU goes to the STOP mode. The following runtime errors are possible. In each case, the named error OB is called: LZF - calling a If a block is called or opened in the user program and this block does not exist, block that is not the system program automatically detects an error. This applies to all block types loaded (OB 19) and is true for conditional and unconditional calls. If the system program detects the call or opening of a block that is not loaded, it calls organization block OB 19, if it is loaded. In OB 19, you can specify how the CPU should proceed. If you have programmed OB 19, it is called and processed following which the interrupted STEP 5 program is continued at the next operation unless OB 19 contains a stop operation. If, on the other hand, you have not programmed OB 19, the CPU goes into the STOP mode when a block that is not loaded is called or opened.

When OB 19 is called, ACCU 1 contains additional information that defines the error in greater detail.

| Error identifier<br>ACCU-1-L ACCU-2-L |   | Explanation                                       |  |
|---------------------------------------|---|---------------------------------------------------|--|
| 1A01H                                 | _ | Data block not loaded for C DB                    |  |
| 1A02H                                 |   | Data block not loaded for CX DX                   |  |
| 1A03H                                 | _ | Block not loaded for JU(C) FB, OB 1 to 39, PB, SB |  |
| 1A04H                                 |   | Block not loaded for DOU(C) FX                    |  |
| 1A05H                                 | _ | Data block not loaded for OB 254 or 255           |  |
| 1A06H                                 | _ | Data block not loaded for OB 182                  |  |
| 1A07H                                 | _ | Data block not loaded for OB150/OB151/OB 153      |  |

Table 5-21 LZF - calling a block that is not loaded

#### Note

If you attempt to open a data block that is not loaded, the DBA register (see Chapter 9) is affected. In this case a loaded data block must be opened again before accessing DB/DX data.

## Load/transfer error (OB 32)

When you transfer data to data blocks (DB, DX), the CPU compares the length of the DB that has been opened with the operand in the transfer operation. If the specified parameter exceeds the actual data block length, the CPU does not execute the transfer statement to prevent data in the memory from being overwritten by mistake.

The system program also detects a load/transfer error if a single bit of a non-existent data word is to be set/reset or scanned.

The system program also detects a load/transfer error if you attempt to access a data word before you call a data block (using C DBn or CX DXn).

When the system program detects a load/transfer error, it calls organization block **OB 32**, if it is loaded. The operation that caused the transfer error is not executed. When OB 32 is called, ACCU 1 contains additional information that defines the error in greater detail.

| Error identifier<br>ACCU-1-L ACCU-2-L |   | Explanation                                                 |  |
|---------------------------------------|---|-------------------------------------------------------------|--|
| 1A11H                                 | — | A/AN D, O/ON D, S/R D, =D access to a non-defined data word |  |
| 1A12H                                 |   | Transfer error: T DR to a non-defined data word             |  |
| 1A13H                                 |   | Transfer error: T DL to a non-defined data word             |  |
| 1A14H                                 |   | Transfer error: T DW to a non-defined data word             |  |
| 1A15H                                 |   | Transfer error: T DD to a non-defined data word             |  |
| 1A16H                                 |   | Load error: L DR to a non-defined data word                 |  |
| 1A17H                                 |   | Load error: L DL to a non-defined data word                 |  |
| 1A18H                                 | _ | Load error: L DW to a non-defined data word                 |  |
| 1A19H                                 |   | Load error: L DD to a non-defined data word                 |  |
| 1A1AH                                 |   | BDW access to a non-defined data word                       |  |

Table 5-22 LZF-load/transfer error (TRAF)

# Other runtime<br/>errors (OB 31)These include all runtime errors that cannot be grouped with the previous types<br/>of runtime error (transfer errors or calling a block that is not loaded).

If the system program detects one of these runtime errors, it calls organization block **OB 31**. The operation (or special function) that caused the error is not processed any further. If OB 31 is not loaded, the CPU goes into the STOP mode. If you want program execution to continue when one of the errors listed below occurs, simply write the block end statement BE in OB 31.

When OB 31 is called, ACCU 1 and ACCU 2 contain additional information that defines the error in greater detail.

#### Error identifiers of different operations, OB 254/255 and OB 250

| Error ide<br>ACCU-1-L | ntifier<br>ACCU-2-L | Explanation                                                                            |  |  |
|-----------------------|---------------------|----------------------------------------------------------------------------------------|--|--|
| 1A21H                 |                     | G DB, GX DX: data block already exists                                                 |  |  |
| 1A22H                 | —                   | G DB, GX DX: illegal number of data words<br>(< 1 or > 4091)                           |  |  |
| 1A23H                 | _                   | G DB, GX DX: not enough space in the RAM                                               |  |  |
| 1A25H                 | —                   | DI: illegal parameter in ACCU 1<br>(< 1 or > 125)                                      |  |  |
| 1A29H                 | _                   | Bracket stack under or overflow following A(, O(, )                                    |  |  |
| 1A2AH                 | —                   | C DB, CX DX, block length in data block header too<br>short (length < 5 words)         |  |  |
| 1A2BH                 | _                   | Function block with incorrect PG software loaded                                       |  |  |
| 1A2CH                 | _                   | ACR: illegal page number in ACCU-1-L (> 255)                                           |  |  |
| 1A31H                 | —                   | OB 254 or OB 255 (shift) or OB 250:<br>destination data block already exists in DB-RAM |  |  |
| 1A32H                 | _                   | OB 254 or OB 255 (duplicate):<br>destination data block already exists in DB-RAM       |  |  |
| 1A33H                 | _                   | OB 254 or OB 255 or OB 250:<br>not enough space in the DB-RAM                          |  |  |

Table 5-23LZF-other runtime errors (OB 254/255 and OB 250 identifiers)

## **OB 182 error identifiers**

| Error identifier<br>ACCU-1-L ACCU-2-L |       | Explanation                                                                          |  |  |
|---------------------------------------|-------|--------------------------------------------------------------------------------------|--|--|
| 1A34H                                 | 0001H | Description of the data field illegal                                                |  |  |
| 1A34H                                 | 0100H | Address area type is illegal                                                         |  |  |
| 1A34H                                 | 0101H | Data block number is illegal                                                         |  |  |
| 1A34H                                 | 0102H | "Number of the first parameter word" illegal                                         |  |  |
| 1A34H                                 | 0200H | "Source data block type" illegal                                                     |  |  |
| 1A34H                                 | 0201H | "Source data block number" illegal                                                   |  |  |
| 1A34H                                 | 0202H | Number of first data word in the source to be transmitted illegal                    |  |  |
| 1A34H                                 | 0203H | Length of source data block in the block header,<br>value < 5 words entered          |  |  |
| 1A34H                                 | 0210H | "Destination data block type" illegal                                                |  |  |
| 1A34H                                 | 0211H | "Destination data block" number illegal                                              |  |  |
| 1A34H                                 | 0212H | Number of the first data word in the destination to be transmitted illegal           |  |  |
| 1A34H                                 | 0213H | Length of the destination data block in the block<br>header, value < 5 words entered |  |  |
| 1A34H                                 | 0220H | Number of data words to be transmitted illegal<br>(= 0 or > 4091)                    |  |  |
| 1A34H                                 | 0221H | Source data block too short                                                          |  |  |
| 1A34H                                 | 0222H | Destination data block too short                                                     |  |  |
| 1A34H                                 | 0223H | Destination data block in EPROM                                                      |  |  |

 Table 5-24
 LZF-other runtime errors (OB 182 identifier)

## Error identifiers of the different special function OBs

| Error identifier<br>ACCU-1-L ACCU-2-L |   | Explanation                                                                                         |                                                                           |  |
|---------------------------------------|---|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|--|
| 1A35H                                 | _ | OB 250:                                                                                             | number of the transfer block illegal                                      |  |
| 1A36H                                 |   | OB 250:                                                                                             | DB x and DB x + 1 or DX x<br>and DX x +1 have different lengths           |  |
| 1A3AH                                 | _ | OB 221:                                                                                             | illegal value for the new cycle<br>time (cycle time < 1 ms or > 13000 ms) |  |
| 1A3BH                                 |   | OB 223:                                                                                             | different CPU start-up types in multiprocessor operation                  |  |
| 1A41H                                 | — | OB 240, OB 241 or OB 242:<br>illegal shift register or data block number<br>(number < 192 or > 255) |                                                                           |  |
| 1A42H                                 |   | OB 241:                                                                                             | shift register not initialized                                            |  |
| 1A43H                                 |   | OB 240:                                                                                             | not enough space in the DB-RAM                                            |  |
| 1A44H                                 |   | OB 240:                                                                                             | data word DW 0 of the data block does<br>not contain '0'                  |  |
| 1A45H                                 | _ | OB 240:                                                                                             | illegal shift register length in DW 1<br>(not between 2 and 256)          |  |
| 1A46H                                 | _ | OB 240:                                                                                             | illegal pointer position or<br>number of pointers > 5                     |  |
| 1A47H                                 | _ | OB 120:                                                                                             | illegal value in ACCU 1 or ACCU-2-L                                       |  |
| 1A48H                                 |   | OB 122:                                                                                             | illegal value in ACCU 1                                                   |  |
| 1A49H                                 |   | OB 110:                                                                                             | illegal value in ACCU 1 or ACCU-2-L                                       |  |
| 1A4AH                                 |   | OB 121:                                                                                             | illegal value in ACCU 1or ACCU-2-L                                        |  |
| 1A4BH                                 |   | OB 123:                                                                                             | illegal value in ACCU 1                                                   |  |

 Table 5-25
 LZF-other runtime errors (special function OB identifiers)

## **OB 150 error identifiers**

| Error identifier<br>ACCU-1-L ACCU-2-L |       | Explanation                                      |  |  |
|---------------------------------------|-------|--------------------------------------------------|--|--|
| 1A4CH                                 | 0001H | illegal function number (=0 or >2)               |  |  |
| 1A4CH                                 | 0100H | address area type illegal                        |  |  |
| 1A4CH                                 | 0101H | data block number illegal                        |  |  |
| 1A4CH                                 | 0102H | "number of the first data field word" illegal    |  |  |
| 1A4CH                                 | 0103H | data block length entered in header < 5 words    |  |  |
| 1A4CH                                 | 0201H | year specification in data field illegal         |  |  |
| 1A4CH                                 | 0202H | month specification in data field illegal        |  |  |
| 1A4CH                                 | 0203H | day of month specification in data field illegal |  |  |
| 1A4CH                                 | 0204H | weekday spec. in data field illegal              |  |  |
| 1A4CH                                 | 0205H | hour specification in data field illegal         |  |  |
| 1A4CH                                 | 0206H | minute specification in data field illegal       |  |  |
| 1A4CH                                 | 0207H | second specification in data field illegal       |  |  |
| 1A4CH                                 | 0208H | 1/100 seconds in data field not equal to 0       |  |  |
| 1A4CH                                 | 0209H | data field word 3 / bits 0 to 3 not equal to 0   |  |  |
| 1A4CH                                 | 020AH | hour format does not match setting in OB 151     |  |  |

 Table 5-26
 LZF-other runtime errors (OB 150 identifiers)

#### Error identifiers of OB 151, OB 152 and OB 153

| Error identifier<br>ACCU-1-L ACCU-2-L |                | Explanation                                      |  |  |
|---------------------------------------|----------------|--------------------------------------------------|--|--|
|                                       |                | OB 151 identifiers                               |  |  |
| 1A4DH                                 | 0001H          | function number illegal (= $0 \text{ or } > 2$ ) |  |  |
| 1A4DH                                 | 0100H          | address area type illegal                        |  |  |
| 1A4DH                                 | 0101H          | data block number illegal                        |  |  |
| 1A4DH                                 | 0102H          | number of the first data field word illegal      |  |  |
| 1A4DH                                 | 010 <b>3</b> H | data block length entered in header < 5 words    |  |  |
| 1A4DH                                 | 0201H          | year specification in data field illegal         |  |  |
| 1A4DH                                 | 0202H          | month specification in data field illegal        |  |  |
| 1A4DH                                 | 0203H          | day of month spec. in data field illegal         |  |  |
| 1A4DH                                 | 0204H          | weekday specification in data field illegal      |  |  |
| 1A4DH                                 | 0205H          | hour specification in data field illegal         |  |  |
| 1A4DH                                 | 0206H          | minute specification in data field illegal       |  |  |
| 1A4DH                                 | 0207H          | second specification in data field illegal       |  |  |

Table 5-27LZF-other runtime errors (identifiers of OB 151, OB 152 and OB 153)

| Error identifier<br>ACCU-1-L ACCU-2-L                   |         | Explanation                                   |  |
|---------------------------------------------------------|---------|-----------------------------------------------|--|
| Table 5-27 cont                                         | tinued: |                                               |  |
| 1A4DH                                                   | 0208H   | 1/100 seconds in data field not equal to 0    |  |
| 1A4DH                                                   | 0209H   | job type in data field illegal (> 7)          |  |
| 1A4DH                                                   | 020AH   | hour format does not match setting in OB 150  |  |
| OB 152 identifiers                                      |         |                                               |  |
| 1A4EH0001Hfunction no. illegal (not 0 to 3, or 8 or 15) |         | function no. illegal (not 0 to 3, or 8 or 15) |  |
| OB 153 identifiers                                      |         |                                               |  |
| 1A4FH                                                   | 0001H   | function no. illegal (=0 or <1)               |  |
| 1A4FH 0002H illegal                                     |         | illegal delay time                            |  |

## Error identifiers of different system operations

| Error identifier<br>ACCU-1-L ACCU-2-L |   | Explanation                                                                 |  |  |
|---------------------------------------|---|-----------------------------------------------------------------------------|--|--|
| 1A50H                                 | _ | LRW, TRW:                                                                   |  |  |
|                                       |   | the calculated memory address<br><br>not in range "0 - EDFFH" <sup>1)</sup> |  |  |
| 1A51H                                 | — | LRD, TRD:                                                                   |  |  |
|                                       |   | the calculated memory address<br><br>not in range "0 - EDFEH" <sup>1)</sup> |  |  |
| 1A52H                                 | — | TSG, LY GB, LW GW, TY GB, TW GW:                                            |  |  |
|                                       |   | the calculated linear address<br><br>not in range "0 - EFFFH"               |  |  |
| 1A53H                                 | — | LY GW, LW GD, TY GW, TW GD:                                                 |  |  |
|                                       |   | the calculated linear address<br><br>not in range "0 - EFFEH"               |  |  |
| 1A54H                                 | _ | LY GD, TY GD:                                                               |  |  |
|                                       |   | the calculated linear address<br><br>not in range "0 - EFFCH"               |  |  |
| 1A55H                                 |   | TSC, LY CB, LW CW, TY CB, TW CW:                                            |  |  |
|                                       |   | the calculated page address<br><br>not in range "F400H - FBFFH"             |  |  |
| 1A56H                                 | — | LY CW, LW CD, TY CW, TW CD:                                                 |  |  |
|                                       |   | the calculated page address<br><br>not in range "400H - FBFEH"              |  |  |
| 1A57H                                 | _ | LY CD, TY CD:                                                               |  |  |
|                                       |   | the calculated page address<br><br>not in range "F400H - FBFCH"             |  |  |

 Table 5-28
 LZF-other runtime errors (identifiers of different system operations)

| Error identifier<br>ACCU-1-L ACCU-2-L |        | Explanation                                           |              |                                    |  |
|---------------------------------------|--------|-------------------------------------------------------|--------------|------------------------------------|--|
| Table 5-28 cont                       | inued: |                                                       |              |                                    |  |
| 1A58H                                 | _      | TNW, TNB:                                             |              |                                    |  |
|                                       |        | the source ranges:                                    | field is not | completely in one of the following |  |
|                                       |        | 0000                                                  | 7FFF         | user memory <sup>1)</sup>          |  |
|                                       |        |                                                       | DD7F         | data block RAM                     |  |
|                                       |        | DD80                                                  | E3FF         | <b>DB</b> 0                        |  |
|                                       |        | E400                                                  | E7FF         | S flags                            |  |
|                                       |        | E800                                                  | EDFF         | system data                        |  |
|                                       |        |                                                       |              | (RI, RJ, RS, RT, C, T)             |  |
|                                       |        | EE00                                                  |              | flags, process image               |  |
|                                       |        | F000                                                  | FFFF         | peripherals                        |  |
| 1A59H                                 | —      | TNW, TN                                               | B:           |                                    |  |
|                                       |        | the destination field is not completely in one of the |              |                                    |  |
|                                       |        | following                                             |              | 1)                                 |  |
|                                       |        | 0000                                                  | 7FFF         | user memory <sup>1)</sup>          |  |
|                                       |        |                                                       | DD7F         |                                    |  |
|                                       |        | DD80                                                  |              | DB 0                               |  |
|                                       |        |                                                       | E7FF         | e                                  |  |
|                                       |        | E800                                                  | EDFF         | system data (RI,                   |  |
|                                       |        | EEOO                                                  | PPPP         | RJ, RS, RT, C, T)                  |  |
|                                       |        | EE00                                                  | EFFF         | flags, process image               |  |
|                                       |        | F000                                                  | FFFF         | peripherals                        |  |

<sup>1)</sup> see Chap. 9

## 5.6.3 ADF (Addressing Error)

| Introduction      | An addressing error occurs when a STEP 5 operation references a process image input or output to which no I/O module was assigned at the time of the last COLD RESTART (e.g. the module is not plugged in, it is defective or it is not defined in DB 1 of the CPU).                                                                                                                                                                                                                                                                                                                             |  |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| OB 25             | The system program interrupts the execution of the user program and calls organization block <b>OB 25</b> . After executing the program in OB 25, the CPU continues with the next operation of the interrupted program. The STEP 5 statement that caused ADF was executed but with an undefined input or output value.<br>If OB 25 is not programmed, the CPU goes into the STOP mode when the error occurs, unless you have specified in data block DX 0 that the program should continue.<br>The address error monitoring can also be completely suppressed if you program DX 0 appropriately. |  |  |
| Error identifiers | The system program transfers the following as error identifiers:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |

| Error ide<br>ACCU-1-L | entifier<br>ACCU-2-L | Explanation                            |
|-----------------------|----------------------|----------------------------------------|
| 1E40H                 | ууууН                | Addressing error<br>yyyy = ADF address |

Table 5-29ADF-identifiers of addressing errors

## 5.6.4 QVZ (Timeout Error)

| Introduction                                  | A timeout error occurs when an input or output module is addressed and does n<br>respond with the ready signal (RDY) within a specific time. The cause of the<br>timeout may be a defect on the I/O module or the module may have been<br>unplugged from the PC during operation.<br>The following timeout errors interrupt the user program, and call the appropriat<br>organization blocks. |  |  |
|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                               | <b>Note</b><br>If the organization blocks called are <b>not programmed</b> , the user program<br>is <b>continued</b> .                                                                                                                                                                                                                                                                        |  |  |
|                                               | If a timeout occurs, the CPU reads in the substitute value "00H" and continues to work with this value if the QVZ is acknowledged.                                                                                                                                                                                                                                                            |  |  |
|                                               | A timeout, however, increases the runtime of the STEP 5 operation that caused it.                                                                                                                                                                                                                                                                                                             |  |  |
| STOP in the case<br>of QVZ                    | If you want a timeout to cause the CPU to stop, you must program the stop operation STP in the called OB (OB 23 or OB 24).<br>You can also program DX 0 to cause a system stop in the event of a timeout without programming OB 23/24.                                                                                                                                                        |  |  |
| QVZ during<br>direct access via<br>the S5 bus | Timeout in the user program during direct access via the S5 bus to CP, IP, coordinator or to a peripheral module (e.g. with load and transfer operations L/T P or O):                                                                                                                                                                                                                         |  |  |
| OB 23                                         | The system program calls organization block <b>OB 23</b> , if it is loaded.                                                                                                                                                                                                                                                                                                                   |  |  |
| Error identifiers                             | ACCUs 1 and 2 contain additional information that defines the error in greater detail.                                                                                                                                                                                                                                                                                                        |  |  |

Table 5-30 QVZ-identifiers of timeout errors

| Error identifier<br>ACCU-1-L ACCU-2-L |       | Explanation                         |
|---------------------------------------|-------|-------------------------------------|
| 1E23H                                 | ууууН | Timeout error<br>yyyy = QVZ address |

| QVZ address                                                  | The QVZ address indicates the <b>first</b> peripheral byte to generate a QVZ.<br>Normally, this is the byte with the lowest address in peripheral operations.<br>An exception to this are QVZ addresses supplied with the commands TNB/TNW<br>in the event of a timeout. Since these operations are decremented, in this case the<br>QVZ address indicates the byte with the highest address that triggered the QVZ<br>during the transfer of data. |  |
|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| QVZ during<br>PII update and<br>transfer of the<br>IPC flags | Timeout error during the update of the process image of inputs/outputs and transfer of IPC flags:                                                                                                                                                                                                                                                                                                                                                   |  |
| OB 24                                                        | The system program calls organization block <b>OB 24</b> , if it is loaded.                                                                                                                                                                                                                                                                                                                                                                         |  |
| Error identifiers                                            | ACCUs 1 and 2 contain additional information that defines the error in greater detail:                                                                                                                                                                                                                                                                                                                                                              |  |

Table 5-31 QVZ flags when calling OB 24

| Error identifier<br>ACCU-1-L ACCU-2-L |       | Explanation                                                                                                          |
|---------------------------------------|-------|----------------------------------------------------------------------------------------------------------------------|
| 1E25H                                 | ууууН | Timeout outputting the process image of the digital<br>outputs<br>yyyy = address of the non-acknowledged output byte |
| 1E26H                                 | ууууН | Timeout updating the process image of the digital inputs<br>yyyy = address of the non-acknowledged input byte        |
| 1E27H                                 | ууууН | Timeout updating the IPC flag outputs<br>yyyy = address of the non-acknowledged IPC flag byte                        |
| 1E28H                                 | ууууН | Timeout updating the IPC flag inputs<br>yyyy = address of the non-acknowledged IPC flag byte                         |

## 5.6.5 ZYK (Cycle Time Exceeded Error)

| Introduction                             | The cycle time includes the entire duration of cyclic program execution. The cycle monitoring time can be exceeded owing to a number of reasons: e.g. incorrect programming, a program loop in a function block, failure of the clock pulse generator or by system activities such as process image updating in conjunction with long programs.             |
|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OB 26                                    | When the cycle time exceeded error occurs, the system program interrupts the user program and calls organization block <b>OB 26</b> , if it is loaded. This retriggers the cycle time monitoring. If the monitoring time elapses again, before OB 26 has been completely processed, the CPU goes into the STOP mode owing to a double call error (DOPP-FE). |
| Cycle monitoring<br>time                 | The cycle monitoring time is variable (1 to 13000 ms) and can be retriggered (see above). Regardless of the cycle time, 100 ms after the cycle time has elapsed, BASP is activated if OB 26 has not yet been completed.<br>You can select the cycle monitoring time by means of an entry in DX 0 or by                                                      |
|                                          | calling the special function organization block OB 221.                                                                                                                                                                                                                                                                                                     |
|                                          | In the cyclic program, the cycle time monitoring can be retriggered by calling the special function OB 222.                                                                                                                                                                                                                                                 |
| STOP in the case<br>of unloaded<br>OB 26 | If you do not program OB 26, the CPU changes to the STOP mode. If you do not want this to happen, you must change the default in DX 0.                                                                                                                                                                                                                      |
| Error identifiers                        | If a cycle time exceeded error occurs, <b>no</b> error identifiers are transferred to ACCU 1 or ACCU 2.                                                                                                                                                                                                                                                     |

## 5.6.6 WECK-FE (Collision of Time Interrupts)

*Introduction* If a particular time interrupt OB is requested before its last request has been completely processed, the system program recognizes a collision of time interrupts.

**OB 33** When a collision of time interrupts occurs, the system program calls organization block **OB 33**, if it is loaded, or the CPU goes to the STOP mode. See Section 4.5.

*Error identifiers* ACCUs 1 and 2 contain additional information that defines the error in greater detail.

| Table 5-32 | WECK-FE identifiers |
|------------|---------------------|
|------------|---------------------|

| Error identifier<br>ACCU-1-L ACCU-2-L |       | Explanation                                    |
|---------------------------------------|-------|------------------------------------------------|
| 1001H                                 | 0016H | Collision of time interrupts in OB 10 (10 ms)  |
| 1001H                                 | 0014H | Collision of time interrupts in OB 11 (20 ms)  |
| 1001H                                 | 0012H | Collision of time interrupts in OB 12 (50 ms)  |
| 1001H                                 | 0010H | Collision of time interrupts in OB 13 (100 ms) |
| 1001H                                 | 000EH | Collision of time interrupts in OB 14 (200 ms) |
| 1001H                                 | 000CH | Collision of time interrupts in OB 15 (500 ms) |
| 1001H                                 | 000AH | Collision of time interrupts in OB 16 (1 sec)  |
| 1001H                                 | 0008H | Collision of time interrupts in OB 17(2 sec)   |
| 1001H                                 | 0006H | Collision of time interrupts in OB 18 (5 sec)  |

#### Note

The identifier in ACCU 2 is the level identifier of the time interrupt that caused the error.

If you do not program OB 33, the CPU goes into the stop mode. You can, however, program **DX 0** so that the program is continued when a collision of time interrupts occurs although you have not programmed OB 33.

A second call for the already active error program processing level "collision of time interrupts" does not lead to a double call error (DOPP).

## 5.6.7 REG-FE (Controller Error)

| Introduction                     | An error occurring during the processing of the standard function block for controller structure R64 is detected as a controller error.                                                                                                                                                                                                                                                                                                         |  |  |  |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                                  | <b>Note</b><br>While, for example, a collision of time interrupts is always recognized by<br>the system program, when a particular time interrupt OB is not started and<br>completed within a particular time interval (e.g. OB 13 within 100 ms),<br>incorrect processing of the closed loop control program is only detected<br>when the program processing level CL CONTROL is <b>called</b> . The error is<br>then indicated in the ISTACK. |  |  |  |
| OB 34                            | If a controller error occurs, the program processing level CL CONTROL is exited and the CONTROLLER ERROR (LEVEL: 001CH) level is called with organization block <b>OB 34</b> . The subsequent reaction of the CPU depends on how you have programmed OB 34:                                                                                                                                                                                     |  |  |  |
|                                  | • If you have not programmed OB 34, the CPU goes into the STOP mode. You can see the cause of the error by displaying the ISTACK.                                                                                                                                                                                                                                                                                                               |  |  |  |
|                                  | • If you have programmed OB 34, the STEP 5 program it contains (e.g. evaluation of ACCU 1 and 2 and then appropriate error handling) is executed. Following this, the controller processing is continued from the point at which it was interrupted.                                                                                                                                                                                            |  |  |  |
| Response to<br>controller errors | If you want to ignore all controller errors, simply write the block end statement BE in OB 34.                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|                                  | If you want the controller processing to continue when a controller error occurs and you do not program OB 34, change the default in DX 0.                                                                                                                                                                                                                                                                                                      |  |  |  |
| Error identifiers                | When OB 34 is called, ACCUs 1 and 2 contain additional information that defines the error in greater detail.                                                                                                                                                                                                                                                                                                                                    |  |  |  |

|                                            | Error identifier<br>ACCU-1-LACCU-2-L               |                                                 | Explanation                                                                                                                                                                                                                                       |
|--------------------------------------------|----------------------------------------------------|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                            | 0801H                                              | DByyH                                           | Sampling time error<br>yy = number of controller data block involved                                                                                                                                                                              |
|                                            | 0802H                                              | DByyH                                           | Controller data block not loaded<br>yy = number of the data block that is not loaded                                                                                                                                                              |
|                                            | 0803H                                              | FByyH                                           | Controller function block not loaded<br>yy = the number of the function block that is not loaded                                                                                                                                                  |
|                                            | 0804H                                              | FByyH                                           | Controller function block not recognized<br>yy = number of the non-recognized function block                                                                                                                                                      |
|                                            | 0805H                                              | FByyH                                           | Controller function block loaded with incorrect PC<br>software<br>yy = function block number                                                                                                                                                      |
|                                            | 0806H                                              | DByyH                                           | Wrong controller data block length<br>yy = data block number                                                                                                                                                                                      |
|                                            | 0880H                                              | 00yyH                                           | Timeout (QVZ) during the controller processing<br>yy = number of the I/O byte that caused the timeout.                                                                                                                                            |
| Entry in the<br>control bit<br>screen form | on the progra<br>system, the la<br>labelled, but i | mmer screen.<br>st position in<br>s also marked | error identifier <b>REG-FE</b> is marked in the control bits<br>If you operate a PG without the S5-DOS operating<br>the lower line of the control bits screen is not<br>I. In the ISTACK screen, the level CL CONTROL,<br>se of the interruption. |
| Sampling time<br>errors                    | next <b>block be</b><br>the processin              | <b>oundary</b> and<br>g of longer bl            | g time has elapsed, the cyclic program is stopped at the<br>the controller processing is inserted. It is possible that<br>ocks takes too long and that the controller processing<br>causes a sampling time error.                                 |
|                                            | described on                                       | the previous j                                  | time error just as the other controller errors (as<br>page) <b>or</b> you can suppress the error by means of a<br>n execution is not interrupted when a sampling time                                                                             |
|                                            | Refer also to the S5 135U"                         |                                                 | n "compact closed loop control in the R processor of                                                                                                                                                                                              |
|                                            | DX 0 "proces                                       | sing of contro                                  | It a sampling time error by changing the default in<br>oller and process interrupts at block boundaries" to<br>nd process interrupts at operation boundaries".                                                                                    |

Table 5-33 REG-FE identifiers

## 5.6.8 ABBR (Abort)

*Triggering and* If, during the RUN mode, the stop mode is requested by one of the following: *response* 

- switching the mode selector on the CPU from RUN to STOP,
- PG online function, PLC STOP,
- reset switch on coordinator set to STOP (in multiprocessor operation),

the system program calls **OB 28**, if it is loaded. After OB 28 has been processed, the CPU goes into the STOP mode.

#### Note

The transition to the stop mode takes place regardless of whether you program OB 28 or not.

No error identifiers are transferred to ACCU 1 or ACCU 2.

## 5.6.9 Communication Errors (FE-3)

| Introduction                   | If problems occur on the second serial interface with the computer link RK 512, data transfer with procedure 3964/3964R, data transfer with "open driver" or data transfer with SINEC L1, the system program calls organization block <b>OB 35</b> and transfers additional information about the problems to ACCU 1.           |  |  |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| OB 35                          | If you do not program OB 35, the system program does <b>not</b> react and the CPU does <b>not</b> go into the stop mode. This is the default reaction.                                                                                                                                                                          |  |  |
|                                | If you want the CPU to go into the stop mode when an interface error occurs and you do not program OB 35, you must change the default in DX 0.                                                                                                                                                                                  |  |  |
| Error information<br>in ACCU 1 | Every 100 ms the system program checks whether communication errors have occurred on the second serial interface. If an error is detected, the system program transfers the error information to ACCU 1 and ACCU 2. If you program OB 35, the system program calls it and transfers the error information in ACCU 1 and ACCU 2. |  |  |
|                                | Error numbers for a maximum of three causes of problems can be transferred<br>when OB 35 is called. If there are more than three causes of problems at the<br>same time, this is indicated by a special overflow identifier.                                                                                                    |  |  |

## Structure of the error information in ACCU 1 and ACCU 2

| 31                           |                                                                                                                                        | 24 23                                                                                                                                                | 18 15 8                                                                    | 7 0            |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|----------------|
| ACCU 1 0 0                   | 0 0 F U B                                                                                                                              | 0 Error number                                                                                                                                       | Error number 2                                                             | Error number 3 |
|                              | <ul> <li>= '1', when there is</li> <li>U = '0', when there is</li> <li>= '1', when there is</li> <li>B = '0', when there is</li> </ul> | s no error entered in t<br>s an error entered in t<br>s no error overflow (r<br>s an error overflow (r<br>s no BREAK on the i<br>s a BREAK on the im | he error area.<br>naximum three entri<br>nore than three entri<br>nterface |                |
| BREAK                        | If there is a BREAK or<br>end of the BREAK stat                                                                                        |                                                                                                                                                      | is only called at the                                                      | beginning and  |
| Error numbers 1<br>to 3      | Here, a maximum of th interface are entered in                                                                                         |                                                                                                                                                      |                                                                            |                |
| Meaning of the error numbers | For the meaning of the interface errors, refer to                                                                                      |                                                                                                                                                      |                                                                            | -              |

# 6

## **Integrated Special Functions**

## Contents of the

chapter

This Chapter tells you which integral special functions the system program contains, where you can use these functions and how you must call and assign parameters to the special function OBs.

In addition, you will learn how to detect errors in processing a special function and how do deal with these in the program.

# Overview of the chapter

| Section | Description                                                         | Page |
|---------|---------------------------------------------------------------------|------|
| 6.1     | Introduction                                                        | 6-3  |
| 6.2     | OB 110: Accessing the Condition Code Byte                           | 6-7  |
| 6.3     | OB 111: Clear ACCUs 1, 2, 3 and 4                                   | 6-9  |
| 6.4     | OB 112/113: Roll Up ACCU and Roll Down ACCU                         | 6-9  |
| 6.5     | OB 120: Enabling/Disabling of Interrupts                            | 6-11 |
| 6.6     | OB 121: Enable/Disable Individual Time-Driven<br>Interrupts         | 6-14 |
| 6.7     | OB 122: Enable/Disable "Delay of All Interrupts"                    | 6-16 |
| 6.8     | OB 123: Enable/Disable "Delay of Individual Time-Driven Interrupts" | 6-19 |
| 6.9     | OB 134, 135, 136 and 139                                            | 6-22 |
| 6.10    | Setting/Reading the System Time (OB 150)                            | 6-23 |
| 6.11    | OB 151: Setting/Reading the Time for Clock-Driven<br>Interrupts     | 6-28 |
| 6.12    | OB 152: Cycle Statistics                                            | 6-35 |
| 6.13    | OB 153: Set/Read Time for Delay Interrupt                           | 6-42 |
| 6.14    | OB 160 to 163: Loop Counters                                        | 6-45 |
| 6.15    | OB 170: Read Block Stack (BSTACK)                                   | 6-47 |
| 6.16    | OB 180: Accessing Variable Data Blocks                              | 6-52 |
| 6.17    | OB 181: Testing Data Blocks (DB/DX)                                 | 6-56 |
| 6.18    | OB 182: Copying a Data Area                                         | 6-58 |
| 6.19    | OB 185: Setting Write Protection                                    | 6-61 |
| 6.20    | OB 186: Compressing Memory                                          | 6-62 |

| Section | Description                                                          | Page  |
|---------|----------------------------------------------------------------------|-------|
| 6.21    | OB 190/OB 192: Transferring Flags to a Data Block                    | 6-63  |
| 6.22    | OB 191/OB 193: Transferring Data Fields to a Flag Area               | 6-65  |
| 6.23    | OB 200 and OB 202 to 205: Multiprocessor<br>Communication            | 6-70  |
| 6.24    | OB 216 to 218: Page Access                                           | 6-71  |
| 6.24.1  | OB 216: Writing to a Page                                            | 6-74  |
| 6.24.2  | OB 217: Reading from a Page                                          | 6-76  |
| 6.24.3  | OB 218: Reserving a Page                                             | 6-78  |
| 6.24.4  | Program Example                                                      | 6-80  |
| 6.25    | OB 220: Sign Extension                                               | 6-82  |
| 6.26    | Setting the Cycle Monitoring Time                                    | 6-83  |
| 6.27    | OB 222: Restarting the Cycle Monitoring Time                         | 6-84  |
| 6.28    | OB 223: Comparing Restart Types                                      | 6-84  |
| 6.29    | OB 224: Transferring Blocks of Interprocessor<br>Communication Flags | 6-85  |
| 6.30    | OB 226, OB 227                                                       | 6-86  |
| 6.31    | OB 228: Reading Status Information of a Program<br>Processing Level  | 6-87  |
| 6.32    | OB 230 to 237: Functions for Standard Function Blocks                | 6-89  |
| 6.33    | OB 240 to 242: Special Functions for Shift Registers                 | 6-90  |
| 6.34    | OB 240: Initializing Shift Registers                                 | 6-94  |
| 6.35    | OB 241: Processing Shift Registers                                   | 6-97  |
| 6.36    | OB 242: Deleting a Shift Register                                    | 6-98  |
| 6.37    | OB 250/251: Closed-Loop Control/ PID Algorithm                       | 6-99  |
| 6.37.1  | Functional Description of the PID Controller                         | 6-99  |
| 6.37.2  | PID Algorithm                                                        | 6-101 |
| 6.38    | OB 250: Initializing the PID Algorithm                               | 6-106 |
| 6.39    | OB 251: Processing the PID Algorithm                                 | 6-107 |
| 6.40    | OB 254, OB 255: Transferring a Data Block to the DB-RAM              | 6-113 |

## 6.1 Introduction

**Overview** The CPU 928B operating system provides you with a number of special functions, that you can call with a conditional (JC OBx) or unconditional (JU OBx) block call. Organization blocks OB 40 to OB 255 are reserved for these special functions.

These functions are known as **integrated** special functions, since they are a fixed part of the system program. You can call these special functions, you cannot, however, read or modify them.

```
Overview of The table below gives you an overview of the special functions available. special functions
```

| Block                                                                      | Function                                                   | see sectio | on /page |
|----------------------------------------------------------------------------|------------------------------------------------------------|------------|----------|
| OB 110                                                                     | Access to the condition code byte                          | 6.2        | 6-7      |
| OB 111                                                                     | Clear ACCU 1, 2, 3 and 4                                   | 6.3        | 6-9      |
| OB 112                                                                     | Roll up ACCU                                               | 6.4        | 6-9      |
| OB 113                                                                     | Roll down ACCU                                             | 6.4        | 6-9      |
| OB 120                                                                     | "Disable all interrupts" on/off                            | 6.5        | 6-11     |
| OB 121                                                                     | "Disable single time interrupts" on/off                    | 6.6        | 6-14     |
| OB 122                                                                     | "Delay all interrupts" on/off                              | 6.7        | 6-16     |
| OB 123                                                                     | "Delay single time interrupts" on/off                      | 6.8        | 6-19     |
| OB 134                                                                     | *D                                                         | 6.9        | 6-22     |
| OB 135                                                                     | /D                                                         | 6.9        | 6-22     |
| OB 136                                                                     | MOD                                                        | 6.9        | 6-22     |
| OB 139                                                                     | PUSH                                                       | 6.9        | 6-22     |
| OB 150                                                                     | Set/read the system time                                   | 6.10       | 6-23     |
| OB 151                                                                     | Set/read time for clock-driven time interrupt              | 6.11       | 6-28     |
| OB 152                                                                     | Read out cycle time                                        | 6.12       | 6-35     |
| OB 153                                                                     | Set/read time for delay interrupt<br>(from Version -3UB12) | 6.13       | 6-42     |
| OB 160 to 163                                                              | Loop counter                                               | 6.14       | 6-45     |
| <b>OB</b> 170                                                              | Read block stack (BSTACK)                                  | 6.15       | 6-47     |
| OB 180                                                                     | Variable data block access                                 | 6.16       | 6-52     |
| OB 181                                                                     | Test data block (DB/DX)                                    | 6.17       | 6-56     |
| OB 182                                                                     | Copy data area                                             | 6.18       | 6-58     |
| OB 185                                                                     | Set/reset write protection                                 | 6.19       | 6-61     |
| OB 186                                                                     | Compressing memory by means of user program                | 6.20       | 6-62     |
| OB 190, 192                                                                | Transfer flags to data blocks                              | 6.21       | 6-63     |
| OB 191, 193                                                                | Transfer data fields to flag area                          | 6.22       | 6-65     |
| OB 200 <sup>1),</sup> 202 <sup>1)</sup><br>OB 203, 204 <sup>1)</sup> , 205 | Functions for multiprocessor communication                 | 6.23       | 6-70     |

 Table 6-1
 Overview of the special functions available with the CPU 928B

| Block                       | Function                                                  | see secti | on /page |
|-----------------------------|-----------------------------------------------------------|-----------|----------|
| Table 6-1 continued:        |                                                           |           |          |
| OB 216 to 218               | Accessing pages                                           | 6.24      | 6-71     |
| OB 220                      | Sign extension                                            | 6.25      | 6-82     |
| OB 221 <sup>2)</sup>        | Set the cycle monitoring time                             | 6.26      | 6-83     |
| OB 222                      | Restart the cycle monitoring time                         | 6.27      | 6-84     |
| OB 223                      | Compare restart types in multiprocessor operation         | 6.28      | 6-84     |
| OB 224 <sup>2)</sup>        | Transfer a block of IPC flags in multiprocessor operation | 6.29      | 6-85     |
| OB 226                      | Read a word from the system program                       | 6.30      | 6-86     |
| OB 227                      | Read the checksum of the system program                   | 6.30      | 6-86     |
| OB 228                      | Read status information of a program processing level     | 6.31      | 6-87     |
| OB 230 to 237 <sup>1)</sup> | Functions for standard function blocks                    | 6.32      | 6-89     |
| OB 240                      | Initialize shift register                                 | 6.34      | 6-94     |
| OB 241                      | Process shift register                                    | 6.35      | 6-97     |
| OB 242                      | Clear shift register                                      | 6.36      | 6-98     |
| OB 250 <sup>1)</sup>        | Initialize PID controller                                 | 6.38      | 6-106    |
| OB 251 <sup>1)</sup>        | Process PID controller                                    | 6.39      | 6-107    |
| OB 254, 255 <sup>1)</sup>   | Copy/duplicate a DB or DX data block                      | 6.40      | 6-113    |

Special functions with pseudo operation boundaries (executed in several steps)
 Instead of these special function organization blocks, assign parameters in data block DX 0 (see Chapter 7).

Interfaces The following operations and parameters are available as interfaces when programming the use of special functions:

> **Block call** .

> > Conditional/unconditional block call JC ... / JU ...

**Parameters** 

Parameters for selecting presets using ACCU 1 and possibly ACCU 2 and/or memory registers.

In this description, the term parameters refers to all data that the CPU needs to carry out the special functions correctly. Before you call these special functions in your STEP 5 program, you must load this data into the accumulators or into the memory registers as indicated.

The abbreviations used in reference to the parameter assignment of special function OBs are as follows:

| ACCU 1:    | ACCU 1,                      | 32 bits |
|------------|------------------------------|---------|
| ACCU-1-L:  | ACCU 1, low word,            | 16 bits |
| ACCU-1-LL: | ACCU 1, low word, low byte,  | 8 bits  |
| ACCU-1-LH: | ACCU 1, low word, high byte, | 8 bits  |

|    | ← High word → |          |    | •  | Low       | wo | rd       | _ |
|----|---------------|----------|----|----|-----------|----|----------|---|
|    | High byte     | Low byte |    |    | High byte |    | Low byte |   |
| 31 | 24            | 23       | 16 | 15 | 8         | 7  |          | 0 |

#### Errors during special function processing

ACCU

abbreviations

If an error occurs during the processing of the special functions, the system program reacts in a specific manner.

In terms of the system program reaction to errors, the special functions can be divided into two groups.

#### • Error OB, ACCU identifiers

There are special functions for which an error **organization block** (error OB) is called in the event of an error. You can program the CPUs reaction in these error OBs. These error OBs are OB 19, OB 30 and OB 31. In ACCU 1 and for some special functions also in ACCU 2 (see Section 5.6), identifiers are transferred to the error OB that define the error in greater detail.

If the CPU encounters for example an incorrect parameter when processing one of these special functions, it detects a runtime error and calls OB 31. On the other hand, if for example the called special function does not exist, the CPU detects an operation code error and attempts to call OB 30. With some of these special functions, if there is a reference to a data block in the call parameters and the data block is not loaded, then the CPU attempts to call OB 19.

If the error OBs 30 or 31 are not loaded or contain an STP operation, the CPU goes into the stop mode. LZF or BCF is marked in the control bits in the ISTACK. The accumulators of the error processing levels contain error identifiers that describe the error in greater detail.

If OB 19, OB 30 or OB 31 is loaded (and does not contain an STP operation), the user program is continued at the next operation after the OB has been processed. In this case, the accumulators remain unchanged.

## • RLO, CC 0/CC 1

In connection with some of the special functions, errors specific to the special function affect the condition codes CC 0/CC 1.

If an error occurs during the processing of these special functions, the RLO is normally set (RLO = 1). When using these special functions, you can use a JC operation (conditional jump) in your STEP 5 program to evaluate the RLO and to react to an error.

The processing of some special functions also affects the condition codes CC 0 and CC 1. In your STEP 5 program, you can scan these condition codes with comparison operations and once again react to an error.

The following descriptions of the individual special function OBs indicate which of these reactions apply to the particular special function OB.

#### Note

Calling a special function OB with the operation JC OB > 39 or JU OB > 39 is not a "genuine" block change, but is handled like a STEP 5 operation without a block operand. **No interrupts** are inserted (when "interrupts at block boundaries" is set).

| Special functions with pseudo | Some of the special functions are carried out in several steps and contain what are known as pseudo operation boundaries.                                        |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               | 1 1                                                                                                                                                              |
| operation                     | This means that the special function is executed in several steps. If an error                                                                                   |
| boundaries                    | (e.g. ZYK) or an interrupt (e.g. time or process interrupt at operation boundaries) occurs during the execution of a step, the appropriate organization block is |
|                               | inserted at the end of this step at the pseudo operation boundary.                                                                                               |
|                               | The anomial functions containing around a constant hour derives are marked in the                                                                                |

The special functions containing pseudo operation boundaries are marked in the overview of the integrated special functions.

## 6.2 OB 110: Accessing the Condition Code Byte

*Function* Using the special function organization block OB 110, you can write the contents of ACCU 1 to the condition code register, or mask it with "1" or "0".

#### Assignment of ACCU 1 for access to the condition code register:

| 31 | 7    | 6      | 5        | 4  | 3  | 2     | 1        | 0    |
|----|------|--------|----------|----|----|-------|----------|------|
| *) | CC 1 | CC 0   | ov       | OS | OR | STA   | RLO      | ERAB |
|    |      | Word a | lisplays |    |    | Bit d | lisplays |      |

\*) Bits 8 to 31 are reserved for extensions and must be "0" when the condition code register is written to. They must also be ignored when reading out the condition code register.

Parameters 1. ACCU-2-L

Function number possible values: 1, 2 or 3

#### 2. ACCU 1

New condition code byte or mask

| Function no. in | Contents of                   | ACCU-1-L                      |                                                                                                                                                              |
|-----------------|-------------------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ACCU-2-L        | before                        | after                         | Function                                                                                                                                                     |
| 1               | New<br>condition<br>code byte | New<br>condition<br>code byte | The contents of ACCU 1 are loaded in the condition code register.                                                                                            |
| 2               | Mask                          | New<br>condition<br>code byte | All the bits indicated as "1" in the mask in ACCU 1 are set to "1" in the condition code register. The new condition code byte is loaded in ACCU 1.          |
| 3               | Mask                          | New<br>condition<br>code byte | All the bits indicated as "1" in the mask in ACCU 1 are set to " <b>0</b> " in the condition code register. The new condition code byte is loaded in ACCU 1. |

Result

After execution of OB 110, the condition code byte will have been changed in accordance with the function and the contents of ACCU-1.

**Possible errors** The following error events may occur.

- Function number in ACCU-2-L not equal to 1, 2 or 3.
- One of the bits no. 8 to no. 31 is set in ACCU 1.

If an error occurs, **OB 31** (other runtime errors) is called. If OB 31 is not loaded, the CPU goes to the STOP mode. In both cases, the error identifier 1A49H is entered in ACCU-1-L.

**Example** With OB 110, you can test the operations that evaluate or affect the condition code register. Its application is, however, not restricted to the operation test. The following example shows you a further possible application.

#### Call distributor One of four subroutines is to be called depending on the contents of flag byte FY 0. The four subroutines are assigned to bits F 0.0 to F 0.3. Only one of these bits can be set at any one time. :L FYO :SLW 4 ;shift F 0.0 to F 0.3 four bits to the left :L KB1 ;load the function number : TAK :JU 0B110 :JS =M000 ;jump if OS = 1 :JO =M001 ; jump if OV = 1:JM =M002 ; jump if CC 0 = 1=M003 ; jump if CC 1 = 1:JP : ; if no bit is set : : : BEU : мооо ; if F 0.0 = 1: : : BEU M001 : ; if F 0.1 = 1: : M002 ; if F 0.2 = 1: : : BEU мооз ; if F 0.3 = 1: :

## 6.3 OB 111: Clear ACCUs 1, 2, 3 and 4

| Function        | Calling special function organization block OB 111 is a simple way of clearing ACCUs 1 to 4. OB 111 overwrites all four registers with "0". |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Parameters      | none                                                                                                                                        |
| Result          | Accus 1 to 4 (32 bits each) are deleted.                                                                                                    |
| Possible errors | none                                                                                                                                        |

## 6.4 OB 112/113: Roll Up ACCU and Roll Down ACCU

| Function        | OBs 112 and 113 roll the contents of the ACCUs either up or down.                                                                                                      |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | • OB 112 (roll up) shifts the contents of ACCU 1 to ACCU 2, the contents of ACCU 2 to ACCU 3 etc.                                                                      |
|                 | • OB 113 (roll down) shifts the contents of the ACCUs in the opposite direction; the contents of ACCU 1 to ACCU 4, ACCU 4 to ACCU 3 etc.                               |
| Parameters      | none                                                                                                                                                                   |
| Result          | Figures 6-1 and 6-2 show the contents of the ACCUs <b>before</b> and <b>after</b> calling OB 112 and OB 113.                                                           |
|                 | Note<br>You can also shift the contents of the ACCUs using the STEP 5 operations<br>ENT (supplementary operation set) and TAK (system operation)<br>(see Section 3.4). |
| Possible errors | none                                                                                                                                                                   |



Fig. 6-1 Effects of the "roll up" function





**OB 112** 

## 6.5 OB 120: Enabling/Disabling of Interrupts

| Introduction | A STEP 5 program can be interrupted at block or operation boundaries by programs with a higher priority. These higher priority program processing levels include the process and all time interrupts (cyclic time interrupts, clock-driven time interrupt and delay interrupt). The runtime of the interrupted program is therefore extended by the runtime of the programs inserted by the interrupts. Using special function organization blocks OB 120, you can prevent the insertion of higher priority program processing levels at one or more consecutive block or operation boundaries (depending on the setting in DX 0). |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function     | The special function organization OB 120 affects the reaction to interrupts:<br><b>Disabling</b> interrupts means that no more interrupts are recognized and the interrupts that have already been detected (e.g. they are waiting for a block boundary) are cleared. If OB 2 (process interrupts) or an OB for time-driven interrupt processing have already started, they are processed to the end.<br><b>Enabling</b> interrupts means that all interrupts are once again recognized immediately, and are inserted and processed at the next block or operation boundary.                                                       |
| Parameters   | <b>1. Double control word</b><br>OB 120 records the interrupts to be disabled or delayed in a system-internal <b>double control word</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

The bits of the double control word are assigned as follows:

| Control word<br>bit no. | Function                                             |  |
|-------------------------|------------------------------------------------------|--|
| 0 = '1'                 | all time-driven interrupts in fixed interval delayed |  |
| 1 = '1'                 | the clock-driven time interrupt is disabled          |  |
| 2 = '1'                 | all process interrupts are disabled                  |  |
| 3 = '1'                 | the delay interrupt is disabled                      |  |
| 4 to 31                 | reserved; these bits must be "0"!                    |  |

As long as a bit is set to '1', the respective interrupt is disabled.

## 2. Accus

## ACCU-2-L

| Function No.<br>Permissible values | 1,2 or 3 with:                                                                                                                              |  |
|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1:                                 | The contents of ACCU 1 are loaded in the control word.                                                                                      |  |
| 2:                                 | All the bits in the mask in ACCU 1<br>marked with a '1' are set to '1' in the<br>control word. The new control word is<br>loaded in ACCU 1. |  |
| 3:                                 | All the bits in the mask in ACCU 1<br>marked with '1' are set to '0' in the<br>control word. The new control word is<br>loaded in ACCU 1.   |  |

#### ACCU1

New control word or mask, depending on the desired function

Result

Calling OB 120 has the following results:

| Function no. | Contents     | of ACCU 1        |
|--------------|--------------|------------------|
| in ACCU-2-L  | before       | after            |
| 1            | Control word | Control word     |
| 2            | Mask         | New control word |
| 3            | Mask         | New control word |

**Possible errors** The following error events may occur.

- Illegal function number in ACCU-2-L.
- One of the reserved bits in ACCU 1 (no. 3 to 31) is set to "1".

In the event of an error, **OB 31** (other runtime errors) is called. If OB 31 is not loaded, the CPU goes to the STOP mode. In both cases, an error ID is entered in ACCU-1-L.

*Notes* • You can scan the status of a control word with the following program sequence:

1. Load the function number 2 or 3 in ACCU-2-L

- 2. Load the value '0' in ACCU 1
- 3. Call special function OB 120
- 4. Read out ACCU 1
- You can determine the status of interrupt processing by reading out system data word RS 131.
  - RS 131 Condition codeword "disable all interrupts"
- Instead of OB 120, you can use the operations IA and RA to disable and enable process interrupts as follows:

| IA corresponds to | :L  | KB 2                |
|-------------------|-----|---------------------|
|                   | :L  | KM 0000000 00000100 |
|                   | :JU | OB 120              |
|                   |     |                     |
| RA corresponds to | :L  | KB 3                |
|                   | :L  | KM 0000000 00000100 |
|                   | :JU | OB 120              |

## 6.6 OB 121: Enable/Disable Individual Time-Driven Interrupts

- *Introduction* Using the special function organization block OB 121, you can prevent the insertion of certain time-driven OBs (time-driven interrupts with a fixed time interval) at one or more consecutive block or operation boundaries. You can, for example, prevent a particular program section being interrupted by an OB 18 (5 s) and an OB 17 (2 s). On the other hand, all other programmed time-driven interrupts are processed as usual
- *Function* OB 121 affects the reaction to time-driven interrupts:

**Disabling** individual time-driven interrupts means that no more of the specified time-driven interrupts are recognized and the interrupts that have already been detected (e.g. they are waiting for a block boundary) are cleared. If OB 2 (process interrupts) or an OB for time-driven interrupt processing (for processing a time-driven interrupt at a fixed time interval) have already started, they are processed to the end.

**Enabling** individual time-driven interrupts means that all interrupts are once again recognized immediately, and are inserted and processed at the next block or operation boundary.

#### Parameters 1. Control word

OBs 121 records the time-driven interrupts to be disabled or delayed in a **control** word.

The bits of the control word are assigned as follows:

| Bit no.                                                          | Interrupt                                                                                                                                                                                                                                                                           |  |
|------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0 to 2                                                           | Reserved; these bits must be "0"!                                                                                                                                                                                                                                                   |  |
| 3 = '1' 4 = '1' 5 = '1' 6 = '1' 7 = '1' 8 = '1' 9 = '1' 10 = '1' | Time-driven interrupt with fixed time intervals:         10 ms       (OB 10)         20 ms       (OB 11)         50 ms       (OB 12)         100 ms       (OB 13)         200 ms       (OB 14)         500 ms       (OB 15)         1 sec       (OB 16)         2 sec       (OB 17) |  |
| 11 = '1'                                                         | 5 sec (OB 18)                                                                                                                                                                                                                                                                       |  |
| 12 to 15                                                         | Reserved; these bits must be "0"!                                                                                                                                                                                                                                                   |  |

|                 | 2. Accus                                                                         |                                                                                                                                                    |  |
|-----------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                 | ACCU-2-L                                                                         |                                                                                                                                                    |  |
|                 | Function No.<br>Permissible values:                                              | 1, 2 or 3 with:                                                                                                                                    |  |
|                 | 1:                                                                               | The contents of ACCU 1 are loaded in the control word.                                                                                             |  |
|                 | 2:                                                                               | All the bits in the mask in ACCU 1<br>marked with a '1' are set to <b>'1'</b> in<br>the control word. The new control word<br>is loaded in ACCU 1. |  |
|                 | 3:                                                                               | All the bits in the mask in ACCU 1<br>marked with '1' are set to '0' in the<br>control word. The new control word<br>is loaded in ACCU 1.          |  |
|                 | ACCU 1                                                                           |                                                                                                                                                    |  |
|                 | New control word or m                                                            | ask, depending on the desired function                                                                                                             |  |
|                 |                                                                                  |                                                                                                                                                    |  |
| Possible errors | The following error eve                                                          | ents may occur.                                                                                                                                    |  |
|                 | • Illegal function num                                                           | iber in ACCU-2-L                                                                                                                                   |  |
|                 | • One of the reserved bits in ACCU 1 is set to "1".                              |                                                                                                                                                    |  |
|                 |                                                                                  | <b>OB 31</b> (other runtime errors) is called. If OB 31 is not the STOP mode. In both cases, an error ID is entered in                             |  |
| Notes           | • You can scan the status of a control word with the following program sequence: |                                                                                                                                                    |  |
|                 | 1. Load the fun                                                                  | ction number 2 or 3 in ACCU-2-L                                                                                                                    |  |
|                 | 2. Load the value                                                                | ue "0" in ACCU 1                                                                                                                                   |  |
|                 | 3. Call special                                                                  | function OB 121                                                                                                                                    |  |
|                 | 4. Read out AC                                                                   | CU 1                                                                                                                                               |  |
|                 | You can determine the out system data word R                                     | status of the time-driven interrupt processing by reading S 135.                                                                                   |  |
|                 | - RS 135 Cond                                                                    | ition codeword "disable individual interrupts"                                                                                                     |  |

## 6.7 OB 122: Enable/Disable "Delay of All Interrupts"

| Introduction | A STEP 5 program can be interrupted at block or operations boundaries by a higher-priority program. Such higher-priority program processing levels include the process interrupts and all time interrupts (cyclic time interrupts, clock-driven time interrupt and delay interrupt). The runtime of the interrupted program is therefore extended by the runtime of the programs inserted by the interrupts. Using special function block OB 122, you can prevent the insertion of higher priority program processing levels at one or more consecutive block or operation boundaries (depending on the setting in DX 0). |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function     | OB 122 affects the reaction to interrupts as follows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|              | <b>Enabling</b> interrupt delay means all interrupts will continue to be registered and already pending interrupts will remain registered. However, registered interrupts will not yet be processed. All operation or block boundaries will be temporarily disabled for the processing interrupts. If OB 2 (process interrupts) or an OB for time-driven interrupt processing have already started, they are processed to the end.                                                                                                                                                                                        |
|              | <b>Disabling</b> interrupt delay means all registered interrupts will be inserted and processed at the next block or operation boundary.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|              | <b>Note</b><br>If a specific time-driven interrupt OB is called for the second time during<br>the "Delay interrupt" phase, a collision of time interrupts occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Parameters   | 1. Double control word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|              | OB 122 records the interrupts to be delayed in a system-internal double control word.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Control word<br>bit no. | Function                                                 |  |  |  |
|-------------------------|----------------------------------------------------------|--|--|--|
| 0 = '1'                 | all time-driven interrupts in fixed interval are delayed |  |  |  |
| 1 = '1'                 | the clock-driven time interrupt is delayed               |  |  |  |
| 2 = '1'                 | all process interrupts are delayed                       |  |  |  |
| 3 = '1'                 | the delay interrupt is delayed                           |  |  |  |
| 4 to 31                 | reserved; these bits must be "0"!                        |  |  |  |

The bits of the double control word are assigned as follows:

As long as a bit is set to '1', the respective interrupt is disabled.

#### 2. Accus

ACCU-2-L

Function No. Permissible values: 1, 2 or 3 with:

- 1: The contents of ACCU 1 are loaded in the control word.
- 2: All the bits in the mask in ACCU 1 marked with "1" are set to "1". The new control word is loaded in ACCU 1.
- 3: All the bits in the mask in ACCU 1 marked with "**0**" are set to "1" in the control word. The new control word is loaded in ACCU 1.

#### ACCU 1

New control word or mask depending on the desired function.

Result

Calling OB 122 has the following results:

| Function no. | Contents of  | of ACCU 1        |
|--------------|--------------|------------------|
| in ACCU-2-L  | before       | after            |
| 1            | Control word | Control word     |
| 2            | Mask         | New control word |
| 3            | Mask         | New control word |

**Possible errors** The following error events may occur.

- Illegal function number in ACCU-2-L.
- One of the reserved bits in ACCU 1 (no. 4 to 31) is set to "1".

In the event of error, **OB 31** (other runtime errors) is called. If OB 31 is not loaded, the CPU goes to the STOP mode. In both cases, the error ID **1A48H** is entered in ACCU-1-L.

- **Notes** You can scan the status of the control work with the following program sequence:
  - 1. Load the function number 2 or 3 in ACCU-2-L
  - 2. Load the value "0" in ACCU 1
  - 3. Call special function OB 122
  - 4. Read out ACCU 1
  - You can determine the status of interrupt processing by reading out system data word RS 132.
    - RS 132 Condition code word "delay all interrupts"

## 6.8 OB 123: Enable/Disable "Delay of Individual Time-Driven Interrupts"

*Introduction* Using special function organization block OB 123, you can prevent the insertion of certain time-driven OBs (time-driven interrupts with a fixed time interval) at one or more consecutive block or operation boundaries.

*Function* OB 123 affects the reaction to time-driven interrupts as follows:

**Disabling** delay of individual time-driven interrupts means all interrupts will continue to be registered and already pending interrupts will remain registered. However, registered interrupts will not yet be processed. All operation or block boundaries will be temporarily disabled for the processing interrupts. If a time interrupt OB (for processing a time interrupt with a fixed time base) has already been started, it is processed to the end.

**Disabling** delay of individual time-driven interrupts means that with immediate effect, all cyclic time-driven interrupts will again be registered, inserted at the next block or operation boundary (depending on the setting in DX 0) and processed.

#### Note

If a specific time-driven interrupt OB is called for the second time during the "Delay interrupt" phase, a collision of time interrupts occurs.

Parameters 1. Control word

OB 123 records the interrupts to be delayed in a system-internal control word.

| Bit no.            | Interrupt                                        |  |  |  |  |
|--------------------|--------------------------------------------------|--|--|--|--|
| 0 to 2             | Reserved; these bits must be "0"!                |  |  |  |  |
|                    | Time-driven interrupt with fixed time intervals: |  |  |  |  |
| 3 = '1'<br>4 = '1' | 10 ms (OB 10)<br>20 ms (OB 11)                   |  |  |  |  |
| 4 = 1<br>5 = '1'   | 20 ms (OB 11)<br>50 ms (OB 12)                   |  |  |  |  |
| 6 = '1'            | 100 ms (OB 13)                                   |  |  |  |  |
| 7 = '1'            | 200 ms (OB 14)                                   |  |  |  |  |
| 8 = '1'            | 500 ms (OB 15)                                   |  |  |  |  |
| 9 = '1'            | 1 sec (OB 16)                                    |  |  |  |  |
| 10 = '1'           | 2 sec (OB 17)                                    |  |  |  |  |
| 11 = '1'           | 5 sec (OB 18)                                    |  |  |  |  |
| 12 to 15           | Reserved; these bits must be "0"!                |  |  |  |  |

The bits of the control word are assigned as follows:

#### 2. Accus

ACCU-2-L

Function No.Permissible values:1, 2 or 3 with:

- 1: The contents of ACCU 1 are loaded in the control word
- 2: All the bits in the mask in ACCU 1 marked with "1" are set to "1". The new control word is loaded in ACCU 1.
- 3: All the bits in the mask in ACCU 1 marked with "**0**" are set to "1" in the control word. The new control word is loaded in ACCU 1.

#### ACCU 1

New control word or mask depending on the desired function.

**Possible errors** The following error events may occur.

- Illegal function number in ACCU-2-L.
- One of the reserved bits in ACCU 1 is set to '1'

In the event of error, **OB 31** (other runtime errors) is called. If OB 31 is not loaded, the CPU goes to the STOP mode. In both cases, the error ID **1A4BH** is entered in ACCU-1-L.

- **Notes** You can scan the status of the control word with the following program sequence:
  - 1. Load the function number 2 or 3 in ACCU-2-L
  - 2. Load the value '0' in ACCU 1
  - 3. Call special function OB 123
  - 4. Read out ACCU 1
  - You can determine the status of interrupt processing by reading out system data word RS 137.
    - RS 137 Condition code word "delay individual time-driven interrupts"

#### 6.9 OB 134, 135, 136 and 139

after:

| Arithmetic | An arithmetic operation (OB 134, 135, 136) changes the arithmetic registers as |
|------------|--------------------------------------------------------------------------------|
| operation  | follows (in fixed point operations only the low word):                         |

ACCU1 ACCU 2 ACCU 3 ACCU4 <ACCU 1> <ACCU 2> <ACCU 3> <ACCU 4> before: <ACCU 3> <ACCU 4> <ACCU 4> <result>

OB 134: \*D \*D (multiply 32-bit fixed point numbers) multiplies ACCU 2 and ACCU 1 and loads the result into ACCU 1. If the result is greater than the largest or smaller than the smallest 32-bit fixed point number that can be represented, this is indicated via OV=1 and OS=1. Then ACCU 3 and ACCU 4 are transferred to ACCU 2 and ACCU 3.

| Condition codes |            | CC 1 | CC 0 | OV | OS | OR | STA | RLO | ERAB |
|-----------------|------------|------|------|----|----|----|-----|-----|------|
|                 | Depends on | -    | -    | -  | -  | -  | -   | -   | -    |
|                 | Sets       | х    | х    | х  | х  | -  | -   | -   | -    |

OB 135: :D :D (divide 32-bit fixed point numbers) divides ACCU 2 by ACCU 1 and loads the result into ACCU 1. Then ACCU 3 and ACCU 4 are transferred to ACCU 2 and ACCU 3.

| Condition codes |            | CC 1 | CC 0 | OV | OS | OR | STA | RLO | <b>ERAB</b> |
|-----------------|------------|------|------|----|----|----|-----|-----|-------------|
|                 | Depends on | -    | -    | -  | -  | -  | -   | -   | -           |
|                 | Sets       | х    | х    | х  | х  | -  | -   | -   | -           |

MOD (remainder of division of two 32-bit fixed point numbers) divides ACCU 2 **OB 136: MOD** by ACCU 1 and loads the remainder of the division as the result into ACCU 1. Then ACCU 3 and ACCU 4 are transferred to ACCU 2 and ACCU 3.

| Condition codes |            | CC 1 | CC 0 | OV | OS | OR | STA | RLO | ERAB |
|-----------------|------------|------|------|----|----|----|-----|-----|------|
|                 | Depends on | -    | -    | -  | -  | -  | -   | -   | -    |
|                 | Sets       | х    | х    | х  | х  | -  | -   | -   | -    |

**OB 139: PUSH** PUSH (push ACCU stack) moves ACCU 1 deeper into the ACCU stack. PUSH can be used to enter the same value in the ACCU stack more than once.

| Condition codes |            | CC 1 | CC 0 | OV | OS | OR | STA | RLO | ERAB |
|-----------------|------------|------|------|----|----|----|-----|-----|------|
|                 | Depends on | -    | -    | -  | -  | -  | -   | -   | -    |
|                 | Sets       | -    | -    | -  | -  | -  | -   | -   | -    |

## 6.10 Setting/Reading the System Time (OB 150)

| Characteristics<br>of the system<br>time | The system time has the following features:                                                                                                                                                                                                                                                                                            |                          |      |  |  |
|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|------|--|--|
|                                          | • The resolution is 10 ms for reading                                                                                                                                                                                                                                                                                                  | g and 1 sec for setting. |      |  |  |
|                                          | • Leap years are taken into account.                                                                                                                                                                                                                                                                                                   |                          |      |  |  |
|                                          | • You can select between a 24 hour of to twelve o'clock), and "pm" (twel                                                                                                                                                                                                                                                               |                          | · -  |  |  |
|                                          | • The weekday can be specified                                                                                                                                                                                                                                                                                                         |                          |      |  |  |
|                                          | • Input and output in BCD.                                                                                                                                                                                                                                                                                                             |                          |      |  |  |
|                                          | • The integral hardware clock for the the PLC rack. If you have set the state following a power down and WAR                                                                                                                                                                                                                           | ystem time, it also ren  |      |  |  |
| Function                                 | Using OB 150, you can set or read the user program. The date and time are k                                                                                                                                                                                                                                                            |                          | -    |  |  |
|                                          | Note<br>Before you can read out the system                                                                                                                                                                                                                                                                                             | time, it must first be   | set. |  |  |
| Parameters                               | 1. Data Field for the Time Paramet                                                                                                                                                                                                                                                                                                     | ters                     |      |  |  |
|                                          | When you <b>set</b> the system time, OB 150 takes the system time from a data field, when you <b>read</b> the system time, OB 150 transfers the current data to the data field. You can set up this data field in a <b>data block</b> or in one of the two <b>flag areas</b> (F or S flags).<br>The data field consists of four words. |                          |      |  |  |
|                                          | 1a) <u>Format of the data field for <b>setting</b></u>                                                                                                                                                                                                                                                                                 | the hardware clock       |      |  |  |
| Bit no.                                  | 15 12 11 8                                                                                                                                                                                                                                                                                                                             | 7 4                      | 3 0  |  |  |
| 1st word                                 | Seconds                                                                                                                                                                                                                                                                                                                                | C                        | )    |  |  |
| 2nd word                                 | Format Hours                                                                                                                                                                                                                                                                                                                           | Minut                    | es   |  |  |
| 3rd word                                 | Day of month                                                                                                                                                                                                                                                                                                                           | Weekday                  | 0    |  |  |
| 4th word                                 | Year                                                                                                                                                                                                                                                                                                                                   | Mon                      | th   |  |  |

| Bit no.  | 15           | 12 11 | 8              | 7 4 | 3 | 0 |
|----------|--------------|-------|----------------|-----|---|---|
| 1st word | Seconds      |       | 1/100th second |     |   |   |
| 2nd word | Format Hours |       | Minutes        |     |   |   |
| 3rd word | Day of month |       | Weekday        | 0   |   |   |
| 4th word | Year         |       | Month          |     |   |   |

#### 1b) Format of the data field when reading the hardware clock

The time parameters have the following meaning, permitted range of values and representation:

| Parameter                                                                                                    | Permitted range of values                                                                                                                                                                        | Representation |
|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Seconds<br>1/100<br>seconds<br>Minutes<br>Hours<br>Weekday<br>Day of<br>month <sup>1)</sup><br>Month<br>Year | 00 to 59<br>00 to 99<br>00 to 59<br>00 to 23 or 01 to 12 depending on selected format<br>0 to 6 where Mo = 0,, Su = 6<br>01 to 31 <sup>1)</sup><br>01 to 12<br>00 to 99                          | BCD format     |
| Format                                                                                                       | The format for the hour field is as follows:<br>Bit 15 = 1: 24 hour format (bit 14 = 0)<br>Bit 15 = 0: 12 hour format<br>(select "am" or "pm" in bit 14)<br>Bit 14 = 0: "am"<br>Bit 14 = 1: "pm" |                |

<sup>1)</sup> The value you input is checked to ensure that the date is logically correct taking into account leap years after OB 150 is called.

#### Data field in the flag area

If you set up the data field in a flag area, you must take into account the following assignment of data field words to flag bytes. "x" is the parameter "number of the first data field word" (see following page) that you must enter in ACCU-1-L when OB 150 is called.

| Bit no.             | 15 8          | 7 0           |
|---------------------|---------------|---------------|
| 1st data field word | flag byte x   | flag byte x+1 |
| 2nd data field word | flag byte x+2 | flag byte x+3 |
| 3rd data field word | flag byte x+4 | flag byte x+5 |
| 4th data field word | flag byte x+6 | flag byte x+7 |

2. Accus

ACCU-2-L

ACCU-2-L contains information on the desired function and the data field used. It must have the following structure:

| Bit no. | 15                                                                        | 12                                                                                            | 11                                 | 8                                                                                                                                               | 7      |         |   | 1   |       | I | 0 |
|---------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|---|-----|-------|---|---|
|         | Function no. Address area ty                                              |                                                                                               |                                    | type Data block no.                                                                                                                             |        |         |   |     |       |   |   |
|         |                                                                           | Parame                                                                                        | ters in ACCU                       | - <u>2-L</u>                                                                                                                                    |        |         |   |     |       |   |   |
|         |                                                                           | 1 = set s<br>2 = Rea                                                                          |                                    |                                                                                                                                                 | e      |         |   |     |       |   |   |
|         | Address area type,<br>permitted values:                                   |                                                                                               |                                    | 1 = DB data block<br>2 = DX data block<br>3 = F flag area<br>4 = S flag area                                                                    |        |         |   |     |       |   |   |
|         | Data block number,<br>permitted values: 3 to 255<br>(only fo<br>irrelevan |                                                                                               |                                    |                                                                                                                                                 | or add |         |   |     | or 4) |   |   |
|         |                                                                           | ACCU-1                                                                                        | <u>l-L</u>                         |                                                                                                                                                 |        |         |   |     |       |   |   |
|         |                                                                           | Number of the 1st data field word,<br>possible value (dependent on the<br>address area type): |                                    |                                                                                                                                                 |        |         |   |     |       |   |   |
|         |                                                                           | uuuross                                                                                       | area type).                        | DB, DX: 0 to 2044<br>F flags : 0 to 248<br>(= no. of flag byte 'x')                                                                             |        |         |   | x') |       |   |   |
|         |                                                                           |                                                                                               |                                    | S flags                                                                                                                                         | :      | 0 to 10 | - | -   | ,     |   |   |
| Result  |                                                                           |                                                                                               | 3 150 has beer<br>= 0. All other o | -                                                                                                                                               |        | • ·     |   |     |       |   |   |
| Possibl | e errors                                                                  | loaded, t                                                                                     | the CPU goes                       | rror, <b>OB 19 or OB 31</b> is called. If OB 19 or OB 31 is not<br>bes to the stop mode.<br>IDs are entered in ACCU 1 and ACCU 2 (see following |        |         |   |     |       |   |   |

| ACCU-1-L | ACCU-2-L       | Cause of error                                | OB called |
|----------|----------------|-----------------------------------------------|-----------|
| 1A07H    | -              | Data block not loaded                         | OB 19     |
| 1A4CH    | 0001H          | Function no. = $0 \text{ or } > 2$            | OB 31     |
|          | 0100H          | Address area type illegal                     |           |
|          | 0101H          | Data block number illegal                     |           |
|          | 0102H          | "Number of the first data field word" illegal |           |
|          | 010 <b>3</b> H | Data block length in block header < 5 words   |           |
|          | 0201H          | Year specified in data field illegal          |           |
|          | 0202H          | Month specified in data field illegal         |           |
|          | 0203H          | Day of month specified in data field illegal  |           |
|          | 0204H          | Weekday specified in data field illegal       |           |
|          | 0205H          | Hour specified in data field illegal          |           |
|          | 0206H          | Minute specified in data field illegal        |           |
|          | 0207H          | Second specified in data field illegal        |           |
|          | 0208H          | 1/100 second in data field not equal to 0     |           |
|          | 0209H          | Data field word 3 / bit no. 0 to $3 \neq 0$   |           |
|          | 020AH          | Hour format not the same as setting in OB 151 |           |

#### Note

If you select incorrect parameters when setting the system time, and if the time has been set correctly at least once, the error IDs are transferred, however, the previously set system time is retained.

#### Example

"Setting the time"
You want to set the system time as follows:
"Thurs, 24.11.1991, 11:30, 0 seconds, 24 hour format"
It is assumed that the time parameters will be stored in data block
DB 10 from data word DW 0 onwards. The system time should be set accurate to the second by triggering a process interrupt (trigger bit, e.g. I 1.0 - button in the vicinity of the PLC).
First, program data block DB 10 with the following values and load it in the PLC. You must include the STEP 5 operations for calling OB 150 in OB 1 in such a way that the operations for calling OB 151 are only executed in the case of a rising edge of the trigger bit:

Continued on the next page

```
"Setting the time":
                          (continued)
DB 10
     0: KH= 0 0 0 0 left byte = seconds (BCD), right byte = 0
     1: KH= 9 1 3 0 91 = format (=80H) + hour (= 11 BCD)
                     30 minutes (BCD)
     2: KH = 2 4 3 0 24 = day of the month (BCD)
                     30 = day of week (3 = Thursday) + bit 0 to bit 3 = 0
     3: KH= 9 1 1 0 93 = year (BCD)
                     10 = month (BCD)
The STEP 5 operations in OB 1 for calling for OB 150 are as follows:
                     Signal edge of the input for setting the system
     :
                     time has occurred
STELL:L KH1 1 0 A
                     Values for ACCU-2-L:
                    Address area type = 1 for "data field in DB"
     :
                   - Function number = 1 for "set"
     :
     :
                     ACCU-1-L:
     :L KF +0
                     Number of the 1st data field word = 0
                     Call OB 150
     :JU OB 150
     :
```

```
"Reading the system time":
You want to write the current system time to data block DB 10 from data word
DW 4. You must therefore call OB 150 with the following parameters:
     :
     :L KH 2 1 0 A
                      Values for ACCU-2-L:
                        DB no. = 10
     :
                        Address area type = 1 for "data field in DB"
     :
                        Function no. = 2 for "read"
     :
     :
                        ACCU-1-L
     :L KF +4
                        Number of 1st data field word = 4
     :
                        Call OB 150
     :JU OB 150
     :C DB 10
                        Open DB 10
                        Evaluate DB 10
     :
After calling OB 150, the actual system time is stored in the following form
in the data block DB 10 ("Thurs, 24.10.93, 11:30, 20 seconds, 13 hundredths,
24 hour format"):
  DW 4:
          KH = 2 \ 0 \ 1 \ 3
                          Seconds = 20 (BCD)
                          1/100 seconds = 13 (BCD)
                          Format = 24 hour (bits 14/15 = 01), hours = 11
  DW 5:
          KH= 9 1 3 0
                          (BCD), Minutes = 30 (BCD)
          KH= 2 4 3 0
  DW 6:
                          Day of month = 24 (BCD)
                          Day of week = 3 = Thursday
  DW 7:
          KH= 9 1 1 0
                          Year = 93 (BCD)
                          Month = 10 (BCD)
```

## 6.11 OB 151: Setting/Reading the Time for Clock-Driven Interrupts

|            |                                                                                                                                                                                                                                                                                                                                                             | J, J                                                                                                                                                                                         |                   |          |                 |  |  |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------|-----------------|--|--|
| Function   | Вус                                                                                                                                                                                                                                                                                                                                                         | calling OB 151 you can perfor                                                                                                                                                                | m the following   | :        |                 |  |  |
|            | i<br>-<br>-<br>-<br>-<br>-                                                                                                                                                                                                                                                                                                                                  | brogram the CPU 928B, to act<br>nterrupt ("Time job" - OB 9, so<br>preset time :<br>• every minute<br>• every hour<br>• every day<br>• every week<br>• every wonth<br>• every year<br>• once |                   |          | ne              |  |  |
|            | • 1                                                                                                                                                                                                                                                                                                                                                         | read out the current status of a                                                                                                                                                             | timed job         |          |                 |  |  |
|            | • (                                                                                                                                                                                                                                                                                                                                                         | cancel a previously generated                                                                                                                                                                | timed job         |          |                 |  |  |
|            | cloc                                                                                                                                                                                                                                                                                                                                                        | can call OB 151 in the mode<br>k-controlled time interrupt is<br>omatic or manual). A COLD                                                                                                   | retained followin | ng a WAl | RM RESTART      |  |  |
|            | auto                                                                                                                                                                                                                                                                                                                                                        | ou generate a new timed job, a<br>matically cancelled. This mea<br>be active.                                                                                                                |                   |          |                 |  |  |
| Parameters | 1. D                                                                                                                                                                                                                                                                                                                                                        | ata Field for Job Parameter                                                                                                                                                                  | 'S                |          |                 |  |  |
|            | <ul> <li>When you generate or cancel a timed job, OB 151 takes the required job parameters from a data field.</li> <li>When you read out the current status of a timed job, OB 151 transfers the current job parameters to a data field.</li> <li>You can set up this data field in a data block or in one of the two flag areas (F or S flags).</li> </ul> |                                                                                                                                                                                              |                   |          |                 |  |  |
|            |                                                                                                                                                                                                                                                                                                                                                             | data field consists of four wo<br>erating and reading out a time                                                                                                                             |                   | ollowing | format for both |  |  |
| Bit no.    | 15                                                                                                                                                                                                                                                                                                                                                          | 12 11                                                                                                                                                                                        | 8 7               | 4        | 3 0             |  |  |
| 1st word   |                                                                                                                                                                                                                                                                                                                                                             | Seconds                                                                                                                                                                                      |                   | C        | )               |  |  |
| 2nd word   | Format                                                                                                                                                                                                                                                                                                                                                      | Hours                                                                                                                                                                                        |                   | Minutes  |                 |  |  |
| 3rd word   |                                                                                                                                                                                                                                                                                                                                                             | Day of month                                                                                                                                                                                 | Weekday           |          | Job type        |  |  |
| 4th word   |                                                                                                                                                                                                                                                                                                                                                             | Year                                                                                                                                                                                         |                   | Month    |                 |  |  |

| Parameter                                                                                             | Permissible range of values                                                                                                                                                                           | Representation |
|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Job type                                                                                              | 0 to 7 where:<br>0 = cancel job or no<br>job active<br>1 = every minute<br>2 = every hour<br>3 = every day<br>4 = every week<br>5 = every month<br>6 = every year<br>7 = once                         | BCD format     |
| Seconds<br>1/100 second<br>Minutes<br>Hours<br>Weekday<br>Day of month <sup>1)</sup><br>Month<br>Year | 00 to 59<br>00 to 99<br>00 to 59<br>00 to 23 or 01 to 12 depending on the selected<br>format<br>0 to 6 where Mo = 0,, Su = 6<br>01 to 31 <sup>1)</sup><br>01 to 12<br>00 to 99                        | BCD format     |
| Format <sup>2)</sup>                                                                                  | The format of the hour field is as follows:<br>Bit 15 = 1: 24 hour format<br>(bit 14 = 0)<br>Bit 15 = 0: 12 hour format<br>(select "am" or<br>"pm" in bit 14)<br>Bit 14 = 0: "am"<br>Bit 14 = 1: "pm" |                |

The parameters have the following meanings, permissible value ranges and representations:

 After calling OB 151, the value specified is checked to ensure it is logically correct taking into account leap years.

#### Data field in the flag area

When you set up the data field in a flag area, you must take into account the following assignment of the data field words to the flag bytes. "x" is the parameter "number of the first data field word" that you must enter in ACCU-1-L when OB 151 is called.

| Bit no.             | 15            | 8 | 7 0           | 0 |
|---------------------|---------------|---|---------------|---|
| 1st data field word | flag byte x   |   | flag byte x+1 |   |
| 2nd data field word | flag byte x+2 |   | flag byte x+3 |   |
| 3rd data field word | flag byte x+4 |   | flag byte x+5 |   |
| 4th data field word | flag byte x+6 |   | flag byte x+7 |   |

<sup>&</sup>lt;sup>2)</sup> For the significance of "am" and "pm", see OB 150 in the previous section: "Format" must agree with the format set for the system time in OB 150.

#### 2. Accus

#### ACCU-2-L

ACCU-2-L contains information on the desired function and the data field used. It must have the following structure:

| Bit no. | 15           | 12 | 11    | 1             | 8 | 7 | I   | I         | I  | I | I | 0 |
|---------|--------------|----|-------|---------------|---|---|-----|-----------|----|---|---|---|
|         | Function no. | ·  | Addre | ess area type |   |   | Dat | a block n | o. |   | · |   |

#### Parameters in ACCU-2-L

| Function number, permitted values:      | 1 = generate<br>2 = read job                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Address area type,<br>permitted values: | 1 = DB data<br>2 = DX data<br>3 = F flag an<br>4 = S flag an                                                                                                          | a block<br>rea                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                                         | er,<br>3 to 255 (for address area type = 1 or 2;<br>irrelevant for address area type 3 or 4                                                                           |                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| ACCU-1-L                                |                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| possible values (depend                 | · · · ·                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|                                         | DB, DX:                                                                                                                                                               | 0 to 2044                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|                                         | · ·                                                                                                                                                                   | 0 to 248                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|                                         | U                                                                                                                                                                     | (= no. of flag byte 'x')                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|                                         | S flags:                                                                                                                                                              | 0 to 1016                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|                                         |                                                                                                                                                                       | (= no. of flag byte 'x')                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|                                         |                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|                                         | permitted values:<br>Address area type,<br>permitted values:<br>Data block number,<br>permitted values: 3 to 2<br>irrele<br><u>ACCU-1-L</u><br>Number of the 1st data | permitted values: $1 = generate2 = read jobAddress area type,permitted values:1 = DB data2 = DX data3 = F flag at4 = S flag at4 = S flag atpermitted values:Data block number,permitted values:3 to 255 (for addressirrelevant for addressACCU-1-LNumber of the 1st data field word,possible values (dependent on theaddress area type):DB, DX:F flags:$ |  |  |  |  |

**Result** After OB 150 has been processed correctly, the condition code bits OR, ERAB and OS = 0. All other condition code bits remain unchanged, as do ACCU 1 and ACCU 2.

|                 | <ul> <li>Note</li> <li>If the job type "0" is set in the data field and all other parameters are "F" or "FF" (hexadecimal) when you read out a timed job, then no timed job is active.</li> <li>This status can occur: <ul> <li>following a COLD RESTART, when no timed job is generated,</li> <li>when a timed job programmed to be executed only once has been executed, or</li> <li>when you have cancelled a job.</li> </ul> </li> </ul> |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Possible errors | In the event of an error, <b>OB 19</b> or <b>OB 31</b> is called. If OB 19 or OB 31 is not                                                                                                                                                                                                                                                                                                                                                   |

**e errors** In the event of an error, **OB 19** or **OB 31** is called. If OB 19 or OB 31 is not loaded, the CPU goes to the stop mode. In both cases, error IDs are entered in ACCU 1 and ACCU 2 (see following table).

Table 6-3OB 151 error IDs

| ACCU-1-L | ACCU-2-L       | Cause of error                                | OB called |
|----------|----------------|-----------------------------------------------|-----------|
| 1A07H    | -              | Data block not loaded                         | OB 19     |
| 1A4DH    | 0001H          | Function no. = $0 \text{ or } > 2$            | OB 31     |
|          | 0100H          | Address area type illegal                     |           |
|          | 0101H          | Data block number illegal                     |           |
|          | 0102H          | "Number of the first data field word" illegal |           |
|          | 010 <b>3</b> H | Data block length in block header < 5 words   |           |
|          | 0201H          | Year specified in data field illegal          |           |
|          | 0202H          | Month specified in data field illegal         |           |
|          | 0203H          | Day of month specified in data field illegal  |           |
|          | 0204H          | Weekday specified in data field illegal       |           |
|          | 0205H          | Hour specified in data field illegal          |           |
|          | 0206H          | Minute specified in data field illegal        |           |
|          | 0207H          | Second specified in data field illegal        |           |
|          | 0208H          | 1/100 second in data field not equal to 0     |           |
|          | 0209H          | Job type in data field > 7                    |           |
|          | 020AH          | Hour format not the same as setting in OB 150 |           |

#### Note

If you assign incorrect parameters **and** a valid timed job has already been generated, the error identifiers are transferred as indicated above, **however**, the previously generated timed job is retained.

#### Important points concerning time parameters

Depending on when you want to trigger a clock-driven time interrupt (timed job) you must select the individual time parameters in certain combinations. Depending on the time you select for the clock-driven time interrupt, you must specify certain parameters, while others are not evaluated by the system program and can therefore be ignored.

The following table indicates which time parameters must be specified for which timed job (XXX = must be specified, --- = irrelevant).

| Time of interrupt | Seconds | Minutes | Hours | Week-<br>day | Day of<br>month | Month | Year |
|-------------------|---------|---------|-------|--------------|-----------------|-------|------|
| every minute      | XXX     |         |       |              |                 |       |      |
| every hour        | XXX     | XXX     |       |              |                 |       |      |
| every day         | XXX     | XXX     | XXX   |              |                 |       |      |
| every week        | XXX     | XXX     | XXX   | XXX          |                 |       |      |
| every month       | XXX     | XXX     | XXX   |              | XXX             |       |      |
| every year        | XXX     | XXX     | XXX   |              | XXX             | XXX   |      |
| once              | XXX     | XXX     | XXX   |              | XXX             | XXX   | XXX  |

| Table 6-4  | "Time job - Time | narameter" | assignments |
|------------|------------------|------------|-------------|
| 1 4010 0-4 |                  | parameter  | assignments |

- If you select the job type "every year" (= 6) and select "February 29th" as the day of the month and month, then OB 9 will only be called every leap year.
  - If you select the job type "every month" (= 5) and select the value "29", "30" or "31" then OB 9 will only be called in the months containing these dates.

**Examples** 

```
Various timed jobs (24 hour format):
1. "Job at the 29th second of every minute"
     (12:44:29, 12:45:29 etc):
  You must specify the following:
                                          job type = 1 (Function no. in
                                                       ACCU-2-L = 1)
                                          seconds = 29
2. "Job every hour at xx:14:15":
                                          job type = 2 (Function no. in
  You must specify the following:
                                                       ACCU-2-L = 1)
                                          seconds = 15
                                          minutes = 14
3. "Job daily at 5:32:47"
                                                          3 (Function no. in
  You must specify the following:
                                          job type =
                                                          ACCU-2-L = 1)
                                          seconds =
                                                          47
                                          minutes =
                                                          32
                                          hours =
                                                          05
4. "Job every week at 10:50:00":
  You must specify the following:
                                                          4 (Function no. in
                                          job type =
                                                          ACCU-2-L = 1)
                                          seconds =
                                                          00
                                          minutes =
                                                          50
                                          hours =
                                                          10
                                          weekday=
                                                          01
5. "Job every month, on the 14th at 7:30:15":
  You must specify the following:
                                                          5 (Function no. in
                                          job type =
                                                          ACCU-2-L = 1)
                                          seconds =
                                                          15
                                          minutes =
                                                          30
                                          hours =
                                                          07
                                          day of month=
                                                          14
6. "Job every year, on May 1st at 00:01:45":
  You must specify the following:
                                          job type =
                                                          6 (Function no. in
                                                           ACCU-2-L = 1)
                                          seconds =
                                                          45
                                          minutes =
                                                          01
                                          hours =
                                                          00
                                          day of month=
                                                          01
                                          month =
                                                          05
                                          Continued on the nex page
```

```
Various timed jobs (24 hour format): (continued)
7. "Job on December 31st 1999 at 23:55:00":
  You must specify the following:
                                        job type =
                                                      7 (Function no. in
                                                       ACCU-2-L = 1)
                                        seconds =
                                                       00
                                        minutes =
                                                       55
                                        hours =
                                                       23
                                        day of month=
                                                      31
                                        month =
                                                       12
                                        year =
                                                       99
8. "Cancel job":
  You must specify the following: job type = 0 (Function no. in
                                                     ACCU-2-L = 1)
9. "Read out timed job":
  You must specify the following: function no. in ACCU-2-L = 2
If no job is active, you receive the following result in the data field:
          Data field word 0:
                                        FFFF H
          Data field word 1:
                                        FFFF H
          Data field word 2:
                                        FFFO H
          Data field word 3:
                                        FFFF H
```

## 6.12 OB 152: Cycle Statistics

**Introduction** A series of statistical data relating to the duration of the cycle can be recorded in the CPU 928B (cycle statistics). Using OB 152, you can initialize the cycle statistics, read out the statistical data and enable and disable the recording of statistical data.

**Overview** The statistical data include the following:

- the duration of the previous cycle,
- the time elapsed in the currently active cycle since the last cycle boundary,
- the minimum and maximum cycle time since the last initialization of the cycle statistics,
- the number of cycles since the last initialization of the cycle statistics,
- the average cycle time: a maximum of the last 256 cycles recorded in the statistics are used to calculate the average value.

#### Note

Only "normal" cycles are recorded in the cycle statistics. If the recording of the duration of the current cycle would falsify the cycle statistics, e.g. owing to a WARM RESTART, these data are **not** included in the statistics. This means that "mavericks" do not affect the statistics.

If the cycle time exceeds 167 seconds, erroneous data will be recorded for the statistics.

Enabling/disabling<br/>the statisticsFollowing a COLD RESTART (automatic or manual), the statistics function is<br/>always disabled and the statistical data are deleted (the cycle statistics are<br/>initialized). A WARM RESTART (automatic or manual) does not affect the<br/>statistics function or the statistical data.

You can activate the statistics function in the RESTART or RUN modes using OB 152.

If the statistics function is enabled with OB 152, the statistical data are updated at each cycle boundary and you can read them out by calling OB 152.

If you no longer require the statistics function, you can disable the function in the RESTART or RUN modes, once again using OB 152. This reduces the cycle time load caused by the updating of the cycle data at each cycle boundary.

You can also initialize the cycle statistics using OB 152 in the RESTART or RUN modes. It may, for example, be useful to initialize the cycle statistics after evaluating the statistical data (possibly also dependent on the value of the cycle counter).

# **Statistical data** The statistical data are read out directly as individual values using OB 152 or calculated when OB 152 is called. They are transferred by OB 152 to ACCU-1-L or ACCU-2-L.

You can determine the following statistical values by calling OB 152:

Table 6-5 Cycle statistics variables - OB 152

| Statistical value | Significance                                                                                      | Format             | Unit             | Range of values |
|-------------------|---------------------------------------------------------------------------------------------------|--------------------|------------------|-----------------|
| CURCYC            | Time already elapsed in the current cycle                                                         |                    |                  |                 |
| LASTCYC           | Duration of the last completed cycle                                                              |                    |                  |                 |
| MINCYC            | Duration of the shortest cycle since the last initialization of the cycle statistics              |                    | 2)               | 2)              |
| MAXCYC            | Duration of the longest cycle since the last initialization of the cycle statistics               | Hexadecimal number |                  |                 |
| AVERAGE           | Average of the cycle times of the last (maximum 256) cycles <sup>1)</sup>                         |                    |                  |                 |
| CYCLE<br>COUNTER  | Number of cycles recorded in the statistics since the last initialization of the cycle statistics |                    | Number of cycles | 0 to<br>0FFFFH  |
| 10 μs<br>COUNTER  | Continuously running counter                                                                      |                    | 10 µs            | 3)              |

see "Calculation of the average value"
 For the function numbers 1, 2 and 3, the

<sup>9</sup> For the function numbers 1, 2 and 3, the unit is milliseconds and the value range runs from 0 to 0FFFFH (in the low word of the accumulators). For the function numbers 5, 6 and 7, the unit is 10 ms and the value range runs from 0 to 0FF FFFFH

(in the high and low words of the accumulators).

<sup>3)</sup> The 10 ms COUNTER is displayed as an 8-digit hexadecimal value in the high and low words of ACCU 1.

| Calculation of the average value | The average value is calculated by OB 152 using the following algorithm:                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                  | Each time the statistical data are updated, the value of LASTCYC is entered into<br>an internal system buffer each time the statistical data are updated. This buffer<br>can take a maximum of 256 values. If the buffer is full, the oldest LASTCYC<br>value is lost and the newest value is entered. During the updating of the data, the<br>sum of the LASTCYC values in the buffer is formed so that it always contains<br>the <b>most recent LASTCYC values</b> (maximum 256). |
|                                  | When OB 152 is called, the average value is formed by dividing the total by the number of LASTCYC values stored in the buffer. In practical terms, this means that the average value is almost always formed from the LASTCYC values of the <b>last 256 cycles</b> .                                                                                                                                                                                                                |

*Functions* When OB 152 is called, you can activate the following individual functions by means of a function number:

| Table 0-0    |                                                  |  |  |  |
|--------------|--------------------------------------------------|--|--|--|
| Function no. | Function                                         |  |  |  |
| 0            | Disable cycle statistics                         |  |  |  |
| 1            | 1 Read CURCYC / LASTCYC, values in ms            |  |  |  |
| 2            | Read MINCYC / MAXCYC, values in ms               |  |  |  |
| 3            | Read AVERAGE VALUE / CYCLE COUNTER, values in ms |  |  |  |
| 5            | Read CURCYC, values in 10 µs                     |  |  |  |
| 6            | Read MINCYC/MAXCYC, values in 10 µs              |  |  |  |
| 7            | Read AVERAGE/CYCLE COUNTER, values in 10 µs      |  |  |  |
| 8            | Initialize cycle statistics                      |  |  |  |
| 9            | Read 10 µs COUNTER                               |  |  |  |
| 15           | Enable cycle statistics                          |  |  |  |

| Table 6-6 | OB 153 functions |
|-----------|------------------|
|           | OD 155 Iunchons  |

Parameters AC

#### ACCU-1-L

ACCU-1-L contains the function no.; it must have the following structure:

| Bit no. | 15 |   |  | 4 | 3      |        | 0 |  |
|---------|----|---|--|---|--------|--------|---|--|
|         |    | 0 |  |   | Functi | on no. | - |  |

Function no., permitted values: see table 6-5

Bit nos. 4 to 15 must always be 0!

**Result** After OB 152 is called, the condition codes OS, OR and  $\overline{\text{ERAB}} = '0'$ , the RLO is also 0 except in the cases listed below. In addition to this, the statistical values requested by some functions are transferred to ACCU-1-L and ACCU-2-L with some functions (see the following table).

#### Table 6-7 Results of the OB 152 functions

| Function                           |                        | Results of             | Results of the functions                                                                              |  |  |  |
|------------------------------------|------------------------|------------------------|-------------------------------------------------------------------------------------------------------|--|--|--|
|                                    | ACCU-1-L               | ACCU-2-L               | Significance of "RLO = 1"                                                                             |  |  |  |
| Disable cycle statistics           | Unch                   | anged                  |                                                                                                       |  |  |  |
| Read CURCYC / LASTCYC              | CURCYC<br>3)           | LASTCYC                | CURCYC is incorrect, the data<br>of the current cycle are not<br>used in the statistics <sup>1)</sup> |  |  |  |
|                                    |                        |                        | or                                                                                                    |  |  |  |
|                                    |                        |                        | Result of function no. 1 is out<br>of permitted range (> FFFFH),<br>FFFFH is the default value        |  |  |  |
| Read MINCYC / MAXCYC               | MINCYC<br>3)           | MAXCYC<br>3)           | Result of function no. 2 is out<br>of permitted range (> FFFFH),<br>FFFFH is the default value        |  |  |  |
| Read AVERAGE VALUE / CYCLE COUNTER | AVERAGE<br>VALUE<br>3) | CYCLE<br>COUNTER<br>3) | CYCLE COUNTER overflow 2)                                                                             |  |  |  |
|                                    |                        |                        | or                                                                                                    |  |  |  |
|                                    |                        |                        | Result of function no. 3 is out<br>of permitted range (> FFFFH),<br>FFFFH is the default value        |  |  |  |
| Initialize cycle statistics        | Unchanged              |                        |                                                                                                       |  |  |  |
| 10 μs COUNTER                      | 10 μs<br>COUNTER       |                        |                                                                                                       |  |  |  |
| Enable cycle statistics            | Unch                   | anged                  |                                                                                                       |  |  |  |

<sup>1)</sup> Due to a WARM RESTART

<sup>3)</sup> In the case of function numbers 1, 2 and 3 in the low word and in the case of function numbers 5, 6, 7 and 9 in the high and in the low word of the accumulators.

**Possible errors** An error occurs if an incorrect function no. is transferred to ACCU-1-L (only the numbers 0 to 3, 8 and 15 are permissible).

In the event of an error, **OB 31** (other runtime errors) is called. If OB 31 is not loaded, the CPU goes to the stop mode.

In both cases, the error ID **1A4EH** is entered in ACCU-1-L and **0001H** is entered in ACCU-2-L.

<sup>&</sup>lt;sup>2)</sup> If RLO = 1 is set when you read out the cycle counter, then when the condition code is transferred, a system internal flag for cycle overflow is cleared. This flag is then only set again when the cycle counter overflows again.

**Special Features** This section explains several special features of OB 152 during a COLD RESTART, following a RESTART or when certain events occur and you should take note of these points if you want to use OB 152.

#### • Reaction to a COLD RESTART

The statistical data are initialized during a COLD RESTART. Calling OB 152 in the first cycle following COLD RESTART reestablishes the initialization data.

The following table shows how the statistical data are

- initialized following a COLD RESTART

and

- modified during the first three cycles by the system program.



<sup>1)</sup> The value for CURCYC is always read out via OB 152, the cycle monitoring timer. For this reason, it is already available during the first cycle.

<sup>2)</sup> Initialization value (= 00FFFFH ms or 0FF FFFFH x 10  $\mu$ s)

When the statistical data are initialized, not only the defaults listed in the table, but also the internal system buffer for the average are deleted and an internal flag for cycle counter overflow is reset.

#### • Calling OB 152 in a start-up OB

Depending on the type of restart, the OB 152 call to read the statistical data provides the following values in ACCU-1-L and ACCU-2-L (columns on a gray background).



<sup>1)</sup> Initialization value (= 00FFFFH ms or 0FF FFFFH x 10  $\mu$ s)

#### • Initializing the statistical data by calling OB 152

The following table shows how the statistical data are changed when they are initialized by calling OB 152 in the CYCLE. The columns with a gray background contain the values transferred when the statistical data are read.



<sup>1)</sup> Initialization value (= 00FFFFH ms or 0FF FFFFH x 10  $\mu$ s)

When the statistical data are initialized, not only the defaults listed in the table, but also the system internal buffer for forming the average value is deleted and an internal flag for cycle counter overflow is reset.

After the statistical data are initialized by calling OB 152, the data are only updated by the system program at the **end** of the first cycle **after** the initialization.

#### • Calling OB 152 when the cycle statistics are disabled

If you disable the cycle statistics by calling OB 152, the statistical data **of the last update** are retained. If you then use OB 152 to read the statistical data, it supplies the data from the last update before the statistics were disabled.

If you read the statistical data following a COLD RESTART, without enabling the cycle statistics with an OB 152 call, OB 152 supplies the initialization data.

Falsifying the<br/>statistical dataCertain events can cause problems when recording the cycle length of the current<br/>cycle and can lead to incorrect values. In these situations, the statistical data for<br/>the cycle affected are not updated.



1) The value of CURCYC corresponds to the time T that has elapsed since the occurrence of the "problem" in the current cycle. This is not the length of the whole cycle. To indicate this situation, the RLO is set to "1" in addition to the values transferred to ACCU-1-L and ACCU-2-L.

## 6.13 OB 153: Set/Read Time for Delay Interrupt

| Introduction | Using OB 153, you can transfer so-called "delay jobs" to the system program.<br>After a specified delay time "a delay interrupt" is then processed (refer to OB 6,<br>Section 4.5).                                                                                                                                                                                                                                         |                                                                                                                         |  |  |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--|--|
| Function     | <ul> <li>By calling OB 153, you can do the following:</li> <li>define and start a delay time,</li> <li>stop an activated delay time (cancel delay job),</li> <li>read how long the delay time still has to run.</li> <li>A delay job can be activated by OB 153 in the RESTART and RUN modes.</li> <li>Life of a delay job</li> <li>The delay interrupt triggered by a delay job is only activated by the system</li> </ul> |                                                                                                                         |  |  |
|              | program in the <b>RUN</b> mode (OB 6 call). Jobs which become due in a mode other<br>than RUN are discarded by the system program <b>without any message</b> .<br>A currently active (but not yet due) job is also discarded if the CPU changes to<br>the STOP mode or if the power is switched off.                                                                                                                        |                                                                                                                         |  |  |
| Parameters   | delay time") when OB 1<br>evaluated in the remaini<br><u>ACCU-1-L</u><br>Function no.<br>Permitted values:                                                                                                                                                                                                                                                                                                                  | 0001H to FFFFH<br>o be supplied with the function number '1' ("define<br>53 is called. The contents of ACCU-2-L are not |  |  |
|              | Note                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                         |  |  |

If a previously defined delay time is not yet elapsed when a further delay time is defined, the previously defined time is lost and the new delay time started. **Result** After correct processing of OB 153, the condition code bits OR,  $\overline{\text{ERAB}}$  and OS = 0.

When OB 153 is called with the function no. '2' or '3', ACCU-1-L contains the remaining time to run in milliseconds.

If no delay job is active when OB 153 is called with function no. '2' or '3', ACCU-1-L contains the value '0'.

**Possible errors**The errors listed in the following table can occur.<br/>OB 31 (other runtime errors) is called. If OB 31 is not loaded, the CPU goes to<br/>the STOP mode.

In both cases, error IDs are entered in ACCU-1-L and ACCU-2-L (see the table below).

Table 6-8 OB 153 error IDs

| ACCU-1-L | ACCU-2-L       | Significance                                 |
|----------|----------------|----------------------------------------------|
| 1A4FH    | 0001H<br>0002H | Function no. = 0 or >3<br>Illegal delay time |

Examples

```
Define and start delay time:
When an AUTOMATIC WARM RESTART is performed, after 5 seconds a certain STEP
5 operation sequence must be run through once. To do this, the delay time
is defined and started in start-up organization block OB 22.
The STEP 5 operations in OB 22 for calling OB 153:
     :
     :
     :L KF +5000
                     Value for ACCU-2-L: 5000 ms
     :L KF +1
                     Value for ACCU-1-L: function no. = 1 for
                     "define and start delay time"
     :
     :JU OB 153
                    Call OB 153
     :
```

```
Read out remaining time of a delay job:

STEP 5 operations for calling OB 153:

:

:L KF +3 Value for ACCU-1-L: function no. = 3 for

: "read out remaining time"

:JU OB 153 Call OB 153

:

: ACCU-1-L contains the time the delay job still

has to run.
```

## 6.14 OB 160 to 163: Loop Counters

| Introduction                                                     | By using these special function operation blocks, you can implement program loops with a particularly fast runtime.                                                                                                                                                                             |  |  |  |  |
|------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Function                                                         | A system data word is assigned to each of the four special function OBs as follows:                                                                                                                                                                                                             |  |  |  |  |
|                                                                  | • RS 60: OB 160                                                                                                                                                                                                                                                                                 |  |  |  |  |
|                                                                  | • RS 61: OB 161                                                                                                                                                                                                                                                                                 |  |  |  |  |
|                                                                  | • RS 62: OB 162                                                                                                                                                                                                                                                                                 |  |  |  |  |
|                                                                  | • RS 63: OB 163                                                                                                                                                                                                                                                                                 |  |  |  |  |
| Programming the program loop                                     | You transfer the value for the required number of loop repetitions to one of these system data words. When you then call the appropriate special function OB, the loop counter in the system data word is decremented by 1. The loop is repeated until the loop counter reaches the value zero. |  |  |  |  |
|                                                                  | <b>Note</b><br>If the loop counter is already zero before the special function OB is called,<br>it is decremented by 1; the loop is then run through 65,536 times.                                                                                                                              |  |  |  |  |
| Parameters                                                       | System data word RS 60 - 63                                                                                                                                                                                                                                                                     |  |  |  |  |
|                                                                  | Loop counters<br>possible values: 0 - 65 535 decimal (0 to FFFFH)                                                                                                                                                                                                                               |  |  |  |  |
| Result                                                           | Loop counter in RLO is set (RLO = 1) system data word >0:                                                                                                                                                                                                                                       |  |  |  |  |
|                                                                  | Loop counter in<br>system data word = 0:RLO is cleared ( $RLO = 0$ )                                                                                                                                                                                                                            |  |  |  |  |
|                                                                  | The other bit and word condition codes are always cleared.                                                                                                                                                                                                                                      |  |  |  |  |
| The accumulators are not changed and not evaluated. This means t |                                                                                                                                                                                                                                                                                                 |  |  |  |  |

still available at the beginning of the next loop and do not need to be set again.

Possible errors none

#### Example

**Programming a loop counter:** The required number of loop repetitions is contained in flag word x. : : Initialize the loop : кво :L MWx Loop counter :L :!=F :JC =M002 :Т RS 62 Transfer loop counter to system data word : : : M001: "Loop program" : . : . : • : Manage loop: : :JU OB162 Loop counter :JC =M001 : : M002: Further: : . : ٠ : • : • :

For a further example, refer to Section 9.2 "TNW and TNB: Transferring Memory Fields".

## 6.15 OB 170: Read Block Stack (BSTACK)

| Introduction | Starting with OB 1 or FB 0, the block stack contains all the blocks that have been called in sequence and that have not yet been completely processed.                                                                                                                                                                                                                                                                                                             |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function     | Using the special function organization block OB 170, you can read the entries currently in the BSTACK into a data block. In this way, you can find out how many entries are currently in the BSTACK and how much space is still available for further entries.<br>For each entry, you obtain the return address (step address counter = SAC), the absolute start address of the data block valid in this block (DBA) and its length (number of data words = DBL). |
|              | Note<br>Before you call OB 170, you must first open a data block (DB or DX) with<br>sufficient length. Four data words are required for each BSTACK entry.                                                                                                                                                                                                                                                                                                         |
| Parameters   | Accus                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|              | ACCU-2-L                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|              | Number of the data word (DW n) from which the entries are to be stored in the open DB (offset)                                                                                                                                                                                                                                                                                                                                                                     |
|              | ACCU-1-L                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|              | Required number of BSTACK elements;<br>Possible values: 1 - 62                                                                                                                                                                                                                                                                                                                                                                                                     |
|              | Example: if ACCU-1-L contains the value "1", you obtain the last BSTACK entry, if it contains "2", you obtain the last and one before last etc.                                                                                                                                                                                                                                                                                                                    |
|              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

Result

#### After OB 170 has been called successfully

- the offset in the data block is still contained in ACCU-2-L
- the actual number of BSTACK elements represented is in ACCU-1-L<sup>1</sup>)
- The RLO is cleared.
- The condition codes CC 0 and CC 1 can be analyzed.
- All other bit and word condition codes are cleared.

<sup>1)</sup> Possible values: 0 - 62, where the represented number is less than or equal to the required number
 0 = "no BSTACK entry exists" or "error"
 (Multiply the contents of ACCU-1-L by four to obtain the number of data words written to the DB).

## RLO, CC 0 and CC 1 settings

| RLO | CC 1 | CC 0 | Scan with | Meaning                                                 |
|-----|------|------|-----------|---------------------------------------------------------|
| 0   | 0    | 1    | ЈМ        | Existing number of BSTACK<br>elements < required number |
| 0   | 0    | 0    | JZ        | Existing number of BSTACK<br>elements = required number |
| 0   | 1    | 0    | JP        | Existing number of BSTACK<br>elements > required number |
| 1   | 1    | 1    | JC        | Error                                                   |

#### Storing the BSTACK elements in open data blocks

The contents of the BSTACK are stored in the data block as follows when OB 170 is called (see Fig. 6-3):

A = BSTACK element number (62 to 1)

(As soon as the last BSTACK element is output you can determine the remaining space: A = 17 reserve = A - 1 = 16)

B = Depth if the BSTACK element (1 to 62)



Fig. 6-3 Storing BSTACK entries in a data block

**Possible errors** The following error events may occur:

- No data block opened
- Opened data block does not exist or is not long enough to take the required number of BSTACK entries
- Illegal parameters in ACCU 1 and ACCU 2

If an error occurs, the RLO and the condition codes CC 0 and CC 1 are set (RLO, CC 0 and CC 1 = 1). The remaining bit and word condition codes are cleared. The contents of ACCU-1-L are set to "0".

#### Example





## 6.16 OB 180: Accessing Variable Data Blocks

| Function         | With OB 180, the starting address of the current data block is shifted by a specified value. In doing so, account is taken of the fact that the remaining available length of the DB has to be reduced (the DBA and DBL registers are loaded in correspondence to the shift).                                                                                                   |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | Note<br>Before you call OB 180, a data block (DB or DX) with an adequate length<br>must already be open.                                                                                                                                                                                                                                                                        |
| DBA/DBL register | When a data block is opened with the operations C DB and CX DX, the DBA register (data block start address) is loaded with the address of data word DW 0, stored in DB 0.                                                                                                                                                                                                       |
|                  | Access to data blocks with operations such as L DR 60 or DO DW 240 etc. are always relative to the data block start address.                                                                                                                                                                                                                                                    |
|                  | In addition to the DBA register, the DBL register (data block length) is always loaded when a data block is called. This register contains the length (in words) of the opened DB or DX data block <b>without</b> the block header.                                                                                                                                             |
|                  | <b>Note</b><br>A maximum of up to 4091 data words can be entered in the DBL register.<br>STEP 5 access to data words is only possible up to a maximum data word<br>number of 255.                                                                                                                                                                                               |
|                  | Example                                                                                                                                                                                                                                                                                                                                                                         |
|                  | The DBA register the address of the memory word in which<br>DW 0 to DB 17 is stored: DBA = 151BH                                                                                                                                                                                                                                                                                |
|                  | The number of data words is stored in the DBL register:<br>DBL = 8 (DW 0 to DW 7)                                                                                                                                                                                                                                                                                               |
|                  | Since access to the data words by means of the STEP 5<br>operations L DW, U D, DO DW etc. is always relative to<br>DBA, 3 is added to 151BH in order to access, e.g. DW 3.<br>Data word DW 3 is stored under the address 151EH.<br>The DBL register is used to check whether a transfer or<br>load operation is pending. T DW 7 is permissible but<br>T DW 8 or L DW 8 are not. |

| Applications of<br>OB 180 | Special function OB 180 allows you to access structured data in an opened data block. You can do this by shifting the starting address of the data block entered in the DBA register to the end of the data block with the help of OB 180. Simultaneously to shifting the starting address, OB 180 decrements the block length entered in the DBL register accordingly. It is important that this is done so that the CPU can monitor load and transfer operations in the case of later accesses to the data block. |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           | • Access to DBs with a length greater than 261 words (five words header) over the whole length of the DB. Using OB 180, you can move an "access window" of 256 data words over the length of the data block.                                                                                                                                                                                                                                                                                                        |
|                           | Handling data structures                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                           | A data block can be divided into several data records of the same length and<br>with the data arranged in the same order. This is known as structuring the<br>data block. A data block structured in this way might, for example, contain<br>the data of several subprocesses, with a temperature value in the first data<br>word, a pressure in the second and other values for the subprocess in the<br>remaining data words.                                                                                     |
|                           | Using OB 180, you can access the data of each subprocess using the same operations (e.g. L DD, S D, T DR etc.), by loading the DBA register with the start address for the subprocess.                                                                                                                                                                                                                                                                                                                              |
|                           | In contrast to other substitution mechanisms, (substitution = indexed parameter assignment) you obtain simpler and faster subroutines.                                                                                                                                                                                                                                                                                                                                                                              |
| Parameters                | ACCU-1-L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                           | offset (number of data words,by which you want to shift the data block start address),possible values: $0 \leq ACCU-1-L < DBL$                                                                                                                                                                                                                                                                                                                                                                                      |
| Result                    | After OB 180 has been called successfully                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                           | • the value of the DBA register (= address of DW 0) is raised by the value of ACCU-1-L                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                           | • the value of the DBL register is reduced by the value of ACCU-1-L                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                           | • the RLO is cleared (RLO = 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

• all other bit and word condition codes are cleared

| Possible errors | The following error events may occur: |
|-----------------|---------------------------------------|
|-----------------|---------------------------------------|

- Negative length
- No data block opened
- Contents of ACCU-1-L  $\ge$  DBL

In the event of an error (ACCU-1-L  $\geq$  DBL) the DBA and DBL registers remain unchanged. The RLO is set (RLO = 1). The remaining bit and word condition codes are cleared.

If the DBL register contains the value "0", OB 180 recognizes that no data block is open. The RLO is set (RLO = 1), signalling an error.

| Resetting DBA  | Opening the data block again using the operations C DB or CX DX, |
|----------------|------------------------------------------------------------------|
| and DBL to the | re-establishes the initial setting.                              |
| initial value  |                                                                  |

#### Example

You want to shift the data block start address (DBA = 151B) in DB 17 (DBL = 8) by two data words. :C DB 17 open DB 17 :L KB 2 shift / offset as constant : JU ОВ 180 call OB 180: DBA and DBL are adjusted When you call OB 180, the data word stored at e.g. address 1520 can no longer be addressed as DW 5, but must be addressed as DW 3 etc. (see Fig. 6-6).



# 6.17 OB 181: Testing Data Blocks (DB/DX)

| Introduction             | With the special function organization block OB 181 you can check the following: |                                                                                                                                                                    |  |  |  |  |
|--------------------------|----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                          | • whether a particular                                                           | DB or DX data block exists,                                                                                                                                        |  |  |  |  |
|                          | • the address of the first data word of the data block,                          |                                                                                                                                                                    |  |  |  |  |
|                          | • how many data words the data block contains,                                   |                                                                                                                                                                    |  |  |  |  |
|                          | • the memory type and area used.                                                 |                                                                                                                                                                    |  |  |  |  |
| Application of<br>OB 181 |                                                                                  | ction is useful before the operations TNB/TNW, G calling the special function organization blocks OB 182,                                                          |  |  |  |  |
|                          | -                                                                                | call OB 181 before transferring a group of data words, to ination data block is both valid and long enough to take wish to transfer.                               |  |  |  |  |
| Function                 | OB 181 checks that a sparameters of the data b                                   | pecified data block exists and returns the characteristic block as a result.                                                                                       |  |  |  |  |
| Parameters               | ACCU-1-L                                                                         |                                                                                                                                                                    |  |  |  |  |
|                          | ACCU-1-LL:                                                                       |                                                                                                                                                                    |  |  |  |  |
|                          | block number<br>possible values:                                                 | 1 to 255                                                                                                                                                           |  |  |  |  |
|                          | ACCU-1-LH:                                                                       |                                                                                                                                                                    |  |  |  |  |
|                          | block identifier<br>possible values:                                             | 1 = DB<br>2 = DX                                                                                                                                                   |  |  |  |  |
| Result                   | • If the block <b>does ex</b>                                                    | ist in the CPU:                                                                                                                                                    |  |  |  |  |
|                          | - ACCU-1-L:                                                                      | contains the address of the first data word (DW $0$ )                                                                                                              |  |  |  |  |
|                          | - ACCU-2-L:                                                                      | contains the length of the data block in words<br>(without block header),<br>Example: ACCU-2-L contains the value "7":<br>the data block consists of DW 0 to DW 6. |  |  |  |  |
|                          | - RLO:                                                                           | = 0                                                                                                                                                                |  |  |  |  |

- CC 0/CC 1: are affected according to the location of the block (see following list)
- the remaining bit and word condition codes: are cleared.
- If the data block **does not exist** in the memory or the parameter assignment is incorrect:
  - ACCU 1 and 2: are not changed
  - **RLO:** = 1
  - CC 0/CC 1: = 1
  - the remaining bit and word condition codes: are cleared
- **RLO, CC1, CC0** The following condition code bits are set according to the check result. The condition code bits can be evaluated by the operations listed in the "Scan" column of the table:

| RLO | CC 1 | CC 0 | Scan | Meaning                                   |                                    |              |  |  |  |  |
|-----|------|------|------|-------------------------------------------|------------------------------------|--------------|--|--|--|--|
| 0   | 0    | 1    | JM   | DB/DX in user memory                      | DB/DX in EPROM<br>mode (read-only) | DB/DX exists |  |  |  |  |
| 0   | 0    | 0    | JZ   |                                           | DB/DX in RAM                       |              |  |  |  |  |
| 0   | 1    | 0    | JP   | DB/DX in DB-RAM                           | mode (read/write)                  |              |  |  |  |  |
| 1   | 1    | 1    | JC   | DB/DX does not exist or there is an error |                                    |              |  |  |  |  |

**Possible errors** The following error events may occur:

- Incorrect block number (illegal: 0: DB 0/DX 0)
- Incorrect block identifier (permitted: 1 = DB, 2 = DX; illegal: 0, 3 to 255)
- Memory error

#### Examples

Refer to Section 8.3 / Section 9.2 / Section 9.3.

### 6.18 OB 182: Copying a Data Area

Function OB 182 copies a data field of variable length from one data block to another. You can use DB and DX data blocks as the source and destination blocks. You can select the start of the field in the source and destination data block as required. OB 182 can copy a maximum of 4091 data words. It contains pseudo operation boundaries. Note The source and destination block can be identical; the data areas of the source and destination can overlap. The original data of the source area are copied unchanged to the **destination area** even if there is an overlap. (The area overlapping in the source is overwritten following the copying.) You can use this feature in certain situations, for example to shift a data area within a block. **Parameters** 1. Data Field with Parameters for Copying Functions Before you call OB 182, supply a data field with all the data required for the copying. This data field can be set up in a DB or DX data block, or in the F or S flag area. The data field defines the source and destination data block, the field start address in both blocks and the number of data words to be transferred. It consists of 5 words. Bit no. 15 7 0 8 1st word Source DB type Source DB no. 2nd word No. of 1st data word in source DB to be transferred

 3rd word
 Dest. DB type

 4th word
 No. of 1st data word to be written in dest. DB

 5th word
 Number of data words

The range of values and meaning of the parameters is as follows:

| Parameters                                        | Permissible value range |
|---------------------------------------------------|-------------------------|
| Data block type (source and destination)          | 1 = DB, 2 = DX          |
| Data block number (source and destination)        | 3255                    |
| No. of the 1st data word (source and destination) | 04090                   |
| Number of data words                              | 14091                   |

Dest. DB no.

#### Data field in the flag area

If you set up the data field in the flag area, you must take into account the following assignment of data field words to flag bytes. "x" is the parameter "no. of the 1st data field word", that you must store in ACCU-1-L when OB 182 is called.

| Bit no.             | 15 8          | 7 0           |
|---------------------|---------------|---------------|
| 1st data field word | Flag byte x   | Flag byte x+1 |
| 2nd data field word | Flag byte x+2 | Flag byte x+3 |
| 3rd data field word | Flag byte x+4 | Flag byte x+5 |
| 4th data field word | Flag byte x+6 | Flag byte x+7 |
| 5th data field word | Flag byte x+8 | Flag byte x+9 |

2. Accus

#### ACCU-2-L

ACCU-2-L contains information regarding the data field used. It must present the following structure:

| Bit no. | 15 | I | 1     | I      | 1       | 1  | 1 | 8 | 7 |  | 1   | I     | 1     | I   | 1 | 1 | ) <sub> </sub> |
|---------|----|---|-------|--------|---------|----|---|---|---|--|-----|-------|-------|-----|---|---|----------------|
|         |    | 1 | Addre | ess ai | rea typ | be |   |   |   |  | Dat | a blo | ock n | 10. |   |   |                |

#### Parameters in ACCU-2-L

| Address area type, |                                                                                                                        |
|--------------------|------------------------------------------------------------------------------------------------------------------------|
| permitted values:  | 1 = DB data block                                                                                                      |
|                    | 2 = DX data block                                                                                                      |
|                    | 3 = F flag area                                                                                                        |
|                    | 4 = S flag area                                                                                                        |
| Data block no.,    |                                                                                                                        |
| permitted values : | 3 to 255 (in the case of address area type "1" or "2" only;<br>irrelevant in the case of address area type "3" or "4") |

### ACCU-1-L

|                        | Number of the 1st data field w<br>permitted values (depending o<br>DB, DX:<br>F flags:<br>S flags: | on the address area type):<br>02043<br>0246<br>(= no. of flag byte "x")<br>01014                                                             |
|------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
|                        |                                                                                                    | (= no. of flag byte "x")                                                                                                                     |
| Result                 | •                                                                                                  | cuted, the condition code bits OR, $\overline{\text{ERAB}}$ and ode bits and ACCUs 1 and 2 are unchanged.                                    |
| Reactions to<br>errors | OB 19 or OB 31 is not loaded                                                                       | <b>9</b> or <b>OB 31</b> (other runtime errors) is called. If<br>I the CPU goes to the STOP mode.<br>Is are transferred to ACCU 1 and ACCU 2 |

Table 6-9 OB 182 error IDs

| ACCU-1-L | ACCU-2-L | Cause of error                                                  | OB called |
|----------|----------|-----------------------------------------------------------------|-----------|
| 1A06H    | -        | Data block not loaded                                           | OB 19     |
| 1A34H    | 0001H    | Data field written to incorrectly                               | OB 31     |
|          | 0100H    | Address area type not permitted                                 |           |
|          | 0101H    | Data block number not permitted                                 |           |
|          | 0102H    | Number of the first data field word not permitted               |           |
|          | 0200H    | Source data block type not permitted                            |           |
|          | 0201H    | Source data block number not permitted                          |           |
|          | 0202H    | Number of 1st data word in the source DB to be transferred not  |           |
|          |          | permitted                                                       |           |
|          | 0203H    | Length of the source data block in the block header < 5 words   |           |
|          | 0210H    | Destination data block type not permitted                       |           |
|          | 0211H    | Destination data block number not permitted                     |           |
|          | 0212H    | Number of the 1st data word to be written to in the destination |           |
|          |          | DB not permitted                                                |           |
|          | 0213H    | Length of the destination data block in the block               |           |
|          |          | header < 5 words                                                |           |
|          | 0220H    | Number of data words to be transferred not permitted            |           |
|          |          | (= 0  or > 4091)                                                |           |
|          | 0221H    | Source data block too short                                     |           |
|          | 0222H    | Destination data block too short                                |           |
|          | 0223H    | Destination data block is write-protected (EPROM mode)          |           |

# 6.19 OB 185: Setting Write Protection

| Function                   | If you are using a memory card and already have to access data blocks within OB 20, you can remove the write protection by calling OB 185 in OB 20.                                                                                   |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Application                | OB 185 evaluates bit 0 of ACCU-1-L and sets the write protection accordingly.<br>Then it transfers the value of bit 0 of ACCU-1-L to bit 0 of the RS 138 system<br>data. The remaining bits in ACCU-1-L are not evaluated.            |
|                            | OB 185 is only processed in a cold restart, i.e. in OB 20. In all other modes, the call has no effect, so does not lead to an error or an error reaction.                                                                             |
| Parameter                  | ACCU-1-L                                                                                                                                                                                                                              |
|                            | Activate/deactivate write protection,permitted values:bit $0 = 0$ : deactivate write protectionbit $0 = 1$ : activate write protection                                                                                                |
| Result                     | OB 185 sets the bit condition codes OR and ERAB and the word condition code OS to 0.                                                                                                                                                  |
| Write protection<br>status | As OB 185 changes the RS data and this is scanned at the end of OB 20 again by the system, you may change the write protection setting unintentionally as a result of the "mixed" use of the OB and the direct change of the RS data. |
| Overview                   | CPU 928B in RAM mode                                                                                                                                                                                                                  |
|                            | • Write protection is deactivated: bit 0 of RS 138=0                                                                                                                                                                                  |
|                            | • PG ISTACK: submodule ID: 32 KW RAM                                                                                                                                                                                                  |
|                            | • PG memory configuration: RAM configured to 07FFEH                                                                                                                                                                                   |
|                            | • PG user memory end address 08000H                                                                                                                                                                                                   |
|                            | • All blocks: "valid in RAM" -> loading, deleting, overwriting possible                                                                                                                                                               |
|                            | CPU 928B in EPROM mode                                                                                                                                                                                                                |
|                            | • Write protection is activated: bit 0 of RS 138=1                                                                                                                                                                                    |
|                            | • PG ISTACK: submodule ID: EPROM                                                                                                                                                                                                      |
|                            | • PG memory configuration: RAM configured to 00000H                                                                                                                                                                                   |
|                            | • PG user memory end address 0EEEEH                                                                                                                                                                                                   |
|                            | <ul> <li>Code blocks and data blocks not copied to DB-RAM: "valid in EPROM" -&gt;<br/>loading, deleting, overwriting not possible</li> </ul>                                                                                          |
|                            | <ul> <li>Data blocks copied to DB-RAM: "valid in RAM" -&gt; loading, deleting,<br/>overwriting possible</li> </ul>                                                                                                                    |

# 6.20 OB 186: Compressing Memory

| Function  | <ul> <li>With the organization block OB 186 you can compress the memory and scan or check the status of the compression function. The functionality of OB 186 corresponds to the PG function "Compress memory" (see Section 11.2).</li> <li>Note While the memory is being compressed by OB 186, the PG function  "Compress memory" is rejected. Other PG functions can only be used with certain restrictions.  As long as a PG function is active, OB 186 is rejected.</li></ul> |  |  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|           | Compressing memory with OB 186 is a long-term function which is distributed<br>by the system program over a number of cycles. No explicit messages are<br>displayed: you can, however, request status messages by calling the OB<br>cyclically with function number 2.                                                                                                                                                                                                             |  |  |
|           | OB 186 calls no error block.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| Parameter | ACCU-1-L                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|           | ACCU-1-L contains the function number,<br>permitted values: 0001H: trigger compression<br>0002H: read/check status of the compression                                                                                                                                                                                                                                                                                                                                              |  |  |
| Result    | OB 186 sets the bit condition codes OR and ERAB and the word condition code OS to 0.                                                                                                                                                                                                                                                                                                                                                                                               |  |  |

Calling OB 186 produces the following results:

| Function no. | RLO | ACCU-1-L       | Significance                                                                                       |  |
|--------------|-----|----------------|----------------------------------------------------------------------------------------------------|--|
| 0001H        | 1   | 0000H          | No error, compressing started                                                                      |  |
|              | 0   | 8002H          | Error, cannot start because PG function active                                                     |  |
|              |     | 800 <b>3</b> H | Error, cannot start because compressing already active                                             |  |
| 0002H        | 1   | 0000H          | No error, compressing still active                                                                 |  |
|              | 0   | 0001H          | Compressing was not possible at last call<br>because CPU not in compressable state at<br>this time |  |
|              |     | 8002H          | Compressing completed without error                                                                |  |
|              |     | 0003H          | Compressing aborted owing to memory inconsistency                                                  |  |
| invalid      | 0   | 8001H          | Error, invalid function number                                                                     |  |

### 6.21 OB 190/OB 192: Transferring Flags to a Data Block

| Application | <ul><li>With organization blocks OB 190 and OB 192, you can transfer a selected number of flag bytes to a data block.</li><li>This can, for example, be an advantage before block calls, in error organization blocks or when cyclic program execution is interrupted by a time or process interrupt.</li><li>Using OB 191 and OB 193, you can then write these flag bytes back from the data block.</li></ul> |  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|             | Note<br>Use OB 190 and OB 191 to save and read back flag bytes, since the time<br>required is extremely short.<br>Before you call OB 190/192, a data block (DB/DX) must already be open.<br>OBs 190/192 only transfer flag bytes from the F flag area to a data block,<br>they cannot transfer flag bytes from the S flag area.                                                                                |  |
| Function    | After you call OB 190/192, the flag bytes are written to the open data block from the specified data word address. OBs 190/192 take the flag area to be saved from ACCU 2. OBs 190 and 192 are identical except for the way in which they transfer the flag bytes:                                                                                                                                             |  |

- OB 190 transfers the flags in bytes
- OB 192 transfers the flags in words.

This difference is significant, when the data transferred to the data block are intended for processing and you are not simply using the data block as a buffer. The following diagram illustrates the difference.



Fig. 6-7 Transferring in bytes (OB 190) and words (OB 192)

| Note |
|------|
|------|

If you transfer an **odd** number of flag bytes, only **half** the **last** data word in the data block is used. With **OB 190**, the **left** date in the destination DB is unchanged, with **OB 192** the **right** date is unchanged.

| Parameters      | 1. Specifying the data source:                                                                                                 |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                 | ACCU-2-LH                                                                                                                      |  |  |  |
|                 | First flag byte to be transferred,<br>permitted values: 0 to 255                                                               |  |  |  |
|                 | ACCU-2-LL                                                                                                                      |  |  |  |
|                 | Last flag byte to be transferred,<br>permitted values: 0 to 255                                                                |  |  |  |
|                 | (The last flag byte must be $\geq$ the first flag byte)                                                                        |  |  |  |
|                 | 2. Specifying the destination                                                                                                  |  |  |  |
|                 | ACCU-1-L                                                                                                                       |  |  |  |
|                 | Number of the first data word to be written to in the open data block:                                                         |  |  |  |
|                 | The permitted values depend on the length of the data block in the memory.<br>Numbers greater than 255 may occur.              |  |  |  |
| Result          | If the special function OBs 190/192 are processed <b>correctly</b> , the RLO is cleared (RLO = 0). The ACCUs remain unchanged. |  |  |  |
|                 | If an <b>error</b> occurs, the RLO is set (RLO = 1), the ACCUs remain unchanged.                                               |  |  |  |
| Possible errors | • No DB or DX data block opened                                                                                                |  |  |  |
|                 | • Incorrect flag area (last flag byte < first flag byte)                                                                       |  |  |  |
|                 | • Data word number does not exist                                                                                              |  |  |  |

• DB or DX data block not long enough

### 6.22 OB 191/OB 193: Transferring Data Fields to a Flag Area

Application With the organization blocks OB 191 and OB 193 you can transfer data from a data block to the flag area. With this function, you can, for example, write flag bytes you have saved in a data block back to the flag area. The only difference between OBs 191/193 and OBs 190/192, is that the source and destination are reversed: OB 190/192: Flag area Data block OB 191/193: Flag area Data block Note Before you call OB 191/193, a data block of sufficient length (DB/DX) must be opened. OBs 191/193 transfer from the data block only to the F flag area and not to the S flag area. Function After OB 191/193 is called, data words starting from the data word address specified are read out of the opened data block and transferred to the flag area. OBs 191 and 193 are identical, except for the way in which they transfer data. OB 191 transfers data words in bytes OB 193 transfers data words in words. The figure on the next page illustrates this difference.







Parameters

#### 1. Specifying the source:

<u>ACCU-2-L</u> Number of the first data word in the open data block to be transferred

#### 2. Specifying the destination:

ACCU-1-LH First flag byte to be written to, permitted values: 0 to 255

ACCU-1-LL Last flag byte to be written to, possible values: 0 to 255

#### (The last flag byte must be $\geq$ the first flag byte)

**Result** If special function OBs 191/193 are processed **correctly**, the RLO is cleared (RLO = 0). The ACCUs remain unchanged.

In the event of an **error**, the RLO is set (RLO = 1), the ACCUs remain unchanged.

**Possible errors** The following error events may occur:

- No DB or DX data block open
- Incorrect flag area (last flag byte < first flag byte)
- Data word number does not exist
- DB or DX data block not long enough

#### Examples

```
Example 1
Before program block PB 12 is called, all the flags (FY 0 to FY 255) must
be saved in data block DX 37 from address 100 onwards and then written
back to the flag area.
Saving:
                      Call the data block
       :CX DX 37
       :L
            КҮ 0,255
                      Flag area FYO to FY255
            KB 100
                      Number of the 1st data word in the destination DB
       :L
       :JU OB 190
                      Save flags
Block change:
       :JU PB 12
Writing back:
       :
                      (Data block already called)
       :L
            KB 100
                      Number of the 1st data word in the source DB
       :L
            KY 0,255
                      Flag area FYO to FY255
       :JU OB 191
                      Write back flags
```

#### Example 2

Flags used by the cyclic user program must not be used by a time or process-driven user program. Each program processing level must have a particular section of the flag area assigned to it.

| e.g.: Cyclic user program:             | FYO FY99   |   |
|----------------------------------------|------------|---|
| Time-driven user program:              | FY100 FY19 | 9 |
| Process interrupt-driven user program: | FY200 FY25 | 5 |

If, however, the cyclic user program is already using all 256 flag bytes and the time-driven user program also requires all 256 flag bytes, the flags must be swapped over when the processing level is changed and the old flags stored until the program returns to the original processing level. The quickest way to save and load these flags is with the special function blocks OB 190 and OB 191. Fig. 6-9 illustrates how a flag area FYx to FYy used by both OB 1 and OB 13 (100 ms time interrupt) can be buffered in a data block DBx.

STEP 5 program in OB 13:







### 6.23 OB 200 and OB 202 to 205: Multiprocessor Communication

**Overview** These special function organization blocks are described in detail in Chapter 10.

You can use the special function organization blocks OB 200 and OB 202 to OB 205 to transfer data between CPUs in multiprocessor operation using the coordinator 923C.

#### • OB 200: initialize

This special function organization block sets up a memory area in the 923C coordinator. This memory is a buffer for the data fields that are transferred.

#### • OB 202: send

This function transfers a data field to the buffer of the 923C coordinator and indicates how many data fields can still be sent.

#### • OB 203: send test

The special function OB 203 determines the number of free memory fields in the buffer of the 923C coordinator.

#### • OB 204: receive

This function transfers a data field from the buffer of the 923C coordinator and indicates how many data fields can still be received.

#### • OB 205: receive test

The special function OB 205 determines the number of occupied memory fields in the buffer of the 923C coordinator.

# 6.24 OB 216 to 218: Page Access

| What are pages?        | To implement a large number of communications registers, within the address range of the S5 bus, an address area with a length of 1024 bytes (2048 bytes are reserved) is imaged 256 times on the memory. Because these 256 images are stored beside or behind each other like individual "pages", these memory areas are also referred to as a "page memory".                                                  |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        | In multiprocessor operation, all modules involved can only access <b>one</b> page of this memory area at any one time, all the remaining pages must be disabled for both reading and writing.                                                                                                                                                                                                                   |
|                        | A page is addressed via a page address register that exists on all modules operating with pages and that has a fixed address on the S5 bus. You set the numbers (addresses) of the pages on each of these modules using a DIL switch, so that each page can only exists once in the PLC.                                                                                                                        |
|                        | Before reading or writing to a page, the CPU specifies the page number by writing to the page address register. All the modules that operate according to this procedure of the S5 bus receive this number <b>simultaneously</b> ("broadcast") and store it in their memory. Only the page addressed in this way can be written to or read from in the page memory of the S5 bus, all other pages are disabled. |
| How to access<br>pages | You can use organization blocks OB 216 to OB 218 and several STEP 5 operations (see Chapter 9) to access the pages.                                                                                                                                                                                                                                                                                             |
|                        | The organization blocks contain the following functions:                                                                                                                                                                                                                                                                                                                                                        |
|                        | • OB 216:                                                                                                                                                                                                                                                                                                                                                                                                       |
|                        | write a byte/word/double word to a page                                                                                                                                                                                                                                                                                                                                                                         |
|                        | • OB 217:                                                                                                                                                                                                                                                                                                                                                                                                       |
|                        | reads a byte/word/double word from a page                                                                                                                                                                                                                                                                                                                                                                       |
|                        | • OB 218:                                                                                                                                                                                                                                                                                                                                                                                                       |
|                        | the CPU occupies a page (used for coordination in multiprocessor operation)                                                                                                                                                                                                                                                                                                                                     |
|                        | Vou can use these functions for test numerous and for programming handling                                                                                                                                                                                                                                                                                                                                      |

You can use these functions for test purposes and for programming handling blocks or similar functions.

Address areas

#### Note

Whenever possible, only program access to pages by calling OB 216 to OB 218. You should only use the available STEP 5 operations if you have considerable experience of the system.

Normally, you can execute all functions using the standard function blocks "handling blocks" and the integrated function organization blocks "multiprocessor communication" (OB 200, OB 202 to OB 205), with which all page access is handled "automatically".

#### for peripherals Page length Address area occupied on the S5 bus 1024 addresses (byte or word addresses) F400H - F7FFH 2048 addresses (byte or word addresses) F400H - FBFFH Bit 7 0 F000 P area Multiple memory area F100 Length: 1024 or 2048 bytes O area F200 Page no. 255 IPC flags on coordinator F300 System area 3 (semaphores) 2 on the coordinator 1 F400 Page no. 0 Address space of a page FC00 Distributed peripherals (or free) FEFF Page address register FF00 not occupied FFFF

Fig. 6-11 Location of the page address area on the S5 bus



Fig. 6-12 Location of the bytes when writing (OB 216) / reading (OB 217) to/from a page in words or double words

#### 6.24.1 OB 216: Writing to a Page

Function The special function organization block transfers a byte, word or double word from ACCU 1 (right-justified) to a particular page. The addressing of the page in single or multiprocessor operation and the transfer of the complete data unit (1, 2 or 4 bytes) is one program function and cannot be interrupted. Parameters Accus ACCU-3-LH Identifier of the data to be transferred, possible values: 0 = byte1 = word2 =double word ACCU-3-LL Current page number, possible values: 0 to 255 ACCU-2-L Destination address on the page, possible values: 0 to 2047 ACCU1 Data to be written (byte, word, double word: right-justified) ACCU contents before writing (before calling OB 216):

|        | High word |          | <b>*</b> L                                                                                                              | Low word                |  |
|--------|-----------|----------|-------------------------------------------------------------------------------------------------------------------------|-------------------------|--|
|        | High byte | Low byte | High byte                                                                                                               | Low byte                |  |
| ACCU 4 | X         | х        | x                                                                                                                       | X                       |  |
| ACCU 3 | X         | x        | Length ID<br>0: byte (8 bits)<br>1: word (16 bits)<br>2: double word (32 bits)                                          | Page number<br>0 to 255 |  |
| ACCU 2 | X         | x        | Address (relative to 5<br>0 2047 if length ID 0 (byte)<br>0 2046 if length ID 1 (word)<br>0 2044 if length ID 2 (double |                         |  |
| ACCU 1 |           | x        |                                                                                                                         | ta (16 bits) →          |  |
|        | •         | data     | . (32 bits)                                                                                                             |                         |  |
|        | 31 24 2   | 3        | 16 15                                                                                                                   | 8 7 0                   |  |

| Result          | • If the data is written to the page <b>correctly</b> : |                                                                                                   |  |
|-----------------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------|--|
|                 | - ACCU 1 and ACCU 3:                                    | remain unchanged.                                                                                 |  |
|                 | - ACCU-2-L:                                             | contains a value incremented by 1,<br>2 or 4 (depending on the length of<br>the data transferred) |  |
|                 | - RLO:                                                  | = 1                                                                                               |  |
|                 | - the remaining bit and<br>word condition codes:        | are cleared                                                                                       |  |
|                 | • If the data <b>cannot</b> be written to the page      |                                                                                                   |  |
|                 | - all ACCUs:                                            | remain unchanged                                                                                  |  |
|                 | - RLO:                                                  | = 0                                                                                               |  |
|                 | - all remaining bit and<br>word condition codes:        | are cleared.                                                                                      |  |
| Possible errors | The following error events may occu                     | ır:                                                                                               |  |
|                 | • wrong length ID in ACCU-3-LH                          |                                                                                                   |  |
|                 |                                                         |                                                                                                   |  |

- destination address on the page is wrong or does not exist
- specified page number does not exist

#### 6.24.2 OB 217: Reading from a Page

| Function   | The special function organization block transfers a byte, word or double word from a specific page to ACCU 1 (right-justified).                                          |  |  |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|            | Addressing the page in the single and multiprocessor modes and transferring the complete data (1, 2 or 4 bytes) form a single program unit that must not be interrupted. |  |  |
| Parameters | Accus                                                                                                                                                                    |  |  |
|            | ACCU-3-LH<br>Identifier of the data to be transferred,<br>permitted values: 0 = byte<br>1 = word<br>2 = double word                                                      |  |  |
|            | ACCU-3-LL<br>Current page no.,<br>permitted values: 0 to 255                                                                                                             |  |  |
|            | ACCU-2-L<br>Source address of the page,<br>permitted values: 0 to 2047                                                                                                   |  |  |
|            | ACCU contents before reading (before calling OB 217):                                                                                                                    |  |  |
| <u>+</u>   | High word Low word                                                                                                                                                       |  |  |



| Result          | • If the OB reads from the page su                                                         | • If the OB reads from the page <b>successfully</b> ,                                              |  |
|-----------------|--------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|--|
|                 | - ACCU 1:                                                                                  | (right-justified) contains the value<br>read (the remaining bits up to<br>maximum 32 are cleared), |  |
|                 | - ACCU 3:                                                                                  | remains unchanged,                                                                                 |  |
|                 | - ACCU-2-L:                                                                                | contains a value incremented by 1,<br>2 or 4 (depending on the length<br>of the data transferred), |  |
|                 | - RLO:                                                                                     | = 1,                                                                                               |  |
|                 | - the remaining bit and word condition codes:                                              | are cleared.                                                                                       |  |
|                 | • If the OB cannot read from the p                                                         | page,                                                                                              |  |
|                 | - all ACCUs:                                                                               | remain unchanged,                                                                                  |  |
|                 | - RLO:                                                                                     | = 0,                                                                                               |  |
|                 | - all other bit and word condition codes:                                                  | are cleared.                                                                                       |  |
| Possible errors | <ul><li>The following error events may occu</li><li>wrong length ID in ACCU-3-LH</li></ul> |                                                                                                    |  |
|                 | • source address on the page is wrong or does not exist                                    |                                                                                                    |  |

• specified page number does not exist

#### 6.24.3 OB 218: Reserving a Page

The special function organization block transfers the number of the CPU to a particular page, providing the contents of the memory location addressed on this page are **zero**. As long as the CPU number is entered in this location, the page is reserved for this CPU and **cannot** be used by other CPUs.

Organization block OB 218 is used to synchronize data transfer and is particularly important when **large blocks of data** must be transmitted as one unit. In the multiprocessor mode, no more than 4 bytes are transferred per bus allocation. Reserving a page is therefore advantageous.

Addressing the page, reading and, if applicable, writing the slot identifier is one program unit that must not be interrupted.

#### Parameters Accus

ACCU-2-LL Number of the page to be reserved, permitted values: 0 to 255

ACCU-1-L Destination address on the page, permitted values: 0 to 2047

(The contents of ACCU 3 and 4 are irrelevant.)

Accu assignments before calling OB 218:



| Result          | • If the page is reserved <b>successfu</b> | If the page is reserved successfully: |  |
|-----------------|--------------------------------------------|---------------------------------------|--|
|                 | - all ACCUs:                               | remain unchanged                      |  |
|                 | - RLO:                                     | = 1                                   |  |
|                 | - the remaining bit and condition codes:   | are cleared.                          |  |
|                 | • If the page <b>cannot</b> be reserved:   |                                       |  |
|                 | - all ACCUs:                               | remain unchanged,                     |  |
|                 | - RLO:                                     | = 0,                                  |  |
|                 | - all other bit and word condition codes:  | are cleared.                          |  |
| Possible errors | The following error events may occ         | ur:                                   |  |
|                 | • incorrect length ID in ACCU-3-           | LH                                    |  |
|                 | • source address on the page is inc        | correct or does not exist             |  |
|                 | • specified page number does not           | exist.                                |  |

#### 6.24.4 Program Example

Task You want to write data words 4 to 11 via the 923C coordinator from the DB 45 of a CPU 928B to the DX 45 (data words 0 to 7) of a second CPU 928B. You want to synchronize the sender and receiver (in the multiprocessor mode)using OB 218. Current page on the coordinator: no. 255 Coordination location on the page (reserved): addr. 53 Data transfer area of the page (reading and writing): addr. 54-69 STEP 5 operations in the SENDER: :L KB 255 Page number KB 53 Address of the coordination cell : L. :JU OB218 Transfer the slot ID to the cell on the page :JC =M001 If RLO = 1 (transfer successful), jump to label :BEU Else block end M001 DB 45 :C Open the source data block KY 2,255 2=length ID double word, page number :L :L KB 54 Start address on page : ENT Write to ACCU 3 :LDD 4 Data words 4 and 5 (= 4 bytes) :JU OB 216 Transfer the 1st double word Increment address by 4 (ACCU-2-L = 58) : TAK Save the destination address : :L DD 6 :JU OB 216 Transfer the 2nd double word : TAK : :L DD 8 :JU OB 216 Transfer the 3rd double word : TAK : :L DD 10 :JU OB 216 Transfer the 4th double word : КҮ 0,255 :L :L Address with slot ID KB 53 : ENT : L кв О ACCU 1 = 0:JU OB 216 Clear slot ID, release data transfer area :BE Continued on the next page

```
Continuation of the example:
STEP 5 operations in the RECEIVER:
          KB 255
                        Page number
       :L
       :L
           KB 53
                        Coordination cell
       :JU OB 218
                        Page reserved by 2nd CPU
       :JC =M002
                        If RLO = 1, jump to label
       : BEU
       :
м002
      :CX DX 45
                        Destination data block
           КҮ 2,255
       :L
      :L
          KB 54
       :ENT
                        Write to ACCU 3
       :L
           KB0
                        Write to ACCU 2
       :
       :JU OB 217
                        Read 1st double word
                        Increment the address by 4 (ACCU 2-L = 58)
       :
       T DD 0
                        Transfer ACCU 1 to data word 0 and 1
                        Read 2nd double word
       :JU OB 217
      :Т
          DD 2
       :
       :JU OB 217
                        Read 3rd double word
           DD 4
       :Т
       :
       :JU OB 217
                        Read 4th double word
       :Т
           DD 6
       :
       :L
           KY 0,255
                        Address with slot ID
       :L
           KB 53
       :ENT
           кв О
                        ACCU 1 = 0
       :L
       :JU OB 216
                        Clear slot ID, release data
                        transfer area
       :
       :BE
```

# 6.25 OB 220: Sign Extension

| Application     | A sign extension is necessary to extend a negative 16-bit fixed point number to a 32-bit fixed point number before performing a fixed point-floating point conversion (32 bits, operation FDG).                                                                                                                                                                    |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function        | <ul> <li>This special function extends the sign of a 16-bit fixed point number in ACCU-1-L to the more significant word (ACCU-1-H):</li> <li>If bit 2<sup>15</sup> = 0 (positive number), the more significant word is loaded with KH = 0000.</li> <li>If bit 2<sup>15</sup> = 1 (negative number), the more significant word is loaded with KH = FFFF.</li> </ul> |
| Parameters      | ACCU-1-L<br>16-bit fixed point number                                                                                                                                                                                                                                                                                                                              |
| Result          | ACCU-1-H is loaded into ACCU-1-L according to the sign of the fixed-point number (see above).                                                                                                                                                                                                                                                                      |
| Possible errors | none                                                                                                                                                                                                                                                                                                                                                               |

# 6.26 OB 221: Setting the Cycle Monitoring Time

| Function        | By calling this special function, you can modify the cycle monitoring time and change the maximum permitted cycle time. As standard, the cycle monitoring time is set to 150 ms.                                                                                                                                                  |  |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                 | Along with this call, the timer for the cycle time monitoring is restarted.                                                                                                                                                                                                                                                       |  |  |  |  |
|                 | The maximum permitted cycle time for the cycle in which OB 221 is called, is extended by the newly selected value, calculated from the time when the special function call took place. The cycle monitoring time of all subsequent cycles corresponds to the newly selected value (= the time value that you transfer in ACCU 1). |  |  |  |  |
| Parameters      | ACCU 1                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|                 | ACCU-1-L                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|                 | new cycle time (in milliseconds),<br>permitted values 1 ms - 13000 ms,<br>positive fixed point number (KF)                                                                                                                                                                                                                        |  |  |  |  |
|                 | ACCU 1-H                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|                 | ACCU-1-H must have the <b>value</b> " <b>0</b> "                                                                                                                                                                                                                                                                                  |  |  |  |  |
| Result          | The new cycle monitoring time is set after correct processing of OB 221.                                                                                                                                                                                                                                                          |  |  |  |  |
| Possible errors | The cycle monitoring time you have specified is not within the range $1 \text{ ms} - 13000 \text{ ms}$ .                                                                                                                                                                                                                          |  |  |  |  |
|                 | The function is not executed. The system program recognizes a runtime error and calls <b>OB 31</b> . The other reactions to the error depend on how you have programmed OB 31 (see Section 5.6). If OB 31 is not loaded, the CPU goes to the STOP mode.                                                                           |  |  |  |  |
|                 | In both cases, the error identifier <b>1A3AH</b> is entered in ACCU-1-L.                                                                                                                                                                                                                                                          |  |  |  |  |

### 6.27 OB 222: Restarting the Cycle Monitoring Time

| Function   | The special function OB 222 retriggers the cycle monitoring time, i.e. the timer<br>for the monitoring is restarted. After you call this special function, the maximum<br>permitted cycle time for the current cycle is extended by the selected value from<br>the time of the call. |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parameters | none                                                                                                                                                                                                                                                                                 |

Possible errors none

### 6.28 OB 223: Comparing Restart Types

# *Function* If you call OB 223 in multiprocessor operation, the system checks whether the restart types of **all** CPUs involved are the same.

|                 | Note<br>OB 223 must only be called when all the CPUs have completed their<br>start up.<br>If start-up synchronization is active (DX 0) this is guaranteed by calling<br>OB 223 in the RUN mode.<br>If start-up synchronization is <b>inactive</b> this must be achieved by other<br>means, e.g. delayed OB 223 call. |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parameters      | none                                                                                                                                                                                                                                                                                                                 |
| Result          | Error messages in the event of deviating restart types                                                                                                                                                                                                                                                               |
| Possible errors | If the restart types of all the CPUs participating in multiprocessor mode are not the same, the CPU in which OB 223 is processed detects a runtime error. <b>OB 31</b> is then called.                                                                                                                               |
|                 | If OB 31 is not loaded, the CPU goes to the STOP mode with the LZF error message. Its STOP LED flashes slowly. The other CPUs also go to the STOP mode, their LEDs show a steady light.                                                                                                                              |
|                 |                                                                                                                                                                                                                                                                                                                      |

*Error IDs* When OB 31 is called and the CPU is in the STOP mode, the error ID **1A3BH** is entered in ACCU-1-L.

### 6.29 OB 224: Transferring Blocks of Interprocessor Communication Flags

| Function        | <ul> <li>The interprocessor communication (IPC) flags are transferred at the end of the program cycle. In the single processor mode, the IPC flags are transferred completely as a block of data to the memory on the coordinator or the CP and/or from this memory to the flags of the CPU. The S5 bus is always available.</li> <li>In multiprocessor operation, on the other hand, each CPU can only use the bus when it is allocated by the coordinator. Each time the CPU has access to the bus, only one byte is transferred. Following this, it is once again the turn of the other CPUs. Sets of data that belong together but that are distributed over several flag bytes are therefore separated.</li> <li>If you call organization block OB 224, you can transfer all the IPC flags specified in DB 1 of the CPU as a block of data. As long as a CPU is transferring IPC flags, it cannot be interrupted by another CPU. Since the next CPU has to wait before it can transfer its data, the cyclic program execution is delayed (cycle time!).</li> </ul> |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | <ul><li>OB 224 ensures the consistency of the IPC flag information. It must be called in the start-up program as follows:</li><li> in all the CPUs involved in IPC flag transfer</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                 | and                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                 | • in each restart type being used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Parameters      | none                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Possible errors | none                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

### 6.30 OB 226, OB 227

| Function | OB 226 and OB 227 are still included in the operating system for compatibility reasons. The original function of these OBs - forming a checksum via the system program - is now integrated into the system program. Both OBs return the value "0" when called.                                                                                           |  |  |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|          | You can still use user programs which use OB 226 or OB 227 to form a checksum without any modifications.                                                                                                                                                                                                                                                 |  |  |
|          | <b>Note</b><br>The system program runs a checksum check automatically following power<br>on and before an overall reset.                                                                                                                                                                                                                                 |  |  |
| Checksum | The firmware EPROMs of the CPU 928B contain a checksum. Following power<br>on and before an overall reset, the system software calculates a checksum itself<br>and compares the calculated value with the stored value.<br>If both values are not the same, a "hard" system error occurs (RUN and STOP<br>light up, RED/GREEN-STOP). The CPU cannot run. |  |  |
|          | Following power off/on, the CPU requests (if still possible) an OVERALL RESET. The value 1170H is entered in RS data EA80H. OVERALL RESET leads again to a RED/GREEN-STOP.                                                                                                                                                                               |  |  |
|          | OB 226 and OB 227, which could previously be used to check the checksum, always return the result "correct checksum".                                                                                                                                                                                                                                    |  |  |

### 6.31 OB 228: Reading Status Information of a Program Processing Level

FunctionIf a particular event occurs, the system program calls the corresponding program<br/>processing level. The program processing level is then "activated".<br/>Using organization block OB 228, you can find out whether a specific program<br/>processing level is active or not at a particular time. Transfer the number of the<br/>program processing level whose status you want to scan to ACCU 1. (The<br/>numbers are those entered under LEVEL in the ISTACK).

When the block is called, it stores the status information of the specified program level in ACCU-1-L. By evaluating this information, you can make your program execution dependent on the status of another program processing level.

Parameters ACCU-1-L

Number of the program processing level (see ISTACK, LEVEL) possible values (hexadecimal): see following table

| Level no. in<br>ACCU-1-L | Level name            | Level no. in<br>ACCU-1-L | Level name                  |
|--------------------------|-----------------------|--------------------------|-----------------------------|
| 02                       | COLD RESTART          | 26                       | Not used                    |
| 04                       | CYCLE                 | 28                       | Not used                    |
| 06                       | TIME INTERRUPT 5 sec  | 2A                       | Not used                    |
| 08                       | TIME INTERRUPT 2 sec  | 2C                       | Abort                       |
| 0A                       | TIME INTERRUPT 1 sec  | 2E                       | Interface error             |
| 0C                       | TIME INTERRUPT 500 ms | 30                       | Collision of time interrupt |
| 0E                       | TIME INTERRUPT 200 ms | 32                       | Controller error            |
| 10                       | TIME INTERRUPT 100 ms | 34                       | Cycle error                 |
| 12                       | TIME INTERRUPT 50 ms  | 36                       | Not used                    |
| 14                       | TIME INTERRUPT 20 ms  | 38                       | Operation code error        |
| 16                       | TIME INTERRUPT 10 ms  | 3A                       | Runtime error               |
| 18                       | TIMED JOB             | 3C                       | Addressing error            |
| 1A                       | Not used              | 3E                       | Timeout                     |
| 1C                       | CONTROLLER INTERRUPT  | 40                       | Not used                    |
| 1E                       | Not used              | 42                       | Not used                    |
| 20                       | DELAY INTERRUPT       | 44                       | MANUAL                      |
| 22                       | Not used              |                          | WARM RESTART                |
| 24                       | PROCESS INTERRUPT     | 46                       | AUTOMATIC                   |
|                          |                       |                          | WARM RESTART                |

**Result**• ACCU-1-L: contains the status information:<br/>= 0Program processing level has not been called<br/> $\neq 0$  $\neq 0$ Program processing level has been activated

• ACCU-2-L: contains the previous contents of ACCU-1-L; the previous contents of ACCU-2-L are lost

Possible errors none

#### Example

You want to ignore a timeout during the COLD RESTART, however, not in the remaining program processing levels. Call special function organization block OB 228 at the beginning of OB 23 to check whether program processing level COLD RESTART (number 02) is active or not when a QVZ (timeout) occurs. You can make the reactions to the error dependent on the status information you obtain as follows: ACCU 1= 0: COLD RESTART not active - $\rightarrow$  QVZ has not occurred in COLD RESTART, but in another program processing level Error handling program must be executed ACCU 1  $\neq$  0: COLD RESTART activated —  $\rightarrow$  QVZ has occurred in COLD RESTART QVZ can be ignored Using OB 228, you can differentiate between various methods of handling errors.

## 6.32 OB 230 to 237: Functions for Standard Function Blocks

| Introduction            | The special function organization blocks OB 230 to OB 237 are reserved for data handling functions and can only be called in the standard function blocks FB 120 to FB 127.                                                                                                                                   |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data handling<br>blocks | These standard function blocks, the data handling blocks known simply as "handling blocks", control the data exchange via the page area in the single and multiprocessor modes. They are used when data or parameters and control information are transferred to or from the communications processors (CPs). |

**Assignment aid** You can use the table below to find out which handling blocks call the special function organization blocks OB 230 to OB 237.

| Standard<br>function block | Special function<br>Organization block | Handling<br>block |
|----------------------------|----------------------------------------|-------------------|
|                            |                                        |                   |
| FB 120                     | SF-OB 230                              | SEND              |
| FB 121                     | SF-OB 231                              | RECEIVE           |
| FB 122                     | SF-OB 232                              | FETCH             |
| FB 123                     | SF-OB 233                              | CONTROL           |
| FB 124                     | SF-OB 234                              | RESET             |
| FB 125                     | SF-OB 235                              | SYNCHRON          |
| FB 126                     | SF-OB 236                              | SEND ALL          |
| FB 127                     | SF-OB 237                              | RECEIVE ALL       |

Using the handling blocks

The use of the handling blocks, that can be ordered as a software product on diskette, is described in the manual "S5 135U programmable controller, handling blocks for the R processor and CPU 928/928B" /5/).

# 6.33 OB 240 to 242: Special Functions for Shift Registers

| Introduction                      | This introduction tells you what you can use shift registers for and the points to note in doing so.                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Application                       | You can use shift registers, e.g. in a manufacturing process, to program a materials follow-up on the programmable controller. On the CPU 928B, you have a maximum of 64 software shift registers available.                                                                                                                                                                                                                                                                                                    |
|                                   | You can write data to the shift register and read data from it. This is done using "pointers". Pointers are flag bytes that contain the contents of individual cells of a shift register.                                                                                                                                                                                                                                                                                                                       |
| Structure                         | A software shift register consists of rows of 8-bit wide memory cells and can be between 2 and 256 memory cells long.                                                                                                                                                                                                                                                                                                                                                                                           |
| <i>Location in the<br/>DB-RAM</i> | The data of a shift register are located in the data block RAM of the CPU. Each shift register is assigned to a specific data block and also has the same number as the data block (permitted: 192 to 255). If you set up a shift register with the number 210, the corresponding data is in data block DB 210.                                                                                                                                                                                                 |
|                                   | The DB-RAM has a capacity of 46 Kbytes (address KH 8000 to KH DD7F). This area contains the data blocks (starting from KH 8000 in ascending order) copied using OB 254 and 255 and the shift registers you have set up (starting from KH DD7F in descending order). If the memory area of the DB RAM is not sufficient for copying DBs or setting up shift registers, the CPU recognizes a runtime error and calls OB 31. The reactions to the error depend on how you have programmed OB 31 (see Section 5.6). |

# Principle of a shift register

The following schematics illustrate the principle of a software shift register with three pointers and twelve memory cells.



Fig. 6-13 Schematic showing the principle of a shift register with 3 pointers and 12 memory cells

**Initializing** When you initialize a shift register (see Section 6.34), you specify the number of the flag byte for pointer 1 (= base pointer). This is then set permanently on the first memory cell of the shift register. You then position all the other pointers relative to the base pointer (you can use between one and a maximum of six pointers per shift register).

**Shifting** When you shift a shift register (like a hardware shift register), the total contents of all the shift register cells are transferred in bytes from one memory cell to the next (see Fig. 6-13). Each time the shift register function is called, the information is shifted one memory cell (corresponds to one clock pulse), and the pointers are supplied with new contents. As shown by the arrows, the information is shifted through the complete shift register to the last memory cell from where it returns to memory cell 1 (after 12 clock pulses for the shift register illustrated in the schematic).

Example



```
Continuation of the example:
You can now evaluate the information in the pointers as follows:
:L FY 0
:
etc.
Flag bits 0, 3 and 2 can be scanned at the base pointer: in this way, you
can evaluate all the information from the entries in all pointers at the
base pointer (in the example, this requires twelve clock pulses).
```

OrganizationIf you want to use a shift register, there are three special function organizationblocksblocks available:

• **OB 240**:

This funciton **initializes** a shift register.

• **OB 241**:

This function **processes** a shift register.

• **OB 242**:

This function **deletes** a shift register.

## 6.34 OB 240: Initializing Shift Registers

| Application | Before processing a shift register, you must first initialize it. This is done by calling OB 240 once (ideally in a restart organization block). The parameters that OB 240 requires to create a shift register are contained in a data block with the number of the shift register to be initialized. DB numbers between 192 and 255 are permitted. |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function    | A specific memory area at the end of the DB-RAM is reserved and initialized with the information from the opened data block.                                                                                                                                                                                                                         |
| Parameters  | Opened data block                                                                                                                                                                                                                                                                                                                                    |

possible values: DB no. 192 to 255

The data block has a fixed structure which you must not change. It can have a maximum length of 9 data words (DW 0 through DW 8).

| 0                                        | DW 0                   |
|------------------------------------------|------------------------|
| Shift register length (bytes) L          | DW 1                   |
| Number of the 1st flag byte/base pointer | DW 2                   |
| Interval n <sub>2</sub>                  | DW 3                   |
| Interval n 3                             | DW 4                   |
| Interval n <sub>4</sub>                  | DW 5                   |
| Interval n <sub>5</sub>                  | DW 6                   |
| Interval n <sub>6</sub>                  | DW 7                   |
| 0                                        | DW 8 or last data word |
| 1                                        |                        |

Fig. 6-16 Structure of the data block for initializing a shift register

# Data word assignment

The individual data words must be assigned as follows:

#### Data word 0

Must always contain the value 0.

#### Data word 1

The shift register length L is the number (in bytes) of memory locations of the shift register. It can be within the range between  $2 \le L \le 256$ .

#### Data word 2

The number of the first flag byte determines the base pointer and with it the block of flags assigned to the pointers. The block of flags contains the total number of pointers you have selected. You select pointers by making entries in data words DW 3 to maximum DW 7, using one data word per pointer. If, for example, you want to set up two further pointers, you then have a total of three pointers. Make sure that you have enough flags available for all pointers up to the end of the block of flags.

#### Data word 3 to maximum 7

You specify the other pointers indirectly. They are defined by their distance (shift register cells = number of bytes) from the base pointer.

 $n_2$  = distance from pointer 2 to base pointer

 $n_3$  = distance from pointer 3 to base pointer

 $n_4$  = distance from pointer 4 to base pointer

etc. (1 to maximum 5 entries)

#### Last data word (DW 4 to maximum DW 8)

(in the example DW 8). This must always contain the value zero. If you only select two additional pointers, the "0" is in data word DW 5 etc.

All the information is specified as fixed point numbers.

|                                      | <ul> <li>Note The number of pointers (6 including the base pointer) must not exceed the length of the shift register. </li> <li>The distance of a pointer to the base pointer must not exceed the length of the shift register.</li> <li>Data word DW 0 and the data word after the last pointer distance must always contain 0. The data block must be open before OB 240 is called. The data block must have a number in the range DB 192 to DB 255.</li></ul>                                                                                                                                        |
|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>Memory</i><br><i>requirements</i> | n = shift register length/2 + 8 data words<br>are required for every shift register, i.e. the length of the DB RAM is reduced by<br>n data words. The data block RAM end address is shifted to lower addresses. If<br>you attempt to initialize a shift register that already exists, the area already<br>assigned will be initialized again providing the new and old shift registers both<br>have the same length. Otherwise the old area will be declared invalid and a new<br>area will be opened.                                                                                                  |
| Possible errors                      | <ul> <li>illegal data block number (&lt;192)</li> <li>not enough memory space in the DB RAM</li> <li>formal error in the structure of the data block</li> <li>illegal length specified for the shift register</li> <li>errors in the pointer parameters</li> <li>In the event of an error, the CPU recognizes a runtime error and calls OB 31.<br/>What happens then depends on how you have programmed OB 31 (see Section 5.6). If OB 31 is not loaded, the CPU goes to the stop mode.</li> <li>In both cases, error IDs are entered in ACCU-1-L that describe the error in greater detail.</li> </ul> |

# 6.35 OB 241: Processing Shift Registers

| Introduction    | The special function organization block OB 241 processes a shift register providing it has been initialized by OB 240. In the CPU 928B, you can call a maximum of 64 shift registers.                                                                                                                                                                                                                                                                    |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Application     | Before you call OB 241, certain flag bits are usually set/reset in the pointers.<br>Each time OB 241 is called, the information is shifted byte by byte from one<br>memory cell to the next higher memory cell. The pointers are then supplied with<br>new contents. By repeatedly calling OB 241, the information can be shifted<br>through the complete shift register to the last memory cell. From here, it is then<br>transferred to memory cell 1. |
| Function        | Each time OB 241 is processed, the shift register addressed via ACCU-1-L is shifted one position to the right.                                                                                                                                                                                                                                                                                                                                           |
| Parameters      | ACCU-1-L                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | Number of the shift register to be processed,<br>permissible values: 192 to 255                                                                                                                                                                                                                                                                                                                                                                          |
| Result          | After you call OB 241, the pointers (maximum 6 per shift register) that can be positioned as required with the exception of the base pointers contain the information of the preceding memory cell. You can then evaluate this information.                                                                                                                                                                                                              |
| Possible errors | • illegal shift register number in ACCU 1                                                                                                                                                                                                                                                                                                                                                                                                                |
|                 | • shift register not initialized.                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                 | In the event of an error, the CPU recognizes a runtime error and calls <b>OB 31</b> . What happens then depends on how you have programmed OB 31 (see Section 5.6). If OB 31 is not loaded, the CPU goes to the stop mode.                                                                                                                                                                                                                               |
|                 | In both cases, error IDs are entered in ACCU-1-L that describe the error in greater detail.                                                                                                                                                                                                                                                                                                                                                              |

## 6.36 OB 242: Deleting a Shift Register

| Function        | With this function, you can delete a shift register in the data block RAM. The entry in the DB 0 address list is cleared and the shift register is declared invalid in the DB RAM (remember: shift registers still occupy memory space after they have been deleted). |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Parameters      | ACCU-1-L                                                                                                                                                                                                                                                              |  |  |
|                 | Number of the shift register to be deleted,possible values:192 to 255                                                                                                                                                                                                 |  |  |
| Result          | After you call OB 242, the shift register is deleted and can no longer be used; if you want to work with it again, it must be reinitialized.                                                                                                                          |  |  |
| Possible errors | <ul> <li>illegal shift register number in ACCU 1</li> <li>shift register not initialized</li> </ul>                                                                                                                                                                   |  |  |
|                 | In the event of an error, the CPU recognizes a runtime error and calls <b>OB 31</b> .<br>What happens then depends on how you programmed OB 31 (see Section 5.6).<br>If OB 31 is not loaded, the CPU goes to the stop mode.                                           |  |  |
|                 | In both cases, error IDs are entered in ACCU-1-L that describe the error in greater detail.                                                                                                                                                                           |  |  |

## 6.37 OB 250/251: Closed-Loop Control/ PID Algorithm

*Introduction* You can work with one or more PID controllers in the CPU 928B of the S5-135U. Each controller must be initialized in the restart organization block. A data block is used to transfer the parameters.

The actual control algorithm is integrated in the system program and you can simply call it as an organization block. A data block is used as the data interface between the control algorithm and the user program.

#### 6.37.1 Functional Description of the PID Controller



Fig. 6-17 Block diagram of the PID controller

#### Index k

## k times sampling

| Switch           | Setting | Effect                                                          |
|------------------|---------|-----------------------------------------------------------------|
| S1               |         |                                                                 |
| CONTROL<br>BIT 1 | 0       | The system error $XW_k$ is supplied to the derivative unit.     |
|                  | 1       | The derivative unit can be supplied with another signal via XZ. |
| S2               |         |                                                                 |
| CONTROL<br>BIT 0 | 0       | Manual operation                                                |
|                  | 1       | Automatic                                                       |
| S3               |         |                                                                 |
| CONTROL<br>BIT 3 | 0       | Position algorithm                                              |
|                  | 1       | Velocity algorithm                                              |
| S4               |         |                                                                 |
| CONTROL<br>BIT 5 | 0       | With feedforward control                                        |
|                  | 1       | Without feedforward control                                     |

| STEU control<br>word                   | You obtain a function corresponding to the switch settings of the block diagram<br>by assigning parameters to the PID controller, i.e. by setting the control bits in<br>the control word STEU. The continuous controller is intended for fast control<br>systems, e.g. in process engineering for pressure, temperature or flow rate control.                                                                              |
|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PID algorithm                          | The controller itself is based on a PID algorithm. Its output signal can either be<br>output as a manipulated variable (position algorithm) or as a change of<br>manipulated variable (velocity algorithm).<br>You can disable the individual P, I and D actions by setting their parameters R,<br>TI and TD to zero. This allows you to implement any controller structure you<br>require, e.g. PI, PID or PD controllers. |
| Differentiator                         | You can supply the derivative unit either with the system error XW or a disturbance or the inverted actual value -x can be supplied via the XZ input.                                                                                                                                                                                                                                                                       |
| Disturbance<br>compensation            | If you require a precontrol of the actuator without dynamic behavior to compensate for the influence of a disturbance, then a disturbance Z measured in the process can be fed forward to the control algorithm. In manual operation, this is replaced by the preselected manipulated variable YM.                                                                                                                          |
| Inverted control direction             | If you require an inverted control direction, preset a negative K value.                                                                                                                                                                                                                                                                                                                                                    |
| Limiting the<br>control<br>information | If the control information (dY or Y) reaches a limit, the I action is automatically disabled in order to prevent deterioration of the controller response.                                                                                                                                                                                                                                                                  |
|                                        | You can supply the control program with preset fixed values or with adaptive (dynamic) parameters (K, R, TI, TD). These are input via the memory cells assigned to the individual parameters.                                                                                                                                                                                                                               |

#### 6.37.2 PID Algorithm

**Introduction** The PID controller is based on a velocity algorithm according to which the control increment  $dY_k$  is calculated at time t = k \* TA, according to the following formula:

$$dY_{k}=K\left[\left(XW_{k}-XW_{k-1}\right)R+\frac{TA}{2TN}\left(XW_{k}+XW_{k-1}\right)+\frac{1}{2}\left\{\frac{TV}{TA}\left(XU_{k}-2XU_{k-1}+XU_{k-2}\right)+dD_{k-1}\right\}\right]$$
$$=K\left(dPW_{k}R+dI_{k}+dD_{k}\right)$$
Paction I action D action

dXXX<sub>k</sub>: change in variable XXX at time t.

U can be either W or Z, depending on whether XW or XZ is supplied to the derivative unit. The following applies:

If XW<sub>k</sub> is supplied:  $PW_{k} = W_{k} - X_{k}$   $PW_{k} = XW_{k} - XW_{k-1}$   $QW_{k} = PW_{k} - PW_{k-1}$   $QZ_{k} = PZ_{k} - PZ_{k-1}$   $QW_{k} = XW_{k} - 2XW_{k-1} + XW_{k-2}$   $QZ_{k} = XZ_{k} - 2XZ_{k-1} + XZ_{k-2}$   $dPW_{k} = (XW_{k} - XW_{k-1})R$   $dI_{k} = TI * XW_{k}$   $TI = \frac{TA}{TN}$   $dD_{k} = \frac{1}{2} (TD * QU_{k} + dD_{k-1})$   $TD = \frac{TV}{TA}$ 

If you require the manipulated variable  $Y_k$  at the controller output at time  $t_k$ , it is calculated according to the following formula:

$$Y_k = \sum_{m=0}^{m=k} dY_m$$

With most controller structures, it is assumed that R = 1 if a P action is required.

Using the variable R, you can adjust the proportional action of the PID controller.

Data blocks for Controller-specific data are input using a transfer data block (see Sections 6.38 the PID controller and 6.39) for initialization and processing of the PID controller.

You must specify these data in the transfer data block x:

K, R, TI, TD, W, STEU, YH, ULV, LLV

The transfer data block must contain data words 0 to 48, i.e. it is 49 data words long. The following table explains the significance of these data words.

#### Structure of the transfer data block

| Table 6-10 | Transferring the data block for PID control |  |
|------------|---------------------------------------------|--|
|            |                                             |  |

| Addr.<br>in DB | Name           | <b>I/O</b><br>1) | Numerical<br>format<br>2) | PG<br>format<br>3) | Remarks                                                                                                                                                                                                                                      |
|----------------|----------------|------------------|---------------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>DW</b> 0    | _              | _                |                           |                    | Reserve                                                                                                                                                                                                                                      |
| DD 1           | К              | Ι                | FLP                       | KG                 | <ul> <li>Proportional cooefficient</li> <li>K &gt;0: Positive control direction, i.e. change of actual value and manipulated variable in same direction</li> <li>K &lt;0: Negative control direction, floating point number range</li> </ul> |
| DD 3           | R              | Ι                | FLP                       | KG                 | R parameter, usually equals 1 for controllers with P action                                                                                                                                                                                  |
| DD 5           | TI             | Ι                | FLP                       | KG                 | TI = TA/TN                                                                                                                                                                                                                                   |
| DD 7           | TD             | Ι                | FLP                       | KG                 | TD = TV/TA                                                                                                                                                                                                                                   |
| DD 9           | Wk             | Ι                | FLP                       | KG                 | Setpoint input here, when control bit $6 = 1$ , otherwise in word no. 19 $(-1 \le W_k < 1)$                                                                                                                                                  |
| DW11           | STEU           | Ι                | FLP                       | KM                 | Control word                                                                                                                                                                                                                                 |
| DD 12          | YHk            | Ι                | FLP                       | KG                 | Manual input here, when control bit $6 = 1$ ; otherwise in word<br>no. 18 (-1 $\leq$ YH <sub>k</sub> <1)<br>For velocity algorithms, you must specifiy manipulated variable<br>increments here                                               |
| DD14           | ULV            | Ι                | FLP                       | KG                 | Upper limit value <sup>4)</sup><br>-1 $\leq$ ULV $\leq$ 1 (YA <sub>k max</sub> );<br>!! LLV $\leq$ ULV !!                                                                                                                                    |
| DD 16          | LLV            | Ι                | FLP                       | KG                 | Lower limit value <sup>4)</sup><br>-1 $\leq$ LLV $\leq$ 1 (YA <sub>k min</sub> )                                                                                                                                                             |
| DW18           | YHk            | Ι                | NF                        | KF                 | Manual input here, when control bit $6 = 0$ (-1 $\leq$ YH $<$ 1). For velocity algorithms, you must specify manipulated variable increments here                                                                                             |
| DW19           | Wk             | Ι                | NF                        | KF                 | Setpoint input here, when control bit $6 = 0$ (-1 $\leq$ W <sub>k</sub> $<$ 1)                                                                                                                                                               |
| DW 20          | MERK           | Ι                | BP                        | KM                 | Bit 0 = 1: positive limit exceeded;<br>Bit 1 = 1: below negative limit                                                                                                                                                                       |
| DW 21          | Xk             | Ι                | NF                        | KF                 | Actual value input for control bit 7 = 0 (-1 $\leq X_k <$ 1)                                                                                                                                                                                 |
| DD 22          | X <sub>k</sub> | Ι                | FLP                       | KG                 | Actual value input for control bit 7 = 1 (-1 $\leq X_k <$ 1)                                                                                                                                                                                 |
| DW 24          | Z <sub>k</sub> | Ι                | NF                        | KF                 | Disturbance $(-1 \le Z_k \le 1)$                                                                                                                                                                                                             |
| DD 25          | Z <sub>k</sub> | Ι                | FLP                       | KG                 | Disturbance input here, if control bit $7 = 1 (-1 \le Z_k \le 1)$                                                                                                                                                                            |

| Addr.<br>in DB | Name              | <b>I/O</b><br>1) | Numerical<br>format<br>2) | PG<br>format<br>3) | Remarks                                                                                                             |  |
|----------------|-------------------|------------------|---------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------|--|
| Table 6-10 d   | continued:        |                  | •                         |                    |                                                                                                                     |  |
| DD 27          | Z <sub>k-1</sub>  | Ι                | FLP                       | KG                 | Historical value of the disturbance                                                                                 |  |
| DW 29          | XZ <sub>k</sub>   | Ι                | NF                        | KF                 | Value supplied to the derivative unit via input XZ (-1 $\leq$ XZ <sub>k</sub> <1); input here, if control bit 7 = 0 |  |
| DD 30          | XZ <sub>k</sub>   |                  | FLP                       | KG                 | XZ input here, if control bit 7 = 1 (-1 $\leq$ XZ <sub>k</sub> $\leq$ 1)                                            |  |
| DD 32          | XZ <sub>k-1</sub> | Ι                | FLP                       | KG                 | Historical value of XZk                                                                                             |  |
| DD 34          | PZ <sub>k-1</sub> | Ι                | FLP                       | KG                 | XZ <sub>k-1</sub> - XZ <sub>k-2</sub>                                                                               |  |
| DD 36          | dD <sub>k-1</sub> |                  | FLP                       | KG                 | Derivative action                                                                                                   |  |
| DD 38          | XW <sub>k-1</sub> |                  | FLP                       | KG                 | Historical value of the system error                                                                                |  |
| DD 40          | PW <sub>k-1</sub> |                  | FLP                       | KG                 | XWk-1 - XWk-2                                                                                                       |  |
| DW 42          |                   | _                | FLP                       | KG                 | Reserve                                                                                                             |  |
| DD 44          | Y <sub>k-1</sub>  |                  | FLP                       | KG                 | Historical value of the calculated manipulated variable Yk-1 or $dY_{k-1}$ before the limiter                       |  |
| DD 46          | YAk               |                  | FLP                       | KG                 | Output variable                                                                                                     |  |
| DW 48          | YA <sub>k</sub>   |                  | NF                        | KF                 | Output variable ULV ≤YA ≤ LLV                                                                                       |  |

<sup>1)</sup> I = input, Q = output

<sup>2)</sup> FLP = floating point number, NF = normalized fixed point number (see page 6 - 103), BP = bit pattern

<sup>3)</sup> Suggested format (KH, KM also permitted)

<sup>4)</sup> In normalized fixed point format, the upper and lower limit value must be entered according to the following formulas:

| DD 14 = BGOG: | Value as fixed point number = | <u>BGOG</u><br>32767 |
|---------------|-------------------------------|----------------------|
| DD 16 = BGUG: | Value as fixed point number = | BGUG<br>32767        |

# Example of limit values

```
- Limit values
Upper limit value = 0.1
Lower limit value = -0.1
- Entries in the DB:
DD 14: *1000 000 +00
DD 16: -1000 000 +00
- Output variable is limited:
DW 48: +-3276
DD 15: +-0.1
Note:
For limit values outside 1, the output variable is limited in floating
point format (DD 46).
```

#### Bit assignment of the control word STEU (data word DW 11 in the transfer DB)

| DW 11<br>Bit no. | Name    | Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11.0             | AUTO    | <ul><li>= 1: Automatic operation</li><li>= 0: Manual operation</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 11.1             | XZ_INP  | <ul> <li>=1: Another variable (not XWk), is supplied to the derivate unit by the input</li> <li>= :: XWk is supplied to the derivate unit. The XZ input is ignored.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 11.2             | DIS_CTR | <ul> <li>= 1: When the controller is called (OB 251) all variables (DW 20 to DW 48) except K, R, TI, TD, BGOG, BGUG, STEU, YH<sub>k</sub>, W<sub>k</sub>, Z<sub>k</sub> and Z<sub>k-1</sub> are cleared once in the DB-RAM. The controller is disabled. The historical value of the disturbance is updated.</li> <li>= 0: control</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 11.3             | VELOC   | <ul><li>= 1: Velocity algorithm</li><li>= 0: Position algorithm</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 11.4             | MANTYPE | <ul> <li>= 1: If VELOC = 0 (position algorithm) the last manipulated variable to be output is retained.<br/>If VELOC is 1 (velocity algorithm) the control increment dY<sub>k</sub> = 0 is set.</li> <li>= 0: If VELOC = 0, then after switching to manual operation, the value of the manipulated variable output YA is brought to the selected manual value exponentially in four sampling steps.<br/>Following this, other manual variables are accepted immediately at the controller output.<br/>If VELOC = 1, the manual values are switched through to the controller output immediately. In manual operation, the limits are effective. In manual operation the following variables are updated:<br/>X<sub>k</sub>, SW<sub>k-1</sub> and PW<sub>k-1</sub><br/>XZ<sub>k</sub>, XZ<sub>k-1</sub> and PZ<sub>k-1</sub>, if control bit 1 = 1<br/>Z<sub>k</sub> and Z<sub>k-1</sub>, if control bit 5 = 0<br/>The variable dD<sub>k-1</sub> is set to = 0. The algorithm is not calculated.</li> </ul> |
| 11.5             | NO_Z    | <ul><li>= 1: no feedforward control</li><li>= 0: with feedforward control</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 11.6             | PGDG    | <ul> <li>= 1: W<sub>k</sub>, YH<sub>k</sub> input as floating point number</li> <li>= 0: Input as normalized fixed point number</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11.7             | VAR_FLP | <ul> <li>= 1: The variables X<sub>k</sub>, XZ<sub>k</sub> and Z<sub>k</sub> are input as floating point numbers</li> <li>= 0: Input of the variables as normalized fixed point numbers</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 11.8             | BUMP    | <ul><li>= 1: No bumpless changeover from manual to automatic</li><li>= 0: Bumpless changeover from manual to automatic</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 11.9 to          | 11.15   | Irrelevant                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

Table 6-11Control word in the transfer DB for PID control

# 6.38 OB 250: Initializing the PID Algorithm

| Function        | OB 250 initializes the PID algorithm and is called in the restart OBs 20/21/22.                                                                                                                                                                                                                                                                                                                                         |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parameters      | The parameters required for the initialization are contained in the transfer data block (DB x).                                                                                                                                                                                                                                                                                                                         |
|                 | <b>Note</b><br>The transfer data block must be open before OB 250 is called.                                                                                                                                                                                                                                                                                                                                            |
|                 | For data transfer, each controller requires its own DB x (x $\leq$ 254). From this, the system program automatically generates a further DB x + 1 in the data block RAM, that the controller uses as a data field in cyclic operation. This means that the corresponding DB numbers must still be available. Data blocks DB x + 1 represent the data interfaces between the controller and the user or peripheral I/Os. |
| Possible errors | Internally, OB 250 uses OB 254 or OB 255 (duplication of data blocks). In the event of an error, the CPU recognizes a runtime error and calls OB 31. If this is not programmed, the CPU goes to the stop mode. The error IDs entered in ACCU 1 then refer to OB 250.                                                                                                                                                    |
|                 | <b>Note</b><br>If DB x + 1 is not kept free during the initialization, it will be used as a controller data field without any warning if its length is identical to that of a controller DB (49 data words); data words 20 through 48 are cleared. Otherwise the CPU goes to the stop mode.                                                                                                                             |
|                 | Instead of DB data blocks, you can also use DX data blocks. Initialization is the                                                                                                                                                                                                                                                                                                                                       |

same as with DB data blocks.

# 6.39 OB 251: Processing the PID Algorithm

| Application                                   | OB 251 is called during cyclic program execution and processes the PID algorithm.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Call                                          | The controller should be called after the sampling time has elapsed. Keep to the following order:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                               | 1. Call data block DB x + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                               | 2. Load input data $X_k$ , $XZ_k$ , $Z_k$ and $YH_k$ or a subset of these                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                               | 3. Convert input data to the correct format and transfer it to DB $x + 1$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                               | 4. Call OB 251 (process PID controller)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                               | 5. Load the output data $YA_k$ from DB x + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                               | 6. Convert the data and transfer to the process I/Os                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Format of<br>controller inputs<br>and outputs | Internally, the PID control algorithm uses the floating point format for numerical representation and can be supplied with floating point values. You can also supply the PID controller algorithm using the normalized fixed point format (see bits 6 and 7 in the control word STEU). In this case, the controller automatically converts the words to the floating point format with every call.<br>Adaptation of words from the input and output modules in the STEP 5 program is faster if you use the normalized fixed point format (see table at the end of this section). |
| Inputs                                        | You can input W, YH, X, Z and XZ as floating point or normalized fixed point numbers. Different memory cells are reserved for each variable in the data transfer block.                                                                                                                                                                                                                                                                                                                                                                                                           |
| Input as<br>normalized fixed<br>point numbers | <ul> <li>(For an explanation of the normalized fixed point numbers, see the table at the end of this section).</li> <li>Note</li> <li>While keeping within the nominal input ranges of the analog input modules,</li> </ul>                                                                                                                                                                                                                                                                                                                                                       |
|                                               | do not forget that the bit pattern for a certain input ranges of the analog input modules,<br>do not forget that the bit pattern for a certain input value is different from<br>when you use the full input range. This is particularly important when you<br>adjust the setpoint. Otherwise, it is possible that a setpoint input at the PG<br>cannot be reached although the actual value is far higher than the desired<br>value.                                                                                                                                              |

|               | If your analog-to-digital converter supplies negative numbers as a number and sign, the 2's complement of this number must be formed before it is transferred to the controller DB. Following this, the binary digit 15 must be set to 1.                                                                                                                                                                                                             |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | If the number -0 is possible as a number and sign in the following format:                                                                                                                                                                                                                                                                                                                                                                            |
|               | 100000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|               | in your analog-to-digital converter, the 2's complement must not be formed. The number must be transferred to the controller DB as +0:                                                                                                                                                                                                                                                                                                                |
|               | 00000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Output        | The controller output YA exists in the DB as a normalized fixed point number<br>and a floating point number. Taking into account the input and output modules<br>used (analog-to-digital converter, digital-to-analog converter) the format must be<br>converted for normalized fixed point inputs and outputs before and after the<br>controller is called in the STEP 5 user program before values are transferred to or<br>from the controller DB. |
| General notes | • Using BUMP                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|               | If BUMP (control bit 8) is set to zero, the changeover from manual to automatic operation is bumpless, i.e. the system error, however large it may be, is corrected only by the I action. If, however, you have selected $TI = TA/TN = 0$ (P or PD controller) the system error does not cause a change of the manipulated variable when the changeover takes place.                                                                                  |
|               | You can prevent this by setting BUMP = 1. This means that a system error is corrected quickly when there is a manual-to- automatic changeover, irrespective of $TI = 0$ . The manipulated variable jump that results corresponds to the value of the system error, which means that it is not arbitrary in the sense of a disturbance of the controller operation.                                                                                    |

• Displaying MERK, bits 0 and 1

Bits 0 and 1 of MERK can be displayed if required to show that the manipulated variable (for velocity algorithm, the control increment) lies between the upper and lower limits. Since these bits are evaluated by the algorithm for disabling the I action, you cannot overwrite them.

#### Note

You must not reload the controller data blocks DB x + 1 during cyclic operation.

#### Cascade control

If two or more controllers are cascaded, remember the following points:

- If the cascade is split, either all the controllers have to change to manual operation simultaneously to prevent any controller drift due to the I action or at least the controller of the outer loop must be operated manually to ensure that the last manipulated variable corresponding to the setpoint of the inner loop is retained or changed to a safe value.
- If you want to close the cascade, both loops should operate at the same time in the automatic mode or at least the inner loop to ensure that the manipulated variable of the outer loop is taken as the setpoint.

#### • Switching to manual mode

If the control system is disconnected from the controller and directly adjusted at the actuator following the changeover to manual operation, the manipulated variable obtained must be supplied to the controller via the manual input. This ensures that when you change from manual to automatic operation, the controller output will correspond to the manipulated variable set during manual operation. In the case of the velocity algorithm, this will be the change in the manipulated variable.





#### PI controller

The parameters for a PI controller are the proportional cooefficient K and the reset time TN. The proportional cooefficient K is the quotient of the output and input value and determines the P action. The reset time TN is the time required to respond to achieve the same change in the manipulated variable due to the I action as occurs due to the P action.



#### • PD controller

The parameters for a PD controller are the proportional cooefficient K (see above) and the derivative time constant TV. The derivative time constant is the time a P controller would require at a constant rate of change of the input variable to bring about the same change in the output variable that is brought about immediately by the D action of a PD controller. To determine the derivative time constant, a linear change in the input variable is assumed and not a jump function.



#### • PID controller

The parameters for a PID controller are the proportional cooefficient K, the reset time TN and the derivative time constant TV. These in turn determine the P, I and D actions.

The P action of the manipulated variable is obtained based on the following formula:

 $P action = KP^*(XW_k - XW_{k-1})$ 

Parameter

changes

If KP or R are changed during automatic operation, this only affects subsequent changes of the system error  $XW_k$ . The current value of the manipulated variable is not affected by the parameter change. This response allows for a bumpless change. If, however, you do not want this response, you can eliminate it using the following calculation, (example of a KP change). This calculation is only made once for each parameter change:

 $Y_{k-1} = Y_{k-1} + XW_{k-1}(KP_{new} - KP_{old})$ 

If you use the following program in the case of a parameter change, the controller responds like an analog controller.

| :L  | KPnew | load KP <sub>new</sub> |
|-----|-------|------------------------|
| :L  | KPold | load KP <sub>old</sub> |
| :-G |       |                        |
| :L  | DD38  | XW <sub>k-1</sub>      |
| :xG |       |                        |
| :L  | DD44  | Y <sub>k-1</sub>       |
| :+G |       |                        |
| :T  | DD44  | $= Y_{k-1}$            |

| Abbreviations for | dY <sub>k</sub> | Calculated control increment                        |
|-------------------|-----------------|-----------------------------------------------------|
| PID controllers   | dZk             | Disturbance increment                               |
|                   | FLP             | Floating point representation                       |
|                   | k               | k * sampling                                        |
|                   | Κ               | Proportional cooefficient                           |
|                   | LL              | Lower limit (limiter)                               |
|                   | NF              | Normalized fixed point representation               |
|                   | R               | R parameter                                         |
|                   | TA              | Sampling time                                       |
|                   | TD              | TV/TA                                               |
|                   | TI              | TA/TN                                               |
|                   | t               | Sampling instant = $\mathbf{k}^{\dagger}$ TA        |
|                   | TN              | Reset time                                          |
|                   | TV              | Derivative time constant                            |
|                   | UL              | Upper limit (limiter)                               |
|                   | Wk              | Setpoint                                            |
|                   | X <sub>k</sub>  | Actual value                                        |
|                   | $XW_k$          | System error                                        |
|                   | Yk              | Calculated manipulated variable                     |
|                   | YAk             | Value of manipulated variable (control increment or |
|                   |                 | manipulated variable)                               |
|                   | Zk              | Disturbance                                         |

# Normalized fixed point numbers

One word is required to represent a normalized fixed point number in a data block. The following example illustrates the difference between a fraction represented decimally, in binary and using the KF format on the programmer.

| Table 6-12 | Fraction |
|------------|----------|
|------------|----------|

| Frac                   | Fixed point                             |        |
|------------------------|-----------------------------------------|--------|
| Decimal representation | <b>Binary representation</b>            | number |
| -0.999                 | 100000000000000000000000000000000000000 | -32767 |
| -0.75                  | 101000000000000                         | -24576 |
| -0.5                   | 1100000000000000                        | -16384 |
| -0.25                  | 111000000000000                         | -8192  |
| 0                      | 000000000000000                         | 0      |
| +0.25                  | 001000000000000                         | + 8192 |
| +0.5                   | 0100000000000000                        | +16384 |
| +0.75                  | 011000000000000                         | +24576 |
| +0.999                 | 011111111111111                         | +32767 |

Negative normalized fixed point numbers in a binary representation are obtained by forming the 2's complement of the positive normalized fixed point number.

Normalized fixed point numbers (NF) can be converted to the values represented in the programmer (KF) as follows:

NF \* 32767 = KFwhere -1 < NF <+1 and  $-32767 \le KF \le +32767$ 

## 6.40 OB 254, OB 255: Transferring a Data Block to the DB-RAM

IntroductionSpecial function organization blocks OB 254 and OB 255 allow you to transfer<br/>data blocks from the user memory to the DB-RAM (data block memory) of the<br/>CPU. The special functions OB 254 and 255 are identical; OB 254 is used for<br/>DX data blocks and OB 255 for DB data blocks.

**Application**Shifting or duplicating a data block

#### Function • Shifting

Shifting a data block from the user memory to the DB-RAM

A data block is shifted from the user memory to the DB-RAM and **retains its original block number**. The new start address of the data block is entered in the address list in DB 0.

#### Duplicating

A data block in the user memory or in the DB-RAM is duplicated in the DB-RAM and assigned a **new block number**. The start address of the new data block is entered in the address list in DB 0. The start address of the old block is retained in DB 0, i.e. the original data block remains valid. The start address is only entered into DB 0 after the transfer is completed and all identifiers are entered correctly in the block header. The duplicated block is only accepted as valid or existing by the system program after it has been completely transferred.

#### Note

**Shifting DB0** into the DB-RAM is not possible since it already exists in the DB-RAM. However, you can **duplicate** DB 0.

| Parameters | 1. ACCU-1-L-L                                         |                                        |  |  |
|------------|-------------------------------------------------------|----------------------------------------|--|--|
|            | Number of the data block to be shifted or duplicated, |                                        |  |  |
|            | permitted values:                                     | 0 to 255                               |  |  |
|            |                                                       | (0 only for DX or for duplicating DBs) |  |  |

2. ACCU-1-H-L With the value in ACCU-1-H, you specify whether you want to shift or duplicate a block: ACCU-1-H-L = 0: the data block DB (OB 255 call) or DX with the number specified in ACCU-1-L-L is shifted to the DB-RAM ACCU-1-H-L = number for new block, permitted values: 1 to 255 the data block DB (OB 255 call) or DX (OB 254 call) with the number specified in ACCU-1-L-L is duplicated in the DB-RAM and entered in DB 0 with the number stored in ACCU-1-H-L.

The values for ACCU-1-L-H and ACCU-1-H-H are not considered by OB 254 and OB 255 and are therefore not significant for assigning parameters to the OBs.

- The data block to be shifted does not exist (OB 19).
  - The block already exists in the DB-RAM (OB 31). (therefore only execute the function once, ideally during the start-up).
  - Not enough memory space in the DB-RAM (OB 31).

In the event of an error, the function is not executed. The system program detects a runtime error and calls **OB 19 or OB 31**. How the CPU reacts to the error depends on the way in which OB 19 or OB 31 are programmed (see Section 5.6). If OB 19 or OB 31 is not programmed, the CPU goes into the stop mode.

In both cases, ACCU 1 contains an error identifier that defines the error in greater detail.

#### Example

It is assumed that the data blocks DB3 and DB4 are defined in the user memory. No DB should yet be present in the DB-RAM other than DB0. The following table shows the memory configuration after calling OB 255 several times with the parameters listed in the table.

| Order   | Function  | ACCU -1-  |      |           |      | DB in memory after call |            |  |
|---------|-----------|-----------|------|-----------|------|-------------------------|------------|--|
| of call |           | -H-H      | -H-L | -L-H      | -L-L | User mem.               | DB-RAM     |  |
| 1       | Shift     |           | 0    |           | 3    | DB 4                    | DB 3       |  |
| 2       | Duplicate | no signi- | 5    | no signi- | 4    | DB 4                    | DB 3,5     |  |
| 3       | Duplicate | ficance   | 6    | ficance   | 5    | DB 4                    | DB 3,5,6   |  |
| 4       | Shift     |           | 0    |           | 4    | no DB                   | DB 3,4,5,6 |  |
|         | •         |           |      |           |      |                         |            |  |
|         |           |           |      |           |      |                         |            |  |

# 7

# **Extended Data Block DX 0**

# Contents of the chapter

This chapter explains how to use the data block DX 0 and how it is structured. You will find information about the meaning of the various DX 0 patterns and will learn how to create and how to assign parameters via a screen form for a DX 0 data block based on examples.

# Overview of the chapter

| Section | Description                      | Page |
|---------|----------------------------------|------|
| 7.1     | Application                      | 7-2  |
| 7.2     | Structure of DX 0                | 7-3  |
| 7.3     | Parameters for DX 0              | 7-6  |
| 7.4     | Examples of Parameter Assignment | 7-10 |

## 7.1 Application

#### Introduction

You can match some of the activities of the system program to your own particular requirements by selecting settings in DX 0 that differ from the defaults.

The system program defaults (marked in table 7-1 by "D") are set automatically at each COLD RESTART. Following this, DX 0 is evaluated. If you do not program and load a DX 0 block, the defaults remain valid; otherwise, the settings you have made in DX 0 become valid.

You program DX 0 just as with other data blocks by assigning values using STEP 5 statements, (see Section 7.2) or with PG system software (S5-DOS from Version 3.0 onwards) entering the values as parameters in a special screen form on your PG.

Note

DX 0 is only evaluated when you perform a COLD RESTART. For any parameters which are not specified in DX 0, the defaults are retained.

# 7.2 Structure of DX 0

| Introduction | DX 0 is made up of the following three parts:                                                                                                                                                                          |  |  |  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|              | • the start ID for DX 0 (DW 0, 1 and 2)                                                                                                                                                                                |  |  |  |
|              | • several fields of varying lengths (depending on the number of parameters)                                                                                                                                            |  |  |  |
|              | • the end delimiter EEEE.                                                                                                                                                                                              |  |  |  |
| Start ID     | ASCII characters MASKX0 in DW 0 to DW 2                                                                                                                                                                                |  |  |  |
| Field        | A field in DX 0 consists of 1 to n data words, these contain the following:                                                                                                                                            |  |  |  |
|              | • the field ID                                                                                                                                                                                                         |  |  |  |
|              | • the field length                                                                                                                                                                                                     |  |  |  |
|              | and                                                                                                                                                                                                                    |  |  |  |
|              | • the field parameters.                                                                                                                                                                                                |  |  |  |
|              | The <b>field ID</b> explains the meaning of the parameters that follow. Each field is assigned to a specific system program part or to a specific system function (e.g. field ID "04" means cyclic program execution). |  |  |  |
| Field length | The <b>field length</b> indicates the number of data words needed for the parameters that follow.                                                                                                                      |  |  |  |
| Parameters   | Section 7.3 describes the possible <b>parameters</b> . Numerical values are specified in hexadecimal format (KH).                                                                                                      |  |  |  |
| End ID       | This indicates the end of DX 0 with EEEEH in the last data word.                                                                                                                                                       |  |  |  |

#### Formal structure



Fig. 7-1 Structure of DX 0

#### Example of DX 0

| Start ID                   | DW O: | KH = 4D41 |         |
|----------------------------|-------|-----------|---------|
|                            | DW 1: | KH = 534B |         |
|                            | DW 2: | KH = 5830 |         |
|                            | DW 3: | KH = 0101 | Field 1 |
| Parameters (occupies 1 DW) | DW 4: | KH = 1001 | FIELU I |
| <br>Field ID/length        | DW 5: | KH = 0402 |         |
| Parameters (occupies 2 DW) | DW 6: | KH = 1000 | Field 2 |
|                            | DW 7: | KH = 0040 |         |
| End ID                     | DW10: | KH = EEEE |         |
|                            |       |           |         |

When assigning parameters in DX 0, remember the following points:

- You can enter individual fields in any order.
- You do not need to specify fields you are not going to use.
- If a field exists more than once, the field you enter last is valid.
- You can enter individual parameters in any order.
- You do not need to specify parameters you are not going to use.
- If a particular parameter is specified several times, the parameter last specified is valid.

# 7.3 Parameters for DX 0

| Field ID/ length   | Parameters<br>1st/2nd word | <b>Meaning</b><br>(D = default with DX 0 not loaded or block/parameter missing)                                                                                                            |  |  |  |  |  |
|--------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                    |                            | RESTART and RUN:                                                                                                                                                                           |  |  |  |  |  |
| 02xx <sup>2)</sup> | 1000<br>1001               | D AUTOMATIC WARM RESTART after POWER UP<br>AUTOMATIC COLD RESTART after POWER UP                                                                                                           |  |  |  |  |  |
|                    | 2000<br>2001               | D Synchronization of RESTART in multiprocessor operation<br>No synchronization of RESTART in multiprocessor operation                                                                      |  |  |  |  |  |
|                    | 3000<br>3001               | D Addressing error monitoring<br>No addressing error monitoring                                                                                                                            |  |  |  |  |  |
|                    | 4000<br>4001               | D WARM RESTART<br>RETENTIVE COLD RESTART                                                                                                                                                   |  |  |  |  |  |
|                    | 6000                       | D Floating point arithmetic with 16-bit mantissa<br>(CPU always calculates with 24 bits)                                                                                                   |  |  |  |  |  |
|                    | 6001                       | Floating point arithmetic with 24-bit mantissa                                                                                                                                             |  |  |  |  |  |
|                    | ВВ00 уууу                  | Number of timers to be updated <sup>2)</sup><br>Default: yyyy = 256 timers, i.e. timer 0 to 255<br>permitted: 0256                                                                         |  |  |  |  |  |
|                    |                            | Cyclic program execution                                                                                                                                                                   |  |  |  |  |  |
| 04xx <sup>1)</sup> | 1000 уууу                  | Length of the cycle monitoring time in milliseconds;<br>default: yyyy = 150 ms,<br>permitted: 1≤ yyyy ≤ 32C8 (hex)<br>1 ms to 13000 ms (dec)                                               |  |  |  |  |  |
|                    | 4000<br>4001               | D Update of the process image of the IPC flags without semaphore protection<br>Upate of the process image of the IPC flags with semaphore protection<br>(in the field, see Section 10.1.3) |  |  |  |  |  |
|                    | I                          | Interrupt-driven program execution                                                                                                                                                         |  |  |  |  |  |
| 06xx <sup>1)</sup> | 3)                         | Selection of the processing mode <sup>3)</sup>                                                                                                                                             |  |  |  |  |  |
|                    | 2000<br>2001               | D Process interrupt signal, level-triggered<br>Process interrupt signal, edge-triggered                                                                                                    |  |  |  |  |  |
|                    |                            | Error handling                                                                                                                                                                             |  |  |  |  |  |
| 10xx <sup>1)</sup> | 1000<br>1001               | <ul><li>Collision of time interrupts</li><li>D System stop when the event occurs and OB 33 is not loaded</li><li>No system stop when the event occurs and OB 33 is not loaded</li></ul>    |  |  |  |  |  |
|                    | 1200<br>1201               | Controller error handling<br>D System stop when the event occurs and OB 34 is not loaded<br>No system stop when the event occurs and OB 34 is not loaded                                   |  |  |  |  |  |

Table 7-1DX 0 parameters and their meaning

| Field ID/ length   | Parameters<br>1st/2nd word | $Meaning^{1)}$ (D = default with DX 0 not loaded or block/parameter missing) |
|--------------------|----------------------------|------------------------------------------------------------------------------|
| Table 7-1 continue | ed:                        |                                                                              |
|                    |                            | Error handling (continued)                                                   |
| 10xx <sup>1)</sup> |                            | Cycle error handling                                                         |
|                    | 1400                       | D System stop when the event occurs and OB 26 is not loaded                  |
|                    | 1401                       | No system stop when the event occurs and OB 26 is not loaded                 |
|                    |                            | Operation code error handling                                                |
|                    | 1800                       | D System stop when the event occurs and OB 27/29/30 is not loaded            |
|                    | 1801                       | No system stop when the event occurs and OB 27/29/30 is not loaded           |
|                    |                            | Runtime error handling                                                       |
|                    | 1A00                       | D System stop when the event occurs and OB 19/31/32 is not loaded            |
| 1A01               |                            | No system stop when the event occurs and OB 19/31/32 is not loaded           |
|                    |                            | Addressing error handling                                                    |
|                    | 1C00                       | D System stop when the event occurs and OB 25 is not loaded                  |
|                    | 1C01                       | No system stop when the event occurs and OB 25 is not loaded                 |
|                    |                            | Timeout error handling                                                       |
|                    | 1E00                       | System stop when the event occurs and OB 23/24 is not loaded                 |
|                    | 1E01                       | D No system stop when the event occurs and OB 23/24 is not loaded            |
|                    |                            | Interface error handling                                                     |
|                    | 2000                       | System stop when the event occurs and OB 35 is not loaded                    |
|                    | 2001                       | D No system stop when the event occurs and OB 35 is not loaded               |
| EEEE               |                            | End delimiter                                                                |

<sup>1)</sup> xx = field length (number of data words occupied by the parameters)

<sup>2)</sup> For updating timers, please read the explanation on the following page.

<sup>3)</sup> For parameters and their significance, see the table on page 7-9.

|                        | Note<br>The current PG software (STEP 5/ST Vers. 6 or STEP 5/MT Vers. 2) for<br>generating DX 0 using a screen form does not transfer the parameters for<br>interface error handling (field ID 02xx, parameter 2000 or 2001) and for the<br>selection "Warm restart or retentive cold restart" (field ID 02xx,<br>parameter 4000 or 4001).<br>You can enter these parameters e.g. with the "output block" PG function<br>(do not forget to change the block length). You can no longer edit a DX 0<br>modified in this way using the output screen form of the current<br>PG software. |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Updating the<br>timers | <ul> <li>As standard, the timers T 0 to T 255 are updated.</li> <li>If you enter the value "0" in DX 0, no timers are updated, even if they are included in the program. There is then also no error message output.</li> </ul>                                                                                                                                                                                                                                                                                                                                                        |
|                        | Note<br>You can also assign parameters to the number of timers in data block DB 1 (see<br>Section 10.1.6). However, we recommend that you specify this parameter only<br>in DX 0.<br>If you set the number of timers both in DX 0 and in DB 1, the value you<br>specify in DB 1 will be valid!                                                                                                                                                                                                                                                                                         |

#### Parameters for interrupt processing

You can use the table below to find the correct parameter for your interrupt processing and you can program DX 0 with this parameter. Depending on the parameter you select, some (or all) interrupts will be effective at block boundaries and other (or all) interrupts will be effective at operation boundaries, according to the shading in the symbols.

| Para-<br>meter/<br>(old) 1) | Clock<br>int. | 5 s | 2 s | Ti<br>1s | m e<br>500<br>ms | int<br>200<br>ms | e r r<br>100<br>ms | upt<br>50<br>ms | s<br>20<br>ms | 10<br>ms | Cont.<br>int. | Delay<br>int. | Proc.<br>int |
|-----------------------------|---------------|-----|-----|----------|------------------|------------------|--------------------|-----------------|---------------|----------|---------------|---------------|--------------|
| 122C D<br>(100C)            |               |     |     |          |                  |                  |                    |                 |               |          |               |               |              |
| 1224<br>(100A)              |               |     |     |          |                  |                  |                    |                 |               |          |               |               |              |
| 1220                        |               |     |     |          |                  |                  |                    |                 |               |          |               |               |              |
| 121C<br>(1008)              |               |     |     |          |                  |                  |                    |                 |               |          |               |               |              |
| 1216                        |               |     |     |          |                  |                  |                    |                 |               |          |               |               |              |
| 1214                        |               |     |     |          |                  |                  |                    |                 |               |          |               |               |              |
| 1212                        |               |     |     |          |                  |                  |                    |                 |               |          |               |               |              |
| 1210                        |               |     |     |          |                  |                  |                    |                 |               |          |               |               |              |
| 120E                        |               |     |     |          |                  |                  |                    |                 |               |          |               |               |              |
| 120C                        |               |     |     |          |                  |                  |                    |                 |               |          |               |               |              |
| 120A                        |               |     |     |          |                  |                  |                    |                 |               |          |               |               |              |
| 1208                        |               |     |     |          |                  |                  |                    |                 |               |          |               |               |              |
| 1206                        |               |     |     |          |                  |                  |                    |                 |               |          |               |               |              |
| 1204<br>(1006)              |               |     |     |          |                  |                  |                    |                 |               |          |               |               |              |

D = Default

Interrupts at block boundaries

Interrupts at operation boundaries

<sup>1)</sup> The PG software for generating DX0 uses the "old" parameters. If you generate a DX0 with new parameters using STEP 5 and want to display it on the PG, an error message is displayed.

#### Note

If you enable interrupt processing at operation boundaries, the operations "TNB" "TNW" may also be interrupted. This also applies to a few of the special function organization blocks, standard function blocks and controller function blocks.

### 7.4 Examples of Parameter Assignment

STEP 5 Programming

| Example A:                                                                                                                                                           |               |                                                                                                                                               |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| · · ·                                                                                                                                                                | n vou want    | to use three CPUs: CPU A, B and C. CPU A and B                                                                                                |  |  |  |  |
|                                                                                                                                                                      |               |                                                                                                                                               |  |  |  |  |
| operate closely together, often exchange data and process a complex restart program.<br>CPU C is largely independent and has a short, time-critical program.         |               |                                                                                                                                               |  |  |  |  |
| CPU C IS largely independe                                                                                                                                           | ent and has a | snort, time-critical program.                                                                                                                 |  |  |  |  |
| an atomical all open in a                                                                                                                                            |               |                                                                                                                                               |  |  |  |  |
| As standard, all CPUs in multiprocessor operation start cyclic program execution together, i.e. the CPUs wait until all CPUs have completed their restart procedures |               |                                                                                                                                               |  |  |  |  |
|                                                                                                                                                                      |               |                                                                                                                                               |  |  |  |  |
| and then start cyclic prog                                                                                                                                           | gram executio | n at the same time.                                                                                                                           |  |  |  |  |
|                                                                                                                                                                      |               |                                                                                                                                               |  |  |  |  |
|                                                                                                                                                                      |               | program independent of the other CPUs, its                                                                                                    |  |  |  |  |
|                                                                                                                                                                      |               | synchronized. By assigning parameters in DX 0,                                                                                                |  |  |  |  |
| you can arrange for CPU C                                                                                                                                            | to start cyc  | lic program execution immediately after its                                                                                                   |  |  |  |  |
| restart, without waiting i                                                                                                                                           | for CPU A and | В.                                                                                                                                            |  |  |  |  |
| Programming DX 0 for CH                                                                                                                                              | UC:           |                                                                                                                                               |  |  |  |  |
| DX 0 start ID "MASKX0"                                                                                                                                               | DW 0:         | KH= 4D41                                                                                                                                      |  |  |  |  |
| _                                                                                                                                                                    | DW 1:         | KH= 534B                                                                                                                                      |  |  |  |  |
|                                                                                                                                                                      | DW 2:         | KH= 5830                                                                                                                                      |  |  |  |  |
| 1st field ID/length                                                                                                                                                  |               | KH= 0201                                                                                                                                      |  |  |  |  |
| parameter 1                                                                                                                                                          | DW 4:         | KH= 2001                                                                                                                                      |  |  |  |  |
| end delimiter                                                                                                                                                        | DW 5:         | KH= EEEE                                                                                                                                      |  |  |  |  |
| end delimiter                                                                                                                                                        | DR J.         |                                                                                                                                               |  |  |  |  |
| next COLD RESTART. Since (                                                                                                                                           | CPU C process | program memory, it becomes effective after the<br>es a very short restart program and does not<br>immediately following the restart. The BASP |  |  |  |  |
| signal (disable command ou                                                                                                                                           | itput) is, ho | wever, only cancelled when all three CPUs have                                                                                                |  |  |  |  |
| completed their restart.                                                                                                                                             | This means th | at CPU C cannot access the digital peripherals.                                                                                               |  |  |  |  |
|                                                                                                                                                                      |               |                                                                                                                                               |  |  |  |  |
|                                                                                                                                                                      |               |                                                                                                                                               |  |  |  |  |
|                                                                                                                                                                      |               |                                                                                                                                               |  |  |  |  |
| _ <b>.</b> _                                                                                                                                                         |               |                                                                                                                                               |  |  |  |  |
| Example B:                                                                                                                                                           |               |                                                                                                                                               |  |  |  |  |
| Assigning the parameters (                                                                                                                                           | o DX 0 as sh  | own below achieves the following:                                                                                                             |  |  |  |  |
| <ul> <li>the addressing error</li> </ul>                                                                                                                             | monitoring    | is disabled,                                                                                                                                  |  |  |  |  |
| <ul> <li>the timer updating i</li> </ul>                                                                                                                             | s disabled,   |                                                                                                                                               |  |  |  |  |
| <ul> <li>the cycle time is see</li> </ul>                                                                                                                            | et to 4 sec.  |                                                                                                                                               |  |  |  |  |
| -                                                                                                                                                                    |               |                                                                                                                                               |  |  |  |  |
| DX 0 start ID "MASKXO                                                                                                                                                | DW 0:         | KH = 4D41                                                                                                                                     |  |  |  |  |
|                                                                                                                                                                      | DW 1:         | KH = 534B                                                                                                                                     |  |  |  |  |
|                                                                                                                                                                      | DW 2:         | KH = 5830                                                                                                                                     |  |  |  |  |
| 1st field ID/length                                                                                                                                                  |               | KH = 0203                                                                                                                                     |  |  |  |  |
|                                                                                                                                                                      | DW 3:         | KH = 3001                                                                                                                                     |  |  |  |  |
| parameter <sup>1</sup> )                                                                                                                                             |               | 1                                                                                                                                             |  |  |  |  |
| parameter <sup>1)</sup>                                                                                                                                              | DW 5:         | KH = BB00                                                                                                                                     |  |  |  |  |
|                                                                                                                                                                      | DW 6:         | KH = 0000                                                                                                                                     |  |  |  |  |
| 2nd field ID/length                                                                                                                                                  |               | KH = 0402                                                                                                                                     |  |  |  |  |
| parameter <sup>1)</sup>                                                                                                                                              | DW 8:         | КН = 1000                                                                                                                                     |  |  |  |  |
|                                                                                                                                                                      | DW 9:         | KF = +4000                                                                                                                                    |  |  |  |  |
| end delimiter                                                                                                                                                        | DW10:         | KH = EEEE                                                                                                                                     |  |  |  |  |
| 88 C                                                                                                                                                                 | DATO:         | RA - LEEL                                                                                                                                     |  |  |  |  |
|                                                                                                                                                                      | DHIO:         | KN - EEEE                                                                                                                                     |  |  |  |  |
| This assignment of paramet                                                                                                                                           |               | has the following effects on program execution:                                                                                               |  |  |  |  |
| This assignment of paramet                                                                                                                                           |               |                                                                                                                                               |  |  |  |  |

- The part of the process image not assigned to peripheral I/O modules can be used as an additional flag area.
- The runtime of the system program is reduced, since no timers are updated.
   A cycle error is only detected when the runtime of the user program and the system program together exceeds 4 sec.
- 1) Parameters occupying two words must be identified with "2" when specifying the field length.

| Assigning<br>Parameters<br>using the PG<br>Screen Form | From stage IV of the PG system software S5-DOS, screen forms are available for<br>assigning parameters to DX 0. The PG software generates the data block DX 0<br>automatically according to the parameter defaults and the parameters you have<br>specified. Two screen forms are required for this parameter assignment.<br>For the basic steps you require to select and complete PG screen forms, see your<br>STEP 5 manual. |
|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>Completing the DX 0 screen</i>                      | The PG screen form for completing DX 0 is in two parts.                                                                                                                                                                                                                                                                                                                                                                         |
| forms                                                  | The first DX 0 screen contains the first group of parameters (Fig. 7-2):                                                                                                                                                                                                                                                                                                                                                        |
|                                                        | RESTART AFTER POWER UP                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                        | SYNCHRONIZE MULTIPROCESSOR RESTART                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                        | BLOCK TRANSFER OF IPC FLAGS                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                        | ADDRESS ERROR MONITORING                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                        | CYCLE TIME MONITORING                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                        | NO. OF TIMER CELLS                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                        | ACCURACY OF FLOAT. POINT ARITHMETIC                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                        | (no effect, CPU always calculates with 24 bits)                                                                                                                                                                                                                                                                                                                                                                                 |

| DX 0 - PA                                                                | RAM. ASS. (S5 | 135U: CPU 92 | 28, R PROCES | SOR) |        |                        |     | DX | 0  |
|--------------------------------------------------------------------------|---------------|--------------|--------------|------|--------|------------------------|-----|----|----|
| RESTART AFTER POWER UP: 1 (1 = WARM RESTART<br>2 = COLD RESTART )        |               |              |              |      |        |                        |     |    |    |
| SYNCHRONIZE MULTIPROCESSOR RESTART                                       |               |              |              | YES  |        |                        |     |    |    |
| BLOCK TRANSFER OF IPC FLAGS                                              |               |              |              |      | NO     |                        |     |    |    |
| ADDRE                                                                    | SSING ERROF   |              | G            |      | YES    |                        |     |    |    |
| CYCLE TIME MONITORING (X 10 MS)                                          |               |              |              |      | 15     | ( R PROC.:<br>CPU 928: |     |    |    |
| NO. OF TIMER CELLS                                                       |               |              |              |      | 256    | ( R PROC:<br>CPU 928:  |     |    |    |
| ACCURACY OF FLOAT. POINT ARITHMETIC<br>#24-BIT MANTISSA ONLY BY CPU 928# |               |              |              |      | 16 - B | IT MANTISS             | 4   |    |    |
| F1                                                                       | F2            | F3           | F 4          | F5   |        | F6                     | F 7 |    | F8 |
|                                                                          |               | SELECT       |              |      | с      | ONTINUE                |     |    |    |

Fig. 7-2 PG screen form for assigning parameters to DX 0 /part 1

Once you have selected all the parameters in the first screen form for your application, you can display the second screen form (Fig. 7-3) with the following group of parameters:

ADDRESS. ERROR, CYCLE ERROR ACKNOWL. ERROR, TIMER ERR. COMMAND CODE ERROR, CONTROLLER ERROR RUNTIME ERROR PROCESS INT SERVICING INTERRUPTABILITY OF USER PROGRAM BY INTERRUPTS

| DX 0 - PARAM. ASS. (S5 135U: CPU 928, R PROCESSOR)                                                                                                                                                                                                                                                                                                                                                              |                                                    |          |             |       |                |         | DX 0 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|----------|-------------|-------|----------------|---------|------|
| SYSTEM STOP IF EVENT OCCURS AND ERROR OB IS MISSING                                                                                                                                                                                                                                                                                                                                                             |                                                    |          |             |       |                |         |      |
| ADE                                                                                                                                                                                                                                                                                                                                                                                                             | ADDRESS. ERROR (OB 25) YES CYCLE ERROR (OB 26) YES |          |             |       |                |         |      |
| ACK                                                                                                                                                                                                                                                                                                                                                                                                             | NOWL. ERROI                                        | R (OB    | 23, 24)     | NO    | TIMER ERR.     | (OB 33) | YES  |
| CON                                                                                                                                                                                                                                                                                                                                                                                                             | MAND CODE                                          | ERR. (OB | 27, 29, 30) | YES   | CONTROLLER ERR | (OB 34) | YES  |
| RUNTIME ERROR (OB 19, 31, 32) YES                                                                                                                                                                                                                                                                                                                                                                               |                                                    |          |             |       |                |         |      |
| PROCE                                                                                                                                                                                                                                                                                                                                                                                                           | ESS INT. SERV                                      | 'ICING   |             | LEVEL | - TRIGGERED    |         |      |
| <ul> <li>INTERRUPTABILITY OF USER PROGRAM BY INTERRUPTS: MODE 1</li> <li>1: ALL INTERRUPTS AT BLOCK BOUNDS</li> <li>2: ALL INTERRUPTS AT OPERATION BOUNDS</li> <li>3: ONLY PROCESS INTERRUPTS AT OPERATION BOUNDS</li> <li>4: ONLY PROC: AND CONTROLLER. INT. AT OP. BOUNDS</li> <li>X: (X=10,17) TIME INT. FROM OB10 - OBX AND CONTROLLER/PROC<br/>INTS. AT OP. BOUNDS #ONLY POSSIBLE WITH CPU 928#</li> </ul> |                                                    |          |             |       |                |         |      |
| F1                                                                                                                                                                                                                                                                                                                                                                                                              | F 2                                                | F3       | F 4         | F 5   | F6             | F 7     | F 8  |
|                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                    | SELECT   |             |       | CONTINUE       |         |      |

Fig. 7-3 PG screen form for assigning parameters to DX 0 / part 2

The following flowchart explains how to complete the screen forms, store the parameters and load the generated data block DX 0.

Flowchart for completing the DX 0 screen forms.



Below you can find an example to fill in.



| You want to assign parameters in DX 0 to achieve the following system program response (different from the defaults).                                                                                                                                                                                 |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <ul> <li>in multiprocessor operation, the CPU for which this DX 0 is programmed does not wait until the other CPUs have completed their restart procedure,</li> <li>the cycle monitoring time is 100 ms,</li> <li>arithmetic operations are performed with 24-bit floating point mantissa,</li> </ul> |  |
| <ul> <li>arithmetic operations are performed with 24-bit floating point mantissa,</li> <li>if cycle errors occur, the CPU does not go to the STOP mode if OB 26 is not<br/>loaded,</li> </ul>                                                                                                         |  |
| <ul> <li>the user program is interrupted at operation boundaries by all interrupts.</li> </ul>                                                                                                                                                                                                        |  |
| To obtain these reactions, complete the screen form as follows:                                                                                                                                                                                                                                       |  |
| First DX 0 screen form:                                                                                                                                                                                                                                                                               |  |
| <ul> <li>Select the "synchronize multiprocessor restart" parameter with function key<br/>F3 as NO.</li> </ul>                                                                                                                                                                                         |  |
| <ul> <li>For the "cycle time monitoring" parameter, press function key F3 and then<br/>type in the number 10 (= 100 ms).</li> </ul>                                                                                                                                                                   |  |
| <ul> <li>Select the "24-bit mantissa" for the "accuracy of floating point arithmetic"<br/>parameter with function key F3.</li> </ul>                                                                                                                                                                  |  |
| - Press function key F6 (CONTINUE). The second DX 0 screen is then displayed.                                                                                                                                                                                                                         |  |
| Second DX 0 screen form:                                                                                                                                                                                                                                                                              |  |
| - Select NO for the "cycle error" parameter with function key F3.                                                                                                                                                                                                                                     |  |
| <ul> <li>Enter the number '2' in the "mode" field of the "interruptability of user<br/>program by interrupts" parameter (= all interrupts at operation boundaries).</li> </ul>                                                                                                                        |  |
| <ul> <li>Confirm your entries by pressing the enter key. Data block DX 0 is now<br/>generated by the PG software.</li> </ul>                                                                                                                                                                          |  |
| Finally, transfer DX 0 to memory or to an EPROM submodule.                                                                                                                                                                                                                                            |  |
|                                                                                                                                                                                                                                                                                                       |  |

# 8

# Memory Assignment and Organization

Contents of the<br/>chapterYou can use this chapter as a reference section to check the organization of the<br/>CPU 928B-3UB21 memory. The chapter also includes important information for<br/>the user contained in some of the system data words.

# Overview of the chapter

| Section | Description                                    | Page |
|---------|------------------------------------------------|------|
| 8.1     | Structure of the Memory Area                   | 8-2  |
| 8.2     | Address Distribution in the CPU 928B-3UB21     | 8-3  |
| 8.2.1   | Address Distribution                           | 8-4  |
| 8.2.2   | Address Distribution of the Peripherals        | 8-5  |
| 8.3     | User Memory Organization in the CPU 928B-3UB21 | 8-7  |
| 8.3.1   | Block Headers in the User Memory               | 8-8  |
| 8.3.2   | Block Address Lists in Data Block DB 0         | 8-9  |
| 8.3.3   | RI / RJ Area                                   | 8-12 |
| 8.3.4   | RS / RT Area                                   | 8-13 |
| 8.3.5   | Bit Assignment of the System Data Words        | 8-16 |

# 8.1 Structure of the Memory Area

**Overview** The memory area of the CPU 928B is basically divided into the following areas:

|                                                                   | Memory area                                                                                                                   | Length                                                                                                | Width                                    |
|-------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|------------------------------------------|
| User memory:                                                      | For OBs, FBs, FXs, PBs, SBs, DBs, DXs                                                                                         | max. $32x2^{10}$ words                                                                                | 16 bits                                  |
| DB-RAM: F                                                         | or data blocks, shift registers                                                                                               | 23x2 <sup>10</sup> words                                                                              | 16 bits                                  |
| Flags:                                                            | S                                                                                                                             | 1024 bytes                                                                                            | 8 bits                                   |
| Interface data area:<br>System data area:<br>Counters:<br>Timers: | RI, RJ<br>RS, RT<br>C<br>T                                                                                                    | each 256 words<br>each 256 words<br>256 words<br>256 words                                            | 16 bits<br>16 bits<br>16 bits<br>16 bits |
| Flags:                                                            | F                                                                                                                             | 256 bytes                                                                                             | 8 bits                                   |
| Process input and output image:                                   | PII, PIQ                                                                                                                      | each 128 bytes                                                                                        | 8 bits                                   |
| Peripheral I/O area,<br>divided in                                | nto:                                                                                                                          |                                                                                                       | 8 bits                                   |
|                                                                   | P peripherals<br>O peripherals<br>IM 3<br>IM 4<br>IPC flags<br>Coordinator module<br>Pages (CP, IP, 923C)<br>Distributed I/Os | 256 bytes<br>256 bytes<br>256 bytes<br>256 bytes<br>256 bytes<br>256 bytes<br>2048 bytes<br>768 bytes |                                          |

Table 8-1Structure of the memory area

Refer to the memory map in the next section for the exact addresses of the areas.

#### Note

With STEP 5, you should never access a memory cell within an operand area (e.g. flags) directly using the absolute address of this memory area, but always relative to the base address of the operand area.

The base addresses of all operand areas are in the system data area (RS area - see "system data assignment").



# 8.2 Address Distribution in the CPU 928B-3UB21

Fig. 8-1 Address distribution in the CPU 928B-3UB21 - overview

# 8.2.1 Address Distribution



Fig. 8-2 Address distribution

| Bit no.      | 7                                                                                 | 0         |
|--------------|-----------------------------------------------------------------------------------|-----------|
| F000         | Digital peripherals (with process image),<br>1024 bits inputs / 1024 bits outputs |           |
| F07F<br>F080 | Digital or analog<br>peripherals (without process image),                         | P area    |
| F0FF<br>F100 | 1024 bits inputs / 1024 bits outputs                                              |           |
| FIFF         | Extended peripherals<br>2048 bits input / 2048 bits output                        | O area    |
| F200         | 2048 bits IPC flags<br>(on coordinator module/CP)                                 |           |
| F2FF<br>F300 | 32 semaphores                                                                     |           |
| F3FF<br>F400 | (on coordinator module)                                                           |           |
| FBFF         | Data transfer area<br>for CP (pages)                                              | Page area |
| FC00         | IM 3 area                                                                         | ¥         |
| FCFF<br>FD00 |                                                                                   |           |
| FDFF         | IM 4 area                                                                         |           |
| FEOO         | Distributed peripherals,<br>extended address volume                               |           |
| FEFE<br>FEFF | Occupied when using page areas                                                    |           |
| FFOO<br>FFFF | Reserved                                                                          |           |

# 8.2.2 Address Distribution of the Peripherals



## Address areas for the peripherals and their programming

| Area (absolute address)          |                                                | Address with                                                                                                                                                             | Parameters                                       |  |  |
|----------------------------------|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|--|--|
| P peripherals with process image |                                                | When the operation is processed, only the process image is changed.<br>The new status of the process image is only output to the peripherals<br>at the end of the cycle. |                                                  |  |  |
| EF00<br>EF7F                     | PII<br>(process input image)                   | L IB / T IB<br>L IW / T IW<br>L ID / T ID<br>A I/ AN I/O I/ON I<br>S I / R I/ = I                                                                                        | 0 to 127<br>0 to 126<br>0 to 124<br>0.0 to 127.7 |  |  |
| EF80<br>EFFF                     | PIQ<br>(process output image)                  | L QB / T QB $L QW / T QW$ $L QD / T QD$ $A Q / AN Q / O Q / ON Q$ $S Q / R Q / = Q$                                                                                      | 0 to 127<br>0 to 126<br>0 to 124<br>0.0 to 127.7 |  |  |
| P periphe                        | rals                                           | The inputs and outputs are addressed di oriented.                                                                                                                        | rectly byte or word                              |  |  |
| F000<br>F07F                     | Digital peripheral inputs/outputs              | L PY / T PY<br>L PW / T PW                                                                                                                                               | 0 to 127<br>0 to 126                             |  |  |
| F080<br>F0FF                     | Digital or analog<br>peripheral inputs/outputs | T PY / T PY<br>T PW / T PW                                                                                                                                               | 128 to 255<br>128 to 254                         |  |  |
| Q periphe                        | erals                                          | The inputs and outputs are addressed directly byte or word oriented.                                                                                                     |                                                  |  |  |
| F100<br>F1FF                     | Extended peripheral inputs/outputs             | L OY / T OY<br>L OW/ T OW                                                                                                                                                | 0 to 255<br>0 to 254                             |  |  |

With STEP 5 operations, you can access the peripherals either directly or via the process image. Remember that the process image only exists for input and output bytes of the P peripherals with byte addresses from 0 to 127.

#### Note

Using the interface modules IM 304, IM 307 and IM 308, you can access distributed address areas using your program. This allows access to two new address areas similar to the O area. In contrast to the O area, however, access to these areas is only possible using absolute addressing or using FB 196 of the "basic functions" software package (refer to Catalog ST59).

# 8.3 User Memory Organization in the CPU 928B-3UB21

| Introduction                                   | The user memory consists of the memory area from 0000H to 7FFFH. When you load the blocks of the user program, they are stored in any order (addresses in ascending order).                                                                                                                                                                                                 |
|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| "Alternative<br>loading" of the<br>data blocks | There are alternative methods of loading DB/DX data blocks depending on the setting in system data word RS 144:<br>The default is that the data blocks are first loaded into the user memory. Only when this has been filled are the data blocks stored in internal DB RAM (8000H to DD7FH). You can reverse this order by setting bit 0 in RS 144 ("alternative loading"). |
| <i>Memory</i><br><i>information</i>            | With the online function MEM CONF (memory configuration) you can obtain<br>the address (hexadecimal) of the memory cell containing the block end operation<br>of the last block in the user memory which then tells you the size of the user<br>memory.                                                                                                                     |
| Block<br>management                            | When you correct blocks, the "old" block is declared invalid in the memory and a<br>new block is set up. This also applies when you delete blocks; the blocks are not<br>really deleted in the memory, but simply declared invalid.<br>Gaps created when blocks are deleted cannot be used again directly<br>(see "Compress memory").                                       |
|                                                | You can neither correct nor delete blocks in EPROM mode.                                                                                                                                                                                                                                                                                                                    |
| Compress<br>memory                             | Using the COMPRESS MEMORY online function you can create memory<br>space for new blocks. This function optimizes the memory occupation by<br>deleting blocks marked as invalid and shifting valid blocks together filling all<br>gaps. The shifting is done separately for the user memory and the DB-RAM<br>(see Section 11.2).                                            |

## 8.3.1 Block Headers in the User Memory

*Structure* Each block in the memory begins with a five word long header.

1st word: block start identifier: 7070H

2nd word: high byte = block type



Low byte = block number

The block number (0 to 255) is in the low byte of the 2nd header word and is coded in binary: 00 to FFH

| 3rd word: | the high byte of the 3rd word contains the identifiers for the programmer, the low byte contains part of the library number. |
|-----------|------------------------------------------------------------------------------------------------------------------------------|
| 4th word: | the fourth word contains the rest of the library number.                                                                     |
| 5th word: | the 5th word (low and high byte) contains the length of the block including the block header. This is specified in words.    |

# 8.3.2 Block Address Lists in Data Block DB 0

| Introduction                    | memory submo<br>generates this l | Data block DB 0 contains a list with the start addresses of all blocks in the memory submodule or in the DB RAM of the CPU. The system program generates this list after OVERALL RESET and updates it automatically when you enter or change blocks at the programmer. |  |  |  |  |
|---------------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Address list start<br>addresses | word is reserve                  | A 256 words long address list is reserved in DB 0 for each block type i.e. one word is reserved for each block. Blocks that are not loaded or have been deleted have the start address "0".                                                                            |  |  |  |  |
|                                 | The start addre RS 32 to RS 38   | sses of the block address lists are also entered in the system data 3.                                                                                                                                                                                                 |  |  |  |  |
|                                 | RS 32:                           | Start address of the DX address list                                                                                                                                                                                                                                   |  |  |  |  |
|                                 | RS 33:                           | Start address of the FX address list                                                                                                                                                                                                                                   |  |  |  |  |
|                                 | RS 34:                           | Start address of the DB address list                                                                                                                                                                                                                                   |  |  |  |  |
|                                 | RS 35:                           | Start address of the SB address list                                                                                                                                                                                                                                   |  |  |  |  |
|                                 | RS 36:                           | Start address of the PB address list                                                                                                                                                                                                                                   |  |  |  |  |
|                                 | RS 37:                           | Start address of the FB address list                                                                                                                                                                                                                                   |  |  |  |  |
|                                 | RS 38: Start                     | t address of the OB address list (only 48 words long)                                                                                                                                                                                                                  |  |  |  |  |
| Block start<br>addresses        | The start addre                  | sses always refer to the first word <b>after</b> the block header:                                                                                                                                                                                                     |  |  |  |  |
|                                 | • this is DW                     | 0 of data blocks                                                                                                                                                                                                                                                       |  |  |  |  |
|                                 |                                  | irst STEP 5 operation of a logic block<br>s is the "JU" operation before the name and the parameter list)                                                                                                                                                              |  |  |  |  |

# Storing block addresses in DB 0:









```
Continuation of the example (address and length of DB 50):
   Using the special function organization block OB 181
b)
    "test data blocks (DB/DX)":
OB 181 (see Section 6.16) executes the same function as described in
example a). In addition to this function, it also determines whether the
data block is in the user memory (RAM or EPROM submodule) or in the DB RAM.
    :L
         KY1,50
                      Data block DB 50
    :JU OB 181
                      "Test data blocks (DB/DX)"
    :JC =NIVO
                      Jump if block does not exist
    :JM =PROM
                      Jump if in EPROM submodule
    :JZ =ANWE
                      Jump if in RAM submodule
    :JP =DBRA
                      Jump if in DB RAM
    :JU = FEHL
                      Jump to error processing
    :
NIVO:
                      Data block does not exist
    : BEU
PROM:
                      Data block is in the user memory / write
                      protected ("EPROM mode")
    :
    : BEU
ANWE :
                      Data block is in the user memory / write
                      enabled ("RAM mode")
    :
    : BEU
DBRA:
                      Data block is in the DB RAM
    •
    :BEU
FEHL:
                      Error processing
    :
    : BE
    Result: ACCU-1-L: Length of DB 50
            ACCU-2-L: Start address of DB 50
            RLO = 1 if DB 50 does not exist
```

#### 8.3.3 RI / RJ Area

**Overview** The RI area is an area 256 words long in the internal system RAM of the CPU. It occupies addresses E800H to E8FFH.

The RJ area is an area 256 words long in the internal system RAM of the CPU. It occupies addresses E900H to E9FFH.

You can use the entire RI area (RI 0 to RI 255) and the entire RJ area (RJ 0 to RJ 255) for your own purposes.

Only an OVERALL RESET can clear the RI / RJ areas (zeros entered).

## 8.3.4 RS / RT Area

**RS area** The RS and RT areas contain information for the system programmer and system internal data.

The **RS area** is an area 256 words long in the internal system RAM of the CPU. It occupies the addresses EA00H to EAFFH.



#### Caution

You can only write to system data words RS 1, RS 60 to RS 63, RS 133 and RS 140.

- You can use RS 60 and RS 63 for your own purposes.
- RS 1 and RS 133 have a fixed function and influence the processing of the program. You must only write valid identifiers to them.

#### You can only read the other system data

Writing to these system data can affect the functional capability of your CPU and connected programmers. Serious faults may result, endangering both personnel and machinery.

You can obtain the information of some of the system data (the internal configuration of the CPU, the software release, the CP identifier etc.) using the SYSTEM PARAMETERS online function.

Following figures 8-6 and 8-7 you will find the bit assignment of some system data that you can evaluate using STEP 5 operations or with the PG (refer to Section 5.3 for an explanation of the abbreviations).

The RS area can only be cleared by an OVERALL RESET.

**RT area** The **RT area** is an area 256 words long in the internal system RAM of the CPU. It occupies the addresses EB00H to EBFFH.

You can use the entire RT area (RT 0 to RT 255) for your own purposes.

The RT area can only be cleared by an OVERALL RESET.

# Assignment of the system data in the RS area

| RS | Name                           | Addr.                                    |      |  |
|----|--------------------------------|------------------------------------------|------|--|
| 0  | Interrupt condition codewo     | EA00                                     |      |  |
| 1  | Interrupt condition code       | e reset word (ICRW)                      | EA01 |  |
| 2  | Interrupt condition code       | group word (ICMK)                        | EA02 |  |
| 3  | Start up orror identifi        | ar condition code                        | EA03 |  |
| 4  | Statt-op enortderning          | Start-up error identifier condition code |      |  |
| 5  | Stop IDs                       | Restart IDs                              | EA05 |  |
| 6  | Cycle IDs                      | Submodule IDs                            | EA06 |  |
| 7  | Overall reset IDs              | Error IDs (Init)                         | EA07 |  |
| 8  | Error IDs (hardware)           | Error IDs (software)                     | EA08 |  |
| 9  |                                | Current ID number                        | EA09 |  |
| 10 | Base address of the input pro  | ocess interface modules                  | EAOA |  |
| 11 | Base address of the output pro | ocess interface modules                  | EAOB |  |
| 12 | Base address of the pr         | Base address of the process input image  |      |  |
| 13 | Base address of the pr         | Base address of the process output image |      |  |
| 14 | Base address of the flag area  |                                          | EAOE |  |
| 15 | Base address of the timer area |                                          | EAOF |  |
| 16 | Base address o                 | Base address of the counter area         |      |  |
| 17 | Base address of                | Base address of the interface area       |      |  |
| 18 |                                | PLC software release                     | EA12 |  |
| 19 | End address of the             | user memory                              | EA13 |  |
| 20 | Base address of th             | ne system area                           | EA14 |  |
| 21 | Length of the D                | B address list                           | EA15 |  |
| 22 | Length of the SI               | B address list                           | EA16 |  |
| 23 | Length of the P                | Length of the PB address list            |      |  |
| 24 | Length of th                   | e FB address list                        | EA18 |  |
| 25 | Length of the O                | EA19                                     |      |  |
| 26 | Length of th                   | e FX address list                        | EAIA |  |
| 27 | Length of the D                | X address list                           | EAIB |  |
| 28 | Length of the addre            | ess list DB (DB 0)                       | EAIC |  |
| 29 | Slot identifier                | CPU identifier 2 (type)                  | EAID |  |

: reserved

Fig. 8-6 RS area memory map (part 1)

| 30  | Length of the block header information                  | EA1E |
|-----|---------------------------------------------------------|------|
| 31  | CPU identifier 1 PG interface software release          | EA1F |
| 32  | Base address of the DX address list                     | EA20 |
| 33  | Base address of the FX address list                     | EA21 |
| 34  | Base address of the DB address list                     | EA22 |
| 35  | Base address of the SB address list                     | EA23 |
| 36  | Base address of the PB address list                     | EA24 |
| 37  | Base address of the FB address list                     | EA25 |
| 38  | Base address of the OB address list                     | EA26 |
| 39  |                                                         | EA27 |
|     |                                                         |      |
| 54  |                                                         | EA36 |
| 55  | Counter for 1 hour (to 3599 sec, hex)                   | EA37 |
| 56  | Reserved for handling block                             | EA38 |
| 59  |                                                         | EA3B |
| 60  |                                                         | EA3C |
| 63  | Reserved for user purposes                              | EA3F |
| 64  |                                                         | EA40 |
| 79  | Reserved for system program                             | EA4E |
| 80  | Additional error ID if bit FE-5 is set in RS 8          | EA50 |
| 81  |                                                         | EA51 |
|     | Reserved for system program                             |      |
| 127 |                                                         | EA7F |
| 128 |                                                         | EA80 |
| 129 |                                                         | EA81 |
| 130 | "Closed loop control" ID                                | EA82 |
| 131 | Condition codeword "disable all interrupts"             | EA83 |
| 132 | Condition codeword "delay all interrupts"               | EA84 |
| 133 | "Process image updating" ID                             | EA85 |
| 134 |                                                         | EA86 |
| 135 | Condition codeword "disable individual time interrupts" | EA87 |
| 136 |                                                         | EA88 |
| 137 | Condition codeword "delay individual interrupts"        | EA89 |
| 138 | Write protection for user memory in EPROM mode          | EA8A |
| 139 | Software protection                                     | EA8B |
| 140 | Condition codeword "write and delete blocks"            | EA8C |
| 141 |                                                         | EA8D |
| 143 |                                                         | EA8F |
| 144 | Alternative loading of data blocks                      | EA90 |
| 145 |                                                         | EA91 |
| 255 |                                                         | EAFF |

Fig. 8-7 RS area memory map (part 2)

# 8.3.5 Bit Assignment of the System Data Words

# **RS 0** Interrupt condition codeword

Address EA00H

| High byte |            |
|-----------|------------|
| Bit no.   | Assignment |
| 15        | NAU        |
| 14        | PEU        |
| 13        | BAU        |
| 12        | MP-STP     |
| 11        | ZYK        |
| 10        | QVZ        |
| 9         | ADF        |
| 8         | STP        |
|           | Low byte   |
| 7         | BCF        |
| 6         | FE-3       |
| 5         | LZF        |
| 4         | REG        |
| 3         | STUEB      |
| 2         | STUEU      |
| 1         | WECK       |
| 0         | DOPP       |

| Table 8-2 | Assignment of RS 0 (Interrupt condition codeword) |
|-----------|---------------------------------------------------|
|-----------|---------------------------------------------------|

The system data RS 0 corresponds to the CAUSE OF INTERR. in the ISTACK. If, e.g. a runtime error occurs during the program execution, bit number 5 is set. Once the program processing level LZF has been processed completely, bit number 5 is reset.

# **RS 1** Interrupt condition code reset word ICRW

## Address: EA01H

RS 1: Active interface, released for user

If you set bit number 9 or bit number 10 of the ICRW the **next** ADF or QVZ is ignored and does not affect the execution of the program. After a QVZ or ADF occurs, the system program resets the corresponding bit.

| High byte |            |
|-----------|------------|
| Bit no.   | Assignment |
| 15        |            |
| 14        |            |
| 13        | not used   |
| 12        |            |
| 11        |            |
| 10        | QVZ        |
| 9         | ADF        |
| 8         | not used   |
|           | Low byte   |
| 7         |            |
| 6         |            |
| 5         | not used   |
| 4         |            |
| 3         |            |
| 2         |            |
| 1         |            |
| 0         |            |

Table 8-3 Assignment of RS 1 (Interrupt condition code reset word)

Each program processing level has its own ICRW.

## Example of ICRW

```
The following example tests whether a module can be addressed at a certain
peripheral address. If the module does not exist, ICRW prevents a timeout
and a program written for the situation is executed. The example also tests
whether a particular peripheral address has been entered in DB 1. If the
address does not exist in DB 1, ICRW prevents an addressing error and a
special program is executed.
FB 201
NAME:L
    :JU FB 10
NAME: PERITEST
                         Test whether a module can be addressed at
                         peripheral adddress 128
PADR: PB 128
MASK: KM 00000100 0000000
    :JN =M001
                         This program section is processed if the module
    :..
                         cannot be addressed
    :..
    :..
M001:
    :JU FB 10
NAME: PERITEST
                         Test whether a module with peripheral
                         address 4 is entered in DB 1
PADR: QB 4
MASK: KM 00000010 0000000
    :JN =M002
                         This program section is processed,
    :..
                         if the peripheral address
    :..
                         is not entered
    :..
M002:
    :BE
FB 10
NAME: PERITEST
DECL:PADRI/Q/D/B/T/C: I BI/BY/W/D:
                                         BY
DECL:MASKI/Q/D/B/T/C: D KM/KH/KY/KS/KF/KT/KC/KG:
                                                        КМ
         RS 1
                         Load and save ICRW
    :L
    :Т
         RS 60
    :LW =MASK
                         Set QVZ or ADF bit
    : OW
    :Т
         RS 1
                         Write ICRW back
    :L
         =PADR
                         Single peripheral access or access to the
                         process image
    :
         RS 1
    :L
    :LW =MASK
                        Mask QVZ or ADF bit
    :AW
         RS 60
                         Write old ICRW back, so that the next
    :L
    :Т
         RS 1
                         QVZ or ADR can be detected
    : TAK
    : BE
```

# **RS 2** Interrupt condition code group word ICMK (RS 2):

#### Address: EA02H

The 16 bits of the interrupt condition code group word correspond to the possible causes of error listed in the CAUSE OF INTERR. in the ISTACK.

If one of these errors occurs, the corresponding bit is set.

| Table 8-4 | Assignment of RS 2 | (Interrupt condition | code group word) |
|-----------|--------------------|----------------------|------------------|
|-----------|--------------------|----------------------|------------------|

| High byte |            |
|-----------|------------|
| Bit no.   | Assignment |
| 15        | NAU        |
| 14        | PEU        |
| 13        | BAU        |
| 12        | MP-STP     |
| 11        | ZYK        |
| 10        | QVZ        |
| 9         | ADF        |
| 8         | STP        |
|           | Low byte   |
| 7         | BCF        |
| 6         | FE-3       |
| 5         | LZF        |
| 4         | REG        |
| 3         | STUEB      |
| 2         | STUEU      |
| 1         | WECK       |
| 0         | DOPP       |

You can only read the interrupt code group word (ICMK in the ISTACK).

#### Example of ICMK

If the CPU goes to the stop mode as a result of an addressing error (ADF), ICMK bit number 9 is set. If an operation code error (BCF) occurs when processing the ADF, bit number 7 is also set in the ICMK. Content of the ICMK (binary): 00000010 10000000 Representation (hexadecimal) in the ISTACK: 0280

While only the last error to occur is marked under CAUSE OF INTERR. in the ISTACK, all the errors that have occurred are indicated in the ICMK (ISTACK depth 05: in ICMK, 5 bits are set). If you convert the hexadecimal code to the binary code, you can analyze the contents of the ICMK. In this way, you can find out which error led to the stop mode.

The error bits are reset as soon as the corresponding error program processing level has been completely processed and is exited.

Interrupt codes of errors to which no program processing level is assigned (e.g. NAU, PEU, STUEB, etc.) are cleared during RESTART.

# **RS 5** STOP and RESTART IDs

# Address: EA05H

The IDs correspond to the control bits in lines 1 and 2 of the ISTACK.

| High byte: STOP IDs |                       |
|---------------------|-----------------------|
| Bit no.             | Assignment            |
| 15                  | PRI-STP               |
| 14                  | not used              |
| 13                  | FE-STP                |
| 12                  | BARB-END              |
| 11                  | PG-STP                |
| 10                  | STP-SCH               |
| 9                   | STP-BEF               |
| 8                   | MP-STP                |
|                     | Low byte: RESTART IDs |
| 7                   | ANL                   |
| 6                   | not used              |
| 5                   | NEUST                 |
| 4                   | MWA                   |
| 3                   | AWA                   |
| 2                   | not used              |
| 1                   | NEU-ZUL               |
| 0                   | MWA-ZUL               |

Table 8-5 Assignment of RS 5 (STOP and RESTART IDs)

# RS 6

# CYCLE and Submodule/MPL IDs

## Address: EA06H

The IDs correspond to the control bits in lines 3 and 4 of the ISTACK.

| High byte: CYCLE IDs |                             |
|----------------------|-----------------------------|
| Bit no.              | Assignment                  |
| 15                   | RUN                         |
| 14                   | not used                    |
| 13                   | EIN-PROZ                    |
| 12                   | BARB                        |
| 11                   | OB1-GEL                     |
| 10                   | FB0-GEL                     |
| 9                    | OB-PROZA                    |
| 8                    | OB-WECKA                    |
|                      | Low byte: Submodule/MPL IDs |
| 7                    | 32KW-RAM                    |
| 6                    | 16KW-RAM                    |
| 5                    | 8KW-RAM                     |
| 4                    | EPROM                       |
| 3                    | KM-AUS                      |
| 2                    | KM-EIN                      |
| 1                    | DIG-EIN                     |
| 0                    | DIG-AUS                     |

Table 8-6Assignment of RS 6 (Cycle and submodule/MPL IDs)

# **RS 7** RESET IDs/Initialize error IDs

# Address: EA07H

The IDs correspond to the control bits in lines 5 and 6 of the ISTACK.

| High byte: RESET IDs |                                |
|----------------------|--------------------------------|
| Bit no.              | Assignment                     |
| 15                   | URGELOE                        |
| 14                   | URL-IA                         |
| 13                   | STP-VER                        |
| 12                   | ANL-ABB                        |
| 11                   | UA-PG                          |
| 10                   | UA-SYS                         |
| 9                    | UA-PRFE                        |
| 8                    | UA-SCH                         |
|                      | Low byte: Initialize error IDs |
| 7                    | DX0-FE                         |
| 6                    | not used                       |
| 5                    | MOD-FE                         |
| 4                    | RAM-FE                         |
| 3                    | DB0-FE                         |
| 2                    | DB1-FE                         |
| 1                    | DB2-FE                         |
| 0                    | KOR-FE                         |

 Table 8-7
 Assignment of RS 7 (RESET IDs/Initialize error IDs)

# RS 8 Error IDs HW/SW

#### Address: EA08H

The IDS correspond to the control bits in lines 7 and 8 of the ISTACK.

|         | High byte: Error IDs HW |  |
|---------|-------------------------|--|
| Bit no. | Assignment              |  |
| 15      | NAU                     |  |
| 14      | PEU                     |  |
| 13      | BAU                     |  |
| 12      | STUE-FE                 |  |
| 11      | ZYK                     |  |
| 10      | QVZ                     |  |
| 9       | ADF                     |  |
| 8       | WECK-FE                 |  |
|         | Low byte: Error IDs SW  |  |
| 7       | BCF                     |  |
| 6       | not used                |  |
| 5       | FE-5                    |  |
| 4       | Power-down error        |  |
| 3       | FE-3                    |  |
| 2       | LZF                     |  |
| 1       | REG-FE                  |  |
| 0       | DOPP-FE                 |  |

Table 8-8 Assignment of RS 8 (Error IDs HW/SW)

-

#### Slot ID/CPU/PLC type RS 29

# Address: EA1DH

| High byte: Slot IDs |                           |
|---------------------|---------------------------|
| Bit no.             | Assignment                |
| 15                  |                           |
| 14                  | not used                  |
| 13                  |                           |
| 12                  |                           |
| 11                  | CPU no. 4                 |
| 10                  | CPU no. 3                 |
| 9                   | CPU no. 2                 |
| 8                   | CPU no. 1                 |
|                     | Low byte: CPU / PLC types |
| 7                   |                           |
| 6                   | CPU type                  |
| 5                   |                           |
| 4                   |                           |
| 3                   |                           |
| 2                   | PLC type                  |
| 1                   |                           |
| 0                   |                           |

| Table 8-9 | Assignment of RS 29 (Slot ID/CPU/PLC type) |
|-----------|--------------------------------------------|
|           |                                            |

| RS 29 (HIGH) | Active interface, used by the handling blocks and in multiprocessor<br>communication as well as by OB 218 and the SED and SEE operations. |      |          |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| RS 29 (LOW)  | CPU type:                                                                                                                                 | 1011 | CPU 928B |
|              | PLC type:                                                                                                                                 | 0111 | S5-135U  |

RS 80

#### Address: EA50H (high and low):

This contains additional information to define the cause of the error when bit 5 is set in RS 8 by the system or when control bit FE 5 is marked in the ISTACK output.

| Identifier in RS 80 | Cause of error                                 |
|---------------------|------------------------------------------------|
| 2460H               | Ready signal continuously active on the S5 bus |

#### RS 130 Address EA82H (low):

The system data RS 130 indicates the following statuses of the program processing level "closed loop control".

Bit no. 0 = 0 : program processing level "closed loop control" activated

Bit no. 0 = 1 : program processing level "closed loop control" suppressed

Before you call a restart organization block (OB 20, 21 or 22) the system program evaluates data block DB 2 (if it exists). Depending on the result of the evaluation, RS 130 is set or reset by the system program. Following this, the system program calls a restart OB.

If RS 130 (LOW) is reset, the closed loop controller is processed in cyclic operation according to the controller list in DB 2.

#### RS 131 Condition codeword "disable all interrupts": see OB 120 (Section 6.5) Address EA83H (low)

The system data RS 131 indicates the following statuses of the program processing levels "interrupt processing".

| Bit no. | Low byte: Disable all interrupts   |
|---------|------------------------------------|
| 7       | 0                                  |
| 6       | 0                                  |
| 5       | 0                                  |
| 4       | 0                                  |
| 3       | Delay interrupt                    |
| 2       | Process interrupts                 |
| 1       | Clock-driven time interrupt        |
| 0       | Time interrupts at fixed intervals |

Table 8-10Assignment of RS 131 (Disable all interrupts)

Bit = 1 means: interrupt(s) is (are) disabled.

# **RS 132** Condition codeword "delay all interrupts": see OB 122 (Section 6.7)

## Address EA84H (low)

The system data RS 132 indicates the following statuses of the program processing levels "interrupt processing".

| Bit no. | Low byte: Delay all interrupts     |
|---------|------------------------------------|
| 7       | 0                                  |
| 6       | 0                                  |
| 5       | 0                                  |
| 4       | 0                                  |
| 3       | Delay interrupt                    |
| 2       | Process interrupts                 |
| 1       | Clock-driven time interrupt        |
| 0       | Time interrupts at fixed intervals |

Table 8-11Assignment of RS 132 (Delay all interrupts)

Bit = 1 means: interrupt(s) is (are) delayed

# **RS 133** Process image updating

#### Address EA85H (low)

| Bit no. | Low byte: Process image updating |
|---------|----------------------------------|
| 7       |                                  |
| 6       | not used                         |
| 5       |                                  |
| 4       |                                  |
| 3       | KM-AUS                           |
| 2       | KM-EIN                           |
| 1       | DIGH-EIN                         |
| 0       | DIGH-AUS                         |

 Table 8-12
 Assignment of RS 133 (Process image updating)

Bit = 1 means: process image of the digital inputs will be prevented **once.** Following this, the bit is **reset to** "**0**" by the system program.

# RS 135 Condition codeword "disable individual time interrupts": see OB 121 (Section 6.6)

#### Address EA87H

The system data RS 135 indicates the following statuses of the program processing levels "time-driven interrupt processing".

|         | High byte: Disable individual time interrupts |  |  |
|---------|-----------------------------------------------|--|--|
| Bit no. | Assignment                                    |  |  |
| 15      | 0                                             |  |  |
| 14      | 0                                             |  |  |
| 13      | 0                                             |  |  |
| 12      | 0                                             |  |  |
| 11      | Time interrupt 5 sec (OB 18)                  |  |  |
| 10      | Time interrupt 2 sec (OB 17)                  |  |  |
| 9       | Time interrupt 1 sec (OB 16)                  |  |  |
| 8       | Time interrupt 500 ms (OB 15)                 |  |  |
|         | Low byte: Disable individual time interrupts  |  |  |
| 7       | Time interrupt 200 ms (OB 14)                 |  |  |
| 6       | Time interrupt 100 ms (OB 13)                 |  |  |
| 5       | Time interrupt 50 ms (OB 12)                  |  |  |
| 4       | Time interrupt 20 ms (OB 11)                  |  |  |
| 3       | Time interrupt 10 ms (OB 10)                  |  |  |
| 2       | 0                                             |  |  |
| 1       | 0                                             |  |  |
| 0       | 0                                             |  |  |

 Table 8-13
 Assignment of RS 135 (Disable individual time interrupts)

Bit = 1 means: this time interrupt is disabled.

# **RS 137** Condition codeword "delay individual time interrupts": see OB 123 (Section 6.8.)

#### Address EA89H

The system data RS 137 indicates the following statuses of the program processing levels "time interrupt processing":

|         | High byte: Delay individual time interrupts |  |  |
|---------|---------------------------------------------|--|--|
| Bit no. | Assignment                                  |  |  |
| 15      | 0                                           |  |  |
| 14      | 0                                           |  |  |
| 13      | 0                                           |  |  |
| 12      | 0                                           |  |  |
| 11      | Time interrupt 5 sec (OB 18)                |  |  |
| 10      | Time interrupt 2 sec (OB 17)                |  |  |
| 9       | Time interrupt 1 sec (OB 16)                |  |  |
| 8       | Time interrupt 500 ms (OB 15)               |  |  |
|         | Low byte: Delay individual time interrupts  |  |  |
| 7       | Time interrupt 200 ms (OB 14)               |  |  |
| 6       | Time interrupt 100 ms (OB 13)               |  |  |
| 5       | Time interrupt 50 ms (OB 12)                |  |  |
| 4       | Time interrupt 20 ms (OB 11)                |  |  |
| 3       | Time interrupt 10 ms (OB 10)                |  |  |
| 2       | 0                                           |  |  |
| 1       | 0                                           |  |  |
| 0       | 0                                           |  |  |

 Table 8-14
 Assignment of RS 137 (Delay individual time interrupts)

Bit = 1 means: this time interrupt is delayed.

# **RS 138** Write protection for user memory in EPROM mode

#### Address EA8AH

The user memory is write protected when the blocks are copied from a memory card (EPROM mode).

By deleting or setting the write protection ID bit 0 in RS 138 via the PG and then performing a COLD RESTART, the write protection can be activated and deactivated selectively. (Bits no. 1 to 15 in RS 138 are irrelevant.)

#### Procedure for activating/deactivating write protection

- 1. Display the content of the address EA8AH on the PG.
- 2. Set or delete bit 0 in RS 138 by overwriting the content of the address EA8AH with the bit pattern 000xH (x = 1 for "set", x = 0 for "delete" write protection).
- 3. Then perform a COLD RESTART. After processing OB 20, bit 0 in the system data word RS 138 is evaluated and the write protection is activated or deactivated accordingly.

RS 138 can not only be set via the PG (1) but also via OB 20.

The status of the write protection is retained until the next OVERALL RESET of the CPU.

| RS 139                                          | Software protection                                                                                                                                                                                                                                                      |
|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                 | The system data word RS 139 controls the system function "software protection". With this function you can prevent blocks being read, overwritten and deleted using the programmer (e.g. by unauthorized personnel) by setting a password.                               |
| Password                                        | The "software protection" function is linked to a password which is made known to the system program via RS 139.                                                                                                                                                         |
| <i>Declaring a<br/>password/<br/>activating</i> | When a password is declared in RS 139, the software protection is activated automatically.                                                                                                                                                                               |
| software<br>protection                          | The password can only be redeclared if it is deleted first.                                                                                                                                                                                                              |
| Deleting a<br>password/                         | When a password is deleted, the software protection is deactivated automatically.                                                                                                                                                                                        |
| deactivating<br>software<br>protection          | When a password is deleted, this must be made known to the system program via RS 139.                                                                                                                                                                                    |
| protection                                      | • Maximum of 5 attempts to delete the password:                                                                                                                                                                                                                          |
|                                                 | Incorrect password entries to delete the password are rejected by the system program and counted. After a maximum of five incorrect entries, the system program prevents any further password editing. The password can then only be deleted again after a COLD RESTART. |
|                                                 | The "error counter" is cleared again after the password was deleted successfully or following a COLD RESTART.                                                                                                                                                            |
|                                                 |                                                                                                                                                                                                                                                                          |
| How is the<br>password<br>declared/<br>deleted? | The password is declared/deleted (and the software protection activated/deactivated) by writing the system data RS 139 with a particular bit pattern (see "Assignment of the system data when writing") either via                                                       |
|                                                 | • the STEP 5 program                                                                                                                                                                                                                                                     |
|                                                 | or                                                                                                                                                                                                                                                                       |
|                                                 | • a PG job "output address".                                                                                                                                                                                                                                             |
|                                                 | <b>Note</b><br>When the CPU is shipped and following an OVERALL RESET, the<br>password is deleted and the software protection deactivated.                                                                                                                               |

| When is the<br>software<br>protection<br>activated/<br>deactivated? | <ul> <li>A password can be declared at any time. Once a password has been declared, the software protection is only activated at specific times:</li> <li>in STOP mode: regularly at the system checkpoint "Stop",</li> </ul> |
|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                     | • in RESTART mode:<br>once following the call of the start-up OBs (OB 20, OB 21, OB 22),                                                                                                                                      |
|                                                                     | • in RUN mode:<br>cyclically before OB 1 is called.                                                                                                                                                                           |
| Assignment of<br>the system data<br>when writing                    | To call the software protection function, assign the system data RS 139 with a bit pattern according to the function you want to perform. Refer to the following table to see how to structure the bit pattern.               |

#### Address: EA8BH

|         | High byte                                               |  |  |
|---------|---------------------------------------------------------|--|--|
| Bit no. | Assignment                                              |  |  |
| 15      | Action bit: 1 = perform function                        |  |  |
| 14      | Function bit: 1 = declare password, 0 = delete password |  |  |
| 13      |                                                         |  |  |
| 12      |                                                         |  |  |
| 11      |                                                         |  |  |
| 10      | Bit numbers 8 to 13 of a 14-bit password                |  |  |
| 9       |                                                         |  |  |
| 8       |                                                         |  |  |
|         | Low byte                                                |  |  |
| 7       |                                                         |  |  |
| 6       |                                                         |  |  |
| 5       |                                                         |  |  |
| 4       | Bit numbers 0 to 7 of a 14-bit password                 |  |  |
| 3       |                                                         |  |  |
| 2       |                                                         |  |  |
| 1       |                                                         |  |  |
| 0       |                                                         |  |  |

Table 8-15 Assignment of RS 139 (Software protection) when writing

# Reading out the system data RS 139

By reading out the system data RS 139 you can determine whether a "job" was executed by writing the system data. The system program stores a message there.

#### Assignment of the system data when reading:

Once the software protection function has been called, you can obtain information about the success of the job by evaluating the message reported.

#### Address: EA8BH

| High byte |                                          |  |
|-----------|------------------------------------------|--|
| Bit no.   | Assignment                               |  |
| 15        | 0                                        |  |
| 14        | Error bit: 0 = no error, 1 = error       |  |
| 13        | 0                                        |  |
| 12        | 0                                        |  |
| 11        | 0                                        |  |
| 10        | Binary counter                           |  |
| 9         | counting the number of attempts          |  |
| 8         | to delete a password                     |  |
| Low byte  |                                          |  |
| 7         | 0                                        |  |
| 6         | 0                                        |  |
| 5         | 0                                        |  |
| 4         | 1 = no password declared                 |  |
| 3         | 1 = cannot delete, incorrect password    |  |
| 2         | 1 = software protection already active   |  |
| 1         | 1 = illegal password                     |  |
| 0         | 1 = counter overflow (too many attempts) |  |

Table 8-16 Assignment of RS 139 (Software protection) when reading

## Valid reports

| Address | Explanation                                                                                                                                                                                                                                                                         |  |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0000H   | No error                                                                                                                                                                                                                                                                            |  |
| 4x01H   | The counter counting attempts to delete the password overflowed.<br>Perform a COLD RESTART to reset the counter.                                                                                                                                                                    |  |
| 4x02H   | llegal password (0000H or 3FFFH)                                                                                                                                                                                                                                                    |  |
| 4x04H   | An attempt was made to declare a new password while the software protection was already activated ( $x = no.$ of attempts to delete)                                                                                                                                                |  |
| 4x08H   | An attempt was made to delete the existing password (deactivate the software protection) using an incorrect password. The counter counting the number of attempts to delete was incremented. The counter level 'x' is reported with the message (binary number in bit 8 to bit 10). |  |
| 4x10H   | An attempt was made to delete a non-existent password.                                                                                                                                                                                                                              |  |

#### When to activate the software protection

You should activate the software protection from the PG immediately after an overall reset. The earliest time you can activate it via the user program is in OB 20.

Reactions to software protection violation Once you have activated the software protection, the system program reacts to any violations by PG jobs. Refer to the following table for the reactions to the various PG jobs.

| PG function                            | Display on PG                                                                                                                              |
|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Delete block                           | Message displayed<br>"block type and number illegal"                                                                                       |
| Read block                             | A dummy block is displayed:<br>FB/FX:<br>FB number<br>NAME :DUMMY<br>:BE<br>DB/DX: DW0 6500<br>OP/PB/SB:<br>:BE                            |
| Write block (block does not exist yet) | The block is entered                                                                                                                       |
| Overwrite block (block already exists) | Message displayed "block available"; following<br>confirmation with Return, the message "block type and<br>number incorrect" is displayed. |

#### Examples of writing and reading RS 139

```
Activate the software protection in the start-up blocks:

(Activating the software protection via the user program should be done in

one of the start-up OBs - OB 20, OB 21, OB 22.)

:

:L KH COAF KH = Bit pattern "declare password"

: (password = 00AFH)

:T RS 139

:
```

Evaluate report in RS 139:

With the following series of STEP 5 operations in OB 1, you can react to an error declaring the password by evaluating the message reported. Note that the report can only be evaluated following specific actions of the system program.

```
:

:L RS 139

:L KB 0

:><F

:JC yyy Call function block for error handling

NAME:PW ERROR

:
```

```
Delete and edit the password from the PG using the function "output address":
Initial situation: The CPU is in RUN or STOP mode.
Perform the following steps:
1. Display the content of the address EA8BH.
2. Delete the old password by overwriting the content with the hexadecimal number 80AFH ("00AFH" = old password).
3. Wait at least as long as the cycle time for OB 1.
4. Display the content of the address EA8BH again.
5. Enter the new password "1234H" by overwriting the content with the hexadecimal number D234H.
```

Г

### **RS 140** Condition codeword "write and read blocks"

#### Address EA8CH

System data RS 140 indicates whether blocks have been overwritten, newly loaded or deleted since the last OVERALL RESET of the CPU or since the last time system data RS 140 was cleared. The bits for changes and block type are allocated to each block. Before a new monitoring section, system data RS 140 must be cleared. RS 140 is also cleared during an overall reset.

| High byte: Write/read IDs |                          |  |  |  |
|---------------------------|--------------------------|--|--|--|
| Bit no.                   | Bit no. Assignment       |  |  |  |
| 15                        | Block deleted            |  |  |  |
| 14                        | Block newly loaded       |  |  |  |
| 13                        | Block overwritten        |  |  |  |
| 12                        |                          |  |  |  |
| 11                        | not used                 |  |  |  |
| 10                        |                          |  |  |  |
| 9                         |                          |  |  |  |
| 8                         |                          |  |  |  |
|                           | Low byte: Write/read IDs |  |  |  |
| 7                         | not used                 |  |  |  |
| 6                         | DX                       |  |  |  |
| 5                         | DB                       |  |  |  |
| 4                         | FX                       |  |  |  |
| 3                         | FB                       |  |  |  |
| 2                         | SP                       |  |  |  |
| 1                         | PB                       |  |  |  |
| 0                         | ОВ                       |  |  |  |

Table 8-17Assignment of RS 140 (Write/read blocks)

# RS 144 "Alternative loading of data blocks into DB-RAM"

#### **Address EA90H**

In the CPU 928B, all blocks are first loaded by the programmer into the user memory as standard. Only when there is no more memory space there, are the **data blocks** (DBs, DXs) and only the data blocks loaded into DB-RAM.

You can influence the order of loading data blocks via bit no. 0 of system data word RS 144:

| Bit 0 = 0: | Default "Standard behavior":<br>The data blocks are loaded into the user memory first.<br>Only when there is no more space there, are they loaded into<br>DB-RAM. |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 0 = 1: | The data blocks are loaded into DB-RAM first.<br>Only when there is no more space there, are they loaded into<br>the user memory.                                 |

The remaining bits of RS 144 are not assigned.

#### Note

**Code blocks** are loaded into the user memory regardless of the setting in RS 144.

The setting in RS 144 has no influence on operations and special function OBs for generating and reloading blocks. Similarly, the setting has no influence on the copying of memory card blocks.

# 9

# Memory Access using Absolute Addresses

Contents of the<br/>chapterThis chapter explains how to use STEP 5 operations and special STEP 5 registers<br/>to address data in certain memory areas using absolute addresses.

# Overview of the chapter

| Section | Description                                                                 | Page |
|---------|-----------------------------------------------------------------------------|------|
| 9.1     | Introduction                                                                | 9-2  |
| 9.2     | Access using the Address in ACCU 1                                          | 9-6  |
| 9.2.1   | LIR/TIR: Loading to or Transferring from a 16-Bit<br>Memory Area Indirectly | 9-7  |
| 9.2.2   | Examples of using the Registers                                             | 9-14 |
| 9.3     | Transferring Fields of Memory                                               | 9-16 |
| 9.3.1   | Example of Transferring Memory Fields                                       | 9-19 |
| 9.4     | Operations with the Base Address Register (BR Register)                     | 9-24 |
| 9.4.1   | Operations for Transfer between Registers                                   | 9-25 |
| 9.4.2   | Accessing the Local Memory                                                  | 9-27 |
| 9.4.3   | Accessing the Global Memory                                                 | 9-28 |
| 9.4.4   | Accessing the Page Memory                                                   | 9-31 |

# 9.1 Introduction

| Introduction           | The STEP 5 programming language contains operations with which you can access the entire memory area. These operations belong to the "system operations".                                                                                                                                       |  |  |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| $\underline{\wedge}$   | <b>Caution</b><br>If the operations described in this section are not used properly, STEP 5<br>blocks and system data can be overwritten. This can result in undesirable<br>operating statuses. Only experienced system programmers should use<br>operations that work with absolute addresses. |  |  |
| Local memory           | Local memory is the memory area available in each CPU (user submodule, DB-RAM, RI, RJ, RS, RT area, counters, timers, flags, process image).                                                                                                                                                    |  |  |
| Global memory          | Global memory only exists once for all CPUs and is addressed via the S5 bus.                                                                                                                                                                                                                    |  |  |
| Memory<br>organization | <ul> <li>Memory areas are organized in bytes or words as follows:</li> <li>bytes: each address addresses a byte</li> <li>words: each address addresses a 16-bit word (= 2 bytes)</li> </ul>                                                                                                     |  |  |



Fig. 9-1 Global and local memory

| Memory access                             | With the following operations, you can access local or global memory area using absolute addresses (see also Fig. 9-2).                                                                                                                                                                                                                                                     |  |  |
|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Access to the<br>local and global<br>area | <ul> <li>You can acccess both the local and global areas:</li> <li>local area (0000 to EFFF) and the part of the global memory organized in bytes (F000 to F3FF, FC00 to FFFF):<br/>TNB, TNW, LIR, TIR</li> <li>the part of the local area organized in words (0000 to E3FF and E800 to EDFF):<br/>LRW, TRW, LRD, TRD</li> </ul>                                            |  |  |
| Access only to<br>the global area         | <ul> <li>You can access the following parts of the global area:</li> <li>the part of the global area organized in bytes (0000 to EFFF):<br/>LY GB, LY GW, LY GD, TY GB, TY GW, TY GD, TSG</li> <li>the part of the global area organized in words (0000 to EFFF):<br/>LW GW, LW GD, TW GW, TW GD, TSG</li> </ul>                                                            |  |  |
| Access to the page area                   | <ul> <li>You can access the following part of the page area:</li> <li>the part of the global area organized in bytes (F400 to FBFF,<br/>= dual-port RAM area):</li> <li>LY CB, LY CW, LY CD, TY CB, TY CW, TY CD, TSC</li> <li>the part of the global area organized in words (F400 to FBFF,<br/>= dual-port RAM area):</li> <li>LW CW, LW CD, TW CW, TW CD, TSC</li> </ul> |  |  |



Fig. 9-2 Access to local or global memory areas using absolute addresses (see also Fig. 9-1)

# 9.2 Access using the Address in ACCU 1

ApplicationRegisters are memory cells used by the CPU to execute a STEP 5 program.<br/>Every register is 16 bits wide. Using the system operations LIR (load a register<br/>indirectly) and TIR (transfer a register indirectly) you can access the contents of<br/>the registers.

#### Operations

| Operation | Operand              | Function                                                                                                         |
|-----------|----------------------|------------------------------------------------------------------------------------------------------------------|
| LIR       | Register no. 0 to 15 | Load the <b>specified register</b> with the content of<br>a memory word addressed by ACCU 1<br>(20-bit address). |
| TIR       | Register no. 0 to 15 | Load the content of the <b>specified register</b> in the memory word addressed by ACCU 1 (20-bit address).       |

 Table 9-1
 Operations for indirect memory access using registers

The memory word is either in the local area (0000 to EFFF) or in the the part of the global area organized in bytes (F000 to F3FF, FC00 to FFFF).

The following pages explain which registers you can use with the operations.

Examples explain how to use the operations.

#### 9.2.1 LIR/TIR: Loading to or Transferring from a 16-Bit Memory Area Indirectly

The following table shows which register numbers you can use with the CPU 928B for the LIR and TIR operations and how these are assigned.

| Register no. | Register assignment (each 16 bits wide) |                                                      |
|--------------|-----------------------------------------|------------------------------------------------------|
| 0            | ACCU-1-H                                | (left word of ACCU1, bits 16 to 31) <sup>1)</sup>    |
| 1            | ACCU-1-L                                | (right word of ACCU1, bits 0 to $15$ ) <sup>1)</sup> |
| 2            | ACCU-2-H                                |                                                      |
| 3            | ACCU-2-L                                |                                                      |
| 6            | DBA                                     | (data block start address register)                  |
| 8            | DBL                                     | (data block length register)                         |
| 9            | ACCU-3-H                                |                                                      |
| 10           | ACCU-3-L                                |                                                      |
| 11           | ACCU-4-H                                |                                                      |
| 12           | ACCU-4-L                                |                                                      |
| 15           | SAC                                     | (step address counter)                               |

Table 9-216-bit register for LIR/TIR

<sup>1)</sup> Loading the contents of an addressed memory register into register '0'or '1 overwrites the address stored in ACCU-1-L.

Registers 4, 5, 7, 13 and 14 do not exist on the CPU 928B. LIR/TIR operations with these register numbers are treated as **no operations** (NOP).

LIR and TIR with the page area (addresses F400 to FBFF) in the S5-135U multiprocessor PLC. Use instead the operations from Section 9.4.4 "Accessing the Page Memory" or the special functions from Section 6.21 "Page Accesses".

LIR/TIR: with 8-bitIf you use the LIR and TIR operations to access memory areas that are onlymemory areas8 bits wide i.e., for memory addresses from E400 to E7FF and  $\geq$  EE00remember that

• the TIR operation transfers only the low byte of the register. The high byte of the register is lost.

and

• the LIR operation overwrites the high byte of the registers with FFH.



Figures 9-3 and 9-4 illustrate the difference between LIR/TIR access to word and byte-oriented areas:

Fig. 9-4 LIR/TIR with 16-bit memory areas (word-oriented)



Fig. 9-3 LIR/TIR with a-bit memory areas (byte-oriented)

| Registers 0 to 3 | During program execution, the CPU uses the accumulators as buffers. Using the    |
|------------------|----------------------------------------------------------------------------------|
| and 9 to 12:     | TIR operation, you can transfer the contents of the accumulators into memory     |
| ACCU 1, 2, 3     | cells with absolute addresses. With the LIR operation, you can load the contents |
| and 4            | of memory cells with absolute addresses into the accumulators. The absolute      |
|                  | address of the memory cell is always in ACCU-1-L.                                |

#### Examples

```
You want to load the contents of the memory cell with the address A000
into flag word FW 100.
:L KH A000 load address A000 of the memory cell into ACCU 1
:LIR 1 load the contents of the memory cell in ACCU 1 into
: register 1 = load ACCU 1
:T FW 100 store the contents of address A000 in flag word FW 100
:BE
```

```
You want to transfer the contents of flag word 200 to the memory cell with
the address A000.
:LFW 200 load flag word FW 200 into ACCU 1
:LKH A000 load address A000, the destination address,
: in ACCU 1 (flag word FW 200 to ACCU 2)
:TIR 3 transfer contents of register 3 = ACCU 2 into
: the memory cell addressed by ACCU 1
:BE
```

```
Register 6:When you open a data block with the operations C DB and CX DX, the addressData Block StartOf DW 0 of this data block is loaded in register 6. The block address list in DB 0<br/>contains this address.<br/>The DBA register is set to "0" before each OB 1 or FB 0 call.
```

The DBA register remains the same if the following occurs:

• a jump operation (JU/JC) causes program execution to continue in a different block

or

a different program processing level is inserted.

It changes if one of the following occurs:

• another data block is opened

or

• the program returns to a higher level block after a new data block was opened in the inserted block (see also Section 2.4.2, Range of Validity of Data Blocks).

#### Note

In the ISTACK, the address entered in the DBA register appears under the heading "DB-ADD".

You normally access data words with the STEP 5 operations L/T DW, L/T DR, L/T DL, L/T DD, A/O/AN/ON/=/S/R Dx.y. You can only use these operations up to data word DW 255. However, by manipulating the DBA register, you can use them to access data words > 255. This is also possible with special function OB 180 (see Section 6.15).

#### Examples



```
Example 2: By changing register 6, you can load data word DW 300 of
          data block DB 100.
FB 7
NAME: LIR/TIR6
                   start address of the DB address list plus 100
         RS 34
    :L
    :ADD BN+100
                   produces the address list entry of DB 100
                   start address of DB 100 (DW 0) to ACCU 1
    :LIR 1
                   store address of DW 200 in DB 100 in system data
    :ADD KF+200
    :T RS 62
                   word RS 62
    :L
         RS 20
                   load base address of system data
                   load address of RS 62 in ACCU 1
    :ADD KF+62
                   load DBA register with the contents of the address of
    :LIR 6
                   RS 62, i.e., the data block start is set to DW 200
    :
    :L
         DW 100
                   load DW (200 + 100) = DW 300
    :Т
         FW 100
                   store DW 300 in flag word FW 100
    : BE
```

```
Example 3: Changing the DBA and DBL registers.
FB7
NAME :OB180
         DB 100
                    DBA and DBL registers are loaded with the values
    :C
                    of DB 100 and with the help of OB 180 the
    :L
         KF 200
    :JU OB 180
                    DBA register is increased by 200 and the DBL
                       register reduced by 200
    :
    :JC =ERRO
                    error output, in case DB 100 contains
                      less than or equal to 200 data words
    :
         DW 100
                    load DW 300 and
    :L
                       store in FW 100
    :Т
         FW 100
    :BEU
ERRO:
                    program section for error handling
    :
    : BE
```

#### Note

If you manipulate the DBA register as shown in example 1, the DBL register is **not** changed. This means that transfer error monitoring can no longer be guaranteed.

By using the special function OB 180 "variable data block access" you can also shift the DBA register by a selected number of data words. Since OB 180 also changes the DBL register at the same time, transfer error monitoring remains in effect. Register 8:In addition to the DBA register, a DBL register is loaded every time a data blockDBL = Datais called. This contains the length (in words) of the data block called, without theBlock Lengthblock header. The DBL register is set to "0" before each OB 1 or FB 0 call.

The DBL register remains the same if the following occurs:

• a jump operation (JU/JC) causes program execution to continue in a different block

or

• a different program processing level is inserted.

It changes if one of the following occurs:

• another data block is opened

or

• the program returns to a higher level block after a new data block was opened in the inserted block (see also Section 2.4.2).



Register 15: SAC = Step Address Counter During STEP 5 program execution, register 15 contains the absolute address of the operation in the program memory to be processed next.

#### 9.2.2 Examples of using the Registers

Example 1: You want all the data words of a data block to contain a constant.
The program shown below writes the constant KH=A5A5 to all data words in DB 50. After changing the STEP 5 operations shown in bold face, it can also be used to write any values required to different data blocks (DB or DX). Non-existent data blocks or data blocks with no data words are detected and cause a jump to the NIVO label.
The start address (DBA) and length (DBL) of the data block are determined by the special function OB 181 "test data block (DB/DX)".

The program uses all four accumulators. In the figure, you can see the occupation of the accumulators during the program as far as the LOOP label. Within the loop, the accumulator occupation does not change.

ACCU 1 initially contains the address of the last data word (DBA + DBL - 1) and is reduced by 1 each time the loop is run through. ACCU 2 contains the address of the first data word (DBA). The loop is abandoned as soon as the contents of ACCU 1 are less than the contents of ACCU 2.

The operation TIR 10 that stores the contents of ACCU-3-L (the constant) under the address located in ACCU-1-L is used to write to the data words.

```
:
         KHA5A5
                      constant to be written to
    :L
                         all data words
    :
                      type and number of the data block
    :L
         KY 1,50
    :ENT
                      special function OB "test data blocks"
    :JU OB 181
                      abandon if DB 50 does not exist
    : JC
         =NIVO
    : TAK
    :ENT
    :+F
                      ACCU 1 := address of last data word + 1
    :
                      ACCU 2 := address of the first data word
    :
                       ACCU 3 := constant
    :
                      abandon if DB 50 contains
    :!=F
                         no data words
    :JC =NIVO
                      constant contained in ACCU-3-L
LOOP:ADD BN-1 the
    :TIR 10
                         is written to all data words beginning
                         with the last data word
    :
    :><F
                      scan: 1st data word reached?
    :JC =LOOP
                      return to loop if 1st data word not reached
    :
                      continuation of the program...
    :
                                         Continued on next page
```



```
Example 2: Clearing all flag bytes (FY 0 to FY 255)
         кв О
                       constant to be written to
    :L
                          all flag bytes
    :
                       base address of the flag area (= address
         RS 14
    :L
                          of the first flag byte FY 0)
    :
    : ENT
    :L
         KF + 256
                    + length of the flag area
    : ENT
                          = (address of the last flag byte FY 255) + 1
    :+F
    :
LOOP:ADD BN -1
                       write the constant contained in ACCU-3-L
    :TIR 10
                          to all 256 flag bytes, beginning with
                          flag byte FY 255
    :
    :JC =LOOP
    :
    :
    :
```

# 9.3 Transferring Fields of Memory

**Application**You can use the system operations TNB and TNW to transfer fields of memory<br/>(max. 255 bytes with TNB, max. 255 words with TNW). With the TNB and<br/>TNW operations you can access both the local memory area and the part of the<br/>global memory area organized in bytes (F000 to F3FF, FC00 to FFFF).

#### Operations

| Operation | Operand  | Function                      |
|-----------|----------|-------------------------------|
| TNW       | 0 to 255 | Field transfer 0 to 255 bytes |
| ТХВ       |          | Field transfer o to 255 words |

#### Parameters Field length

Operand = number of bytes (TNB) or number of words (TNW)

#### End address of the source area

ACCU-2-L = End address of the source area

#### End address of the destination area

ACCU-1-L = End address of the destination area

The entire source and destination areas must be located in one of the memory areas listed in Table 9-4 and **cannot overlap.** 

#### Permissible memory areas

#### Table 9-4Memory areas permitted for TNW, TXB and TXW

| Addresses                                                                                                 | Memory area                                                                                                                                                                                       |  |
|-----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0000H to 1 FFFH<br>0000H to 3FFFH<br>0000H to 7FFFH                                                       | User memory:<br>User submodule (16 bits) 8 Kwords<br>User submodule (16 bit) 16 Kwords<br>User submodule (16 bit) 32 Kwords                                                                       |  |
| 8000H to DD7FH<br>DD80H to E3FFH<br>E400H to E7FFH<br>E800H to EDFFH<br>EE00H to EFFFH<br>F0000H to FFFFH | System RAM:<br>DB-RAM (16 bits)<br>DB 0 (16 bits)<br>S flags (8 bits)<br>System data (16 bits: BA, BB, BS, BT, timers and counters)<br>RAM (8 bits: flags, process image)<br>I/Os (8 bits)/S5 bus |  |

| Sequence                                                        | The field transfer is made in descending order, i.e. it begins with the highest address of the source area (= end address) and ends with the lowest.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Use in the page<br>area                                         | The TNB and TNW operations are <b>not</b> suitable for accessing the page area (addresses F400 to FBFF) in the S5-135U multiprocessor PLC. Use instead the operations from Section 9.4.4 "Accessing the Page Memory" or the special functions from Section 6.24 "Page Accesses".                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Special features                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <i>Pseudo<br/>operation<br/>boundaries with<br/>TNB and TNW</i> | The TNB and TNW operations are long-running STEP 5 operations that contain<br>so-called "pseudo operation boundaries". This means that the data is transferred<br>in sub-fields of various sizes depending on the source and destination area. If an<br>error (e.g. cycle error) or an interrupt (e.g. caused by a time or process-driven<br>interrupt) occurs during the transfer of a sub-field, the appropriate organization<br>block is inserted at the end of this sub-field. This is, however, only possible if<br>DX 0 is programmed to allow interruptions at operation boundaries.                                                                                                           |
|                                                                 | If one or more timeouts and/or addressing errors occur during the transfer, all the sub-fields are transferred first and then before the next operation is executed, the appropriate error organization block is called once (if QVZ and ADF occur simultaneously, only the QVZ-OB is called). The error address specified is always <b>the</b> address at which an error occurred <b>first</b> . Since TNB and TNW operate with decrementing addresses, when there is more than one error, this is always the <b>highest</b> error address in the area in which an error <b>first</b> occurred. OB 2, OB 10 to 18 or an error organization block can be inserted at the pseudo operation boundaries. |

#### TNB and TWN between 8 and 16 bit memory areas



Fig. 9-8 Transferring blocks of memory

#### 9.3.1 Example of Transferring Memory Fields



```
Example 1 continued:
b) Program structure:
FB 10 is made up of five program sections with the following tasks:
- Input parameters
 a) Check that the source and destination data block are not the same
    type and same number.
 b) Check that the input parameters "source offset", "destination offset"
    and "length of field" are less than 4096.
- Source data block:
 a) Check that the source data block exists and is long enough.
 b) Calculate the absolute address of the last data word in the
    destination field.
- Destination data block:
 a) Check that the destination data block exists and is long enough and
    whether it is in the random access memory (RAM submodule or DB-RAM).
 b) Calculate the absolute address of the last data word in the
    destination field.
- Transfer:
 Execute the copy function with the help of the TNW operation.
 Blocks of data with more than 255 words are transferred in sub-fields
 of 128 words (operation TNW 128).
 Any remaining data is transferred by an additional TNW operation.
- Condition code:
 Write the output parameter "status" according to the results of the
 checks carried out.
c) Occupied memory cells
FW 242 End address of the data destination
FW 244 End address of the data source
FW 246 Length of the field of data
FW 248 Offset in the destination data block
FW 250 Type and number of the destination data block
FW 252 Offset in the source data block
FW 254 Type and number of the source data block
RS 60
         Sub-field counter
                                          Continued on next page
```

Example 1 continued: b) Programming function block FB 10 Note: If you want to copy from data word DW 0, the program sections shown in heavy print can be omitted. You do not specify an offset value. **FB10** SEGMENT 1 NAME: DB-DB-TR DATA BLOCK-DATA BLOCK TRANSFER DECL :STNO I/Q/D/B/T/C: D KM/KH/KY/KS/KF/KT/KC/KG: KY DECL:SOFFI/Q/D/B/T/C: D KM/KH/KY/KS/KF/KT/KC/KG: KF DECL: DTNOI/Q/D/B/T/C: D KM/KH/KY/KS/KF/KT/KC/KG: KY DECL:DOFFI/Q/D/B/T/C: D KM/KH/KY/KS/KF/KT/KC/KG: KF DECL:LENGI/Q/D/B/T/C: D KM/KH/KY/KS/KF/KT/KC/KG: KF DECL:STAT I/Q/D/B/T/C: Q BI/BY/W/D: BY : BEGINNING OF INPUT PARAMETERS : .....-SINUTYPE (DB/DX) AND NUMBER OF:TFW 254THE SOURCE DATA BLOCK:LW =DTNOTYPE (DB/DX) AND NUMBER OF:TFW 250:T FW 250THE DESTINATION DATA FOR THE DESTINATION DATA BLOCK :!=F SOURCE DB = DESTINATION DB ? :JC =F001 JUMP IF YES : : • :LW =SOFF **OFFSET IN SOURCE** :TFW 252 DATA BLOCK :LW =DOFF OFFSET IN DESTINATION :T FW 248 DATA BLOCK :OW :LW =LAEN LENGTH (NUMBER OF DATA WORDS) FW 246 OF THE FIELD TO BE TRANSFERRED :T (LENGTH OF FIELD) : OR SOURCE OFFSET, DESTINATION OFFSET :OW :L KH F000 **LENGTH** >= 4096 ? : AW JUMP, IF YES :JP =F002 END OF INPUT PARAMETERS : : : : : : Continued on next page

Example 1 continued:

| :                                                                                                   |        | BEGINNING OF SOURCE DATA BLOCK                                   |
|-----------------------------------------------------------------------------------------------------|--------|------------------------------------------------------------------|
|                                                                                                     | FW 254 |                                                                  |
|                                                                                                     | OB 181 | TEST DATA BLOCK                                                  |
| : JC                                                                                                | =F003  | JUMP, IF BLOCK TEST NEGATIVE                                     |
| : TAK                                                                                               |        | A1: NUMBER OF DWs, A2: ADDRESS                                   |
| : ENT                                                                                               |        | A3: ADDRESS                                                      |
| :L                                                                                                  | FW 252 | OFFSET IN SOURCE DATA BLOCK                                      |
| : ENT                                                                                               |        | A3: NUMBER OF DWs, A4: ADDRESS                                   |
| :L                                                                                                  | FW 246 | LENGTH OF FIELD                                                  |
| :+F                                                                                                 |        | OFFSET + LENGTH OF FIELD                                         |
| : <f< td=""><td></td><td>NO. OF DWs <offset +="" ?<="" field="" length="" td=""></offset></td></f<> |        | NO. OF DWs <offset +="" ?<="" field="" length="" td=""></offset> |
|                                                                                                     |        | JUMP, IF YES                                                     |
| :L                                                                                                  | КВ 1   | A2: OFFSET + FIELD LEN, A3: ADDRESS                              |
| :-F                                                                                                 |        | <i>OFFSET</i> + FIELD LENGTH - 1                                 |
| :+F                                                                                                 |        | OFFSET + FIELD LEN - 1 + ADDRESS                                 |
| :Т                                                                                                  | FW 244 | END ADDRESS OF THE DATA SOURCE                                   |
| :                                                                                                   |        | END OF SOURCE DATA BLOCK                                         |
| :                                                                                                   |        |                                                                  |
| :                                                                                                   |        |                                                                  |
| :                                                                                                   |        |                                                                  |
| :                                                                                                   |        |                                                                  |
| :                                                                                                   |        |                                                                  |
| :                                                                                                   |        |                                                                  |
| :                                                                                                   |        |                                                                  |
| :                                                                                                   |        | BEGINNING OF DESTINATION DATA BLOCK                              |
|                                                                                                     | FW 250 |                                                                  |
|                                                                                                     | OB 181 |                                                                  |
|                                                                                                     |        | JUMP, IF BLOCK TEST NEGATIVE                                     |
|                                                                                                     | =F006  | JUMP, IF BLOCK IN EPROM                                          |
| : TAK                                                                                               |        | A1: NUMBER OF DWs, A2: ADDRESS                                   |
| : ENT                                                                                               |        | A3: ADDRESS                                                      |
|                                                                                                     | FW 248 | OFFSET IN DESTINATION DATA BLOCK                                 |
| :ENT                                                                                                |        | A3: NUMBER OF DWs, A4: ADDRESS                                   |
|                                                                                                     | FW 246 | LENGTH OF FIELD                                                  |
| :+F                                                                                                 |        | OFFSET + LENGTH OF FIELD                                         |
| : <f< td=""><td></td><td>NO. OF DWS &lt; OFFSET + FIELD LENGTH ?</td></f<>                          |        | NO. OF DWS < OFFSET + FIELD LENGTH ?                             |
|                                                                                                     |        | JUMP, IF YES                                                     |
|                                                                                                     | KB 1   | •                                                                |
| :-F                                                                                                 |        | OFFSET + FIELD LENGTH - 1                                        |
| :+F                                                                                                 |        | OFFSET + FIELD LEN - 1 + ADDRESS                                 |
| • -                                                                                                 | FW 242 | END ADDRESS OF THE DATA DESTINATION                              |
| :                                                                                                   |        | END OF DESTINATION DATA BLOCK                                    |
| :                                                                                                   |        |                                                                  |
| :                                                                                                   |        |                                                                  |
| :                                                                                                   |        |                                                                  |
| :                                                                                                   |        |                                                                  |
|                                                                                                     |        |                                                                  |
|                                                                                                     |        |                                                                  |
|                                                                                                     |        |                                                                  |
|                                                                                                     |        |                                                                  |
|                                                                                                     |        | Continued on next page                                           |

Example 1 continued: BEGINNING OF TRANSFER : :L KB 0 COMPARISON VALUE :L FY 246 FIELD LENGTH, HIGH BYTE :!=F FIELD LENGTH >= 256 WORDS ? :SLW 1 MULTIPLIED BY 2, NUMBER OF SUB-:TRS60FIELDSEACH WITH128WORDS:LFW244ENDADDRESSOFTHEDATASOURCE :LFW 242END ADDRESS OF THE DATA DESTINATION:JC=RESTJUMP, IF FIELD LENGTH < 256 WORDS</td>:TNW 128TRANSFER A SUB-FIELD LOOP:TNW 128 :ADD KF -128 REDUCE SOURCE END ADDRESS BY : TAK LENGTH OF THE SUB-FIELD :ADD KF -128 REDUCE DESTINATION END ADDRESS : TAK BY LENGTH OF THE SUB-FIELD :JU OB 160 COUNT LOOP :JC =LOOP JUMP, IF NOT ALL SUB-FIELDS HAVE BEEN TRANSFERRED : REST:DO FW 246 FIELD LENGTH, LOW BYTE :TNW 0 TRANSFER REMAINDER OF FIELD END TRANSFER : • : : • : BEGINNING OF CONDITION CODE : :L KB 0 ID 00 (HEX): NO ERROR END :T =STAT OUTPUT PARAMETER STATUS/ERROR :BEU F001:L KB 129 ERROR ID 81 (HEX): :JU =END SOURCE DB = DESTINATION DB F002:L KB 130 ERROR ID 82 (HEX): :JU =END OFFSET OR LENGTH >= 4096 F003:L KB 131 ERROR ID 83 (HEX): :JU =END SOURCE DB ILLEGAL F004:L KB 132 ERROR ID 84 (HEX): :JU =END SOURCE DB TOO SHORT F005:L KB 133 ERROR ID 85 (HEX): :JU =END DESTINATION DB ILLEGAL F006:L KB 134 ERROR ID 86 (HEX): :JU =END DESTINATION DB IN READ-ONLY MEMORY F007:L KB 135 ERROR ID 87 (HEX): :JU =END DESTINATION DB TOO SHORT : END OF CONDITION CODE :BEU : END OF CONDITION CODE :BE

# 9.4 Operations with the Base Address Register (BR Register)

**Application**The BR register (base address register, 32 bits) is used by the load and transfer<br/>operations described from Section 9.3.3 onwards to address the memory. The<br/>absolute address of the memory cell to be accessed is calculated as the sum of the<br/>contents of the BR register and a constant as follows:

Absolute address = BR register contents + constant

#### Operations

| Operation | Operand                       | Function                                                 |
|-----------|-------------------------------|----------------------------------------------------------|
| MBR       | Constant (0H to F FFFFH)      | Load the BR register with a 20-bit constant $^{(1)}$     |
| ABR       | Constant (-32 768 to +32 767) | Add a 16-bit constant to the contents of the BR register |

 Table 9-5
 Load and arithmetic operations with the BR register

<sup>1)</sup> Bits  $2^{20}$  to  $2^{31}$  of the BR register are set to "0".





# Changing the BR register is retained when the same program processing level is continued in another block called by the jump operation (JU FB / JC FB).

• The BR register is **retained** after **nesting in** a different program execution level.

When the system program calls **another program processing level**, the BR register is set to "**0**".

## 9.4.1 Operations for Transfer between Registers

**Application** You can use the operations described in this section for the fast exchange of values between the restisters ACCU 1, STEP address counter (SAC) and base address register (BR).

#### Operations

| Operation | Operand | Explanation                                                                                                                          |  |
|-----------|---------|--------------------------------------------------------------------------------------------------------------------------------------|--|
| MAS       | _       | Transfer the contents of ACCU 1 (bit $2^0$ to $2^{14}$ ) to the SAC register (STEP address counter)                                  |  |
| MAB       | _       | Transfer the contents of ACCU 1 (bits $2^0$ to $2^{31}$ ) to the BR register (base address register)                                 |  |
| MSA       | _       | Transfer the contents of the STEP address counter (SAC register) to ACCU 1 $^{1)}$                                                   |  |
| MSB       | _       | Transfer the contents of the SAC register (STEP address counter) to the BR register (base address register) <sup>1)</sup>            |  |
| MBA       | _       | Transfer the contents of the BR register (base address register) to ACCU 1                                                           |  |
| MBS       | _       | Transfer the contents of the BR register (bits $2^0$ to $2^{14}$ , base address register) to the SAC register (STEP address counter) |  |

 Table 9-6
 Operations for transfer between registers

<sup>1)</sup> Bits  $2^{15}$  to  $2^{31}$  are set to "0"

The following figure illustrates how the registers are changed by the operations.



Fig. 9-8 Register - register transfer operations

#### 9.4.2 Accessing the Local Memory

ApplicationWith the following operations, you can access the local memory organized in<br/>words using an absolute memory address. The absolute address is the total of the<br/>BR register contents and the 16-bit constant contained in the operation (-32768<br/>to +32767).

#### Operations

| Operation | Operand                        | Description                                                                                                                                |
|-----------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| LRW       | Constant<br>(-32768 to +32767) | add the specified constant to content <sup>1)</sup><br>of the BR register and load the word<br>addressed in this way in ACCU-1-L           |
| LRD       | Constant<br>(-32768 to +32767) | add the specified constant to content <sup>1)</sup> of the BR register and load the double word addressed in this way in ACCU 1            |
| TRW       | Constant<br>(-32768 to +32767) | add the specified constant to content of the BR<br>register and transfer the content of ACCU-1-L<br>to the word addressed in this way      |
| TRD       | Constant<br>(-32768 to +32767) | add the specified constant to content of the BR<br>register and transfer the content of ACCU 1 to<br>the double word addressed in this way |

 Table 9-7
 Operations for accessing the local memory

<sup>1)</sup> ACCU  $2_{\text{new}} = \text{ACCU } 1_{\text{old}}$ 

| Permissible<br>address area | The absolute address must be as follows:                                                                                                                                                                                                                                                                                                       |                                           |  |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--|
|                             | • for LRW, TRW:                                                                                                                                                                                                                                                                                                                                | between 000H and E3FFH or E800H and EDFFH |  |
|                             | • for LRD, TRD:                                                                                                                                                                                                                                                                                                                                | between 000H and E3FEH or E800H and EDFEH |  |
| Error reaction              | If the calculated address of the memory location is not in the permissible memory area, the CPU detects a runtime error and calls <b>OB 31</b> , providing it is loaded. If OB 31 is not loaded, the CPU goes to the stop mode. In both cases, error IDs are entered in ACCU-1-L, that define the error in greater detail (see Section 5.7.2). |                                           |  |

#### 9.4.3 Accessing the Global Memory

Application With the following operations, you can access the global memory organized in bytes or words using an absolute memory address. The absolute address is the total of the BR register contents and the constant contained in the operation (-32768 to 32767).
 Testing and setting a busy Vou can control the access of individual CPUs to common memory areas using a busy location. Each memory area used by more than one CPU has a busy

location in the global area

busy location. Each memory area used by more than one CPU has a busy location assigned to it that must be tested by each CPU before it can access this area. The busy location either contains the value "0" or the slot identifier of the CPU currently using the memory area. This CPU releases the memory area by writing "0" to the busy location again when it is finished. (Note the explanations for the operations "set semaphore/SED" and "enable semaphore/SEE" in Section 3.5.5.).

The CPU tests and sets a busy location using the TSG operation.

| Operation | Operand          | Explanation                                                                                                             |
|-----------|------------------|-------------------------------------------------------------------------------------------------------------------------|
| TSG       | -32768 to +32767 | Add the specified constant to the content of<br>the BR register and test and set the location<br>addressed in this way. |

**Sequence** The low byte of the word addressed by the contents of the BR register + the constant is used as the busy location. If the content of the low byte is "0", the TSG operation enters the slot ID (from RS 29) into the busy location.

Testing (= reading) and setting (= writing) the busy location is one program unit that cannot be interrupted.

**Result** You can evaluate the result of the test in condition codes CC 0 and CC 1, as follows:

| CC 1 | CC 0 | Explanation                                                           |
|------|------|-----------------------------------------------------------------------|
| 0    | 0    | The busy location contains the value "0"; the CPU enters its slot ID. |
| 1    | 0    | The CPU's own slot ID is already entered in the busy location.        |
| 0    | 1    | The busy location contains a different slot ID.                       |

#### Note

All CPUs that require synchronized access to a **common global memory area** must use the TSG operation.

# **Permissible** The absolute address must be between 0000H and EFFFH.

# address area

Error reaction

If the calculated address of the memory location is not in the range shown, the CPU detects a runtime error and calls **OB 31**, providing it is loaded. If OB 31 is not loaded, the CPU goes to the stop mode.

In both cases, error IDs are entered in ACCU-1-L, that define the error in greater detail (see Section 5.6.2).

#### Load and transfer operations for the global memory organized <u>in bytes</u>

 Table 9-8
 Operations for access to the global memory organized in bytes

| Operation | Operand          | Description                                                                                                                                           |
|-----------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| LY GB     | -32768 to +32767 | add the specified constant to content of the BR register and load the byte addressed in this way in ACCU-1-LL $^{(1)}$ $^{(3)}$                       |
| LY GW     | -32768 to +32767 | add the specified constant to content of the BR register and load the word addressed in this way in ACCU-1-L <sup><math>2</math></sup> ) <sup>3</sup> |
| LY GD     | -32768 to +32767 | add the specified constant to content of the BR register and load the double word addressed in this way in ACCU $1^{3}$                               |
| TY GB     | -32768 to +32767 | add the specified constant to content of the BR<br>register and transfer the content of ACCU-1-LL<br>to the byte addressed in this way                |
| TY GW     | -32768 to +32767 | add the specified constant to content of the BR<br>register and transfer the content of ACCU-1-L<br>to the word addressed in this way                 |
| TY GD     | -32768 to +32767 | add the specified constant to content of the BR<br>register and transfer the content of ACCU 1 to<br>the double word addressed in this way            |

- <sup>1)</sup> ACCU-1-LH and ACCU-1-H are set to '0'.
- <sup>2)</sup> ACCU-1-H is set to '0'.
- <sup>3)</sup> ACCU 2 <sub>new</sub> : = ACCU  $1_{old}$

#### Permissible address area

The absolute address must be as follows:

| • between 0 and EFFFH | (for LY GB, TY GB) |
|-----------------------|--------------------|
| • between 0 and EFFEH | (for LY GW, TY GW) |

• between 0 and EFFCH (for LY GD, TY GD)

**Error reaction** If the calculated address of the memory location is not in the range shwon, the CPU detects a runtime error and calls **OB 31**, providing it is loaded. If OB 31 is not loaded, the CPU goes to the stop mode. In both cases, error IDs are entered in ACCU-1-L, that define the error in greater detail (see Section 5.7.2).

#### Load and transfer operations for the global memory organized <u>in words</u>

Table 9-9 Operations for access to the global memory organized in words

| Operation | Operand          | Description                                                                                                                                         |
|-----------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| LW GW     | -32768 to +32767 | add the specified constant to content of the BR register and load the word addressed in this way in ACCU-1-L <sup><math>1</math>)<sup>2</sup></sup> |
| LW GD     | -32768 to +32767 | add the specified constant to content of the BR register and load the double word addressed in this way in ACCU 1 $^{2}$                            |
| TW GW     | -32768 to +32767 | add the specified constant to content of the BR<br>register and transfer the content of ACCU-1-L<br>to the word addressed in this way               |
| TW GD     | -32768 to +32767 | add the specified constant to content of the BR<br>register transfer the content of ACCU 1 to the<br>double word addressed in this way              |

<sup>1)</sup> ACCU-1-H is set to '0'.

<sup>2)</sup> ACCU 2 <sub>new</sub> : = ACCU  $1_{old}$ 

| Permissible<br>address area | The absolute address must be as follows:                                                                                                                                                                            |                     |  |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--|
|                             | • for LW GW, TW GW:                                                                                                                                                                                                 | between 0 and EFFFH |  |
|                             | • for LW GD, TW GD:                                                                                                                                                                                                 | between 0 and EFFEH |  |
|                             |                                                                                                                                                                                                                     |                     |  |
| Error reaction              | If the calculated address of the memory location is not in the range shown, the CPU detects a runtime error and calls <b>OB 31</b> , providing it is loaded. If OB 31 is not loaded, the CPU goes to the stop mode. |                     |  |

In both cases, error IDs are entered in ACCU-1-L, that define the error in greater detail (see Section 5.7.2).

# 9.4.4 Accessing the Page Memory

| Application                     | Using the following operations, you can access pages organized in <b>bytes or words</b> via an absolute memory address. The absolute address is the total of the BR register contents and the constant contained in the operation (-32768 to 32767).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Procedure of<br>accessing pages | The global area includes a "window" in the address area F400H to FBFFH to allow access to one of maximum 256 memory areas (= pages). A page occupies maximum of 2 K addresses and can be organized in bytes or words. Before each access to the page area, one of the 256 pages must be selected by entering its page number in the select register. Writing to the select register and the subsequent access to the page area cannot be interrupted. Before any access (load/transfer) to the page area, one of the 256 pages must be opened. To do this, you transfer the number of the page to be opened to ACCU-1-L; this number is entered in the CPU internal page register with the ACR operation. All subsequent page operations write the contents of the page register to the select register of the appropriate modules on the S5 bus before the page is accessed. |  |
|                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| Changing the page register      | • The page register is <b>retained</b> when <b>the same program processing level is continued in another block</b> called by the jump operation (JU FB / JC FB).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|                                 | • When the page register is modified in a block, its <b>value is retained</b> if the program jumps back to the calling block at the end of the block.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|                                 | • After another program processing level has been inserted, the system program loads <b>the same value</b> in the page register as it had <b>before</b> the other level was inserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|                                 | • When the system program calls <b>another program processing level</b> , the page register is set to " <b>0</b> ".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| Opening a page                  | FF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |

| Operation | Operand | Explanation                                                                  |
|-----------|---------|------------------------------------------------------------------------------|
| ACR       |         | Open the page whose number is located in ACCU-1-L permitted values: 0 to 255 |

**Error reaction** The page number must be between 0 and 255. If this is not the case, the CPU recognizes a runtime error and calls **OB 31**, providing it is loaded. If OB 31 is not loaded, the CPU goes to the stop mode. In both cases, error IDs are entered in ACCU-1-L, that define the error in greater detail (see Section 5.7.2).

Testing and setting a busy location in the page area You can control the access of individual CPUs to common memory areas using a busy location. Each memory area used by more than one CPU has a busy location assigned to it that must be tested by each CPU before it can access this area. The busy location either contains the value "0" or the slot identifier of the CPU currently using the memory area. This CPU releases the memory area by writing "0" to the busy location again when it is finished. (Note the explanations of the operations "set semaphore/SED" and "enable semaphore/SEE" in Section 3.5.5.).

The CPU tests and sets a busy location on the open page using the TSC operation.

| Operation | Operand          | Explanation                                                                                                                                |
|-----------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| TSC       | -32768 to +32767 | Add the specified constant to the content of<br>the BR register and test and set the location on<br>the opened page addressed in this way. |

**Sequence** The low byte of the word addressed by the contents of the BR register + the constant is used as the busy location. If the content of the low byte is "0", the TSC operation enters the slot ID (from RS 29) into the busy location.

Testing (= reading) and setting (= writing) the busy location is one program unit that cannot be interrupted.

**Result** You can evaluate the result of the TSC operation in condition codes CC 0 and CC 1, as follows:

| CC 1 | CC 1 | Explanation                                                           |
|------|------|-----------------------------------------------------------------------|
| 0    | 0    | The busy location contains the value "0"; the CPU enters its slot ID. |
| 1    | 0    | The CPUs own slot ID is already entered in the busy location.         |
| 0    | 1    | The busy location contains a different slot ID.                       |

#### Note

All CPUs requiring synchronized access to a common global memory area (page area) must use the TSC operation.

Error reactionThe location must be on the corresponding module and on the common page<br/>between F F400H and F FBFFH. If this is not the case, the CPU recognizes a<br/>runtime error and calls OB 32, providing it is loaded. If OB 32 is not loaded, the<br/>CPU goes to the stop mode.<br/>In both cases, error IDs are entered in ACCU-1-L, that define the error in greater<br/>detail (see Section 5.6.2).

#### Load and transfer operations for the pages organized in bytes

Table 9-10 Operations for access to the pages organized in bytes

| Operation | Operand          | Description                                                                                                                                                                |
|-----------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LY CB     | -32768 to +32767 | add the specified constant to content of the BR register and load the byte in the opened page addressed in this way into ACCU-1-LL $^{1)}$ 3)                              |
| LY CW     | -32768 to +32767 | add the specified constant to content of the BR register and load the word in the opened page addressed in this way into ACCU-1-L <sup><math>2</math></sup> ) <sup>3</sup> |
| LY CD     | -32768 to +32767 | add the specified constant to content of the BR register and load the double word in the opened page addressed in this way into ACCU $1^{3}$                               |
| ТҮ СВ     | -32768 to +32767 | add the specified constant to content of the BR<br>register and transfer the content of ACCU-1-LL<br>to the byte addressed in this way in the opened<br>page               |
| TY CW     | -32768 to +32767 | add the specified constant to content of the BR<br>register and transfer the content of ACCU-1-L to<br>the word addressed in this way in the opened page                   |
| TY CD     | -32768 to +32767 | add the specified constant to content of the BR register and transfer the content of ACCU 1 to the double word addressed in this way in the opened page.                   |

- <sup>1)</sup> ACCU-1-LH and ACCU-1-H are set to '0'.
- <sup>2)</sup> ACCU-1-H is set to '0'.
- <sup>3)</sup> ACCU 2 new : = ACCU  $1_{old}$

| Permissible<br>address area | The absolute address must be as follows: |                                                                                                                                                   |  |
|-----------------------------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                             | • for LY CB, TY CB:                      | between F400H and FBFFH                                                                                                                           |  |
|                             | • for LY CW, TY CW:                      | between F400H and FBFEH                                                                                                                           |  |
|                             | • for LY CD, TY CD:                      | between F400H and FBFCH                                                                                                                           |  |
| Error reaction              | runtime error and calls OB 31,           | s not in the range shown, the CPU recognizes a providing it is loaded. If OB 31 is not loaded, the both cases, error IDs are entered in ACCU-1-L, |  |

that define the error in greater detail (see Section 5.7.2).

Load and transfer operations for pages organized in words

Table 9-11 Operations for access to the pages organized in words

| Operation | Operand          | Explanation                                                                                                                                          |
|-----------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| LW CW     | -32768 to +32767 | add the specified constant to content of the BR register and load the word addressed in this way in the opened page into ACCU-1-L <sup>1)</sup>      |
| LW CD     | -32768 to +32767 | add the specified constant to content of the BR register and load the double word addressed in this way in the opened page into ACCU 1 $^{2)}$       |
| TW CW     | -32768 to +32767 | add the specified constant to content of the BR register and transfer the content of ACCU-1-L to the word addressed in this way in the opened page.  |
| TW CD     | -32768 to +32767 | add the specified constant to content of the BR register transfer the content of ACCU 1 to the double word addressed in this way in the opened page. |

<sup>1)</sup> ACCU-1-H is set to '0'.

<sup>2)</sup> ACCU 2 <sub>new</sub> : = ACCU  $1_{old}$ 

| Permissible<br>address area | The absolute address must be as follows:                      |                                                                                                                                                                                                        |  |
|-----------------------------|---------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                             | • for LW CW, TW CW:                                           | between F400H and FBFFH                                                                                                                                                                                |  |
|                             | • for LW CD, TW CD:                                           | between F400H and FBFEH                                                                                                                                                                                |  |
| Error reaction              | recognizes a runtime error and not loaded, the CPU goes to th | memory cell is not in the range shown, the CPU calls <b>OB 31</b> , providing it is loaded. If OB 31 is e stop mode. In both cases, error IDs are entered in or in greater detail (see Section 5.7.2). |  |

# 10

# Multiprocessor Mode and Communication

## Contents of the chapter

At the beginning of this chapter, you will see when you can use the multiprocessor mode and which data exchange is possible in this mode. The chapter provides you with information about programming for multiprocessor operation (Section 10.1).

The second part of the chapter provides you with detailed instructions and examples of exchanging larger amounts of data in the multiprocessor mode (multiprocessor communication Sections 10.2 to 10.9).

## Overview of the chapter

| Section | Description                                                                  | Page  |
|---------|------------------------------------------------------------------------------|-------|
| 10.1    | Multiprocessor Mode                                                          | 10-3  |
| 10.1.1  | Exchanging Data via IPC Flags                                                | 10-4  |
| 10.1.2  | I/O Flag Assignment and IPC Flag Assignment in<br>Multiprocessor Mode (DB 1) | 10-8  |
| 10.1.3  | How to Create Data Block DB 1                                                | 10-9  |
| 10.2    | Multiprocessor Communication                                                 | 10-13 |
| 10.2.1  | How the Transmitter and Receiver are Identified                              | 10-15 |
| 10.2.2  | Why Data is Buffered                                                         | 10-16 |
| 10.2.3  | How the Buffer is Processed and Managed                                      | 10-17 |
| 10.2.4  | System Start-Up                                                              | 10-20 |
| 10.2.5  | Calling Communication OBs                                                    | 10-21 |
| 10.2.6  | How to Assign Parameters to Communication OBs                                | 10-22 |
| 10.2.7  | How to Evaluate the Output Parameters                                        | 10-24 |
| 10.3    | Runtimes of the Communication OBs                                            | 10-29 |
| 10.4    | INITIALIZE Function (OB 200)                                                 | 10-30 |
| 10.4.1  | Function                                                                     | 10-30 |
| 10.4.2  | Call Parameters                                                              | 10-32 |
| 10.4.3  | Input Parameters                                                             | 10-33 |
| 10.4.4  | Output Parameters                                                            | 10-36 |
| 10.5    | SEND Function (OB 202)                                                       | 10-38 |

| Section | Description                                           | Page  |
|---------|-------------------------------------------------------|-------|
| 10.5.1  | Function                                              | 10-38 |
| 10.5.2  | Call Parameters                                       | 10-38 |
| 10.5.3  | Input Parameters                                      | 10-39 |
| 10.5.4  | Output Parameters                                     | 10-41 |
| 10.6    | SEND TEST Function (OB 203)                           | 10-43 |
| 10.6.1  | Function                                              | 10-43 |
| 10.6.2  | Call Parameters                                       | 10-43 |
| 10.6.3  | Input Parameters                                      | 10-43 |
| 10.6.4  | Output Parameters                                     | 10-44 |
| 10.7    | RECEIVE Function (OB 204)                             | 10-45 |
| 10.7.1  | Function                                              | 10-45 |
| 10.7.2  | Call Parameters                                       | 10-45 |
| 10.7.3  | Input Parameters                                      | 10-45 |
| 10.7.4  | Output Parameters                                     | 10-46 |
| 10.8    | RECEIVE TEST Function (OB 205)                        | 10-48 |
| 10.8.1  | Function                                              | 10-48 |
| 10.8.2  | Call Parameters                                       | 10-48 |
| 10.8.3  | Input Parameters                                      | 10-48 |
| 10.8.4  | Output Parameters                                     | 10-49 |
| 10.9    | Applications                                          | 10-50 |
| 10.9.1  | Calling the Special Function OB using Function Blocks | 10-50 |
| 10.9.2  | Transferring Data Blocks                              | 10-58 |
| 10.9.3  | Extending the IPC Flag Area                           | 10-64 |

## 10.1 Multiprocessor Mode

| Definitions of<br>terms                                | You are in multiprocessor mode as soon as you plug in a coordinator module, regardless of how many CPUs or CP/IPs are plugged in.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| When to use the<br>multiprocessor<br>mode              | <ul> <li>If your user program is too large for one CPU and there is not enough memory, distribute your program on several CPUs.</li> <li>When a particular part of your system has to be processed especially fast, separate the appropriate program part from the total program and run it on its own fast CPU.</li> <li>When your system consists of several parts that you can separate easily and control independently, let CPU 1 process system part 1, CPU 2 process system part 2, etc.</li> <li>For more information on multiprocessing, read the information in your system manual. This will help you to decide which CPUs are best suited for your problem.</li> </ul> |
| What<br>communications<br>mechanisms are<br>available? | <ul> <li>"Interprocessor communication flags" are available for cyclic exchange of binary data between CPUs (CPU 948, CPU 946/947, CPU 928B, CPU 928 and CPU 922) or between CPUs and communications processors (CPs).</li> <li>For the eventuation of large externate of data (a.g., entire data blocks) between</li> </ul>                                                                                                                                                                                                                                                                                                                                                       |
|                                                        | • For the exchange of large amounts of data (e.g. entire data blocks) between                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

• For the exchange of large amounts of data (e.g., entire data blocks) between the CPU 948, CPU 946/947, CPU 928B, CPU 928 and CPU 922 you are supported by the "**special functions for multiprocessing**" OB 200 to OB 205 (for more information refer to Section 10.2).

### 10.1.1 Exchanging Data via IPC Flags

| Introduction    | Interprocessor communication (IPC) flags are available for cyclic exchange of binary data. They are used mainly for transmitting information <b>byte by byte</b> .                                                                                                                                                                                                                   |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                 | Data is transferred as follows:                                                                                                                                                                                                                                                                                                                                                      |  |
|                 | $CPU(s)  \leftrightarrow  CPU(s)$                                                                                                                                                                                                                                                                                                                                                    |  |
|                 | $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                                                                                                                                                 |  |
|                 | The system program transfers IPC flags once per cycle. For data transfer between CPUs, the IPC flags are buffered physically on the coordinator.                                                                                                                                                                                                                                     |  |
|                 | IPC flags are bytes that are transferred. You define them in DB 1 for each CPU as IPC input or output flags. If, for example, you have defined flag byte 50 on the CPU 1 as an IPC <b>output</b> flag byte, its signal state is transferred cyclically via the coordinator to the CPU on which the flag byte FY 50 is defined as an IPC <b>input</b> flag byte (see Section 10.1.5). |  |
|                 | <b>Note</b><br>There is <b>no</b> error message when the IPC flag byte exists physically but is<br>only written by one CPU and never read out and vice-versa.                                                                                                                                                                                                                        |  |
| Memory area     | With the CPU 948 the memory area for the IPC flags in the coordinator and the CPs covers the addresses <b>F 200H to F F2FFH</b> . On a CPU/communications processor there are 256 available IPC flag bytes.                                                                                                                                                                          |  |
| Jumper settings | To avoid double assignments you must group the 256 available IPC flag bytes on<br>the COR or CP modules. Fields of 32 bytes can be enabled or disabled (your<br>system manual contains information about setting the jumpers).                                                                                                                                                       |  |

#### Example



Fig. 10-1 Transferring IPC flags in the multiprocessor mode

#### Note

- The only flag bytes that you can specify as IPC flags are the ones enabled on the coordinator or on the CP(s).
- A flag byte that is defined on one or more CPUs as an IPC **input** flag byte must be defined as an IPC **output** flag byte on one other CPU or CP. An **IPC output flag byte** is only allowed on **one CPU**, but this may be used as an IPC input flag in all other CPUs in the rack.
- If you have flag bytes that you have not defined as IPC flags in a CPU, you can use them as normal flags!

#### You cannot use S flags as IPC flags!

| Data exchange<br>between CPUs<br>and<br>communication | If you want to exchange data between one CPU and one CP, you must enable the necessary number of IPC flags on the CP. You have 256 bytes available that you can divide into groups of 32 bytes.                                                                                                                        |
|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| processors                                            | If you want to transfer data from one CPU to several CPs, the areas you enable in the CPs and the coordinator must <b>not overlap</b> , otherwise the same address is assigned twice.                                                                                                                                  |
|                                                       | If you want to use IPC flags <b>simultaneously</b> on the coordinator and in one or<br>more CPs, you must also prevent double addressing as follows:<br>Divide the IPC flags among the coordinator and the CPs in groups of 32 bytes.<br>Remove jumpers on the coordinator to mask the IPC flag bytes that you want to |

use in the CP (refer to the System Manual).

You can define a specific flag byte as an IPC output flag in **one** CPU only. However, you can define a specific flag byte as in IPC input flag in several CPUs.



Fig. 10-2 Example of IPC flag areas on the CPs

| Transmitting IPC<br>flags in<br>multiprocessor<br>operation | the CPU transmits the IPC flags spect<br>the CPU that it can access the S5 bus.<br>The coordinator allocates the bus ena  | ble signal to each CPU in sequence. When a                                                                                                                                                                                                                           |
|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                             |                                                                                                                           | ransmit only <b>one</b> byte. Because of this<br>e groups) IPC flag information can be<br>d with old or incorrect values.                                                                                                                                            |
|                                                             | prevent corruption of data by setting a<br>This parameter uses semaphores to er<br>transferred in groups (see Chapter 7). | at takes up more than one byte, you can<br>a parameter in extended data block DX 0.<br>nsure that all IPC flags specified in DB 1 are<br>While one CPU is transmitting IPC flags,<br>nuse the next CPU has to wait to transmit its<br>is CPU is delayed accordingly. |
| Multiprocessor<br>communication                             |                                                                                                                           | exactly fields of data with a size of max.<br>ving special functions are integrated in                                                                                                                                                                               |
|                                                             | • OB 200: INITIALIZE:                                                                                                     | preassign                                                                                                                                                                                                                                                            |
|                                                             | • OB 202: SEND:                                                                                                           | send a data field                                                                                                                                                                                                                                                    |
|                                                             | • OB 203: SEND TEST:                                                                                                      | test sending capacity                                                                                                                                                                                                                                                |
|                                                             | • OB 204: RECEIVE:                                                                                                        | receive a data field                                                                                                                                                                                                                                                 |
|                                                             | • OB 205: RECEIVE TEST:                                                                                                   | test receiving capacity                                                                                                                                                                                                                                              |

# 10.1.2 I/O Flag Assignment and IPC Flag Assignment in Multiprocessor Mode (DB 1)

Introduction The I/O area of the programmable controller is available only once on the S5 bus. The I/O area encompasses the addresses F000H to FFFFH.

In multiprocessor mode, all CPUs in the programmable controller access this I/O area "simultaneously". To avoid data being overwritten, the I/O area must be divided between the individual CPUs.

For this purpose, you must program **DB 1 for every CPU**. In DB 1 you define the **inputs and outputs** (byte addresses 0 to 127) and **IPC flag inputs and outputs** each CPU is to work with.

If the CPU does not use any I/O or IPC flags, an (empty) DB 1 must still be available in multiprocessor mode.

#### Note

Only the input and output bytes defined in DB 1 will be taken into account during updating of the process I/O image by each CPU.

| Entering or<br>editing DB 1   | • Create/modify DB 1 on the PG using the DB 1 screen form or                                                                                                                   |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               | • by editing DB 1 as a data block on the PG and then transferring it to the CPU.                                                                                               |
|                               | <b>Note</b><br>The CPU evaluates the entered or changed DB 1 only after a cold restart!                                                                                        |
| Using the DB 1<br>screen form | 1. Select the editor for the DB 1 screen form on your PG (refer to Fig. 10-3).                                                                                                 |
|                               | 2. Enter the required values for "digital inputs" etc. as decimal numbers.                                                                                                     |
|                               | 3. Enter the values by pressing the enter key on the PG.<br>The PG then generates DB 1.                                                                                        |
|                               | 4. Transfer DB 1 to the CPU or load it into an EPROM submodule.                                                                                                                |
|                               | <b>Note</b><br>You can specify the timer field length in DX 0 and/or in the DB 1 screen<br>form. We recommend that you specify this parameter only in DX 0 (see<br>Chapter 7). |

#### 10.1.3 How to Create Data Block DB 1

# Example of the DB 1 screen form

| DB 1              | I/O assignment:                               |
|-------------------|-----------------------------------------------|
| Digital inputs:   | , 0, 1, 2, 3, 7, 10, , , , , , , , , , ,      |
| Digital outputs:  | , 0, 2, 4, 12, , , , , , , , , , , , , ,      |
| IPC flag inputs:  | ,50,51,60, , , , , , , , , , , , , , ,        |
| IPC flag outputs: | , 70, 72,100, , , , , , , , , , , , , , , , , |
|                   |                                               |

| Editing DB 1 as a | 1. | Write the DB 1 start ID in data words 0, 1 and 2: |
|-------------------|----|---------------------------------------------------|
| data block        |    |                                                   |

| DW 0: KH = 4D41 | ('M' 'A') |
|-----------------|-----------|
| DW 1: KH = 534B | ('S' 'K') |
| DW 2: KH = 3031 | ('0' '1') |

2. Type in the individual operand areas (from data word 3 onwards). Before each operand area, you must specify an ID. The possible ID words are as follows:

| KH = DE00 |
|-----------|
| KH = DA00 |
| KH = CE00 |
| KH = CA00 |
|           |

After each ID word, use fixed-point format to list the numbers of the inputs and outputs used.

3. Complete the entries with the DB 1 end ID "KH = EEEE" and transfer DB 1 to the CPU.

#### Note

You can make the DB 1 entries in any order. Remember that the process image of the inputs and outputs is updated in the **reverse order** to which you store the **addresses in DB 1** (i.e. the last entry is updated first). Multiple entries of the same bytes (e.g., for test purposes) are possible. The system program makes multiple updates of the process images of bytes that are entered more than once.

## Example of editing DB 1

| DB1 | FD: CPU948ST.S5D                                                   |                              |
|-----|--------------------------------------------------------------------|------------------------------|
| 0:  | KH = 4D41;                                                         | DW 0-2:                      |
| 1:  | KH = 534B;                                                         | Start ID                     |
| 2:  | KH = 3031;                                                         | for DB 1                     |
| 3:  | KH = DEOO;                                                         | ID word for digital inputs   |
| 4:  | KF = +00000;                                                       | Input byte 0                 |
| 5:  | KF = +00001;                                                       | Input byte 1                 |
| 6:  | KF = +00002;                                                       | Input byte 2                 |
| 7:  | KF = +00003;                                                       | Input byte 3                 |
| 8:  | KF = +00007;                                                       | •                            |
| 9:  | KF = +00010;                                                       | Input byte 10                |
| 10: | KH = DA00;                                                         | ID word for digital outputs  |
| 11: | KF = +00000;                                                       | Output byte O                |
| 12: | KF = +00002;                                                       | Output byte 2                |
| 13: | KF = +00004;                                                       | •                            |
| 14: | KF = +00012;                                                       | Output byte 12               |
| 15: | KH = CEOO;                                                         | ID word for IPC flag inputs  |
| 16: | KF = +00050;                                                       | Flag byte 50                 |
| 17: | KF = +00051;                                                       | •                            |
| 18: | KF = +00060;                                                       | Flag byte 60                 |
| 19: | KH = CA00;                                                         | ID word for IPC flag outputs |
| 20: | KF = +00070;                                                       | Flag byte 70                 |
| 21: | KF = +00072;                                                       | •                            |
| 22: | KF = +00100;                                                       | Flag byte 100                |
| 23: | $\mathbf{K}\mathbf{H} = \mathbf{E}\mathbf{E}\mathbf{E}\mathbf{E};$ | End ID                       |
| 24: |                                                                    |                              |

**Entering DB 1** The system program adopts DB 1 during a cold restart. The system program checks to see if the inputs and outputs or IPC flags indicated in DB 1 exist in their corresponding modules. If they are not present there, a DB 1 error causes the CPU to go into the STOP mode and the STOP LED flashes slowly. The CPU no longer processes your program.

After you program DB 1 and the CPU accepts it during a cold restart, the following rules apply:

- Only the inputs and outputs indicated in DB 1 can access peripheral modules via the process images (L.../T... ...IB, ...IW, ...ID, ...QB, ...QW, ...QD operations and logic operations with inputs and outputs). Access to process image addresses not entered in DB 1 cause addressing errors.
- You can **load** peripheral bytes directly by bypassing the process image using the L PY, L PW, L OY, L OW operations for all acknowledging inputs, regardless of entries in DB 1.
- You can **transfer** directly (T PY, T PW) to bytes 0 to 127 only for the outputs indicated in DB 1. This is because the process image is also written to during direct transfer. Writing to I/O addresses not entered in DB 1 causes an addressing error.
- Transfer without a process image : Direct transfer to byte addresses >127 is possible regardless of the entries in DB 1. Direct transfer of byte addresses of the extended I/Os (T OY, T OW) is also possible regardless of the entries in DB 1.

## 10.2 Multiprocessor Communication

| Definition                           | Multiprocessor <b>communication</b> means the exchange of larger amounts of data (data blocks) between CPUs operating in the multiprocessor mode. The COR 923C coordinator is necessary for multiprocessor communication.                                                                                |                                               |  |  |  |  |  |  |
|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|--|--|--|--|--|--|
| Introduction                         | To transfer data blocks, or to be more precise, blocks of data with a maximum length of 64 bytes (= 32 data words), you can use the following special function that are integrated in the CPU:                                                                                                           |                                               |  |  |  |  |  |  |
|                                      | • OB 200: INITIALIZE:                                                                                                                                                                                                                                                                                    | preassign                                     |  |  |  |  |  |  |
|                                      | • OB 202: SEND:                                                                                                                                                                                                                                                                                          | send a field of data                          |  |  |  |  |  |  |
|                                      | • OB 203: SEND TEST:                                                                                                                                                                                                                                                                                     | test sending capacity                         |  |  |  |  |  |  |
|                                      | • OB 204: RECEIVE:                                                                                                                                                                                                                                                                                       | receive a data field                          |  |  |  |  |  |  |
|                                      | • OB 205: RECEIVE TEST:                                                                                                                                                                                                                                                                                  | test receiving capacity                       |  |  |  |  |  |  |
|                                      | The special function OBs, OB 200 and<br>"communication OBs" in the following                                                                                                                                                                                                                             |                                               |  |  |  |  |  |  |
| Required<br>knowledge                | To use these functions, you only require basic knowledge of the STEP 5 programming language and the way in which SIMATIC S5 programmable controllers operate. You can obtain this basic information from the publications listed in "Further Reading".                                                   |                                               |  |  |  |  |  |  |
| Basic sequence                       | To transfer data, you must activate the SEND function on the transmitting CPU and the RECEIVE function on the receiving CPU.                                                                                                                                                                             |                                               |  |  |  |  |  |  |
|                                      | The data words of a DB or DX data block located in the transmitting CPU are transported via the coordinator 923C to the receiving CPU one after the other and written to the DB or DX data block with the same number and under the same data word address; i.e. this represents a "1:1" copy operation. |                                               |  |  |  |  |  |  |
| Length of data<br>fields transferred | The amount of data that can be transfe<br>functions is normally 32 words.<br>If the block length (without header) is<br>data to be transferred is an exception a                                                                                                                                         | not a multiple of 32 words, the last field of |  |  |  |  |  |  |

The data block in the receiving CPU can be longer or shorter than the data block to be sent. It is, however, important that the data words transferred by the SEND function exist in the receiving block; otherwise the RECEIVE function signals an error.

|                   | Data to be sent<br>in the<br>transmitting CPU: | Data received<br>in the<br>receiving CPU: |
|-------------------|------------------------------------------------|-------------------------------------------|
| Data block:       | DB 17                                          | DB 17                                     |
| Data word address | DW 32 to DW 63                                 | DW 32 to DW 63                            |

#### 10.2.1 How the Transmitter and Receiver are Identified

Each field of data exchanged between the CPUs is marked with a number to indicate the source and destination CPU. The CPUs are numbered so that the leftmost CPU has the number 1 and each subsequent CPU to the right has a number increased by 1.



#### 10.2.2 Why Data is Buffered

Generally, the multiprocessor mode is used to distribute tasks on several CPUs. Since the tasks are not identical and the performance of the CPUs involved can be different, the program execution of the individual CPs in the multiprocessor mode is always **asynchronous**. This means that the data sent by a CPU cannot always be received immediately by another CPU.

For this reason, the data to be transferred is buffered on the coordinator 923 C. The number of the CPU executing the task and the number of the sender when receiving and the receiver when sending define the source or the destination of a data field.



### 10.2.3 How the Buffer is Processed and Managed

| Principle       | The buffer is based on the FIFO principle (first in - first out, queue principle).<br>The data is received in the order in which it is sent. This applies to each<br>individual link (identified by the transmitting and receiving CPU) and is<br>independent of other links.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data protection | The buffer is battery-backed; this means that the "automatic warm restart<br>following a power down" is possible without any restrictions. A loss of power<br>during a data transfer does not cause any loss of data in the programmable<br>controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Management      | <ul> <li>The coordinator 923 C has a memory capacity of 48 data fields each with a fixed length of 32 words. The INITIALIZE function assigns these fields to individual CPU links.</li> <li>Each memory field can receive exactly one field of data. The length of the data can be from 1 data word to 32 data words. A data field is entered in a memory field by a SEND function and read out again by a RECEIVE function. The number of memory fields assigned to a link is directly related to the parameters for the transmitting capacity (SEND, SEND TEST function) and receiving capacity (RECEIVE, RECEIVE TEST function).</li> <li>The transmitting capacity indicates how many of the memory fields reserved for a link are free at any particular time.</li> <li>The sum of the transmitting and receiving capacity is always equal to the number of memory fields reserved for a link.</li> </ul> |



# **Summary** Buffering data on the coordinator COR 923C allows the asynchronous operation of transmitting and receiving CPUs and compensates for their different processing speeds.

Since the capacity of the buffer is limited, the receiver should check "often" and "regularly" whether there are data in the buffer (RECEIVE TEST function, receiving capacity > 0) and should attempt to fetch stored data (RECEIVE function). Ideally, the RECEIVE function should be repeated until the receiving capacity is zero. This means that the transmitted data are not buffered for a longer period of time and that the receiver always has the current data. This also means that memory fields remain free (the transmitting capacity is increased) and prevents the sender from being blocked (i.e. when the transmitting capacity is zero).

#### Note

A receiving capacity of zero represents the ideal state (i.e. all transmitted data have been fetched by the receiver), on the other hand a transmitting capacity of zero indicates **incorrect planning**, as follows:

- the SEND function is called too often,
- the RECEIVE function is not called often enough

or

- there are not enough memory fields assigned to the link. The capacity of the buffer is insufficient to compensate temporary imbalances in the frequency with which the CPUs transmit and receive data.

#### 10.2.4 System Start-Up

If you require multiprocessor communication, then all CPUs involved must go through the **same** STOP-RUN transition (= RESTART), i.e. all the CPUs go through a COLD RESTART or all CPUs go through a WARM RESTART.

You must make sure that the restart of at least all the CPUs involved in the communication is **uniform** in the following ways:

- direct operation (front switch, programmer),
- parameter assignment (DX 0)

and/or

• programming (using the special function organization block OB 223 "stop if non-uniform restarts occur in the multiprocessor mode")

COLD RESTART In organization block OB 20 (COLD RESTART) only one CPU must set up the buffer (in the COR 923C) using the INITIALIZE function. Any existing data is lost.
 Following this, i.e. during the RESTART, you can call the SEND, SEND TEST, RECEIVE, RECEIVE TEST functions in the individual CPUs. With appropriate programming, you must make sure that this only occurs after the buffer in the coordinator has been correctly initialized.
 On completion of the RESTART, i.e. in the RUN mode, the user program is processed from the beginning, i.e. from the first operation in OB 1 or FB 0.

**WARM RESTART** You must **not** use the INITIALIZE function in the organization blocks OB 21 (MANUAL WARM RESTART) and OB 22 (AUTOMATIC WARM RESTART). Calling the SEND, SEND TEST, RECEIVE, RECEIVE TEST functions can cause problems (refer to the following sections).

On completion of the WARM RESTART, i.e. in the RUN mode, the user program is not processed from the start, but from the **point at which it was interrupted**. The point of interruption can, for example, be within the SEND function.

| 10.2.5 Calling Co       | ommunication OBs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                         | Proceed as follows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|                         | 1. Call the INITIALIZE functi<br>OB 20 on one CPU.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ion only in the cold restart organization block                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | T, RECEIVE, RECEIVE TEST functions either ram or <b>only</b> within the time-driven program.                                                                                                                                                                                                                                                     |  |  |  |  |  |
| Double call             | boundaries"), and the type of pr<br>handling, e.g. OB 26 for cycle to<br>INITIALIZE, SEND, SEND The<br>interrupted.<br>If a user interface inserted at the<br>functions SEND, SEND TEST,                                                                                                                                                                                                                                                                                                                                                                                          | of parameters in DX 0 ("interrupts at operation<br>rogram execution (WARM RESTART, interrupt<br>time error) it is possible that one of the functions<br>EST, RECEIVE and RECEIVE TEST can be<br>e point of interruption also contains one of the<br>, RECEIVE and RECEIVE TEST <b>an illegal call</b><br>an error is signalled (error number 67, |  |  |  |  |  |
| Parallel<br>processing  | Once you have completed the assignment of the buffer (INITIALIZE function),<br>you can execute the functions SEND, SEND TEST,<br>RECEIVE and RECEIVE TEST in any combination and with any parameter<br>assignment in all the CPUs simultaneously and parallel to each other.<br>Taking a single link (e.g. from CPU 2 to CPU 3) it is possible to execute the<br>SEND function (CPU 2) and the RECEIVE function (CPU 3) simultaneously.<br>While CPU 2 is sending data fields to the coordinator, CPU 3 can already receive<br>(fetch) buffered data fields from the coordinator. |                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| Areas occupied          | The communication OBs do not require a working area (for buffering variables)<br>and do not call data blocks. They do, of course, access areas containing<br>parameters, although only the parameters marked as output parameters are<br>modified.                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| Result bits             | The result bits (CC 1/CC 0, RLO etc.) are influenced by the communication OBs. For more detailed information refer to Section 10.2.8.                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| Changes in the<br>ACCUs | • CPU 922, CPU 928,<br>CPU 928B:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | The contents of ACCU 1 to ACCU 4 and the contents of the registers are not affected by the communication OBs.                                                                                                                                                                                                                                    |  |  |  |  |  |
|                         | • CPU 946/947,<br>CPU 948:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | The contents of all registers and ACCU 1, 2<br>and 3 remain the same, only the contents of<br>ACCU 4 are affected.                                                                                                                                                                                                                               |  |  |  |  |  |

#### 10.2.6 How to Assign Parameters to Communication OBs

The communication OBs have the following types of parameter:

- input parameters,
- output parameters

and

• call parameters.

Input and output parameters are located in a maximum 10 byte long **data field in the F flag area**. The data field is divided into an area for **input parameters** and an area for **output parameters**.

*Input parameters* The input parameters specify how a function is handled. All or part of the parameters are read out by communication OBs and evaluated, no write access takes place.

Output<br/>parametersThe output parameters contain all the information that the calling program needs<br/>about the result of a job, e.g. error bits.<br/>Some or all of the output parameters are written to by the communication OBs,<br/>this area is not read.

#### Note You can assign a flag area with 10 flag bytes for all communications functions. The functions themselves require different numbers of bytes. Refer to the description of the single functions (Sections 10.4 and following).

**Call parameters** For all communication OBs the number of the first flag byte in the data field (= pointer to data field) in ACCU-1-L is transferred as the call parameter. Permitted values are 0 to 246.

Example

```
Data field with parameters for the RECEIVE function
(OB 204)
  FY x + 0: transmitting CPU
                                         input parameter
  FY x + 1:
                                         not used
  FY x + 2: condition code byte
                                         output parameter
  FY x + 3: receiving capacity
                                         output parameter
  FY x + 4: block ID
                                         output parameter
  FY x + 5: block number
                                         output parameter
  FY x + 6: address of the first
                                         output parameter
  FY x + 7: received data word
                                         output parameter
  FY x + 8: address of the last
                                         output parameter
  FY x + 9: received data word
                                         output parameter
```

This example illustrates that the number of the first F flag byte in the data field must not be higher than FY 246, since otherwise the parameter field of up to 10 bytes would exceed the limits of the flag area (FY 255).

#### 10.2.7 How to Evaluate the Output Parameters

Among other things, the output parameters indicate whether or not a function could be executed and if not they indicate the reason for the termination of the function.

**Condition codes** The INITIALIZE, SEND, SEND TEST, RECEIVE and RECEIVE TEST functions affect the condition codes (see programming instructions for your CPUs, general notes on the STEP 5 operations):

- the OV and OS bits (word condition codes) are always cleared,
- the OR, STA, ERAB bits (bit condition codes) are always cleared,
- RLO, CC 1 and CC 0 indicate whether a function has been executed correctly and completely.

| Condition codes |      | Evaluation | Meaning        |                                                                                                                      |  |  |  |
|-----------------|------|------------|----------------|----------------------------------------------------------------------------------------------------------------------|--|--|--|
| RLO             | CC 1 | CC 0       | Lyuuuuion      |                                                                                                                      |  |  |  |
| 0               | 0    | 0          | JC=            | Function executed completely and correctly                                                                           |  |  |  |
| 1               | 0    | 0          | JC=            | Function aborted, pointer to data field<br>illegal (>246)<br>Function aborted owing to an<br>initialization conflict |  |  |  |
| 1               | 0    | 1          | JC= and<br>JM= | Function aborted owing to an error (error number 1 to 9)                                                             |  |  |  |
| 1               | 1    | 0          | JC= and JP=    | Function aborted owing to a warning (warning number 1 or 2)                                                          |  |  |  |

 Table 10-1
 Condition codes of the communication OBs

In the following sections, it is assumed that the pointer to the data field contains a correct value. The first byte of the output parameter provides detailed information about the cause of termination.

| Bit no. | 7 | 6 | 5 | 4 | 3 | 2   | 1    | 0 |
|---------|---|---|---|---|---|-----|------|---|
|         | W | Е | Ι | 0 |   | Nun | nber |   |

| <b>W</b> = 1: | Warning                 |
|---------------|-------------------------|
| E = 1:        | Error                   |
| I = 1:        | Initialization conflict |
| Number:       | - of a warning          |
|               | - of an error           |

- of an initialization conflict

| The firs | t byte in th | e field  | of the  | outpu | it para | ameter  | s (conditio  | on code | byt   | e) also  |  |
|----------|--------------|----------|---------|-------|---------|---------|--------------|---------|-------|----------|--|
| indicate | s whether o  | or not a | functi  | on ha | is bee  | n corr  | ectly and c  | comple  | tely  | executed |  |
| This by  | e contains   | detaile  | d infor | matio | on ab   | out the | e cause of t | termina | ition | ofa      |  |
| function | l <b>.</b>   |          |         |       |         |         |              |         |       |          |  |
|          |              |          | • .     |       | 1.      | C* 1 1  |              |         | 1     |          |  |

Assuming that at least the pointer to the data field contains a correct value, this byte is **always** relevant.

If the function has been executed correctly and completely, all the bits are cleared (= 0), and all other output parameters are relevant.

If the function is aborted with a warning (bit number 7 = 1), only the condition code for the transmitting/receiving capacity is relevant, other output parameters (if they exist) are unchanged.

If the function is aborted owing to an error (bit number 6 = 1) or an initialization conflict (bit number 5 = 1), all other output parameters remain unchanged.

**Evaluation of the code byte** The identifiers 'W', 'E' and 'I' indicate the significance of the numbers. Apart from this bit-by-bit evaluation, it is also possible to interpret the whole condition code byte as a fixed point number without sign. If you interpret the condition code byte as a **byte**, the groups of numbers have the following significance:

| Number group | Significance                                         |  |
|--------------|------------------------------------------------------|--|
| 0            | Function executed correctly and completely           |  |
| 33 to 42     | Function aborted owing to an initialization conflict |  |
| 65 to 73     | Function aborted owing to an error                   |  |
| 129 to 130   | Function aborted owing to a warning                  |  |

 Table 10-2
 Code byte for the communication OBs/number groups

Errors are detected and indicated in the ascending order of the error numbers. This means that several errors may have occurred although (currently) only **one** is indicated. The other errors are then indicated by further calls.

#### Example

The SEND function indicates an error and is not executed. If you then make program and/or parameter modifications and the SEND function again indicates an error with a higher number than previously, you can assume that you have corrected one of several errors.

# InitializationAn initialization conflict can only occur with the INITIALIZATION function. If<br/>a conflict occurs, you must modify the program or the parameters.

Initialization conflict numbers (evaluation of the condition code byte as a byte):

| Cond.<br>code byte | Significance                                                                                                                                                                                                             |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 33                 | The pages required for multiprocessor communication (numbers 252 to 255) are not or not all available.                                                                                                                   |
| 34                 | The pages required for multiprocessor communication (numbers 252 to 255) are defective.                                                                                                                                  |
| 35                 | The parameter "automatic/manual" is illegal. The following errors are possible:<br>- the "automatic/manual" ID is less than 1,<br>- the "automatic/manual" ID is greater than 2.                                         |
| 36                 | The parameter "number of CPUs" is illegal. The following errors are<br>possible:<br>- the number of CPUs is less than 2,<br>- the number of CPUs is greater than 4.                                                      |
| 37                 | The parameter "block ID" is illegal. The following errors are possible:<br>- the block ID is less than 1,<br>- the block ID is greater than 2.                                                                           |
| 38                 | The parameter "block number" is incorrect, since it is a data<br>block with a special significance.<br>The following errors are possible:<br>- if block ID = 1 :DB 0, DB 1, DB 2<br>- if block ID = 2 : DX 0, DX 1, DX 2 |
| 39                 | The parameter "block number " is incorrect, since the data block does not exist.                                                                                                                                         |
| 40                 | The parameter "start address of the assignment list" is too high or the data block is too short.                                                                                                                         |
| 41                 | The assignment list in the data block is not correctly structured.                                                                                                                                                       |
| 42                 | The sum of the assigned memory fields is greater than 48.                                                                                                                                                                |

 Table 10-3
 Condition code byte: Initialization conflict numbers

*Errors* If an error occurs, you must change the program/parameters.

Error numbers (evaluation of the condition code byte as a byte):

| Cond.<br>code byte | Significance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 65                 | <ul> <li>The parameter "receiving CPU" (SEND, SEND TEST) is illegal. The following errors are possible:</li> <li>The number of the receiving CPU is greater than 4.</li> <li>The number of the receiving CPU is less than 1.</li> <li>The number of the receiving CPU is the same as the CPU's own number.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 66                 | <ul> <li>The parameter "transmitting CPU" (RECEIVE, RECEIVE TEST) is illegal.</li> <li>The following errors are possible:</li> <li>The number of the transmitting CPU is greater than 4.</li> <li>the number of the transmitting CPU is less than 1.</li> <li>the number of the transmitting CPU is the same as the CPU's own number.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 67                 | <ul> <li>The special function organization block call is wrong (SEND, RECEIVE, SEND TEST, RECEIVE TEST). The following errors are possible:</li> <li>Secondary error, since the INITIALIZE function could not be called or was terminated by an initialization conflict.</li> <li>Double call: the call for this function (SEND, SEND TEST, RECEIVE or RECEIVE TEST) is illegal, since one of these functions INITIALIZE, SEND, SEND TEST, RECEIVE or RECEIVE TEST, RECEIVE or RECEIVE TEST, RECEIVE or RECEIVE TEST, RECEIVE in a lower processing level (i.e. cyclic program execution).</li> <li>The CPU's own number is incorrect (system data corrupted); following power down/power up the CPU number is generated again by the system program.</li> </ul> |
| 68                 | The management data (queue management) of the selected links are incorrect; set up the buffer in the coordinator 923C again using the INITIALIZE function (SEND, RECEIVE, SEND TEST, RECEIVE TEST).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 69                 | <ul> <li>The parameter "block ID" (SEND) or the block ID provided by the sender (RECEIVE) is illegal. The following errors are possible:</li> <li>The block ID is less than 1.</li> <li>the block ID is greater than 2.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 70                 | <ul> <li>The parameter "block number" (SEND) or the block number supplied by the sender (RECEIVE) is illegal, since it is a data block with a special significance. The following errors are possible:</li> <li>If the block ID = 1 : DB 0, DB 1, DB 2</li> <li>if the block ID = 2 : DX 0, DX 1, DX 2</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 71                 | The parameter "block number" (SEND) or the block number provided by the sender (RECEIVE) is incorrect. The specified data block does not exist.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 72                 | The parameter "field number" (SEND) is incorrect.<br>The data block is too short or the field number too high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 73                 | The data block is not large enough to receive the data field transmitted by the sender (RECEIVE).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

 Table 10-4
 Condition code byte: Error numbers

*Warning* The function could not be executed; the function call must be repeated, e.g. in the next cycle.

Warning numbers (evaluation of the condition code byte as a byte):

| Cond.<br>code byte | Significance                                                                                                           |
|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 129                | The SEND function cannot transfer data, since the transmitting capacity was already zero when the function was called. |
| 130                | The RECEIVE function cannot accept data, since the receiving capacity was already zero when the function was called.   |

 Table 10-5
 Condition code bytes: Warning numbers

## **10.3 Runtimes of the Communication OBs**

The "runtime" is the processing time of the special function organization blocks.

| Special function OB |                                                                               |                                                                               |                                                                                     |
|---------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|
| Block name          | CPU 928                                                                       | CPU 928B                                                                      | CPU 948                                                                             |
| OB 200/initialize   | 104 ms                                                                        | 104 ms                                                                        | 90 ms                                                                               |
| OB 202/send         | 533 μs<br>(200 μs basic time<br>+ 10.5 μs/word);<br>92 μs if a warning occurs | 533 μs<br>(200 μs basic time<br>+ 10.5 μs/word);<br>92 μs if a warning occurs | 542 μs<br>(220 μs basic time<br>+ 19 μs/double word);<br>110 μs if a warning occurs |
| OB 203/send test    | 40 µs                                                                         | 40 µs                                                                         | 115 µs                                                                              |
| OB 204/receive      | 528 μs<br>(195 μs basic time<br>+ 10.5 μs/word);<br>79 μs if a warning occurs | 528 μs<br>(195 μs basic time<br>+ 10.5 μs/word);<br>79 μs if a warning occurs | 506 μs<br>(218 μs basic time<br>+ 18 μs/double word);<br>132 μs if a warning occurs |
| OB 205/receive test | 39 µs                                                                         | 39 µs                                                                         | 120 μs                                                                              |

| Table 10-6 | Runtimes of the | communication OBs |
|------------|-----------------|-------------------|
|            |                 |                   |

The time from calling a block to its termination can be much greater if it is interrupted by higher priority activities (e.g. updating timers, etc.).

The runtimes listed in Table 10-6 assume that of four CPUs inserted in a rack, only the CPU whose runtimes are being measured accesses the SIMATIC S5 bus. If other CPUs use the bus intensively, the runtime increases particularly for the send/receive functions.

**Transfer time** An important factor of a link (e.g. from CPU 1 to CPU 2) is the total data transfer time. This is made up of the following components:

- time required to send (see runtime),
- length of time the data are buffered (on the COR 923C coordinator)

and

• the time required to receive data (see runtime)

The length of time that the data are "in transit" is largely dependent on the length of time that the data is buffered and therefore on the structure of the user program (see "Buffering Data").

### 10.4 INITIALIZE Function (OB 200)

#### 10.4.1 Function

To transfer data from one CPU to another CPU, the data must be temporarily buffered. The INITIALIZE function sets up a buffer on the COR 923C coordinator.

The memory is initialized in fields with a fixed length of 32 words.

Each memory field accepts one data field with a length between 1 data word and 32 data words. A data field is entered in a memory field by a SEND function and read out by a RECEIVE function.

If you are using two CPUs, there are two links (transfer directions, "channels"):



If you are using three CPUs, there are six links:





If you are using four CPUs, there are twelve links:

The INITIALIZE function specifies how the total of **48** available memory fields are assigned to the maximum twelve links.

This means that each possible link, specified by the parameters "transmitting CPU" and "receiving CPU" has a certain memory capacity available.

#### Note

Before you can call the SEND / RECEIVE / SEND TEST / RECEIVE TEST functions, one CPU must have already called the INITIALIZE function and executed it completely and without errors.

If the INITIALIZE function is called several times, one after the other, the last assignment made is valid. While a CPU is processing the INITIALIZE function, no other multiprocessor communication functions including the INITIALIZE function can be called on other CPUs.

#### 10.4.2 Call Parameters

| FY x + 0: Mode (automatic/manual) input parar                                                    | Before calling OB 200, you must supply the input parameters in the data field.<br>OB 200 requires eight F flag bytes in the data field for input and output<br>parameters: |  |  |
|--------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                                                                                  | neter                                                                                                                                                                      |  |  |
| FY $x + 1$ : Number of CPUs input parar                                                          | neter                                                                                                                                                                      |  |  |
| FY x + 2: Block ID input parar                                                                   | neter                                                                                                                                                                      |  |  |
| FY x + 3: Block number input param                                                               | neter                                                                                                                                                                      |  |  |
| FY x + 4:Start address of theinput pararFY x + 5:assignment list                                 | neter                                                                                                                                                                      |  |  |
| FY x + 6: Condition code byte output para                                                        | meter                                                                                                                                                                      |  |  |
| FY x + 7: Total capacity output para                                                             | meter                                                                                                                                                                      |  |  |
| ACCU-1-L When OB 200 is called, you transfer the flag byte number data field begins to ACCU-1-L: | at which the parameter                                                                                                                                                     |  |  |

| ACCU-1-LH: | 0        |
|------------|----------|
| ACCU-1-LL: | 0 to 246 |

#### 10.4.3 Input Parameters

| Mode        | Mode = 1:                                  | automatic                                  |
|-------------|--------------------------------------------|--------------------------------------------|
| (automatic/ | Mode = 2:                                  | manual                                     |
| manual)     | Mode = $0 \text{ or } 3 \text{ to } 255$ : | illegal, causes an initialization conflict |

**Number of CPUs** This parameter is only relevant when you have selected the "automatic" mode. With the "automatic" setting, the memory fields are divided **evenly** according to the number of CPUs.

| Number of CPUs | Number of links                            | Memory fields per link |
|----------------|--------------------------------------------|------------------------|
| 2              | 2                                          | 24                     |
| 3              | 6                                          | 8                      |
| 4              | 12                                         | 4                      |
| 0; 1; 5 to 255 | Illegal, causes an initialization conflict |                        |

#### Block ID, block number, address assignment list

The parameters are only relevant if you select the "manual" mode. You must then create an assignment list in a data block in which the 48 available memory fields (or less) are assigned to the maximum 12 links. This function is particularly useful when some CPUs transfer more data than others.

The CPUs not involved in the multiprocessor communication do not need and should not have memory fields assigned to them. The parameters

- block ID,
- block number

and

• start address of the assignment list

specify where the assignment list is stored.

| Block ID | ID = 1:                  | DB data block                              |
|----------|--------------------------|--------------------------------------------|
|          | ID = 2:                  | DX data block                              |
|          | ID = 0  or  3  to  255 : | illegal, causes an initialization conflict |

| Block number                               | For the block number, you specify the number of the DB or DX data block in which the assignment list is stored.                                                                                                                                                                                                                             |
|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Start address of<br>the assignment<br>list | Along with the block ID and number, this specifies the area (or more precisely, the start address of the area) in the data block in which the assignment list is stored.<br>As the address of the assignment list, specify the data word number at which the assignment list begins in flag bytes FY x+4 (high byte) and FY x+5 (low byte). |
| Assignment list                            | With the assignment list, you specify how many of the existing 48 memory fields are                                                                                                                                                                                                                                                         |

to be assigned to the links.

The list is not changed by the system program. It has the following structure.

| Data word |        | Format | Value | Significance |         |
|-----------|--------|--------|-------|--------------|---------|
| DW        | n + 0  | KS     | S1    | Transmitter  | = CPU 1 |
| DW        | n + 1  | KY     | 2,a   | Receiver     | = CPU 2 |
| DW        | n + 2  | KY     | 3,b   | Receiver     | = CPU 3 |
| DW        | n + 3  | KY     | 4,c   | Receiver     | = CPU 4 |
| DW        | n + 4  | KS     | S2    | Transmitter  | = CPU 2 |
| DW        | n + 5  | KY     | 1,d   | Receiver     | = CPU 1 |
| DW        | n + 6  | KY     | 3,e   | Receiver     | = CPU 3 |
| DW        | n + 7  | KY     | 4,f   | Receiver     | = CPU 4 |
| DW        | n + 8  | KS     | S3    | Transmitter  | = CPU 3 |
| DW        | n + 9  | KY     | 1,g   | Receiver     | = CPU 1 |
| DW        | n + 10 | KY     | 2,h   | Receiver     | = CPU 2 |
| DW        | n + 11 | KY     | 4,i   | Receiver     | = CPU 4 |
| DW        | n + 12 | KS     | S4    | Transmitter  | = CPU 4 |
| DW        | n + 13 | KY     | 1,k   | Receiver     | = CPU 1 |
| DW        | n + 14 | KY     | 2,l   | Receiver     | = CPU 2 |
| DW        | n + 15 | KY     | 3,m   | Receiver     | = CPU 3 |

Table 10-7Assignment list for OB 200 (initialize)

Instead of the lower case letters a to m (in bold face) numbers between 0 and 48 must be inserted depending on the number of assigned memory fields. The sum of these numbers must not exceed 48.

#### Note

You must keep to the structure shown in Table 10-7 even if you have less than four CPUs.

#### Example

You have three CPUs in your rack, CPU 2 sends a lot of data to the other two CPUs. The other two CPUs, however, only send a small amount of data back to CPU 2 as acknowledgements in a logical handshake. There is no data exchange between CPU 1 and CPU 3. The assignment list is stored in data block DB 40 from DW 0 onwards and has the following parameters: DB40 FD: CPU928ST.S5D KS = S1;Transmitter: CPU 1 0: 1: KY = 2,2;Receiver: CPU 2/2 fields Receiver: 2: KY = 3,0;CPU 3/no field Receiver: 3: KY = 4,0;CPU 4 (does not exist)/no field 4: KS = S2;Transmitter: CPU 2 5: KY = 1,22;Receiver: CPU 1/22 fields Receiver: Receiver: CPU 3/22 fields KY = 3, 22;6: KY = 4,0;CPU 4 (does not exist)/no field 7: Transmitter: CPU 3 8: KS = S3;Receiver: CPU 1/no field 9: KY = 1,0;KY = 2, 2;Receiver: CPU 2/2 fields 10: KY = 4,0;CPU 4 (does not exist)/no field 11: Receiver: KS = S4;Transmitter: CPU 4 (does not exist) 12: KY = 1,0;Receiver: CPU 1/no field 13: 14: KY = 2,0;Receiver: CPU 2/no field CPU 3/no field 15: KY = 3,0;Receiver: 16:

# 10.4.4 Output Parameters

| Condition<br>code byte     | This byte informs you whether the INITIALIZE function was executed correctly and completely.                              |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------|
| Initialization<br>conflict | The initialization conflicts listed are recognized and indicated by the function in the ascending order of their numbers. |

If an initialization conflict occurs, you must change the program/parameters.

All the numbers listed in the following table can occur in the condition code byte.

| Cond.<br>code byte | Significance                                                                                                                                                                                                              |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 33                 | The pages required for multiprocessor communication (numbers 252 to 255) are not or not all available.                                                                                                                    |
| 34                 | The pages required for multiprocessor communication (numbers 252 to 255) are defective.                                                                                                                                   |
| 35                 | The parameter "automatic/manual" is illegal.<br>The following errors are possible:<br>- The "automatic/manual" ID is less than 1.<br>- The "automatic/manual" ID is greater than 2.                                       |
| 36                 | <ul> <li>The parameter "number of CPUs" is illegal.</li> <li>The following errors are possible: <ul> <li>The number of CPUs is less than 2.</li> <li>The number of CPUs is greater than 4.</li> </ul> </li> </ul>         |
| 37                 | The parameter "block ID" is illegal.<br>The following errors are possible:<br>- The block ID is less than 1.<br>- The block ID is greater than 2.                                                                         |
| 38                 | The parameter "block number" is incorrect, since it is a data<br>block with a special significance.<br>The following errors are possible:<br>- If block ID = 1 : DB 0, DB 1, DB 2<br>- If block ID = 2 : DX 0, DX 1, DX 2 |
| 39                 | The parameter "block number " is incorrect, since the data block does not exist.                                                                                                                                          |
| 40                 | The parameter "start address of the assignment list" is too high or the data block is too short.                                                                                                                          |
| 41                 | The assignment list in the data block is not correctly structured.                                                                                                                                                        |
| 42                 | The sum of the assigned memory fields is greater than 48.                                                                                                                                                                 |

 Table 10-8
 Condition code byte: warning numbers

| Errors         | The "error" number group cannot occur with the INITIALIZE function.                                                                                                                                                                                                                   |  |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Warning        | The "warning" number group cannot occur with the INITIALIZE function.                                                                                                                                                                                                                 |  |  |
| Total capacity | This parameter specifies how many of the 48 available memory fields are<br>assigned to links.<br>In the "automatic" mode, this parameter always has the value 48. In the "manual"<br>mode, it can have a value less than 48. This means that existing memory capacity is<br>not used. |  |  |

# 10.5 SEND Function (OB 202)

# 10.5.1 Function

The SEND function transfers a data field to the buffer of the COR 923C coordinator. It also indicates how many data fields can still be sent or buffered.

### 10.5.2 Call Parameters

| <i>Structure of the<br/>(parameter) data<br/>field</i> | Before calling OB 202 you must specify the input parameters in the data field.<br>OB 202 requires six F flag bytes in the data field for input and output parameters: |                       |                  |
|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------|
|                                                        | FY x + 0:                                                                                                                                                             | receiving CPU         | input parameter  |
|                                                        | FY x + 1:                                                                                                                                                             | block ID              | input parameter  |
|                                                        | FY x + 2:                                                                                                                                                             | block number          | input parameter  |
|                                                        | FY x + 3:                                                                                                                                                             | field number          | input parameter  |
|                                                        | FY x + 4:                                                                                                                                                             | condition code byte   | output parameter |
|                                                        | FY x + 5:                                                                                                                                                             | transmitting capacity | output parameter |
|                                                        |                                                                                                                                                                       |                       |                  |
|                                                        |                                                                                                                                                                       |                       |                  |

**ACCU-1-L** When OB 202 is called, transfer the flag byte at which the parameter data field begins to ACCU-1-L:

| ACCU-1-LH: | 0        |
|------------|----------|
| ACCU-1-LL: | 0 to 246 |

# 10.5.3 Input Parameters

| Receiving CPU | CPU number of the receiver (destination); the permitted value is between 1 and 4 but must be different from the CPU's own number.                                                                                                                                                                                                                                                                                                                                                                              |                                                                    |  |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--|
| Block ID      | ID = 1:<br>ID = 2:<br>ID = 0 or 3 to 255:                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | DB data block<br>DX data block<br>illegal, causes an error message |  |
| Block number  | The block number, along with the block ID and the field number specifies the area from which the data to be sent is taken (and where it is to be stored in the receiving CPU).<br>Remember that certain data blocks have a special significance, for example, DB 0, DB 1 or DX 0 (see programming instructions for your CPUs). These data blocks must therefore not be used for the data transfer described here!<br>If you attempt to use these block numbers, the function is aborted with an error message. |                                                                    |  |

# *Field number* The field number indicates the area in which the data to be sent is located.

| Field<br>number | Data            | area           |
|-----------------|-----------------|----------------|
|                 | First data word | Last data word |
| 0               | <b>DW</b> 0     | DW 31          |
| 1               | DW 32           | DW 63          |
| 2               | DW 64           | DW 95          |
| 3               | DW 96           | DW 127         |
| 4               | DW 128          | DW 159         |
| 5               | DW 160          | DW 191         |
| 6               | DW 192          | DW 223         |
| 7               | DW 224          | DW 255         |
| 8               | DW 256          | DW 287         |
| 9               | DW 288          | DW 319         |
| :               | :               | :              |
| :               | :               | :              |

The following situations are possible:

## • DB is longer than source area:

If the data block is sufficiently long, you obtain a 32-word long area per field as shown in the table above.

• DB is too short:

If the end of the data block is within the selected field, in the last field an area with a length between 1 and 32 words will be transferred.

• Field is outside the DB:

If the first data word address of a field is not within the length of the data block, the SEND function detects and indicates an error.

## Example

| Data block with a length of 80 words: DW 0 to<br>DW 74, 5 words are required for the block header. |                     |                    |          |
|----------------------------------------------------------------------------------------------------|---------------------|--------------------|----------|
| Field no.:                                                                                         | First<br>data word: | Last<br>data word: | Length:  |
| 0                                                                                                  | DW 0                | DW 31              | 32 words |
| 1                                                                                                  | DW 32               | DW 63              | 32 words |
| 2                                                                                                  | DW 64               | DW 74              | 11 words |
| 3 and                                                                                              |                     |                    |          |
| higher                                                                                             | Incorrect p         | arameter assign    | nment    |
|                                                                                                    |                     |                    |          |
|                                                                                                    |                     |                    |          |

## 10.5.4 Output Parameters

| Condition code<br>byte     | This byte informs you whether the SEND function was executed correctly and completely. |  |
|----------------------------|----------------------------------------------------------------------------------------|--|
| Initialization<br>conflict | Has no significance with the SEND function.                                            |  |
| Errors                     | When the SEND function is called, the following error numbers (evaluation of           |  |

the condition code byte) can occur:

| Condition<br>code byte | Significance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 65                     | <ul> <li>The parameter "receiving CPU" is illegal.</li> <li>The following errors are possible: <ul> <li>The number of the receiving CPU is greater than 4</li> <li>The number of the receiving CPU is less than 1</li> <li>The number of the receiving CPU is the same as the CPU's own number.</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                        |
| 67                     | <ul> <li>The special function organization block call is wrong.</li> <li>The following errors are possible: <ul> <li>Secondary error, since the INITIALIZE function could not be called or was terminated by an initialization conflict.</li> <li>Double call: the call for this function, SEND, SEND TEST, RECEIVE or RECEIVE TEST is illegal, since one of the functions INITIALIZE, SEND, SEND TEST, RECEIVE or RECEIVE or RECEIVE TEST has already been called in this CPU in a lower processing level (e.g. cyclic program processing).</li> <li>The CPU's own number is incorrect (system data corrupted) following power down/power up the CPU number is generated again by the system program.</li> </ul> </li> </ul> |
| 68                     | The management data (queue management) of the selected links are incorrect; set up the buffer in the coordinator 923C again using the INITIALIZE function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 69                     | The parameter "block ID" is illegal.<br>The following errors are possible:<br>- The block ID is less than 1.<br>- The block ID is greater than 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 70                     | The parameter "block number" is illegal, since it is a data block with a special significance. The following errors are possible:<br>- If the block ID = 1 : DB 0, DB 1, DB 2<br>- If the block ID = 2 : DX 0, DX 1, DX 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 71                     | The parameter "block number" is incorrect.<br>The specified data block does not exist.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 72                     | The parameter "field number" is incorrect. The data block is too short or the field number too high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

*Warning* The function could be executed; the function call must be repeated, e.g. in the next cycle.

The following warning numbers (evaluation of the condition code byte) can occur:

| Condition<br>code byte | Significance                                                                                                           |
|------------------------|------------------------------------------------------------------------------------------------------------------------|
| 129                    | The SEND function cannot transfer data, since the transmitting capacity was already zero when the function was called. |

# Transmitting<br/>capacityThe "transmitting capacity" indicates how many data fields can still be sent and<br/>buffered.

# 10.6 SEND TEST Function (OB 203)

# 10.6.1 Function

The SEND TEST function determines the number of free memory fields in the buffer of the COR 923C coordinator. Depending on this number m, the SEND function can be called m times to transfer m data fields.

# 10.6.2 Call Parameters

Structure of the<br/>(parameter) dataBefore calling OB 203, you must specify the input parameters in the data field.OB 203 requires 4 F flag bytes in the data field for input and output parameters:field

| FY x + 0:<br>FY x + 1: | receiving CPU                             | input parameter<br>not used          |
|------------------------|-------------------------------------------|--------------------------------------|
| FY x + 2:<br>FY x + 3: | condition code byte transmitting capacity | output parameter<br>output parameter |

**ACCU-1-L** When OB 203 is called, transfer the flag byte number at which the parameter data field begins to ACCU-1-L:

| ACCU-1-LH: | 0        |
|------------|----------|
| ACCU-1-LL: | 0 to 246 |

# 10.6.3 Input Parameters

**Receiving CPU** The CPU's own number and the number of the receiving CPU identify the link for which the transmitting capacity is determined.

## 10.6.4 Output Parameters

| Condition code<br>byte     | This byte indicates whether the SEND TEST function was executed correctly and completely. |
|----------------------------|-------------------------------------------------------------------------------------------|
| Initialization<br>conflict | Has no significance for the SEND TEST function.                                           |
| Errors                     | When calling the SEND TEST function, the following error numbers (evaluation              |

of the condition code byte) can occur:

Condition Significance code byte 65 The parameter "receiving CPU" is illegal. The following errors are possible: The number of the receiving CPU is greater than 4, The number of the receiving CPU is less than 1, The number of the receiving CPU is the same as the CPU's own number. 67 The special function organization block call is wrong. The following errors are possible: Secondary error, since the INITIALIZE function could not be called or was terminated by an initialization conflict. Double call: the call for this function, SEND, SEND TEST, RECEIVE or RECEIVE TEST is illegal, since one of the functions INITIALIZE, SEND, SEND TEST, RECEIVE or RECEIVE TEST has already been called in this CPU in a lower processing level (e.g. cyclic program processing). The CPU's own number is incorrect (system data corrupted); following power down/power up the CPU number is generated again by the system program. 68 The management data (queue management) of the selected links are incorrect; set up the buffer in the coordinator 923C again using the **INITIALIZE** function.

| Warning                  | The "warning" number group cannot occur with the SEND TEST function.                           |
|--------------------------|------------------------------------------------------------------------------------------------|
| Transmitting<br>capacity | The "transmitting capacity" parameter indicates how many data fields can be sent and buffered. |

# 10.7 RECEIVE Function (OB 204)

## 10.7.1 Function

The RECEIVE function takes a data field from the buffer of the COR 923C coordinator. It also indicates how many data fields are still buffered and can still be received. The RECEIVE function should be called in a loop until all the buffered data

fields have been received.

# 10.7.2 Call Parameters

| Structure of the<br>(parameter) data<br>field | Before calling OB 204, you must specify the input parameters in the data field.<br>OB 204 requires 10 F flag bytes in the data field for input and output parameters: |                                                  |                                                                                                                                          |  |
|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                               | FY x + 0:<br>FY x + 1:                                                                                                                                                | transmitting CPU<br>—                            | input parameter<br>not used                                                                                                              |  |
|                                               |                                                                                                                                                                       |                                                  | output parameter<br>output parameter<br>output parameter<br>output parameter<br>output parameter<br>output parameter<br>output parameter |  |
| ACCU-1-L                                      | field begins to A                                                                                                                                                     | B 204, transfer the flag byte numbe<br>ACCU-1-L: |                                                                                                                                          |  |
|                                               | ACCU-1-LH:<br>ACCU-1-LL:                                                                                                                                              |                                                  | 0<br>0 to 246                                                                                                                            |  |

## 10.7.3 Input Parameters

**Transmitting CPU** The receives block receives data supplied by the transmitting CPU. Specify the number of the transmitting CPU. The permitted value is between 1 and 4, but must be different from the CPU's own number.

# 10.7.4 Output Parameters

| Condition code<br>byte     | This byte informs you whether the RECEIVE function was executed correctly and completely.                        |
|----------------------------|------------------------------------------------------------------------------------------------------------------|
| Initialization<br>conflict | Has no significance with the RECEIVE function.                                                                   |
| Errors                     | When calling the RECEIVE function the following error numbers (evaluation of the condition code byte) can occur: |

| Condition<br>code byte | Significance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 66                     | <ul> <li>The parameter "transmitting CPU" is illegal.</li> <li>The following errors are possible: <ul> <li>The number of the transmitting CPU is greater than 4,</li> <li>The number of the transmitting CPU is less than 1,</li> <li>The number of the transmitting CPU is the same as the CPU's own number.</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                               |
| 67                     | <ul> <li>The special function organization block call is wrong.</li> <li>The following errors are possible: <ul> <li>Secondary error, since the INITIALIZE function could not be called or was terminated by an initialization conflict.</li> <li>Double call: the call for this function, SEND, SEND TEST, RECEIVE or RECEIVE TEST is illegal, since one of the functions INITIALIZE, SEND, SEND TEST, RECEIVE or RECEIVE TEST has already been called in this CPU in a lower processing level (e.g. cyclic program processing).</li> <li>The CPU's own number is incorrect (system data corrupted) following power down/power up the CPU number is generated again by the system program.</li> </ul> </li> </ul> |
| 68                     | The management data (queue management) of the selected links are incorrect; set up the buffer in the coordinator 923C again using the INITIALIZE function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 69                     | <ul> <li>The block identifiers supplied by the transmitter are illegal.</li> <li>The following errors are possible: <ul> <li>The block ID is less than 1.</li> <li>The block ID is greater than 2.</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 70                     | <ul> <li>The block number supplied by the transmitter is illegal, since it is a data block with a special significance. The following errors are possible:</li> <li>If the block ID = 1 : DB 0, DB 1, DB 2</li> <li>If the block ID = 2 : DX 0, DX 1, DX 2</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 71                     | The block number provided by the transmitter is incorrect. The specified data block does not exist.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 73                     | The data block is too small to receive the data field supplied by the transmitter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

*Warning* The function could not be executed; the function call must be repeated, e.g. in the next cycle.

The following warning number (evaluation of the condition code byte) can occur:

|                                               | Condition<br>code byte                                                                                                                                                                                                                                                                                                                      | Significance                                                                                                          |  |
|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|--|
|                                               | 130                                                                                                                                                                                                                                                                                                                                         | The RECEIVE function cannot receive data, since the receiving capacity was already zero when the function was called. |  |
| Receiving<br>capacity                         |                                                                                                                                                                                                                                                                                                                                             | g capacity" parameter indicates how many data fields are still can still be received.                                 |  |
| Block ID:                                     | ID = 1:                                                                                                                                                                                                                                                                                                                                     | DB data block                                                                                                         |  |
|                                               | ID = 2:                                                                                                                                                                                                                                                                                                                                     | DX data block                                                                                                         |  |
|                                               | ID = 0  or  3  to                                                                                                                                                                                                                                                                                                                           | 255: illegal, causes an error message                                                                                 |  |
| Block number                                  | Block number of the DB/DX in which the received data are stored (and from<br>which they are taken by the SEND function in the transmitting CPU).<br>Remember that the receive data blocks must be in a random access memory, using<br>read-only memories (EPROM) might possibly serve a practical purpose for transmit<br>data blocks only. |                                                                                                                       |  |
| Address of the<br>first received<br>data word | Data word number within the DB/DX in which the first transferred/received data word was stored.                                                                                                                                                                                                                                             |                                                                                                                       |  |
| Address of the<br>last received<br>data word  | Data word number within the DB/DX in which the last transferred/received data word was stored.                                                                                                                                                                                                                                              |                                                                                                                       |  |
|                                               | <b>Note</b><br>The difference between the addresses of the first and last data word<br>transferred is a maximum of 31, since a maximum of 32 data words can be<br>transferred per function call.                                                                                                                                            |                                                                                                                       |  |

# 10.8 RECEIVE TEST Function (OB 205)

# 10.8.1 Function

The RECEIVE TEST function determines the number of occupied memory fields in the buffer of the COR 923C coordinator. Depending on this number m, the RECEIVE function can be called m times to receive m data fields.

## 10.8.2 Call Parameters

| Structure of the<br>(parameter)<br>data field | Before calling OB 205, you must specify the input parameters in the data field.<br>OB 205 requires 4 F flag bytes in the data field for input and output parameters |                                                  |                                |
|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|--------------------------------|
|                                               | FY x + 0:                                                                                                                                                           | transmitting CPU                                 | input parameter                |
|                                               | FY x + 1:                                                                                                                                                           | —                                                | not used                       |
|                                               | FY x + 2:                                                                                                                                                           | condition code byte                              | output parameter               |
|                                               | FY x + 3:                                                                                                                                                           | receiving capacity                               | output parameter               |
| ACCU-1-L                                      | When calling field begins to                                                                                                                                        | OB 204, transfer the flag byte numb<br>ACCU-1-L: | er at which the parameter data |
|                                               | ACCU-1-LH:                                                                                                                                                          |                                                  | 0                              |
|                                               | ACCU-1-LL:                                                                                                                                                          |                                                  | 0 to 246                       |

## 10.8.3 Input Parameters

**Transmitting CPU** The CPU's own number and the number of the transmitting CPU identify the link for which the receiving capacity is determined.

# 10.8.4 Output Parameters

| Condition code<br>byte     | <ul> <li>This byte indicates whether the RECEIVE TEST function was executed correctly and completely.</li> <li>Has no significance with the RECEIVE TEST function.</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Initialization<br>conflict |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| Errors                     |                                                                                                                                                                               | the RECEIVE TEST function, the following error numbers the condition code byte) can occur:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|                            | Condition<br>code byte                                                                                                                                                        | Significance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                            | 66                                                                                                                                                                            | <ul> <li>The parameter "transmitting CPU" is illegal.</li> <li>The following errors are possible: <ul> <li>The number of the transmitting CPU is greater than 4.</li> <li>The number of the transmitting CPU is less than 1.</li> <li>The number of the transmitting CPU is the same as the CPU's own number.</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                            | 67                                                                                                                                                                            | <ul> <li>The special function organization block call is wrong.</li> <li>The following errors are possible: <ul> <li>Secondary error, since the INITIALIZE function could not be called or was terminated by an initialization conflict.</li> <li>Double call: the call for this function, SEND, SEND TEST, RECEIVE or RECEIVE TEST is illegal, since one of the functions INITIALIZE, SEND, SEND TEST, RECEIVE or RECEIVE TEST has already been called in this CPU in a lower processing level (e.g. cyclic program processing).</li> <li>The CPU's own number is incorrect (system data corrupted); following power down/power up the CPU number is generated again by the system program.</li> </ul> </li> </ul> |  |  |
|                            | 68                                                                                                                                                                            | The management data (queue management) of the selected links are incorrect; set up the buffer in the coordinator COR 923C again using the INITIALIZE function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |

**Receiving** The "receiving capacity" parameter indicates how many data fields can be received and buffered.

# 10.9 Applications

Based on examples, this section explains how to program multiprocessor communication.

## Note

If you use the function blocks listed below and service interrupts on your CPU (e.g. with OB 2) remember to save the "scratchpad flags" at the start of interrupt servicing and to write them back when the interrupt is completed. This also applies to the setting "interrupts at block boundaries", since the call of the special function organization blocks represents a block boundary.

## 10.9.1 Calling the Special Function OB using Function Blocks

The following five function blocks (FB 200 and FB 202 to FB 205) contain the call for the corresponding special function organization block for multiprocessor communication (OB 200 and OB 202 to OB 205).

The numbers of the function blocks are not fixed and can be changed. The parameters of the special function OBs are transferred as actual parameters when the function blocks are called. The direct call of the special function organization blocks is faster, however, is more difficult to read owing to the absence of formal parameters

| FB no.                                       | FB name  | Function                |  |
|----------------------------------------------|----------|-------------------------|--|
| FB 200         INITIAL         Set up buffer |          | Set up buffer           |  |
| FB 202                                       | SEND     | Send a data field       |  |
| FB 203                                       | SEND-TST | Test sending capacity   |  |
| FB 204                                       | RECEIVE  | Receive a data field    |  |
| FB 205                                       | RECV-TST | Test receiving capacity |  |

The flag area from FY 246 to maximum FY 255 is used by the function blocks as a parameter field for the special function organization blocks.

The exact significance of the input and output parameters is explained in the description of the special function organization blocks.

## Note

The following examples of applications involve finished applications that you can program by copying them.

# Programming function blocks



| Parameter name | Significance                                                                                             | Parameter<br>type | Data<br>type | Parameter field |
|----------------|----------------------------------------------------------------------------------------------------------|-------------------|--------------|-----------------|
| AUMA           | Automatic/manual                                                                                         | Ι                 | BY           | FY 246          |
| NUMC           | Number of CPUs                                                                                           | Ι                 | BY           | FY 247          |
| TNAS           | Type (H byte) and <b>n</b> umber (L byte) of<br>the data block containing the<br><b>as</b> signment list | Ι                 | W            | FW 248          |
| STAS           | Start address of the assignment list                                                                     | Ι                 | W            | FW 250          |
| INIC           | Initialization conflict                                                                                  | Q                 | BY           | FY 252          |
| ТСАР           | Total capacity                                                                                           | Q                 | BY           | FY 253          |
|                |                                                                                                          |                   |              |                 |

Continued on the next page

| FB 20  | FB 200 continued |                                       |   |            |                |  |
|--------|------------------|---------------------------------------|---|------------|----------------|--|
| FB 20  | 00               |                                       |   |            | LEN=45         |  |
| SEGME  | -                | 0000                                  |   |            |                |  |
| NAME : | INITIAL          |                                       |   |            |                |  |
| DECL   | : AUMA           | I/Q/D/B/T/C:                          | I | BI/BY/W/D: | ВҮ             |  |
| DECL   | : NUMC           | I/Q/D/B/T/C:                          | I | BI/BY/W/D: | ВҮ             |  |
| DECL   | : TNAS           | I/Q/D/B/T/C:                          | I | BI/BY/W/D: | W              |  |
| DECL   | :STAS            | I/Q/D/B/T/C:                          | I | BI/BY/W/D: | W              |  |
| DECL   | :INIC            | I/Q/D/B/T/C:                          | Q | BI/BY/W/D: | ВҮ             |  |
| DECL   | :TCAP            | I/Q/D/B/T/C:                          | Q | BI/BY/W/D: | ВУ             |  |
|        |                  |                                       |   |            |                |  |
| 0017   | :L               | =AUMA                                 |   | Automatic  | /manual        |  |
| 0018   | :Т               | FY 246                                |   |            |                |  |
| 0019   | :L               | =NUMC                                 |   | Number of  | CPUs           |  |
| 001A   |                  | FY 247                                |   |            |                |  |
| 001B   |                  | =TNAS DB type, DB no.                 |   |            |                |  |
| 001C   | • –              | FY 248                                |   |            |                |  |
| 001D   |                  | =STAS Start address of the assignment |   |            |                |  |
| 001E   | <b>:</b> T       | FW 250 list                           |   |            |                |  |
| 001F   | :                |                                       |   |            |                |  |
| 0020   | :L               | KB 246                                |   | SF OB:     |                |  |
| 0021   | : JU             | OB 200                                |   | "Initiali: | ze"            |  |
| 0022   | :                |                                       |   |            |                |  |
| 0023   |                  | FY 252                                |   | Initializa | ation conflict |  |
| 0024   |                  | =INIC                                 |   |            |                |  |
|        | • —              |                                       |   | Total capa | acity          |  |
| 0026   |                  | =TCAP                                 |   |            |                |  |
| 0027   | :BE              |                                       |   |            |                |  |
|        |                  |                                       |   |            |                |  |
|        |                  |                                       |   |            |                |  |

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ling a data fie                                                                                                                                                                      | eTq                                                                                                                                                    |                                                               |              |                 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|--------------|-----------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | FB                                                                                                                                                                                   | 202                                                                                                                                                    |                                                               |              |                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                      | SEND                                                                                                                                                   |                                                               |              |                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | (1) — RCI                                                                                                                                                                            | 9U                                                                                                                                                     | ERWA                                                          | (4)          |                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | (2) — TNI                                                                                                                                                                            | DB                                                                                                                                                     | TCAP                                                          | (5)          |                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | (3) — FII                                                                                                                                                                            | 10                                                                                                                                                     |                                                               |              |                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                      |                                                                                                                                                        |                                                               |              |                 |
| Parameter nam                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | e Sig                                                                                                                                                                                | nificance                                                                                                                                              | Parameter<br>type                                             | Data<br>type | Parameter field |
| RCPU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Receiving CPU                                                                                                                                                                        |                                                                                                                                                        | I                                                             | BY           | FY 246          |
| TNDB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Type (H byte) and<br>of the source data                                                                                                                                              | d <b>n</b> umber (L byte)<br>block                                                                                                                     | I                                                             | W            | FW 247          |
| FINO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Field number                                                                                                                                                                         |                                                                                                                                                        | Ι                                                             | BY           | FY 249          |
| ERWA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Error/warning                                                                                                                                                                        |                                                                                                                                                        | Q                                                             | BY           | FY 250          |
| TCAP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                      |                                                                                                                                                        |                                                               | BY           | FY 251          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                      | •                                                                                                                                                      | Q                                                             | 21           |                 |
| FB 202                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                      | ·                                                                                                                                                      |                                                               | LEN=4        | 40              |
| SEGMENT 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0000                                                                                                                                                                                 | -<br>                                                                                                                                                  |                                                               |              | 40              |
| SEGMENT 1<br>NAME:SEND<br>DECL:RCPU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0000<br>I/Q/D/B/T/C:                                                                                                                                                                 | I BI/BY/W/D:                                                                                                                                           | BY                                                            |              | 40              |
| SEGMENT 1<br>NAME:SEND<br>DECL:RCPU<br>DECL:TNDB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0000<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:                                                                                                                                                 | I BI/BY/W/D:<br>I BI/BY/W/D:                                                                                                                           | BY<br>W                                                       |              | 40              |
| SEGMENT 1<br>NAME:SEND<br>DECL:RCPU<br>DECL:TNDB<br>DECL:FINO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0000<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:                                                                                                                                 | I BI/BY/W/D:<br>I BI/BY/W/D:<br>I BI/BY/W/D:                                                                                                           | BY<br>W<br>By                                                 |              | 40              |
| SEGMENT 1<br>NAME:SEND<br>DECL:RCPU<br>DECL:TNDB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0000<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:                                                                                                                 | I BI/BY/W/D:<br>I BI/BY/W/D:<br>I BI/BY/W/D:<br>Q BI/BY/W/D:                                                                                           | BY<br>W                                                       |              | 40              |
| SEGMENT 1<br>NAME:SEND<br>DECL:RCPU<br>DECL:TNDB<br>DECL:FINO<br>DECL:ERWA<br>DECL:TCAP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0000<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>=RCPU                                                                                        | I BI/BY/W/D:<br>I BI/BY/W/D:<br>I BI/BY/W/D:<br>Q BI/BY/W/D:                                                                                           | ВҮ<br>W<br>ВҮ<br>ВҮ<br>ВУ                                     |              | 40              |
| SEGMENT 1<br>NAME:SEND<br>DECL:RCPU<br>DECL:TNDB<br>DECL:FINO<br>DECL:ERWA<br>DECL:TCAP<br>0014 :L<br>0015 :T                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0000<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>=RCPU<br>FY 246                                                                              | I BI/BY/W/D:<br>I BI/BY/W/D:<br>I BI/BY/W/D:<br>Q BI/BY/W/D:<br>Q BI/BY/W/D:<br>Receiving                                                              | BY<br>W<br>BY<br>BY<br>BY                                     |              | 40              |
| SEGMENT 1<br>NAME:SEND<br>DECL:RCPU<br>DECL:TNDB<br>DECL:FINO<br>DECL:ERWA<br>DECL:TCAP<br>0014 :L<br>0015 :T<br>0016 :L                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0000<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>=RCPU                                                                                        | I BI/BY/W/D:<br>I BI/BY/W/D:<br>I BI/BY/W/D:<br>Q BI/BY/W/D:<br>Q BI/BY/W/D:                                                                           | BY<br>W<br>BY<br>BY<br>BY                                     |              | 40              |
| SEGMENT 1<br>NAME:SEND<br>DECL:RCPU<br>DECL:FIND<br>DECL:FINO<br>DECL:ERWA<br>DECL:TCAP<br>0014 :L<br>0015 :T<br>0016 :L<br>0017 :T<br>0018 :L                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0000<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>=RCPU<br>FY 246<br>=TNDB<br>FW 247<br>=FINO                                                  | I BI/BY/W/D:<br>I BI/BY/W/D:<br>I BI/BY/W/D:<br>Q BI/BY/W/D:<br>Q BI/BY/W/D:<br>Receiving                                                              | BY<br>W<br>BY<br>BY<br>BY<br>G CPU<br>DB no.                  |              | 40              |
| SEGMENT 1         NAME:SEND         DECL:RCPU         DECL:TNDB         DECL:FINO         DECL:FINO         DECL:FINO         DECL:TCAP         0014:L         0015:T         0016:L         0017:T         0018:L         0019:T                                                                                                                                                                                                                                                                                                                                                   | 0000<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>=RCPU<br>FY 246<br>=TNDB<br>FW 247                                                           | I BI/BY/W/D:<br>I BI/BY/W/D:<br>I BI/BY/W/D:<br>Q BI/BY/W/D:<br>Q BI/BY/W/D:<br>Receiving<br>DB type,                                                  | BY<br>W<br>BY<br>BY<br>BY<br>G CPU<br>DB no.                  |              | 40              |
| SEGMENT 1         NAME:SEND         DECL:RCPU         DECL:TNDB         DECL:FINO         DECL:FINO         DECL:FINO         DECL:TCAP         0014         D015         D016         D017         D018         D019         D01A                                                                                                                                                                                                                                                                                                                                                  | 0000<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>=RCPU<br>FY 246<br>=TNDB<br>FW 247<br>=FINO<br>FY 249                                        | I BI/BY/W/D:<br>I BI/BY/W/D:<br>I BI/BY/W/D:<br>Q BI/BY/W/D:<br>Q BI/BY/W/D:<br>Receiving<br>DB type,<br>Field nu                                      | BY<br>W<br>BY<br>BY<br>BY<br>G CPU<br>DB no.                  |              | 40              |
| SEGMENT 1         NAME:SEND         DECL:RCPU         DECL:TNDB         DECL:FINO         DECL:FINO         DECL:FINO         DECL:TCAP         0014         D015         D016         D017         D018         D019         D018         D018         D018         D018                                                                                                                                                                                                                                                                                                           | 0000<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>=RCPU<br>FY 246<br>=TNDB<br>FW 247<br>=FINO<br>FY 249<br>KB 246                              | I BI/BY/W/D:<br>I BI/BY/W/D:<br>I BI/BY/W/D:<br>Q BI/BY/W/D:<br>Q BI/BY/W/D:<br>Receiving<br>DB type,<br>Field num<br>SF OB:                           | BY<br>W<br>BY<br>BY<br>BY<br>G CPU<br>DB no.                  | LEN=4        | 40              |
| SEGMENT 1         NAME:SEND         DECL:RCPU         DECL:TNDB         DECL:FINO         DECL:FINO         DECL:FINO         DECL:TCAP         0014         D015         D016         D018         D019         D01A         D01A         D01B                                                                                                                                                                                                                                                                                                                                     | 0000<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>=RCPU<br>FY 246<br>=TNDB<br>FW 247<br>=FINO<br>FY 249                                        | I BI/BY/W/D:<br>I BI/BY/W/D:<br>I BI/BY/W/D:<br>Q BI/BY/W/D:<br>Q BI/BY/W/D:<br>Receiving<br>DB type,<br>Field num<br>SF OB:                           | BY<br>W<br>BY<br>BY<br>BY<br>DB no.<br>nber                   | LEN=4        | 40              |
| SEGMENT 1         NAME:SEND         DECL:RCPU         DECL:TNDB         DECL:FINO         DECL:FINO         DECL:TCAP         0014         D015         D016         D018         D018         D018         D018         D011         D012         D013         D014         L         D017         D018         L         D018         L         D0101         D011         D012         D011                                                                                                                                                                                      | 0000<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>=RCPU<br>FY 246<br>=TNDB<br>FW 247<br>=FIN0<br>FY 249<br>KB 246<br>OB 202<br>FY 250          | I BI/BY/W/D:<br>I BI/BY/W/D:<br>I BI/BY/W/D:<br>Q BI/BY/W/D:<br>Q BI/BY/W/D:<br>Receiving<br>DB type,<br>Field num<br>SF OB:                           | BY<br>W<br>BY<br>BY<br>g CPU<br>DB no.<br>mber<br>data field" | LEN=4        | 40              |
| SEGMENT 1         NAME:SEND         DECL:RCPU         DECL:TNDB         DECL:FINO         DECL:FINO         DECL:TCAP         D014         D015         D016         D018         D018         D018         D018         D011         D012         D013         D014         L         D017         D018         L         D018         L         D011         D012         D011         D012         D014                                                                                                                                                                          | 0000<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>=RCPU<br>FY 246<br>=TNDB<br>FW 247<br>=FIN0<br>FY 249<br>KB 246<br>OB 202<br>FY 250<br>=ERWA | I BI/BY/W/D:<br>I BI/BY/W/D:<br>I BI/BY/W/D:<br>Q BI/BY/W/D:<br>Q BI/BY/W/D:<br>Receiving<br>DB type,<br>Field num<br>SF OB:<br>"Send a d<br>Error/wa: | BY<br>W<br>BY<br>BY<br>DB no.<br>mber<br>data field"          | LEN=4        | 40              |
| SEGMENT 1         NAME:SEND         DECL:RCPU         DECL:TNDB         DECL:FINO         DECL:FINO         DECL:TCAP         D014         D015         D016         D018         D018         D018         D018         D011         D012         D013         D014         L         D017         D018         L         D018         L         D011         D012         D011         D011 | 0000<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>I/Q/D/B/T/C:<br>=RCPU<br>FY 246<br>=TNDB<br>FW 247<br>=FIN0<br>FY 249<br>KB 246<br>OB 202<br>FY 250          | I BI/BY/W/D:<br>I BI/BY/W/D:<br>I BI/BY/W/D:<br>Q BI/BY/W/D:<br>Q BI/BY/W/D:<br>Receiving<br>DB type,<br>Field num<br>SF OB:<br>"Send a d<br>Error/wa: | BY<br>W<br>BY<br>BY<br>g CPU<br>DB no.<br>mber<br>data field" | LEN=4        | 40              |

| FB 203: Test                                                                                                                                                                  | ing the tr                                                                                                              |                    |                                                                     |                                         |              |                 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--------------------|---------------------------------------------------------------------|-----------------------------------------|--------------|-----------------|
|                                                                                                                                                                               |                                                                                                                         | FB 203             |                                                                     |                                         |              |                 |
|                                                                                                                                                                               |                                                                                                                         |                    | SEND-TST                                                            |                                         |              |                 |
|                                                                                                                                                                               | (1)                                                                                                                     | RCPU               |                                                                     | ERRO                                    | (2)          |                 |
|                                                                                                                                                                               |                                                                                                                         |                    |                                                                     |                                         |              |                 |
|                                                                                                                                                                               |                                                                                                                         |                    |                                                                     | TCAP                                    | (3)          |                 |
|                                                                                                                                                                               |                                                                                                                         |                    |                                                                     |                                         |              |                 |
| Parameter name                                                                                                                                                                |                                                                                                                         | Significa          | nce                                                                 | Parameter<br>type                       | Data<br>type | Parameter field |
| RCPU                                                                                                                                                                          | Receiving C                                                                                                             | PU                 |                                                                     | Ι                                       | BY           | FY 246          |
| ERRO                                                                                                                                                                          | Error                                                                                                                   |                    |                                                                     | Q                                       | BY           | FY 248          |
|                                                                                                                                                                               |                                                                                                                         |                    |                                                                     | 1 1                                     |              |                 |
| ТСАР                                                                                                                                                                          | Transmitting                                                                                                            | g <b>cap</b> acity |                                                                     | Q                                       | BY           | FY 249          |
| ТСАР<br><b>FB 203</b>                                                                                                                                                         | Transmitting                                                                                                            | g <b>cap</b> acity |                                                                     | Q                                       | BY<br>LEN=   |                 |
| FB 203                                                                                                                                                                        |                                                                                                                         | g <b>cap</b> acity |                                                                     | Q                                       |              |                 |
|                                                                                                                                                                               | 0000                                                                                                                    | g <b>cap</b> acity |                                                                     | Q                                       |              |                 |
| FB 203<br>SEGMENT 1<br>NAME:SEND-TS<br>DECL :RCPU                                                                                                                             | 0000<br>T<br>I/Q/D/B/T,                                                                                                 | /C: I              | BI/BY/W/D:                                                          | ВҮ                                      |              |                 |
| FB 203<br>SEGMENT 1<br>NAME:SEND-TS<br>DECL :RCPU<br>DECL :ERRO                                                                                                               | 0000<br>T                                                                                                               | /C: I<br>/C: Q     | BI/BY/W/D:<br>BI/BY/W/D:<br>BI/BY/W/D:                              | BY<br>BY                                |              |                 |
| FB 203<br>SEGMENT 1<br>NAME:SEND-TS'<br>DECL :RCPU<br>DECL :ERRO<br>DECL :TCAP<br>000E :L                                                                                     | 0000<br>T<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>=RCPU                                                            | /C: I<br>/C: Q     | BI/BY/W/D:                                                          | BY<br>BY<br>BY                          |              |                 |
| FB 203<br>SEGMENT 1<br>NAME:SEND-TS<br>DECL :RCPU<br>DECL :ERRO<br>DECL :TCAP<br>000E :L<br>000F :T                                                                           | 0000<br>T<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>I/Q/D/B/T,                                                                     | /C: I<br>/C: Q     | BI/BY/W/D:<br>BI/BY/W/D:                                            | BY<br>BY<br>BY                          |              |                 |
| FB 203<br>SEGMENT 1<br>NAME:SEND-TS<br>DECL :RCPU<br>DECL :ERRO<br>DECL :TCAP<br>000E :L<br>000F :T<br>0010 :                                                                 | 0000<br>T<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>=RCPU<br>FY 246                                                  | /C: I<br>/C: Q     | BI/BY/W/D:<br>BI/BY/W/D:<br>Receivin                                | BY<br>BY<br>BY                          |              |                 |
| FB 203<br>SEGMENT 1<br>NAME:SEND-TS<br>DECL:RCPU<br>DECL:ERRO<br>DECL:TCAP<br>000E :L<br>000F :T<br>0010 :<br>0011 :L                                                         | 0000<br>T<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>=RCPU<br>FY 246<br>KB 246                                        | /C: I<br>/C: Q     | BI/BY/W/D:<br>BI/BY/W/D:<br>Receivin<br>SF OB:                      | BY<br>BY<br>BY<br>ng CPU                | len=:        | 30              |
| FB 203<br>SEGMENT 1<br>NAME:SEND-TS<br>DECL:RCPU<br>DECL:ERRO<br>DECL:TCAP<br>000E :L<br>000F :T<br>0010 :<br>0011 :L                                                         | 0000<br>T<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>=RCPU<br>FY 246                                                  | /C: I<br>/C: Q     | BI/BY/W/D:<br>BI/BY/W/D:<br>Receivin<br>SF OB:                      | BY<br>BY<br>BY                          | len=:        | 30              |
| FB 203<br>SEGMENT 1<br>NAME:SEND-TS<br>DECL:RCPU<br>DECL:ERRO<br>DECL:TCAP<br>000F :L<br>000F :T<br>0010 :<br>0011 :L<br>0012 :JU<br>0013 :<br>0014 :L                        | 0000<br>T<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>=RCPU<br>FY 246<br>KB 246<br>OB 203<br>FY 248                    | /C: I<br>/C: Q     | BI/BY/W/D:<br>BI/BY/W/D:<br>Receivin<br>SF OB:                      | BY<br>BY<br>BY<br>ng CPU                | len=:        | 30              |
| FB 203<br>SEGMENT 1<br>NAME:SEND-TS<br>DECL:RCPU<br>DECL:ERRO<br>DECL:TCAP<br>000F :L<br>000F :T<br>0010 :<br>0011 :L<br>0012 :JU<br>0013 :<br>0014 :L<br>0015 :T             | 0000<br>T<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>=RCPU<br>FY 246<br>KB 246<br>OB 203<br>FY 248<br>=ERRO           | /C: I<br>/C: Q     | BI/BY/W/D:<br>BI/BY/W/D:<br>Receivin<br>SF OB:<br>"Test th<br>Error | BY<br>BY<br>BY<br>ng CPU<br>ransmitting | LEN=         | 30              |
| FB 203<br>SEGMENT 1<br>NAME:SEND-TS'<br>DECL:RCPU<br>DECL:ERRO<br>DECL:TCAP<br>000F :L<br>000F :T<br>0010 :<br>0011 :L<br>0012 :JU<br>0013 :<br>0014 :L<br>0015 :T<br>0016 :L | 0000<br>T<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>=RCPU<br>FY 246<br>KB 246<br>OB 203<br>FY 248<br>=ERRO<br>FY 249 | /C: I<br>/C: Q     | BI/BY/W/D:<br>BI/BY/W/D:<br>Receivin<br>SF OB:<br>"Test th<br>Error | BY<br>BY<br>BY<br>ng CPU                | LEN=         | 30              |
| FB 203<br>SEGMENT 1<br>NAME:SEND-TS'<br>DECL:RCPU<br>DECL:ERRO<br>DECL:TCAP<br>000F :L<br>000F :T<br>0010 :<br>0011 :L<br>0012 :JU<br>0013 :<br>0014 :L<br>0015 :T<br>0016 :L | 0000<br>T<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>I/Q/D/B/T,<br>=RCPU<br>FY 246<br>KB 246<br>OB 203<br>FY 248<br>=ERRO           | /C: I<br>/C: Q     | BI/BY/W/D:<br>BI/BY/W/D:<br>Receivin<br>SF OB:<br>"Test th<br>Error | BY<br>BY<br>BY<br>ng CPU<br>ransmitting | LEN=         | 30              |



| Parameter name | Significance                                                    | Parameter<br>type | Data<br>type | Parameter<br>field |
|----------------|-----------------------------------------------------------------|-------------------|--------------|--------------------|
| TCPU           | Transmitting CPU                                                | I                 | BY           | FY 246             |
| ERWA           | Error/warning                                                   | Q                 | BY           | FY 248             |
| RCAP           | Receiving capacity                                              | Q                 | BY           | FY 249             |
| TNDB           | Type (H byte) and number (L byte) of the destination data block | Q                 | W            | FW 250             |
| STAA           | Address of the first received data word (start address)         | Q                 | W            | FW 252             |
| ENDA           | Address of the last received data word (end address)            | Q                 | W            | FW 254             |

Continued on the next page

| FB 204 cont  | tinued:        |                        |
|--------------|----------------|------------------------|
| FB 204       |                | LEN=45                 |
| SEGMENT 1    | 0000           |                        |
| NAME: RECEIV | VE             |                        |
| DECL :TCPU   | I/Q/D/B/T/C: I | BI/BY/W/D: BY          |
| DECL :ERWA   | I/Q/D/B/T/C: Q | BI/BY/W/D: BY          |
| DECL :RCAP   | I/Q/D/B/T/C: Q | BI/BY/W/D: BY          |
| DECL : TNDB  | I/Q/D/B/T/C: Q | BI/BY/W/D: W           |
| DECL :STAA   | I/Q/D/B/T/C: Q | BI/BY/W/D: W           |
| DECL : ENDA  | I/Q/D/B/T/C: Q | BI/BY/W/D: W           |
|              |                |                        |
| 0017 :L      | =TCPU          | Transmitting CPU       |
|              | FY 246         |                        |
| 0019 :       |                |                        |
| 001A :L      | KB 246         | SF OB:                 |
| 001B :JU     | OB 204         | "Receive a data field" |
| 001C :       |                |                        |
|              | FY 248         | Error/warning          |
|              | =ERWA          |                        |
|              | FY 249         | Receiving capacity     |
|              | =RCAP          |                        |
|              | FW 250         | DB type, DB no.        |
| 0022 :Т      | =TNDB          |                        |
|              | FW 252         | Start address          |
|              | =STAA          |                        |
|              | FW 254         | End address            |
| 0026 :Т      | =ENDA          |                        |
| 0027 :BE     |                |                        |
|              |                |                        |

| FB 205: Testi              | ng the rec   | eiving  | capacity      |                   |                |                    |
|----------------------------|--------------|---------|---------------|-------------------|----------------|--------------------|
|                            |              | FB 205  | 5             |                   |                |                    |
|                            |              |         | RECV-TST      |                   |                |                    |
|                            |              |         | RECV-151      |                   |                |                    |
|                            | (1)          | TCPU    |               | ERRO              | (2)            |                    |
|                            |              |         |               | RCAP              | (3)            |                    |
|                            |              |         |               | KOM               | (3)            |                    |
|                            |              |         |               |                   |                |                    |
|                            | 1            |         |               | 1                 | -              |                    |
| Parameter name             | e            | Signi   | ficance       | Parameter<br>type | r Data<br>type | Parameter<br>field |
| ТСРИ                       | Transmitting | g CPU   |               | I                 | BY             | FY 246             |
| ERRO                       | Error        |         |               | Q                 | BY             | FY 248             |
| RCAP                       | Receiving ca | apacity |               | Q                 | BY             | FY 249             |
|                            |              |         |               |                   |                |                    |
| FB 205                     |              |         |               |                   | LEN=3          | D                  |
| SEGMENT 1                  | 0000         |         |               |                   |                |                    |
| NAME:RECV-TS<br>DECL :TCPU |              | /c. T   | BI/BY/W/D: BY |                   |                |                    |
| DECL :ERRO                 |              |         | BI/BY/W/D: BY |                   |                |                    |
| DECL :RCAP                 | I/Q/D/B/T    |         | BI/BY/W/D: BY |                   |                |                    |
| 000E :L                    | =TCPU        |         | Transmitting  | CPU               |                |                    |
| 000F :T                    | FY 246       |         | 5             |                   |                |                    |
| 0010 :                     |              |         |               |                   |                |                    |
| 0011 :L                    | KB 246       |         | SF OB:        |                   |                |                    |
| 0012 :JU                   | OB 205       |         | "Test         | : receiv          | ing capac      | ity"               |
| 0013 :                     |              |         |               |                   |                |                    |
| 0014 :L                    | FY 248       |         | Error         |                   |                |                    |
| 0015 :Т                    | =ERRO        |         |               |                   |                |                    |
|                            | FY 249       |         | Receiving cap | pacity            |                |                    |
| 0017 :T                    | =RCAP        |         |               |                   |                |                    |
| 0018 :BE                   |              |         |               |                   |                |                    |
|                            |              |         |               |                   |                |                    |
|                            |              |         |               |                   |                |                    |

## 10.9.2 Transferring Data Blocks

In this example, the function block TRAN DAT (FB 110) transfers a selectable number of data fields from a data block in one CPU to the data block of the same type and same number in a different CPU.

The FB number (FB 110) has been selected at random and you can use other numbers.

Programming FB 110 is described first followed by the application of FB 110.

### Programming FB 110

#### **FB 110: Transferring a data block**

#### <u>Task</u>

The data area to be transferred is stipulated by the input parameter FIRB (= number of the first data field to be transferred) and NUMB (= number of data fields to be transferred). A data field normally consists of 32 data words. Depending on the data block length, the last data field may be less than 32 data words.

The transfer is triggered by a positive-going edge at the start input STAR. If the output parameter REST is zero after the transfer, this means that the function block TRANDAT was able to send all the data fields (according to the NUMB parameter).

If, however, the REST output parameter has a value greater than zero, this means that the function block must be called again, for example in the next cycle. This means that you or the user program can only change the set parameters (i.e. the values of all parameters) when the REST parameter indicates zero showing that the data transfer is complete.

You can call the function block TRANDAT several times with different parameters. In this case, various data areas are transferred simultaneously (interleaved in each other). The special function organization blocks for multiprocessor communication OB 202 to OB 205 can also be used "directly". This possibly is illustrated in the application example.

If the SEND function (OB 202) is not correctly executed with the TRANDAT function block, the error number is entered in the output parameter ERRO, the RLO = '1' and the output parameter REST is set to '0'.

The TRANDAT function block uses flag bytes FY 246 to FY 251 as scratchpad flags. All other variables whose value is significant as long as the output parameter REST = '0' continue to have memory assigned to them using the mechanism of formal/actual parameters. This is necessary to allow various data blocks to be transferred simultaneously.

| Implementation                                                                                            | <u>n</u> FE              | 110                |                          |                  |          |                   |              |
|-----------------------------------------------------------------------------------------------------------|--------------------------|--------------------|--------------------------|------------------|----------|-------------------|--------------|
|                                                                                                           |                          |                    | TRAN-DAT                 |                  |          |                   |              |
|                                                                                                           | (1) —                    | STAR               |                          | ERRO             | (6)      | ,                 |              |
|                                                                                                           | (2)——                    | RCPU               |                          | REST             | (7)      |                   |              |
|                                                                                                           | (3)——                    | TNDB               |                          | CUBN             |          |                   |              |
|                                                                                                           |                          |                    |                          |                  | (8)      |                   |              |
|                                                                                                           | (4)——                    | NUMB               |                          | EDGF             | (9)      | )                 |              |
|                                                                                                           | (5)——                    | FIRB               |                          |                  |          |                   |              |
| Parameter name                                                                                            |                          |                    | Significance             |                  | ]        | Parameter<br>type | Data<br>type |
| STAR                                                                                                      | Start the tra            | nsfer of th        | e data block on a j      | positive-going e | dge      | I                 | BI           |
| RCPU                                                                                                      | Receiving C              | PU                 |                          |                  |          | Ι                 | BY           |
| TNDB                                                                                                      | Type (H byt transferred. | e) and <b>n</b> ur | mber (L byte) of th      | e data block to  | be       | Ι                 | w            |
| NUMB                                                                                                      |                          | ata fields         | to be transferred.       |                  |          | Ι                 | BY           |
| FIRB                                                                                                      | Number of t              | ne first da        | ta field to be trans     | ferred.          |          | Ι                 | BY           |
| ERRO                                                                                                      | Error                    |                    |                          |                  |          | Q                 | BY           |
| REST                                                                                                      | Number of c              | ata fields         | still to be transfer     | ed.              |          | Q                 | BY           |
| CUBN <sup>1)</sup>                                                                                        | Current field            | l <b>n</b> umber   |                          |                  |          | Q                 | BY           |
| EDGF <sup>1)</sup>                                                                                        | Edge flag                |                    |                          |                  |          | Q                 | BI           |
| <ul> <li><sup>1)</sup> Internal scratchpad fl</li> <li><b>FB</b> 110</li> <li><b>SEGMENT</b> 1</li> </ul> | ag, not intended<br>0000 | for evalua         | tion                     |                  | LEN      | <b>I=8</b> 9      |              |
| NAME : TRAN-DAT                                                                                           |                          |                    | ( ( (-                   |                  |          |                   |              |
|                                                                                                           | [/Q/D/B/T/<br>[/Q/D/B/T/ |                    | BI/BY/W/D:<br>BI/BY/W/D: |                  |          |                   |              |
| DECL : TNDB 1                                                                                             | /Q/D/B/T/                | с: і               | BI/BY/W/D:               | W                |          |                   |              |
|                                                                                                           | /Q/D/B/T/                |                    | BI/BY/W/D:               |                  |          |                   |              |
|                                                                                                           | [/Q/D/B/T/               |                    | BI/BY/W/D:               |                  |          |                   |              |
|                                                                                                           | [/Q/D/B/T/<br>[/Q/D/B/T/ |                    | BI/BY/W/D:<br>BI/BY/W/D: |                  |          |                   |              |
|                                                                                                           | [/Q/D/B/T/<br>[/Q/D/B/T/ |                    |                          |                  |          |                   |              |
|                                                                                                           | (/Q/D/B/T/               |                    | BI/BY/W/D:               |                  |          |                   |              |
| 0020 :L =                                                                                                 | RCPU                     |                    |                          | Assign par       | ameter f | ield for          |              |
|                                                                                                           | Y 246                    |                    |                          | SF OB 202        |          |                   |              |
|                                                                                                           | TNDB                     |                    |                          |                  |          |                   |              |
|                                                                                                           | W 247                    |                    |                          |                  |          |                   |              |
| 0024 :                                                                                                    |                          |                    |                          | Continued        | on the n | ext name          |              |
|                                                                                                           |                          |                    |                          | Concrined        |          | CAL Paye          |              |

| FB 11 | 0 conti                              | inued: |                              |
|-------|--------------------------------------|--------|------------------------------|
| 0025  | :L                                   | =REST  | First send any remaining     |
| 0026  | :L                                   | кв О   | data fields                  |
| 0027  | :> <f< td=""><td></td><td></td></f<> |        |                              |
|       | : JC                                 | =TRAN  |                              |
| 0029  | :                                    |        |                              |
| 002A  | : AN                                 | =STAR  | Positive edge at start       |
|       |                                      | =EDGF  | input ?                      |
|       |                                      | =STAR  |                              |
| 002D  | :0                                   | =EDGF  |                              |
| 002E  | : JC                                 | =GOOD  |                              |
| 002F  | :S                                   | =EDGF  |                              |
| 0030  | :                                    |        |                              |
| 0031  | :L                                   | =NUMB  | Initialize the global flags  |
| 0032  | :Т                                   | =REST  | after postive edge at        |
| 0033  | :L                                   | =FIRB  | START input                  |
| 0034  | :Т                                   | =CUBN  | -                            |
| 0035  | :                                    |        |                              |
| 0036  | :L                                   | =REST  | As long as REST $>>0$ ,      |
| 0038  | LOOP:L                               | KF+0   | continue to attempt to       |
| 0039  | :!=F                                 |        | send data fields             |
| 003A  | : JC                                 | =GOOD  |                              |
| 003B  | TRAN:L                               | =CUBN  |                              |
| 003C  | :Т                                   | FY 249 |                              |
| 003D  | :L                                   | KB 246 | SF OB:                       |
| 003E  | :JU                                  | OB 202 | "Send a data field"          |
| 003F  |                                      | FY 250 |                              |
| 0040  |                                      |        | Abort if error               |
| 0041  | :JP                                  | =GOOD  | Abort if trans-cap. = $0$    |
| 0042  | :L                                   | =CUBN  | Increment                    |
| 0043  | :I                                   | 1      | field number                 |
| 0044  | :Т                                   | =CUBN  |                              |
| 0045  | :L                                   | =REST  | Decrement number of          |
| 0046  | :D                                   | 1      | remaining data fields        |
| 0047  | :T                                   | =REST  |                              |
| 0048  | : JU                                 | =LOOP  |                              |
| 0049  | :                                    |        |                              |
| 004A  | GOOD :A                              | F 0.0  | Regular end of program:      |
| 004B  | : AN                                 | F 0.0  |                              |
| 004C  | :L                                   | КВ О   | RLO = 0, $ERRO = 0$          |
| 004D  | :T                                   | =ERRO  |                              |
| 004E  | :BE                                  |        |                              |
| 004F  | :                                    |        |                              |
| 0050  | ERRO :1                              | =ERRO  | Program end if error:        |
| 0051  | :L                                   | КВ 0   |                              |
| 0052  | :Т                                   | =REST  | RLO = 1, ERRO contains error |
| 0053  | :BE                                  |        | number                       |
|       |                                      |        |                              |

## Application of FB 110

### <u>Task</u>

You want CPU 1 to transfer data blocks DB 3 (data fields 2 to 5) and DB 4 (data fields 1 to 3) to CPU 2 during the cyclic user program. The RECEIVE function (OB 204) is also called in the cyclic user program.

#### **Implementation**

| Function                    | CPU 1      | CPU 2      |
|-----------------------------|------------|------------|
|                             | called in: | called in: |
| Initialization (OB 200)     | OB 20      | _          |
| Send organization (FB 1)    | OB 1       | -          |
| Receive organization (FB 2) | -          | OB 1       |
|                             | exists:    | exists:    |
| Send DB                     | DB 3; DB 4 | _          |
| Receive DB                  | _          | DB 3; DB 4 |

The user program in function block FB 1 of CPU 1 contains two calls for the function block TRANDAT in each case with different sets of parameters. The transfer of the first data block DB 3 begins after a positive edge after input I 2.0. A positive edge at input I 2.1 starts the transfer of the second data block.

| FB 1             |            |        | LEN=yy                     |
|------------------|------------|--------|----------------------------|
| SEGMEN<br>NAME:S |            | 0000   |                            |
| 0000             | :L         | КВ 2   | То СРИ 2                   |
| 0001             | : T        | FY O   |                            |
| 0002             | :L         | КҮ 1,3 | from data block DB 3       |
| 0003             | <b>:</b> T | FW 1   |                            |
| 0004             | :L         | KB 4   | four data fields           |
| 0005             | <b>:</b> T | FY 3   |                            |
| 0006             | :L         | KB 2   | send from 2nd data field   |
| 0007             | : T        | FY 4   |                            |
| 0008             | :          |        |                            |
|                  |            |        |                            |
|                  |            |        | Continued on the next page |
|                  |            |        |                            |
|                  |            |        |                            |

| Application example continued: |                                 |
|--------------------------------|---------------------------------|
| 0009 :JU FB 110                |                                 |
| 000A NAME :TRAN-DAT            |                                 |
| 000B STAR : I 2.0              |                                 |
| OOOC RCPU: FY O                |                                 |
| OOOD TNDB : FW 1               |                                 |
| OOOE NUMB: FY 3                |                                 |
| OOOF FIRB : FY 4               |                                 |
| 0010 ERRO : FY 5               |                                 |
| 0011 REST : FY 6               |                                 |
| 0012 CUBN : FY 7               |                                 |
| 0013 EDGF : F 8.0              |                                 |
| 0014 :                         |                                 |
| 0015 :                         |                                 |
| 0016 :JC =HALT                 | Abort after error               |
| 0017 :                         |                                 |
| 0018 :L KB 2                   | To CPU 2                        |
| 0019 :T FY 10                  |                                 |
| 001A :L KY 1,4                 | from data block DB 4            |
| 001B :T FW 11                  |                                 |
| 001C :L KB 3                   | three data fields               |
| 001D :T FY 13                  |                                 |
| 001E :L KB 1                   | send from 2nd data field        |
| 001F :T FY 14                  |                                 |
| 0020 :                         |                                 |
| 0021 :JU FB 110                |                                 |
| 0023 NAME :TRAN-DAT            |                                 |
| 0024 STAR : I 2.1              |                                 |
| 0025 RCPU: FY 10               |                                 |
| 0026 TNDB : FW 11              |                                 |
| 0027 NUMB : FY 13              |                                 |
| 0028 FIRB : FY 14              |                                 |
| 0029 ERRO : FY 5               |                                 |
| 002A REST : FY16               |                                 |
| 002B CUBN : FY17               |                                 |
| 002C EDGF : F 8.1              |                                 |
| 002D :                         |                                 |
| 002E :                         |                                 |
| 002F :JC =HALT                 | Abort after error               |
| 0030 :BEU                      |                                 |
| 0031 :                         |                                 |
| 0032 HALT :                    |                                 |
| 0033 :                         | The error handling takes place  |
| 0034 :                         | here (e.g. stop, message output |
| 0035 :                         | on the printer,)                |
| 0036 :                         |                                 |
|                                |                                 |
| OOxx :BE                       |                                 |
|                                |                                 |
|                                |                                 |
|                                | Continued on the next rese      |
|                                | Continued on the next page      |
|                                |                                 |
|                                |                                 |

```
Application example continued:
In CPU 2, the RECEIVE function (OB 204) called by FB 2 enters each transmitted
data field into the appropriate data block. It may take
several cycles before a data block has been completely received.
FB 2
                                                      LEN=yy
SEGMENT 1
               0000
NAME : RECV-DAT
0000 :L KB 1
                               Receive data from CPU 1
0001
     :T FY 246
0002
      :
0003 SCHL :L KB 246
                               SF OB:
0004 :JU
              OB 204
                               "Receive"
0005
     : JM
             =ERRO
                              Abort if error
0006 :L FY 249
                              The RECEIVE function is
0007 :L KB 0
                               called until there are no
8000
     :><F
                               further of data fields in
0009
      :JC
             =LOOP
                               the buffer, i.e. the
A000
                               receiving capacity = 0.
       :
000в
     :BEU
000C ERRO :
000D
                                The error handling takes place
      :
000E
                                here (e.g. stop, message output
       :
000F
                                on printer, ...)
      :
00xx
       :BE
```

# 10.9.3 Extending the IPC Flag Area

| The problem    | In the S5-135U/155U programmable controllers, each of the 256 flag bytes of a CPU can become an input or output IPC flag by making an entry in data block DB 1. This, however, reduces the number of "normal" flag bytes. To transfer a data record (several bytes) other mechanisms are also required (semaphore variable or DX 0 parameter assignment "transfer IPC flags as a block") are necessary to prevent the receiver from receiving a fragmented data record.                                                    |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| The solution   | Consecutive data words of a DB or DX data block are defined from DW 0 onwards as "IPC data words". Each link is assigned its own data block and is totally <b>in</b> dependent of the other links.                                                                                                                                                                                                                                                                                                                         |
|                | At the beginning of the cycle block, the IPC data words are received with the aid<br>of the special function organization blocks for multiprocessor communication.<br>This is followed by the "regular" cyclic program, that evaluates the received data<br>and generates the data to be sent. At the end of the cycle, this data is then sent<br>with the aid of the special organization blocks for multiprocessor<br>communication. It can therefore be received by the other CPUs at the beginning<br>of their cycles. |
|                | The following applies for each of the maximum 12 possible links regardless of the other links:                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                | • The transmitting CPU is only active when the receiving CPU has read out all the "old" data from the COR 923C buffer.                                                                                                                                                                                                                                                                                                                                                                                                     |
|                | • The receiving CPU is only active when the transmitting CPU has written all the "new" data in the COR 923C buffer.                                                                                                                                                                                                                                                                                                                                                                                                        |
|                | This means that the receiving CPU can either receive a complete new data record or the old data record remains unchanged: <b>no mixing of "old" and "new" data.</b>                                                                                                                                                                                                                                                                                                                                                        |
| Data structure | Which data words (for the data word area below) are to be transferred from which CPU to which CPU is described in the link list (see the table on the following page). This is located in an additional data block that must exist in all the CPUs involved.                                                                                                                                                                                                                                                               |
|                | The data word areas always begin from data word DW 0, and their lengths are specified in data fields. Remember the following points:                                                                                                                                                                                                                                                                                                                                                                                       |
|                | • A complete data field consists of 32 data words.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                | • If the last data field is "truncated", i.e. it contains between 1 and 31 data words, less data words are transferred.                                                                                                                                                                                                                                                                                                                                                                                                    |
|                | • If a send data block is longer than the number of fields of data specified in the link list, the excess data words can be used in the corresponding CPU.                                                                                                                                                                                                                                                                                                                                                                 |
|                | • If a receive data block is longer than the received data word area, the excess data words can be used in the corresponding CPU.                                                                                                                                                                                                                                                                                                                                                                                          |

## Structure of the link list

|               |             | SUB-LIST 1      |                   | SUB-LIST 2 |                 |                       |  |
|---------------|-------------|-----------------|-------------------|------------|-----------------|-----------------------|--|
| Link          |             | DB type         | DB number         |            |                 | No. of data<br>fields |  |
| from CPU 1 to | <b>DW</b> 0 | S               | 51                | DW 16      | 1               | 51                    |  |
| CPU 2         | DW 1        |                 |                   | DW 17      | 2               |                       |  |
| CPU 3         | DW 2        |                 |                   | DW 18      | 3               |                       |  |
| CPU 4         | DW 3        |                 |                   | DW 19      | 4               |                       |  |
| from CPU 2 to | DW 4        | S               | 52                | DW 20      | 5               | 52                    |  |
| CPU 1         | DW 5        |                 |                   | DW 21      | 1               |                       |  |
| CPU 3         | DW 6        | 1 1)            | 10 <sup>-1)</sup> | DW 22      | 3               | 2 1)                  |  |
| CPU 4         | DW 7        |                 |                   | DW 23      | 4               |                       |  |
| from CPU 3 to | DW 8        | S               | 33                | DW 24      | 1               | \$3                   |  |
| CPU 1         | DW 9        |                 |                   | DW 25      | 1               |                       |  |
| CPU 2         | DW 10       |                 |                   | DW 26      | 2               |                       |  |
| CPU 4         | DW 11       |                 |                   | DW 27      | 4               |                       |  |
| from CPU 4 to | DW 12       | s               | 54                | DW 28      | 5               | 54                    |  |
| CPU 1         | DW 13       |                 |                   | DW 29      | 1               |                       |  |
| CPU 2         | DW 14       |                 |                   | DW 30      | 2               |                       |  |
| CPU 3         | DW 15       |                 |                   | DW 31      | 3               |                       |  |
|               |             | 2 <sup>15</sup> | 20                |            | 2 <sup>15</sup> | 20                    |  |

Table 10-9 Link list for extending the IPC flag area

<sup>1)</sup> Refer to the example on the following page

The link consists of two similarly structured sub-lists, each with 16 data words. For each of the four sender CPUs (S1, S2, S3, S4) three entries are required to describe a link.

## • Number of data fields

The number of data fields specifies the size (= the number of data words) of the data word area to be transferred. (If links do not exist or you do not require them, enter 0 for the number of data fields, and for the DB type and DB number.)

## • DB type

Type of data block containing the data word area to be transferred.

## • DB number

Number of the data block containing the data word area to be transferred.

As shown in the table, these entries can be read in and completed in lines. If, for example, you want to transfer the first two data fields in data block DB 10 from CPU 2 (S2) to CPU 3, make the following entries:

CPU 2 (S 2) sends ...



Sub-list 2 is identical to the assignment ("manual" mode) required for the INITIALIZE function (OB 200). Within the data block, sub-list 2 must occupy data words 0 to 15 and sub-list 2 data words 16 to 31. You must not alter the entries shown in bold face.

# Program structure

During restart, one of the CPUs calls the INITIALIZE function (OB 200) to reserve exactly the same number of coordinator memory fields per link as data fields to be transmitted on this link.

To send and receive data word areas, each CPU uses two function blocks:

| FB no. | Name            | Function                                    |
|--------|-----------------|---------------------------------------------|
| FB 100 | SEND-DAT        | Send data word areas to the other CPUs      |
| FB 101 | <b>RECV-DAT</b> | Receive data word areas from the other CPUs |

These FB numbers have been selected at random and you can use others.

The function blocks SEND-DAT and RECV-DAT read the link list to determine which data word areas are to be sent from or received by which data blocks. The **whole** data word area is always sent or received. If this is not possible owing to insufficient transmitting or receiving capacity, the send or receive function is not executed.

### Note

This example (IPC flag extension using function blocks SEND-DAT and RECV-DAT) can only run correctly when the special function organization blocks for multiprocessor communication OB 202 to OB 205 are not called in any of the CPUs.

The function blocks SEND-DAT and RECV-DAT contain the special function organization blocks for multiprocessor communication OB 202 to OB 205. You cannot call these organization blocks outside SEND-DAT/RECV-DAT.



#### Fig. 10-6 Overview of the blocks required in each CPU

### Programming function blocks

#### FB 100: Sending data word areas

Before you call FB 100, the data block containing the link list must be open. The function block SEND-DAT requires the number of the CPU on which it is called in order to evaluate the information contained in the link list. If the SEND function (OB 202) is not executed correctly in the function block, the error or warning number is transferred to the output parameter ERWA and RLO is set to 1. If the input parameter CPUN (CPU number) is illegal, ERWA has the value 16 (bit no. 4 = 1). The function block SEND-DAT uses flag bytes FY 239 to FY 251 as scratchpad flags.



| Parameter name | Significance                                                                             | Parameter<br>type | Data type |
|----------------|------------------------------------------------------------------------------------------|-------------------|-----------|
| CPUN           | Number of the <b>CPU</b> on which FB 100 is called.<br>The numbers 1 to 4 are permitted. | D                 | KF        |
| ERWA           | Error/warning (see SEND function/<br>OB 202)                                             | Q                 | BY        |

```
FB 100
```

LEN=90

| 0000                 |                                                                                                                                                                                                                                                               |                                                                                   |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
| T                    |                                                                                                                                                                                                                                                               |                                                                                   |
| DECL : CPUN I/Q/D/B/ |                                                                                                                                                                                                                                                               | KM/KH/KY/KS/KF/KT/KC/KG:KF                                                        |
| I/Q/D/B/             | /C: Q                                                                                                                                                                                                                                                         | BI/BY/W/D: BY                                                                     |
| =CPUN                |                                                                                                                                                                                                                                                               | CPUN = CPUN - 1                                                                   |
| KB 1                 |                                                                                                                                                                                                                                                               | Error if:                                                                         |
|                      |                                                                                                                                                                                                                                                               |                                                                                   |
| =ERWA                |                                                                                                                                                                                                                                                               | CPU no. <1                                                                        |
| КВ З                 |                                                                                                                                                                                                                                                               |                                                                                   |
|                      |                                                                                                                                                                                                                                                               |                                                                                   |
| =ERWA                |                                                                                                                                                                                                                                                               | CPU no. >4                                                                        |
|                      |                                                                                                                                                                                                                                                               |                                                                                   |
|                      |                                                                                                                                                                                                                                                               | Continued on the next page                                                        |
|                      | $\begin{array}{c} \mathbf{AT} \\ \mathbf{I}/\mathbf{Q}/\mathbf{D}/\mathbf{B}/\mathbf{T} \\ \mathbf{I}/\mathbf{Q}/\mathbf{D}/\mathbf{B}/\mathbf{T} \\ = \mathbf{CPUN} \\ \mathbf{KB} \ 1 \\ = \mathbf{ERWA} \\ \mathbf{KB} \ 3 \\ = \mathbf{ERWA} \end{array}$ | AT<br>I/Q/D/B/T/C: D<br>I/Q/D/B/T/C: Q<br>=CPUN<br>KB 1<br>=ERWA<br>KB 3<br>=ERWA |

```
FB 100 continued:
0013
      :
     :SLW
                              CPUN = CPUN * 4
0014
             2
     :T
0015
             FY 245
                              Base address
0016
     :
0017
           КВ 1
    :L
0018
     :T FY 244
                             Link counter
0019
      •
001A LOOP :L FY 245
                             Base address
001B :L FY 244
                               + counter
001C :+F
001D :T
             FW 240
001E :ADD
             BN+16
                               + offset
001F :T
             FW 242
0020
     :
0021
     :DO
            FW 242
0022
    :L DR O
                              Number of reserved
0023
    :Т
          FY 239
                              fields = 0 ?
0024
     :L
             кв О
0025
     :!=F
0026
      :JC
             =EMPT
0027
     :
0028
            FW 242
     :B
    :L DL O
0029
                             No. of the receiving CPU
002A
    :Т
             FY 246
002B
    :L
             KB 246
                             SF OB:
002C
     : JU
            OB 203
                              "Test sending capacity"
002D
                             Abort if error
      :L
           FY 248
002E
      :JC
             =OBER
002F
      :
                            Transmitting capacity \succ no.
0030
      :L
           FY 249
0031
      :L
         FY 239
                              of reserved fields?
0032
      :><F
0033
      :JC
             =EMPT
0034
      :
0035
      :L
            КВ О
                              Field counter
0036
      :Т
             FY 249
0037
      :
0038
      :B
             FY 240
      :L
          DW O
0039
                              Type and number of
003A
         FW 247
                              the source DB
      :Т
003B
      :
                             SF OB:
003C TRAN :L
             KB 246
003D
    : JU
             OB 202
                             Send a data field
003E
      :L FY 250
                             Abort if error/warning
003F
    :JC
             =OBER
0040
      :
0041
      :L
          FY 249
                             Field no. = field no. + 1
0042
      :I
            1
0043
      :Т
           FY 249
                             All data fields transferred ?
      :L
0044
             FY 239
0045
      :<F
0046
      : JC
             =TRAN
0047
      :
                                     Continued on the next page
```

```
FB 100 continued:
0048 EMPT :L
             FY 244
0049
    :I 1
004A
     :Т
             FY 244
004B
     :L
          KB 4
004C
     :<F
004D
     :JM
            =LOOP
004E
     :L KB 0
004F
     :T =ERWA
     :BEU
0050
0051
      :
0052 ERWA :L
           KB 16
0053 OBER :T
             =ERWA
0054
     :BE
```

```
Increment
link counter
All links
processed ?
Regular program end:
RLO = 0, ERWA = 0
Program end if error:
RLO = 1, ERWA contains
error/warning number
```

#### FB 101: Receive data word areas

Before you call FB 101, the data block containing the link list must already be open. The function block RECV-DAT requires the number of the CPU in which it is called in order to evaluate the information contained in the link list.

If the RECEIVE function (OB 204) is not correctly processed within the function block, the corresponding error or warning number is transferred to the output parameter ERWA and the RLO is set to 1. If the input parameter CPUN is illegal, ERWA has the value 16 (bit no. 4 = 1).

The RECV-DAT function block uses flag bytes FY 242 to FY 255 as scratchpad flags.



| Parameter name | Significance                                                                       | Parameter<br>type | Data type |
|----------------|------------------------------------------------------------------------------------|-------------------|-----------|
| CPUN           | Number of the CPU, on which FB 101 is called.<br>The numbers 1 to 4 are permitted. | D                 | KF        |
| ERWA           | Error/warning (see RECEIVE function / OB 204)                                      | Q                 | BY        |
|                | Continued on the r                                                                 | next page         |           |

| FB 101 continued: |            |                  |          |         |                                      |           |
|-------------------|------------|------------------|----------|---------|--------------------------------------|-----------|
| FB 101 LEN=88     |            |                  | EN=88    |         |                                      |           |
|                   | -          |                  |          |         |                                      |           |
|                   | ENT 1      | 0000             |          |         |                                      |           |
|                   | RECV-DA    |                  |          | _       |                                      | /20/20.20 |
|                   |            | I/Q/D/B/T/C:     |          | D       | KM/KH/KY/KS/KF/KT                    |           |
| DECL              | :ERWA      | I/Q/D/B/T/C:     |          | Q       | BI/BY/W/D:                           | BY        |
| 000в              | :LW        | =CPUN            |          | Error   | if.                                  |           |
| 000D              |            |                  |          | drivi . |                                      |           |
| 000D              |            |                  |          |         |                                      |           |
| 000E              |            | =ERWA            |          | CPU no  | . <1                                 |           |
| 000F              |            | =CPUN            |          |         |                                      |           |
| 0010              |            |                  |          |         |                                      |           |
| 0011              | :>F        |                  |          |         |                                      |           |
| 0012              | :JC        | =ERWA            |          | CPU no  | . >4                                 |           |
| 0013              | :          |                  |          |         |                                      |           |
| 0014              | :L         | KB 1             |          | Link C  | ounter                               |           |
| 0015              | <b>:</b> T | FY 242           |          |         |                                      |           |
| 0016              |            |                  |          |         |                                      |           |
|                   |            | KB 16            |          |         |                                      |           |
| 0018              |            | FW 244           |          | Pointe  | r to sub-list 2                      |           |
| 0019              | -          |                  |          |         |                                      |           |
|                   | SRCH :L    |                  |          |         | sub-list 2 until                     |           |
| 001B              |            | 1                |          |         | t entry for the                      |           |
| 001C              |            | FW 244           |          |         | ing CPU with the<br>'CPUN' is found. |           |
| 001D<br>001E      |            |                  |          | number  | CPUN' IS IOUND.                      |           |
| 001E<br>001F      |            |                  |          |         |                                      |           |
| 0011              |            |                  |          |         |                                      |           |
| 0021              |            | =SRCH            |          |         |                                      |           |
| 0022              |            |                  |          |         |                                      |           |
| 0023              |            | FW 244           |          |         |                                      |           |
| 0024              | :L         | DR O             |          | Number  | of reserved                          |           |
| 0025              | :Т         | FY 243           |          | memory  | fields = $0$ ?                       |           |
| 0026              | :L         | КВ О             |          |         |                                      |           |
| 0027              | :!=F       |                  |          |         |                                      |           |
| 0028              | : JC       | =EMPT            |          |         |                                      |           |
| 0029              |            |                  |          |         |                                      | -         |
| 002A              |            | FW 244           |          |         | ine the number of t                  |           |
| 002B              |            | км 0000000       | 00001100 |         | itting CPU from the                  | 9         |
| 002D              |            | •                |          | pointe  | r to sub-list 2.                     |           |
| 002E              |            |                  |          |         |                                      |           |
| 002F              |            | 1<br>EV 246      |          |         |                                      |           |
| 0030              |            | FY 246           |          |         |                                      |           |
| 0031              |            | KB 246           |          | SF OB:  |                                      |           |
|                   |            | OB 205           |          |         | receiving capacity'                  | n         |
| 0033<br>0034      |            | OB 205<br>FY 248 |          | TGRE    | Lecenving capacity                   |           |
| 0034              |            | FI 248<br>= OBER |          | Abort   | if error                             |           |
| 0035              |            | - VBER           |          |         |                                      |           |
| 0050              | •          |                  |          |         |                                      |           |
|                   |            |                  |          |         | Continued on the                     | next page |
|                   |            |                  |          |         |                                      |           |
|                   |            |                  |          |         |                                      |           |

```
FB 101 continued:
0037
      :L FY 249
                              Receiving capacity = number
0038
     :L FY 243
                             of reserved
     :><F
0039
                             memory fields ?
     :JC = EMPT
003A
003в
      :
003C RECV :L KB 246
                              SF OB:
003D
       :JU OB 204
                              "Receive a data field"
003E
       :L FY 248
003F
       :JM =OBER
                            Abort if error/warning
0040
       :L FY 249
                            if receiving capacity = 0
0041
       :L KB 0
                             process next link
0042
       :><F
0043
       :JC =RECV
0044
        :
0045 EMPT :L FY 242
                              Increment
     :I 1
0046
                              link counter
        :T FY 242
0047
0048
            KB 4
                            All links
        :L
0049
        :<F
                             processed ?
004A
        :JM = SRCH
        :L KB 0
004B
                             Regular program end:
004C
             =ERWA
                              RLO = 0, ERWA = 0
        :T
004D
        : BEU
004E
         :
004F ERWA :L KB 16
                              Program end if error:
0050 OBER :T =ERWA
                              RLO = 1, ERWA contains
0051
      :BE
                              error/warning number
```

Application example



```
Application example continued:
Implementation
1. Loading blocks
The following blocks must be loaded in the individual CPUs:
       Function
                           CPU 1
                                              CPU 2
                                                                 CPU 3
Restart OB
                        OB 20
User program
                        FB 1
                                        FB 1
                                                           FB 1
                                        FB 100
FB: SEND-DAT
                        FB 100
                                                           FB 100
FB: RECV-DAT
                        FB 101
                                        FB 101
                                                           FB 101
Link list
                        DB 100
                                        DB 100
                                                           DB 100
Input DB
                        DB 5
                                        DB 3
                                                           DB 5; DX 4
Output DB
                        DB 3; DX 4
                                        DB 5
                                                            ____
2. Creating the link list
The link list is created and entered in data block DB 100:
DB100
                                                          LEN=37
                                                          PAGE
                                                                  1
- - Sub-list 1 - -
0:
       KS = 'S1';
                                 Send from CPU 1 to ..
       KY = 001,003;
                                 .. CPU 2 (DB 3)
 1:
 2:
       KY = 002,004;
                                 .. CPU 3 (DX 4)
       KY = 000,000;
 3:
 4:
       KS = S2;
                                  Send from CPU 2 to ..
       KY = 001,005;
                                  .. CPU 1 (DB 5)
 5:
 6:
       KY = 001,005;
                                  .. CPU 3 (DB 5)
7:
      KY = 000,000;
      KS = 'S3';
 8:
9:
      KY = 000,000;
10:
      KY = 000,000;
11: KY = 000,000;
12: KS = 'S4';
13: KY = 000,000;
14: KY = 000,000;
15: KY = 000,000;
                                          Continued on the next page
```

```
Application example continued:
- - Sub-list 1 - -
                              Send from CPU 1 to ..
.. CPU 2 (four data fields)
      KS = 'S1';
16:
    KY = 002,004;
17:
    KY = 003,002;
18:
                               .. CPU 3 (two data fields)
19:
    KY = 004,000;
    KS = S2';
                                        Send from CPU 2 to ..
20:
                              .. CPU 1 (three data fields)
    KY = 001,003;
KY = 003,003;
21:
22:
                                .. CPU 3 (three data fields)
23:
    KY = 004,000;
    KS = 'S3';
24:
    KY = 001,000;
25:
26:
    KY = 002,000;
27:
    KY = 004,000;
28:
    KS = 'S4';
29:
     KY = 001,000;
30:
     KY = 002,000;
31:
      KY = 003,000;
Data words DW 16 to DW 31 contain the assignment list required for the
manual INITIALIZATION function (OB 200).
3. Program OB 200 call in the start-up block OB 20 for CPU 1
OB 200 is called by the OB 20 shown below in CPU 1 during the restart.
OB 20
                                             LEN=yy
                                                       ABS
SEGMENT 1
0000
          KB 2
                               Manual initialization of
     :L
      :T FY 246
0001
                               the pages
0002
      :
0003
          KY 1,100
     :L
                             The assignment list is entered
     :T
          FW 248
0005
                               in DB 100 from data word 16
          KF+16
0006
                                onwards
      :L
8000
      :Т
          FW 250
0009
       :
A000
      :L
           KB 246
                                SF OB:
000в
       : JU
             OB 200
                                        "Initialize"
000C
       :
000D
       : AN
              F 252.5
                                        Block end if there is no
000E
       : BEC
                                        initialization conflict
000F
       :
0010
                                        The error handling routine
       :
0011
                                        is inserted here if an
       :
0012
       :
                                        initialization clonflict
0013
                                        occurs (e.g. stop, output
       :
0014
                                        message on printer, or ...)
       :
00xx
       :BE
                                        Continued on the next page
```

Application example continued: 4. Program calls for the function blocks in FB 1 of the CPUs: The user program on each CPU is extended by the RECV-DAT and SEND-DAT call. Function block FB 1 shown below is for CPU 1. For the other CPUs, the input parameter CPUN (CPU number) must be modified. LAN=yy FB 1 SEGMENT 1 0000 NAME: EM-SE 0000 Link list DB 100 DB100 0000 :C :JU FB101 Receive the input 0001 data blocks 0002 : 0003 NAME : RECV-DAT 0004 CPUN : KF+1 0005 ERWA : FY0 :JC =ERWA Abort if error/warning 0006 0007 : 8000 : Here, the cyclic user program 0009 : that reads data from the inpu 000A : data blocks and enters data in 000в : 000C the output data blocks is : 000D inserted. : 000E : 000F : Link list DB 100 DB 100 0010 :C :JU FB100 Send the output 0011 data blocks 0012 : 0012 NAME :SEND-DAT 0013 CPUN : KF+1 0014 ERWA : FY0 :JC =ERWA Abort if error/warning 0015 : BEU 0016 0017 : Run an error handling routine 0018 ERWA : following an error/warning (here, 0019 : the error handling routine is 001A : inserted, e.g. stop, output error 001B : message on printer or screen, 001C : or ..) 00xx :BE

# 11

## **PG Interfaces and Functions**

# Contents of the chapter

This chapter explains how to connect your PG to the CPU 928B and the functions provided by the PG software with which you can test your STEP 5 program.

If you only use the standard PG interface (1st serial PG interface) you do not need to read Section 11.5. This section tells you about further interfaces with which you can connect a PG to your CPU. It also contains points to note if you use PG functions on both interfaces.

# Overview of the chapter

| Section | Description                                          | Page  |
|---------|------------------------------------------------------|-------|
| 11.1    | Overview                                             | 11-2  |
| 11.2    | PG Functions                                         | 11-3  |
| 11.2.1  | Information                                          | 11-5  |
| 11.2.2  | Memory Functions and Transfer Functions              | 11-5  |
| 11.2.3  | Program Test                                         | 11-7  |
| 11.3    | Activities at Checkpoint                             | 11-15 |
| 11.4    | Serial Link PG - PLC via 1st or 2nd Serial Interface | 11-16 |
| 11.5    | Parallel Operation of Two Serial PG Interfaces       | 11-17 |
| 11.5.1  | Installation                                         | 11-19 |
| 11.5.2  | Operation                                            | 11-19 |
| 11.5.3  | Sequence in Certain Operating Situations             | 11-21 |

## 11.1 Overview

*Link CPU - PG* You can load and test your user program using the online functions of the STEP 5 software.

To use these functions, the CPU must be connected to the PG. The following interfaces are available for this link:

- link via the serial standard interface "PG PLC",
- link via the 2nd serial interface of the CPU 928B.

The PG functions can operate simultaneously on the two serial interfaces.

**Overview of the**PG functions provide the following support for installing and testing your**PG functions**STEP 5 program:

| Function                                             | Section                  |  |
|------------------------------------------------------|--------------------------|--|
| Info                                                 |                          |  |
| Size of the internal RAM and free user memory        | "Memory configuration"   |  |
| List of loaded blocks                                | "Output DIR"             |  |
| Display contents of memory words/bytes and I/O bytes | "Output address"         |  |
| Memory n                                             | nanagement               |  |
| Delete the whole memory                              | "Overall reset"          |  |
| Create more memory space                             | "Compress memory         |  |
| Manage blocks                                        | "Transfer/delete blocks" |  |
| Program test                                         |                          |  |
| Start/stop CPU                                       | "Start/stop"             |  |
| Test the operation sequence in a block               | "Status block"           |  |
| Test single program steps                            | "Program test"           |  |
| Display signal state of process variables            | "Status variables"       |  |
| Output signals in the stop mode                      | "Force"                  |  |
| Display/change process variables                     | "Force variables"        |  |

 Table 11-1
 Functions for installation and testing

## 11.2 PG Functions

| Note concerning<br>some terms used | The terms used in this section for the PG functions may in some cases differ from the terms in your PG software.                                                                                         |  |  |
|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Calling and using functions        | How to call and use the individual PG functions is described in the STEP 5 manual.                                                                                                                       |  |  |
|                                    | <b>Note</b><br>The COMPRESS MEMORY function is rejected as long as OB 186 is<br>compressing the memory. Other PG functions can only be used with certain<br>restrictions.                                |  |  |
|                                    | As long as a PG function is active, OB 186 is rejected.                                                                                                                                                  |  |  |
| Execution                          | The PG functions are executed at defined points in the programmable controller.<br>There are points in the system program (= system checkpoints) and points in the<br>user program (= user checkpoints). |  |  |
| System<br>checkpoints              | In the STOP mode there is the system checkpoint "stop" that is called regularly.                                                                                                                         |  |  |
| oncorpoints                        | In the RUN mode there is the system checkpoint " <b>cycle</b> " that is called at the end of the program processing level CYCLE before the process image is updated.                                     |  |  |
|                                    | If the CPU is in the WAIT state, the system checkpoint "wait state" is called regularly.                                                                                                                 |  |  |
|                                    | There is also a time-dependent system checkpoint " <b>asynchronous</b> ". This system checkpoint is inserted asynchronously during program execution.                                                    |  |  |
| User checkpoints                   | In the test functions STATUS and PROGRAM TEST, user checkpoints are used.<br>A user checkpoint is called when a command is executed that is marked<br>accordingly by the PG.                             |  |  |

| WAIT STATE                 | So far you have come across the modes STOP, RESTART and RUN. When<br>using the online function PROGRAM TEST, the CPU has a fourth mode, the<br>WAIT STATE. When the CPU is in the WAIT STATE, you can call further<br>online functions.                                                                                                                                                                            |         |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| Features of the wait state | • The user program is not processed in the wait state.                                                                                                                                                                                                                                                                                                                                                             |         |
|                            | • LEDS on the front panel: RUN-LED: off                                                                                                                                                                                                                                                                                                                                                                            |         |
|                            | STOP-LED: off                                                                                                                                                                                                                                                                                                                                                                                                      |         |
|                            | BASP-LED: on                                                                                                                                                                                                                                                                                                                                                                                                       |         |
|                            | <ul> <li>All the timers are "frozen", i.e. no timers are running (i.e. the timers is changed). All system timers such as for closed loop control and time processing are also stopped.</li> <li>Once the CPU exits the WAIT STATE the timers start running again</li> <li>Causes of interrupts, for example PEU, BAU, MPSTP or the stop sw registered in the WAIT STATE, however, there is no reaction.</li> </ul> | -driven |
| Interrupts                 | If causes of interrupts are registered in the WAIT STATE, the appropria<br>program processing levels are called immediately after the WAIT STAT<br>exited.                                                                                                                                                                                                                                                         |         |
|                            | If NAU occurs, the WAIT STATE is exited and the PROGRAM TEST of function is aborted. Following POWER ON, BARBEND is marked in the bits. You can only exit the stop mode with COLD RESTART.                                                                                                                                                                                                                         |         |

### 11.2.1 Information

| Memory<br>configuration | The "Memory configuration" programmer function shows you the highest usable address of the RAM submodule ("0" is displayed in the case of EPROM) and the last address of the memory submodule occupied by blocks of the user program.                                                                                                                                                                                                                                                                        |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Output address          | With the "output address" function, you can display the contents of memory and I/O addresses in hexadecimal format. You can access all addresses (RAM, S5 bus, areas with no modules assigned). In the process image area no ADF is triggered, in the I/O area there is no QVZ.                                                                                                                                                                                                                              |  |
|                         | In the areas addressed as bytes (flags, process image) the high byte is represented as 'FF'.                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|                         | In the I/O area, the high byte is output as "00" in the case of acknowledging addresses. If an I/O module does not acknowledge, the high byte is displayed as 'FF'.                                                                                                                                                                                                                                                                                                                                          |  |
|                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 11.2.2 Memory Fu        | nctions and Transfer Functions                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| Overall reset           | With the function "delete all blocks" you can carry out an overall reset of the CPU from the PG. The overall reset is carried out unconditionally (refer to Section 4.3.2).                                                                                                                                                                                                                                                                                                                                  |  |
|                         | If the CPU is in RESTART or RUN when "Delete all blocks" is called, a transition to the Stop state is executed first. Organization block OB 28 is called here if it is loaded.                                                                                                                                                                                                                                                                                                                               |  |
|                         | <b>Note</b><br>Overall reset is not permissible as long as "Program test" is active!                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| Compress<br>memory      | This function optimizes the memory space occupied by blocks. The space taken<br>up by blocks marked as invalid is overwritten by the valid blocks of the user<br>program (the block is rewritten to a different memory area). Following this, the<br>blocks are located from the beginning of the memory, one after the other without<br>gaps between them.<br>This function is performed separately in the RAM submodule and in the DB<br>RAM and is executed at the system checkpoints "cycle" and "stop". |  |
|                         | With the CPU 928B, the COMPRESS MEMORY function is always possible in the STOP mode, even if the BSTACK is not empty.                                                                                                                                                                                                                                                                                                                                                                                        |  |



Caution

After COMPRESSING memory in the STOP mode, you can only restart with a COLD RESTART. The ISTACK and BSTACK are not updated.

| Power down<br>during<br>compressing | If there is a power down during the compressing function, no further block is<br>rewritten. If you call the COMPRESS MEMORY function again following the<br>return of power, the function is continued. |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Errors in the<br>block memory       | The COMPRESS MEMORY function detects the following errors in the block memory:                                                                                                                          |
|                                     | • wrong block length                                                                                                                                                                                    |
|                                     | • corrupted pattern "7070" in the block header                                                                                                                                                          |
|                                     | • invalid block type (with OBs invalid block number).                                                                                                                                                   |
|                                     | The function is then terminated and a message is displayed at the PG. You must<br>then perform an overall reset. The function can only be called again following<br>the overall reset.                  |
|                                     | <b>Note</b><br>You cannot use the COMPRESS MEMORY function as long as the<br>PROGRAM TEST is active.                                                                                                    |
| Transfer block                      | With this function you can transfer new or existing logic and data blocks to the user memory of the CPU or to the internal DB-RAM of the CPU.                                                           |
|                                     | If a block already exists in the user memory of the CPU, it is declared invalid and<br>the new block becomes valid. A block will only be declared invalid when it is<br>not being processed.            |
| Delete block                        | With this function you declare a logic or data block in the user memory as invalid. A block will only be declared invalid when it is not being processed.                                               |
|                                     | The space occupied by these blocks can be used for other blocks via the "Compress memory" function.                                                                                                     |

## 11.2.3 Program Test

| Start/stop                                                          | When you use the START and STOP PG functions, operating the PG corresponds to manual operation.                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                                                     | You can put the programmable controller into the STOP mode by calling the STOP function while the controller is in the RUN mode.                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|                                                                     | You will see the following display for the CPU connected to the PG:                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                                                                     | STOP-LED: on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|                                                                     | BASP-LED: off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|                                                                     | PG-STP is marked in the control bit display. In multiprocessor operation, the MP-STP control bit is set for the other CPUs.                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                                                                     | You exit the SOFT STOP status with a COLD RESTART or WARM<br>RESTART. In the single processor mode, the CPU exits the stop mode. In<br>multiprocessor operation, the restart type is registered initially (the NEUST or<br>MWA control bit is set). However, the CPU stays in the soft STOP mode until<br>all CPUs are initialized for multiprocessing. With the next operation "system<br>start" you can start the programmable controller. This corresponds to operation<br>via the coordinator (switch to RUN). |  |  |
|                                                                     | You can call the START PG function in the multiprocessor mode to select the restart type you want for all the CPUs you are using. After that, you can start the programmable controller with the last CPU.                                                                                                                                                                                                                                                                                                         |  |  |
|                                                                     | • COLD RESTART PG function:<br>MANUAL COLD RESTART of the CPU is executed.                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                                                                     | • WARM RESTART PG function:<br>Depending on the setting in DX 0, MANUAL WARM RESTART or<br>RETENTIVE MANUAL COLD RESTART is executed.                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| Status block                                                        | You can call the "status" PG function to test related operational sequences<br>(STEP 5 operations) in one block at any location in the user program.<br>The current signal status of operands, the accumulator contents, and the RLO are<br>output on the PG screen for every executed operation in the block (i.e., step<br>mode). You can also use this function to test the parameter assignment of<br>function blocks (i.e., field operation):<br>The signal status of the actual operands is displayed.       |  |  |
| <i>Calling the<br/>function and<br/>specifying a<br/>breakpoint</i> | When you call the "status" function on a PG and enter the type and number of the block you want to test (possibly including the nesting sequence and search key), you enter a breakpoint.                                                                                                                                                                                                                                                                                                                          |  |  |
| <b>,</b>                                                            | When the "status" function is called during program processing in the RUN mode, program processing continues until it reaches the operation marked by the specified breakpoint in the correct nesting sequence. Then the system program executes each of the monitored operations up to the operation boundary, outputting the processing results to the PG.                                                                                                                                                       |  |  |

| <i>Calling the<br/>function in the</i><br>STOP <i>mode</i> | You can auch activate the STATUS function in the STOP mode. You can then<br>carry out either a COLD RESTART or a MANUAL WARM RESTART. The<br>CPU executes the program up to the marked operation. The data for the desired<br>operation are then output. This means that the "Status" function is also suitable<br>for, e.g., testing the user program in restart or in the first cycle. |
|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                            | <b>Note</b><br>The results of operation processing are not output in each of the program cycles.                                                                                                                                                                                                                                                                                         |
| Nesting and interruptions                                  | A sequence of operations marked by a breakpoint is completed even if a different program execution level (e.g., an error OB or interrupt OB) is activated and processed. With this you can see whether data has been changed by nested program sections.                                                                                                                                 |
|                                                            | If an interruption in a nested program execution level puts the CPU into the STOP mode, data is output up to the operation that was executed before the program execution levels changed. The data of the remaining operations is padded with zeros (the SAC is also 0).                                                                                                                 |
|                                                            | If the CPU changes from one operating mode to another (e.g., RUN - STOP -<br>MANUAL WARM RESTART), the function remains active. "Status" is<br>terminated by pressing the abort key on the programmer.                                                                                                                                                                                   |
| Program test                                               | You can call the "program test" function to test individual program steps<br>anywhere in your user program. When you do this, you stop program processing<br>and allow the CPU to process one operation after the other. The PG outputs the<br>current signal status of operands, the accumulator contents, and the RLO for each<br>operation executed.                                  |

| <i>Calling the<br/>function and<br/>specifying the<br/>first breakpoint</i> | To call the "program test" function, specify the <b>type</b> and <b>number</b> of the block (if necessary with nesting sequence) you want to test. At the PG, mark the first operation, whose data are to be output. This is how you specify the first breakpoint. BARB is marked in the control bits. Command output is disabled (BASP LED = on).                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $\bigwedge$                                                                 | <b>Caution</b><br>If you set <b>Test mode on the coordinator</b> , command output is <b>not</b> disabled<br>(BASP LED = off). If commands are now processed which change the<br>digital I/O or if the CPU updates the process image, the I/O modules output<br>appropriate signals.                                                                                                                                                                                                                                                                                                                                                                                                       |
| Calling in<br>RESTART and<br>in RUN                                         | When you specify the first breakpoint during <b>program processing</b> , the CPU continues processing the program until it reaches the operation marked by the specified breakpoint. The operation is executed up to the operation boundary. (The DO FW and DO DW operations are processed <b>including</b> the substituted operation.)<br>The CPU then goes to the WAIT STATE. The data of the marked and last executed operation are output there.                                                                                                                                                                                                                                      |
| <i>Calling test<br/>functions in<br/>SOFT STOP</i>                          | You can also call the "program test" function and specify an initial breakpoint<br>when the CPU is in the soft STOP mode. The CPU remains in the soft STOP<br>mode, and you can execute either a COLD RESTART or a MANUAL WARM<br>RESTART. The CPU processes the program up to the marked operation and it<br>proceeds as outlined above.                                                                                                                                                                                                                                                                                                                                                 |
| Executing the<br>function and<br>specifying<br>another<br>breakpoint        | <ul> <li>Initial situation: the CPU is in the WAIT STATE.</li> <li>To continue the function, you have two possibilities:</li> <li>1. Specify the next operation as the following breakpoint:</li> <li>Move the cursor down to the next operation to specify the following breakpoint. The CPU continues by processing this operation up to the operation boundary. Then the CPU outputs the data and waits for further instructions from the PG.</li> <li>However, if a nested program execution level interrupts operation processing at the following breakpoint, the CPU processes the nested program first. Then the CPU returns to the 2nd breakpoint that you specified.</li> </ul> |

|                              | <b>Note</b><br>You <b>cannot</b> specify a following breakpoint when the CPU is in the STOP mode.                                                                                                                                                                                                                                                  |  |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                              | 2. Specify a <b>new</b> breakpoint:                                                                                                                                                                                                                                                                                                                |  |
|                              | At the PG, specify any other operation in the same block or in a different<br>block. The CPU continues program processing until it reaches the new<br>breakpoint. The operation is processed fully. The CPU then goes to the<br>WAIT STATE and outputs the data there.                                                                             |  |
|                              | You can also run the program through a whole cycle (cyclic test), by setting<br>the breakpoint at the same operation as previously in the WAIT STATE.<br>Remember, however, that the operation must not be in a program loop. In this<br>case, the loop is run through once; and the program execution does not go<br>beyond the end of the cycle. |  |
|                              | <b>Note</b><br>You can call other functions, such as OUTPUT DIR, STATUS<br>VARIABLES or FORCE VARIABLES in the WAIT STATE. Once<br>program execution is continued after exiting the WAIT STATE, the timers<br>and system timers continue to run until the next breakpoint is reached.                                                              |  |
| Cancelling the<br>breakpoint | If a specified breakpoint has not yet been reached, you can cancel it by pressing<br>the break key on the PG. The CPU then changes to the WAIT STATE. You can<br>then select a new breakpoint or call PROGRAM TEST END.                                                                                                                            |  |
| Aborting the<br>function     | If you call the PROGRAM TEST END function during program execution, in<br>the WAIT STATE and in the STOP MODE, you can terminate the function. The<br>CPU goes to the STOP mode (or remains in the STOP mode). The STOP LED<br>flashes slowly. BARBEND is marked in the control bits. Following this you<br>must perform a COLD RESTART.           |  |
|                              | If an interface error (break on the PG cable) or NAU occurs during the PROGRAM TEST function, the function is terminated as described above.                                                                                                                                                                                                       |  |
| Nesting                      | When the PROGRAM TEST function is active, other program processing levels can be inserted after the WAIT STATE is exited.                                                                                                                                                                                                                          |  |
|                              | When the operation is processed at the breakpoint and if a different program processing level is called at this point (e.g. an error OB, a process interrupt or a time-driven interrupt) this is inserted and completely processed only when the WAIT STATE is exited again.                                                                       |  |

#### Note

The data are read at the operation boundary and output there. Program processing levels which may have been inserted after this point are not yet processed.

The sequence of the "program test" function is illustrated in Fig. 11-1.



Fig. 11-1 Sequence of "program test"

If requests such as PEU, MP-STP, stop switch etc. occur during the WAIT STATE, these are only registered. These can become active immediately after the CPU exits the WAIT STATE: A program processing level is inserted or an interrupt leads to the STOP mode.

The reaction depends on the order in which the events occurred. Simultaneous requests have an order of priority.

#### Note

When the CPU is in the WAIT STATE and the insertion of a program processing level is requested, you can set a breakpoint at an operation in the inserted program section. This allows you, for example, to monitor the QVZ error OB immediately after an operation that triggers a QVZ.

- Interruptions
   Program processing (RESTART/RUN) → STOP mode: If an interruption occurs during program processing (e.g., multiprocessor stop, I/O not ready/STOP, error OB not programmed etc.) before the program reaches the specified breakpoint, the CPU goes into the STOP mode immediately. If you execute a COLD RESTART or a MANUAL WARM RESTART, the "program test" function is still in effect and the breakpoint is still set.
  - Program processing at breakpoint (RESTART/RUN)  $\rightarrow$  STOP mode:

If stop conditions occur at the breakpoint or following breakpoint during program processing, the CPU goes directly into the soft STOP mode and outputs the data.

If you do not specify a new breakpoint while the CPU is in the STOP mode, the "program test" function is still in effect after the restart.

• Wait state  $\rightarrow$  STOP

Causes of interrupts occurring in the WAIT STATE (e.g. MP-STP, PEU, I/O not ready, stop switch) or resulting from the previous operation (error causing the CPU to stop) are registered, however, the CPU remains in the WAIT STATE. The causes of interrupts only bring about a transition to the STOP mode after you have specified a new breakpoint in the WAIT STATE and the CPU has exited the WAIT STATE. The specified breakpoint is not reached. If you then carry out a RESTART (COLD RESTART or MANUAL WARM RESTART) the new breakpoint remains set.

#### Note

If you switch the CPU to stop using the stop switch while it is in the WAIT STATE, it only goes into the STOP mode after exiting the WAIT STATE.

If causes of interrupts bring the CPU to the STOP mode during the PROGRAM TEST, the PROGRAM TEST function (and any breakpoint you may have specified) remain active after the restart.

| Status variables                                               | Using the "status variables" function, you can display the current signal states of certain operands (process variables).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                | The function activates system checkpoints in the CYCLE, in the STOP MODE and in the WAIT STATE.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                | When a checkpoint is reached, the PG displays the present signal status of the desired process variable. You can specify all process variables (inputs, outputs, flags, timers, counters and data words). No addressing error (ADF) is triggered in the process image area when accessing an address for which there is no I/O available.                                                                                                                                                                                                                                                                         |
| The function<br>during program<br>execution                    | If the function is activated in the RESTART or RUN modes, program execution<br>is continued until the system checkpoint "cycle" is reached. The signal states of<br>the operands are then scanned and output at the end of the cycle. Inputs are read<br>from the <b>process image</b> . Providing the function is not aborted, the signal states<br>are updated during program execution. In this case the signal states are not<br>scanned at every system checkpoint.<br>If the system checkpoint "cycle" is not reached, the signal states are not output<br>(e.g. in a continuous loop in the user program). |
| The function in<br>the STOP mode                               | If the STATUS VARIABLES function is active in the STOP mode, the signal states of the operands are output as they stand at the system checkpoint "stop". The important point to note here is that the <b>inputs</b> are scanned <b>directly</b> (not from the process image) and output. This feature, for example, allows you to check whether an input signal actually reaches the CPU. Even in multiprocessor operation, you can specify all inputs regardless of the assignment in DB 1. The outputs are read from the process image.                                                                         |
| The function in<br>the WAIT STATE                              | You can also call the STATUS VARIABLES function when the CPU is in the WAIT STATE caused by the PROGRAM TEST function. The signal states of the operands are scanned at the system checkpoint "wait state" and output. As in the stop mode, the inputs are scanned directly and the outputs are read from the <b>process image</b> .                                                                                                                                                                                                                                                                              |
| Changing the<br>operating<br>state/terminating<br>the function | When the CPU changes from one mode to another (e.g. RUN $\rightarrow$ STOP $\rightarrow$ MANUAL WARM RESTART), the function remains activated. STATUS VARIABLES is terminated by pressing the break key on the programmer.                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                | <b>Note</b><br>The variables are not output in every program cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Force                    | Using the FORCE function you can set the output bytes of the programmable controller to a particular signal state directly (avoiding the process image) or you can recognize process interface modules (digital peripherals 0 to 127) that do not acknowledge (message on the PG). You can check and directly control the process devices (actuators e.g. motor, valve) supplied with signals by the outputs.                                                                                                                                                         |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | Note<br>The "force" function is only permitted in the stop mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Function<br>sequence     | When you call the function in the STOP mode, the command output disable<br>function is cancelled (BASP = inactive). The <b>whole</b> digital peripheral area<br>(F000H to F07FH) is cleared, and the value "0" is written to each address. You<br>cannot interrupt this function while the peripherals are being cleared.<br>The peripheral outputs are forced in bytes directly and without affecting the<br>process output image.<br>In multiprocessor operation, you can force <b>all</b> peripheral outputs (regardless of<br>the peripheral assignment in DB 1). |
|                          | When the function is active (message "End of force fct" on the PG), you can<br>perform a COLD RESTART or a MANUAL WARM RESTART. If the CPU<br>once again changes to the STOP mode, you can use the force function again. The<br>process interface output modules are <b>not cleared</b> in this case.                                                                                                                                                                                                                                                                 |
| Terminating the function | You terminate the function by pressing the break key on the PG. The command output disable function is once again activated (BASP LED = on).                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Force variables          | Using the PG function FORCE VARIABLES, you can change the values of operands (process variables) once. You can do this in any CPU mode. You can specify all process variables. If you attempt to access an address in the range of the process image for which there is no I/O, no ADF is triggered. The modification becomes effective asynchronously to the system checkpoints, i.e. not till the end of the cycle. Remember that the forced values can be overwritten later (e.g. by the user program or when the process image is updated).                       |
|                          | <b>Note</b><br>The PG forces the I, Q and F process variables in bytes and the DW, T<br>and C variables in words.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                          | If you force <b>several operands</b> , the modified bytes (for DW, T and C the words) are changed in the CPU memory, distributed over several function calls.                                                                                                                                                                                                                                                                                                                                                                                                         |

## **11.3 Activities at Checkpoints**

Overview The table below shows you which activities of the PG functions are executed at the checkpoints.

|                                                   |        | System checkpoint |                 |                     |                 |
|---------------------------------------------------|--------|-------------------|-----------------|---------------------|-----------------|
| Activities of the online<br>functions             | "Stop" | "Cycle"           | "Wait<br>state" | "Asyn-<br>chronous" | check-<br>point |
| Input of the address:<br>write data <sup>1)</sup> | *      |                   | *               | *                   |                 |
| Block input:                                      | *      | *                 | *               | *                   |                 |
| declare block as valid                            |        |                   | *               |                     |                 |
| Delete block                                      | *      |                   | *               | *                   |                 |
| Compress memory:<br>shift blocks <sup>1) 2)</sup> | * 3)   | *                 |                 |                     |                 |
| START/STOP                                        | *      | *                 | *               | *                   |                 |
| OVERALL RESET                                     | *      |                   |                 | *                   |                 |
| STATUS: read and output data                      |        |                   |                 |                     | *               |
| STATUS VARIABLES: read                            |        |                   |                 |                     |                 |
| and output data                                   | *      | *                 | *               |                     |                 |
| PROGRAM TEST:                                     |        |                   |                 |                     |                 |
| preset breakpoints                                | *      | *                 | *               | *                   | *               |
| read and output data                              |        |                   |                 |                     | *               |
| FORCE (process interface modules) <sup>1)</sup>   | *      |                   |                 |                     |                 |
| FORCE VARIABLE <sup>1)</sup>                      | *      | *                 | *               | *                   |                 |

Table 11-2 Activities at checkpoints

1) Activities distributed over more than 1 system checkpoint

2)

Maximum one block per system checkpoint After compressing the memory in STOP, only COLD RESTART is permitted. 3)

## 11.4 Serial Link PG - PLC via 1st or 2nd Serial Interface

*Link possibilities* For the serial link PG - PLC there are the following possibilities:

- Direct link to the CPU via the standard cable.
- Link to the PG via the coordinator COR 923C. In this case the PG is connected via the cable to the coordinator. This means that the 1st serial interface is no longer available.
- Link to the PG via a PG multiplexer 757. The permitted cables can be found in the S5-135U/155U System Manual (/2/ in Chapter 13).
- Link to the PG via SINEC H1/L2/L1 and "swing cable"; the COR 923C or PG multiplexer can be connected in the link.

## 11.5 Parallel Operation of Two Serial PG Interfaces

*Introduction* You can use the second interface on the CPU 928B (SI 2) as a **PG interface** in exactly the same way as the first interface.

To be able to link your PG via this interface, you must also order the PG interface module in addition to your CPU 928B (the order number is listed in the S5-135U/155U System Manual /2/).



Fig. 11-2 Using the second interface as a PG interface

All the PG functions are available on both interfaces. The following sections contain only the information that you require if you work with PGs or OPs on both interfaces simultaneously.



Fig. 11-3 First example of a configuration



Fig. 11-4 Second example of a configuration

#### 11.5.1 Installation

**Procedure** To use the second interface of the CPU 928B as a PG interface, follow the steps below:

- 1. Install the PG submodule in the CPU 928B.
- 2. Connect the PG to the serial interface SI2.

#### 11.5.2 Operation

Range of<br/>functionsIf you use the second interface as a PG interface then initially the full range of<br/>functions of the standard PG interface is available on each interface. This<br/>remains true, providing the individual functions do not influence each other, i.e.,<br/>called sequentially one after the other.

To understand the exceptions to this, the PG functions can be divided into three groups:

| Group                   | Name                                                                                                                                       |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Short-running functions | Functions that execute a job and then are terminated.<br>(e.g. "transfer", "delete" etc.)                                                  |
| Long-running functions  | Functions that process a fixed number of jobs:<br>- "force",<br>- "program test".                                                          |
| Cyclic functions        | Functions that execute a job repeatedly until you<br>terminate them:<br>- "status block",<br>- "status variables",<br>- "force variables". |



#### Caution

With long-running and cyclic functions you must coordinate the activation of these functions on both PGs.

The table below lists the pairs of functions that you **cannot work with simultaneously**.

| Function active on the first PG:                                     | You <i>must not activate</i> this function on the second PG |
|----------------------------------------------------------------------|-------------------------------------------------------------|
| "Force"                                                              | Any function                                                |
| "Program test"                                                       | Any function                                                |
| A "status" function"                                                 | "Force"                                                     |
| A "status" function"                                                 | "Program test"                                              |
| A "status" function"                                                 | "Overall reset"                                             |
| "Status" on long running blocks or<br>blocks which are not processed | Any function                                                |

 Table 11-3
 Functions which cannot run simultaneously on both PGs

If you attempt to start one of the illegal functions, the second PG displays an error message, e.g.: "AS function disabled: function active".

The same error message or "Overflow in data exchange with PG" appears if the CPU 928B is currently processing functions of the other PG, which prevent your PG accessing the CPU within the monitoring time. Your input is then rejected. Repeat your input once the functions are completed on the other PG.

#### Note

Owing to the different performances and range of functions, time monitoring and the response to errors is not identical in all PGs and OPs.

If you activate the function "memory configuration" simultaneously on both PGs, the displays may be incorrect.



#### Caution

If you input, correct or delete blocks online on both PGs simultaneously, you must make sure that the blocks are not protected by the other PG before you access them.

"Status" of a block which is not processed or "status" in the STOP mode blocks the other interface for all functions.

#### 11.5.3 Sequence in Certain Operating Situations

Parallel operation with short-running functions If you work with PGs on both interfaces simultaneously, both PGs want to execute their functions independently of each other. As long as they stagger the jobs they send to the CPU, the jobs will be processed in the order in which they arrive.

The situation may, however, arise that the CPU 928B either receives two jobs simultaneously or receives a job from the second PG while a job from the first PG is still active.

Since simultaneous processing is not possible, the jobs are processed one after the other; the second job is, however, delayed by such a short time that it is hardly noticeable for the user.

When jobs are sent simultaneously, the sequence is as follows:



Fig. 11-5 Handling simultaneous jobs

From this sequence, you can see that both PGs can operate independently from each other, but that the one nevertheless affects the other. It is possible that both PGs process the same block simultaneously or that a block currently being processed by one PG is deleted by the other PG. With this configuration, you must always take into account the way in which input at one PG affects the other PG.

#### Parallel operation with long-running functions

The long-running functions "force" and ""program test" cannot interrupt other functions and cannot be interrupted by other functions. They can therefore not be executed parallel to other functions, i.e. they are treated as a standard job "en bloc".

Parallel operation with cyclic functions Cyclic functions can be executed both parallel to other cyclic and to short-running functions. The following example shows the standard sequence of the "status variables" function.





To allow a second PG to send a job to the CPU, the status function is interrupted between two requests and then continued on completion of the inserted job. Since the interrupting function requires CPU facilities, the whole CPU system facilities must be divided between the two functions, e.g. the updating of the data output by the "status variables" function takes somewhat longer.

With both PGs working simultaneously, the sequence shown in Figure 11.7 results.

This also applies when cyclic functions are active on both PGs; the two PGs then access the PLC alternately.



Fig. 11-7 Sequence of two parallel cyclic functions

Special feature with cyclic functions on both PGs If the interrupting function blocks the CPU 948 ("status" in a block that is not executed) the interrupted function is also blocked. It can only be resumed when the interrupting function is terminated.

When working simultaneously with two PGs, the following sequence results:



Fig. 11-8 Sequence when a function blocks the CPU 928B

*General notes* If "status variables", "force variables" (with the status display) or "status" is output on **one** interface and "compress memory", "delete block" or "transfer block" on the **other**, the status display can be corrupted.

# Α

# Appendix

# Contents of appendix A

Appendix A gives you additional information, such as runtime comparison, on several CPU types of the S5-135U programmable controllers.

# Overview of appendix A

| Section | Description                                                             | Page |
|---------|-------------------------------------------------------------------------|------|
| A.1     | Runtime Comparison between CPU 928-3UA21,<br>CPU 928B-3UB21 and CPU 948 | A-2  |
| A.2     | Error Identifiers                                                       | A-5  |
| A.3     | STEP 5 Operations not Contained in the CPU 928B                         | A-13 |
| A.4     | Identifiers for the Program Processing Levels                           | A-14 |
| A.5     | Example "ISTACK Evaluation"                                             | A-15 |

# A.1 Runtime Comparison between CPU 928-3UA21, CPU 928B-3UB21 and CPU 948

#### Definition of terms

#### • Basic time

The basic time is the part of the cyclic system runtime required without updating the process image, without transferring IPC flags and without interrupts or errors.

#### • Response time

The response time is the time from activating the program processing level PROCESS INTERRUPT for processing the first operation in OB 2. It is a prerequisite that OB 2 can be called **immediately** after recognizing the process interrupt. The response time is extended if the program **waits** until the next operation or block boundary

#### Runtime comparison

| Operation / processing                                                                                                                                        | CPU 928-3UA21                                                     | CPU 928B-3UB21                                            | CPU 948                                                                                    |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------|--|
| Typical operation execution times for bit operations:                                                                                                         |                                                                   |                                                           |                                                                                            |  |
| with<br>F, I, Q<br>D<br>formal operands                                                                                                                       | 0.9 μs<br>23 μs<br>22 μs                                          | 0.57 μs<br>3.4 μs<br>2.4 μs                               | 0.18 μs<br>0.7 μs<br>0.91 μs                                                               |  |
| Typical operati                                                                                                                                               | on execution times for w                                          | vord operations:                                          |                                                                                            |  |
| <ul> <li>load operations<br/>L FY (byte)<br/>L FW (word)<br/>L FD (double word)</li> <li>fixed point arithmetic</li> <li>floating point arithmetic</li> </ul> | 11 μs<br>11 μs<br>11 μs<br>11 23 μs<br>25 μs                      | 0.81 μs<br>0.9 μs<br>1.6 μs<br>0.9 10.4 μs<br>9.1 15.6 μs | 0.81 μs<br>0.5 μs<br>0.71 μs<br>0.55 3.8 μs<br>3.3 6.3 μs                                  |  |
| Cyclic program execution (single processor mode)                                                                                                              |                                                                   |                                                           |                                                                                            |  |
| Basic time calling OB 1/FB 0:                                                                                                                                 | 104/106 μs                                                        |                                                           | 65/– μs                                                                                    |  |
| Additional time for updating the process<br>image dependent on the number of I/O<br>bytes (n)<br>where $0 < n \le 128$                                        | I: 14 $\mu$ s + n * 1.1 $\mu$ s<br>Q: 5 $\mu$ s + n * 4.1 $\mu$ s |                                                           | $n \le 64:$<br>$64 \ \mu s + n * 2.3 \ \mu s$<br>n > 64:<br>$92 \ \mu s + n * 2.3 \ \mu s$ |  |

| <b>Operation</b> / processing                                                                                                                                        | CPU 928-3UA21                                                                                         | CPU 928B-3UB21                                                                    | CPU 948                                                                                                                                                       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Additional time for transfer of IPC flags depending on the number of IPC flags (n) where $0 < n \le 256$                                                             | I: 14 $\mu$ s + n * 1.4 $\mu$ s<br>Q: 5 $\mu$ s + n * 4.3 $\mu$ s                                     |                                                                                   | n ≤ 64:<br>64 μs + n * 2.1 μs<br>n > 64:<br>92 μs + n * 2.1 μs                                                                                                |
| Additional time for timer processing<br>depending on the timer field length (TFL)<br>TFL =0<br>TFL #0<br>n = number of currently active timers<br>(time base: 10 ms) | every 10 ms<br>10 μs<br>16 μs + TFL * 0.2 μs<br>(no difference between active and inactive<br>timers) |                                                                                   | every 10 ms<br>11.6 μs<br>16 μs + TFL * 0.2 μs                                                                                                                |
| Interro                                                                                                                                                              | ıpt-driven program proc                                                                               | essing                                                                            |                                                                                                                                                               |
| Extension of the cycle time by inserting an<br>empty OB 2 (without STEP 5 operations)<br>at an operation boundary                                                    | 300 µs                                                                                                | 300 µs                                                                            | 262 μs                                                                                                                                                        |
| Response time                                                                                                                                                        | 270 µs                                                                                                | 270 µs                                                                            | 175 μs                                                                                                                                                        |
| Tim                                                                                                                                                                  | e-driven program proces                                                                               | ssing                                                                             |                                                                                                                                                               |
| Extension of the cycle time by inserting an<br>empty OB 13 (without STEP 5 operations)<br>at an operation boundary                                                   | 310 μs for the first time interrupt OB                                                                | 310 µs for the first time interrupt OB                                            | 287 µs                                                                                                                                                        |
|                                                                                                                                                                      | 170 μs for each<br>further interrupt OB<br>due at the same time                                       | 170 μs for each<br>further interrupt OB<br>due at the same time                   |                                                                                                                                                               |
| Clock pulse for calling the time-driven<br>program (Time interrupt OB 10 to OB<br>18)                                                                                | 10, 20, 50, 100,<br>200, 500 ms,<br>1, 2, 5 sec                                                       | 10, 20, 50, 100,<br>200, 500 ms,<br>1, 2, 5 sec                                   | basic pulse rate of<br>1 255 ms per 10 ms:<br>10, 20, 50, 100,<br>200, 500 ms,<br>1, 2, 5 sec<br>or<br>10, 20, 40, 80,<br>160, 320, 640 ms,<br>1.28, 2.56 sec |
| Resolution times for clock-driven time interrupt (OB 9)                                                                                                              | _                                                                                                     | every minute,<br>every hour,<br>every day,<br>every month,<br>every year,<br>once | every minute,<br>every hour,<br>every day,<br>every month,<br>every year,<br>once                                                                             |
| Resolution time for delay interrupt (OB 6)                                                                                                                           | _                                                                                                     | 1 ms                                                                              | 1 ms                                                                                                                                                          |
|                                                                                                                                                                      | Cycle time monitoring                                                                                 |                                                                                   |                                                                                                                                                               |
| default<br>selectable between<br>triggerable                                                                                                                         | 150 ms<br>1 13000 ms<br>yes                                                                           | 150 ms<br>1 13000 ms<br>yes                                                       | 200 ms<br>1 2250 ms<br>yes                                                                                                                                    |

| <b>Operation</b> / processing                          | CPU 928-3UA21            | CPU 928B-3UB21               | CPU 948                       |
|--------------------------------------------------------|--------------------------|------------------------------|-------------------------------|
|                                                        | Size of the memory       |                              |                               |
| Size of the user memory<br>(in Kbytes) per submodule   | 64                       | 64                           | 640 or 1664                   |
| Size of the memory for data blocks (DB-RAM, in Kbytes) | approx. 46.6             | approx. 46.6                 | _                             |
| Т                                                      | imers and counters, flag | <u></u> ŞS                   |                               |
| Number of timers and counters                          | 256 each                 | 256 each                     | 256 each                      |
| Number of flags                                        | 2048 flags               | 2048 flags<br>+ 8192 S flags | 2048 flags<br>+ 32768 S flags |

## A.2 Error Identifiers

# Error IDs in system data RS 3 and RS 4

| RS 3  | RS 4                                                      | Explanation                                                                                                                                                                                             |  |  |  |
|-------|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|       | Structure of the block address lists (Evaluation of DB 0) |                                                                                                                                                                                                         |  |  |  |
| 8001H | уууун                                                     | Wrong block length                                                                                                                                                                                      |  |  |  |
| 8002H | ууууН                                                     | yyyy = addressof the block with the wrong length<br>Calculated end address of the block in the memory is wrong<br>yyyy = block address                                                                  |  |  |  |
| 8003H | уууун                                                     | Illegal block ID                                                                                                                                                                                        |  |  |  |
| 8004H | ууууН                                                     | yyyy = addressof the block with wrong ID<br>Organization block number too high (permitted: OB 1 to OB 39)<br>yyyy = address of the block with wrong number                                              |  |  |  |
| 8005H | ууууН                                                     | Data block number 0 (permitted: DB 1 to DB 255)<br>yyyy = address of the block with the wrong number                                                                                                    |  |  |  |
|       | Structu                                                   | rre of the address lists for updating the process image (Evaluation of DB 1)                                                                                                                            |  |  |  |
| 0410H | ууууН                                                     | Illegal iD:<br>- header ID missing or incorrect (correct KS MASK01)<br>- ID illegal (permitted KH DE00, DA00, CE00, CA00, BB00)<br>- end ID missing or incorrect (correct KH EEEE)<br>yyyy = illegal ID |  |  |  |
| 0411H | ууууН                                                     | "Digital iputs", number of addresses illegal (permitted 0 128)<br>yyyy = illegal number of addresses                                                                                                    |  |  |  |
| 0412H | ууууН                                                     | "Digital outputs", number of addresses illegal (permitted 0 128)<br>yyyy = illegal number of addresses                                                                                                  |  |  |  |
| 0413H | уууун                                                     | "IPC input flags", number of addresses illegal (permitted 0 256)                                                                                                                                        |  |  |  |
| 0414H | ууууН                                                     | yyyy = illegal number of addresses<br>"IPC output flags", number of addresses illegal (permitted 0 256)<br>yyyy = illegal number of addresses                                                           |  |  |  |
| 0415H | ууууН                                                     | Illegal number of timers (permitted: 256)<br>yyyy = illegal number of timers                                                                                                                            |  |  |  |
| 0419H | ууууН                                                     | Timeout in the digital inputs                                                                                                                                                                           |  |  |  |
| 041AH | ууууН                                                     | yyyy = address of the non-acknowledged input byte<br>Timeout in the digital ioutputs<br>yyyy = address of the non-acknowledged output byte                                                              |  |  |  |
| 041BH | ууууН                                                     | Timeout in IPC input flags<br>yyyy = address of the non-acknowledged IPC flag byte                                                                                                                      |  |  |  |
| 041CH | ууууН                                                     | Timeout in IPC output flags<br>yyyy = address of the non-acknowledged IPC flag byte                                                                                                                     |  |  |  |
|       | Evaluation of DB 2                                        |                                                                                                                                                                                                         |  |  |  |
| 0421H | DByyH                                                     | Data block not loaded                                                                                                                                                                                   |  |  |  |
| 0422H | FByyH                                                     | yy = number of the non-loaded data block<br>Function block not loaded                                                                                                                                   |  |  |  |
| 0423H | FByyH                                                     | yy = number of the non-loaded function block<br>Function block not recognized<br>yy = number of the non-recognized function block                                                                       |  |  |  |
| 0424H | FByyH                                                     | Function block loaded with wrong PG software<br>yy = number of the function block                                                                                                                       |  |  |  |
| 0425H | DByyH                                                     | Wrong closed loop controller data block length<br>yy = number of the data block                                                                                                                         |  |  |  |
| 0426H | -                                                         | There is not enough space in the DB RAM to shift the closed loop<br>controller DB from the user EPROM to the DB RAM                                                                                     |  |  |  |

| RS 3           | RS 4       | Explanation                                                                                                                              |  |  |  |  |  |  |
|----------------|------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|                | l          | Evaluation of DX 0                                                                                                                       |  |  |  |  |  |  |
| 0431H          | ууууН      | Illegal ID<br>-header ID missing or incorrect (correct KS MASKX0)<br>-field ID illegal<br>-end ID missing or incorrect (correct KH EEEE) |  |  |  |  |  |  |
| 0432H          | ууууН      | yyyy = illegal ID<br>Illegal parameter                                                                                                   |  |  |  |  |  |  |
| 0434H          | ууууН      | yyyy = illegal parameter<br>Illegal number of timers (permitted: 0256)<br>yyyy = wrong number of timers                                  |  |  |  |  |  |  |
| 0435H          | ууууН      | Illegal cycle monitoring time (permitted: 1ms to 13000ms)<br>yyyy = incorrect time                                                       |  |  |  |  |  |  |
|                | 1          | Evaluation of DX 2                                                                                                                       |  |  |  |  |  |  |
| 0451H<br>0452H | -<br>уууун | DX 2 length (without block header)< 4 words is not permitted<br>DX 2 length (without block header) is too short for the link type        |  |  |  |  |  |  |
| 0453H          | ууууН      | yyyy = length of DX 2<br>Type of link illegal                                                                                            |  |  |  |  |  |  |
| 0454H          | xx00H      | yyyy = link type<br>Data ID for static parameter set illegal (not 44H, 58H)<br>xx = data ID                                              |  |  |  |  |  |  |
| 0455H          | ххууН      | Block for static parameter set illegal<br>xx = ID / yy = DB number                                                                       |  |  |  |  |  |  |
| 0456H          | ххууН      | Static parameter set does not exist<br>xx = ID / yy = DB number                                                                          |  |  |  |  |  |  |
| 0457H          | ууууН      | Static parameter set too short<br>yyyy = number of the non-existent DW                                                                   |  |  |  |  |  |  |
| 0458H          | xx00H      | Data ID for dynamic parameter set illegal (not 44H, 58H, 00H)<br>xx = data ID                                                            |  |  |  |  |  |  |
| 0459H          | ххууН      | Block for dynamic parameter set illegal<br>xx = ID / yy = DB number                                                                      |  |  |  |  |  |  |
| 0045AH         | xx00H      | Data ID for send mail box / job mail box illegal (not 44H, 58H,00H)<br>xx = data ID                                                      |  |  |  |  |  |  |
|                |            | Evaluation of DX 2 (continued)                                                                                                           |  |  |  |  |  |  |
| 045BH          | ххууН      | Block for send mail box 7 job mail box illegal<br>xx = ID / yy = DB number                                                               |  |  |  |  |  |  |
| 045CH          | xx00H      | Data ID for receive mail box illegal (not 44H, 58H, 00H)<br>xx = data ID                                                                 |  |  |  |  |  |  |
| 045DH          | ххууН      | Block for receive mail box illegal<br>xx = ID / yy = DB number                                                                           |  |  |  |  |  |  |
| 045EH          | xx00H      | Data ID for coordination byte illegal (not 44H, 58H, 4DH)<br>xx = ID                                                                     |  |  |  |  |  |  |
| 045FH          | ххууН      | Block for coordination byte illegal<br>xx = ID / yy = DB number                                                                          |  |  |  |  |  |  |
| 0460H          | ххууН      | Block for coordination byte does not exist<br>xx = ID / yy = DB number                                                                   |  |  |  |  |  |  |
| 0461H          | ууууН      | Data word for coordination byte does not exist<br>yyyy = number of non-existent DW                                                       |  |  |  |  |  |  |

#### Error IDs in ACCU 1 and ACCU 2

| ACCU-1-L       | ACCU-2-L       | Explanation                                                                                                  | OB called |
|----------------|----------------|--------------------------------------------------------------------------------------------------------------|-----------|
|                |                | <b>REG-FE</b> (closed loop controller error)                                                                 |           |
| 0801H          | DByyH          | Sampling time error                                                                                          | OB 34     |
| 000011         |                | yy = number of the affected controller data block                                                            |           |
| 0802H          | DByyH          | Controller data block not loaded<br>yy = number of the data block not loaded                                 |           |
| 0803H          | FByyH          | Controller function block not loaded                                                                         |           |
| 000 477        |                | yy = number of the function block not loaded                                                                 |           |
| 0804H          | FByyH          | Controller function block not regcognized<br>yy = number of the function block not recognized                |           |
| 0805H          | FByyH          | Controller function block loaded with wrong PG software                                                      |           |
|                |                | yy = function block number                                                                                   |           |
| 0806H          | DByyH          | Wrong controller data block length                                                                           |           |
| 0880H          | 00yyH          | yy = data block number<br>Timeout (QVZ) during controller processing                                         |           |
| 000011         | 009911         | yy = number of the I/O byte that caused the QVZ                                                              |           |
|                |                |                                                                                                              |           |
|                |                | WECK-FE (collision of timed interrupts)                                                                      |           |
| 1001H          | 0016H          | Collision of timed interrupts - OB 10 (10 ms)                                                                | OB 33     |
|                | 0014H          | Collision of timed interrupts - OB 11 (20 ms)                                                                |           |
|                | 0012H          | Collision of timed interrupts - OB 12 (50 ms)                                                                |           |
|                | 0010H          | Collision of timed interrupts - OB 13 (100 ms)                                                               |           |
|                | 000EH          | Collision of timed interrupts - OB 14 (200 ms)                                                               |           |
|                | 000CH          | Collision of timed interrupts - OB 15 (500 ms)                                                               |           |
|                | 000AH<br>0008H | Collision of timed interrupts - OB 16 (1 sec)                                                                |           |
|                | 0008H<br>0006H | Collision of timed interrupts - OB 17( 2 sec)Collision of timed interrupts - OB 18( 5 sec)                   |           |
|                |                |                                                                                                              |           |
|                |                | BCF (operation code error)/substitution error                                                                |           |
| 1801H          | _              | Substitution error with the DO RS operation                                                                  | OB 27     |
| 1802H          | -              | Substitution error with the DO DW, DO FW operations                                                          |           |
| 1803H          | -              | Substitution error with the DO=, DI= operations                                                              |           |
| 1804H          | —              | Substitution error with the $L=$ , = T operations                                                            |           |
| 1805H          | -              | Substitution error with the A=, AN=, O=, ON=,                                                                |           |
| 190411         |                | S = and RB= operations                                                                                       |           |
| 1806H          | _              | Substitution error with the RD=, LD=, FR=, SFD=,<br>SR=, SP=, SSU= and SEC= operations                       |           |
|                |                |                                                                                                              |           |
|                |                | BCF (operation code error)                                                                                   |           |
| 1811H          | _              | Operation with illegal opcode                                                                                | OB 29     |
| 1812H          | _              | Illegal opcode for an operation in which the high byte                                                       |           |
|                |                | of the first operation word contains the value 68H                                                           |           |
| 181 <b>3</b> H | _              | Illegal opcode for an operation in which the high byte                                                       |           |
| 101 / 17       |                | of the first operation word contains the value 78H                                                           |           |
| 1814H          | _              | Illegal opcode for an operation in which the high byte                                                       |           |
| 1815H          |                | of the first operation word contains the value 70H<br>Illegal opcode for an operation in which the high byte |           |
| 101311         | _              | of the first operation word contains the value 60H                                                           |           |
|                |                |                                                                                                              |           |

| ACCU-1-L ACCU-2-L Explanation |   |                                                                                                          |       |  |  |
|-------------------------------|---|----------------------------------------------------------------------------------------------------------|-------|--|--|
|                               |   | BCF (operation code error)/parameter error                                                               |       |  |  |
|                               |   | Illegal parameter with the following:                                                                    | OB 30 |  |  |
| 1821H                         | _ | C DB 0, 1, 2                                                                                             |       |  |  |
| 182BH                         | _ | JU(C) OB 0                                                                                               |       |  |  |
| 182CH                         | - | JU(C) OB > 39: special function does not exist                                                           |       |  |  |
| 182DH                         | - | CX DX 0, CX DX 1 and CX DX 2                                                                             |       |  |  |
| 182EH<br>182FH                | - | LFW/TFW/LPW/TPW/LOW/TOW/LDD/TDD/DOFW:255<br>LIW/TIW/LQW/TQW 127                                          |       |  |  |
| 182FH<br>1830H                | _ | L FD / T FD 253, 254, 255                                                                                |       |  |  |
| 1831H                         | _ | L ID/T ID/L QD/T QD 125, 126, 127                                                                        |       |  |  |
| 1832H                         | _ | RLD/RRD/SSD/SLD 33-255                                                                                   |       |  |  |
| 1833H                         | - | SLW/SRW/LIR/TIR 16-255                                                                                   |       |  |  |
| 1834H                         | - | SED/SEE 32-255                                                                                           |       |  |  |
| 1835H                         | - | A=/AN=/O=/ON=/S=/RB=/==/RD=/FR=/SP=/SR=/                                                                 |       |  |  |
| 102/11                        |   | SEC=/SSU=/SFD=/L=/LD=/LW=/T= 0, 127-255                                                                  |       |  |  |
| 1836H<br>1837H                | _ | DO=/LDW= 0, 126-255<br>A S/O S/S S/= S/AN S/ON S/R S byte number > 1023                                  |       |  |  |
| 1837H<br>1838H                | _ | A S/O S/S S/= S/AN S/ON S/R S byte number $> 7$                                                          |       |  |  |
| 1839H                         | _ | L SY/T SY parameter > 1023                                                                               |       |  |  |
| 183AH                         | _ | L SW/T SW parameter > 1022                                                                               |       |  |  |
| 183BH                         | - | L SD/T SD parameter >1020                                                                                |       |  |  |
| 183CH                         | - | G DB/GX DX parameter 0, 1 or 2 (DB or DX 0, 1, 2 cannot                                                  |       |  |  |
|                               |   | be generated)                                                                                            |       |  |  |
|                               |   | LZF (runtime errors)/block not loaded                                                                    |       |  |  |
| 1A01H                         |   | Plack not loaded for CDP operation                                                                       | OB 19 |  |  |
| 1A01H<br>1A02H                |   | Block not loaded for C DB operation<br>Block not loaded for CX DX operation                              |       |  |  |
| 1A03H                         | _ | Block not loaded for JU(C) FB, OB 1 to OB 39,                                                            |       |  |  |
|                               |   | PB, SB operation                                                                                         |       |  |  |
| 1A04H                         | - | Block not loaded for DOU/DOC FX operation                                                                |       |  |  |
| 1A05H                         | - | Block not loaded for OB 254 or 255 operation                                                             |       |  |  |
| 1A06H                         | - | Block not loaded for OB 182 operation                                                                    |       |  |  |
| 1A07H                         | _ | Block not loaded for OB 150/OB 151 operation                                                             |       |  |  |
|                               |   | LZF (runtime error)/load or transfer error                                                               |       |  |  |
|                               |   |                                                                                                          | OB 32 |  |  |
| 1A11H                         | - | Access to a non-defined data word with A/AN D, O/ON D, S/R D, = D                                        |       |  |  |
| 1A12H                         | _ | Transfer error with TDR to a non-defined data word                                                       |       |  |  |
| 1A13H<br>1A14H                | - | Transfer error with TDL to a non-defined data word<br>Transfer error with TDW to a non-defined data word |       |  |  |
| 1A14H<br>1A15H                | _ | Transfer error with TDD to a non-defined data word<br>Transfer error with TDD to a non-defined data word |       |  |  |
| 1A15H<br>1A16H                | _ | Load error with LDR to a non-defined data word                                                           |       |  |  |
| 1A17H                         | _ | Load error with LDL to a non-defined data word                                                           |       |  |  |
| 1A18H                         | _ | Load error with LDW to a non-defined data word                                                           |       |  |  |
| 1A19H                         | _ | Load error with LDD to a non-defined data word                                                           |       |  |  |
|                               |   |                                                                                                          |       |  |  |
|                               |   |                                                                                                          |       |  |  |

| ACCU-1-L | ACCU-2-L | Explanation                                                | OB called |
|----------|----------|------------------------------------------------------------|-----------|
|          |          | LZF (runtime error)/other runtime errors                   |           |
|          |          | Error indicated for/by :                                   |           |
| 1A21H    | _        | G DB, GX DX: data block already exists                     | OB 31     |
| 1A22H    | _        | G DB, GX DX: illegal number of data words                  |           |
|          |          | (<1  or  > 4091)                                           |           |
| 1A23H    | _        | G DB, GX DX: not enough space in the RAM                   |           |
| 1A25H    | _        | DI: illegal parameter in ACCU 1 (< 1 or > 125)             |           |
| 1A29H    | _        | Bracket stack under of overflow after 'A(', 'O(, ')'       |           |
| 1A2AH    | _        | C DB, CX DX: block length in data block header too short   |           |
|          |          | (length < 5 words)                                         |           |
| 1A2BH    | _        | Function block loaded with wrong PG software               |           |
| 1A2CH    | _        | ACR: illegal page number in ACCU-1-L (> 255)               |           |
| 1A31H    | _        | OB 254 or OB 255 (shift) or OB 250:                        |           |
|          |          | destination data block already exists in DB-RAM            |           |
| 1A32H    | _        | OB 254 or OB 255 (duplicate):                              |           |
|          |          | destination data block already exists in DB-RAM            |           |
| 1A33H    | _        | OB 254 or OB 255 or OB250:                                 |           |
|          |          | not enough space in the DB-RAM                             |           |
| 1A34H    | 0001H    | OB 182: data field written to illegally                    |           |
| 1A34H    | 0100H    | OB 182: address area type illegal                          |           |
| 1A34H    | 0101H    | OB 182: data block number illegal                          |           |
| 1A34H    | 0102H    | OB 182: "number of the first parameter word" illegal       |           |
| 1A34H    | 0200H    | OB 182: "source data block type" illegal                   |           |
| 1A34H    | 0201H    | OB 182: "source data block number" illegal                 |           |
| 1A34H    | 0202H    | OB 182: "number of the first data word in the source       |           |
|          |          | to be transferred" illegal                                 |           |
| 1A34H    | 0203H    | OB 182: a value $< 5$ words is entered in the block header |           |
|          |          | as the length of the source data block                     |           |
| 1A34H    | 0210H    | OB 182: "destination data block type" illegal              |           |
| 1A34H    | 0211H    | OB 182: "destination data block number" illegal            |           |
| 1A34H    | 0212H    | OB 182: "number of the first destination data word         |           |
|          |          | to be transferred" illegal                                 |           |
| 1A34H    | 0213H    | OB 182: a value < 5 words is entered in the block header   |           |
|          |          | as the length of the destination data block                |           |
|          |          |                                                            |           |

| ACCU-1-L        | ACCU-2-L | CCU-2-L Explanation                                          |       |  |  |  |  |
|-----------------|----------|--------------------------------------------------------------|-------|--|--|--|--|
|                 |          | LZF (runtime error)/other runtime errors (continued)         | OB 31 |  |  |  |  |
|                 |          | Error indicated for/by :                                     |       |  |  |  |  |
| 1A34H           | 0220H    | OB 182: "number of data words to be transferred" illegal     |       |  |  |  |  |
|                 | 022011   | (=0 or > 4091)                                               |       |  |  |  |  |
| 1A34H           | 0221H    | OB 182: source data block too short                          |       |  |  |  |  |
| 1A34H           | 0222H    | OB 182: destination data block too short                     |       |  |  |  |  |
| 1A34H           | 0223H    | OB 182: destination data block in EPROM                      |       |  |  |  |  |
| 1A35H           | _        | OB 250: number of the transfer block illegal                 |       |  |  |  |  |
| 1A36H           | _        | OB 250: different length in DB x and DB $x+1$ or DX x        |       |  |  |  |  |
| 11 10 011       |          | and DX x+1                                                   |       |  |  |  |  |
| 1A3AH           | _        | OB 221: illegal value for the new cycle time (cycle time     |       |  |  |  |  |
| 11 27 11        |          | <1  ms or  > 13 000  ms)                                     |       |  |  |  |  |
| 1A3BH           | _        | OB 223: different start-up types for the CPUs involved in    |       |  |  |  |  |
| 116,5011        |          | multiprocessor operation                                     |       |  |  |  |  |
| 1A41H           | _        | OB 240, OB 241 or OB 242:                                    |       |  |  |  |  |
| 17 17111        |          | illegal shift register or data block number                  |       |  |  |  |  |
|                 |          | (no. $< 192 \text{ or } > 255$ )                             |       |  |  |  |  |
| 1A42H           | _        | OB 241: shift register not initialized                       |       |  |  |  |  |
| 1A43H           |          | OB 240: not enough space in the DB-RAM                       |       |  |  |  |  |
| 1A44H           | _        | OB 240: data word DW 0 dof the data block does not           |       |  |  |  |  |
| 1A44II<br>1A45H | _        | contain the value '0'                                        |       |  |  |  |  |
| 1A4511          | _        | OB 240: illegal shift register length in DW 1                |       |  |  |  |  |
| 14461           |          |                                                              |       |  |  |  |  |
| 1A46H           | _        | (not between 2 and 256)                                      |       |  |  |  |  |
| 1A47H           | _        | OB 240: illegal pointer position or number of pointers $> 5$ |       |  |  |  |  |
| 1A48H           | _        | OB 120: illegal value in ACCU 1 or ACCU-2-L                  |       |  |  |  |  |
| 1A49H           | _        | OB 122: illegal value in ACCU 1                              |       |  |  |  |  |
| 1A4AH           | _        | OB 110: illegal value in ACCU 1 or ACCU-2-L                  |       |  |  |  |  |
| 1A4BH           | -        | OB 121: illegal value in ACCU 1 or ACCU-2-L                  |       |  |  |  |  |
| 1A4CH           | 0001H    | OB 123: illegal value in ACCU 1                              |       |  |  |  |  |
| 1A4CH           | 0100H    | OB 150: function number illegal $(= 0 \text{ or } > 2)$      |       |  |  |  |  |
| 1A4CH           | 0101H    | OB 150: address area type illegal                            |       |  |  |  |  |
| 1A4CH           | 0102H    | OB 150: data block number illegal                            |       |  |  |  |  |
| 1A4CH           | 0103H    | OB 150: "number of the first data field word" illegal        |       |  |  |  |  |
| 4.4.4011        | 000111   | OB 150: a value < 5 words is entered in the block header     |       |  |  |  |  |
| 1A4CH           | 0201H    | as the length of the data block                              |       |  |  |  |  |
| 1A4CH           | 0202H    | OB 150: year specified in data field illegal                 |       |  |  |  |  |
| 1A4CH           | 0203H    | OB 150: month specified in data field illegal                |       |  |  |  |  |
| 1A4CH           | 0204H    | OB 150: day of month specified in data field illegal         |       |  |  |  |  |
| 1A4CH           | 0205H    | OB 150: weekday specified in data field illegal              |       |  |  |  |  |
| 1A4CH           | 0206H    | OB 150: hour specified in data field illegal                 |       |  |  |  |  |
| 1A4CH           | 0207H    | OB 150: minute specified in data field illegal               |       |  |  |  |  |
| 1A4CH           | 0208H    | OB 150: second specified in data field illegal               |       |  |  |  |  |
| 1A4CH           | 0209H    | OB 150: "1/100 second" specified in data field not           |       |  |  |  |  |
| 1A4CH           | 020AH    | equal to 0                                                   |       |  |  |  |  |
| 1A4DH           | 0001H    | OB 150: data field word 3 /bits 0 to 3 not equal to 0        |       |  |  |  |  |
| 1A4DH           | 0100H    | OB 150: hour format does not match setting in OB 151         |       |  |  |  |  |
| 1A4DH           | 0101H    | OB 151: function number illegal (= $0 \text{ or } > 2$ )     |       |  |  |  |  |
|                 |          | OB 151: address area type illegal                            |       |  |  |  |  |
|                 |          | OB 151: data block number illegal                            |       |  |  |  |  |

| ACCU-1-L       | ACCU-2-L       | Explanation                                                                                                | OB called |
|----------------|----------------|------------------------------------------------------------------------------------------------------------|-----------|
|                |                | LZF (runtime error)/other runtime errors (continued)                                                       |           |
|                |                |                                                                                                            | OB 31     |
|                |                | Error indicated for/by :                                                                                   |           |
| 1A4DH          | 0102H          | OB 151: "number of the first data field word" illegal                                                      |           |
| 1A4DH          | 0103H          | OB 151: a value $< 5$ words is entered in the block header                                                 |           |
|                |                | as the length of the data block                                                                            |           |
| 1A4DH          | 0201H          | OB 151: year specified in the data field illegal                                                           |           |
| 1A4DH          | 0202H          | OB 151: month specified in the data field illegal                                                          |           |
| 1A4DH          | 0203H          | OB 151: day of month specified in the data field illegal                                                   |           |
| 1A4DH          | 0204H          | OB 151: weekday specified in the data field illegal                                                        |           |
| 1A4DH          | 0205H          | OB 151: hour specified in the data field illegal                                                           |           |
| 1A4DH          | 0206H          | OB 151: minute specified in the data field illegal                                                         |           |
| 1A4DH          | 0207H          | OB 151: second specified in the data field illegal                                                         |           |
| 1A4DH          | 0208H          | OB 151: "1/100 second" specified in data field is not equal to 0                                           |           |
| 1A4DH<br>1A4DH | 0209H<br>020AH | OB 151: job type in data field illegal (> 7)<br>OB 151: hour format does not match satting in OB 150.      |           |
| IA4DH          | 020AH          | OB 151: hour format does not match setting in OB 150                                                       |           |
| 1A4EH          | 0001H          | OB 152: function number illegal (not 0 to 3 or                                                             |           |
|                |                | 8 to 15)                                                                                                   |           |
| 1A4FH          | 0001H          | OB 153: function number illegal (=0 or <0)                                                                 |           |
| 1A4FH          | 0002H          | OB 153: delay time illegal                                                                                 |           |
| 1A50H          | -              | LRW, TRW: the calculated memory address < BR + constant>                                                   |           |
| 1A51H          | _              | is not in the range "0. EDFFH" (see Chapter 9)<br>LRD, TRD: the calculated memory address < BR + constant> |           |
| 1A52H          | -              | is not in the range "0 EDFEH" (see Chapter 9)<br>TSG, LY GB, LW GW, TY GB, TW GW:                          |           |
|                |                | the calculated linear address < BR + constant><br>is not in the range "0 EFFFH"                            |           |
| 1A53H          |                | LY GW, LW GD, TY GW, TW GD:                                                                                |           |
| 110511         | _              | the calculated linear address < BR + constant>                                                             |           |
|                |                | is not in the range "0 EFFEH"                                                                              |           |
| 1A54H          | _              | LY GD, TY GD:                                                                                              |           |
|                |                | the calculated linear address < BR + constant>                                                             |           |
|                |                | is not in the range "0 EFFCH"                                                                              |           |
| 1A55H          | _              | TSC, LY CB, LW CD, TY CW, TW CD:                                                                           |           |
|                |                | the calculated page address < BR + constant>                                                               |           |
|                |                | is not in the range "F400H EBFFH"                                                                          |           |
| 1A56H          | _              | LY CW, LW CD, TY CW, TW CD:                                                                                |           |
|                |                | the calculated page address < BR + constant>                                                               |           |
|                |                | is not in the range "F400H FFFEH"                                                                          |           |
| 1A57H          | —              | LY CD, TY CD:                                                                                              |           |
|                |                | the calculated page address < BR + constant><br>is not in the range "F400H FBFCH"                          |           |
|                |                |                                                                                                            |           |
|                |                |                                                                                                            |           |
|                |                |                                                                                                            |           |

| ACCU-1-L | ACCU-2-L | Explanation                                                                                             | OB called |
|----------|----------|---------------------------------------------------------------------------------------------------------|-----------|
|          |          | LZF (runtime error)/other runtime errors (continued)                                                    | OB 31     |
|          |          | Error indicated for/by :                                                                                | 00 51     |
| 1A58H    | _        | TNW/TNB: the source block is not completely in one of                                                   |           |
|          |          | the following areas:                                                                                    |           |
|          |          | 0000 7FFF user memory (see Chapter 9)                                                                   |           |
|          |          | 8000 DD7F DB-RAM                                                                                        |           |
|          |          | DD80 E3FF DB 0                                                                                          |           |
|          |          | E400E7FF S flags                                                                                        |           |
|          |          | E800 EDFF system data (RI, RJ, RS, RT, C, T)                                                            |           |
|          |          | EE00. EFFF flags, process image                                                                         |           |
| 1A59H    |          | F000 FFFF peripherals<br>TNW/TNB: the destination block is not completely in one of                     |           |
| ТАЈУП    | _        | the following areas:                                                                                    |           |
|          |          | 0000 7FFF user memory (see Chapter 9)                                                                   |           |
|          |          | 8000 DD7F DB-RAM                                                                                        |           |
|          |          | DD80 E3FF DB 0                                                                                          |           |
|          |          | E400 E7FF S flags                                                                                       |           |
|          |          | E800 EDFF system data (RI, RJ, RS, RT, C, T)                                                            |           |
|          |          | EE00 EFFF flags, process image                                                                          |           |
|          |          | F000 FFFF peripherals                                                                                   |           |
|          |          | QVZ (timeout)                                                                                           |           |
| 1E23H    | ууууН    | Timeout (QVZ) in the user program when accessing the<br>peripherals<br>yyyy = QVZ address               | OB 23     |
|          | TT       |                                                                                                         |           |
| 1E25H    | ууууН    | Timeout outputting the process image of the digital                                                     | OB 24     |
|          |          | outputs                                                                                                 |           |
| 1E26H    |          | yyyy = address of the non-acknowledged output byte<br>Timeout updating the process image of the digital |           |
| 1Е20П    | ууууН    | inputs                                                                                                  |           |
| 450511   |          | yyyy = address of the non-acknowledged input byte                                                       |           |
| 1E27H    | ууууН    | Timeout updating the IPC input flags<br>yyyy = address of the non-acknowledged IPC flag byte            |           |
| 1E28H    | 5555=    | Timeout updating the IPC output flags                                                                   |           |
| 11.2011  | ууууН    | yyyy = address of the non-acknowledged IPC flag byte                                                    |           |
|          | <u> </u> | ADF (adressing error)                                                                                   | 1         |
| 1E40H    | ууууН    | Adressing error (ADF) in the user program<br>yyyy = ADF address                                         | OB 25     |

#### A.3 STEP 5 Operations not Contained in the CPU 928B

Please note that the following STEP 5 operations belonging to the CPU 946/947 and CPU 948 **cannot** be processed in the CPU 928B.

| Operation                                   | Function                                           |
|---------------------------------------------|----------------------------------------------------|
| BAS                                         | Block command output                               |
| BAF                                         | Release command output                             |
| <b>TB</b> I, Q, F, C, T, D, RI, RJ, RS, RT  | Test bit for signal status '1'                     |
| <b>TBN</b> I, Q, F, C, T, D, RI, RJ, RS, RT | Test bit for signal stauts '0'                     |
| SU I, Q, F, C, T, D, RI, RJ, RS, RT         | Set bit unconditionally                            |
| <b>RU</b> I, Q, F, C, T, D, RI, RJ, RS, RT  | Reset bit unconditionally                          |
| LIM                                         | Load interrupt mask                                |
| SIM                                         | Set interrupt mask                                 |
| UBE                                         | Interrupt block end                                |
| STW                                         | Stop operation in time-driven interrupt processing |
| IAE                                         | Disable addressing error interrupt                 |
| RAE                                         | Enable addressing error interrupt                  |
| RAI                                         | Enable requested interrupt processing              |
| IAI                                         | Disable requested interrupt processing             |

### A.4 Identifiers for the Program Processing Levels

The identifiers correspond to the identifiers entered in the ISTACK under **LEVEL** (hexadecimal).

| Identifier     | Level                            |
|----------------|----------------------------------|
| 0002H          | Cold restart                     |
| 0004H          | Cycle                            |
| 0006H          | Time-driven interrupt 5 sec      |
| 0008H          | Time-driven interrupt 2 sec      |
| 000AH          | Time-driven interrupt 1 sec      |
| 000CH          | Time-driven interrupt 500 ms     |
| 000EH          | Time-driven interrupt 200 ms     |
| 0010H          | Time-driven interrupt 100 ms     |
| 0012H          | Time-driven interrupt 50 ms      |
| 0014H          | Time-driven interrupt 20 ms      |
| 0016H          | Time-driven interrupt 10 ms      |
| 0018H          | Timed job                        |
| 001AH          | Not used                         |
| 001CH          | Closed loop control              |
| 001EH          | Not used                         |
| 0020H          | Delay interrupt                  |
| 0022H          | Not used                         |
| 0024H          | Process interrupt                |
| 0026H          | Not used                         |
| 0028H          | Retentive manual cold restart    |
| 002AH          | Retentive automatic cold restart |
| 002CH          | Abort                            |
| 002EH          | Interface error                  |
| 00 <b>3</b> 0H | Collision of timed interrupts    |
| 0032H          | Closed loop controller error     |
| 0034H          | Cycle error                      |
| 0036H          | Not used                         |
| 0038H          | Operation code error             |
| 003AH          | Runtime error                    |
| 003CH          | Addressing error                 |
| 003EH          | Timeout                          |
| 0040H          | Not used                         |
| 0042H          | Not used                         |
| 0044H          | Manual warm restart              |
| 0046H          | Automatic warm restart           |

#### A.5 Example "ISTACK Evaluation"

This (simplified) example illustrates how to evaluate the ISTACK.

For more detailed information, you should also refer to Section 5.3 "Control Bits and the Interrupt Stack".

**Ready to start?** The CPU has interrupted cyclic program processing and has changed to the stop mode.

*Error analysis* To find the cause of the interruption, select the programmer online function "output ISTACK".

The control bits then appear on the PG screen as shown below:

| 00           | NTROL        | BITS        |         |             |            |              |              |
|--------------|--------------|-------------|---------|-------------|------------|--------------|--------------|
| >>STP<<<br>X | STP-6        | FE-STP      | BARBEND | PG-STP      | STP-SCH    | STP-BEF<br>X | MP-STP       |
| >>ANL<<      | ANL-6        | NEUSTA<br>X | MWA     | A W A       | ANL-2      | NEUZU<br>X   | MWA-ZUL<br>X |
| >>RUN<<      | RUN-6        | EINPROZ     | BARB    | OB1GEL<br>X | FB0GEL     | OBPROZA      | OBWECKA      |
| 32KWRAM      | 16KWRAM<br>X | 8KWRAM      | EPROM   | KM-AUS      | KM-EIN     | DIG-EIN<br>X | DIG-AUS<br>X |
| URGELOE      | URL-IA       | STP-VER     | ANL-ABB | UA-PG       | UA-SYS     | UA-PRFE      | UA-SCH       |
| DX0-FE       | FE-22        | MOF-FE      | RAM-FE  | DB0-FE      | DB1-FE     | DB2-FE       | KOR-FE       |
| NAU          | PEU          | BAU         | STUE-FE | ΖΥΚ         | QVZ        | ADF          | WECK-FE      |
| BCF          | FE-6         | FE-5        | FE-4    | FE-3        | L Z F<br>X | REG-FE       | DOPP-FE      |

The "X"s in the control bits indicate the current operating status of the CPU (>>STP<<), and certain characteristics of the CPU are marked (OB 1 loaded, single processor mode, 16 KW user memory etc.). In the top line the cause of the stoppage is indicated as **STP-BEF**. It is assumed that you have not programmed an STP operation in your STEP 5 user program. This means that the stoppage was caused by a stop operation from the system program because an error OB was not loaded. The identifier **LZF** is marked in the bottom line.

It is possible that the system program has detected a runtime error and that the corresponding error organization block is not programmed. Since there are various runtime errors, and you cannot possibly know which of them has occurred, the information shown in the control bits is not yet sufficient for reliable diagnosis.

You can now display the actual ISTACK:

| ( | INTERF              | RUPT ST     | ACK |                              |          |                     |      |                         |     |      |      |                |       |      |
|---|---------------------|-------------|-----|------------------------------|----------|---------------------|------|-------------------------|-----|------|------|----------------|-------|------|
|   | DEPTH:              | 01          |     |                              |          |                     |      |                         |     |      |      |                |       |      |
|   | OP REG:<br>BST-STP: | 0000<br>000 | -   | SAC:<br>SAC-NO.:<br>REL-SAC: |          | 0000<br>226<br>0006 |      | DB-AD<br>DB-NG<br>DBL-F | D.: |      | 0000 | BA-ADD:<br>-NC |       | 0000 |
|   | LEVEL:              | 003/        | 4   | UAMK:                        |          | 0120                |      | ICRW                    |     |      | 0000 |                |       |      |
|   | ACCU1:              | 0000 0A0    | 1   | ACCU2:                       | 0000     | 0000                |      | ACCU                    | 13: | 0000 | 0000 | ACCU4:         | 0000  | 0000 |
|   | CONDITION           | N CODE:     |     | CC1                          | CC0      |                     | OVFL | -                       | OVF | LS   | OR   | Ē              | RAB   |      |
|   |                     |             |     | STATUS                       | RLO      |                     |      |                         |     |      |      |                |       |      |
|   | CAUSE OF            | INTERR.:    |     | NAU                          | PEU      |                     | BAU  |                         | MPS | TP   | ZYK  | Q              | νz    |      |
|   |                     |             |     | ADF                          | STP<br>X |                     | BCF  |                         | S-6 | ;    | LZF  | R              | EG-FE |      |
|   |                     |             |     | STUEB                        | STUE     | U                   | WEC  | к                       | DOP | Ρ    |      |                |       | ,    |

The ISTACK at **depth 01** represents the program processing level that was last active before the transition to the stop mode. From the identifier **003A** (after LEVEL) you can see that this is the ISTACK of the program processing level **RUNTIME ERROR**. The error identifier **00001A01** is entered in **ACCU 1**. This tells you that the runtime error was caused by calling a data block that was not loaded using the operation "C DB". Since the corresponding error, OB 19, does not exist in our user program, the system program aborted program execution (STP). The interrupt display mask word **ICMK** also contains the cause of interrupt. The identifier **0120** corresponds to the bit pattern "**0000 0001 0010 0000**". Bit  $2^5$  (LZF) and Bit  $2^8$  (STP) are set.

You must now find out which block and which operation caused the runtime error.

| $\left( \right)$ | INTERF    | RUPT STACH | <                   |           |        |                      |      |      |         |           |
|------------------|-----------|------------|---------------------|-----------|--------|----------------------|------|------|---------|-----------|
|                  | DEPTH     | 02         |                     |           |        |                      |      |      |         |           |
|                  | OP REG:   | 2006       | SAC:                | 0037      |        | DB-ADD:              |      | 0000 | BA-ADD: | 0000      |
|                  | BST-STP:  | 0001       | OB-NO.:<br>REL-SAC: | 0004      | 1<br>4 | DB-NO.:<br>DBL-REG.: |      | 0000 | -NO.:   |           |
|                  | LEVEL:    | 0004       | ICMK:               | 0020      |        | ICRW:                |      | 0000 |         |           |
|                  | ACCU1:    | 0001 1001  | ACCU2:              | 0000 0101 | I      | ACCU3:               | 0000 | 0000 | ACCU4:  | 0000 0000 |
|                  | CONDITION | I CODE:    | CC1                 | CC0       | OVFI   | _ ov                 | FLS  | OR   | ERA     | λB        |
|                  |           |            | STATUS              | VKE       |        |                      |      |      |         |           |
|                  | CAUSE OF  | INTERR.:   | NAU                 | PEU       | BAU    | MPS                  | STP  | ZYK  | QVZ     | 2         |
|                  |           |            | ADF                 | STP       | BCF    | S-                   | 6    | LZF  | REC     | à-FE      |
|                  |           |            | STUEB               | STUEU     | WEC    | K DOF                | P    | x    |         |           |

You can now move on in the ISTACK to depth 02:

The identifier **0004** (after LEVEL) tells you that this is the ISTACK of the interrupted program processing level **CYCLE**. The STEP address counter (**SAC**) indicates the address **0037H**. The operation that caused the error is stored at this absolute address in the user memory. Its code is specified as **2006** (**OP-REG**). From the listing of the machine codes in the operations list, you can see that this is the STEP 5 operation '**ADB 6**'.

The interrupt occurred in organization block **OB 1**. Within OB 1, the operation that caused the error is at the relative address **0004 (REL-SAC)**. As you have already established, this operation led to a runtime error (see ICMK, bit  $2^5$ , and CAUSE OF INTERR.).

You can now display the incorrect operation on the screen using the SEARCH online function. Enter the appropriate block (OB 1) and the relative address of the operation.

| F1         | F2   | F3        | F4  | F5 | F6      | F7      | F8 |
|------------|------|-----------|-----|----|---------|---------|----|
| DISP SYMB  |      |           |     |    | LIB.NO. |         |    |
| OUTPUT DEV | ICE: | PC BLOCK: | OB1 |    | SEARCH: | 4H<br>│ |    |
|            |      |           |     |    | F       | EL-SAC  |    |

Following the search, you can see the operation "**C DB 6**", that caused the interruption; there is no data block with the number 6 in the user memory.

ов 1

| SEGMENT<br>0004 | 1 0000  | ensurtion that soughd the surrou |
|-----------------|---------|----------------------------------|
| 0004            | :C DB 6 | operation that caused the error  |
| 0005            | :       |                                  |
| 0006            | :       |                                  |
| 0007            | :       |                                  |
| 0008            | :BE     |                                  |

## B

## **Further reading**

/1/ S5-135U/155U CPU 922/CPU 928/CPU 928B/CPU 948 Pocket Guide

Order no. 6ES5 997-3UA22

/2/ S5-135U/155U System Manual

Order no. 6ES5 998-0SH21

/3/ STEP 5 Manual

Order no. C79000-G8576-C140

/4/ GRAPH 5: Graphic programming of sequential controls under the S5-DOS SIMATIC S5 operating system

Order no. 6ES5 998-1SA01

- /5/ Standard Function Blocks
   Data Handling Blocks CPU 922, CPU 928, CPU 928B
   S5-135U, S5-155U Programmable Controllers
- /6/ SINEC Manual CP 143 with COM 143

Order no. 6GK1970-1AB43-0AB0

/7/ Hans Berger: Automating with the SIMATIC S5-135U

> SIEMENS AG Order no. A19100-L531-F505-X-7600

/8/ Programmable Controllers Basic Concepts

> SIEMENS AG Order no. E80850-C293-X-A2

- /9/ Catalog ST 59: Programmers SIMATIC S5
- /10/ Catalog ST 54.1: Programmable Controllers S5-135U, S5-155U and S5-155H
- /11/ Catalog ST 57: Standard Function Blocks and Driver Programs for Programmable Controllers of the U Series SIMATIC S5
- /12/ SCL Manual

Order no. C79000-G8576-C162

- /13/ R64 Controller Structure
- /14/ S5-135U Communication CPU 928B

Order no. 6ES5 998-0CN21

# С

## List of Abbreviations

(An explanation of the ISTACK abbreviations can be found in Section 5.4)

| ACCU-1 (2, 3, 4)-L<br>ACCU-1 (2, 3, 4)-H<br>ACCU-1 (2, 3, 4)-LL<br>ACCU-1 (2, 3, 4)-LH<br>ADF<br>ANZW | low word in accumulator 1 (2, 3, 4), 16 bit<br>high word in accumulator 1 (2, 3, 4), 16 bit<br>low byte of low word in accumulator 1 (2, 3, 4), 8 bit<br>high byte of low word in accumulator 1 (2, 3, 4), 8 bit<br>addressing error<br>condition code word |
|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BASP                                                                                                  | disable command output (signal on S5 bus)                                                                                                                                                                                                                   |
| BCD<br>BR                                                                                             | binary coded decimal<br>base address register                                                                                                                                                                                                               |
| BSTACK                                                                                                | block stack                                                                                                                                                                                                                                                 |
| DOTACK                                                                                                | block stack                                                                                                                                                                                                                                                 |
| CC 1, CC 0                                                                                            | condition code bits for digital operations                                                                                                                                                                                                                  |
| COR                                                                                                   | coordinator module                                                                                                                                                                                                                                          |
| СР                                                                                                    | communications processor                                                                                                                                                                                                                                    |
| CPU                                                                                                   | central processing unit                                                                                                                                                                                                                                     |
| CSF                                                                                                   | control system flowchart                                                                                                                                                                                                                                    |
| DB                                                                                                    | data block                                                                                                                                                                                                                                                  |
| DBA                                                                                                   | data block start address (in register 6)                                                                                                                                                                                                                    |
| DBL                                                                                                   | data block length (in register 8)                                                                                                                                                                                                                           |
| DX                                                                                                    | extended data block                                                                                                                                                                                                                                         |
|                                                                                                       |                                                                                                                                                                                                                                                             |
| EPROM                                                                                                 | erasable programmable read only memory                                                                                                                                                                                                                      |
| ERAB                                                                                                  | first scan (bit code)                                                                                                                                                                                                                                       |
| EU                                                                                                    | expansion unit                                                                                                                                                                                                                                              |
| FB                                                                                                    | function block                                                                                                                                                                                                                                              |
| FX                                                                                                    | extended function block                                                                                                                                                                                                                                     |
|                                                                                                       |                                                                                                                                                                                                                                                             |
| IM                                                                                                    | interface module                                                                                                                                                                                                                                            |
| INT                                                                                                   | (system)interrupt                                                                                                                                                                                                                                           |
| IP<br>IOTA OV                                                                                         | intelligent peripheral module                                                                                                                                                                                                                               |
| ISTACK                                                                                                | interrupt stack                                                                                                                                                                                                                                             |

| KB<br>KDB | call for a non-existent code block opening a non-existent DB/DX data block |
|-----------|----------------------------------------------------------------------------|
| LAD       | ladder diagram                                                             |
| LED       | light-emitting diode                                                       |
| NAU       | power failure                                                              |
| OB        | organization block                                                         |
| OR        | or (bit code)                                                              |
| OS        | overflow latching (word code)                                              |
| OV        | overflow (word code)                                                       |
| PAFE      | parameter assignment error byte                                            |
| PARE      | parity error                                                               |
| PB        | program block                                                              |
| PEU       | power failure on expansion unit                                            |
| PG        | programmer                                                                 |
| PI        | process image                                                              |
| PII       | process image of the inputs                                                |
| PIQ       | process image of the outputs                                               |
| PLC       | programmable controller                                                    |
| QVZ       | timeout                                                                    |
| RAM       | random-access memory                                                       |
| RLO       | result of logic operation                                                  |
| SAC       | step address counter                                                       |
| SB        | sequence block                                                             |
| SPU       | operating system processor                                                 |
| STA       | status (bit code)                                                          |
| STL       | statement list                                                             |
| STS       | stop statement                                                             |
| SUF       | substitution error                                                         |
| STUEB     | BSTACK overflow                                                            |
| STUEU     | ISTACK overflow                                                            |
| TRAF      | transfer or load error                                                     |
| ZYK       | cycle error                                                                |

## Index

#### A

| Accumulators (ACCUs)   | 3-13, 6-10 |
|------------------------|------------|
| Actual operands        |            |
| of function blocks     | 2-27       |
| Addressing             | 1-12       |
| ADF (addressing error) | 5-22, 5-45 |
| Arithmetic operations  | 3-52       |
| Assignment list        | 2-5, 2-22  |
| AUTOMATIC COLD RESTART |            |
| See RESTART            |            |
| AUTOMATIC WARM RESTART |            |
| See RESTART            |            |
|                        |            |

#### B

| Basic levels               | 4-6, 4-9          |
|----------------------------|-------------------|
| Basic operations           | 2-2, 3-17         |
| BASP LED                   | 4-4               |
| BASP signal                | 4-24              |
| BCF (operation code error) |                   |
| operation code error       | 5-22, 5-33, 5-35  |
| parameter error            | 5-22, 5-33, 5-35  |
| substitution error         | 5-22, 5-33 - 5-34 |
| Binary numbers             | 2-6               |
| Block                      |                   |
| address list               | 3-6               |
| block ID                   | 2-34              |
| body                       | 2-11, 2-22, 2-34  |
| calls                      | 2-14, 3-6, 3-30   |
| formal operands (block j   |                   |
| header                     | 2-11, 2-34        |
| number                     | 2-10, 2-34, 3-31  |
| preheader                  | 2-11, 2-33        |
| Block operations           | 3-30              |
| Blocks                     |                   |
| nesting blocks             | 3-6               |
| BR register                | 9-24              |
| BSTACK                     |                   |
| output                     | 5-5               |
| -                          |                   |

| BSTACK (block stack) |      |
|----------------------|------|
| evaluating           | 5-6  |
| read                 | 6-47 |

#### С

| See Results codes                    |         |
|--------------------------------------|---------|
| Clock-driven time interrupts         |         |
| interrupt points                     | 4-30    |
| special features                     | 4-31    |
| Closed loop controller structure R64 | 4-35    |
| Closed-loop control                  | 6-99    |
| Communication OBs                    | 10-21   |
| parameters                           | 10-22   |
| runtimes                             | 10-29   |
| Communication processors (CPs)       | 10-6    |
| Comparison operations                | 3-30    |
| COMPRESS MEMORY                      | 2-13    |
| Control bits 5-3, 5-                 | 7 - 5-8 |
| Controller                           |         |
| processing closed-loop controller    |         |
| interrupts                           | 4-35    |
| CONTROLLER                           |         |
| INTERRUPT 4-6, 4-8, 4-2:             |         |
| interrupt points                     | 4-35    |
| Conversion operations                | 3-58    |
| Counter value                        | 3-26    |
| Counters C                           | 1-11    |
| CSF (control system flowchart)       | 2-2     |
| Current data block                   | 1-12    |
|                                      | 0, 4-26 |
|                                      | 2, 3-10 |
| interrupt points                     | 4-27    |
| program processing levels            | 4-6     |
| user interface OB 1                  | 4-27    |
| Cycle boundary                       | 6-35    |
| Cycle statistics                     | 6-37    |
| Cycle time                           | 6-35    |

| Cyclic processing                     | 1-3, 1-14, 4-26         | F                                  |           |
|---------------------------------------|-------------------------|------------------------------------|-----------|
| Cyclic program execution              | 1-14                    |                                    |           |
|                                       |                         | F flags 1-1                        | 0, 10-22  |
| D                                     |                         | Fixed point numbers                | 2-7       |
|                                       |                         | Floating point numbers             | 2-6       |
| Data area                             | 6-63                    | Formal operands 2-                 | 23, 3-48  |
| Data block DB 0                       | 2-39, 3-6               | Function blocks (FB/FX)            |           |
| Data block DB 1                       | 2-39                    | · /                                | 10, 2-21  |
| Data block DB 2                       | 2-39                    | programming                        | 2-23      |
| Data block DX 0                       | 2-39                    |                                    | 21, 2-31  |
| Data block DX 1                       | 2-39                    | structure                          | 2-22      |
| Data block RAM (DB RAM)               | 1-8, 3-8, 6-90          |                                    |           |
| Data blocks                           | -,,                     | G                                  |           |
| general                               | 1-11                    |                                    |           |
| Data blocks (DB/DX)                   |                         | Global memory                      |           |
| accessing data blocks                 | 6-52                    | access                             | 9-28      |
| general                               | 2-11, 2-33              | general                            | 9-2       |
| generating                            | 3-31                    | GRAPH 5                            | 2-3       |
| programming                           | 2-35                    |                                    | 20        |
| structure                             | 2-33                    | Н                                  |           |
| validity                              | 2-36                    | 11                                 |           |
| Data word                             | 1-11, 2-33, 2-37        | Handling blocks                    | 6-89      |
| DBA (data block start address)        | 1-11, 2-33, 2-37<br>9-9 | Handling blocks                    | 0-09      |
| · · · · · · · · · · · · · · · · · · · | 9-9                     | I                                  |           |
| DBL (data block length)               |                         | 1                                  |           |
| Decimal numbers                       | 2-6<br>3-60             | L/Oc                               |           |
| Decrementing                          | 5-00                    | I/Os                               | 05        |
| Default                               | 1.6                     | address distribution               | 8-5       |
| system reaction                       | 1-6                     | modules                            | 1-9       |
| Defaults, modifying                   | 1-6                     | O area                             | 1-9       |
| Definition of the "9th track"         | 4-21                    | P area                             | 1-9       |
| DELAY INTERRUPT                       | 4.00                    | ICMK                               | 8-19      |
| interrupt points                      | 4-29                    | ICRW                               | 8-17      |
| special features                      | 4-29                    | Incrementing                       | 3-60      |
| Delay time                            | 4-25                    | Interface                          |           |
| Delay interrupt                       | 6-42                    | second serial interface            | 5-29      |
| Display generation operation          | 3-31                    |                                    | 1-8, 2-16 |
|                                       |                         | Interprocessor communication flags |           |
| E                                     |                         | data exchange via IPCs             | 10-4      |
|                                       |                         | 6                                  | 12, 10-4  |
| ERAB                                  |                         | jumper settings                    | 10-4      |
| See Results codes                     |                         | Interrupt condition codeword       | 8-16      |
| Error handling                        |                         | Interrupt events                   | 3-12      |
| using organization blocks             | 5-22                    | Interrupt-driven processing        | 1-4       |
| Error IDs                             | 5-5                     | IPC flags                          |           |
| Error information                     | 5-3                     | transferring blocks of IPC flags   | 6-85      |
| Error levels                          | 4-7, 4-9                | ISTACK (interrupt stack)           |           |
| Error OBs                             | 2-17                    | code bits                          | 5-14      |
| Executive operations                  | 3-54                    | contents                           | 5-13      |
| -                                     |                         | error information                  | 5-3       |
|                                       |                         | information in ISTACK              | 5-14      |
|                                       |                         | output                             | 5-3, 5-7  |
|                                       |                         | 1                                  | ,         |

#### J

Jump operations

#### L

| LAD (ladder diagram) | 2-2        |
|----------------------|------------|
| LED RUN              | 4-3        |
| LED STOP             | 4-3        |
| Library number       | 2-34       |
| Load operations      | 3-19, 3-51 |
| Local memory         |            |
| access               | 9-27       |
| general              | 9-2        |
| Logic operations     | 3-48       |
| binary               | 3-17       |
| digital              | 3-48       |
| LZF (runtime errors) | 5-37, 5-39 |
|                      |            |

#### Μ

| MANUAL COLD RESTART          |       |
|------------------------------|-------|
| See RESTART                  | 4-6   |
| MANUAL WARM RESTART          |       |
| See RESTART                  |       |
| Memory access                |       |
| general                      | 9-2   |
| via the BR register          | 9-24  |
| Memory organization          | 9-2   |
| Mode of operation of a CPU   | 1-3   |
| Multiprocessor communication |       |
| application examples         | 10-50 |
| assignment list              | 10-34 |
| buffering data               | 10-16 |
| data amount                  | 10-13 |
| initializing                 | 10-30 |
| modes                        | 10-33 |
| receive data                 | 10-45 |
| send data                    | 10-38 |
| sequence                     | 10-13 |
| Multiprocessor mode          |       |
| data exchange between CPUs   |       |
| and CPs                      | 10-6  |
| Multiprocessor operation     |       |
| communications mechanisms    | 10-3  |
| I/O assignment               | 10-8  |
| restart types                | 6-84  |
| N                            |       |
| IN                           |       |

| Nesting                   |     |
|---------------------------|-----|
| program processing levels | 4-7 |
| Nesting depth             | 3-6 |

| No operation                   | 3-31         |
|--------------------------------|--------------|
| Normalized fixed point numbers | 6-107, 6-112 |

#### 0

3-54

| O area                            |            |
|-----------------------------------|------------|
| See I/Os                          |            |
| Operand areas                     | 1-9        |
| Operand substitution              | 3-62       |
| Operating modes                   | 4-2, 11-4  |
| Operation code                    | 2-5        |
| OR                                |            |
| See Results codes                 |            |
| Organization blocks (OBs)         |            |
| as user interfaces                | 2-16       |
| control of the start-up procedure | 2-17       |
| error OBs                         | 2-17       |
| general                           | 2-10, 2-14 |
| special functions OBs             | 2-19       |
| OS (overflow latching)            |            |
| See Results codes                 |            |
| OV (overflow)                     |            |
| See Results codes                 |            |

#### Р

| P area                             |                |
|------------------------------------|----------------|
| See I/Os                           |                |
| Page area/page memory              | 9-7, 9-31      |
| busy location                      | 9-32           |
| Pages                              |                |
| accessing pages                    | 9-31           |
| Parallel operation of serial PG in | terfaces 11-17 |
| cyclic functions                   | 11-22          |
| long-running functions             | 11-19, 11-22   |
| short-running functions            | 11-19, 11-21   |
| Parameter                          | 2-5            |
| Parameters for DX 0                | 1-6, 7-2, 7-6  |
| PG functions                       | 11-2           |
| PG interface module                | 11-17          |
| PG screen form                     |                |
| for generating DB1                 | 10-9           |
| PID controller                     | 6-99           |
| Priority                           | 1-4, 4-9       |
| Process image                      |                |
| general                            | 1-9, 3-12      |
| inputs (PII)                       | 1-3, 1-9       |
| outputs (PIQ)                      | 1-3, 1-9       |
| updating                           | 4-24           |
| PROCESS INTERRUPT                  | 4-6, 4-8, 4-25 |
| Process interrupt signals          |                |
| level-triggered                    | 4-37           |
| Process interrupts                 |                |
| disabling                          | 3-66, 4-38     |
|                                    |                |

| edge-triggered            | 4-38              | S                               |                              |
|---------------------------|-------------------|---------------------------------|------------------------------|
| enabling                  | 3-66, 4-38        |                                 |                              |
| interrupts                | 4-36              | S flags                         | 1-10                         |
| multiple interrupts       | 4-37              | Scratchpad flags                | 10-50                        |
| processing                | 4-36              | Second serial interface         | 5-29                         |
| Processing operations     | 3-61              | Semaphores                      | 3-67                         |
| Program                   |                   | Sequence blocks                 | 2-14                         |
| program organization      | 3-3               | Sequence blocks (SB)            | 2-10                         |
| system program            | 1-5               | Serial link PG - PLC            | 11-16                        |
| user program              | 1-7               | Set/reset operations            | 3-18, 3-48                   |
| Program blocks (PB)       | 2-10, 2-14        | Shift operations                | 3-56                         |
| Program processing levels |                   | Shift register                  | 6-90                         |
| general                   | 6-11, 6-16        | Special functions               |                              |
| level number              | 6-87              | errors during special functio   | n                            |
| Programming               |                   | processing                      | 6-5                          |
| general                   | 1-13              | general                         | 6-3                          |
| Programming language      |                   | interfaces                      | 6-4                          |
| GRAPH 5                   | 1-16              | Special functions OBs           | 6-3                          |
| SCL                       | 1-16              | STA (status)                    |                              |
| STEP 5                    | 1-16              | See Results codes               |                              |
| Programming tools         | 1-16              | Standard function blocks        |                              |
|                           |                   | See also Function blocks        |                              |
| Q                         |                   | START-UP                        | 3-10                         |
|                           |                   | general                         | 3-10                         |
| QVZ (timeout error)       | 5-22, 5-46        | STEP 5 operations               | 3-13                         |
|                           | ,                 | STEP 5 programming language     | 2-2                          |
| R                         |                   | STL (statement list)            | 2-2                          |
|                           |                   | STOP                            | 4-2                          |
| REG-FE (controller error) | 5-50              | Stop operations                 | 3-31                         |
| Response time             | 4-40              | Structure of the memory area    | 8-2, 8-4                     |
| RESTART                   |                   | Structured programming          | 2-4                          |
| errors during restart     | 5-25              | Suitability of the CPU 948      | 1-2                          |
| errors in restart         | 5-32              | Supplementary operations        | 2-2                          |
| restart types             | 6-84              | System checkpoint               | 11-3                         |
| Results codes             |                   | System data                     | 8-13                         |
| ERAB                      | 3-14, 3-18        | System data words               | 0 10                         |
| CC 1 and CC 0             | 3-15, 3-56        | bit assignment                  | 8-16                         |
| OR                        | 3-15              | System data words RS 3 and RS 4 |                              |
| OS                        | 3-15              | System operations               | 2-2, 3-54                    |
| OV OV                     | 3-15              | System program                  | 1-5                          |
| RLO                       | 2-5, 3-15, 3-18   | System program defaults         | 1-6                          |
| STA                       | 3-15, 3-18        | System time                     | 6-23                         |
| RETENTIVE AUTOMATIC       | ,                 | System time                     | 0 23                         |
| See RESTART               | 4-6               | Т                               |                              |
| RETENTIVE MANUAL CO       |                   | •                               |                              |
| See RESTART               | 4-6               | TIME INTERRUPT                  | 4-6, 4-8, 4-25               |
| RLO                       | + 0               | Time interrupts                 | + 0, + 0, + 25               |
| See Results codes         |                   | at fixed intervals              | 4-25                         |
| RS/RT area                | 8-13              | clock-controlled                | 4-25                         |
| RUN                       | 0-15              | interrupt points                | 4-23                         |
| errors in RUN             | 5-32              | Time-controlled processing      | 4- <i>32</i><br>1-4          |
| general                   | 4-2, 4-24         | Time-driven program execution   | T-4                          |
| Seneral                   | <b>⊤⁻∠, ┭⁻∠</b> ┭ | clock-driven time interrupt     | 4-25, 4-28                   |
|                           |                   | delay interrupt                 | 4-23, 4-28                   |
|                           |                   | using interrupt                 | - <b>- - - - - - - - - -</b> |

| in fixed time bases           | 4-25, 4-31 |
|-------------------------------|------------|
| time interrupts               | 4-28       |
| TIMED JOB                     | 4-6        |
| Timed job, generate           | 6-28       |
| Timer and counter operations  | 3-24, 3-49 |
| Timer value                   | 3-25       |
| Timers T                      | 1-11       |
| Transfer operations           | 3-19, 3-51 |
| Transferring fields of memory | 9-16       |

#### U

| User checkpoints                   | 11-3      |
|------------------------------------|-----------|
| User interface                     |           |
| for clock-driven time interrupt    | 4-30      |
| for closed loop controller interru | pt 4-35   |
| for cyclic program execution       | 4-27      |
| for delay interrupt                | 4-28      |
| for process interrupt              | 4-36      |
| for restart                        | 4-21      |
| for time interrupts                | 4-31      |
| User memory                        | 1-8       |
| organization                       | 8-7       |
| User program                       | 1-5, 1-7  |
| See also Program                   |           |
| processing                         | 3-2, 3-10 |
| storing                            | 1-8       |
| tasks                              | 1-8       |
|                                    |           |

#### W

| WECK-FE (collision of |                        |
|-----------------------|------------------------|
| time interrupts)      | 4-31, 4-33, 5-22, 5-49 |

#### Z

| ZYK-FE (cycle time exceeded) | 5-48 |
|------------------------------|------|
|------------------------------|------|