public inbox for isar-users@googlegroups.com
 help / color / mirror / Atom feed
* [PATCH v2 0/2] Move isar-image into image class
@ 2019-03-21 11:57 claudius.heine.ext
  2019-03-21 11:57 ` [PATCH v2 1/2] meta: merges " claudius.heine.ext
                   ` (2 more replies)
  0 siblings, 3 replies; 4+ messages in thread
From: claudius.heine.ext @ 2019-03-21 11:57 UTC (permalink / raw)
  To: isar-users; +Cc: Claudius Heine

From: Claudius Heine <ch@denx.de>

Hi,

this is the second version of this patchset.

Changes from v1:
 - added documentation changes to first patch
 - added second patch that marks isar-image as deprecated

Claudius Heine (2):
  meta: merges isar-image into image class
  deprecate isar-image

 RECIPE-API-CHANGELOG.md                       |  9 ++
 doc/user_manual.md                            |  4 +-
 .../recipes-core/images/isar-image-base.bb    |  2 +-
 .../recipes-core/images/isar-image-ubi.bb     |  2 +-
 meta/classes/image.bbclass                    | 86 +++++++++++++++++-
 meta/classes/isar-image.bbclass               | 91 +------------------
 6 files changed, 101 insertions(+), 93 deletions(-)

-- 
2.20.1


^ permalink raw reply	[flat|nested] 4+ messages in thread

* [PATCH v2 1/2] meta: merges isar-image into image class
  2019-03-21 11:57 [PATCH v2 0/2] Move isar-image into image class claudius.heine.ext
@ 2019-03-21 11:57 ` claudius.heine.ext
  2019-03-21 11:57 ` [PATCH v2 2/2] deprecate isar-image claudius.heine.ext
  2019-03-28 12:45 ` [PATCH v2 0/2] Move isar-image into image class Maxim Yu. Osipov
  2 siblings, 0 replies; 4+ messages in thread
From: claudius.heine.ext @ 2019-03-21 11:57 UTC (permalink / raw)
  To: isar-users; +Cc: Claudius Heine

From: Claudius Heine <ch@denx.de>

(no functional change intended)

Signed-off-by: Claudius Heine <ch@denx.de>
---
 doc/user_manual.md              |  2 +-
 meta/classes/image.bbclass      | 86 +++++++++++++++++++++++++++++--
 meta/classes/isar-image.bbclass | 90 +--------------------------------
 3 files changed, 86 insertions(+), 92 deletions(-)

diff --git a/doc/user_manual.md b/doc/user_manual.md
index 6fe4d83..9ea3f42 100644
--- a/doc/user_manual.md
+++ b/doc/user_manual.md
@@ -516,7 +516,7 @@ Packages in the `IMAGE_TRANSIENT_PACKAGES` variable are installed to the image a
 
 ## Create a Custom Image Recipe
 
-A custom image recipe may be created to assemble packages of your choice into a root file-system image. The `isar-image` class
+A custom image recipe may be created to assemble packages of your choice into a root file-system image. The `image` class
 implements a `do_rootfs` function to compile and configure the file-system for you. Prebuilt packages may be selected for
 installation by appending them to the `IMAGE_PREINSTALL` variable while packages created by ISAR should be appended to
 `IMAGE_INSTALL`. A sample image recipe follows.
diff --git a/meta/classes/image.bbclass b/meta/classes/image.bbclass
index bebac6b..3ba755f 100644
--- a/meta/classes/image.bbclass
+++ b/meta/classes/image.bbclass
@@ -25,6 +25,24 @@ BUILDROOT_DEPLOY = "${BUILDCHROOT_DIR}${PP_DEPLOY}"
 BUILDROOT_ROOTFS = "${BUILDCHROOT_DIR}${PP_ROOTFS}"
 BUILDROOT_WORK = "${BUILDCHROOT_DIR}${PP_WORK}"
 
+def cfg_script(d):
+    cf = d.getVar('DISTRO_CONFIG_SCRIPT', True) or ''
+    if cf:
+        return 'file://' + cf
+    return ''
+
+FILESPATH =. "${LAYERDIR_core}/conf/distro:"
+SRC_URI += "${@ cfg_script(d) }"
+
+DEPENDS += "${IMAGE_INSTALL} ${IMAGE_TRANSIENT_PACKAGES}"
+
+IMAGE_TRANSIENT_PACKAGES += "isar-cfg-localepurge isar-cfg-rootpw"
+
+WORKDIR = "${TMPDIR}/work/${DISTRO}-${DISTRO_ARCH}/${MACHINE}/${PN}"
+
+ISAR_RELEASE_CMD_DEFAULT = "git -C ${LAYERDIR_core} describe --tags --dirty --match 'v[0-9].[0-9]*'"
+ISAR_RELEASE_CMD ?= "${ISAR_RELEASE_CMD_DEFAULT}"
+
 image_do_mounts() {
     sudo flock ${MOUNT_LOCKFILE} -c ' \
         mkdir -p "${BUILDROOT_DEPLOY}" "${BUILDROOT_ROOTFS}" "${BUILDROOT_WORK}"
@@ -36,6 +54,7 @@ image_do_mounts() {
 }
 
 inherit ${IMAGE_TYPE}
+inherit isar-bootstrap-helper
 
 # Extra space for rootfs in MB
 ROOTFS_EXTRA ?= "64"
@@ -97,18 +116,79 @@ python set_image_size () {
     d.setVarFlag('ROOTFS_SIZE', 'export', '1')
 }
 
+isar_image_gen_fstab() {
+    cat > ${WORKDIR}/fstab << EOF
+# Begin /etc/fstab
+/dev/root	/		auto		defaults		0	0
+proc		/proc		proc		nosuid,noexec,nodev	0	0
+sysfs		/sys		sysfs		nosuid,noexec,nodev	0	0
+devpts		/dev/pts	devpts		gid=5,mode=620		0	0
+tmpfs		/run		tmpfs		defaults		0	0
+devtmpfs	/dev		devtmpfs	mode=0755,nosuid	0	0
+
+# End /etc/fstab
+EOF
+}
+
+isar_image_gen_rootfs() {
+    setup_root_file_system --clean --keep-apt-cache \
+        --fstab "${WORKDIR}/fstab" \
+        "${IMAGE_ROOTFS}" ${IMAGE_PREINSTALL} ${IMAGE_INSTALL}
+}
+
+isar_image_conf_rootfs() {
+    # Configure root filesystem
+    if [ -n "${DISTRO_CONFIG_SCRIPT}" ]; then
+        sudo install -m 755 "${WORKDIR}/${DISTRO_CONFIG_SCRIPT}" "${IMAGE_ROOTFS}"
+        TARGET_DISTRO_CONFIG_SCRIPT="$(basename ${DISTRO_CONFIG_SCRIPT})"
+        sudo chroot ${IMAGE_ROOTFS} "/$TARGET_DISTRO_CONFIG_SCRIPT" \
+                                    "${MACHINE_SERIAL}" "${BAUDRATE_TTY}"
+        sudo rm "${IMAGE_ROOTFS}/$TARGET_DISTRO_CONFIG_SCRIPT"
+   fi
+}
+
+isar_image_cleanup() {
+    # Cleanup
+    sudo sh -c ' \
+        rm "${IMAGE_ROOTFS}/etc/apt/sources.list.d/isar-apt.list"
+        test ! -e "${IMAGE_ROOTFS}/usr/share/doc/qemu-user-static" && \
+            find "${IMAGE_ROOTFS}/usr/bin" \
+                -maxdepth 1 -name 'qemu-*-static' -type f -delete
+             umount -l ${IMAGE_ROOTFS}/isar-apt
+        rmdir ${IMAGE_ROOTFS}/isar-apt
+        umount -l ${IMAGE_ROOTFS}/dev
+        umount -l ${IMAGE_ROOTFS}/proc
+        umount -l ${IMAGE_ROOTFS}/sys
+        rm -f "${IMAGE_ROOTFS}/etc/apt/apt.conf.d/55isar-fallback.conf"
+        if [ "${ISAR_USE_CACHED_BASE_REPO}" = "1" ]; then
+            umount -l ${IMAGE_ROOTFS}/base-apt
+            rmdir ${IMAGE_ROOTFS}/base-apt
+            # Replace the local apt we bootstrapped with the
+            # APT sources initially defined in DISTRO_APT_SOURCES
+            rm -f "${IMAGE_ROOTFS}/etc/apt/sources.list.d/base-apt.list"
+            mv "${IMAGE_ROOTFS}/etc/apt/sources-list" \
+                "${IMAGE_ROOTFS}/etc/apt/sources.list.d/bootstrap.list"
+        fi
+        rm -f "${IMAGE_ROOTFS}/etc/apt/sources-list"
+    '
+}
+
 do_fetch[stamp-extra-info] = "${DISTRO}-${MACHINE}"
 do_unpack[stamp-extra-info] = "${DISTRO}-${MACHINE}"
 
 do_rootfs[stamp-extra-info] = "${DISTRO}-${MACHINE}"
 do_rootfs[depends] = "isar-apt:do_cache_config isar-bootstrap-target:do_bootstrap"
 
+do_rootfs[deptask] = "do_deploy_deb"
+do_rootfs[root_cleandirs] = "${IMAGE_ROOTFS} \
+                             ${IMAGE_ROOTFS}/isar-apt"
 do_rootfs() {
-    die "No root filesystem function defined, please implement in your recipe"
+    isar_image_gen_fstab
+    isar_image_gen_rootfs
+    isar_image_conf_rootfs
+    isar_image_cleanup
 }
-
 addtask rootfs before do_build after do_unpack
-do_rootfs[deptask] = "do_deploy_deb"
 
 do_mark_rootfs() {
     BUILD_ID=$(get_build_id)
diff --git a/meta/classes/isar-image.bbclass b/meta/classes/isar-image.bbclass
index e7a5dee..1d5870b 100644
--- a/meta/classes/isar-image.bbclass
+++ b/meta/classes/isar-image.bbclass
@@ -1,92 +1,6 @@
-# Root filesystem for target installation
+# Class for backwards compatibility of images that use it
 #
 # This software is a part of ISAR.
 # Copyright (C) 2015-2018 ilbers GmbH
-
+# Copyright (c) Siemens AG, 2019
 inherit image
-inherit isar-bootstrap-helper
-
-def cfg_script(d):
-    cf = d.getVar('DISTRO_CONFIG_SCRIPT', True) or ''
-    if cf:
-        return 'file://' + cf
-    return ''
-
-FILESPATH =. "${LAYERDIR_core}/conf/distro:"
-SRC_URI += "${@ cfg_script(d) }"
-
-DEPENDS += "${IMAGE_INSTALL} ${IMAGE_TRANSIENT_PACKAGES}"
-
-IMAGE_TRANSIENT_PACKAGES += "isar-cfg-localepurge isar-cfg-rootpw"
-
-WORKDIR = "${TMPDIR}/work/${DISTRO}-${DISTRO_ARCH}/${MACHINE}/${PN}"
-
-ISAR_RELEASE_CMD_DEFAULT = "git -C ${LAYERDIR_core} describe --tags --dirty --match 'v[0-9].[0-9]*'"
-ISAR_RELEASE_CMD ?= "${ISAR_RELEASE_CMD_DEFAULT}"
-
-do_rootfs[root_cleandirs] = "${IMAGE_ROOTFS} \
-                             ${IMAGE_ROOTFS}/isar-apt"
-
-isar_image_gen_fstab() {
-    cat > ${WORKDIR}/fstab << EOF
-# Begin /etc/fstab
-/dev/root	/		auto		defaults		0	0
-proc		/proc		proc		nosuid,noexec,nodev	0	0
-sysfs		/sys		sysfs		nosuid,noexec,nodev	0	0
-devpts		/dev/pts	devpts		gid=5,mode=620		0	0
-tmpfs		/run		tmpfs		defaults		0	0
-devtmpfs	/dev		devtmpfs	mode=0755,nosuid	0	0
-
-# End /etc/fstab
-EOF
-}
-
-isar_image_gen_rootfs() {
-    setup_root_file_system --clean --keep-apt-cache \
-        --fstab "${WORKDIR}/fstab" \
-        "${IMAGE_ROOTFS}" ${IMAGE_PREINSTALL} ${IMAGE_INSTALL}
-}
-
-isar_image_conf_rootfs() {
-    # Configure root filesystem
-    if [ -n "${DISTRO_CONFIG_SCRIPT}" ]; then
-        sudo install -m 755 "${WORKDIR}/${DISTRO_CONFIG_SCRIPT}" "${IMAGE_ROOTFS}"
-        TARGET_DISTRO_CONFIG_SCRIPT="$(basename ${DISTRO_CONFIG_SCRIPT})"
-        sudo chroot ${IMAGE_ROOTFS} "/$TARGET_DISTRO_CONFIG_SCRIPT" \
-                                    "${MACHINE_SERIAL}" "${BAUDRATE_TTY}"
-        sudo rm "${IMAGE_ROOTFS}/$TARGET_DISTRO_CONFIG_SCRIPT"
-   fi
-}
-
-isar_image_cleanup() {
-    # Cleanup
-    sudo sh -c ' \
-        rm "${IMAGE_ROOTFS}/etc/apt/sources.list.d/isar-apt.list"
-        test ! -e "${IMAGE_ROOTFS}/usr/share/doc/qemu-user-static" && \
-            find "${IMAGE_ROOTFS}/usr/bin" \
-                -maxdepth 1 -name 'qemu-*-static' -type f -delete
-             umount -l ${IMAGE_ROOTFS}/isar-apt
-        rmdir ${IMAGE_ROOTFS}/isar-apt
-        umount -l ${IMAGE_ROOTFS}/dev
-        umount -l ${IMAGE_ROOTFS}/proc
-        umount -l ${IMAGE_ROOTFS}/sys
-        rm -f "${IMAGE_ROOTFS}/etc/apt/apt.conf.d/55isar-fallback.conf"
-        if [ "${ISAR_USE_CACHED_BASE_REPO}" = "1" ]; then
-            umount -l ${IMAGE_ROOTFS}/base-apt
-            rmdir ${IMAGE_ROOTFS}/base-apt
-            # Replace the local apt we bootstrapped with the
-            # APT sources initially defined in DISTRO_APT_SOURCES
-            rm -f "${IMAGE_ROOTFS}/etc/apt/sources.list.d/base-apt.list"
-            mv "${IMAGE_ROOTFS}/etc/apt/sources-list" \
-                "${IMAGE_ROOTFS}/etc/apt/sources.list.d/bootstrap.list"
-        fi
-        rm -f "${IMAGE_ROOTFS}/etc/apt/sources-list"
-    '
-}
-
-do_rootfs() {
-    isar_image_gen_fstab
-    isar_image_gen_rootfs
-    isar_image_conf_rootfs
-    isar_image_cleanup
-}
-- 
2.20.1


^ permalink raw reply	[flat|nested] 4+ messages in thread

* [PATCH v2 2/2] deprecate isar-image
  2019-03-21 11:57 [PATCH v2 0/2] Move isar-image into image class claudius.heine.ext
  2019-03-21 11:57 ` [PATCH v2 1/2] meta: merges " claudius.heine.ext
