* [PATCH v3] kbuild: deb-pkg: Don't fail if modules.order is missing
@ 2024-11-07 15:05 Matt Fleming
2024-11-09 11:22 ` Masahiro Yamada
0 siblings, 1 reply; 2+ messages in thread
From: Matt Fleming @ 2024-11-07 15:05 UTC (permalink / raw)
To: Masahiro Yamada, Nathan Chancellor, Nicolas Schier
Cc: linux-kernel, kernel-team, Matt Fleming, linux-kbuild
From: Matt Fleming <mfleming@cloudflare.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.
Fixes: 16c36f8864e3 ("kbuild: deb-pkg: use build ID instead of debug link for dbg package")
Cc: Masahiro Yamada <masahiroy@kernel.org>
Cc: linux-kbuild@vger.kernel.org
Signed-off-by: Matt Fleming <mfleming@cloudflare.com>
---
Changes in v3:
- Wrap modules.order logic in 'if is_enabled CONFIG_MODULES'
scripts/package/builddeb | 22 ++++++++++++----------
1 file changed, 12 insertions(+), 10 deletions(-)
diff --git a/scripts/package/builddeb b/scripts/package/builddeb
index 441b0bb66e0d..fb686fd3266f 100755
--- a/scripts/package/builddeb
+++ b/scripts/package/builddeb
@@ -96,16 +96,18 @@ install_linux_image_dbg () {
# Parse modules.order directly because 'make modules_install' may sign,
# compress modules, and then run unneeded depmod.
- while read -r mod; do
- mod="${mod%.o}.ko"
- dbg="${pdir}/usr/lib/debug/lib/modules/${KERNELRELEASE}/kernel/${mod}"
- buildid=$("${READELF}" -n "${mod}" | sed -n 's@^.*Build ID: \(..\)\(.*\)@\1/\2@p')
- link="${pdir}/usr/lib/debug/.build-id/${buildid}.debug"
-
- mkdir -p "${dbg%/*}" "${link%/*}"
- "${OBJCOPY}" --only-keep-debug "${mod}" "${dbg}"
- ln -sf --relative "${dbg}" "${link}"
- done < modules.order
+ if is_enabled CONFIG_MODULES; then
+ while read -r mod; do
+ mod="${mod%.o}.ko"
+ dbg="${pdir}/usr/lib/debug/lib/modules/${KERNELRELEASE}/kernel/${mod}"
+ buildid=$("${READELF}" -n "${mod}" | sed -n 's@^.*Build ID: \(..\)\(.*\)@\1/\2@p')
+ link="${pdir}/usr/lib/debug/.build-id/${buildid}.debug"
+
+ mkdir -p "${dbg%/*}" "${link%/*}"
+ "${OBJCOPY}" --only-keep-debug "${mod}" "${dbg}"
+ ln -sf --relative "${dbg}" "${link}"
+ done < modules.order
+ fi
# Build debug package
# Different tools want the image in different locations
--
2.34.1
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH v3] kbuild: deb-pkg: Don't fail if modules.order is missing
2024-11-07 15:05 [PATCH v3] kbuild: deb-pkg: Don't fail if modules.order is missing Matt Fleming
@ 2024-11-09 11:22 ` Masahiro Yamada
0 siblings, 0 replies; 2+ messages in thread
From: Masahiro Yamada @ 2024-11-09 11:22 UTC (permalink / raw)
To: Matt Fleming
Cc: Nathan Chancellor, Nicolas Schier, linux-kernel, kernel-team,
Matt Fleming, linux-kbuild
On Fri, Nov 8, 2024 at 12:05 AM Matt Fleming <matt@readmodwrite.com> wrote:
>
> From: Matt Fleming <mfleming@cloudflare.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.
>
> Fixes: 16c36f8864e3 ("kbuild: deb-pkg: use build ID instead of debug link for dbg package")
> Cc: Masahiro Yamada <masahiroy@kernel.org>
> Cc: linux-kbuild@vger.kernel.org
> Signed-off-by: Matt Fleming <mfleming@cloudflare.com>
Applied to linux-kbuild.
Thanks!
> ---
>
> Changes in v3:
> - Wrap modules.order logic in 'if is_enabled CONFIG_MODULES'
>
> scripts/package/builddeb | 22 ++++++++++++----------
> 1 file changed, 12 insertions(+), 10 deletions(-)
>
> diff --git a/scripts/package/builddeb b/scripts/package/builddeb
> index 441b0bb66e0d..fb686fd3266f 100755
> --- a/scripts/package/builddeb
> +++ b/scripts/package/builddeb
> @@ -96,16 +96,18 @@ install_linux_image_dbg () {
>
> # Parse modules.order directly because 'make modules_install' may sign,
> # compress modules, and then run unneeded depmod.
> - while read -r mod; do
> - mod="${mod%.o}.ko"
> - dbg="${pdir}/usr/lib/debug/lib/modules/${KERNELRELEASE}/kernel/${mod}"
> - buildid=$("${READELF}" -n "${mod}" | sed -n 's@^.*Build ID: \(..\)\(.*\)@\1/\2@p')
> - link="${pdir}/usr/lib/debug/.build-id/${buildid}.debug"
> -
> - mkdir -p "${dbg%/*}" "${link%/*}"
> - "${OBJCOPY}" --only-keep-debug "${mod}" "${dbg}"
> - ln -sf --relative "${dbg}" "${link}"
> - done < modules.order
> + if is_enabled CONFIG_MODULES; then
> + while read -r mod; do
> + mod="${mod%.o}.ko"
> + dbg="${pdir}/usr/lib/debug/lib/modules/${KERNELRELEASE}/kernel/${mod}"
> + buildid=$("${READELF}" -n "${mod}" | sed -n 's@^.*Build ID: \(..\)\(.*\)@\1/\2@p')
> + link="${pdir}/usr/lib/debug/.build-id/${buildid}.debug"
> +
> + mkdir -p "${dbg%/*}" "${link%/*}"
> + "${OBJCOPY}" --only-keep-debug "${mod}" "${dbg}"
> + ln -sf --relative "${dbg}" "${link}"
> + done < modules.order
> + fi
>
> # Build debug package
> # Different tools want the image in different locations
> --
> 2.34.1
>
--
Best Regards
Masahiro Yamada
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2024-11-09 11:22 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-11-07 15:05 [PATCH v3] kbuild: deb-pkg: Don't fail if modules.order is missing Matt Fleming
2024-11-09 11:22 ` Masahiro Yamada
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox