All of lore.kernel.org
 help / color / mirror / Atom feed
From: Jan Kiszka <jan.kiszka@web.de>
To: Alexander Graf <agraf@suse.de>
Cc: Linus Torvalds <torvalds@linux-foundation.org>,
	"kvm@vger.kernel.org list" <kvm@vger.kernel.org>,
	qemu-devel Developers <qemu-devel@nongnu.org>,
	"linux-kernel@vger.kernel.org List"
	<linux-kernel@vger.kernel.org>, Pekka Enberg <penberg@kernel.org>,
	Avi Kivity <avi@redhat.com>
Subject: Re: [PATCH] KVM: Add wrapper script around QEMU to test kernels
Date: Sun, 06 Nov 2011 14:54:07 +0100	[thread overview]
Message-ID: <4EB6917F.3000507@web.de> (raw)
In-Reply-To: <1314221904-28266-1-git-send-email-agraf@suse.de>

[-- Attachment #1: Type: text/plain, Size: 11644 bytes --]

On 2011-08-24 23:38, Alexander Graf wrote:
> On LinuxCon I had a nice chat with Linus on what he thinks kvm-tool
> would be doing and what he expects from it. Basically he wants a
> small and simple tool he and other developers can run to try out and
> see if the kernel they just built actually works.
> 
> Fortunately, QEMU can do that today already! The only piece that was
> missing was the "simple" piece of the equation, so here is a script
> that wraps around QEMU and executes a kernel you just built.
> 
> If you do have KVM around and are not cross-compiling, it will use
> KVM. But if you don't, you can still fall back to emulation mode and
> at least check if your kernel still does what you expect. I only
> implemented support for s390x and ppc there, but it's easily extensible
> to more platforms, as QEMU can emulate (and virtualize) pretty much
> any platform out there.
> 
> If you don't have qemu installed, please do so before using this script. Your
> distro should provide a package for it (might even call it "kvm"). If not,
> just compile it from source - it's not hard!
> 
> To quickly get going, just execute the following as user:
> 
>     $ ./Documentation/run-qemu.sh -r / -a init=/bin/bash
> 
> This will drop you into a shell on your rootfs.
> 
> Happy hacking!
> 
> Signed-off-by: Alexander Graf <agraf@suse.de>
> 
> ---
> 
> v1 -> v2:
> 
>   - fix naming of QEMU
>   - use grep -q for has_config
>   - support multiple -a args
>   - spawn gdb on execution
>   - pass through qemu options
>   - dont use qemu-system-x86_64 on i386
>   - add funny sentence to startup text
>   - more helpful error messages
> ---
>  scripts/run-qemu.sh |  334 +++++++++++++++++++++++++++++++++++++++++++++++++++
>  1 files changed, 334 insertions(+), 0 deletions(-)
>  create mode 100755 scripts/run-qemu.sh
> 
> diff --git a/scripts/run-qemu.sh b/scripts/run-qemu.sh
> new file mode 100755
> index 0000000..5d4e185
> --- /dev/null
> +++ b/scripts/run-qemu.sh
> @@ -0,0 +1,334 @@
> +#!/bin/bash
> +#
> +# QEMU Launcher
> +#
> +# This script enables simple use of the KVM and QEMU tool stack for
> +# easy kernel testing. It allows to pass either a host directory to
> +# the guest or a disk image. Example usage:
> +#
> +# Run the host root fs inside a VM:
> +#
> +# $ ./scripts/run-qemu.sh -r /
> +#
> +# Run the same with SDL:
> +#
> +# $ ./scripts/run-qemu.sh -r / --sdl
> +# 
> +# Or with a PPC build:
> +#
> +# $ ARCH=ppc ./scripts/run-qemu.sh -r /
> +# 
> +# PPC with a mac99 model by passing options to QEMU:
> +#
> +# $ ARCH=ppc ./scripts/run-qemu.sh -r / -- -M mac99
> +#
> +
> +USE_SDL=
> +USE_VNC=
> +USE_GDB=1
> +KERNEL_BIN=arch/x86/boot/bzImage
> +MON_STDIO=
> +KERNEL_APPEND2=
> +SERIAL=ttyS0
> +SERIAL_KCONFIG=SERIAL_8250
> +BASENAME=$(basename "$0")
> +
> +function usage() {
> +	echo "
> +$BASENAME allows you to execute a virtual machine with the Linux kernel
> +that you just built. To only execute a simple VM, you can just run it
> +on your root fs with \"-r / -a init=/bin/bash\"
> +
> +	-a, --append parameters
> +		Append the given parameters to the kernel command line.
> +
> +	-d, --disk image
> +		Add the image file as disk into the VM.
> +
> +	-D, --no-gdb
> +		Don't run an xterm with gdb attached to the guest.
> +
> +	-r, --root directory
> +		Use the specified directory as root directory inside the guest.
> +
> +	-s, --sdl
> +		Enable SDL graphical output.
> +
> +	-S, --smp cpus
> +		Set number of virtual CPUs.
> +
> +	-v, --vnc
> +		Enable VNC graphical output.
> +
> +Examples:
> +
> +	Run the host root fs inside a VM:
> +	$ ./scripts/run-qemu.sh -r /
> +
> +	Run the same with SDL:
> +	$ ./scripts/run-qemu.sh -r / --sdl
> +	
> +	Or with a PPC build:
> +	$ ARCH=ppc ./scripts/run-qemu.sh -r /
> +	
> +	PPC with a mac99 model by passing options to QEMU:
> +	$ ARCH=ppc ./scripts/run-qemu.sh -r / -- -M mac99
> +"
> +}
> +
> +function require_config() {
> +	if [ "$(grep CONFIG_$1=y .config)" ]; then
> +		return
> +	fi
> +
> +	echo "You need to enable CONFIG_$1 for run-qemu to work properly"
> +	exit 1
> +}
> +
> +function has_config() {
> +	grep -q "CONFIG_$1=y" .config
> +}
> +
> +function drive_if() {
> +	if has_config VIRTIO_BLK; then
> +		echo virtio
> +	elif has_config ATA_PIIX; then
> +		echo ide

+ require_config "BLK_DEV_SD"

Maybe there should also be a warning if no standard FS (ext[34], btrfs,
xfs etc.) is build into the kernel.

Another thing, but that's just a recommendation for initrd-free mode:
DEVTMPFS_MOUNT

> +	else
> +		echo "\
> +Your kernel must have either VIRTIO_BLK or ATA_PIIX
> +enabled for block device assignment" >&2
> +		exit 1
> +	fi
> +}
> +
> +GETOPT=`getopt -o a:d:Dhr:sS:v --long append,disk:,no-gdb,help,root:,sdl,smp:,vnc \
> +	-n "$(basename \"$0\")" -- "$@"`
> +
> +if [ $? != 0 ]; then
> +	echo "Terminating..." >&2
> +	exit 1
> +fi
> +
> +eval set -- "$GETOPT"
> +
> +while true; do
> +	case "$1" in
> +	-a|--append)
> +		KERNEL_APPEND2="$KERNEL_APPEND2 $KERNEL_APPEND2"

That should be

KERNEL_APPEND2="$KERNEL_APPEND2 $2"

> +		shift
> +		;;
> +	-d|--disk)
> +		QEMU_OPTIONS="$QEMU_OPTIONS -drive \
> +			file=$2,if=$(drive_if),cache=unsafe"

		if [ $? != 0 ]; then
			exit $?
		fi

> +		USE_DISK=1
> +		shift
> +		;;
> +	-D|--no-gdb)
> +		USE_GDB=
> +		;;
> +	-h|--help)
> +		usage
> +		exit 0
> +		;;
> +	-r|--root)
> +		ROOTFS="$2"
> +		shift
> +		;;
> +	-s|--sdl)
> +		USE_SDL=1
> +		;;
> +	-S|--smp)
> +		SMP="$2"
> +		shift
> +		;;
> +	-v|--vnc)
> +		USE_VNC=1
> +		;;
> +	--)
> +		shift
> +		break
> +		;;
> +	*)
> +		echo "Could not parse option: $1" >&2
> +		exit 1
> +		;;
> +	esac
> +	shift
> +done
> +
> +if [ ! "$ROOTFS" -a ! "$USE_DISK" ]; then
> +	echo "\
> +Error: Please specify at least -r or -d with a target \
> +FS to run off of" >&2
> +	exit 1
> +fi
> +
> +# Try to find the KVM accelerated QEMU binary
> +
> +[ "$ARCH" ] || ARCH=$(uname -m)
> +case $ARCH in
> +x86_64)
> +	KERNEL_BIN=arch/x86/boot/bzImage
> +	# SUSE and Red Hat call the binary qemu-kvm
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which qemu-kvm 2>/dev/null)
> +
> +	# Debian and Gentoo call it kvm
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which kvm 2>/dev/null)
> +
> +	# QEMU's own build system calls it qemu-system-x86_64
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which qemu-system-x86_64 2>/dev/null)
> +	;;
> +i*86)
> +	KERNEL_BIN=arch/x86/boot/bzImage
> +	# SUSE and Red Hat call the binary qemu-kvm
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which qemu-kvm 2>/dev/null)
> +
> +	# Debian and Gentoo call it kvm
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which kvm 2>/dev/null)
> +
> +	KERNEL_BIN=arch/x86/boot/bzImage
> +	# i386 version of QEMU
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which qemu 2>/dev/null)
> +	;;
> +s390*)
> +	KERNEL_BIN=arch/s390/boot/image
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which qemu-system-s390x 2>/dev/null)
> +	;;
> +ppc*)
> +	KERNEL_BIN=vmlinux
> +
> +	IS_64BIT=
> +	has_config PPC64 && IS_64BIT=64
> +	if has_config PPC_85xx; then
> +		QEMU_OPTIONS="$QEMU_OPTIONS -M mpc8544ds"
> +	elif has_config PPC_PSERIES; then
> +		QEMU_OPTIONS="$QEMU_OPTIONS -M pseries"
> +		SERIAL=hvc0
> +		SERIAL_KCONFIG=HVC_CONSOLE
> +	elif has_config PPC_PMAC; then
> +		has_config SERIAL_PMACZILOG_TTYS || SERIAL=ttyPZ0
> +		SERIAL_KCONFIG=SERIAL_PMACZILOG
> +	else
> +		echo "Unknown PPC board" >&2
> +		exit 1
> +	fi
> +
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which qemu-system-ppc${IS_64BIT} 2>/dev/null)
> +	;;
> +esac
> +
> +if [ ! -e "$QEMU_BIN" ]; then
> +	echo "\
> +Could not find a usable QEMU binary. Please install one from \
> +your distro or from source code using:
> +
> +  $ git clone git://git.qemu.org/qemu.git
> +  $ cd qemu
> +  $ ./configure
> +  $ make -j
> +  $ sudo make install
> +" >&2
> +	exit 1
> +fi
> +
> +# The binaries without kvm in their name can be too old to support KVM, so
> +# check for that before the user gets confused
> +if [ ! "$(echo $QEMU_BIN | grep kvm)" -a \
> +     ! "$($QEMU_BIN --help | egrep '^-machine')" ]; then
> +	echo "Your QEMU binary is too old, please update to at least 0.15." >&2
> +	exit 1
> +fi
> +QEMU_OPTIONS="$QEMU_OPTIONS -machine accel=kvm:tcg"
> +
> +# We need to check some .config variables to make sure we actually work
> +# on the respective kernel.
> +if [ ! -e .config ]; then
> +	echo "\
> +Please run this script on a fully compiled and configured
> +Linux kernel build directory" >&2
> +	exit 1
> +fi
> +
> +if [ ! -e "$KERNEL_BIN" ]; then
> +	echo "Could not find kernel binary: $KERNEL_BIN" >&2
> +	exit 1
> +fi
> +
> +QEMU_OPTIONS="$QEMU_OPTIONS -kernel $KERNEL_BIN"
> +
> +if [ "$USE_SDL" ]; then
> +	# SDL is the default, so nothing to do
> +	:
> +elif [ "$USE_VNC" ]; then
> +	QEMU_OPTIONS="$QEMU_OPTIONS -vnc :5"
> +else
> +	# When emulating a serial console, tell the kernel to use it as well
> +	QEMU_OPTIONS="$QEMU_OPTIONS -nographic"
> +	KERNEL_APPEND="$KERNEL_APPEND console=$SERIAL earlyprintk=serial"
> +	MON_STDIO=1
> +	require_config "$SERIAL_KCONFIG"
> +fi
> +
> +if [ "$ROOTFS" ]; then
> +	# Using rootfs with 9p
> +	require_config "NET_9P_VIRTIO"