@ 2019-03-21 11:57 ` claudius.heine.ext
  2019-03-28 12:45 ` [PATCH v2 0/2] Move isar-image into image class Maxim Yu. Osipov
  2 siblings, 0 replies; 4+ messages in thread
From: claudius.heine.ext @ 2019-03-21 11:57 UTC (permalink / raw)
  To: isar-users; +Cc: Claudius Heine

From: Claudius Heine <ch@denx.de>

This deprecates the isar-image class, the image class should be
inherited instead.

Signed-off-by: Claudius Heine <ch@denx.de>
---
 RECIPE-API-CHANGELOG.md                          | 9 +++++++++
 doc/user_manual.md                               | 2 +-
 meta-isar/recipes-core/images/isar-image-base.bb | 2 +-
 meta-isar/recipes-core/images/isar-image-ubi.bb  | 2 +-
 meta/classes/isar-image.bbclass                  | 5 +++++
 5 files changed, 17 insertions(+), 3 deletions(-)

diff --git a/RECIPE-API-CHANGELOG.md b/RECIPE-API-CHANGELOG.md
index e5f3150..d389d99 100644
--- a/RECIPE-API-CHANGELOG.md
+++ b/RECIPE-API-CHANGELOG.md
@@ -145,3 +145,12 @@ a root password, leak that password via its script in /var/lib/dpkg/info.
 Instead set the CFG_ROOT_PW variable to the encrypted password and use the
 transient 'isar-cfg-rootpw' package (now installed as transient package per
 default).
