This commit is contained in:
Ciro Santilli
2017-05-21 12:30:43 +01:00
parent f628c6e07f
commit 960eca1008
6 changed files with 142 additions and 35 deletions

56
runqemu
View File

@@ -3,12 +3,16 @@
set -e
# CLI handling.
arch=x86_64
debug=false
nographic=false
extra_append=''
extra_flags=''
while getopts dn OPT; do
while getopts a:dn OPT; do
case "$OPT" in
a)
arch=$OPTARG
;;
d)
debug=true
extra_flags="$extra_flags -S -s"
@@ -21,23 +25,41 @@ while getopts dn OPT; do
esac
done
# If we turn on buildroot host QEMU some day.
#cmd="./buildroot/output/host/usr/bin/qemu-system-x86_64 \
cmd="qemu-system-x86_64 \
-M pc \
-append 'root=/dev/vda $extra_append' \
-drive file=buildroot/output/images/rootfs.ext2,if=virtio,format=raw \
-kernel buildroot/output/images/bzImage \
-m 128M \
-net nic,model=virtio \
-net user \
-smp 1 \
$extra_flags \
;
"
images_dir='buildroot/output/images'
case "$arch" in
x86_64)
# If we turn on buildroot host QEMU some day.
#cmd="./buildroot/output/host/usr/bin/qemu-system-x86_64 \
cmd="qemu-system-x86_64 \
-M pc \
-append 'root=/dev/vda $extra_append' \
-drive file=${images_dir}/rootfs.ext2,if=virtio,format=raw \
-kernel ${images_dir}/bzImage \
-m 128M \
-net nic,model=virtio \
-net user \
-smp 1 \
$extra_flags
"
;;
arm)
cmd="qemu-system-arm \
-M versatilepb \
-append 'root=/dev/sda console=ttyAMA0,115200' \
-drive file=${images_dir}/rootfs.ext2,if=scsi,format=raw \
-dtb ${images_dir}/versatile-pb.dtb \
-kernel ${images_dir}/zImage \
-m 128M \
-net nic,model=rtl8139 \
-net user \
-serial stdio \
-smp 1 \
$extra_flags"
;;
esac
if $debug && ! $nographic; then
eval nohup "$cmd" &>/dev/null &
if "$debug" && ! "$nographic" && [ ! "$arch" = 'arm' ]; then
eval "$cmd" &>/dev/null &
# TODO: Ctrl +C gets sent to QEMU? Why? Does not happen if I run
# ./rungdb manually from outside this script!!! But why?!?!
# eval has nothing to do with it, minimized example with explicit