#!/usr/bin/python3 # # Collect information about a kernel oops. # # Copyright (c) 2007 Canonical Ltd. # Author: Martin Pitt <martin.pitt@ubuntu.com> # # This program is free software; you can redistribute it and/or modify it # under the terms of the GNU General Public License as published by the # Free Software Foundation; either version 2 of the License, or (at your # option) any later version. See http://www.gnu.org/copyleft/gpl.html for # the full text of the license. import os, re, glob import apport, apport.fileutils pr = apport.Report('KernelCrash') package = apport.packaging.get_kernel_package() pr.add_package(package) pr.add_os_info() vmcore_path = os.path.join(apport.fileutils.report_dir, 'vmcore') # only accept plain files here, not symlinks; otherwise we might recursively # include the report, or similar DoS attacks if os.path.exists(vmcore_path + '.log'): try: log_fd = os.open(vmcore_path + '.log', os.O_RDONLY | os.O_NOFOLLOW) pr['VmCoreLog'] = (os.fdopen(log_fd, 'rb'),) os.unlink(vmcore_path + '.log') except OSError as e: apport.fatal('Cannot open vmcore log: ' + str(e)) if os.path.exists(vmcore_path): try: core_fd = os.open(vmcore_path, os.O_RDONLY | os.O_NOFOLLOW) pr['VmCore'] = (os.fdopen(core_fd, 'rb'),) with apport.fileutils.make_report_file(pr) as f: pr.write(f) except (IOError, OSError) as e: apport.fatal('Cannot create report: ' + str(e)) try: os.unlink(vmcore_path) except OSError: pass # huh, already gone? else: # check for kdump-tools generated dmesg in timestamped dir for dmesg_file in glob.glob(os.path.join(apport.fileutils.report_dir, '*', 'dmesg.*')): timedir = os.path.dirname(dmesg_file) timestamp = os.path.basename(timedir) if re.match('^[0-9]{12}$', timestamp): # we require the containing dir to be owned by root, to avoid users # creating a symlink to someplace else and disclosing data; we just # compare against euid here so that we can test this as non-root if os.lstat(timedir).st_uid != os.geteuid(): apport.fatal('%s has unsafe permissions, ignoring' % timedir) report_name = package + '-' + timestamp + '.crash' try: crash_report = os.path.join(apport.fileutils.report_dir, report_name) dmesg_fd = os.open(dmesg_file, os.O_RDONLY | os.O_NOFOLLOW) pr['VmCoreDmesg'] = (os.fdopen(dmesg_fd, 'rb'),) # TODO: Replace with open(..., 'xb') once we drop Python 2 support with os.fdopen(os.open(crash_report, os.O_WRONLY | os.O_CREAT | os.O_EXCL, 0o640), 'wb') as f: pr.write(f) except (IOError, OSError) as e: apport.fatal('Cannot create report: ' + str(e))
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
general-hooks | Folder | 0755 |
|
|
package-hooks | Folder | 0755 |
|
|
symptoms | Folder | 0755 |
|
|
testsuite | Folder | 0755 |
|
|
apport | File | 31.6 KB | 0755 |
|
apport-checkreports | File | 1.24 KB | 0755 |
|
apport.jar | File | 2.38 KB | 0644 |
|
apportcheckresume | File | 3.14 KB | 0755 |
|
dump_acpi_tables.py | File | 1.41 KB | 0755 |
|
dump_acpi_tables.pyc | File | 1.53 KB | 0644 |
|
gcc_ice_hook | File | 1.18 KB | 0755 |
|
is-enabled | File | 672 B | 0755 |
|
iwlwifi_error_dump | File | 1.92 KB | 0755 |
|
java_uncaught_exception | File | 2.58 KB | 0755 |
|
kernel_crashdump | File | 2.82 KB | 0755 |
|
kernel_oops | File | 1.2 KB | 0755 |
|
package_hook | File | 2.15 KB | 0755 |
|
recoverable_problem | File | 2.25 KB | 0755 |
|
root_info_wrapper | File | 96 B | 0755 |
|
unkillable_shutdown | File | 3.41 KB | 0755 |
|
whoopsie-upload-all | File | 5.58 KB | 0755 |
|