public inbox for stable@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] kbuild: deb-pkg: don't set KBUILD_BUILD_VERSION indiscriminately
@ 2025-03-05 19:25 Alexandru Gagniuc
  2025-03-07 16:36 ` Nicolas Schier
  2025-03-11 18:05 ` Masahiro Yamada
  0 siblings, 2 replies; 4+ messages in thread
From: Alexandru Gagniuc @ 2025-03-05 19:25 UTC (permalink / raw)
  To: masahiroy, nathan, linux-kbuild
  Cc: nicolas, linux-kernel, Alexandru Gagniuc, stable

In ThinPro, we use the convention <upstream_ver>+hp<patchlevel> for
the kernel package. This does not have a dash in the name or version.
This is built by editing ".version" before a build, and setting
EXTRAVERSION="+hp" and KDEB_PKGVERSION make variables:

    echo 68 > .version
    make -j<n> EXTRAVERSION="+hp" bindeb-pkg KDEB_PKGVERSION=6.6.6+hp69

    .deb name: linux-image-6.6.6+hp_6.6.6+hp69_amd64.deb

Since commit 7d4f07d5cb71 ("kbuild: deb-pkg: squash
scripts/package/deb-build-option to debian/rules"), this no longer
works. The deb build logic changed, even though, the commit message
implies that the logic should be unmodified.

Before, KBUILD_BUILD_VERSION was not set if the KDEB_PKGVERSION did
not contain a dash. After the change KBUILD_BUILD_VERSION is always
set to KDEB_PKGVERSION. Since this determines UTS_VERSION,the uname
output to look off:

    (now)      uname -a: version 6.6.6+hp ... #6.6.6+hp69
    (expected) uname -a: version 6.6.6+hp ... #69

Update the debian/rules logic to restore the original behavior.

Cc: <stable@vger.kernel.org> # v6.12+
Fixes: 7d4f07d5cb71 ("kbuild: deb-pkg: squash scripts/package/deb-build-option to debian/rules")
Signed-off-by: Alexandru Gagniuc <alexandru.gagniuc@hp.com>
---
 scripts/package/debian/rules | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)

diff --git a/scripts/package/debian/rules b/scripts/package/debian/rules
index ca07243bd5cd..bbc214f2e6bd 100755
--- a/scripts/package/debian/rules
+++ b/scripts/package/debian/rules
@@ -21,9 +21,13 @@ ifeq ($(origin KBUILD_VERBOSE),undefined)
     endif
 endif
 
-revision = $(lastword $(subst -, ,$(shell dpkg-parsechangelog -S Version)))
+debian_revision = $(shell dpkg-parsechangelog -S Version)
+revision = $(lastword $(subst -, ,$(debian_revision)))
 CROSS_COMPILE ?= $(filter-out $(DEB_BUILD_GNU_TYPE)-, $(DEB_HOST_GNU_TYPE)-)
-make-opts = ARCH=$(ARCH) KERNELRELEASE=$(KERNELRELEASE) KBUILD_BUILD_VERSION=$(revision) $(addprefix CROSS_COMPILE=,$(CROSS_COMPILE))
+make-opts = ARCH=$(ARCH) KERNELRELEASE=$(KERNELRELEASE) $(addprefix CROSS_COMPILE=,$(CROSS_COMPILE))
+ifneq ($(revision), $(debian_revision))
+    make-opts+=KBUILD_BUILD_VERSION=$(revision)
+endif
 
 binary-targets := $(addprefix binary-, image image-dbg headers libc-dev)
 
-- 
2.48.1


^ permalink raw reply related	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2025-03-11 18:05 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-03-05 19:25 [PATCH] kbuild: deb-pkg: don't set KBUILD_BUILD_VERSION indiscriminately Alexandru Gagniuc
2025-03-07 16:36 ` Nicolas Schier
2025-03-07 20:56   ` Nathan Chancellor
2025-03-11 18:05 ` Masahiro Yamada

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox