mirror of
https://git.yoctoproject.org/poky
synced 2026-06-02 13:29:49 +00:00
poky-qemu: integrate userspace nfsroot support
This is the first phase of some refactoring the poky-qemu control scripts are getting. This integrates userspace nfsroot support into poky-qemu, making runqemu-nfs obsolete. This fixes [BUGID #295] Signed-off-by: Scott Garman <scott.a.garman@intel.com>
This commit is contained in:
committed by
Richard Purdie
parent
c8a181e847
commit
fcbd67c047
+117
-136
@@ -17,7 +17,6 @@
|
||||
# with this program; if not, write to the Free Software Foundation, Inc.,
|
||||
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
|
||||
|
||||
# Call setting:
|
||||
# QEMU_MEMORY (optional) - set the amount of memory in the emualted system.
|
||||
# SERIAL_LOGFILE (optional) - log the serial port output to a file
|
||||
@@ -25,35 +24,37 @@
|
||||
#
|
||||
# Image options:
|
||||
# MACHINE - the machine to run
|
||||
# TYPE - the image type to run
|
||||
# ZIMAGE - the kernel image file to use
|
||||
# HDIMAGE - the disk image file to use
|
||||
# FSTYPE - the image type to run
|
||||
# KERNEL - the kernel image file to use
|
||||
# ROOTFS - the disk image file to use
|
||||
#
|
||||
|
||||
if [ -z "$QEMU_MEMORY" ]; then
|
||||
case "$MACHINE" in
|
||||
"qemux86")
|
||||
QEMU_MEMORY="128M"
|
||||
;;
|
||||
"qemux86-64")
|
||||
QEMU_MEMORY="128M"
|
||||
;;
|
||||
"qemumips")
|
||||
QEMU_MEMORY="128M"
|
||||
;;
|
||||
"qemuppc")
|
||||
QEMU_MEMORY="128M"
|
||||
;;
|
||||
*)
|
||||
QEMU_MEMORY="64M"
|
||||
;;
|
||||
esac
|
||||
case "$MACHINE" in
|
||||
"qemux86")
|
||||
QEMU_MEMORY="128M"
|
||||
;;
|
||||
"qemux86-64")
|
||||
QEMU_MEMORY="128M"
|
||||
;;
|
||||
"qemumips")
|
||||
QEMU_MEMORY="128M"
|
||||
;;
|
||||
"qemuppc")
|
||||
QEMU_MEMORY="128M"
|
||||
;;
|
||||
*)
|
||||
QEMU_MEMORY="64M"
|
||||
;;
|
||||
esac
|
||||
|
||||
fi
|
||||
|
||||
QEMUIFUP=`which poky-qemu-ifup`
|
||||
QEMUIFDOWN=`which poky-qemu-ifdown`
|
||||
|
||||
NFSRUNNING="false"
|
||||
|
||||
LOCKDIR="/tmp/qemu-tap-locks"
|
||||
[ ! -d "$LOCKDIR" ] && mkdir $LOCKDIR
|
||||
|
||||
@@ -63,8 +64,8 @@ LOCKFILE=""
|
||||
for tap in $POSSIBLE; do
|
||||
LOCKFILE="$LOCKDIR/$tap"
|
||||
if lockfile -2 -r 1 $LOCKFILE; then
|
||||
TAP=$tap
|
||||
break;
|
||||
TAP=$tap
|
||||
break;
|
||||
fi
|
||||
done
|
||||
|
||||
@@ -79,8 +80,7 @@ if [ "$TAP" = "" ]; then
|
||||
fi
|
||||
LOCKFILE="$LOCKDIR/$tap"
|
||||
if lockfile $LOCKFILE; then
|
||||
TAP=$tap
|
||||
break;
|
||||
TAP=$tap
|
||||
fi
|
||||
else
|
||||
echo "Using preconfigured tap device '$TAP'"
|
||||
@@ -93,6 +93,12 @@ release_lock() {
|
||||
echo "Releasing lockfile of preconfigured tap device '$TAP'"
|
||||
rm -f $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
|
||||
}
|
||||
|
||||
n1=$[ (`echo $TAP | sed 's/tap//'` * 2) + 1 ]
|
||||
@@ -110,44 +116,62 @@ if [ "x$SERIAL_LOGFILE" != "x" ]; then
|
||||
fi
|
||||
|
||||
case "$MACHINE" in
|
||||
"qemuarm") ;;
|
||||
"qemumips") ;;
|
||||
"qemuppc") ;;
|
||||
"qemuarmv6") ;;
|
||||
"qemuarmv7") ;;
|
||||
"qemux86") ;;
|
||||
"qemux86-64") ;;
|
||||
"akita") ;;
|
||||
"spitz") ;;
|
||||
"nokia800") ;;
|
||||
"nokia800-maemo") ;;
|
||||
*)
|
||||
echo "Error: Unsupported machine type $MACHINE"
|
||||
return
|
||||
;;
|
||||
"qemuarm") ;;
|
||||
"qemumips") ;;
|
||||
"qemuppc") ;;
|
||||
"qemuarmv6") ;;
|
||||
"qemuarmv7") ;;
|
||||
"qemux86") ;;
|
||||
"qemux86-64") ;;
|
||||
"akita") ;;
|
||||
"spitz") ;;
|
||||
*)
|
||||
echo "Error: Unsupported machine type $MACHINE"
|
||||
return
|
||||
;;
|
||||
esac
|
||||
|
||||
if [ "$TYPE" != "nfs" -a ! -f "$HDIMAGE" ]; then
|
||||
echo "Error: Image file $HDIMAGE doesn't exist"
|
||||
if [ ! -f "$KERNEL" ]; then
|
||||
echo "Error: Kernel image file $KERNEL doesn't exist"
|
||||
release_lock
|
||||
return
|
||||
fi
|
||||
|
||||
if [ "$TYPE" = "nfs" ]; then
|
||||
if [ "$FSTYPE" != "nfs" -a ! -f "$ROOTFS" ]; then
|
||||
echo "Error: Image file $ROOTFS doesn't exist"
|
||||
release_lock
|
||||
return
|
||||
fi
|
||||
|
||||
if [ "$FSTYPE" = "nfs" ]; then
|
||||
NFS_SERVER="192.168.7.1"
|
||||
NFS_DIR=`echo $HDIMAGE | sed 's/^[^:]*:\(.*\)/\1/'`
|
||||
NFS_DIR=`echo $ROOTFS | sed 's/^[^:]*:\(.*\)/\1/'`
|
||||
UNFS_OPTS="nfsvers=2,mountprog=21111,nfsprog=11111,udp"
|
||||
|
||||
PSEUDO_LOCALSTATEDIR=~/.poky-sdk/pseudo
|
||||
export PSEUDO_LOCALSTATEDIR
|
||||
|
||||
rpcbind_running=`ps ax | grep rpcbind | grep -v grep | wc -l`
|
||||
portmap_running=`ps ax | grep portmap | grep -v grep | wc -l`
|
||||
if [[ $rpcbind_running == 0 && $portmap_running == 0 ]]; then
|
||||
echo "You need to be running either rpcbind or portmap to continue"
|
||||
release_lock
|
||||
return
|
||||
fi
|
||||
|
||||
# Start the userspace NFS server
|
||||
echo "poky-export-rootfs restart $ROOTFS"
|
||||
poky-export-rootfs restart $ROOTFS
|
||||
if [ $? != 0 ]; then
|
||||
release_lock
|
||||
return
|
||||
fi
|
||||
NFSRUNNING="true"
|
||||
fi
|
||||
|
||||
if [ "$NFS_SERVER" = "" ]; then
|
||||
NFS_SERVER="192.168.7.1"
|
||||
NFS_DIR=$HDIMAGE
|
||||
fi
|
||||
|
||||
if [ ! -f "$ZIMAGE" ]; then
|
||||
echo "Error: Kernel image file $ZIMAGE doesn't exist"
|
||||
release_lock
|
||||
return
|
||||
NFS_DIR=$ROOTFS
|
||||
fi
|
||||
|
||||
if [ "$MACHINE" = "qemuarm" -o "$MACHINE" = "qemuarmv6" -o "$MACHINE" = "qemuarmv7" ]; then
|
||||
@@ -162,37 +186,37 @@ if [ "$MACHINE" = "qemuarm" -o "$MACHINE" = "qemuarmv6" -o "$MACHINE" = "qemuarm
|
||||
MACHINE_SUBTYPE=versatilepb
|
||||
QEMU_UI_OPTIONS="$QEMU_UI_OPTIONS"
|
||||
# QEMU_UI_OPTIONS="$QEMU_UI_OPTIONS -force-pointer"
|
||||
if [ "$TYPE" = "ext3" ]; then
|
||||
if [ "$FSTYPE" = "ext3" ]; then
|
||||
KERNCMDLINE="root=/dev/sda console=ttyAMA0,115200 console=tty $KERNEL_NETWORK_CMD mem=$QEMU_MEMORY highres=off"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -M versatilepb -hda $HDIMAGE -no-reboot $QEMU_UI_OPTIONS"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -M versatilepb -hda $ROOTFS -no-reboot $QEMU_UI_OPTIONS"
|
||||
fi
|
||||
if [ "$TYPE" = "nfs" ]; then
|
||||
if [ "$FSTYPE" = "nfs" ]; then
|
||||
if [ "$NFS_SERVER" = "192.168.7.1" -a ! -d "$NFS_DIR" ]; then
|
||||
echo "Error: NFS mount point $HDIMAGE doesn't exist"
|
||||
echo "Error: NFS mount point $ROOTFS doesn't exist"
|
||||
release_lock
|
||||
return
|
||||
fi
|
||||
KERNCMDLINE="root=/dev/nfs nfsroot=$NFS_SERVER:$NFS_DIR,$UNFS_OPTS rw $KERNEL_NETWORK_CMD mem=$QEMU_MEMORY"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -M versatilepb --no-reboot $QEMU_UI_OPTIONS"
|
||||
fi
|
||||
if [ "$MACHINE" = "qemuarmv6" ]; then
|
||||
QEMUOPTIONS="$QEMUOPTIONS -cpu arm1136"
|
||||
fi
|
||||
if [ "$MACHINE" = "qemuarmv7" ]; then
|
||||
QEMUOPTIONS="$QEMUOPTIONS -cpu cortex-a8"
|
||||
fi
|
||||
if [ "$MACHINE" = "qemuarmv6" ]; then
|
||||
QEMUOPTIONS="$QEMUOPTIONS -cpu arm1136"
|
||||
fi
|
||||
if [ "$MACHINE" = "qemuarmv7" ]; then
|
||||
QEMUOPTIONS="$QEMUOPTIONS -cpu cortex-a8"
|
||||
fi
|
||||
fi
|
||||
|
||||
if [ "$MACHINE" = "qemux86" ]; then
|
||||
QEMU=qemu
|
||||
QEMU_UI_OPTIONS="$QEMU_UI_OPTIONS -vga vmware -enable-gl"
|
||||
if [ "$TYPE" = "ext3" ]; then
|
||||
if [ "$FSTYPE" = "ext3" ]; then
|
||||
KERNCMDLINE="vga=0 root=/dev/hda mem=$QEMU_MEMORY $KERNEL_NETWORK_CMD"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -hda $HDIMAGE $QEMU_UI_OPTIONS"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -hda $ROOTFS $QEMU_UI_OPTIONS"
|
||||
fi
|
||||
if [ "$TYPE" = "nfs" ]; then
|
||||
if [ "$FSTYPE" = "nfs" ]; then
|
||||
if [ "$NFS_SERVER" = "192.168.7.1" -a ! -d "$NFS_DIR" ]; then
|
||||
echo "Error: NFS mount point $HDIMAGE doesn't exist."
|
||||
echo "Error: NFS mount point $ROOTFS doesn't exist."
|
||||
release_lock
|
||||
return
|
||||
fi
|
||||
@@ -204,16 +228,16 @@ fi
|
||||
if [ "$MACHINE" = "qemux86-64" ]; then
|
||||
QEMU=qemu-system-x86_64
|
||||
QEMU_UI_OPTIONS="$QEMU_UI_OPTIONS -vga vmware -enable-gl"
|
||||
if [ "$TYPE" = "ext3" ]; then
|
||||
if [ "$FSTYPE" = "ext3" ]; then
|
||||
KERNCMDLINE="vga=0 root=/dev/hda mem=$QEMU_MEMORY $KERNEL_NETWORK_CMD"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -hda $HDIMAGE $QEMU_UI_OPTIONS"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -hda $ROOTFS $QEMU_UI_OPTIONS"
|
||||
fi
|
||||
if [ "$TYPE" = "nfs" ]; then
|
||||
if [ "x$HDIMAGE" = "x" ]; then
|
||||
HDIMAGE=/srv/nfs/qemux86-64
|
||||
if [ "$FSTYPE" = "nfs" ]; then
|
||||
if [ "x$ROOTFS" = "x" ]; then
|
||||
ROOTFS=/srv/nfs/qemux86-64
|
||||
fi
|
||||
if [ ! -d "$HDIMAGE" ]; then
|
||||
echo "Error: NFS mount point $HDIMAGE doesn't exist."
|
||||
if [ ! -d "$ROOTFS" ]; then
|
||||
echo "Error: NFS mount point $ROOTFS doesn't exist."
|
||||
release_lock
|
||||
return
|
||||
fi
|
||||
@@ -224,15 +248,15 @@ fi
|
||||
|
||||
if [ "$MACHINE" = "spitz" ]; then
|
||||
QEMU=qemu-system-arm
|
||||
if [ "$TYPE" = "ext3" ]; then
|
||||
echo $HDIMAGE
|
||||
HDIMAGE=`readlink -f $HDIMAGE`
|
||||
echo $HDIMAGE
|
||||
if [ ! -e "$HDIMAGE.qemudisk" ]; then
|
||||
if [ "$FSTYPE" = "ext3" ]; then
|
||||
echo $ROOTFS
|
||||
ROOTFS=`readlink -f $ROOTFS`
|
||||
echo $ROOTFS
|
||||
if [ ! -e "$ROOTFS.qemudisk" ]; then
|
||||
echo "Adding a partition table to the ext3 image for use by QEMU, please wait..."
|
||||
poky-addptable2image $HDIMAGE $HDIMAGE.qemudisk
|
||||
poky-addptable2image $ROOTFS $ROOTFS.qemudisk
|
||||
fi
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -M spitz -hda $HDIMAGE.qemudisk -portrait"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -M spitz -hda $ROOTFS.qemudisk -portrait"
|
||||
fi
|
||||
fi
|
||||
|
||||
@@ -243,11 +267,11 @@ if [ "$MACHINE" = "qemumips" ]; then
|
||||
if [ "$TYPE" = "ext3" ]; then
|
||||
#KERNCMDLINE="root=/dev/hda console=ttyS0 console=tty0 $KERNEL_NETWORK_CMD mem=$QEMU_MEMORY"
|
||||
KERNCMDLINE="root=/dev/hda console=ttyS0 console=tty $KERNEL_NETWORK_CMD mem=$QEMU_MEMORY"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -M $MACHINE_SUBTYPE -hda $HDIMAGE -no-reboot $QEMU_UI_OPTIONS"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -M $MACHINE_SUBTYPE -hda $ROOTFS -no-reboot $QEMU_UI_OPTIONS"
|
||||
fi
|
||||
if [ "$TYPE" = "nfs" ]; then
|
||||
if [ "$FSTYPE" = "nfs" ]; then
|
||||
if [ "$NFS_SERVER" = "192.168.7.1" -a ! -d "$NFS_DIR" ]; then
|
||||
echo "Error: NFS mount point $HDIMAGE doesn't exist"
|
||||
echo "Error: NFS mount point $ROOTFS doesn't exist"
|
||||
release_lock
|
||||
return
|
||||
fi
|
||||
@@ -262,13 +286,13 @@ if [ "$MACHINE" = "qemuppc" ]; then
|
||||
CPU_SUBTYPE=603e
|
||||
BIOS=powerpc_rom.bin
|
||||
QEMU_UI_OPTIONS="$QEMU_UI_OPTIONS -nographic"
|
||||
if [ "$TYPE" = "ext3" ]; then
|
||||
if [ "$FSTYPE" = "ext3" ]; then
|
||||
KERNCMDLINE="root=/dev/hda console=ttyS0 console=tty0 $KERNEL_NETWORK_CMD mem=$QEMU_MEMORY"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -cpu $CPU_SUBTYPE -M $MACHINE_SUBTYPE -bios $BIOS -hda $HDIMAGE -no-reboot $QEMU_UI_OPTIONS"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -cpu $CPU_SUBTYPE -M $MACHINE_SUBTYPE -bios $BIOS -hda $ROOTFS -no-reboot $QEMU_UI_OPTIONS"
|
||||
fi
|
||||
if [ "$TYPE" = "nfs" ]; then
|
||||
if [ "$FSTYPE" = "nfs" ]; then
|
||||
if [ "$NFS_SERVER" = "192.168.7.1" -a ! -d "$NFS_DIR" ]; then
|
||||
echo "Error: NFS mount point $HDIMAGE doesn't exist"
|
||||
echo "Error: NFS mount point $ROOTFS doesn't exist"
|
||||
release_lock
|
||||
return
|
||||
fi
|
||||
@@ -279,56 +303,13 @@ fi
|
||||
|
||||
if [ "$MACHINE" = "akita" ]; then
|
||||
QEMU=qemu-system-arm
|
||||
if [ "$TYPE" = "jffs2" ]; then
|
||||
HDIMAGE=`readlink -f $HDIMAGE`
|
||||
if [ ! -e "$HDIMAGE.qemuflash" ]; then
|
||||
if [ "$FSTYPE" = "jffs2" ]; then
|
||||
ROOTFS=`readlink -f $ROOTFS`
|
||||
if [ ! -e "$ROOTFS.qemuflash" ]; then
|
||||
echo "Converting raw image into flash image format for use by QEMU, please wait..."
|
||||
raw2flash.akita < $HDIMAGE > $HDIMAGE.qemuflash
|
||||
raw2flash.akita < $ROOTFS > $ROOTFS.qemuflash
|
||||
fi
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -M akita -mtdblock $HDIMAGE.qemuflash -portrait"
|
||||
fi
|
||||
fi
|
||||
|
||||
if [ "$MACHINE" = "nokia800" ]; then
|
||||
QEMU=qemu-system-arm
|
||||
if [ "$TYPE" = "jffs2" ]; then
|
||||
HDIMAGE=`readlink -f $HDIMAGE`
|
||||
if [ ! -e "$HDIMAGE.qemuflash" ]; then
|
||||
echo "'Flashing' rootfs, please wait..."
|
||||
poky-nokia800-flashutil $HDIMAGE $HDIMAGE.qemuflash
|
||||
fi
|
||||
KERNCMDLINE="root=/dev/mtdblock4 rootfstype=jffs2"
|
||||
QEMU_NETWORK_CMD="-net nic,model=usb,vlan=0 $QEMU_TAP_CMD"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -M n800 -mtdblock $HDIMAGE.qemuflash -serial vc -m 130 -serial vc -serial vc -serial vc -usb -usbdevice net:0"
|
||||
fi
|
||||
fi
|
||||
|
||||
if [ "$MACHINE" = "nokia800-maemo" ]; then
|
||||
QEMU=qemu-system-arm
|
||||
if [ "$TYPE" = "jffs2" ]; then
|
||||
HDIMAGE=`readlink -f $HDIMAGE`
|
||||
if [ ! -e "$HDIMAGE.qemuflash" ]; then
|
||||
if [ ! -e "$HDIMAGE.initfs" ]; then
|
||||
echo "Error, $HDIMAGE.initfs must exist!"
|
||||
release_lock
|
||||
return
|
||||
fi
|
||||
if [ ! -e "$HDIMAGE.config" ]; then
|
||||
echo "Error, $HDIMAGE.config must exist!"
|
||||
echo "To generate it, take an n800 and cat /dev/mtdblock1 > $HDIMAGE.config"
|
||||
release_lock
|
||||
return
|
||||
fi
|
||||
echo "'Flashing' config partition, please wait..."
|
||||
poky-nokia800-flashutil $HDIMAGE.config $HDIMAGE.qemuflash config
|
||||
echo "'Flashing' initfs, please wait..."
|
||||
poky-nokia800-flashutil $HDIMAGE.initfs $HDIMAGE.qemuflash initfs
|
||||
echo "'Flashing' rootfs, please wait..."
|
||||
poky-nokia800-flashutil $HDIMAGE $HDIMAGE.qemuflash
|
||||
fi
|
||||
KERNCMDLINE=""
|
||||
QEMU_NETWORK_CMD="-net nic,model=usb,vlan=0 $QEMU_TAP_CMD"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -M n800 -mtdblock $HDIMAGE.qemuflash -serial vc -m 130 -serial vc -serial vc -serial vc -usb -usbdevice net:0 -show-cursor"
|
||||
QEMUOPTIONS="$QEMU_NETWORK_CMD -M akita -mtdblock $ROOTFS.qemuflash -portrait"
|
||||
fi
|
||||
fi
|
||||
|
||||
@@ -384,8 +365,8 @@ else
|
||||
fi
|
||||
|
||||
echo "Running $QEMU..."
|
||||
echo $QEMUBIN -kernel $ZIMAGE $QEMUOPTIONS $SERIALOPTS $* --append '"'$KERNCMDLINE'"'
|
||||
$QEMUBIN -kernel $ZIMAGE $QEMUOPTIONS $SERIALOPTS $* --append "$KERNCMDLINE" || /bin/true
|
||||
echo $QEMUBIN -kernel $KERNEL $QEMUOPTIONS $SERIALOPTS $* --append '"'$KERNCMDLINE'"'
|
||||
$QEMUBIN -kernel $KERNEL $QEMUOPTIONS $SERIALOPTS $* --append "$KERNCMDLINE" || /bin/true
|
||||
|
||||
release_lock
|
||||
|
||||
|
||||
Reference in New Issue
Block a user