diff options
| author | Paul Eggleton <paul.eggleton@linux.intel.com> | 2013-09-12 12:04:52 +0100 | 
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2013-09-12 16:48:38 +0100 | 
| commit | 7e90261aec61f79680b5eaeaf5b18c7b795412a4 (patch) | |
| tree | e971aa90f82a754e6d005533036702903a450b72 /scripts/runqemu | |
| parent | ebfdddc23ff78231a819c62c8ffcced9633aa08b (diff) | |
| download | openembedded-core-7e90261aec61f79680b5eaeaf5b18c7b795412a4.tar.gz openembedded-core-7e90261aec61f79680b5eaeaf5b18c7b795412a4.tar.bz2 openembedded-core-7e90261aec61f79680b5eaeaf5b18c7b795412a4.zip | |
bitbake.conf: include machine name in DEPLOY_DIR_IMAGE
This allows a clean seperation between image outputs from different
machines, and makes it possible to have convenience symlinks to make
the output ready to deploy.
This did require some surgery in runqemu; if explicit paths to the image
and kernel are not supplied then DEPLOY_DIR_IMAGE needs to be determined
from bitbake or set in the environment. However the script does try to
avoid requiring it unless it really is needed. Corresponding changes
were made in the automated testing code as well.
Based on an RFC patch by Koen Kooi <koen@dominion.thruhere.net>
Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'scripts/runqemu')
| -rwxr-xr-x | scripts/runqemu | 56 | 
1 files changed, 39 insertions, 17 deletions
| diff --git a/scripts/runqemu b/scripts/runqemu index b49678502a..efab1a27b3 100755 --- a/scripts/runqemu +++ b/scripts/runqemu @@ -321,9 +321,17 @@ AKITA_DEFAULT_FSTYPE=jffs2  SPITZ_DEFAULT_KERNEL=zImage-spitz.bin  SPITZ_DEFAULT_FSTYPE=ext3 -setup_tmpdir() { -    if [ -z "$OE_TMPDIR" ]; then -        # Try to get OE_TMPDIR from bitbake +setup_path_vars() { +    if [ -z "$OE_TMPDIR" ] ; then +        PATHS_REQUIRED=true +    elif [ "$1" = "1" -a -z "$DEPLOY_DIR_IMAGE" ] ; then +        PATHS_REQUIRED=true +    else +        PATHS_REQUIRED=false +    fi + +    if [ "$PATHS_REQUIRED" = "true" ]; then +        # Try to get the variable values from bitbake          type -P bitbake &>/dev/null || {              echo "In order for this script to dynamically infer paths";              echo "to kernels or filesystem images, you either need"; @@ -331,21 +339,35 @@ setup_tmpdir() {              echo "before running this script" >&2;              exit 1; } -        # We have bitbake in PATH, get OE_TMPDIR from bitbake -        OE_TMPDIR=`MACHINE=$MACHINE bitbake -e | grep ^TMPDIR=\" | cut -d '=' -f2 | cut -d '"' -f2` +        # We have bitbake in PATH, get the variable values from bitbake +        BITBAKE_ENV_TMPFILE=`mktemp runqemu.XXXXXXXXXX` +        if [ "$?" != "0" ] ; then +            echo "Error: mktemp failed for bitbake environment output" +            exit 1 +        fi + +        MACHINE=$MACHINE bitbake -e > $BITBAKE_ENV_TMPFILE +        if [ -z "$OE_TMPDIR" ] ; then +            OE_TMPDIR=`cat $BITBAKE_ENV_TMPFILE | sed -n 's/^TMPDIR=\"\(.*\)\"/\1/p'` +        fi +        if [ -z "$DEPLOY_DIR_IMAGE" ] ; then +            DEPLOY_DIR_IMAGE=`cat $BITBAKE_ENV_TMPFILE | sed -n 's/^DEPLOY_DIR_IMAGE=\"\(.*\)\"/\1/p'` +        fi          if [ -z "$OE_TMPDIR" ]; then              # Check for errors from bitbake that the user needs to know about -            BITBAKE_OUTPUT=`bitbake -e | wc -l` +            BITBAKE_OUTPUT=`cat $BITBAKE_ENV_TMPFILE | wc -l`              if [ "$BITBAKE_OUTPUT" -eq "0" ]; then -                echo "Error: this script needs to be run from your build directory," -                echo "or you need to explicitly set OE_TMPDIR in your environment" +                echo "Error: this script needs to be run from your build directory, or you need" +                echo "to explicitly set OE_TMPDIR and DEPLOY_DIR_IMAGE in your environment"              else                  echo "There was an error running bitbake to determine TMPDIR"                  echo "Here is the output from 'bitbake -e':" -                bitbake -e +                cat $BITBAKE_ENV_TMPFILE              fi +            rm $BITBAKE_ENV_TMPFILE              exit 1          fi +        rm $BITBAKE_ENV_TMPFILE      fi  } @@ -355,7 +377,7 @@ setup_sysroot() {      # either in an in-tree build scenario or the environment      # script wasn't source'd.      if [ -z "$OECORE_NATIVE_SYSROOT" ]; then -        setup_tmpdir +        setup_path_vars          BUILD_ARCH=`uname -m`          BUILD_OS=`uname | tr '[A-Z]' '[a-z]'`          BUILD_SYS="$BUILD_ARCH-$BUILD_OS" @@ -405,9 +427,9 @@ if [ -e "$ROOTFS" -a -z "$FSTYPE" ]; then  fi  if [ -z "$KERNEL" -a "x$FSTYPE" != "xvmdk" ]; then -    setup_tmpdir +    setup_path_vars 1      eval kernel_file=\$${machine2}_DEFAULT_KERNEL -    KERNEL=$OE_TMPDIR/deploy/images/$kernel_file +    KERNEL=$DEPLOY_DIR_IMAGE/$kernel_file      if [ -z "$KERNEL" ]; then          error "Unable to determine default kernel for MACHINE [$MACHINE]" @@ -428,14 +450,14 @@ fi  # Handle cases where a ROOTFS type is given instead of a filename, e.g.  # core-image-sato  if [ "$LAZY_ROOTFS" = "true" ]; then -    setup_tmpdir -    echo "Assuming $ROOTFS really means $OE_TMPDIR/deploy/images/$ROOTFS-$MACHINE.$FSTYPE" -    ROOTFS=$OE_TMPDIR/deploy/images/$ROOTFS-$MACHINE.$FSTYPE +    setup_path_vars 1 +    echo "Assuming $ROOTFS really means $DEPLOY_DIR_IMAGE/$ROOTFS-$MACHINE.$FSTYPE" +    ROOTFS=$DEPLOY_DIR_IMAGE/$ROOTFS-$MACHINE.$FSTYPE  fi  if [ -z "$ROOTFS" -a "x$FSTYPE" != "xvmdk" ]; then -    setup_tmpdir -    T=$OE_TMPDIR/deploy/images +    setup_path_vars 1 +    T=$DEPLOY_DIR_IMAGE      eval rootfs_list=\$${machine2}_DEFAULT_ROOTFS      findimage $T $MACHINE $FSTYPE | 
