diff options
author | Scott Garman <scott.a.garman@intel.com> | 2010-10-03 21:16:24 -0700 |
---|---|---|
committer | Richard Purdie <rpurdie@linux.intel.com> | 2010-10-07 19:55:50 +0100 |
commit | e70c8981f250ead9e025ecd27aef94b67d784fc6 (patch) | |
tree | 0644d5cfb98596f71e5cce7ff8f1e23508c4a4a2 | |
parent | 8532405c1d6b2184ca88922506b725110a1f7627 (diff) | |
download | openembedded-core-e70c8981f250ead9e025ecd27aef94b67d784fc6.tar.gz openembedded-core-e70c8981f250ead9e025ecd27aef94b67d784fc6.tar.bz2 openembedded-core-e70c8981f250ead9e025ecd27aef94b67d784fc6.zip |
Allow running of multiple QEMU nfs instances
These changes allow multiple instances of the userspace NFS server
to run, when brought up by consecutive instances of the poky-qemu
control script.
This fixes [BUGID #393]
Signed-off-by: Scott Garman <scott.a.garman@intel.com>
-rwxr-xr-x | scripts/poky-export-rootfs | 39 | ||||
-rwxr-xr-x | scripts/poky-qemu-internal | 31 |
2 files changed, 39 insertions, 31 deletions
diff --git a/scripts/poky-export-rootfs b/scripts/poky-export-rootfs index ef527dc058..f3552516ad 100755 --- a/scripts/poky-export-rootfs +++ b/scripts/poky-export-rootfs @@ -61,11 +61,11 @@ if [ ! -d ~/.poky-sdk ]; then mkdir -p ~/.poky-sdk fi -TARGET_VIRT_INSTANCE=${TARGET_VIRT_INSTANCE:=0} -EXPORTS=~/.poky-sdk/exports$TARGET_VIRT_INSTANCE -RMTAB=~/.poky-sdk/rmtab$TARGET_VIRT_INSTANCE -NFSPID=~/.poky-sdk/nfs$TARGET_VIRT_INSTANCE.pid -MOUNTPID=~/.poky-sdk/mount$TARGET_VIRT_INSTANCE.pid +NFS_INSTANCE=${NFS_INSTANCE:=0} +EXPORTS=~/.poky-sdk/exports$NFS_INSTANCE +RMTAB=~/.poky-sdk/rmtab$NFS_INSTANCE +NFSPID=~/.poky-sdk/nfs$NFS_INSTANCE.pid +MOUNTPID=~/.poky-sdk/mount$NFS_INSTANCE.pid PSEUDO_OPTS="-P $POKY_NATIVE_SYSROOT/usr" PSEUDO_LOCALSTATEDIR="$NFS_EXPORT_DIR/var/pseudo" @@ -78,15 +78,14 @@ if [ ! -d "$PSEUDO_LOCALSTATEDIR" ]; then fi # rpc.mountd RPC port -NFS_MOUNTPROG="21111" +NFS_MOUNTPROG=$[ 21111 + $NFS_INSTANCE ] # rpc.nfsd RPC port -NFS_NFSPROG="11111" +NFS_NFSPROG=$[ 11111 + $NFS_INSTANCE ] # NFS port number -NFS_PORT="3049" +NFS_PORT=$[ 3049 + $NFS_INSTANCE ] ## For debugging you would additionally add ## --debug all - MOUNTD_OPTS="--allow-non-root --mount-pid $MOUNTPID -f $EXPORTS --rmtab $RMTAB --prog $NFS_MOUNTPROG -r" NFSD_OPTS="--allow-non-root --nfs-pid $NFSPID -f $EXPORTS --prog $NFS_NFSPROG -P $NFS_PORT -r" @@ -102,7 +101,7 @@ case "$1" in echo "Starting User Mode rpc.mountd" echo " $PSEUDO $PSEUDO_OPTS $POKY_NATIVE_SYSROOT/usr/sbin/rpc.mountd $MOUNTD_OPTS" $PSEUDO $PSEUDO_OPTS $POKY_NATIVE_SYSROOT/usr/sbin/rpc.mountd $MOUNTD_OPTS - if [ ! $? = 0 ] ; then + if [ ! $? = 0 ]; then echo "=====================" echo "Error starting MOUNTD" echo "=====================" @@ -125,26 +124,26 @@ case "$1" in echo "Starting User Mode nfsd" echo " $PSEUDO $PSEUDO_OPTS $POKY_NATIVE_SYSROOT/usr/sbin/rpc.nfsd $NFSD_OPTS" $PSEUDO $PSEUDO_OPTS $POKY_NATIVE_SYSROOT/usr/sbin/rpc.nfsd $NFSD_OPTS - if [ ! $? = 0 ] ; then + if [ ! $? = 0 ]; then echo "Error starting nfsd" exit 1 fi # Check to make sure everything started ok. - if [ ! -f $MOUNTPID ] ; then + if [ ! -f $MOUNTPID ]; then echo "rpc.mountd did not start correctly" exit 1 fi - if [ ! -f $NFSPID ] ; then + if [ ! -f $NFSPID ]; then echo "rpc.nfsd did not start correctly" exit 1 fi ps -fp `cat $MOUNTPID` > /dev/null 2> /dev/null - if [ ! $? = 0 ] ; then + if [ ! $? = 0 ]; then echo "rpc.mountd did not start correctly" exit 1 fi ps -fp `cat $NFSPID` > /dev/null 2> /dev/null - if [ ! $? = 0 ] ; then + if [ ! $? = 0 ]; then echo "rpc.nfsd did not start correctly" exit 1 fi @@ -153,25 +152,29 @@ case "$1" in echo "nfsroot=IP_ADDRESS:$NFS_EXPORT_DIR,nfsvers=2,mountprog=$NFS_MOUNTPROG,nfsprog=$NFS_NFSPROG,udp" ;; stop) - if [ -f "$MOUNTPID" ] ; then + if [ -f "$MOUNTPID" ]; then echo "Stopping rpc.mountd" kill `cat $MOUNTPID` rm -f $MOUNTPID else echo "No PID file, not stopping rpc.mountd" fi - if [ -f "$NFSPID" ] ; then + if [ -f "$NFSPID" ]; then echo "Stopping rpc.nfsd" kill `cat $NFSPID` rm -f $NFSPID else echo "No PID file, not stopping rpc.nfsd" fi + if [ -f "$EXPORTS" ]; then + echo "Removing exports file" + rm -f $EXPORTS + fi ;; restart) $0 stop $NFS_EXPORT_DIR $0 start $NFS_EXPORT_DIR - if [ ! $? = 0 ] ; then + if [ ! $? = 0 ]; then exit 1 fi ;; diff --git a/scripts/poky-qemu-internal b/scripts/poky-qemu-internal index 0ea38eef60..532b255da9 100755 --- a/scripts/poky-qemu-internal +++ b/scripts/poky-qemu-internal @@ -50,8 +50,9 @@ if [ -z "$QEMU_MEMORY" ]; then fi -# This flag file is created when poky-gen-tapdevs creates a bank of -# tap devices, indicating that the user does not have sudo privs. +# This file is created when poky-gen-tapdevs creates a bank of tap +# devices, indicating that the user should not bring up new ones using +# sudo. NOSUDO_FLAG="/etc/poky-nosudo" QEMUIFUP=`which poky-qemu-ifup` @@ -113,18 +114,17 @@ else fi release_lock() { - if [ "$LOCKFILE" = "" ]; then + if [ ! -e "$NOSUDO_FLAG" ]; then $QEMUIFDOWN $TAP $POKY_NATIVE_SYSROOT - else - echo "Releasing lockfile of preconfigured tap device '$TAP'" - lockfile-remove $LOCKFILE - fi - - if [ "$NFSRUNNING" = "true" ]; then - echo "Shutting down the userspace NFS server:" - echo "poky-export-rootfs stop $ROOTFS" - poky-export-rootfs stop $ROOTFS fi + echo "Releasing lockfile of preconfigured tap device '$TAP'" + lockfile-remove $LOCKFILE + + if [ "$NFSRUNNING" = "true" ]; then + echo "Shutting down the userspace NFS server..." + echo "poky-export-rootfs stop $ROOTFS" + poky-export-rootfs stop $ROOTFS + fi } n1=$[ (`echo $TAP | sed 's/tap//'` * 2) + 1 ] @@ -136,6 +136,9 @@ QEMU_NETWORK_CMD="-net nic,vlan=0 $QEMU_TAP_CMD" KERNCMDLINE="mem=$QEMU_MEMORY" QEMU_UI_OPTIONS="-show-cursor -usb -usbdevice wacom-tablet" +NFS_INSTANCE=`echo $TAP | sed 's/tap//'` +export NFS_INSTANCE + SERIALOPTS="" if [ "x$SERIAL_LOGFILE" != "x" ]; then SERIALOPTS="-serial file:$SERIAL_LOGFILE" @@ -172,7 +175,9 @@ fi if [ "$FSTYPE" = "nfs" ]; then NFS_SERVER="192.168.7.1" NFS_DIR=`echo $ROOTFS | sed 's/^[^:]*:\(.*\)/\1/'` - UNFS_OPTS="nfsvers=2,mountprog=21111,nfsprog=11111,udp" + MOUNTD_PORT=$[ 21111 + $NFS_INSTANCE ] + NFSD_PORT=$[ 11111 + $NFS_INSTANCE ] + UNFS_OPTS="nfsvers=2,mountprog=$MOUNTD_PORT,nfsprog=$NFSD_PORT,udp" PSEUDO_LOCALSTATEDIR=~/.poky-sdk/pseudo export PSEUDO_LOCALSTATEDIR |