X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=virt-what.in;h=a5ed33ef3e4bfa3281c9589eccac4d92dff1babe;hb=87d670b4c8b4e4e0cc314736562a9a6612d555ef;hp=ed08daefa291a28223dd95f7d18c541103469488;hpb=18d21a55c9551b76f0cdb93cd8e7b127173f083b;p=virt-what.git diff --git a/virt-what.in b/virt-what.in index ed08dae..a5ed33e 100644 --- a/virt-what.in +++ b/virt-what.in @@ -103,7 +103,7 @@ dmi=$(LANG=C dmidecode 2>&1) # Architecture. # Note for the purpose of testing, we only call uname with -p option. -arch=$(uname -p) +arch=$(uname -p | sed -e 's/i.86/i386/' | sed -e 's/arm.*/arm/') # Check for VMware. # cpuid check added by Chetan Loke. @@ -223,6 +223,13 @@ elif [ -f "${root}/sys/hypervisor/type" ] && # enough information at present to tell whether this is dom0 # or domU. XXX echo xen +elif [ "$arch" = "arm" ] || [ "$arch" = "aarch64" ]; then + if [ -d "${root}/proc/device-tree/hypervisor" ] && + grep -q "xen" "${root}/proc/device-tree/hypervisor/compatible"; then + echo xen + skip_qemu_kvm=true + skip_lkvm=true + fi elif [ "$arch" = "ia64" ]; then if [ -d "${root}/sys/bus/xen" -a ! -d "${root}/sys/bus/xen-backend" ]; then # PV-on-HVM drivers installed in a Xen guest. @@ -250,6 +257,14 @@ fi if ! "$skip_qemu_kvm"; then if [ "$cpuid" = "KVMKVMKVM" ]; then echo kvm + elif [ "$arch" = "arm" ] || [ "$arch" = "aarch64" ]; then + if [ -d "${root}/proc/device-tree" ] && + ls "${root}/proc/device-tree" | grep -q "fw-cfg"; then + # We don't have enough information to determine if we're + # using KVM acceleration or not. + echo qemu + skip_lkvm=true + fi else # XXX This is known to fail for qemu with the explicit -cpu # option, since /proc/cpuinfo will not contain the QEMU @@ -264,6 +279,11 @@ fi if ! "$skip_lkvm"; then if [ "$cpuid" = "LKVMLKVMLKVM" ]; then echo lkvm + elif [ "$arch" = "arm" ] || [ "$arch" = "aarch64" ]; then + if [ -d "${root}/proc/device-tree" ] && + grep -q "dummy-virt" "${root}/proc/device-tree/compatible"; then + echo lkvm + fi fi fi