X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=virt-what.in;h=f525a89d3c80728a160112cb00832ea2a891548c;hb=dc0c2972e178a6de9ee87501acca54447ea9c699;hp=64ab770dafab87af53c7faf315c54cc365fa9a9a;hpb=90f6be5a33a2c23fffdd86053d37b8db7ae0d6b1;p=virt-what.git diff --git a/virt-what.in b/virt-what.in index 64ab770..f525a89 100644 --- a/virt-what.in +++ b/virt-what.in @@ -194,7 +194,9 @@ fi if have_cpuinfo && grep -q '^vendor_id.*IBM/S390' "${root}/proc/cpuinfo"; then echo ibm_systemz if [ -f "${root}/proc/sysinfo" ]; then - if grep -q 'VM.*Control Program.*z/VM' "${root}/proc/sysinfo"; then + if grep -q 'VM.*Control Program.*KVM/Linux' "${root}/proc/sysinfo"; then + echo ibm_systemz-kvm + elif grep -q 'VM.*Control Program.*z/VM' "${root}/proc/sysinfo"; then echo ibm_systemz-zvm elif grep -q '^LPAR' "${root}/proc/sysinfo"; then echo ibm_systemz-lpar @@ -223,6 +225,10 @@ fi if [ "$cpuid" = "XenVMMXenVMM" ]; then echo xen; echo xen-hvm + # Check for AWS + if echo "$dmi" | grep -q 'Version: [0-9]\.[0-9]\.amazon'; then + echo aws + fi skip_qemu_kvm=true elif [ -d "${root}/proc/xen" ]; then echo xen @@ -273,6 +279,9 @@ fi if ! "$skip_qemu_kvm"; then if [ "$cpuid" = "KVMKVMKVM" ]; then echo kvm + elif [ "$cpuid" = "TCGTCGTCGTCG" ]; then + echo qemu + skip_lkvm=true elif echo "$dmi" | grep -q 'Product Name: KVM'; then echo kvm skip_lkvm=true @@ -295,10 +304,10 @@ if ! "$skip_qemu_kvm"; then echo kvm skip_lkvm=true else - # XXX This is known to fail for qemu with the explicit -cpu + # This is known to fail for qemu with the explicit -cpu # option, since /proc/cpuinfo will not contain the QEMU - # string. The long term fix for this would be to export - # another CPUID leaf for non-accelerated qemu. + # string. QEMU 2.10 added a new CPUID leaf, so this + # problem only triggered for older QEMU if grep -q 'QEMU' "${root}/proc/cpuinfo"; then echo qemu fi @@ -344,3 +353,28 @@ if [ "$arch" = "ppc64" ]; then fi fi fi + +# Check for OpenBSD/VMM +if [ "$cpuid" = "OpenBSDVMM58" ]; then + echo vmm +fi + +# Check for LDoms +if [[ "$arch" == sparc* && -e ${root}/dev/mdesc ]]; then + echo ldoms + if [[ -d ${root}/sys/class/vlds/ctrl && \ + -d ${root}/sys/class/vlds/sp ]]; then + echo ldoms-control + else + echo ldoms-guest + fi + MDPROP="${root}/usr/lib/ldoms/mdprop.py" + if [[ -x ${MDPROP} ]]; then + if [[ -n $($MDPROP -v iodevice device-type=pciex) ]]; then + echo ldoms-root + echo ldoms-io + elif [[ -n $($MDPROP -v iov-device vf-id=0) ]]; then + echo ldoms-io + fi + fi +fi