From 45612299061107694553deda4ea18dc3ef4e81b4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Oliver=20St=C3=B6neberg?= Date: Mon, 15 Jul 2019 15:37:31 +0200 Subject: [PATCH] =?UTF-8?q?donate-cpu.py:=20treat=20signal=206=20(SIGABRT)?= =?UTF-8?q?=20as=20crash=20as=20well=20so=20we=20get=20a=20=E2=80=A6=20(#1?= =?UTF-8?q?995)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * donate-cpu.py: treat signal 6 (SIGABRT) as crash as well so we get a stack trace in the result * donate-cpu.py: simplified returncode/signal check / also generate stack traces for SIGILL, SIGFPE, SIGBUS * donate-cpu.py: avoid usage of "not" in if * donate-cpu.py: do not overwrite returncode in crash handling --- tools/donate-cpu.py | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/tools/donate-cpu.py b/tools/donate-cpu.py index a70c48508..cbf948016 100644 --- a/tools/donate-cpu.py +++ b/tools/donate-cpu.py @@ -40,7 +40,7 @@ import platform # Version scheme (MAJOR.MINOR.PATCH) should orientate on "Semantic Versioning" https://semver.org/ # Every change in this script should result in increasing the version number accordingly (exceptions may be cosmetic # changes) -CLIENT_VERSION = "1.1.24" +CLIENT_VERSION = "1.1.25" def check_requirements(): @@ -281,14 +281,21 @@ def scan_package(work_path, cppcheck_path, jobs): cppcheck_cmd = cppcheck_path + '/cppcheck' + ' ' + options cmd = 'nice ' + cppcheck_cmd returncode, stdout, stderr, elapsed_time = run_command(cmd) - print('cppcheck finished with ' + str(returncode)) - if returncode == -11 or stderr.find('Internal error: Child process crashed with signal 11 [cppcheckError]') > 0: + sig_num = -1 + sig_msg = 'Internal error: Child process crashed with signal ' + sig_pos = stderr.find(sig_msg) + if sig_pos != -1: + sig_start_pos = sig_pos + len(sig_msg) + sig_num = int(stderr[sig_start_pos:stderr.find(' ', sig_start_pos)]) + print('cppcheck finished with ' + str(returncode) + ('' if sig_num == -1 else ' (signal ' + str(sig_num) + ')')) + # generate stack trace for SIGSEGV, SIGABRT, SIGILL, SIGFPE, SIGBUS + if returncode in (-11,-6,-4,-8,-7) or sig_num in (11,6,4,8,7): print('Crash!') stacktrace = '' if cppcheck_path == 'cppcheck': # re-run within gdb to get a stacktrace cmd = 'gdb --batch --eval-command=run --eval-command=bt --return-child-result --args ' + cppcheck_cmd + " -j1" - returncode, stdout, stderr, elapsed_time = run_command(cmd) + dummy, stdout, stderr, elapsed_time = run_command(cmd) gdb_pos = stdout.find(" received signal") if not gdb_pos == -1: last_check_pos = stdout.rfind('Checking ', 0, gdb_pos) @@ -296,7 +303,7 @@ def scan_package(work_path, cppcheck_path, jobs): stacktrace = stdout[gdb_pos:] else: stacktrace = stdout[last_check_pos:] - return -11, stacktrace, '', -11, options + return returncode, stacktrace, '', returncode, options if returncode != 0: print('Error!') if returncode > 0: