diff options
author | Bruce Ashfield <bruce.ashfield@gmail.com> | 2023-07-05 14:44:39 +0000 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2023-07-12 16:50:45 +0100 |
commit | bb0f9e87700aa40ec8db880ede3c018c1d055786 (patch) | |
tree | 56e78884db517cc5c4605c81bb806586da4fe692 /meta/classes-recipe | |
parent | 9cc1290cd6dd87f8b5adcf804ae29ef63d9aca95 (diff) | |
download | poky-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.bbclass | 7 | ||||
-rw-r--r-- | meta/classes-recipe/kernel.bbclass | 6 |
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}" | |||
80 | KERNEL_STRIP = "${CCACHE}${HOST_PREFIX}strip ${HOST_STRIP_KERNEL_ARCH}" | 80 | KERNEL_STRIP = "${CCACHE}${HOST_PREFIX}strip ${HOST_STRIP_KERNEL_ARCH}" |
81 | TOOLCHAIN ?= "gcc" | 81 | TOOLCHAIN ?= "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. | ||
88 | KERNEL_LOCALVERSION ??= "" | ||
89 | export 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 |
621 | SYSROOT_DIRS = "" | 621 | SYSROOT_DIRS = "" |
622 | 622 | ||
623 | KERNEL_LOCALVERSION ??= "" | ||
624 | KERNEL_CONFIG_COMMAND ?= "oe_runmake_call -C ${S} O=${B} olddefconfig || oe_runmake -C ${S} O=${B} oldnoconfig" | 623 | KERNEL_CONFIG_COMMAND ?= "oe_runmake_call -C ${S} O=${B} olddefconfig || oe_runmake -C ${S} O=${B} oldnoconfig" |
625 | 624 | ||
626 | python check_oldest_kernel() { | 625 | python 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 |