From 2713386f233907d652935cca7158475c26a0cac7 Mon Sep 17 00:00:00 2001 From: Richard Purdie Date: Wed, 30 Jan 2008 15:37:49 +0000 Subject: scripts: Add poky-chroot scripts (credit should mainly go to Ross) git-svn-id: https://svn.o-hand.com/repos/poky/trunk@3627 311d38ba-8fff-0310-9ca6-ca027cbcb966 --- scripts/poky-chroot-run | 73 +++++++++++++++++++++++++++++++++++++++++++++++ scripts/poky-chroot-setup | 30 +++++++++++++++++++ 2 files changed, 103 insertions(+) create mode 100755 scripts/poky-chroot-run create mode 100755 scripts/poky-chroot-setup diff --git a/scripts/poky-chroot-run b/scripts/poky-chroot-run new file mode 100755 index 000000000..6b78e3c60 --- /dev/null +++ b/scripts/poky-chroot-run @@ -0,0 +1,73 @@ +#!/bin/bash +# +# Runs a command within a Poky chroot +# + +set -e + +case $# in + 0) + echo "Invalid arguments." + echo "$ $0 [command]" + exit 1 + ;; + 1) + ROOTFS=$1 + shift + # Set $1 to be the boot script + set -- /usr/bin/poky-chroot-launch + ;; + *) + ROOTFS=$1 + shift + # Now $1 onwards are the command and arguments to run + ;; +esac + +test -f "$ROOTFS/.pokychroot" || { echo "$ROOTFS is not setup for use as a Poky chroot." ; exit 1 ;} + +# chrootuid doesn't handle relative paths, so ensure that the rootfs path is +# absolute +if test ${ROOTFS:0:1} != /; then + ROOTFS="$(pwd)/$ROOTFS" +fi + +safe_mount() { + if ! mountpoint -q "$ROOTFS/$1"; then + sudo mount --bind $1 "$ROOTFS/$1" + fi +} +safe_umount() { + if mountpoint -q "$ROOTFS/$1"; then + sudo umount "$ROOTFS/$1" + fi +} + +# Mount the directories we need +for m in /dev /dev/pts /dev/shm /proc /sys /tmp; do + safe_mount $m +done + +# Set up the environment +export PATH=/bin:/usr/bin:/sbin:/usr/sbin +export HOME=/home/$USER + +if [ ! -f "$ROOTFS/.pokychroot.init" ]; then + sudo chrootuid -i "$ROOTFS" $USER /bin/sh -c "/usr/bin/poky-chroot-init" + touch "$ROOTFS/.pokychroot.init" +fi + +Xephyr :1 -ac -screen 640x480x16 & + +# Go go go! +sudo chrootuid -i "$ROOTFS" $USER "$@" || /bin/true + +# Trap term signals so we don't kill ourselves +trap true TERM +# send term signal to the process group +kill -- -$$ + +# Unmount TODO: only umount if there are no other sessions active, somehow. +for m in /tmp /sys /proc /dev/shm /dev/pts /dev; do + safe_umount $m +done diff --git a/scripts/poky-chroot-setup b/scripts/poky-chroot-setup new file mode 100755 index 000000000..d85c864da --- /dev/null +++ b/scripts/poky-chroot-setup @@ -0,0 +1,30 @@ +#!/bin/bash +# +# Script to extract a poky qemux86 rootfs and prepare it for +# use as a chroot +# + +set -e + +case $# in + 2) + TGZ=$1 + TARGET=$2 + ;; + *) + echo "Invalid arguments, please run as:" + echo "$ $0 " + exit 1 +esac + +echo "Extracting $TGZ into $TARGET" + +test -d "$TARGET" && { echo "$TARGET already exists, please remove and retry or specify a dirferent directory." ; exit 1 ; } +mkdir --parents "$TARGET" + +tar -C "$TARGET" --exclude ./dev/\* -jxp -f "$TGZ" +echo "HAVE_TOUCHSCREEN=0" >> "$TARGET/etc/formfactor/machconfig" +echo "DISPLAY_WIDTH_PIXELS=640" >> "$TARGET/etc/formfactor/machconfig" +echo "DISPLAY_HEIGHT_PIXELS=480" >> "$TARGET/etc/formfactor/machconfig" +cp /etc/passwd "$TARGET/etc/passwd" +touch "$TARGET/.pokychroot" -- cgit v1.2.3