From patchwork Fri Dec 15 09:56:39 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Srinuvasan Arjunan X-Patchwork-Id: 3234 Return-Path: Received: from shymkent.ilbers.de ([unix socket]) by shymkent (Cyrus 2.5.10-Debian-2.5.10-3+deb9u2) with LMTPA; Fri, 15 Dec 2023 10:57:13 +0100 X-Sieve: CMU Sieve 2.4 Received: from mail-io1-f64.google.com (mail-io1-f64.google.com [209.85.166.64]) by shymkent.ilbers.de (8.15.2/8.15.2/Debian-8+deb9u1) with ESMTPS id 3BF9vCgw003408 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT) for ; Fri, 15 Dec 2023 10:57:12 +0100 Received: by mail-io1-f64.google.com with SMTP id ca18e2360f4ac-7b71da9f8b9sf85253539f.2 for ; Fri, 15 Dec 2023 01:57:12 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1702634226; cv=pass; d=google.com; s=arc-20160816; b=JfkgRCXek8XOBrKTClEiEuFhAQ1mHHO/CaK86ncvnDLTya7LdUaSM+TX2XX9UKmRv8 lrLCDq63Kt5PTrb3ee6HUsOHah+sMqKI7w0xV/uBskYqlIfKWi9nhDuIF4Hz9ktUFNBX 6fhgHKpoGMnUIT2y8ZuTrOXgOYqm5Xrj4fH1N1ojEsojqqjl2XqMHoMt5KM5B5o+MMDt GGbZd0JHm6xg3p0NDMLrMepX+Ncb12Q625i7KUxPxSG8oBCao5KKnXzsPrxDwwsClwNC 2ZBUMg2kaqgydS5AwWkwVJkXONB/9SRtuhSiapNpTu5otQu2qbjt5ELwaDW4CU2LkQ7+ 3UaQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-unsubscribe:list-subscribe:list-archive:list-help:list-post :list-id:mailing-list:precedence:mime-version:message-id:date :subject:cc:to:from:ironport-sdr:sender:dkim-signature; bh=TZfaxg8Wl0C4qOsZcyliEg+V37pgjzDY4AncLKwR27o=; fh=Igj93TBK3i6c7Oy07qB7xeVIIK1PlortB1TNWYO0u9U=; b=YDPm1i8BmXCo71o2d2vSpJ/UE5Ul+VOLB92xIPkiGj4PzyCLk28ibIXfqOyH4a0+RO zYm74wcTdiJP4XH92tHdpCQUF6cKTm6nWhAbdkHEId2D03+OBE0m1vM58esVLMC20269 9H2S4EKc3ugV/DaCM8OOGwTUItNBZguRKTVLSokEhRMFeu3KVDrvCCXyOe4DUYfOYnYy zCtoL+XY3XRqbsza925qjHO4o/WH2pDrAQ2skY8KgEczs6wM/UGLhCYQTopvhltaKvOy djPPDQr6SWP6im+Bh/cOStZ3edubf5gNuYkIZljbpUvndVfWjQDzeq+giyLSn2ivyXVr Cw1w== ARC-Authentication-Results: i=2; gmr-mx.google.com; spf=pass (google.com: domain of srinuvasan_a@mentor.com designates 68.232.129.153 as permitted sender) smtp.mailfrom=Srinuvasan_A@mentor.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=googlegroups.com; s=20230601; t=1702634226; x=1703239026; darn=isar-build.org; h=list-unsubscribe:list-subscribe:list-archive:list-help:list-post :list-id:mailing-list:precedence:x-original-authentication-results :x-original-sender:mime-version:message-id:date:subject:cc:to:from :ironport-sdr:sender:from:to:cc:subject:date:message-id:reply-to; bh=TZfaxg8Wl0C4qOsZcyliEg+V37pgjzDY4AncLKwR27o=; b=kwsB0eBb4m0oavl4u+ruBHAotxgBh/+SrLZcdOiJCbe2fW/kxmrMB7ZOyLAPtkgCyt 710EpSNdPKnPjYe+rf6j9bg6Xm7DHf2WXgzg10ofNZieaIvyUuECT+j2glCvD/4SLCsq jS7QJGDM3jECDyOaISV/mW92hfwFp3GTHZ6rTUAZ5pJXPXDi8mTYJ/c7sKIyk9w9WgNj g1qSAf43cOQDlbKEfv3+2CeFtY0AbGphltEbzykh8elC6AGQMXzCO9A9VIYXQ7VFXyOs KpY2P7FOwkOkxWHk6Xpy41bT9f8m0rqZ6TuR6WEsrBYQGyZFEV93DOpPWb7RPYMDe3EC mXaw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1702634226; x=1703239026; h=list-unsubscribe:list-subscribe:list-archive:list-help:list-post :x-spam-checked-in-group:list-id:mailing-list:precedence :x-original-authentication-results:x-original-sender:mime-version :message-id:date:subject:cc:to:from:ironport-sdr:x-beenthere :x-gm-message-state:sender:from:to:cc:subject:date:message-id :reply-to; bh=TZfaxg8Wl0C4qOsZcyliEg+V37pgjzDY4AncLKwR27o=; b=b46llYOqUixwqaBRaFYI/hKglYxtcKDajU+xUayHyvW258p4T0R1GY8gWpXbwWjIP4 ippiMkA1Cm4qo3zWN+uwMP7q2/WLT3tmzN/7ZVUnSLJT7Pc0nuVgfDW5MA2pHmKWCPAW pK4kls0CHex+njGmtGflXWhBw2pR04f9O0RvJ8zzkHGMsFyJLQ2O1Lh/JSrB3gJMUEM7 s2v3Hq3FPYn1/qk2TTpd5uNMA8/c2uvvT2N96hI1XbPmN23n5ZnazYGynH/qWRMfLtv1 imlq/WYQXfO1Q+B3gAotPGjAWuAU25H/XvWuEwi5ZEhO1gS/+HRrE9nXKsBVj0lnaetZ TaQA== Sender: isar-users@googlegroups.com X-Gm-Message-State: AOJu0Yyixrv8QcBAQPvlQ1/CVUqXNBGvPzx8vlW1xRGNM8Hwq/M2VYFX JONa5OZ+6R/4KMCZyshYAgc= X-Google-Smtp-Source: AGHT+IHAC81vuv+DHYriNJ0Y3IHn+okNf+qCjOq7rT7QfqvTcZyQ+oLAEvJxSX5PXlqq1riOVGQlnw== X-Received: by 2002:a05:6e02:15cb:b0:35d:59a2:2cf with SMTP id q11-20020a056e0215cb00b0035d59a202cfmr17140768ilu.111.1702634226330; Fri, 15 Dec 2023 01:57:06 -0800 (PST) X-BeenThere: isar-users@googlegroups.com Received: by 2002:a92:1949:0:b0:35d:7c0c:b961 with SMTP id e9-20020a921949000000b0035d7c0cb961ls1173001ilm.1.-pod-prod-02-us; Fri, 15 Dec 2023 01:57:05 -0800 (PST) X-Received: by 2002:a05:6e02:1a88:b0:35d:5543:45dd with SMTP id k8-20020a056e021a8800b0035d554345ddmr15518591ilv.22.1702634225588; Fri, 15 Dec 2023 01:57:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1702634225; cv=none; d=google.com; s=arc-20160816; b=rAhovC+uMyQOb/StFHQYuG5GGCJsRjitU1h1hgnuXCaQVuWDmk2SnVZxSC9fkoaYMV I/UiavVqZsJB8es69JtNfDK4M8PMmbGtyjSBK0JjTJkNoyfnfLVrpQ6mDI/JfVdP9WDD b+xP5rjo9NDWqdF64D8We4jkOvvZvYwMU413J9OTKqzl0vNg136PDrIBOipBbpi+Mikc weKkcIhkp32bTbEhOeCOoyoE9FM+X2fn3IBKuT2fxMqarVTM417eUWmWkWOjzyKDLp6o EHEwotYCpnLn9iHhlobnhNlo9Z51oDtKYIXdSzqcdvu0Zrk+x3P4RBW5oWl2HlS5uBon YzEg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:ironport-sdr; bh=4a4qackidrmP5wnwq6IGkPik0iNfx001d4+dDraIz3o=; fh=Igj93TBK3i6c7Oy07qB7xeVIIK1PlortB1TNWYO0u9U=; b=c59mSdcCfLHf9bbekiX6ED4j/d+iHcpS4AtxFm+N/NPB1zUFrbimZgZnp6pAv6pz0H Q60pJE0NJxXN+KrgzqWo20KRe49BGWORQl6m0wsYcSBfOj/hzZj7c30i7MflvHkCLhSo Yz9YfkcN4bnHqgbWXFyN/retf45O98aMzNj0rrcMwPArxyiGCdA2+4KETheyzh+XQbEc mm/0H5SMMJOtrdX0MXYdFvBX6888IYK+Crc/o7Wf1h/buKSYMiorERrZHY7LYqbe/WAQ AdKqFgMuKWCRVcBM/KAhMfyapBzjO9gKRLb3ei7ox9EPBAsz3Y5n00erLibZoShmTX5n XdcA== ARC-Authentication-Results: i=1; gmr-mx.google.com; spf=pass (google.com: domain of srinuvasan_a@mentor.com designates 68.232.129.153 as permitted sender) smtp.mailfrom=Srinuvasan_A@mentor.com Received: from esa1.mentor.iphmx.com (esa1.mentor.iphmx.com. [68.232.129.153]) by gmr-mx.google.com with ESMTPS id 82-20020a630055000000b005ca45e6a45bsi506204pga.5.2023.12.15.01.57.05 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Fri, 15 Dec 2023 01:57:05 -0800 (PST) Received-SPF: pass (google.com: domain of srinuvasan_a@mentor.com designates 68.232.129.153 as permitted sender) client-ip=68.232.129.153; X-CSE-ConnectionGUID: oHcpFNe4R0ilaic4howMRg== X-CSE-MsgGUID: e2c3Llg/QKy94yYHF6FTzA== X-IronPort-AV: E=Sophos;i="6.04,278,1695715200"; d="scan'208";a="28651628" Received: from orw-gwy-02-in.mentorg.com ([192.94.38.167]) by esa1.mentor.iphmx.com with ESMTP; 15 Dec 2023 01:57:04 -0800 IronPort-SDR: g4OhP9PAxOa1UdzsWdzku8Ct6CkhdLz+9/Oja5sZ1ccvh6qcB+IQ7s+vLI0cUB0ZoHIiMOy9dx wBg6y04gyt6aPsmfMOLpwUkcf2SfMad5YOO/GwV6ruzg56a/cXWmAtX1mYXYG+UfFK6dvboJFG A66/zebMKmBbyG+rUkisqY7vKoozrnkiYcglchbKURjoxPgfjOiGKqpS8Ier0ixaV/D5HJjAoY BpDeSROsM3HRomGt4V2JcjJnLPKIYlDIzbavdXg/GKPoe3ibfaw6lfD04UoebtiV5sWo9qgRNM xzg= From: Srinuvasan Arjunan To: CC: , srinuvasan Subject: [PATCH] recipes-devtools/sbuild-chroot: install self-built packages in sbuild flavor Date: Fri, 15 Dec 2023 15:26:39 +0530 Message-ID: <20231215095639.566978-1-srinuvasan_a@mentor.com> X-Mailer: git-send-email 2.34.1 MIME-Version: 1.0 X-ClientProxiedBy: svr-orw-mbx-11.mgc.mentorg.com (147.34.90.211) To svr-orw-mbx-13.mgc.mentorg.com (147.34.90.213) X-Original-Sender: srinuvasan_a@mentor.com X-Original-Authentication-Results: gmr-mx.google.com; spf=pass (google.com: domain of srinuvasan_a@mentor.com designates 68.232.129.153 as permitted sender) smtp.mailfrom=Srinuvasan_A@mentor.com Precedence: list Mailing-list: list isar-users@googlegroups.com; contact isar-users+owners@googlegroups.com List-ID: X-Spam-Checked-In-Group: isar-users@googlegroups.com X-Google-Group-Id: 914930254986 List-Post: , List-Help: , List-Archive: , List-Unsubscribe: , X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIMWL_WL_MED,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_EF,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RCVD_IN_MSPIKE_H2,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.2 X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on shymkent.ilbers.de X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= From: srinuvasan In some use-cases we need to install custom packages in sbuildchroot and this can be referred later time during image generation part, hence we need the persistent sbuildchroot rather than the temporary sessions. Introduced persistent-sbuildchroot class to handle the above scenarios. Introduced SBUILD_CHROOT_INSTALL_EXTRA variable, here you can define the additional custom packages that you need to install in sbuild flavor. Signed-off-by: srinuvasan --- .../recipes-app/hello-isar/hello-isar.bb | 2 +- meta-isar/recipes-app/libhello/libhello.bb | 2 +- .../recipes-core/images/isar-image-base.bb | 3 + ...b => sbuild-chroot-host-extra-packages.bb} | 2 +- ...=> sbuild-chroot-target-extra-packages.bb} | 2 +- meta/classes/image.bbclass | 1 + meta/classes/persistent-sbuildchroot.bbclass | 64 +++++++++++++++++++ 7 files changed, 72 insertions(+), 4 deletions(-) rename meta-isar/recipes-devtools/sbuild-chroot/{sbuild-chroot-host-db2m.bb => sbuild-chroot-host-extra-packages.bb} (91%) rename meta-isar/recipes-devtools/sbuild-chroot/{sbuild-chroot-target-db2m.bb => sbuild-chroot-target-extra-packages.bb} (91%) create mode 100644 meta/classes/persistent-sbuildchroot.bbclass diff --git a/meta-isar/recipes-app/hello-isar/hello-isar.bb b/meta-isar/recipes-app/hello-isar/hello-isar.bb index 51dac2b7..484e5704 100644 --- a/meta-isar/recipes-app/hello-isar/hello-isar.bb +++ b/meta-isar/recipes-app/hello-isar/hello-isar.bb @@ -23,4 +23,4 @@ SRCREV = "a18c14cc11ce6b003f3469e89223cffb4016861d" inherit dpkg # Example of using alternative sbuild chroot -SBUILD_FLAVOR="db2m" +SBUILD_FLAVOR="extra-packages" diff --git a/meta-isar/recipes-app/libhello/libhello.bb b/meta-isar/recipes-app/libhello/libhello.bb index 71604bf5..4e6522fe 100644 --- a/meta-isar/recipes-app/libhello/libhello.bb +++ b/meta-isar/recipes-app/libhello/libhello.bb @@ -16,4 +16,4 @@ SRCREV = "98f2e41e7d05ab8d19b0c5d160b104b725c8fd93" inherit dpkg # Example of using alternative sbuild chroot -SBUILD_FLAVOR="db2m" +SBUILD_FLAVOR="extra-packages" diff --git a/meta-isar/recipes-core/images/isar-image-base.bb b/meta-isar/recipes-core/images/isar-image-base.bb index b381d859..17840906 100644 --- a/meta-isar/recipes-core/images/isar-image-base.bb +++ b/meta-isar/recipes-core/images/isar-image-base.bb @@ -10,4 +10,7 @@ LIC_FILES_CHKSUM = "file://${LAYERDIR_core}/licenses/COPYING.GPLv2;md5=751419260 PV = "1.0" +SBUILD_FLAVOR = "extra-packages" +SBUILD_CHROOT_INSTALL_EXTRA = "hello-isar" + inherit image diff --git a/meta-isar/recipes-devtools/sbuild-chroot/sbuild-chroot-host-db2m.bb b/meta-isar/recipes-devtools/sbuild-chroot/sbuild-chroot-host-extra-packages.bb similarity index 91% rename from meta-isar/recipes-devtools/sbuild-chroot/sbuild-chroot-host-db2m.bb rename to meta-isar/recipes-devtools/sbuild-chroot/sbuild-chroot-host-extra-packages.bb index 1795c5a2..b035a926 100644 --- a/meta-isar/recipes-devtools/sbuild-chroot/sbuild-chroot-host-db2m.bb +++ b/meta-isar/recipes-devtools/sbuild-chroot/sbuild-chroot-host-extra-packages.bb @@ -8,5 +8,5 @@ DESCRIPTION = "Isar sbuild/schroot filesystem for host (docbook-to-man)" require recipes-devtools/sbuild-chroot/sbuild-chroot-host.bb -SBUILD_FLAVOR = "db2m" +SBUILD_FLAVOR = "extra-packages" SBUILD_CHROOT_PREINSTALL_EXTRA ?= "docbook-to-man" diff --git a/meta-isar/recipes-devtools/sbuild-chroot/sbuild-chroot-target-db2m.bb b/meta-isar/recipes-devtools/sbuild-chroot/sbuild-chroot-target-extra-packages.bb similarity index 91% rename from meta-isar/recipes-devtools/sbuild-chroot/sbuild-chroot-target-db2m.bb rename to meta-isar/recipes-devtools/sbuild-chroot/sbuild-chroot-target-extra-packages.bb index e2e10433..80440df2 100644 --- a/meta-isar/recipes-devtools/sbuild-chroot/sbuild-chroot-target-db2m.bb +++ b/meta-isar/recipes-devtools/sbuild-chroot/sbuild-chroot-target-extra-packages.bb @@ -8,5 +8,5 @@ DESCRIPTION = "Isar sbuild/schroot filesystem for target (docbook-to-man)" require recipes-devtools/sbuild-chroot/sbuild-chroot-target.bb -SBUILD_FLAVOR = "db2m" +SBUILD_FLAVOR = "extra-packages" SBUILD_CHROOT_PREINSTALL_EXTRA ?= "docbook-to-man" diff --git a/meta/classes/image.bbclass b/meta/classes/image.bbclass index 73f1d52c..03a02583 100644 --- a/meta/classes/image.bbclass +++ b/meta/classes/image.bbclass @@ -85,6 +85,7 @@ inherit image-tools-extension inherit image-postproc-extension inherit image-locales-extension inherit image-account-extension +inherit persistent-sbuildchroot # Extra space for rootfs in MB ROOTFS_EXTRA ?= "64" diff --git a/meta/classes/persistent-sbuildchroot.bbclass b/meta/classes/persistent-sbuildchroot.bbclass new file mode 100644 index 00000000..388d156a --- /dev/null +++ b/meta/classes/persistent-sbuildchroot.bbclass @@ -0,0 +1,64 @@ +# This software is a part of ISAR. +# Copyright (C) Siemens AG, 2023 +# +# SPDX-License-Identifier: MIT +# +# This file extends the image.bbclass to supply tools for futher imager functions + +inherit sbuild + +SBUILD_FLAVOR = "extra-packages" +SBUILD_CHROOT_INSTALL_EXTRA ??= "" + +SCHROOT_MOUNTS = "${WORKDIR}:${PP_WORK} ${IMAGE_ROOTFS}:${PP_ROOTFS} ${DEPLOY_DIR_IMAGE}:${PP_DEPLOY}" +SCHROOT_MOUNTS += "${REPO_ISAR_DIR}/${DISTRO}:/isar-apt" + +ROOTFS_INSTALL_COMMAND:prepend = " sbuild_chroot_install_extra" + +sbuild_chroot_install_extra() { + + schroot_create_configs + insert_mounts + + if [ -n "${SBUILD_CHROOT_INSTALL_EXTRA}" ]; then + echo "Installing self built packages: ${SBUILD_CHROOT_INSTALL_EXTRA}" + + distro="${BASE_DISTRO}-${BASE_DISTRO_CODENAME}" + if [ ${ISAR_CROSS_COMPILE} -eq 1 ]; then + distro="${HOST_BASE_DISTRO}-${BASE_DISTRO_CODENAME}" + fi + + # prepare isar-apt + sudo -E chroot ${SCHROOT_DIR} sh -c " \ + mkdir -p '/etc/apt/sources.list.d' + echo 'deb [trusted=yes] file:///isar-apt ${DEBDISTRONAME} main' > \ + '/etc/apt/sources.list.d/isar-apt.list' + + mkdir -p '/etc/apt/preferences.d' + cat << EOF > '/etc/apt/preferences.d/isar-apt' +Package: ${SBUILD_CHROOT_INSTALL_EXTRA} +Pin: release n=${DEBDISTRONAME} +Pin-Priority: 1000 +EOF" + + E="${@ isar_export_proxies(d)}" + deb_dl_dir_import ${schroot_dir} ${distro} + sudo -E chroot ${SCHROOT_DIR} sh -c " \ + apt-get update \ + -o Dir::Etc::SourceList='sources.list.d/isar-apt.list' \ + -o Dir::Etc::SourceParts='-' \ + -o APT::Get::List-Cleanup='0' + apt-get -o Debug::pkgProblemResolver=yes --no-install-recommends -y \ + --allow-unauthenticated --allow-downgrades --download-only install \ + ${SBUILD_CHROOT_INSTALL_EXTRA}" + + deb_dl_dir_export ${schroot_dir} ${distro} + sudo -E chroot ${SCHROOT_DIR} sh -c " \ + apt-get -o Debug::pkgProblemResolver=yes --no-install-recommends -y \ + --allow-unauthenticated --allow-downgrades install \ + ${SBUILD_CHROOT_INSTALL_EXTRA}" + fi + + remove_mounts + schroot_delete_configs +}