Blame SOURCES/0006-Allow-using-sysctl-for-example-when-proc-isn-t-avail.patch

90b589
From d7fd8a7843030d2b1719353edfcd49dba3000122 Mon Sep 17 00:00:00 2001
90b589
From: Jasper Lievisse Adriaanse <jasper@humppa.nl>
90b589
Date: Wed, 25 Apr 2018 16:41:32 +0200
c18f13
Subject: [PATCH 06/22] Allow using sysctl, for example when /proc isn't
90b589
 available
90b589
90b589
---
90b589
 virt-what.in | 13 +++++++++++++
90b589
 1 file changed, 13 insertions(+)
90b589
90b589
diff --git a/virt-what.in b/virt-what.in
90b589
index 2011ff4..d037a99 100644
90b589
--- a/virt-what.in
90b589
+++ b/virt-what.in
90b589
@@ -38,6 +38,13 @@ have_cpuinfo () {
90b589
     test -e "${root}/proc/cpuinfo"
90b589
 }
90b589
 
90b589
+use_sysctl() {
90b589
+    # Lacking /proc, on some systems sysctl can be used instead.
90b589
+    OS=$(uname) || fail "failed to get operating system name"
90b589
+
90b589
+    [ "$OS" == "OpenBSD" ]
90b589
+}
90b589
+
90b589
 fail () {
90b589
     echo "virt-what: $1" >&2
90b589
     exit 1
90b589
@@ -304,6 +311,12 @@ if ! "$skip_qemu_kvm"; then
90b589
         # We are running as a spapr KVM guest on ppc64
90b589
         echo kvm
90b589
         skip_lkvm=true
90b589
+    elif use_sysctl; then
90b589
+        # SmartOS KVM
90b589
+        product=$(sysctl -n hw.product)
90b589
+        if echo "$product" | grep -q 'SmartDC HVM'; then
90b589
+            echo kvm
90b589
+        fi
90b589
     else
90b589
         # This is known to fail for qemu with the explicit -cpu
90b589
         # option, since /proc/cpuinfo will not contain the QEMU
90b589
-- 
c18f13
2.32.0
90b589