added boot device selection to grub-shell
This commit is contained in:
parent
c5431d4029
commit
afafb37e9b
2 changed files with 32 additions and 10 deletions
|
@ -1,5 +1,7 @@
|
||||||
2010-01-12 BVK Chaitanya <bvk@dbook>
|
2010-01-12 BVK Chaitanya <bvk@dbook>
|
||||||
|
|
||||||
|
* tests/util/grub-shell.in: New --boot option.
|
||||||
|
|
||||||
* conf/tests.rmk: Build tests on make.
|
* conf/tests.rmk: Build tests on make.
|
||||||
* Makefile.in (check): Use new variables.
|
* Makefile.in (check): Use new variables.
|
||||||
|
|
||||||
|
|
|
@ -42,6 +42,7 @@ Run GRUB script in a Qemu instance.
|
||||||
|
|
||||||
-h, --help print this message and exit
|
-h, --help print this message and exit
|
||||||
-v, --version print the version information and exit
|
-v, --version print the version information and exit
|
||||||
|
--boot=[fd|hd|cd] boot method for Qemu instance
|
||||||
--modules=MODULES pre-load specified modules MODULES
|
--modules=MODULES pre-load specified modules MODULES
|
||||||
--qemu-opts=OPTIONS extra options to pass to Qemu instance
|
--qemu-opts=OPTIONS extra options to pass to Qemu instance
|
||||||
|
|
||||||
|
@ -67,11 +68,20 @@ for option in "$@"; do
|
||||||
--qemu-opts=*)
|
--qemu-opts=*)
|
||||||
qs=`echo "$option" | sed -e 's/--qemu-opts=//'`
|
qs=`echo "$option" | sed -e 's/--qemu-opts=//'`
|
||||||
qemuopts="$qemuopts $qs" ;;
|
qemuopts="$qemuopts $qs" ;;
|
||||||
|
--boot=*)
|
||||||
|
dev=`echo "$option" | sed -e 's/--boot=//'`
|
||||||
|
if [ "$dev" = "fd" ] ; then bootdev=a;
|
||||||
|
elif [ "$dev" = "hd" ] ; then bootdev=c;
|
||||||
|
elif [ "$dev" = "cd" ] ; then bootdev=d;
|
||||||
|
else
|
||||||
|
echo "Unrecognized boot method \`$dev'" 1>&2
|
||||||
|
usage
|
||||||
|
exit 1
|
||||||
|
fi ;;
|
||||||
-*)
|
-*)
|
||||||
echo "Unrecognized option \`$option'" 1>&2
|
echo "Unrecognized option \`$option'" 1>&2
|
||||||
usage
|
usage
|
||||||
exit 1
|
exit 1 ;;
|
||||||
;;
|
|
||||||
*)
|
*)
|
||||||
if [ "x${source}" != x ] ; then
|
if [ "x${source}" != x ] ; then
|
||||||
echo "too many parameters at the end" 1>&2
|
echo "too many parameters at the end" 1>&2
|
||||||
|
@ -83,11 +93,15 @@ for option in "$@"; do
|
||||||
done
|
done
|
||||||
|
|
||||||
if [ "x${source}" = x ] ; then
|
if [ "x${source}" = x ] ; then
|
||||||
tmpfile=`mktemp`
|
tmpfile=`mktemp`
|
||||||
while read; do
|
while read; do
|
||||||
echo $REPLY >> ${tmpfile}
|
echo $REPLY >> ${tmpfile}
|
||||||
done
|
done
|
||||||
source=${tmpfile}
|
source=${tmpfile}
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "x${bootdev}" = x ] ; then
|
||||||
|
bootdev=c # default is boot as disk image
|
||||||
fi
|
fi
|
||||||
|
|
||||||
cfgfile=`mktemp`
|
cfgfile=`mktemp`
|
||||||
|
@ -101,7 +115,7 @@ EOF
|
||||||
|
|
||||||
for mod in ${modules}
|
for mod in ${modules}
|
||||||
do
|
do
|
||||||
echo "insmod ${mod}" >> ${cfgfile}
|
echo "insmod ${mod}" >> ${cfgfile}
|
||||||
done
|
done
|
||||||
|
|
||||||
cat <<EOF >>${cfgfile}
|
cat <<EOF >>${cfgfile}
|
||||||
|
@ -114,12 +128,18 @@ grub-mkrescue --output=${isofile} --override-directory=${builddir} \
|
||||||
/boot/grub/grub.cfg=${cfgfile} /boot/grub/testcase.cfg=${source} \
|
/boot/grub/grub.cfg=${cfgfile} /boot/grub/testcase.cfg=${source} \
|
||||||
>/dev/null 2>&1
|
>/dev/null 2>&1
|
||||||
|
|
||||||
|
hdafile=`mktemp`
|
||||||
|
cp ${isofile} ${hdafile}
|
||||||
|
|
||||||
|
fdafile=`mktemp`
|
||||||
|
cp ${isofile} ${fdafile}
|
||||||
|
|
||||||
outfile=`mktemp`
|
outfile=`mktemp`
|
||||||
qemu ${qemuopts} -nographic -serial stdio -cdrom ${isofile} -boot d | tr -d "\r" >${outfile}
|
qemu ${qemuopts} -nographic -serial stdio -hda ${hdafile} -fda ${fdafile} -cdrom ${isofile} -boot ${bootdev} | tr -d "\r" >${outfile}
|
||||||
|
|
||||||
cat $outfile
|
cat $outfile
|
||||||
|
|
||||||
rm -f ${tmpfile} ${outfile} ${cfgfile} ${isofile}
|
rm -f ${tmpfile} ${outfile} ${cfgfile} ${isofile} ${hdafile} ${fdafile}
|
||||||
exit 0
|
exit 0
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue