[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <CAK7LNAT0TaQ+ynuww2VY2NaDN+7mGDsYyxe2TdYV7QBT+QyS6w@mail.gmail.com>
Date: Wed, 6 Nov 2024 08:03:17 +0900
From: Masahiro Yamada <masahiroy@...nel.org>
To: Matt Fleming <matt@...dmodwrite.com>
Cc: Nathan Chancellor <nathan@...nel.org>, Nicolas Schier <nicolas@...sle.eu>, linux-kernel@...r.kernel.org,
kernel-team@...udflare.com, Matt Fleming <mfleming@...udflare.com>,
linux-kbuild@...r.kernel.org
Subject: Re: [PATCH v2] kbuild: deb-pkg: Don't fail if modules.order is missing
On Wed, Nov 6, 2024 at 5:57 AM Matt Fleming <matt@...dmodwrite.com> wrote:
>
> From: Matt Fleming <mfleming@...udflare.com>
>
> Kernels built without CONFIG_MODULES might still want to create -dbg deb
> packages but install_linux_image_dbg() assumes modules.order always
> exists. This obviously isn't true if no modules were built, so we should
> skip reading modules.order in that case.
Good catch.
> Fixes: 16c36f8864e3 ("kbuild: deb-pkg: use build ID instead of debug link for dbg package")
> Cc: Masahiro Yamada <masahiroy@...nel.org>
> Cc: linux-kbuild@...r.kernel.org
> Signed-off-by: Matt Fleming <mfleming@...udflare.com>
> ---
> scripts/package/builddeb | 7 ++++++-
> 1 file changed, 6 insertions(+), 1 deletion(-)
>
> diff --git a/scripts/package/builddeb b/scripts/package/builddeb
> index 404587fc71fe..9739b0429337 100755
> --- a/scripts/package/builddeb
> +++ b/scripts/package/builddeb
> @@ -96,6 +96,11 @@ install_linux_image_dbg () {
>
> # Parse modules.order directly because 'make modules_install' may sign,
> # compress modules, and then run unneeded depmod.
> + modules_file=modules.order
> + if [ ! -s $modules_file ]; then
> + modules_file=/dev/null
> + fi
This leaves a possibility to pick up a stale modules.order
in incremental builds without 'make clean'.
(1) build with CONFIG_MODULES=y
(2) disable CONFIG_MODULES
(3) 'make bindeb-pkg'
(3) picks up an unrelated modules.order
in the previous build (1).
> while read -r mod; do
> mod="${mod%.o}.ko"
> dbg="${pdir}/usr/lib/debug/lib/modules/${KERNELRELEASE}/kernel/${mod}"
> @@ -105,7 +110,7 @@ install_linux_image_dbg () {
> mkdir -p "${dbg%/*}" "${link%/*}"
> "${OBJCOPY}" --only-keep-debug "${mod}" "${dbg}"
> ln -sf --relative "${dbg}" "${link}"
> - done < modules.order
> + done < $modules_file
Please enclose this block with CONFIG_MODULES.
if is_enabled CONFIG_MODULES; then
while read -r mod; do
...
done < modules.order
fi
--
Best Regards
Masahiro Yamada
Powered by blists - more mailing lists