+
+Changes in v0.8
+---------------
+
+### `isar-image.bbclass` class will be deprecated in future version of isar
+
+The content of `isar-image.bbclass` was moved to the `image.bbclass` file.
+Recipes that inherit `isar-image` should be modified to inherit from `image`
+instead.
diff --git a/doc/user_manual.md b/doc/user_manual.md
index 9ea3f42..5e74927 100644
--- a/doc/user_manual.md
+++ b/doc/user_manual.md
@@ -534,7 +534,7 @@ IMAGE_PREINSTALL = " \
     openssh-server   \
 "
 
-inherit isar-image
+inherit image
 
 ```
 
diff --git a/meta-isar/recipes-core/images/isar-image-base.bb b/meta-isar/recipes-core/images/isar-image-base.bb
index c86e63b..b381d85 100644
--- a/meta-isar/recipes-core/images/isar-image-base.bb
+++ b/meta-isar/recipes-core/images/isar-image-base.bb
@@ -10,4 +10,4 @@ LIC_FILES_CHKSUM = "file://${LAYERDIR_core}/licenses/COPYING.GPLv2;md5=751419260
 
 PV = "1.0"
 
-inherit isar-image
+inherit image
diff --git a/meta-isar/recipes-core/images/isar-image-ubi.bb b/meta-isar/recipes-core/images/isar-image-ubi.bb
index 4b7e109..3b41f23 100644
--- a/meta-isar/recipes-core/images/isar-image-ubi.bb
+++ b/meta-isar/recipes-core/images/isar-image-ubi.bb
@@ -10,7 +10,7 @@ DESCRIPTION = "UBI Isar image"
 LICENSE = "gpl-2.0"
 LIC_FILES_CHKSUM = "file://${LAYERDIR_core}/licenses/COPYING.GPLv2;md5=751419260aa954499f7abaabaa882bbe"
 
-inherit isar-image
+inherit image
 
 SRC_URI += "file://ubinize.cfg.tmpl \
             file://fitimage.its.tmpl"
diff --git a/meta/classes/isar-image.bbclass b/meta/classes/isar-image.bbclass
index 1d5870b..743ecbb 100644
--- a/meta/classes/isar-image.bbclass
+++ b/meta/classes/isar-image.bbclass
@@ -4,3 +4,8 @@
 # Copyright (C) 2015-2018 ilbers GmbH
 # Copyright (c) Siemens AG, 2019
 inherit image
+
+python() {
+    bb.warn("isar-image is deprecated, please change 'isar-image' inheritance "
+            "to 'image'.")
+}
-- 
2.20.1


^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH v2 0/2] Move isar-image into image class
  2019-03-21 11:57 [PATCH v2 0/2] Move isar-image into image class claudius.heine.ext
  2019-03-21 11:57 ` [PATCH v2 1/2] meta: merges " claudius.heine.ext
  2019-03-21 11:57 ` [PATCH v2 2/2] deprecate isar-image claudius.heine.ext
@ 2019-03-28 12:45 ` Maxim Yu. Osipov
  2 siblings, 0 replies; 4+ messages in thread
