From 160ecd4c1e8b9663e960f0464ba9a76ea8b0d501 Mon Sep 17 00:00:00 2001 From: CentOS Sources Date: Tue, 16 May 2023 06:16:37 +0000 Subject: [PATCH] import virt-what-1.25-3.el8 --- ...arrange-lxc-test-to-avoid-use-of-cat.patch | 27 + ...ker-and-podman-tests-up-add-comments.patch | 83 ++ ...location-of-test-file-proc-1-environ.patch | 36 + SOURCES/0004-Detect-OCI-containers.patch | 888 ++++++++++++++++++ ...support-for-Alibaba-cloud-on-aarch64.patch | 371 ++++++++ SOURCES/copy-patches.sh | 2 +- SPECS/virt-what.spec | 18 +- 7 files changed, 1421 insertions(+), 4 deletions(-) create mode 100644 SOURCES/0001-Rearrange-lxc-test-to-avoid-use-of-cat.patch create mode 100644 SOURCES/0002-Move-docker-and-podman-tests-up-add-comments.patch create mode 100644 SOURCES/0003-podman-Fix-location-of-test-file-proc-1-environ.patch create mode 100644 SOURCES/0004-Detect-OCI-containers.patch create mode 100644 SOURCES/0005-Add-support-for-Alibaba-cloud-on-aarch64.patch diff --git a/SOURCES/0001-Rearrange-lxc-test-to-avoid-use-of-cat.patch b/SOURCES/0001-Rearrange-lxc-test-to-avoid-use-of-cat.patch new file mode 100644 index 0000000..4446201 --- /dev/null +++ b/SOURCES/0001-Rearrange-lxc-test-to-avoid-use-of-cat.patch @@ -0,0 +1,27 @@ +From a29d4a5632ff9f60f939e4f0f36ce97ed43c5650 Mon Sep 17 00:00:00 2001 +From: "Richard W.M. Jones" +Date: Thu, 22 Dec 2022 10:31:47 +0000 +Subject: [PATCH] Rearrange lxc test to avoid use of cat + +Thanks: Elias Probst +--- + virt-what.in | 3 ++- + 1 file changed, 2 insertions(+), 1 deletion(-) + +diff --git a/virt-what.in b/virt-what.in +index d090898e5..170bc24ab 100644 +--- a/virt-what.in ++++ b/virt-what.in +@@ -175,7 +175,8 @@ fi + # Added by Marc Fournier + + if [ -e "${root}/proc/1/environ" ] && +- cat "${root}/proc/1/environ" | tr '\000' '\n' | grep -Eiq '^container=lxc'; then ++ tr '\000' '\n' < "${root}/proc/1/environ" | ++ grep -Eiq '^container=lxc'; then + echo lxc + fi + +-- +2.31.1 + diff --git a/SOURCES/0002-Move-docker-and-podman-tests-up-add-comments.patch b/SOURCES/0002-Move-docker-and-podman-tests-up-add-comments.patch new file mode 100644 index 0000000..10b115c --- /dev/null +++ b/SOURCES/0002-Move-docker-and-podman-tests-up-add-comments.patch @@ -0,0 +1,83 @@ +From 57966df6adddbebc4f4a6b9db7680d99344b0b1c Mon Sep 17 00:00:00 2001 +From: "Richard W.M. Jones" +Date: Thu, 22 Dec 2022 10:34:03 +0000 +Subject: [PATCH] Move docker and podman tests up, add comments + +Refactor to bring related tests closer together and make the comments +more uniform. +--- + virt-what.in | 31 +++++++++++++++---------------- + 1 file changed, 15 insertions(+), 16 deletions(-) + +diff --git a/virt-what.in b/virt-what.in +index 170bc24ab..c6e4a1e00 100644 +--- a/virt-what.in ++++ b/virt-what.in +@@ -165,7 +165,6 @@ fi + # /proc/vz - always exists if OpenVZ kernel is running (inside and outside + # container) + # /proc/bc - exists on node, but not inside container. +- + if [ -d "${root}/proc/vz" -a ! -d "${root}/proc/bc" ]; then + echo openvz + fi +@@ -173,13 +172,13 @@ fi + # Check for LXC containers + # http://www.freedesktop.org/wiki/Software/systemd/ContainerInterface + # Added by Marc Fournier +- + if [ -e "${root}/proc/1/environ" ] && + tr '\000' '\n' < "${root}/proc/1/environ" | + grep -Eiq '^container=lxc'; then + echo lxc + fi + ++# Check for Illumos LX + if [ -e "${root}/proc/1/environ" ] && + tr '\0' '\n' < "${root}/proc/1/environ" | grep -q '^container=zone$' && + [ -e "${root}/proc/version" ] && +@@ -187,6 +186,20 @@ if [ -e "${root}/proc/1/environ" ] && + echo illumos-lx + fi + ++# Check for Docker. ++if [ -f "${root}/.dockerenv" ] || [ -f "${root}/.dockerinit" ] || \ ++ grep -qF /docker/ "${root}/proc/self/cgroup" 2>/dev/null; then ++ echo docker ++fi ++ ++# Check for Podman. ++if [ -e "${root}/proc/1/environ" ] && ++ cat "${root}/proc/1/environ" | tr '\000' '\n' | grep -Eiq '^container=podman'; then ++ echo podman ++elif grep -qF /libpod- "${root}/proc/self/cgroup" 2>/dev/null; then ++ echo podman ++fi ++ + # Check for Linux-VServer + if test -e "${root}/proc/self/status" \ + && cat "${root}/proc/self/status" | grep -q "VxID: [0-9]*"; then +@@ -381,20 +394,6 @@ if ! "$skip_lkvm"; then + fi + fi + +-# Check for Docker. +-if [ -f "${root}/.dockerenv" ] || [ -f "${root}/.dockerinit" ] || \ +- grep -qF /docker/ "${root}/proc/self/cgroup" 2>/dev/null; then +- echo docker +-fi +- +-# Check for Podman. +-if [ -e "${root}/proc/1/environ" ] && +- cat "${root}/proc/1/environ" | tr '\000' '\n' | grep -Eiq '^container=podman'; then +- echo podman +-elif grep -qF /libpod- "${root}/proc/self/cgroup" 2>/dev/null; then +- echo podman +-fi +- + # Check ppc64 lpar, kvm or powerkvm + + # example /proc/cpuinfo line indicating 'not baremetal' +-- +2.31.1 + diff --git a/SOURCES/0003-podman-Fix-location-of-test-file-proc-1-environ.patch b/SOURCES/0003-podman-Fix-location-of-test-file-proc-1-environ.patch new file mode 100644 index 0000000..2ddd094 --- /dev/null +++ b/SOURCES/0003-podman-Fix-location-of-test-file-proc-1-environ.patch @@ -0,0 +1,36 @@ +From 1cbcbb801c86f8f791ecd930c4ac311f034e3e1a Mon Sep 17 00:00:00 2001 +From: "Richard W.M. Jones" +Date: Thu, 5 Jan 2023 12:48:55 +0000 +Subject: [PATCH] podman: Fix location of test file /proc/1/environ + +Since it was at the wrong location, the file was not even used by the +test. + +Fixes: commit 1df728aa4b ("Add podman support") +--- + tests/podman/Makefile.am | 2 +- + tests/podman/{ => proc}/1/environ | Bin + 2 files changed, 1 insertion(+), 1 deletion(-) + rename tests/podman/{ => proc}/1/environ (100%) + +diff --git a/tests/podman/Makefile.am b/tests/podman/Makefile.am +index 2962f3237..1745ef6c6 100644 +--- a/tests/podman/Makefile.am ++++ b/tests/podman/Makefile.am +@@ -20,8 +20,8 @@ CLEANFILES = *~ + TESTS = test.sh + + EXTRA_DIST = \ +- 1/environ \ + test.sh \ ++ proc/1/environ \ + proc/cpuinfo \ + proc/self/cgroup \ + proc/self/status \ +diff --git a/tests/podman/1/environ b/tests/podman/proc/1/environ +similarity index 100% +rename from tests/podman/1/environ +rename to tests/podman/proc/1/environ +-- +2.31.1 + diff --git a/SOURCES/0004-Detect-OCI-containers.patch b/SOURCES/0004-Detect-OCI-containers.patch new file mode 100644 index 0000000..f8e9a57 --- /dev/null +++ b/SOURCES/0004-Detect-OCI-containers.patch @@ -0,0 +1,888 @@ +From 54c2ad4a764658ec8a9aadc52c749eabf1de73a0 Mon Sep 17 00:00:00 2001 +From: "Richard W.M. Jones" +Date: Thu, 5 Jan 2023 12:34:02 +0000 +Subject: [PATCH] Detect OCI containers + +Podman using OCI containers sets container=oci in PID 1's environment. +Detect that and print "oci" fact. + +This patch was originally contributed by Alessandro Valentini. I +modified it and added tests and documentation. + +Reported-by: Alessandro Valentini +Fixes: https://bugzilla.redhat.com/show_bug.cgi?id=2155233 +--- + configure.ac | 2 + + tests/oci/Makefile.am | 28 ++ + tests/oci/proc/1/environ | Bin 0 -> 124 bytes + tests/oci/proc/cpuinfo | 671 ++++++++++++++++++++++++++ + tests/oci/sbin/dmidecode | 7 + + tests/oci/sbin/uname | 2 + + tests/oci/sbin/virt-what-cpuid-helper | 2 + + tests/oci/test.sh | 32 ++ + virt-what.in | 6 + + virt-what.pod | 8 +- + 10 files changed, 757 insertions(+), 1 deletion(-) + create mode 100644 tests/oci/Makefile.am + create mode 100644 tests/oci/proc/1/environ + create mode 100644 tests/oci/proc/cpuinfo + create mode 100755 tests/oci/sbin/dmidecode + create mode 100755 tests/oci/sbin/uname + create mode 100755 tests/oci/sbin/virt-what-cpuid-helper + create mode 100755 tests/oci/test.sh + +diff --git a/configure.ac b/configure.ac +index 8f808a38b..a80a4b6f0 100644 +--- a/configure.ac ++++ b/configure.ac +@@ -56,6 +56,7 @@ tests="\ + lx86 \ + lxc \ + nutanix-ahv \ ++ oci \ + parallels-desktop \ + podman \ + ppc64-baremetal \ +@@ -104,6 +105,7 @@ AC_CONFIG_FILES([Makefile + tests/lx86/Makefile + tests/lxc/Makefile + tests/nutanix-ahv/Makefile ++ tests/oci/Makefile + tests/parallels-desktop/Makefile + tests/podman/Makefile + tests/ppc64-baremetal/Makefile +diff --git a/tests/oci/Makefile.am b/tests/oci/Makefile.am +new file mode 100644 +index 000000000..b2f6f2469 +--- /dev/null ++++ b/tests/oci/Makefile.am +@@ -0,0 +1,28 @@ ++# Makefile for virt-what ++# Copyright (C) 2008-2023 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 ++# the Free Software Foundation; either version 2 of the License, or ++# (at your option) any later version. ++# ++# This program is distributed in the hope that it will be useful, ++# but WITHOUT ANY WARRANTY; without even the implied warranty of ++# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++# GNU General Public License for more details. ++# ++# You should have received a copy of the GNU General Public License ++# along with this program; if not, write to the Free Software ++# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ ++CLEANFILES = *~ ++ ++TESTS = test.sh ++ ++EXTRA_DIST = \ ++ test.sh \ ++ proc/1/environ \ ++ proc/cpuinfo \ ++ sbin/dmidecode \ ++ sbin/uname \ ++ sbin/virt-what-cpuid-helper +diff --git a/tests/oci/proc/1/environ b/tests/oci/proc/1/environ +new file mode 100644 +index 0000000000000000000000000000000000000000..03d40a45377eaeccef15532734d2f5b7fd42234e +GIT binary patch +literal 124 +zcmWG=4DqnlFD)+8&&f|t%+W7S%FMGu;={QJ39t}^3uH2cxCZ&!R+OX` ++ ++The guest is running in an OCI container. ++ ++Status: contributed by Alessandro Valentini, confirmed by RWMJ ++ + =item B + + The guest appears to be running inside an OpenVZ or Virtuozzo +@@ -226,7 +232,7 @@ Status: contributed by Justin Clift + + =item B + +-This is a Podman container. ++This is a Podman container. (See also C above.) + + Status: contributed by Jordan Webb + +-- +2.31.1 + diff --git a/SOURCES/0005-Add-support-for-Alibaba-cloud-on-aarch64.patch b/SOURCES/0005-Add-support-for-Alibaba-cloud-on-aarch64.patch new file mode 100644 index 0000000..6f2e762 --- /dev/null +++ b/SOURCES/0005-Add-support-for-Alibaba-cloud-on-aarch64.patch @@ -0,0 +1,371 @@ +From 04b504c47e0dc43c82b0d413a253d0599ce83321 Mon Sep 17 00:00:00 2001 +From: Yongkui Guo +Date: Mon, 30 Jan 2023 18:20:32 +0800 +Subject: [PATCH] Add support for Alibaba cloud on aarch64 + +This assumes you are running RHEL or another tenant which supports +ACPI. It probably won't work for guests using device tree. + +Also we assume that the hypervisor is KVM. Since the hypervisor +indicates that it is RHEL 7, this is very likely to be true, but hard +to prove since there is no CPUID on Arm. + +Fixes: https://bugzilla.redhat.com/show_bug.cgi?id=2165285 +(cherry picked from commit 805604762468b754ea60e5dc176fa26f68d211b8) +--- + configure.ac | 2 + + tests/alibaba-cloud-arm/Makefile.am | 28 +++++ + tests/alibaba-cloud-arm/proc/cpuinfo | 18 +++ + tests/alibaba-cloud-arm/proc/self/status | 57 +++++++++ + tests/alibaba-cloud-arm/sbin/dmidecode | 116 ++++++++++++++++++ + tests/alibaba-cloud-arm/sbin/uname | 2 + + .../sbin/virt-what-cpuid-helper | 3 + + tests/alibaba-cloud-arm/test.sh | 33 +++++ + virt-what.in | 5 + + 9 files changed, 264 insertions(+) + create mode 100644 tests/alibaba-cloud-arm/Makefile.am + create mode 100644 tests/alibaba-cloud-arm/proc/cpuinfo + create mode 100644 tests/alibaba-cloud-arm/proc/self/status + create mode 100755 tests/alibaba-cloud-arm/sbin/dmidecode + create mode 100755 tests/alibaba-cloud-arm/sbin/uname + create mode 100755 tests/alibaba-cloud-arm/sbin/virt-what-cpuid-helper + create mode 100755 tests/alibaba-cloud-arm/test.sh + +diff --git a/configure.ac b/configure.ac +index a80a4b6f0..cfb7ca371 100644 +--- a/configure.ac ++++ b/configure.ac +@@ -34,6 +34,7 @@ AM_CONDITIONAL([HOST_CPU_IA64], [ test "x$host_cpu" = "xia64" ]) + + dnl List of tests. + tests="\ ++ alibaba-cloud-arm \ + alibaba-cloud-x86 \ + aws-baremetal-x86 \ + aws-kvm-arm \ +@@ -83,6 +84,7 @@ AC_CONFIG_HEADERS([config.h]) + AC_CONFIG_FILES([virt-what],[chmod +x virt-what]) + AC_CONFIG_FILES([Makefile + tests/Makefile ++ tests/alibaba-cloud-arm/Makefile + tests/alibaba-cloud-x86/Makefile + tests/aws-baremetal-x86/Makefile + tests/aws-kvm-arm/Makefile +diff --git a/tests/alibaba-cloud-arm/Makefile.am b/tests/alibaba-cloud-arm/Makefile.am +new file mode 100644 +index 000000000..09ce07861 +--- /dev/null ++++ b/tests/alibaba-cloud-arm/Makefile.am +@@ -0,0 +1,28 @@ ++# Makefile for virt-what ++# Copyright (C) 2008-2023 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 ++# the Free Software Foundation; either version 2 of the License, or ++# (at your option) any later version. ++# ++# This program is distributed in the hope that it will be useful, ++# but WITHOUT ANY WARRANTY; without even the implied warranty of ++# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++# GNU General Public License for more details. ++# ++# You should have received a copy of the GNU General Public License ++# along with this program; if not, write to the Free Software ++# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ ++CLEANFILES = *~ ++ ++TESTS = test.sh ++ ++EXTRA_DIST = \ ++ test.sh \ ++ proc/cpuinfo \ ++ proc/self/status \ ++ sbin/dmidecode \ ++ sbin/uname \ ++ sbin/virt-what-cpuid-helper +diff --git a/tests/alibaba-cloud-arm/proc/cpuinfo b/tests/alibaba-cloud-arm/proc/cpuinfo +new file mode 100644 +index 000000000..03dbb22ab +--- /dev/null ++++ b/tests/alibaba-cloud-arm/proc/cpuinfo +@@ -0,0 +1,18 @@ ++processor : 0 ++BogoMIPS : 50.00 ++Features : fp asimd evtstrm aes pmull sha1 sha2 crc32 atomics fphp asimdhp cpuid asimdrdm lrcpc dcpop asimddp ssbs ++CPU implementer : 0x41 ++CPU architecture: 8 ++CPU variant : 0x3 ++CPU part : 0xd0c ++CPU revision : 1 ++ ++processor : 1 ++BogoMIPS : 50.00 ++Features : fp asimd evtstrm aes pmull sha1 sha2 crc32 atomics fphp asimdhp cpuid asimdrdm lrcpc dcpop asimddp ssbs ++CPU implementer : 0x41 ++CPU architecture: 8 ++CPU variant : 0x3 ++CPU part : 0xd0c ++CPU revision : 1 ++ +diff --git a/tests/alibaba-cloud-arm/proc/self/status b/tests/alibaba-cloud-arm/proc/self/status +new file mode 100644 +index 000000000..08c63e9cb +--- /dev/null ++++ b/tests/alibaba-cloud-arm/proc/self/status +@@ -0,0 +1,57 @@ ++Name: cat ++Umask: 0022 ++State: R (running) ++Tgid: 6341 ++Ngid: 0 ++Pid: 6341 ++PPid: 1588 ++TracerPid: 0 ++Uid: 0 0 0 0 ++Gid: 0 0 0 0 ++FDSize: 256 ++Groups: 0 ++NStgid: 6341 ++NSpid: 6341 ++NSpgid: 6341 ++NSsid: 1588 ++VmPeak: 2352 kB ++VmSize: 2352 kB ++VmLck: 0 kB ++VmPin: 0 kB ++VmHWM: 768 kB ++VmRSS: 768 kB ++RssAnon: 80 kB ++RssFile: 688 kB ++RssShmem: 0 kB ++VmData: 348 kB ++VmStk: 132 kB ++VmExe: 24 kB ++VmLib: 1728 kB ++VmPTE: 44 kB ++VmSwap: 0 kB ++HugetlbPages: 0 kB ++CoreDumping: 0 ++THP_enabled: 1 ++Threads: 1 ++SigQ: 0/29002 ++SigPnd: 0000000000000000 ++ShdPnd: 0000000000000000 ++SigBlk: 0000000000000000 ++SigIgn: 0000000000000000 ++SigCgt: 0000000000000000 ++CapInh: 0000000000000000 ++CapPrm: 000001ffffffffff ++CapEff: 000001ffffffffff ++CapBnd: 000001ffffffffff ++CapAmb: 0000000000000000 ++NoNewPrivs: 0 ++Seccomp: 0 ++Seccomp_filters: 0 ++Speculation_Store_Bypass: thread vulnerable ++SpeculationIndirectBranch: unknown ++Cpus_allowed: 3 ++Cpus_allowed_list: 0-1 ++Mems_allowed: 00000000,00000001 ++Mems_allowed_list: 0 ++voluntary_ctxt_switches: 0 ++nonvoluntary_ctxt_switches: 0 +diff --git a/tests/alibaba-cloud-arm/sbin/dmidecode b/tests/alibaba-cloud-arm/sbin/dmidecode +new file mode 100755 +index 000000000..89fa9a34b +--- /dev/null ++++ b/tests/alibaba-cloud-arm/sbin/dmidecode +@@ -0,0 +1,116 @@ ++#!/bin/sh - ++cat <<'EOF' ++# dmidecode 3.3 ++Getting SMBIOS data from sysfs. ++SMBIOS 3.0.0 present. ++Table at 0x2348C0000. ++ ++Handle 0x0100, DMI type 1, 27 bytes ++System Information ++ Manufacturer: Alibaba Cloud ++ Product Name: Alibaba Cloud ECS ++ Version: virt-rhel7.6.0 ++ Serial Number: 8c43355a-242e-42c2-bdf7-9fae99316221 ++ UUID: 8c43355a-242e-42c2-bdf7-9fae99316221 ++ Wake-up Type: Power Switch ++ SKU Number: Not Specified ++ Family: Red Hat Enterprise Linux ++ ++Handle 0x0300, DMI type 3, 21 bytes ++Chassis Information ++ Manufacturer: Alibaba Cloud ++ Type: Other ++ Lock: Not Present ++ Version: virt-rhel7.6.0 ++ Serial Number: Not Specified ++ Asset Tag: Not Specified ++ Boot-up State: Safe ++ Power Supply State: Safe ++ Thermal State: Safe ++ Security Status: Unknown ++ OEM Information: 0x00000000 ++ Height: Unspecified ++ Number Of Power Cords: Unspecified ++ Contained Elements: 0 ++ ++Handle 0x0400, DMI type 4, 42 bytes ++Processor Information ++ Socket Designation: CPU 0 ++ Type: Central Processor ++ Family: Other ++ Manufacturer: Alibaba Cloud ++ ID: 00 00 00 00 00 00 00 00 ++ Version: virt-rhel7.6.0 ++ Voltage: Unknown ++ External Clock: Unknown ++ Max Speed: 2000 MHz ++ Current Speed: 2000 MHz ++ Status: Populated, Enabled ++ Upgrade: Other ++ L1 Cache Handle: Not Provided ++ L2 Cache Handle: Not Provided ++ L3 Cache Handle: Not Provided ++ Serial Number: Not Specified ++ Asset Tag: Not Specified ++ Part Number: Not Specified ++ Core Count: 2 ++ Core Enabled: 2 ++ Thread Count: 1 ++ Characteristics: None ++ ++Handle 0x1000, DMI type 16, 23 bytes ++Physical Memory Array ++ Location: Other ++ Use: System Memory ++ Error Correction Type: Multi-bit ECC ++ Maximum Capacity: 8 GB ++ Error Information Handle: Not Provided ++ Number Of Devices: 1 ++ ++Handle 0x1100, DMI type 17, 40 bytes ++Memory Device ++ Array Handle: 0x1000 ++ Error Information Handle: Not Provided ++ Total Width: Unknown ++ Data Width: Unknown ++ Size: 8 GB ++ Form Factor: DIMM ++ Set: None ++ Locator: DIMM 0 ++ Bank Locator: Not Specified ++ Type: RAM ++ Type Detail: Other ++ Speed: Unknown ++ Manufacturer: Alibaba Cloud ++ Serial Number: Not Specified ++ Asset Tag: Not Specified ++ Part Number: Not Specified ++ Rank: Unknown ++ Configured Memory Speed: Unknown ++ Minimum Voltage: Unknown ++ Maximum Voltage: Unknown ++ Configured Voltage: Unknown ++ ++Handle 0x2000, DMI type 32, 11 bytes ++System Boot Information ++ Status: No errors detected ++ ++Handle 0x0000, DMI type 0, 26 bytes ++BIOS Information ++ Vendor: EFI Development Kit II / OVMF ++ Version: 0.0.0 ++ Release Date: 02/06/2015 ++ Address: 0xE8000 ++ Runtime Size: 96 kB ++ ROM Size: 64 kB ++ Characteristics: ++ BIOS characteristics not supported ++ Targeted content distribution is supported ++ UEFI is supported ++ System is a virtual machine ++ BIOS Revision: 0.0 ++ ++Handle 0xFEFF, DMI type 127, 4 bytes ++End Of Table ++ ++EOF +diff --git a/tests/alibaba-cloud-arm/sbin/uname b/tests/alibaba-cloud-arm/sbin/uname +new file mode 100755 +index 000000000..bd33a2d73 +--- /dev/null ++++ b/tests/alibaba-cloud-arm/sbin/uname +@@ -0,0 +1,2 @@ ++#!/bin/sh - ++echo aarch64 +diff --git a/tests/alibaba-cloud-arm/sbin/virt-what-cpuid-helper b/tests/alibaba-cloud-arm/sbin/virt-what-cpuid-helper +new file mode 100755 +index 000000000..08e293436 +--- /dev/null ++++ b/tests/alibaba-cloud-arm/sbin/virt-what-cpuid-helper +@@ -0,0 +1,3 @@ ++#!/bin/sh - ++# Arm, so no cpuid. ++# No output, exits with 0. +diff --git a/tests/alibaba-cloud-arm/test.sh b/tests/alibaba-cloud-arm/test.sh +new file mode 100755 +index 000000000..1e7360931 +--- /dev/null ++++ b/tests/alibaba-cloud-arm/test.sh +@@ -0,0 +1,33 @@ ++# Test for Alibaba Cloud ++# Copyright (C) 2018-2023 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 ++# the Free Software Foundation; either version 2 of the License, or ++# (at your option) any later version. ++# ++# This program is distributed in the hope that it will be useful, ++# but WITHOUT ANY WARRANTY; without even the implied warranty of ++# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++# GNU General Public License for more details. ++# ++# You should have received a copy of the GNU General Public License ++# along with this program; if not, write to the Free Software ++# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ ++output="$(PATH=../..:$PATH virt-what --test-root=. 2>&1)" ++expected="alibaba_cloud ++kvm" ++ ++if [ "$output" != "$expected" ]; then ++ echo "$0: test failed because output did not match expected" ++ echo "Expected output was:" ++ echo "----------------------------------------" ++ echo "$expected" ++ echo "----------------------------------------" ++ echo "But the actual output of the program was:" ++ echo "----------------------------------------" ++ echo "$output" ++ echo "----------------------------------------" ++ exit 1 ++fi +diff --git a/virt-what.in b/virt-what.in +index 102e23f67..fbf8c54c5 100644 +--- a/virt-what.in ++++ b/virt-what.in +@@ -354,6 +354,11 @@ if ! "$skip_qemu_kvm"; then + # This is for AWS Graviton (Arm) systems which don't have CPUID. + echo kvm + skip_lkvm=true ++ elif echo "$dmi" | grep -q 'Manufacturer: Alibaba Cloud' && ++ echo "$dmi" | grep -q 'System is a virtual machine'; then ++ # This is for Alibaba Arm systems which don't have CPUID. ++ echo kvm ++ skip_lkvm=true + elif echo "$dmi" | grep -q 'Manufacturer: QEMU'; then + # The test for KVM above failed, so now we know we're + # not using KVM acceleration. +-- +2.31.1 + diff --git a/SOURCES/copy-patches.sh b/SOURCES/copy-patches.sh index f9f4479..25823fe 100755 --- a/SOURCES/copy-patches.sh +++ b/SOURCES/copy-patches.sh @@ -8,7 +8,7 @@ set -e # ./copy-patches.sh project=virt-what -rhel_version=8.7 +rhel_version=8.8 # Check we're in the right directory. if [ ! -f $project.spec ]; then diff --git a/SPECS/virt-what.spec b/SPECS/virt-what.spec index 7ec0c70..d146afc 100644 --- a/SPECS/virt-what.spec +++ b/SPECS/virt-what.spec @@ -1,6 +1,6 @@ Name: virt-what Version: 1.25 -Release: 1%{?dist} +Release: 3%{?dist} Summary: Detect if we are running in a virtual machine License: GPLv2+ @@ -11,10 +11,14 @@ Source0: http://people.redhat.com/~rjones/virt-what/files/%{name}-%{versi Source1: copy-patches.sh # Patches are maintained in the following repository: -# http://git.annexia.org/?p=virt-what.git;a=shortlog;h=refs/heads/rhel-8.7 +# http://git.annexia.org/?p=virt-what.git;a=shortlog;h=refs/heads/rhel-8.8 # Patches. -#(no patches) +Patch0001: 0001-Rearrange-lxc-test-to-avoid-use-of-cat.patch +Patch0002: 0002-Move-docker-and-podman-tests-up-add-comments.patch +Patch0003: 0003-podman-Fix-location-of-test-file-proc-1-environ.patch +Patch0004: 0004-Detect-OCI-containers.patch +Patch0005: 0005-Add-support-for-Alibaba-cloud-on-aarch64.patch BuildRequires: make BuildRequires: git @@ -121,6 +125,14 @@ fi %changelog +* Mon Jan 30 2023 Richard W.M. Jones - 1.25-3 +- Add support for Alibaba cloud on aarch64 + resolves: rhbz#2165518 + +* Thu Jan 05 2023 Richard W.M. Jones - 1.25-2 +- Add support for OCI containers + resolves: rhbz#2155233 + * Wed Aug 17 2022 Richard W.M. Jones - 1.25-1 - Rebase to 1.25 resolves: rhbz#2118195