X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=virt-what.in;h=f6854611baad9ffe330acd8719a5a7d6dd153113;hb=e52beb21195b9e5c6c5b00974848f325cee38193;hp=39afedb80c006121602f95809c7f257fdb079d69;hpb=50153230d19401fe47fcfd19d7ca0a2623c1ff09;p=virt-what.git diff --git a/virt-what.in b/virt-what.in index 39afedb..f685461 100644 --- a/virt-what.in +++ b/virt-what.in @@ -1,6 +1,6 @@ #!/bin/sh - # @configure_input@ -# Copyright (C) 2008-2015 Red Hat Inc. +# Copyright (C) 2008-2017 Red Hat Inc. # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -38,6 +38,13 @@ have_cpuinfo () { test -e "${root}/proc/cpuinfo" } +use_sysctl() { + # Lacking /proc, on some systems sysctl can be used instead. + OS=$(uname) || fail "failed to get operating system name" + + [ "$OS" = "OpenBSD" ] +} + fail () { echo "virt-what: $1" >&2 exit 1 @@ -74,6 +81,7 @@ test $# -gt 0 && fail "extra operand '$1'" prefix=@prefix@ exec_prefix=@exec_prefix@ PATH="${root}@libexecdir@:${root}/sbin:${root}/usr/sbin:${PATH}" +export PATH # Check we're running as root. EFFUID=$(id -u) || fail "failed to get current user id" @@ -101,9 +109,9 @@ cpuid=$(virt-what-cpuid-helper) dmi=$(LANG=C dmidecode 2>&1) # Architecture. -# Note for the purpose of testing, we only call uname with -p option. +# Note for the purpose of testing, we only call uname with -m option. -arch=$(uname -p | sed -e 's/i.86/i386/' | sed -e 's/arm.*/arm/') +arch=$(uname -m | sed -e 's/i.86/i386/' | sed -e 's/arm.*/arm/') # Check for VMware. # cpuid check added by Chetan Loke. @@ -193,7 +201,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 @@ -220,7 +230,8 @@ fi # Check for Xen. -if [ "$cpuid" = "XenVMMXenVMM" ]; then +if [ "$cpuid" = "XenVMMXenVMM" ] && + ! echo "$dmi" | grep -q 'No SMBIOS nor DMI entry point found, sorry'; then echo xen; echo xen-hvm skip_qemu_kvm=true elif [ -d "${root}/proc/xen" ]; then @@ -272,6 +283,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 @@ -288,17 +302,23 @@ if ! "$skip_qemu_kvm"; then echo qemu skip_lkvm=true fi - elif [ -d /proc/device-tree/hypervisor ] && + elif [ -d ${root}/proc/device-tree/hypervisor ] && grep -q "linux,kvm" /proc/device-tree/hypervisor/compatible; then # We are running as a spapr KVM guest on ppc64 echo kvm skip_lkvm=true + elif use_sysctl; then + # SmartOS KVM + product=$(sysctl -n hw.product) + if echo "$product" | grep -q 'SmartDC HVM'; then + echo kvm + fi 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. - if grep -q 'QEMU' "${root}/proc/cpuinfo"; then + # string. QEMU 2.10 added a new CPUID leaf, so this + # problem only triggered for older QEMU + if have_cpuinfo && grep -q 'QEMU' "${root}/proc/cpuinfo"; then echo qemu fi fi @@ -328,7 +348,7 @@ fi # example /proc/ppc64/lparcfg systemtype line # system_type=IBM pSeries (emulated by qemu) -if [ "$arch" = "ppc64" ]; then +if [ "$arch" = "ppc64" ] || [ "$arch" = "ppc64le" ] ; then if have_cpuinfo && grep -q 'platform.**pSeries' "${root}/proc/cpuinfo"; then if grep -q 'model.*emulated by qemu' "${root}/proc/cpuinfo"; then echo ibm_power-kvm @@ -343,3 +363,37 @@ if [ "$arch" = "ppc64" ]; then fi fi fi + +# Check for OpenBSD/VMM +if [ "$cpuid" = "OpenBSDVMM58" ]; then + echo vmm +fi + +# Check for LDoms +if [ "${arch#sparc}" != "$arch" ] && [ -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 + +# Check for AWS. +# AWS on Xen. +if echo "$dmi" | grep -q 'Version: [0-9]\.[0-9]\.amazon'; then + echo aws +# AWS on baremetal or KVM. +elif echo "$dmi" | grep -q 'Vendor: Amazon EC2'; then + echo aws +fi