From: Maxim Yu. Osipov @ 2019-03-28 12:45 UTC (permalink / raw)
  To: claudius.heine.ext, isar-users; +Cc: Claudius Heine

On 3/21/19 12:57 PM, claudius.heine.ext@siemens.com wrote:
> From: Claudius Heine <ch@denx.de>
> 
> Hi,
> 
> this is the second version of this patchset.
> 
> Changes from v1:
>   - added documentation changes to first patch
>   - added second patch that marks isar-image as deprecated

Applied to the 'next'.

Regards,
Maxim.

> Claudius Heine (2):
>    meta: merges isar-image into image class
>    deprecate isar-image
> 
>   RECIPE-API-CHANGELOG.md                       |  9 ++
>   doc/user_manual.md                            |  4 +-
>   .../recipes-core/images/isar-image-base.bb    |  2 +-
>   .../recipes-core/images/isar-image-ubi.bb     |  2 +-
>   meta/classes/image.bbclass                    | 86 +++++++++++++++++-
>   meta/classes/isar-image.bbclass               | 91 +------------------
>   6 files changed, 101 insertions(+), 93 deletions(-)
> 


-- 
Maxim Osipov
ilbers GmbH
Maria-Merian-Str. 8
85521 Ottobrunn
Germany
+49 (151) 6517 6917
mosipov@ilbers.de
http://ilbers.de/
Commercial register Munich, HRB 214197
General Manager: Baurzhan Ismagulov

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2019-03-28 12:45 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-03-21 11:57 [PATCH v2 0/2] Move isar-image into image class claudius.heine.ext
2019-03-21 11:57 ` [PATCH v2 1/2] meta: merges " claudius.heine.ext
2019-03-21 11:57 ` [PATCH v2 2/2] deprecate isar-image claudius.heine.ext
2019-03-28 12:45 ` [PATCH v2 0/2] Move isar-image into image class Maxim Yu. Osipov

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox