diff options
author | Jens Rehsack <sno@netbsd.org> | 2019-04-18 16:08:42 +0200 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2019-04-26 10:09:08 +0100 |
commit | 67886623d9728f2bd370fb55cea5ab39bcc429c1 (patch) | |
tree | 743b54a9c163f593730279792bb430063a5d8121 | |
parent | c814947e03943c305226f17686f34b0c62450680 (diff) | |
download | poky-67886623d9728f2bd370fb55cea5ab39bcc429c1.tar.gz |
kernel-module-split.bbclass: support CONFIG_MODULE_COMPRESS=y
In case, kernel config enables compressed modules, support of
splitting via split_kernel_module_packages won't find any module.
So, first expand module pattern regex to recognize compressed
modules and then objcopy on temporary extacted to extract module
information.
(From OE-Core rev: fae400b225827400bf32380a7d599d3b2969db55)
Signed-off-by: Jens Rehsack <sno@netbsd.org>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r-- | meta/classes/kernel-module-split.bbclass | 20 |
1 files changed, 18 insertions, 2 deletions
diff --git a/meta/classes/kernel-module-split.bbclass b/meta/classes/kernel-module-split.bbclass index e8d3eb5105..221022b7bc 100644 --- a/meta/classes/kernel-module-split.bbclass +++ b/meta/classes/kernel-module-split.bbclass | |||
@@ -44,9 +44,23 @@ python split_kernel_module_packages () { | |||
44 | def extract_modinfo(file): | 44 | def extract_modinfo(file): |
45 | import tempfile, subprocess | 45 | import tempfile, subprocess |
46 | tempfile.tempdir = d.getVar("WORKDIR") | 46 | tempfile.tempdir = d.getVar("WORKDIR") |
47 | compressed = re.match( r'.*\.([xg])z$', file) | ||
47 | tf = tempfile.mkstemp() | 48 | tf = tempfile.mkstemp() |
48 | tmpfile = tf[1] | 49 | tmpfile = tf[1] |
49 | cmd = "%sobjcopy -j .modinfo -O binary %s %s" % (d.getVar("HOST_PREFIX") or "", file, tmpfile) | 50 | if compressed: |
51 | tmpkofile = tmpfile + ".ko" | ||
52 | if compressed.group(1) == 'g': | ||
53 | cmd = "gunzip -dc %s > %s" % (file, tmpkofile) | ||
54 | subprocess.check_call(cmd, shell=True) | ||
55 | elif compressed.group(1) == 'x': | ||
56 | cmd = "xz -dc %s > %s" % (file, tmpkofile) | ||
57 | subprocess.check_call(cmd, shell=True) | ||
58 | else: | ||
59 | msg = "Cannot decompress '%s'" % file | ||
60 | raise msg | ||
61 | cmd = "%sobjcopy -j .modinfo -O binary %s %s" % (d.getVar("HOST_PREFIX") or "", tmpkofile, tmpfile) | ||
62 | else: | ||
63 | cmd = "%sobjcopy -j .modinfo -O binary %s %s" % (d.getVar("HOST_PREFIX") or "", file, tmpfile) | ||
50 | subprocess.check_call(cmd, shell=True) | 64 | subprocess.check_call(cmd, shell=True) |
51 | # errors='replace': Some old kernel versions contain invalid utf-8 characters in mod descriptions (like 0xf6, 'ö') | 65 | # errors='replace': Some old kernel versions contain invalid utf-8 characters in mod descriptions (like 0xf6, 'ö') |
52 | f = open(tmpfile, errors='replace') | 66 | f = open(tmpfile, errors='replace') |
@@ -54,6 +68,8 @@ python split_kernel_module_packages () { | |||
54 | f.close() | 68 | f.close() |
55 | os.close(tf[0]) | 69 | os.close(tf[0]) |
56 | os.unlink(tmpfile) | 70 | os.unlink(tmpfile) |
71 | if compressed: | ||
72 | os.unlink(tmpkofile) | ||
57 | vals = {} | 73 | vals = {} |
58 | for i in l: | 74 | for i in l: |
59 | m = modinfoexp.match(i) | 75 | m = modinfoexp.match(i) |
@@ -133,7 +149,7 @@ python split_kernel_module_packages () { | |||
133 | kernel_package_name = d.getVar("KERNEL_PACKAGE_NAME") or "kernel" | 149 | kernel_package_name = d.getVar("KERNEL_PACKAGE_NAME") or "kernel" |
134 | kernel_version = d.getVar("KERNEL_VERSION") | 150 | kernel_version = d.getVar("KERNEL_VERSION") |
135 | 151 | ||
136 | module_regex = r'^(.*)\.k?o$' | 152 | module_regex = r'^(.*)\.k?o(?:\.[xg]z)?$' |
137 | 153 | ||
138 | module_pattern_prefix = d.getVar('KERNEL_MODULE_PACKAGE_PREFIX') | 154 | module_pattern_prefix = d.getVar('KERNEL_MODULE_PACKAGE_PREFIX') |
139 | module_pattern_suffix = d.getVar('KERNEL_MODULE_PACKAGE_SUFFIX') | 155 | module_pattern_suffix = d.getVar('KERNEL_MODULE_PACKAGE_SUFFIX') |