summaryrefslogtreecommitdiffstats
path: root/dkms_apport.py
diff options
context:
space:
mode:
Diffstat (limited to 'dkms_apport.py')
-rwxr-xr-xdkms_apport.py101
1 files changed, 101 insertions, 0 deletions
diff --git a/dkms_apport.py b/dkms_apport.py
new file mode 100755
index 0000000..e761866
--- /dev/null
+++ b/dkms_apport.py
@@ -0,0 +1,101 @@
+#!/usr/bin/env python3
+#
+# Dynamic Kernel Module Support (DKMS) <dkms-devel@dell.com>
+# Copyright (C) 2009 Dell, Inc.
+# by Mario Limonciello
+#
+# 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.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+#
+
+import apport
+from apport.hookutils import *
+import sys
+import subprocess, optparse
+
+from datetime import datetime
+
+optparser = optparse.OptionParser('%prog [options]')
+optparser.add_option('-m', help="Specify the DKMS module to find the package for",
+ action='store', type='string', dest='module')
+optparser.add_option('-v', help="Specify the DKMS version to find the package for",
+ action='store', type='string', dest='version')
+optparser.add_option('-k', help="Specify the kernel version",
+ action='store', type='string', dest='kernel')
+options=optparser.parse_args()[0]
+
+if not options.module or not options.version:
+ sys.stderr.write('ERROR (dkms apport): both -m and -v are required\n')
+ sys.exit(2)
+
+package=packaging.get_file_package('/usr/src/' + options.module + '-' + options.version)
+if package is None:
+ sys.stderr.write('ERROR (dkms apport): binary package for %s: %s not found\n' % (options.module,options.version))
+ sys.exit(1)
+
+if options.kernel:
+ # TODO: Ubuntu specific
+ kernel_package = "linux-headers-" + options.kernel
+
+ supported_kernel = True
+ try:
+ supported_kernel = apport.packaging.is_distro_package(kernel_package)
+ except ValueError as e:
+ if str(e) == 'package %s does not exist' % kernel_package:
+ supported_kernel = False
+
+ if not supported_kernel:
+ sys.stderr.write('ERROR (dkms apport): kernel package %s is not supported\n' % (kernel_package))
+ sys.exit(1)
+
+make_log=os.path.join('/var','lib','dkms',options.module,options.version,'build','make.log')
+
+report = apport.Report('Package')
+try:
+ version = packaging.get_version(package)
+except ValueError:
+ version = '(not installed)'
+if version is None:
+ version = '(not installed)'
+report['Package'] = '%s %s' % (package, version)
+try:
+ report['SourcePackage'] = apport.packaging.get_source(package)
+except ValueError:
+ sys.stderr.write('ERROR (dkms apport): unable to determine source package for %s\n' % package)
+ sys.exit(3)
+
+if report['SourcePackage'] == 'fglrx-installer':
+ fglrx_make_log = os.path.join('/var','lib','dkms',options.module,options.version,'build','make.sh.log')
+ attach_file_if_exists(report, fglrx_make_log, 'FglrxBuildLog')
+
+report['PackageVersion'] = version
+report['Title'] = "%s %s: %s kernel module failed to build" % (package, version, options.module)
+attach_file_if_exists(report, make_log, 'DKMSBuildLog')
+if 'DKMSBuildLog' in report:
+ this_year = str(datetime.today().year)
+ if 'Segmentation fault' in report['DKMSBuildLog']:
+ sys.stderr.write('ERROR (dkms apport): There was a segmentation fault when trying to build the module\n')
+ sys.exit(1)
+ for line in report['DKMSBuildLog'].split('\n'):
+ if ': error:' in line:
+ report['DuplicateSignature'] = 'dkms:%s:%s:%s' % (package, version, line.strip())
+ break
+
+if options.kernel:
+ report['DKMSKernelVersion'] = options.kernel
+try:
+ with apport.fileutils.make_report_file(report) as f:
+ report.write(f)
+except (IOError, OSError) as e:
+ apport.fatal('Cannot create report: ' + str(e))