diff options
Diffstat (limited to 'meta-sota/recipes-sota/ostree-initrd')
-rw-r--r-- | meta-sota/recipes-sota/ostree-initrd/files/init.sh | 84 | ||||
-rw-r--r-- | meta-sota/recipes-sota/ostree-initrd/ostree-initrd.bb | 19 |
2 files changed, 0 insertions, 103 deletions
diff --git a/meta-sota/recipes-sota/ostree-initrd/files/init.sh b/meta-sota/recipes-sota/ostree-initrd/files/init.sh deleted file mode 100644 index 806a7b1..0000000 --- a/meta-sota/recipes-sota/ostree-initrd/files/init.sh +++ /dev/null @@ -1,84 +0,0 @@ -#!/bin/sh - -# global variables - -SMACK=n -DEBUG=n - -# ------------------------------------------- - -log_info() { echo "$0[$$]: $@" >&2; } -log_error() { echo "$0[$$]: ERROR $@" >&2; } - -do_mount_fs() { - log_info "mounting FS: $@" - [[ -e /proc/filesystems ]] && { grep -q "$1" /proc/filesystems || { log_error "Unknown filesystem"; return 1; } } - [[ -d "$2" ]] || mkdir -p "$2" - [[ -e /proc/mounts ]] && { grep -q -e "^$1 $2 $1" /proc/mounts && { log_info "$2 ($1) already mounted"; return 0; } } - mount -t "$1" "$1" "$2" -} - -bail_out() { - log_error "$@" - log_info "Rebooting..." - #exec reboot -f - exec sh -} - -get_ostree_sysroot() { - for opt in `cat /proc/cmdline`; do - arg=`echo $opt | cut -d'=' -f1` - if [ $arg == "ostree_root" ]; then - echo $opt | cut -d'=' -f2 - return - fi - done -} - -export PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/lib/ostree - -log_info "starting initrd script" - -do_mount_fs proc /proc -do_mount_fs sysfs /sys -do_mount_fs devtmpfs /dev -do_mount_fs devpts /dev/pts -do_mount_fs tmpfs /dev/shm -do_mount_fs tmpfs /tmp -do_mount_fs tmpfs /run - -# check if smack is active (and if so, mount smackfs) -grep -q smackfs /proc/filesystems && { - SMACK=y - - do_mount_fs smackfs /sys/fs/smackfs - - # adjust current label and network label - echo System >/proc/self/attr/current - echo System >/sys/fs/smackfs/ambient -} - -mkdir -p /sysroot -ostree_sysroot=$(get_ostree_sysroot) - -mount $ostree_sysroot /sysroot || bail_out "Unable to mount $ostree_sysroot as physical sysroot" -ostree-prepare-root /sysroot - -# move mounted devices to new root -cd /sysroot -for x in dev proc; do - log_info "Moving /$x to new rootfs" - mount -o move /$x $x -done - -# switch to new rootfs -log_info "Switching to new rootfs" -mkdir -p run/initramfs - -pivot_root . run/initramfs || bail_out "pivot_root failed." - -log_info "Launching target init" - -exec chroot . sh -c 'umount /run/initramfs; exec /sbin/init' \ - <dev/console >dev/console 2>&1 - diff --git a/meta-sota/recipes-sota/ostree-initrd/ostree-initrd.bb b/meta-sota/recipes-sota/ostree-initrd/ostree-initrd.bb deleted file mode 100644 index 5c85bee..0000000 --- a/meta-sota/recipes-sota/ostree-initrd/ostree-initrd.bb +++ /dev/null @@ -1,19 +0,0 @@ -SUMMARY = "Extremely basic live image init script" -LICENSE = "MIT" -LIC_FILES_CHKSUM = "file://${COREBASE}/meta/COPYING.MIT;md5=3da9cfbcb788c80a0384361b4de20420" -SRC_URI = "file://init.sh" - -S = "${WORKDIR}" - -do_install() { - install -dm 0755 ${D}/etc - touch ${D}/etc/initrd-release - install -dm 0755 ${D}/dev - install -dm 0755 ${D}/sbin - install -m 0755 ${WORKDIR}/init.sh ${D}/sbin/init -} - -inherit allarch - -FILES_${PN} += " /dev /etc/initrd-release /sbin/init " - |