OpenSCADAWiki: Home Page En/Doc/ Crash Report ...

Home | Index | Changes | Comments | Users | Registration | Login  Password:  
 
This is an old revision of HomePageEn/Doc/CrashReport from 2010-04-05 17:54:26..

Russian (1 Kb) Русская версия
Ukrainian (1 Kb) Українська версія

Guide to localize crashes and to report about them

Introduction

For the debugging and system testing of the OpenSCADA it is given considerable time of developers, but in view of limited resources and even a practical impossibility to cover all the configuration options and performance of the OpenSCADA system, errors can occur either as a failure of some functions, incorrectness of their implementation and even crash of the program. Understanding of this from the user side is very important, and with his hand it is required goodwill to cost some time to prepare a report on the problem with a view of its subsequent removal by developers.


Before preparing the report of the problem it is recommend to review the list of errors and comments in the corresponding part Errors and comments to the OpenSCADA system.

Requirements for the report of an error

To avoid unnecessary suggestive questions and to accelerate the localization of the problem it is recommended to follow the following requirements for the report.

Variants of the report

To report about an error in the OpenSCADA system it is possible in several ways:

Getting the pre-mortem dump file and its processing

In the Linux operating system while crashing of programs the OS kernel can generate the pre-mortem memory dump of the program. With this dump it is often possible to identify a place in the program that caused the emergency stop. To enable the generation of pre-mortem memory dump of the program by the kernel it is necessary to execute the following commands:

# Check the possibility of generation of memory dumps
# Specifies the "core" if it is enabled
$ cat /proc/sys/kernel/core_pattern
# Enabling the generation of memory dumps
$ echo "core" > /proc/sys/kernel/core_pattern


After this you need before calling OpenSCADA to specify the command "ulimit-c unlimited". For example, it can be done in the calling scripts of the special configuration:
/etc/openscada_demo_ru and /etc/openscada_start:

#!/bin/sh
ulimit -c unlimited
openscada --Config=/etc/oscada_demo_ru.xml $@


Then you can just make sure that the user which running OpenSCADA, is entitled to write in the working directory OpenSCADA, parameter "Workdir" in the configuration file of the program.


Then the OpenSCADA system is running and the crashe is reproduced, the result of which the file is created in a working directory of the OpenSCADA core.N, where N - number of crashed process.


Next, you need to process the resulting memory dump file in order to obtain reversal of the execution stack at the time of the accident. For this purpose you will need the debugger gdb, in which the following commands are executed for the global configuration:

# Transfer to the working directory of OpenSCADA
(gdb) cd /var/spool/openscada
# Specifying an executable file, not scripts!
(gdb) file /usr/bin/openscada
# Specifying the dump file of the program
(gdb) core-file /var/spool/openscada/core.26658
# Getting the reversal of the stack execution
(gdb) bt
#0  0xb7d104c0 in pthread_cancel () from /lib/librt.so.1
#1  0xb7d1edaa in start_thread () from /lib/libpthread.so.0
#2  0xb7dfcf5e in clone () from /lib/libc.so.6


 
There are no files on this page.[Display files/form]
There is no comment on this page. [Display comments/form]