Message ID | 20241024060903.1407158-2-srinuvasan.a@siemens.com |
---|---|
State | Superseded, archived |
Headers | show |
Series | [v3,1/2] add new machine qemuamd64-cip and corresponding mc | expand |
Hi Jan, Addressed the suggested points, Please confirm is this changes in V3 is fine or still need to look any changes? Many thanks, Srinu -----Original Message----- From: Arjunan, Srinu (FT FDS CES LX PBU 2) <srinuvasan.a@siemens.com> Sent: 24 October 2024 11:39 To: isar-users@googlegroups.com Cc: Hombourger, Cedric (FT FDS CES LX) <cedric.hombourger@siemens.com>; Kiszka, Jan (FT RPD CED) <jan.kiszka@siemens.com>; Arjunan, Srinu (FT FDS CES LX PBU 2) <srinuvasan.a@siemens.com> Subject: [PATCH v3 2/2] linux-custom: Add a provision to support CONFIG_LOCALVERSION_AUTO From: srinuvasan <srinuvasan.a@siemens.com> This change might be useful for downstream layers to set CONFIG_LOCALVERSION_AUTO in their base defconfig to append the version automatically to the kernel release. Presently ISAR doesn't have this support, hence add this provision. Here we try to find the CONFIG_LOCALVERSION_AUTO availability and .git present during build the kernel package, unfortunately we are not getting the .git directory in the dpkg_build stage even if we are fetching the git repo, this is due to sbuild always using the sources (dsc) file to build the package, when we generate the dsc file it creates the tar ball without .git, hence during the dpkg_build stage it is not possible to get the latest commit HEAD value using "git rev-parse --verify HEAD" To solve this issue, we have base .config and .git available in the do_dpkg_source stage, here we try to find the latest commit and write them into .scmversion file, later during the kernel build package stage we are calling the kernelrelease target to set the localversion, this setlocalversion script handle the availability of .scmversion file and append the string accordingly to the kernelrelease. Added qemuamd64-cip BSP to demonstrate this feature. Signed-off-by: srinuvasan <srinuvasan.a@siemens.com> --- meta-isar/recipes-kernel/linux/files/x86_64_defconfig | 2 +- .../linux/files/debian/isar/version.cfg.tmpl | 1 - meta/recipes-kernel/linux/linux-custom.inc | 10 ++++++++++ 3 files changed, 11 insertions(+), 2 deletions(-) diff --git a/meta-isar/recipes-kernel/linux/files/x86_64_defconfig b/meta-isar/recipes-kernel/linux/files/x86_64_defconfig index f3bafe00..c27a5a61 100644 --- a/meta-isar/recipes-kernel/linux/files/x86_64_defconfig +++ b/meta-isar/recipes-kernel/linux/files/x86_64_defconfig @@ -1,6 +1,6 @@ # Copy of linux/arch/x86/configs/x86_64_defconfig for demonstration purposes -# CONFIG_LOCALVERSION_AUTO is not set +CONFIG_LOCALVERSION_AUTO=y CONFIG_SYSVIPC=y CONFIG_POSIX_MQUEUE=y CONFIG_BSD_PROCESS_ACCT=y diff --git a/meta/recipes-kernel/linux/files/debian/isar/version.cfg.tmpl b/meta/recipes-kernel/linux/files/debian/isar/version.cfg.tmpl index 17effe52..1ab699f5 100644 --- a/meta/recipes-kernel/linux/files/debian/isar/version.cfg.tmpl +++ b/meta/recipes-kernel/linux/files/debian/isar/version.cfg.tmpl @@ -1,2 +1 @@ CONFIG_LOCALVERSION="${LINUX_VERSION_EXTENSION}" -# CONFIG_LOCALVERSION_AUTO is not set diff --git a/meta/recipes-kernel/linux/linux-custom.inc b/meta/recipes-kernel/linux/linux-custom.inc index 0f23d6f0..bf6c879b 100644 --- a/meta/recipes-kernel/linux/linux-custom.inc +++ b/meta/recipes-kernel/linux/linux-custom.inc @@ -296,6 +296,16 @@ EOF done } +get_localversion_auto() { + if grep -q "^CONFIG_LOCALVERSION_AUTO=y" ${S}/${KERNEL_BUILD_DIR}/.config; then + cd ${S} + if head=$(git rev-parse --verify --short HEAD 2>/dev/null); then + echo "-g${head}" >${S}/.scmversion + fi + fi +} + do_dpkg_source:prepend() { dpkg_configure_kernel + get_localversion_auto } -- 2.39.5
On 25.10.24 07:14, Arjunan, Srinu (FT FDS CES LX PBU 2) wrote: > Hi Jan, > > Addressed the suggested points, Please confirm is this changes in V3 is fine or still need to look any changes? Looks good to me now. Jan > > Many thanks, > Srinu > > -----Original Message----- > From: Arjunan, Srinu (FT FDS CES LX PBU 2) <srinuvasan.a@siemens.com> > Sent: 24 October 2024 11:39 > To: isar-users@googlegroups.com > Cc: Hombourger, Cedric (FT FDS CES LX) <cedric.hombourger@siemens.com>; Kiszka, Jan (FT RPD CED) <jan.kiszka@siemens.com>; Arjunan, Srinu (FT FDS CES LX PBU 2) <srinuvasan.a@siemens.com> > Subject: [PATCH v3 2/2] linux-custom: Add a provision to support CONFIG_LOCALVERSION_AUTO > > From: srinuvasan <srinuvasan.a@siemens.com> > > This change might be useful for downstream layers to set CONFIG_LOCALVERSION_AUTO in their base defconfig to append the version automatically to the kernel release. > > Presently ISAR doesn't have this support, hence add this provision. > > Here we try to find the CONFIG_LOCALVERSION_AUTO availability and .git present during build the kernel package, unfortunately we are not getting the .git directory in the dpkg_build stage even if we are fetching the git repo, this is due to sbuild always using the sources (dsc) file to build the package, when we generate the dsc file it creates the tar ball without .git, hence during the dpkg_build stage it is not possible to get the latest commit HEAD value using "git rev-parse --verify HEAD" > > To solve this issue, we have base .config and .git available in the do_dpkg_source stage, here we try to find the latest commit and write them into .scmversion file, later during the kernel build package stage we are calling the kernelrelease target to set the localversion, this setlocalversion script handle the availability of .scmversion file and append the string accordingly to the kernelrelease. > > Added qemuamd64-cip BSP to demonstrate this feature. > > Signed-off-by: srinuvasan <srinuvasan.a@siemens.com> > --- > meta-isar/recipes-kernel/linux/files/x86_64_defconfig | 2 +- > .../linux/files/debian/isar/version.cfg.tmpl | 1 - > meta/recipes-kernel/linux/linux-custom.inc | 10 ++++++++++ > 3 files changed, 11 insertions(+), 2 deletions(-) > > diff --git a/meta-isar/recipes-kernel/linux/files/x86_64_defconfig b/meta-isar/recipes-kernel/linux/files/x86_64_defconfig > index f3bafe00..c27a5a61 100644 > --- a/meta-isar/recipes-kernel/linux/files/x86_64_defconfig > +++ b/meta-isar/recipes-kernel/linux/files/x86_64_defconfig > @@ -1,6 +1,6 @@ > # Copy of linux/arch/x86/configs/x86_64_defconfig for demonstration purposes > > -# CONFIG_LOCALVERSION_AUTO is not set > +CONFIG_LOCALVERSION_AUTO=y > CONFIG_SYSVIPC=y > CONFIG_POSIX_MQUEUE=y > CONFIG_BSD_PROCESS_ACCT=y > diff --git a/meta/recipes-kernel/linux/files/debian/isar/version.cfg.tmpl b/meta/recipes-kernel/linux/files/debian/isar/version.cfg.tmpl > index 17effe52..1ab699f5 100644 > --- a/meta/recipes-kernel/linux/files/debian/isar/version.cfg.tmpl > +++ b/meta/recipes-kernel/linux/files/debian/isar/version.cfg.tmpl > @@ -1,2 +1 @@ > CONFIG_LOCALVERSION="${LINUX_VERSION_EXTENSION}" > -# CONFIG_LOCALVERSION_AUTO is not set > diff --git a/meta/recipes-kernel/linux/linux-custom.inc b/meta/recipes-kernel/linux/linux-custom.inc > index 0f23d6f0..bf6c879b 100644 > --- a/meta/recipes-kernel/linux/linux-custom.inc > +++ b/meta/recipes-kernel/linux/linux-custom.inc > @@ -296,6 +296,16 @@ EOF > done > } > > +get_localversion_auto() { > + if grep -q "^CONFIG_LOCALVERSION_AUTO=y" ${S}/${KERNEL_BUILD_DIR}/.config; then > + cd ${S} > + if head=$(git rev-parse --verify --short HEAD 2>/dev/null); then > + echo "-g${head}" >${S}/.scmversion > + fi > + fi > +} > + > do_dpkg_source:prepend() { > dpkg_configure_kernel > + get_localversion_auto > } > -- > 2.39.5 >
On Fri, 2024-10-25 at 11:09 +0200, 'Jan Kiszka' via isar-users wrote: > On 25.10.24 07:14, Arjunan, Srinu (FT FDS CES LX PBU 2) wrote: > > Hi Jan, > > > > Addressed the suggested points, Please confirm is > > this changes in V3 is fine or still need to look any changes? > > Looks good to me now. > > Jan > > > Just one more addition for patch v1. Since a new machine config is added, it is worth having kas menu item for it as well. Running `scripts/generate_yaml.sh` should help with it, but manual editing of Kconfig files (distro/ and machine/) is also required. > > Many thanks, > > Srinu > > > > -----Original Message----- > > From: Arjunan, Srinu (FT FDS CES LX PBU 2) > > <srinuvasan.a@siemens.com> > > Sent: 24 October 2024 11:39 > > To: isar-users@googlegroups.com > > Cc: Hombourger, Cedric (FT FDS CES LX) > > <cedric.hombourger@siemens.com>; Kiszka, Jan (FT RPD CED) > > <jan.kiszka@siemens.com>; Arjunan, Srinu (FT FDS CES LX PBU 2) > > <srinuvasan.a@siemens.com> > > Subject: [PATCH v3 2/2] linux-custom: Add a provision to support > > CONFIG_LOCALVERSION_AUTO > > > > From: srinuvasan <srinuvasan.a@siemens.com> > > > > This change might be useful for downstream layers to set > > CONFIG_LOCALVERSION_AUTO in their base defconfig to append the > > version automatically to the kernel release. > > > > Presently ISAR doesn't have this support, hence add this provision. > > > > Here we try to find the CONFIG_LOCALVERSION_AUTO availability and > > .git present during build the kernel package, unfortunately we are > > not getting the .git directory in the dpkg_build stage even if we > > are fetching the git repo, this is due to sbuild always using the > > sources (dsc) file to build the package, when we generate the dsc > > file it creates the tar ball without .git, hence during the > > dpkg_build stage it is not possible to get the latest commit HEAD > > value using "git rev-parse --verify HEAD" > > > > To solve this issue, we have base .config and .git available in the > > do_dpkg_source stage, here we try to find the latest commit and > > write them into .scmversion file, later during the kernel build > > package stage we are calling the kernelrelease target to set the > > localversion, this setlocalversion script handle the availability > > of .scmversion file and append the string accordingly to the > > kernelrelease. > > > > Added qemuamd64-cip BSP to demonstrate this feature. > > > > Signed-off-by: srinuvasan <srinuvasan.a@siemens.com> > > --- > > meta-isar/recipes-kernel/linux/files/x86_64_defconfig | 2 +- > > .../linux/files/debian/isar/version.cfg.tmpl | 1 - > > meta/recipes-kernel/linux/linux-custom.inc | 10 > > ++++++++++ > > 3 files changed, 11 insertions(+), 2 deletions(-) > > > > diff --git a/meta-isar/recipes-kernel/linux/files/x86_64_defconfig > > b/meta-isar/recipes-kernel/linux/files/x86_64_defconfig > > index f3bafe00..c27a5a61 100644 > > --- a/meta-isar/recipes-kernel/linux/files/x86_64_defconfig > > +++ b/meta-isar/recipes-kernel/linux/files/x86_64_defconfig > > @@ -1,6 +1,6 @@ > > # Copy of linux/arch/x86/configs/x86_64_defconfig for > > demonstration purposes > > > > -# CONFIG_LOCALVERSION_AUTO is not set > > +CONFIG_LOCALVERSION_AUTO=y > > CONFIG_SYSVIPC=y > > CONFIG_POSIX_MQUEUE=y > > CONFIG_BSD_PROCESS_ACCT=y > > diff --git a/meta/recipes- > > kernel/linux/files/debian/isar/version.cfg.tmpl b/meta/recipes- > > kernel/linux/files/debian/isar/version.cfg.tmpl > > index 17effe52..1ab699f5 100644 > > --- a/meta/recipes-kernel/linux/files/debian/isar/version.cfg.tmpl > > +++ b/meta/recipes-kernel/linux/files/debian/isar/version.cfg.tmpl > > @@ -1,2 +1 @@ > > CONFIG_LOCALVERSION="${LINUX_VERSION_EXTENSION}" > > -# CONFIG_LOCALVERSION_AUTO is not set > > diff --git a/meta/recipes-kernel/linux/linux-custom.inc > > b/meta/recipes-kernel/linux/linux-custom.inc > > index 0f23d6f0..bf6c879b 100644 > > --- a/meta/recipes-kernel/linux/linux-custom.inc > > +++ b/meta/recipes-kernel/linux/linux-custom.inc > > @@ -296,6 +296,16 @@ EOF > > done > > } > > > > +get_localversion_auto() { > > + if grep -q "^CONFIG_LOCALVERSION_AUTO=y" > > ${S}/${KERNEL_BUILD_DIR}/.config; then > > + cd ${S} > > + if head=$(git rev-parse --verify --short HEAD > > 2>/dev/null); then > > + echo "-g${head}" >${S}/.scmversion > > + fi > > + fi > > +} > > + > > do_dpkg_source:prepend() { > > dpkg_configure_kernel > > + get_localversion_auto > > } > > -- > > 2.39.5 > > > > -- > Siemens AG, Technology > Linux Expert Center >
diff --git a/meta-isar/recipes-kernel/linux/files/x86_64_defconfig b/meta-isar/recipes-kernel/linux/files/x86_64_defconfig index f3bafe00..c27a5a61 100644 --- a/meta-isar/recipes-kernel/linux/files/x86_64_defconfig +++ b/meta-isar/recipes-kernel/linux/files/x86_64_defconfig @@ -1,6 +1,6 @@ # Copy of linux/arch/x86/configs/x86_64_defconfig for demonstration purposes -# CONFIG_LOCALVERSION_AUTO is not set +CONFIG_LOCALVERSION_AUTO=y CONFIG_SYSVIPC=y CONFIG_POSIX_MQUEUE=y CONFIG_BSD_PROCESS_ACCT=y diff --git a/meta/recipes-kernel/linux/files/debian/isar/version.cfg.tmpl b/meta/recipes-kernel/linux/files/debian/isar/version.cfg.tmpl index 17effe52..1ab699f5 100644 --- a/meta/recipes-kernel/linux/files/debian/isar/version.cfg.tmpl +++ b/meta/recipes-kernel/linux/files/debian/isar/version.cfg.tmpl @@ -1,2 +1 @@ CONFIG_LOCALVERSION="${LINUX_VERSION_EXTENSION}" -# CONFIG_LOCALVERSION_AUTO is not set diff --git a/meta/recipes-kernel/linux/linux-custom.inc b/meta/recipes-kernel/linux/linux-custom.inc index 0f23d6f0..bf6c879b 100644 --- a/meta/recipes-kernel/linux/linux-custom.inc +++ b/meta/recipes-kernel/linux/linux-custom.inc @@ -296,6 +296,16 @@ EOF done } +get_localversion_auto() { + if grep -q "^CONFIG_LOCALVERSION_AUTO=y" ${S}/${KERNEL_BUILD_DIR}/.config; then + cd ${S} + if head=$(git rev-parse --verify --short HEAD 2>/dev/null); then + echo "-g${head}" >${S}/.scmversion + fi + fi +} + do_dpkg_source:prepend() { dpkg_configure_kernel + get_localversion_auto }