+ require_config "9P_FS"

> +	KERNEL_APPEND="$KERNEL_APPEND \
> +root=/dev/root rootflags=rw,trans=virtio,version=9p2000.L rootfstype=9p"
> +
> +#Usage: -virtfs fstype,path=/share_path/,security_model=[mapped|passthrough|none],mount_tag=tag.
> +
> +
> +	QEMU_OPTIONS="$QEMU_OPTIONS \
> +-virtfs local,id=root,path=$ROOTFS,mount_tag=root,security_model=passthrough \
> +-device virtio-9p-pci,fsdev=root,mount_tag=/dev/root"
> +fi
> +
> +[ "$SMP" ] || SMP=1
> +
> +# User append args come last
> +KERNEL_APPEND="$KERNEL_APPEND $KERNEL_APPEND2"
> +
> +############### Execution #################
> +
> +QEMU_OPTIONS="$QEMU_OPTIONS -smp $SMP"
> +
> +echo "
> +	################# Linux QEMU launcher #################
> +
> +This script executes your currently built Linux kernel using QEMU. If KVM is
> +available, it will also use KVM for fast virtualization of your guest.
> +
> +The intent is to make it very easy to run your kernel. If you need to do more
> +advanced things, such as passing through real devices, please use QEMU command
> +line options and add them to the $BASENAME command line using --.
> +
> +This tool is for simplicity, not world dominating functionality coverage.
> +(just a hobby, won't be big and professional like libvirt)
> +
> +"
> +
> +if [ "$MON_STDIO" ]; then
> +	echo "\
> +### Your guest is bound to the current foreground shell. To quit the guest, ###
> +### please use Ctrl-A x                                                     ###
> +"
> +fi
> +
> +echo "  Executing: $QEMU_BIN $QEMU_OPTIONS -append \"$KERNEL_APPEND\""
> +echo
> +
> +GDB_PID=
> +if [ "$USE_GDB" -a "$DISPLAY" -a -x "$(which xterm)" -a -e "$(which gdb)" ]; then
> +	# Run a gdb console in parallel to the kernel
> +
> +	# XXX find out if port is in use
> +	PORT=$$
> +	xterm -T "$BASENAME" -e "sleep 2; gdb vmlinux -ex 'target remote localhost:$PORT' -ex c" &
> +	GDB_PID=$!
> +	QEMU_OPTIONS="$QEMU_OPTIONS -gdb tcp::$PORT"
> +fi
> +
> +$QEMU_BIN $QEMU_OPTIONS -append "$KERNEL_APPEND" "$@"
> +wait $GDB_PID &>/dev/null
> +

Nice that it forks off a gdb session. I will contribute my gdb helper
script soon (module symbol loading, dmesg, per-cpu variable lookup etc.)
so that it can be loaded automatically.

Jan


[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 262 bytes --]

WARNING: multiple messages have this Message-ID (diff)
From: Jan Kiszka <jan.kiszka@web.de>
To: Alexander Graf <agraf@suse.de>
Cc: "kvm@vger.kernel.org list" <kvm@vger.kernel.org>,
	qemu-devel Developers <qemu-devel@nongnu.org>,
	"linux-kernel@vger.kernel.org List"
	<linux-kernel@vger.kernel.org>, Pekka Enberg <penberg@kernel.org>,
	Avi Kivity <avi@redhat.com>,
	Linus Torvalds <torvalds@linux-foundation.org>
Subject: Re: [Qemu-devel] [PATCH] KVM: Add wrapper script around QEMU to test kernels
Date: Sun, 06 Nov 2011 14:54:07 +0100	[thread overview]
Message-ID: <4EB6917F.3000507@web.de> (raw)
In-Reply-To: <1314221904-28266-1-git-send-email-agraf@suse.de>

[-- Attachment #1: Type: text/plain, Size: 11644 bytes --]

On 2011-08-24 23:38, Alexander Graf wrote:
> On LinuxCon I had a nice chat with Linus on what he thinks kvm-tool
> would be doing and what he expects from it. Basically he wants a
> small and simple tool he and other developers can run to try out and
> see if the kernel they just built actually works.
> 
> Fortunately, QEMU can do that today already! The only piece that was
> missing was the "simple" piece of the equation, so here is a script
> that wraps around QEMU and executes a kernel you just built.
> 
> If you do have KVM around and are not cross-compiling, it will use
> KVM. But if you don't, you can still fall back to emulation mode and
> at least check if your kernel still does what you expect. I only
> implemented support for s390x and ppc there, but it's easily extensible
> to more platforms, as QEMU can emulate (and virtualize) pretty much
> any platform out there.
> 
> If you don't have qemu installed, please do so before using this script. Your
> distro should provide a package for it (might even call it "kvm"). If not,
> just compile it from source - it's not hard!
> 
> To quickly get going, just execute the following as user:
> 
>     $ ./Documentation/run-qemu.sh -r / -a init=/bin/bash
> 
> This will drop you into a shell on your rootfs.
> 
> Happy hacking!
> 
> Signed-off-by: Alexander Graf <agraf@suse.de>
> 
> ---
> 
> v1 -> v2:
> 
>   - fix naming of QEMU
>   - use grep -q for has_config
>   - support multiple -a args
>   - spawn gdb on execution
>   - pass through qemu options
>   - dont use qemu-system-x86_64 on i386
>   - add funny sentence to startup text
>   - more helpful error messages
> ---
>  scripts/run-qemu.sh |  334 +++++++++++++++++++++++++++++++++++++++++++++++++++
>  1 files changed, 334 insertions(+), 0 deletions(-)
>  create mode 100755 scripts/run-qemu.sh
> 
> diff --git a/scripts/run-qemu.sh b/scripts/run-qemu.sh
> new file mode 100755
> index 0000000..5d4e185
> --- /dev/null
> +++ b/scripts/run-qemu.sh
> @@ -0,0 +1,334 @@
> +#!/bin/bash
> +#
> +# QEMU Launcher
> +#
> +# This script enables simple use of the KVM and QEMU tool stack for
> +# easy kernel testing. It allows to pass either a host directory to
> +# the guest or a disk image. Example usage:
> +#
> +# Run the host root fs inside a VM:
> +#
> +# $ ./scripts/run-qemu.sh -r /
> +#
> +# Run the same with SDL:
> +#
> +# $ ./scripts/run-qemu.sh -r / --sdl
> +# 
> +# Or with a PPC build:
> +#
> +# $ ARCH=ppc ./scripts/run-qemu.sh -r /
> +# 
> +# PPC with a mac99 model by passing options to QEMU:
> +#
> +# $ ARCH=ppc ./scripts/run-qemu.sh -r / -- -M mac99
> +#
> +
> +USE_SDL=
> +USE_VNC=
> +USE_GDB=1
> +KERNEL_BIN=arch/x86/boot/bzImage
> +MON_STDIO=
> +KERNEL_APPEND2=
> +SERIAL=ttyS0
> +SERIAL_KCONFIG=SERIAL_8250
> +BASENAME=$(basename "$0")
> +
> +function usage() {
> +	echo "
> +$BASENAME allows you to execute a virtual machine with the Linux kernel
> +that you just built. To only execute a simple VM, you can just run it
> +on your root fs with \"-r / -a init=/bin/bash\"
> +
> +	-a, --append parameters
> +		Append the given parameters to the kernel command line.
> +
> +	-d, --disk image
> +		Add the image file as disk into the VM.
> +
> +	-D, --no-gdb
> +		Don't run an xterm with gdb attached to the guest.
> +
> +	-r, --root directory
> +		Use the specified directory as root directory inside the guest.
> +
> +	-s, --sdl
> +		Enable SDL graphical output.
> +
> +	-S, --smp cpus
> +		Set number of virtual CPUs.
> +
> +	-v, --vnc
> +		Enable VNC graphical output.
> +
> +Examples:
> +
> +	Run the host root fs inside a VM:
> +	$ ./scripts/run-qemu.sh -r /
> +
> +	Run the same with SDL:
> +	$ ./scripts/run-qemu.sh -r / --sdl
> +	
> +	Or with a PPC build:
> +	$ ARCH=ppc ./scripts/run-qemu.sh -r /
> +	
> +	PPC with a mac99 model by passing options to QEMU:
> +	$ ARCH=ppc ./scripts/run-qemu.sh -r / -- -M mac99
> +"
> +}
> +
> +function require_config() {
> +	if [ "$(grep CONFIG_$1=y .config)" ]; then
> +		return
> +	fi
> +
> +	echo "You need to enable CONFIG_$1 for run-qemu to work properly"
> +	exit 1
> +}
> +
> +function has_config() {
> +	grep -q "CONFIG_$1=y" .config
> +}
> +
> +function drive_if() {
> +	if has_config VIRTIO_BLK; then
> +		echo virtio
> +	elif has_config ATA_PIIX; then
> +		echo ide

+ require_config "BLK_DEV_SD"

Maybe there should also be a warning if no standard FS (ext[34], btrfs,
xfs etc.) is build into the kernel.

Another thing, but that's just a recommendation for initrd-free mode:
DEVTMPFS_MOUNT

> +	else
> +		echo "\
> +Your kernel must have either VIRTIO_BLK or ATA_PIIX
> +enabled for block device assignment" >&2
> +		exit 1
> +	fi
> +}
> +
> +GETOPT=`getopt -o a:d:Dhr:sS:v --long append,disk:,no-gdb,help,root:,sdl,smp:,vnc \
> +	-n "$(basename \"$0\")" -- "$@"`
> +
> +if [ $? != 0 ]; then
> +	echo "Terminating..." >&2
> +	exit 1
> +fi
> +
> +eval set -- "$GETOPT"
> +
> +while true; do
> +	case "$1" in
> +	-a|--append)
> +		KERNEL_APPEND2="$KERNEL_APPEND2 $KERNEL_APPEND2"

That should be

KERNEL_APPEND2="$KERNEL_APPEND2 $2"

> +		shift
> +		;;
> +	-d|--disk)
> +		QEMU_OPTIONS="$QEMU_OPTIONS -drive \
> +			file=$2,if=$(drive_if),cache=unsafe"

		if [ $? != 0 ]; then
			exit $?
		fi

