summaryrefslogtreecommitdiffstats
path: root/meta/classes-recipe
diff options
context:
space:
mode:
authorBruce Ashfield <bruce.ashfield@gmail.com>2023-07-05 14:44:39 +0000
committerRichard Purdie <richard.purdie@linuxfoundation.org>2023-07-12 16:50:45 +0100
commitbb0f9e87700aa40ec8db880ede3c018c1d055786 (patch)
tree56e78884db517cc5c4605c81bb806586da4fe692 /meta/classes-recipe
parent9cc1290cd6dd87f8b5adcf804ae29ef63d9aca95 (diff)
downloadpoky-bb0f9e87700aa40ec8db880ede3c018c1d055786.tar.gz
kernel: fix localversion in v6.3+
During testing of the v6.4 reference kernel, it was noticed that on-target modules no longer matched the magic value of the running kernel. This was due to a different localversion in the cross built kernel and the scripts / resources created on target. This was due to changes in the setlocalversion script introduced in the v6.3 series. The .scmversion file is no longer used (or packaged) to inhibit the addition of a "+" (through querying of the git status of the kernel) or the setting of a local version. We recently introduced the KERNEL_LOCALVERSION variable to allow recipes to place a value in .scmversion, so we extend the use of that variable to kernel-arch.bbclass and use it to set the exported variable LOCALVERSION. We must do it at the kernel-arch level, as the variable must be exported in any kernel build to ensure that setlocalversion always correctly sets the localversion. (From OE-Core rev: 765b13b7305c8d2f222cfc66d77c02e6a088c691) Signed-off-by: Bruce Ashfield <bruce.ashfield@gmail.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/classes-recipe')
-rw-r--r--meta/classes-recipe/kernel-arch.bbclass7
-rw-r--r--meta/classes-recipe/kernel.bbclass6
2 files changed, 11 insertions, 2 deletions
diff --git a/meta/classes-recipe/kernel-arch.bbclass b/meta/classes-recipe/kernel-arch.bbclass
index 6e19dbbba8..df4884b6c4 100644
--- a/meta/classes-recipe/kernel-arch.bbclass
+++ b/meta/classes-recipe/kernel-arch.bbclass
@@ -80,3 +80,10 @@ KERNEL_OBJCOPY = "${CCACHE}${HOST_PREFIX}objcopy ${HOST_OBJCOPY_KERNEL_ARCH}"
80KERNEL_STRIP = "${CCACHE}${HOST_PREFIX}strip ${HOST_STRIP_KERNEL_ARCH}" 80KERNEL_STRIP = "${CCACHE}${HOST_PREFIX}strip ${HOST_STRIP_KERNEL_ARCH}"
81TOOLCHAIN ?= "gcc" 81TOOLCHAIN ?= "gcc"
82 82
83# 6.3+ requires the variable LOCALVERSION to be set to not get a "+" in
84# the local version. Having it empty means nothing will be added, and any
85# value will be appended to the local kernel version. This replaces the
86# use of .scmversion file for setting a localversion without using
87# the CONFIG_LOCALVERSION option.
88KERNEL_LOCALVERSION ??= ""
89export LOCALVERSION ?= "${KERNEL_LOCALVERSION}"
diff --git a/meta/classes-recipe/kernel.bbclass b/meta/classes-recipe/kernel.bbclass
index 855c784149..2aedf3a31b 100644
--- a/meta/classes-recipe/kernel.bbclass
+++ b/meta/classes-recipe/kernel.bbclass
@@ -426,7 +426,7 @@ do_compile_kernelmodules() {
426 if (grep -q -i -e '^CONFIG_MODULES=y$' ${B}/.config); then 426 if (grep -q -i -e '^CONFIG_MODULES=y$' ${B}/.config); then
427 oe_runmake -C ${B} ${PARALLEL_MAKE} modules ${KERNEL_EXTRA_ARGS} 427 oe_runmake -C ${B} ${PARALLEL_MAKE} modules ${KERNEL_EXTRA_ARGS}
428 428
429 # Module.symvers gets updated during the 429 # Module.symvers gets updated during the
430 # building of the kernel modules. We need to 430 # building of the kernel modules. We need to
431 # update this in the shared workdir since some 431 # update this in the shared workdir since some
432 # external kernel modules has a dependency on 432 # external kernel modules has a dependency on
@@ -620,7 +620,6 @@ do_shared_workdir () {
620# We don't need to stage anything, not the modules/firmware since those would clash with linux-firmware 620# We don't need to stage anything, not the modules/firmware since those would clash with linux-firmware
621SYSROOT_DIRS = "" 621SYSROOT_DIRS = ""
622 622
623KERNEL_LOCALVERSION ??= ""
624KERNEL_CONFIG_COMMAND ?= "oe_runmake_call -C ${S} O=${B} olddefconfig || oe_runmake -C ${S} O=${B} oldnoconfig" 623KERNEL_CONFIG_COMMAND ?= "oe_runmake_call -C ${S} O=${B} olddefconfig || oe_runmake -C ${S} O=${B} oldnoconfig"
625 624
626python check_oldest_kernel() { 625python check_oldest_kernel() {
@@ -642,6 +641,9 @@ kernel_do_configure() {
642 # $ scripts/setlocalversion . => + 641 # $ scripts/setlocalversion . => +
643 # $ make kernelversion => 2.6.37 642 # $ make kernelversion => 2.6.37
644 # $ make kernelrelease => 2.6.37+ 643 # $ make kernelrelease => 2.6.37+
644 # See kernel-arch.bbclass for post v6.3 removal of the extra
645 # + in localversion. .scmversion is no longer used, and the
646 # variable LOCALVERSION must be used
645 if [ ! -e ${B}/.scmversion -a ! -e ${S}/.scmversion ]; then 647 if [ ! -e ${B}/.scmversion -a ! -e ${S}/.scmversion ]; then
646 echo ${KERNEL_LOCALVERSION} > ${B}/.scmversion 648 echo ${KERNEL_LOCALVERSION} > ${B}/.scmversion
647 echo ${KERNEL_LOCALVERSION} > ${S}/.scmversion 649 echo ${KERNEL_LOCALVERSION} > ${S}/.scmversion