Gerd Hoffmann
2d8c17a9b6
OvmfPkg/PlatformCI: Boot OVMF in SMP mode.
...
Increase the chance that CI finds bugs in MP changes.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com >
(cherry picked from commit f92a9dce10
)
Reapplying, since the CI (Windows and Linux) use Qemu 8 now, which works
with SMP again.
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4324
Signed-off-by: Oliver Steffen <osteffen@redhat.com >
[ardb: use single-threaded TCG for SMM]
2023-08-04 16:36:04 +02:00
Oliver Steffen
bae848ee25
OvmfPkg/PlatformCI VS2019: Disable workaround for cpuhp bugfix
...
This reverts commit 3beb8c9654
.
Both Windows and Linux CI jobs are now using Qemu 8, this workaround is
no longer needed.
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4324
Signed-off-by: Oliver Steffen <osteffen@redhat.com >
Reviewed-by: Laszlo Ersek <lersek@redhat.com >
Reviewed-by: Michael Kubacki <michael.kubacki@microsoft.com >
2023-08-04 16:36:04 +02:00
Oliver Steffen
744c42bfd8
OvmfPkg/PlatformCI: Use recent Qemu on Windows
...
Bump the version of the Qemu chocolatey package up to 2023.7.25.
The Linux CI is already using Qemu 8.
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4324
Signed-off-by: Oliver Steffen <osteffen@redhat.com >
Reviewed-by: Laszlo Ersek <lersek@redhat.com >
Reviewed-by: Michael Kubacki <michael.kubacki@microsoft.com >
2023-08-04 16:36:04 +02:00
Yi Li
af8859bce2
OvmfPkg/PlatformCI: Skip GCC5_OVMF_IA32X64_FULL_NOOPT build
...
The effect of LTO is limited with optimization turned off, and blocked
the upgrade of Openssl3.0. We already skipped this build with VS2019,
skip the GCC NOOPT build also.
Signed-off-by: Yi Li <yi1.li@intel.com >
Cc: Ard Biesheuvel <ardb+tianocore@kernel.org >
Cc: Jiewen Yao <jiewen.yao@intel.com >
Cc: Jordan Justen <jordan.l.justen@intel.com >
Cc: Gerd Hoffmann <kraxel@redhat.com >
Acked-by: Gerd Hoffmann <kraxel@redhat.com >
Reviewed-by: Jiewen Yao <jiewen.yao@intel.com >
2023-07-05 08:39:36 +00:00
Michael Kubacki
66f4b1b0d2
OvmfPkg/CI: Revert SMP mode
...
This is causing excessive boot times in the VS2019 IA32/X64 Full
run to shell tasks (> 2 minutes) and blocking all edk2 CI.
This patch removes the change so it can be root caused separately
without blocking other patches unrelated to OVMF.
Reverts f92a9dce10
Cc: Ard Biesheuvel <ardb+tianocore@kernel.org >
Cc: Jiewen Yao <jiewen.yao@intel.com >
Cc: Jordan Justen <jordan.l.justen@intel.com >
Cc: Gerd Hoffmann <kraxel@redhat.com >
Cc: Michael D Kinney <michael.d.kinney@intel.com >
Signed-off-by: Michael Kubacki <michael.kubacki@microsoft.com >
2023-03-31 17:38:27 +00:00
Gerd Hoffmann
f92a9dce10
OvmfPkg/CI: Boot OVMF in SMP mode.
...
Increase the chance that CI finds bugs in MP changes.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com >
2023-03-29 15:50:53 +00:00
Sunil V L
7cfe9048e3
OvmfPkg/PlatformCI: Add CI coverage for RiscVVirtQemu
...
Add support for building RiscVVirtQemu platform in CI.
Cc: Ard Biesheuvel <ardb+tianocore@kernel.org >
Cc: Jiewen Yao <jiewen.yao@intel.com >
Cc: Jordan Justen <jordan.l.justen@intel.com >
Cc: Gerd Hoffmann <kraxel@redhat.com >
Signed-off-by: Sunil V L <sunilvl@ventanamicro.com >
Acked-by: Gerd Hoffmann <kraxel@redhat.com >
2023-03-16 11:05:18 +00:00
Ard Biesheuvel
3beb8c9654
OvmfPkg/PlatformCI VS2019: Enable temporary workaround for cpuhp bugfix
...
QEMU for x86 has a nasty CPU hotplug bug of which the ramifications are
difficult to oversee, even though KVM acceleration seems to be
unaffected. This has been addressed in QEMU mainline, and will percolate
through the ecosystem at its usual pace. In the mean time, due to the
potential impact on production workloads, we will be updating OVMF to
abort the boot when it detects a QEMU build that is affected.
Tiancore's platform CI uses QEMU in TCG mode, and is therefore impacted
by this mitigation, unless its QEMU builds are updated. This has been
done for Ubuntu-GCC5, but Windows-VS2019 still uses a QEMU build that is
affected.
Aborting the boot upon detecting the QEMU issue will render all boot
tests carried out on Windows-VS2019 broken unless we implement the
'escape hatch' that enables proceed-at-your-own-risk mode, and permits
the boot to proceed even if the QEMU issue is detected.
So let's enable this for Windows-VS2019, and remove it again once it is
no longer needed.
Cc: Laszlo Ersek <lersek@redhat.com >
Cc: Gerd Hoffmann <kraxel@redhat.com >
Cc: Jiewen Yao <jiewen.yao@intel.com >
Cc: Michael Brown <mcb30@ipxe.org >
Cc: Oliver Steffen <osteffen@redhat.com >
Cc: Michael Kubacki <michael.kubacki@microsoft.com >
Bugzilla: https://bugzilla.tianocore.org/show_bug.cgi?id=4250
Signed-off-by: Ard Biesheuvel <ardb@kernel.org >
Message-Id: <20230119134302.1524569-1-ardb@kernel.org >
Acked-by: Gerd Hoffmann <kraxel@redhat.com >
Reviewed-by: Michael Kubacki <michael.kubacki@microsoft.com >
Acked-by: Jiewen Yao <Jiewen.yao@Intel.com >
Reviewed-by: Laszlo Ersek <lersek@redhat.com >
2023-01-20 13:41:16 +00:00
Oliver Steffen
7edf120150
OvmfPkg: CI: use ubuntu-22.04 vm_image (Linux only)
...
Switch over to ubuntu-22.04 as the vm_image for Linux CI jobs. The
previously used ubuntu-18.04 which is not available anymore since
Dec 1st 2022.
Signed-off-by: Oliver Steffen <osteffen@redhat.com >
Reviewed-by: Michael Kubacki <michael.kubacki@microsoft.com >
Acked-by: Jiewen Yao <jiewen.yao@intel.com >
Acked-by: Ard Biesheuvel <ardb@kernel.org >
Acked-by: Gerd Hoffmann <kraxel@redhat.com >
Reviewed-by: Chris Fernald <chfernal@microsoft.com >
2023-01-17 19:06:32 +00:00
Oliver Steffen
7fab007f33
OvmfPkg: CI: Use Fedora 35 container (Linux only)
...
Run the Linux jobs of the OvmfPkg platform CI inside a container,
in the same way the general CI does now. Make use of the default image
specified in the defaults.yml template.
Do not run apt-get in CI jobs to install qemu and gcc dependencies.
Assume the container image provides these.
Use Python from the container image, do not download at runtime.
Signed-off-by: Oliver Steffen <osteffen@redhat.com >
Acked-by: Jiewen Yao <jiewen.yao@intel.com >
Reviewed-by: Michael Kubacki <michael.kubacki@microsoft.com >
Acked-by: Ard Biesheuvel <ardb@kernel.org >
Acked-by: Gerd Hoffmann <kraxel@redhat.com >
Reviewed-by: Chris Fernald <chfernal@microsoft.com >
2023-01-17 19:06:32 +00:00
Oliver Steffen
65cc189414
OvmfPkg: CI: use Python version from defaults template
...
Use the default Python version from the defaults template
(.azurepipelines/templates/defaults.yml) in the Windows and
Linux CI jobs.
Previous changes to the CI job templates make it necessary
to specify a version number, if Python shall be pulled
at CI runtime.
Signed-off-by: Oliver Steffen <osteffen@redhat.com >
Reviewed-by: Michael Kubacki <michael.kubacki@microsoft.com >
Acked-by: Jiewen Yao <jiewen.yao@intel.com >
Acked-by: Ard Biesheuvel <ardb@kernel.org >
Acked-by: Gerd Hoffmann <kraxel@redhat.com >
Reviewed-by: Chris Fernald <chfernal@microsoft.com >
2023-01-17 19:06:32 +00:00
Michael Kubacki
316e6df435
OvmfPkg: Add reference to new build instructions
...
Adds a reference to the new build instructions on the TianoCore wiki
that currently describe building with containers and Stuart.
Cc: Ard Biesheuvel <ardb+tianocore@kernel.org >
Cc: Jiewen Yao <jiewen.yao@intel.com >
Cc: Jordan Justen <jordan.l.justen@intel.com >
Cc: Gerd Hoffmann <kraxel@redhat.com >
Cc: Sean Brogan <sean.brogan@microsoft.com >
Cc: Michael D Kinney <michael.d.kinney@intel.com >
Cc: Liming Gao <gaoliming@byosoft.com.cn >
Signed-off-by: Michael Kubacki <michael.kubacki@microsoft.com >
Acked-by: Ard Biesheuvel <ardb@kernel.org >
Reviewed-by: Gerd Hoffmann <kraxel@redhat.com >
Reviewed-by: Jiewen Yao <Jiewen.yao@intel.com >
2022-12-16 22:17:18 +00:00
Min Xu
f966093f5b
OvmfPkg/PlatformCI: add IntelTdxBuild.py
...
Add build test for OvmfPkg/IntelTdx
Cc: Erdem Aktas <erdemaktas@google.com >
Cc: James Bottomley <jejb@linux.ibm.com >
Cc: Tom Lendacky <thomas.lendacky@amd.com >
Cc: Gerd Hoffmann <kraxel@redhat.com >
Cc: Jiewen Yao <Jiewen.yao@intel.com >
Cc: Ard Biesheuvel <ardb@kernel.org >
Signed-off-by: Min Xu <min.m.xu@intel.com >
Acked-by: Gerd Hoffmann <kraxel@redhat.com >
Reviewed-by: Jiewen Yao <Jiewen.yao@intel.com >
2022-07-01 06:48:12 +00:00
Michael Kubacki
75628d27c0
OvmfPkg: Use windows-2019 VM image
...
REF:https://bugzilla.tianocore.org/show_bug.cgi?id=3890
The YAML file previously specified "windows-latest" which recently
moved to VS2022. To continue using VS2019 (at least in the short
term), the VM image needs to be explicitly set to "windows-2019".
Cc: Ard Biesheuvel <ardb+tianocore@kernel.org >
Cc: Jiewen Yao <jiewen.yao@intel.com >
Cc: Jordan Justen <jordan.l.justen@intel.com >
Cc: Gerd Hoffmann <kraxel@redhat.com >
Signed-off-by: Michael Kubacki <michael.kubacki@microsoft.com >
Reviewed-by: Sean Brogan <sean.brogan@microsoft.com >
Reviewed-by: Michael D Kinney <michael.d.kinney@intel.com >
2022-04-02 02:56:48 +00:00
Sebastien Boeuf
5302bd81d9
OvmfPkg: Add CloudHvX64 to the CI
...
Adding the newly created target for Cloud Hypervisor to the CI,
validating it can be properly built.
Acked-by: Gerd Hoffmann <kraxel@redhat.com >
Acked-by: Jiewen Yao <Jiewen.yao@intel.com >
Signed-off-by: Sebastien Boeuf <sebastien.boeuf@intel.com >
2022-01-13 14:54:40 +00:00
Gerd Hoffmann
4de8d61bce
OvmfPkg: rework TPM configuration
...
Rename TPM_ENABLE to TPM2_ENABLE so naming is in line with the
ArmVirtPkg config option name.
Add separate TPM1_ENABLE option for TPM 1.2 support.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com >
Tested-by: Stefan Berger <stefanb@linux.ibm.com >
2021-12-15 16:16:05 +00:00
Gerd Hoffmann
5711ff4d0b
OvmfPkg: drop TPM_CONFIG_ENABLE
...
Drop TPM_CONFIG_ENABLE config option. Including TPM support in the
build without also including the TPM configuration menu is not useful.
Suggested-by: Stefan Berger <stefanb@linux.ibm.com >
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com >
Tested-by: Stefan Berger <stefanb@linux.ibm.com >
2021-12-15 16:16:05 +00:00
Gerd Hoffmann
1203eba58e
OvmfPkg/PlatformCI: add XenBuild.py
...
Add build test for OvmfXen.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com >
2021-12-13 11:36:57 +00:00
Gerd Hoffmann
2722856a87
OvmfPkg/PlatformCI: dummy grub.efi for AmdSev
...
Building grub.efi for AmdSev is difficult because it depends on patches
not yet merged to upstream grub. So shortcut the grub build by simply
creating an empty grub.efi file. That allows to at least build-test the
AmdSev variant.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com >
Acked-by: Jiewen Yao <Jiewen.yao@intel.com >
Acked-by: Ard Biesheuvel <ardb@kernel.org >
Reviewed-by: Dov Murik <dovmurik@linux.ibm.com >
2021-12-13 11:36:57 +00:00
Gerd Hoffmann
8b8ae609a7
OvmfPkg/PlatformCI: add AmdSevBuild.py
...
Add build test for OvmfPkg/AmdSev.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com >
Acked-by: Jiewen Yao <Jiewen.yao@intel.com >
Acked-by: Ard Biesheuvel <ardb@kernel.org >
Reviewed-by: Philippe Mathieu-Daude <philmd@redhat.com >
2021-12-13 11:36:57 +00:00
Gerd Hoffmann
04eacd3943
OvmfPkg/PlatformCI: add MicrovmBuild.py
...
Add build test for OvmfPkg/Microvm.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com >
Acked-by: Jiewen Yao <Jiewen.yao@intel.com >
Acked-by: Ard Biesheuvel <ardb@kernel.org >
Reviewed-by: Philippe Mathieu-Daude <philmd@redhat.com >
2021-12-13 11:36:57 +00:00
Gerd Hoffmann
64bccda534
OvmfPkg/PlatformCI: add BhyveBuild.py
...
Add build test for OvmfPkg/Bhyve.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com >
Acked-by: Jiewen Yao <Jiewen.yao@intel.com >
Acked-by: Ard Biesheuvel <ardb@kernel.org >
2021-12-13 11:36:57 +00:00
Gerd Hoffmann
21ee379407
OvmfPkg/PlatformCI: add QEMU_SKIP
...
Skip the qemu boot test in case QEMU_SKIP is set to true.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com >
Acked-by: Jiewen Yao <Jiewen.yao@intel.com >
Acked-by: Ard Biesheuvel <ardb@kernel.org >
Reviewed-by: Philippe Mathieu-Daude <philmd@redhat.com >
2021-12-13 11:36:57 +00:00
Gerd Hoffmann
61be49e0f7
OvmfPkg/PlatformCI: factor out PlatformBuildLib.py
...
Move SettingsManager and PlatformBuilder classes to PlatformBuildLib.py
file, keep only CommonPlatform class in PlatformBuild.py. Allows
reusing these classes for other builds. Pure code motion, no functional
change.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com >
Acked-by: Jiewen Yao <Jiewen.yao@intel.com >
Acked-by: Ard Biesheuvel <ardb@kernel.org >
2021-12-13 11:36:57 +00:00
Laszlo Ersek
702ba436ed
OvmfPkg/PlatformCI: bump QEMU choco package version to 2021.5.5
...
We currently require QEMU choco package version 2020.08.14 (from commit
3ab9d60fcb
), in "OvmfPkg/PlatformCI/.azurepipelines/Windows-VS2019.yml".
Said package version references the following URLs:
https://community.chocolatey.org/packages/Qemu/2020.08.14#files
-> https://qemu.weilnetz.de/w32/qemu-w32-setup-20200814.exe
-> https://qemu.weilnetz.de/w64/qemu-w64-setup-20200814.exe
These URLs no longer work; Stefan Weil seems to have moved the binaries to
the following archive directories:
- https://qemu.weilnetz.de/w32/2020/
- https://qemu.weilnetz.de/w64/2020/
In theory, the old QEMU choco packages should be fixed (their powershell
scripts should be updated to reference the new URLs on Stefan Weil's
website). However, this PlatformCI issue is blocking the merging of the
security fix for TianoCore#3356, so getting PlatformCI functional again is
urgent. Let's bump our QEMU choco package requirement to 2021.5.5, whose
URLs work, for now.
(Currently we cannot use any other choco package version, as Stefan's
directories <https://qemu.weilnetz.de/w32 > and
<https://qemu.weilnetz.de/w64 >, without any further subdirectories, only
offer the 20210505 EXE files.)
Cc: Ard Biesheuvel <ardb+tianocore@kernel.org >
Cc: Bret Barkelew <Bret.Barkelew@microsoft.com >
Cc: Jordan Justen <jordan.l.justen@intel.com >
Cc: Liming Gao <gaoliming@byosoft.com.cn >
Cc: Michael D Kinney <michael.d.kinney@intel.com >
Cc: Philippe Mathieu-Daudé <philmd@redhat.com >
Cc: Sean Brogan <sean.brogan@microsoft.com >
Signed-off-by: Laszlo Ersek <lersek@redhat.com >
Message-Id: <20210609155731.10431-1-lersek@redhat.com >
Acked-by: Ard Biesheuvel <ardb@kernel.org >
2021-06-09 16:43:39 +00:00
Michael D Kinney
d21d270676
OvmfPkg/.azurepipelines: Enable EDK II CI for stable/* branches
...
https://bugzilla.tianocore.org/show_bug.cgi?id=3130
Cc: Jordan Justen <jordan.l.justen@intel.com >
Cc: Laszlo Ersek <lersek@redhat.com >
Cc: Ard Biesheuvel <ard.biesheuvel@arm.com >
Cc: Sean Brogan <sean.brogan@microsoft.com >
Cc: Bret Barkelew <Bret.Barkelew@microsoft.com >
Cc: Liming Gao <gaoliming@byosoft.com.cn >
Signed-off-by: Michael D Kinney <michael.d.kinney@intel.com >
Reviewed-by: Liming Gao <gaoliming@byosoft.com.cn >
2020-12-22 22:11:48 +00:00
Laszlo Ersek
c487970ac8
OvmfPkg/PlatformCI: stick with "ubuntu-18.04" for now
...
"vm_image: 'ubuntu-latest'" now refers to Ubuntu Focal (20.04LTS), not
Ubuntu Bionic (18.04LTS), according to
<https://github.com/actions/virtual-environments/issues/1816 >.
In Focal, the "qemu" package is a dummy package with no dependencies, and
so the actual emulators are not pulled in. Compare:
https://packages.ubuntu.com/bionic/qemu
https://packages.ubuntu.com/focal/qemu
This causes CI runs to fail.
It would be best to switch to the "qemu-system" package name, which
continues to depend on the emulators:
https://packages.ubuntu.com/bionic/qemu-system
https://packages.ubuntu.com/focal/qemu-system
However, while that package does make the emulators available, the
emulators crash. So for now, stick with the previous Ubuntu environment,
which continues to be supported, per
<https://github.com/actions/virtual-environments/issues/1816 >.
Cc: Ard Biesheuvel <ard.biesheuvel@arm.com >
Cc: Jordan Justen <jordan.l.justen@intel.com >
Cc: Philippe Mathieu-Daudé <philmd@redhat.com >
Signed-off-by: Laszlo Ersek <lersek@redhat.com >
Message-Id: <20201217204049.26817-3-lersek@redhat.com >
Reviewed-by: Michael D Kinney <michael.d.kinney@intel.com >
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com >
Reviewed-by: Ard Biesheuvel <ard.biesheuvel@arm.com >
2020-12-18 09:51:16 +00:00
Michael D Kinney
3ab9d60fcb
OvmfPkg/PlatformCI/.azurepiplines: Use stable release of QEMU
...
Install the 2020.08.14 release of QEMU for Windows.
The QEMU release from 2020.11.20 is installed into the incorrect
directory and is causing EDK II CI failures in the run to shell
step.
Cc: Sean Brogan <sean.brogan@microsoft.com >
Cc: Bret Barkelew <Bret.Barkelew@microsoft.com >
Cc: Liming Gao <gaoliming@byosoft.com.cn >
Cc: Jordan Justen <jordan.l.justen@intel.com >
Cc: Laszlo Ersek <lersek@redhat.com >
Cc: Ard Biesheuvel <ard.biesheuvel@arm.com >
Signed-off-by: Michael D Kinney <michael.d.kinney@intel.com >
Acked-by: Laszlo Ersek <lersek@redhat.com >
Reviewed-by: Philippe Mathieu-Daude <philmd@redhat.com >
2020-11-25 17:54:11 +00:00
Sean Brogan
6cdf647b5f
OvmfPkg: Add Platform CI and configuration for Core CI
...
REF:https://bugzilla.tianocore.org/show_bug.cgi?id=2570
Add new Azure Pipeline definitions to build and run OvmfPkg with:
* Ubuntu GCC5
* Windows VS2019
Add PyTool based build of OvmfPkg
Add extdep for managing the iasl dependency
Add OvmfPkg.ci.yaml for Core CI
Add ReadMe.md for details and instructions
Cc: Jordan Justen <jordan.l.justen@intel.com >
Cc: Laszlo Ersek <lersek@redhat.com >
Cc: Ard Biesheuvel <ard.biesheuvel@arm.com >
Signed-off-by: Michael Kubacki <michael.kubacki@microsoft.com >
Acked-by: Laszlo Ersek <lersek@redhat.com >
Acked-by: Ard Biesheuvel <ard.biesheuvel@arm.com >
Reviewed-by: Shenglei Zhang <shenglei.zhang@intel.com >
Reviewed-by: Bret Barkelew <bret.barkelew@microsoft.com >
2020-04-28 18:07:59 +00:00