> +		USE_DISK=1
> +		shift
> +		;;
> +	-D|--no-gdb)
> +		USE_GDB=
> +		;;
> +	-h|--help)
> +		usage
> +		exit 0
> +		;;
> +	-r|--root)
> +		ROOTFS="$2"
> +		shift
> +		;;
> +	-s|--sdl)
> +		USE_SDL=1
> +		;;
> +	-S|--smp)
> +		SMP="$2"
> +		shift
> +		;;
> +	-v|--vnc)
> +		USE_VNC=1
> +		;;
> +	--)
> +		shift
> +		break
> +		;;
> +	*)
> +		echo "Could not parse option: $1" >&2
> +		exit 1
> +		;;
> +	esac
> +	shift
> +done
> +
> +if [ ! "$ROOTFS" -a ! "$USE_DISK" ]; then
> +	echo "\
> +Error: Please specify at least -r or -d with a target \
> +FS to run off of" >&2
> +	exit 1
> +fi
> +
> +# Try to find the KVM accelerated QEMU binary
> +
> +[ "$ARCH" ] || ARCH=$(uname -m)
> +case $ARCH in
> +x86_64)
> +	KERNEL_BIN=arch/x86/boot/bzImage
> +	# SUSE and Red Hat call the binary qemu-kvm
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which qemu-kvm 2>/dev/null)
> +
> +	# Debian and Gentoo call it kvm
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which kvm 2>/dev/null)
> +
> +	# QEMU's own build system calls it qemu-system-x86_64
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which qemu-system-x86_64 2>/dev/null)
> +	;;
> +i*86)
> +	KERNEL_BIN=arch/x86/boot/bzImage
> +	# SUSE and Red Hat call the binary qemu-kvm
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which qemu-kvm 2>/dev/null)
> +
> +	# Debian and Gentoo call it kvm
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which kvm 2>/dev/null)
> +
> +	KERNEL_BIN=arch/x86/boot/bzImage
> +	# i386 version of QEMU
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which qemu 2>/dev/null)
> +	;;
> +s390*)
> +	KERNEL_BIN=arch/s390/boot/image
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which qemu-system-s390x 2>/dev/null)
> +	;;
> +ppc*)
> +	KERNEL_BIN=vmlinux
> +
> +	IS_64BIT=
> +	has_config PPC64 && IS_64BIT=64
> +	if has_config PPC_85xx; then
> +		QEMU_OPTIONS="$QEMU_OPTIONS -M mpc8544ds"
> +	elif has_config PPC_PSERIES; then
> +		QEMU_OPTIONS="$QEMU_OPTIONS -M pseries"
> +		SERIAL=hvc0
> +		SERIAL_KCONFIG=HVC_CONSOLE
> +	elif has_config PPC_PMAC; then
> +		has_config SERIAL_PMACZILOG_TTYS || SERIAL=ttyPZ0
> +		SERIAL_KCONFIG=SERIAL_PMACZILOG
> +	else
> +		echo "Unknown PPC board" >&2
> +		exit 1
> +	fi
> +
> +	[ "$QEMU_BIN" ] || QEMU_BIN=$(which qemu-system-ppc${IS_64BIT} 2>/dev/null)
> +	;;
> +esac
> +
> +if [ ! -e "$QEMU_BIN" ]; then
> +	echo "\
> +Could not find a usable QEMU binary. Please install one from \
> +your distro or from source code using:
> +
> +  $ git clone git://git.qemu.org/qemu.git
> +  $ cd qemu
> +  $ ./configure
> +  $ make -j
> +  $ sudo make install
> +" >&2
> +	exit 1
> +fi
> +
> +# The binaries without kvm in their name can be too old to support KVM, so
> +# check for that before the user gets confused
> +if [ ! "$(echo $QEMU_BIN | grep kvm)" -a \
> +     ! "$($QEMU_BIN --help | egrep '^-machine')" ]; then
> +	echo "Your QEMU binary is too old, please update to at least 0.15." >&2
> +	exit 1
> +fi
> +QEMU_OPTIONS="$QEMU_OPTIONS -machine accel=kvm:tcg"
> +
> +# We need to check some .config variables to make sure we actually work
> +# on the respective kernel.
> +if [ ! -e .config ]; then
> +	echo "\
> +Please run this script on a fully compiled and configured
> +Linux kernel build directory" >&2
> +	exit 1
> +fi
> +
> +if [ ! -e "$KERNEL_BIN" ]; then
> +	echo "Could not find kernel binary: $KERNEL_BIN" >&2
> +	exit 1
> +fi
> +
> +QEMU_OPTIONS="$QEMU_OPTIONS -kernel $KERNEL_BIN"
> +
> +if [ "$USE_SDL" ]; then
> +	# SDL is the default, so nothing to do
> +	:
> +elif [ "$USE_VNC" ]; then
> +	QEMU_OPTIONS="$QEMU_OPTIONS -vnc :5"
> +else
> +	# When emulating a serial console, tell the kernel to use it as well
> +	QEMU_OPTIONS="$QEMU_OPTIONS -nographic"
> +	KERNEL_APPEND="$KERNEL_APPEND console=$SERIAL earlyprintk=serial"
> +	MON_STDIO=1
> +	require_config "$SERIAL_KCONFIG"
> +fi
> +
> +if [ "$ROOTFS" ]; then
> +	# Using rootfs with 9p
> +	require_config "NET_9P_VIRTIO"

