From f1da57f28981ae3b332ac6b3efca264f6dba5884 Mon Sep 17 00:00:00 2001 From: Yauheni Kaliuta Date: Wed, 25 Mar 2020 09:55:48 +0200 Subject: [PATCH] fix crash on fseek/ftell of stdout (27-2) - add 0001-depmod-do-not-output-.bin-to-stdout.patch Resolves: rhbz#1808430 Signed-off-by: Yauheni Kaliuta --- ...-depmod-do-not-output-.bin-to-stdout.patch | 53 +++++++++++++++++++ kmod.spec | 9 +++- 2 files changed, 61 insertions(+), 1 deletion(-) create mode 100644 0001-depmod-do-not-output-.bin-to-stdout.patch diff --git a/0001-depmod-do-not-output-.bin-to-stdout.patch b/0001-depmod-do-not-output-.bin-to-stdout.patch new file mode 100644 index 0000000..1461006 --- /dev/null +++ b/0001-depmod-do-not-output-.bin-to-stdout.patch @@ -0,0 +1,53 @@ +From 53b30aeba2dedae9f5558f560231d9462e063dfc Mon Sep 17 00:00:00 2001 +From: Lucas De Marchi +Date: Thu, 5 Mar 2020 13:33:10 -0800 +Subject: [PATCH] depmod: do not output .bin to stdout + +index_write() relies on fseek/ftell to manage the position to which we +are write and thus needs the file stream to support it. + +Right now when trying to write the index to stdout we fail with: + + depmod: tools/depmod.c:416: index_write: Assertion `initial_offset >= 0' failed. + Aborted (core dumped) + +We have no interest in outputting our index to stdout, so just skip it +like is done with other indexes. + +While at it, add/remove some newlines to improve readability. + +Reported-by: Yanko Kaneti +Fix: b866b2165ae6 ("Lookup aliases in the modules.builtin.modinfo") +--- + tools/depmod.c | 6 +++++- + 1 file changed, 5 insertions(+), 1 deletion(-) + +diff --git a/tools/depmod.c b/tools/depmod.c +index fbbce10eb0db..875e31480818 100644 +--- a/tools/depmod.c ++++ b/tools/depmod.c +@@ -2408,8 +2408,10 @@ static int output_builtin_alias_bin(struct depmod *depmod, FILE *out) + struct index_node *idx; + struct kmod_list *l, *builtin = NULL; + +- idx = index_create(); ++ if (out == stdout) ++ return 0; + ++ idx = index_create(); + if (idx == NULL) { + ret = -ENOMEM; + goto fail; +@@ -2456,7 +2458,9 @@ static int output_builtin_alias_bin(struct depmod *depmod, FILE *out) + + if (count) + index_write(idx, out); ++ + index_destroy(idx); ++ + fail: + if (builtin) + kmod_module_unref_list(builtin); +-- +2.25.0 + diff --git a/kmod.spec b/kmod.spec index 652b5d5..0dbfbb4 100644 --- a/kmod.spec +++ b/kmod.spec @@ -1,6 +1,6 @@ Name: kmod Version: 27 -Release: 1%{?dist} +Release: 2%{?dist} Summary: Linux kernel module management utilities License: GPLv2+ @@ -9,6 +9,8 @@ Source0: https://www.kernel.org/pub/linux/utils/kernel/kmod/%{name}-%{version}.t Source1: weak-modules Exclusiveos: Linux +Patch01: 0001-depmod-do-not-output-.bin-to-stdout.patch + BuildRequires: gcc BuildRequires: chrpath BuildRequires: zlib-devel @@ -44,6 +46,7 @@ applications that wish to load or unload Linux kernel modules. %prep %autosetup -p1 +%patch01 -p %build %configure \ @@ -104,6 +107,10 @@ install -m 755 %{SOURCE1} $RPM_BUILD_ROOT%{_sbindir}/weak-modules %{_libdir}/libkmod.so %changelog +* Wed Mar 25 2020 Yauheni Kaliuta - 27-2 +- add 0001-depmod-do-not-output-.bin-to-stdout.patch + Resolves: rhbz#1808430 + * Thu Feb 20 2020 Peter Robinson - 27-1 - New upstream v27