lib/ohai/plugins/solaris2/virtualization.rb in ohai-8.11.1 vs lib/ohai/plugins/solaris2/virtualization.rb in ohai-8.12.0

- old
+ new

@@ -16,10 +16,13 @@ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # +require "ohai/mixin/dmi_decode" +include Ohai::Mixin::DmiDecode + Ohai.plugin(:Virtualization) do provides "virtualization" def collect_solaris_guestid command = "/usr/sbin/zoneadm list -p" @@ -27,38 +30,32 @@ so.stdout.split(":").first end collect_data(:solaris2) do virtualization Mash.new + virtualization[:systems] = Mash.new - # Detect KVM/QEMU from cpuinfo, report as KVM + # Detect paravirt KVM/QEMU from cpuinfo, report as KVM psrinfo_path = Ohai.abs_path( "/usr/sbin/psrinfo" ) - if File.exists?(psrinfo_path) + if File.exist?(psrinfo_path) so = shell_out("#{psrinfo_path} -pv") - if so.stdout =~ /QEMU Virtual CPU/ + if so.stdout =~ /QEMU Virtual CPU|Common KVM processor|Common 32-bit KVM processor/ virtualization[:system] = "kvm" virtualization[:role] = "guest" + virtualization[:systems][:kvm] = "guest" end end - # http://www.dmo.ca/blog/detecting-virtualization-on-linux - smbios_path = Ohai.abs_path( "/usr/sbin/smbios" ) - if File.exists?(smbios_path) - so = shell_out(smbios_path) - case so.stdout - when /Manufacturer: Microsoft/ - if so.stdout =~ /Product: Virtual Machine/ - virtualization[:system] = "virtualpc" - virtualization[:role] = "guest" - end - when /Manufacturer: VMware/ - if so.stdout =~ /Product: VMware Virtual Platform/ - virtualization[:system] = "vmware" - virtualization[:role] = "guest" - end - else - nil + # Pass smbios information to the dmi_decode mixin to + # identify possible virtualization systems + smbios_path = Ohai.abs_path("/usr/sbin/smbios") + if File.exist?(smbios_path) + guest = guest_from_dmi(shell_out(smbios_path).stdout) + if guest + virtualization[:system] = guest + virtualization[:role] = "guest" + virtualization[:systems][guest.to_sym] = "guest" end end if File.executable?("/usr/sbin/zoneadm") zones = Mash.new @@ -75,18 +72,20 @@ } end if zones.length == 1 first_zone = zones.keys[0] - unless( first_zone == "global") + unless first_zone == "global" virtualization[:system] = "zone" virtualization[:role] = "guest" + virtualization[:systems][:zone] = "guest" virtualization[:guest_uuid] = zones[first_zone]["uuid"] virtualization[:guest_id] = collect_solaris_guestid end elsif zones.length > 1 virtualization[:system] = "zone" virtualization[:role] = "host" + virtualization[:systems][:zone] = "host" virtualization[:guests] = zones end end end end