+ require_config "9P_FS"

> +	KERNEL_APPEND="$KERNEL_APPEND \
> +root=/dev/root rootflags=rw,trans=virtio,version=9p2000.L rootfstype=9p"
> +
> +#Usage: -virtfs fstype,path=/share_path/,security_model=[mapped|passthrough|none],mount_tag=tag.
> +
> +
> +	QEMU_OPTIONS="$QEMU_OPTIONS \
> +-virtfs local,id=root,path=$ROOTFS,mount_tag=root,security_model=passthrough \
> +-device virtio-9p-pci,fsdev=root,mount_tag=/dev/root"
> +fi
> +
> +[ "$SMP" ] || SMP=1
> +
> +# User append args come last
> +KERNEL_APPEND="$KERNEL_APPEND $KERNEL_APPEND2"
> +
> +############### Execution #################
> +
> +QEMU_OPTIONS="$QEMU_OPTIONS -smp $SMP"
> +
> +echo "
> +	################# Linux QEMU launcher #################
> +
> +This script executes your currently built Linux kernel using QEMU. If KVM is
> +available, it will also use KVM for fast virtualization of your guest.
> +
> +The intent is to make it very easy to run your kernel. If you need to do more
> +advanced things, such as passing through real devices, please use QEMU command
> +line options and add them to the $BASENAME command line using --.
> +
> +This tool is for simplicity, not world dominating functionality coverage.
> +(just a hobby, won't be big and professional like libvirt)
> +
> +"
> +
> +if [ "$MON_STDIO" ]; then
> +	echo "\
> +### Your guest is bound to the current foreground shell. To quit the guest, ###
> +### please use Ctrl-A x                                                     ###
> +"
> +fi
> +
> +echo "  Executing: $QEMU_BIN $QEMU_OPTIONS -append \"$KERNEL_APPEND\""
> +echo
> +
> +GDB_PID=
> +if [ "$USE_GDB" -a "$DISPLAY" -a -x "$(which xterm)" -a -e "$(which gdb)" ]; then
> +	# Run a gdb console in parallel to the kernel
> +
> +	# XXX find out if port is in use
> +	PORT=$$
> +	xterm -T "$BASENAME" -e "sleep 2; gdb vmlinux -ex 'target remote localhost:$PORT' -ex c" &
> +	GDB_PID=$!
> +	QEMU_OPTIONS="$QEMU_OPTIONS -gdb tcp::$PORT"
> +fi
> +
> +$QEMU_BIN $QEMU_OPTIONS -append "$KERNEL_APPEND" "$@"
> +wait $GDB_PID &>/dev/null
> +

Nice that it forks off a gdb session. I will contribute my gdb helper
script soon (module symbol loading, dmesg, per-cpu variable lookup etc.)
so that it can be loaded automatically.

Jan


[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 262 bytes --]

  parent reply	other threads:[~2011-11-06 14:02 UTC|newest]

Thread overview: 184+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-08-24 21:38 [PATCH] KVM: Add wrapper script around QEMU to test kernels Alexander Graf
2011-08-24 21:38 ` [Qemu-devel] " Alexander Graf
2011-08-24 21:38 ` Alexander Graf
2011-08-25 18:01 ` [Qemu-devel] " Blue Swirl
2011-08-25 18:01   ` Blue Swirl
2011-11-06  0:03   ` Alexander Graf
2011-11-06  0:03     ` Alexander Graf
2011-11-06  0:03     ` Alexander Graf
2011-11-06 13:54 ` Jan Kiszka [this message]
2011-11-06 13:54   ` [Qemu-devel] " Jan Kiszka
2012-05-11 13:42   ` Alexander Graf
2012-05-11 13:42     ` [Qemu-devel] " Alexander Graf
2012-05-11 14:05     ` Jan Kiszka
2012-05-11 14:05       ` [Qemu-devel] " Jan Kiszka
2012-05-11 14:05       ` Jan Kiszka
  -- strict thread matches above, loose matches on Subject: below --
2012-05-11 15:46 Alexander Graf
2011-11-07 14:34 青云
2011-11-06  1:35 Alexander Graf
2011-11-06  1:35 ` Alexander Graf
2011-11-06 10:04 ` Pekka Enberg
2011-11-06 10:04   ` Pekka Enberg
2011-11-06 10:07   ` Avi Kivity
2011-11-06 10:07     ` Avi Kivity
2011-11-06 10:12     ` Pekka Enberg
2011-11-06 10:12       ` Pekka Enberg
2011-11-06 10:23       ` Avi Kivity
2011-11-06 10:23         ` Avi Kivity
2011-11-06 11:08         ` Pekka Enberg
2011-11-06 11:08           ` Pekka Enberg
2011-11-06 11:50           ` Avi Kivity
2011-11-06 11:50             ` Avi Kivity
2011-11-06 12:14             ` Pekka Enberg
2011-11-06 12:14               ` Pekka Enberg
2011-11-06 12:27               ` Avi Kivity
2011-11-06 12:27                 ` Avi Kivity
2011-11-06 12:32                 ` Pekka Enberg
2011-11-06 12:32                   ` Pekka Enberg
2011-11-06 12:43                   ` Avi Kivity
2011-11-06 12:43                     ` Avi Kivity
2011-11-06 13:06                     ` Pekka Enberg
2011-11-06 13:06                       ` Pekka Enberg
2011-11-06 15:56                       ` Avi Kivity
2011-11-06 15:56                         ` Avi Kivity
2011-11-06 16:35                         ` Pekka Enberg
2011-11-06 16:35                           ` Pekka Enberg
2011-11-06 16:50                           ` Avi Kivity
2011-11-06 17:08                             ` Anthony Liguori
2011-11-06 18:09                               ` Pekka Enberg
2011-11-07  1:38                                 ` Anthony Liguori
2011-11-06 18:31                               ` [Qemu-devel] " Ted Ts'o
2011-11-06 18:54                                 ` Pekka Enberg
2011-11-06 18:58                                   ` Pekka Enberg
2011-11-06 23:19                                     ` Ted Ts'o
2011-11-07  6:42                                       ` Pekka Enberg
2011-11-07 17:03                                         ` Vince Weaver
2011-11-07 17:59                                           ` [Qemu-devel] " Ingo Molnar
2011-11-07 20:03                                             ` Frank Ch. Eigler
2011-11-07 20:09                                               ` Pekka Enberg
2011-11-08  5:29                                             ` [Qemu-devel] " Vince Weaver
2011-11-08 12:07                                               ` Ingo Molnar
2011-11-08 13:08                                                 ` Arnaldo Carvalho de Melo
2011-11-09  6:04                                                   ` Vince Weaver
2011-11-07 19:53                                           ` [Qemu-devel] " Pekka Enberg
2011-11-07 20:32                                             ` Ted Ts'o
2011-11-07 21:36                                               ` [Qemu-devel] " Pekka Enberg
2011-11-07 22:19                                                 ` Anthony Liguori
2011-11-07 23:42                                                   ` Theodore Tso
2011-11-07 10:31                                 ` Kevin Wolf
2011-11-07 11:38                                   ` Pekka Enberg
2011-11-07 11:59                                     ` Kevin Wolf
2011-11-06 16:19                       ` Jan Kiszka
2011-11-06 16:30                         ` Pekka Enberg
2011-11-06 16:30                           ` Pekka Enberg
2011-11-06 16:39                           ` Jan Kiszka
2011-11-06 16:39                             ` Jan Kiszka
2011-11-06 17:11                             ` Pekka Enberg
2011-11-06 17:11                               ` Pekka Enberg
2011-11-06 17:23                               ` Jan Kiszka
2011-11-06 17:23                                 ` Jan Kiszka
2011-11-06 17:55                                 ` Pekka Enberg
2011-11-06 17:55                                   ` Pekka Enberg
2011-11-06 16:39                         ` Pekka Enberg
2011-11-06 16:39                           ` Pekka Enberg
2011-11-07 10:11                         ` Gerd Hoffmann
2011-11-07 10:11                           ` Gerd Hoffmann
2011-11-07 10:18                           ` Pekka Enberg
2011-11-06 17:10                       ` Anthony Liguori
2011-11-06 17:15                       ` Alexander Graf
2011-11-06 17:15                         ` Alexander Graf
2011-11-06 17:28                         ` Pekka Enberg
2011-11-06 17:28                           ` Pekka Enberg
2011-11-06 17:30                           ` Alexander Graf
2011-11-06 17:30                             ` Alexander Graf
2011-11-06 18:05                             ` Pekka Enberg
2011-11-06 18:05                               ` Pekka Enberg
2011-11-06 19:14                               ` Paolo Bonzini
2011-11-06 19:14                                 ` Paolo Bonzini
2011-11-06 19:19                                 ` Pekka Enberg
2011-11-06 19:19                                   ` Pekka Enberg
2011-11-06 22:08                             ` Frank Ch. Eigler
2011-11-06 22:08                               ` Frank Ch. Eigler
2011-11-07  6:58                               ` Pekka Enberg
2011-11-07  6:58                                 ` Pekka Enberg
2011-11-06 19:11                           ` Paolo Bonzini
2011-11-06 19:11                             ` Paolo Bonzini
2011-11-06 19:17                             ` Pekka Enberg
2011-11-06 20:01                               ` Paolo Bonzini
2011-11-06 20:01                                 ` Paolo Bonzini
2011-11-06 20:17                                 ` Pekka Enberg
2011-11-06 20:17                                   ` Pekka Enberg
2011-11-07  8:00                                   ` Paolo Bonzini
2011-11-07  8:00                                     ` Paolo Bonzini
2011-11-07  8:09                                     ` Pekka Enberg
2011-11-07  8:09                                       ` Pekka Enberg
2011-11-07  8:20                                       ` Paolo Bonzini
2011-11-07  8:20                                         ` Paolo Bonzini
2011-11-07  8:45                                         ` Pekka Enberg
2011-11-07  8:45                                           ` Pekka Enberg
2011-11-07  8:52                                           ` Paolo Bonzini
2011-11-07  8:52                                             ` Paolo Bonzini
2011-11-07  8:57                                             ` Pekka Enberg
2011-11-07  8:57                                               ` Pekka Enberg
2011-11-07  8:13                                     ` Pekka Enberg
2011-11-07  8:13                                       ` Pekka Enberg
2011-11-06 20:31                                 ` Pekka Enberg
2011-11-06 20:31                                   ` Pekka Enberg
2011-11-07 10:23                           ` Gerd Hoffmann
2011-11-07 10:23                             ` Gerd Hoffmann
2011-11-07 10:30                             ` Sasha Levin
2011-11-07 11:02                               ` Paolo Bonzini
2011-11-07 11:02                                 ` Paolo Bonzini
2011-11-07 11:44                                 ` Pekka Enberg
2011-11-07 11:44                                   ` Pekka Enberg
2011-11-07 12:18                                   ` Gerd Hoffmann
2011-11-07 12:18                                     ` Gerd Hoffmann
2011-11-07 12:21                                     ` Pekka Enberg
2011-11-07 12:21                                       ` Pekka Enberg
2011-11-07 12:26                               ` Avi Kivity
2011-11-07 12:29                                 ` Pekka Enberg
2011-11-07 12:43                                   ` Ted Ts'o
2011-11-07 12:44                                   ` Avi Kivity
2011-11-07 11:34                             ` Pekka Enberg
2011-11-07 11:57                               ` Ingo Molnar
2011-11-07 11:57                                 ` Ingo Molnar
2011-11-07 12:08                               ` Gerd Hoffmann
2011-11-07 12:29                                 ` Ted Ts'o
2011-11-07 12:42                                   ` Pekka Enberg
2011-11-07 12:42                                   ` Pekka Enberg
2011-11-07 12:47                                     ` Ted Ts'o
2011-11-07 12:47                                       ` Ted Ts'o
2011-11-07 12:59                                       ` Pekka Enberg
2011-11-07 12:59                                       ` Pekka Enberg
2011-11-07 13:12                                       ` Pekka Enberg
2011-11-07 13:12                                       ` Pekka Enberg
2011-11-08 13:29                                         ` Karel Zak
2011-11-08 14:30                                           ` Pekka Enberg
2011-11-08 14:30                                             ` Pekka Enberg
2011-11-06 13:11                     ` Pekka Enberg
2011-11-06 13:11                       ` Pekka Enberg
2011-11-06 17:09                       ` Alexander Graf
2011-11-06 12:27             ` Pekka Enberg
2011-11-06 12:27               ` Pekka Enberg
2011-11-08 14:41 ` Avi Kivity
2011-11-08 14:52   ` Christoph Hellwig
2011-11-08 14:55     ` Sasha Levin
2011-11-08 14:55       ` Sasha Levin
2011-11-08 14:57     ` Avi Kivity
2011-11-08 14:57       ` Avi Kivity
2011-11-08 14:59       ` Christoph Hellwig
2011-11-08 17:34         ` Alexander Graf
2011-11-08 17:36           ` Avi Kivity
2011-11-08 15:04     ` Jan Kiszka
2011-11-08 15:26     ` Pekka Enberg
2011-11-08 15:26       ` Pekka Enberg
2011-11-08 15:28       ` Christoph Hellwig
2011-08-23 22:16 [PATCH] KVM: Add wrapper script around Qemu " Alexander Graf
2011-08-23 22:16 ` Alexander Graf
2011-08-24  5:19 ` Pekka Enberg
2011-08-24  5:19   ` Pekka Enberg
2011-08-24  5:31   ` Américo Wang
2011-08-24  5:31     ` Américo Wang
2011-08-24 20:35     ` Alexander Graf
2011-08-24 20:35       ` Alexander Graf
2011-08-25  3:44       ` Américo Wang
2011-08-25  3:44         ` Américo Wang
2011-11-05 23:47         ` Alexander Graf
2011-11-05 23:47           ` Alexander Graf
2011-08-24  8:25 ` Avi Kivity
2011-08-24  9:16   ` Jan Kiszka
2011-08-24 21:06     ` Alexander Graf
2011-08-24 21:06       ` Alexander Graf
2011-08-24 17:40 ` [Qemu-devel] " Blue Swirl
2011-08-24 19:17   ` Avi Kivity

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4EB6917F.3000507@web.de \
    --to=jan.kiszka@web.de \
    --cc=agraf@suse.de \
    --cc=avi@redhat.com \
    --cc=kvm@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=penberg@kernel.org \
    --cc=qemu-devel@nongnu.org \
    --cc=torvalds@linux-foundation.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.