From: Bruce Ashfield <bruce.ashfi...@gmail.com>

linux-yocto-dev tracks the latest mainline kernel, and uses
standard/* for that support.

Archived -dev versions are under v<kernel version>/standard/base.

This policy works, except that a released branch will still follow
the new kernel versions, causing potential breakage with newer
kernels than are supported in that release.

Rather than lock the SRCREVs and update branches in old releases,
we can preserve the AUTOREV nature of -dev, and allow them to
switch automatically to the archived branch based on the LINUX_VERSION
in the -dev recipe (which is unchanged in the release branch).

This is consistent with the other branch switching done for the
kernels and with the -dev workflow.

Signed-off-by: Bruce Ashfield <bruce.ashfi...@gmail.com>
---
 meta/classes/kernel-yocto.bbclass | 24 ++++++++++++++++++++++++
 1 file changed, 24 insertions(+)

diff --git a/meta/classes/kernel-yocto.bbclass 
b/meta/classes/kernel-yocto.bbclass
index ba139dd7f8..0df61cdef0 100644
--- a/meta/classes/kernel-yocto.bbclass
+++ b/meta/classes/kernel-yocto.bbclass
@@ -631,7 +631,31 @@ do_validate_branches() {
        # if SRCREV is AUTOREV it shows up as AUTOINC there's nothing to
        # check and we can exit early
        if [ "${machine_srcrev}" = "AUTOINC" ]; then
+           
linux_yocto_dev='${@oe.utils.conditional("PREFERRED_PROVIDER_virtual/kernel", 
"linux-yocto-dev", "1", "", d)}'
+           if [ -n "$linux_yocto_dev" ]; then
+               git checkout -q -f ${machine_branch}
+               ver=$(grep "^VERSION =" ${S}/Makefile | sed s/.*=\ *//)
+               patchlevel=$(grep "^PATCHLEVEL =" ${S}/Makefile | sed s/.*=\ 
*//)
+               sublevel=$(grep "^SUBLEVEL =" ${S}/Makefile | sed s/.*=\ *//)
+               kver="$ver.$patchlevel"
+               bbnote "dev kernel: performing version -> branch -> SRCREV 
validation"
+               bbnote "dev kernel: recipe version ${LINUX_VERSION}, src 
version: $kver"
+               echo "${LINUX_VERSION}" | grep -q $kver
+               if [ $? -ne 0 ]; then
+                   version="$(echo ${LINUX_VERSION} | sed 's/\+.*$//g')"
+                   versioned_branch="v$version/$machine_branch"
+
+                   machine_branch=$versioned_branch
+                   force_srcrev="$(git rev-parse $machine_branch 2> /dev/null)"
+                   if [ $? -ne 0 ]; then
+                       bbfatal "kernel version mismatch detected, and no valid 
branch $machine_branch detected"
+                   fi
+
+                   bbnote "dev kernel: adjusting branch to $machine_branch, 
srcrev to: $force_srcrev"
+               fi
+           else
                bbnote "SRCREV validation is not required for AUTOREV"
+           fi
        elif [ "${machine_srcrev}" = "" ]; then
                if [ "${SRCREV}" != "AUTOINC" ] && [ "${SRCREV}" != "INVALID" 
]; then
                       # SRCREV_machine_<MACHINE> was not set. This means that 
a custom recipe
-- 
2.19.1

-=-=-=-=-=-=-=-=-=-=-=-
Links: You receive all messages sent to this group.
View/Reply Online (#153039): 
https://lists.openembedded.org/g/openembedded-core/message/153039
Mute This Topic: https://lists.openembedded.org/mt/83590328/21656
Group Owner: openembedded-core+ow...@lists.openembedded.org
Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub 
[arch...@mail-archive.com]
-=-=-=-=-=-=-=-=-=-=-=-

Reply via email to