diff options
author | Michal Suchanek <msuchanek@suse.de> | 2021-08-18 22:52:00 +0200 |
---|---|---|
committer | Lucas De Marchi <lucas.demarchi@intel.com> | 2022-01-20 00:46:13 -0800 |
commit | 4e391ac92d1b9a2c8c0e9d8735d2913ee86c0ad8 (patch) | |
tree | 28e99e9b92872af3189bb502b4a7c987c710f200 | |
parent | 43bdf97ce1298c8727effb470291ed884e1161e6 (diff) | |
download | kmod-4e391ac92d1b9a2c8c0e9d8735d2913ee86c0ad8.tar.gz kmod-4e391ac92d1b9a2c8c0e9d8735d2913ee86c0ad8.tar.bz2 kmod-4e391ac92d1b9a2c8c0e9d8735d2913ee86c0ad8.zip |
libkmod: Set builtin to no when module is created from path.
A recent bug report showed that modinfo doesn't give the signature
information for certain modules, and it turned out to happen only on
the modules that are built-in on the running kernel; then modinfo
skips the signature check, as if the target module file never exists.
The behavior is, however, inconsistent when modinfo is performed for
external modules (no matter which kernel version is) and the module
file path is explicitly given by a command-line argument, which
guarantees the presence of the module file itself.
Fixes: e7e2cb61fa9f ("modinfo: Show information about built-in modules")
Link: https://lore.kernel.org/linux-modules/CAKi4VAJVvY3=JdSZm-GD1hJqyCPYaYz-jBJ_REeY5BakVb6_ww@mail.gmail.com/
BugLink: https://bugzilla.opensuse.org/show_bug.cgi?id=1189537
Suggested-by: Lucas De Marchi <lucas.de.marchi@gmail.com>
Signed-off-by: Michal Suchanek <msuchanek@suse.de>
Reviewed-by: Petr Vorel <pvorel@suse.cz>
-rw-r--r-- | libkmod/libkmod-module.c | 17 |
1 files changed, 9 insertions, 8 deletions
diff --git a/libkmod/libkmod-module.c b/libkmod/libkmod-module.c index 6e0ff1a..6f7747c 100644 --- a/libkmod/libkmod-module.c +++ b/libkmod/libkmod-module.c @@ -431,17 +431,18 @@ KMOD_EXPORT int kmod_module_new_from_path(struct kmod_ctx *ctx, return -EEXIST; } - *mod = kmod_module_ref(m); - return 0; - } + kmod_module_ref(m); + } else { + err = kmod_module_new(ctx, name, name, namelen, NULL, 0, &m); + if (err < 0) { + free(abspath); + return err; + } - err = kmod_module_new(ctx, name, name, namelen, NULL, 0, &m); - if (err < 0) { - free(abspath); - return err; + m->path = abspath; } - m->path = abspath; + m->builtin = KMOD_MODULE_BUILTIN_NO; *mod = m; return 0; |