donate-cpu.py: treat signal 6 (SIGABRT) as crash as well so we get a … (#1995)
* 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
This commit is contained in:
parent
dcc375ca64
commit
4561229906
|
@ -40,7 +40,7 @@ import platform
|
||||||
# Version scheme (MAJOR.MINOR.PATCH) should orientate on "Semantic Versioning" https://semver.org/
|
# 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
|
# Every change in this script should result in increasing the version number accordingly (exceptions may be cosmetic
|
||||||
# changes)
|
# changes)
|
||||||
CLIENT_VERSION = "1.1.24"
|
CLIENT_VERSION = "1.1.25"
|
||||||
|
|
||||||
|
|
||||||
def check_requirements():
|
def check_requirements():
|
||||||
|
@ -281,14 +281,21 @@ def scan_package(work_path, cppcheck_path, jobs):
|
||||||
cppcheck_cmd = cppcheck_path + '/cppcheck' + ' ' + options
|
cppcheck_cmd = cppcheck_path + '/cppcheck' + ' ' + options
|
||||||
cmd = 'nice ' + cppcheck_cmd
|
cmd = 'nice ' + cppcheck_cmd
|
||||||
returncode, stdout, stderr, elapsed_time = run_command(cmd)
|
returncode, stdout, stderr, elapsed_time = run_command(cmd)
|
||||||
print('cppcheck finished with ' + str(returncode))
|
sig_num = -1
|
||||||
if returncode == -11 or stderr.find('Internal error: Child process crashed with signal 11 [cppcheckError]') > 0:
|
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!')
|
print('Crash!')
|
||||||
stacktrace = ''
|
stacktrace = ''
|
||||||
if cppcheck_path == 'cppcheck':
|
if cppcheck_path == 'cppcheck':
|
||||||
# re-run within gdb to get a stacktrace
|
# re-run within gdb to get a stacktrace
|
||||||
cmd = 'gdb --batch --eval-command=run --eval-command=bt --return-child-result --args ' + cppcheck_cmd + " -j1"
|
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")
|
gdb_pos = stdout.find(" received signal")
|
||||||
if not gdb_pos == -1:
|
if not gdb_pos == -1:
|
||||||
last_check_pos = stdout.rfind('Checking ', 0, gdb_pos)
|
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:]
|
stacktrace = stdout[gdb_pos:]
|
||||||
else:
|
else:
|
||||||
stacktrace = stdout[last_check_pos:]
|
stacktrace = stdout[last_check_pos:]
|
||||||
return -11, stacktrace, '', -11, options
|
return returncode, stacktrace, '', returncode, options
|
||||||
if returncode != 0:
|
if returncode != 0:
|
||||||
print('Error!')
|
print('Error!')
|
||||||
if returncode > 0:
|
if returncode > 0:
|
||||||
|
|
Loading…
Reference in New Issue