Expand description
flowey nodes specific to the HvLite project.
Modules§
- Defines top-level “job nodes” which can be composed when defining a flowey pipeline using
flowey::pipeline::prelude::PipelineJob::dep_on
. - Artifact:
guest_test_uefi.img
disk image, along with containedguest_test_uefi.efi
UEFI executable (with symbols). - Artifact: mdbook-rendered HvLite Guide
- Artifact:
hypestv
executable + debug symbols. - Artifact:
igvmfilegen
executable + debug symbols - Artifact: cargo-nextest archive file containing hvlite repo unit-tests.
- Artifact: cargo-nextest archive file containing VMM tests.
- Artifact:
ohcldiag-dev
executable + debug symbols. - Artifact:
openhcl_boot
executable + debug symbols - Artifact: A collection of OpenHCL IGVM files.
- Artifact: An artifact containing various “extras” that are generated as part of the OpenHCL IGVM build. e.g: debug symbols, constituent binaries, etc.
- Artifact:
openvmm
executable + debug symbols - Artifact:
openhcl
binary to use for PR binary size comparison - Artifact:
pipette
executable + debug symbols. - Artifact:
rustdoc
documentation, compiled to HTML, and compressed as atar.gz
file`. - Artifact:
vmgs_lib
dynamic library + debug symbols. - Artifact:
vmgstool
executable + debug symbols. - Builds and tests
vmgs_lib
library. - Build
guest_test_uefi
images and binaries - Build the OpenVMM Guide.
- Build
hypestv
binaries - Build
igvmfilegen
binaries - Build all cargo-nextest based unit-tests in the OpenVMM workspace.
- Build the cargo-nextest based VMM tests.
- Build
ohcldiag_dev
binaries - Build
openhcl_boot
binaries - Build an OpenHCL IGVM file using a particular known-good “recipe”, which encodes the precise features / build parameters used by each constituent component.
- Wrapper around
update-rootfs.py
- Build
openvmm
binaries - Build
openvmm_hcl
binaries (NOT IGVM FILES!) - Build
pipette
binaries - Document crates in the hvlite repo using rustdoc (via
cargo doc
). - Build
sidecar
binaries - Build an instance of
vmfirmwareigvm.dll
- Build
vmgstool
binaries - Build
xtask
binary - A node which returns a PathBuf to the “magic path” where OpenVMM code expects certain binary dependencies to be symlinked / extracted into.
- Download pre-built lxutil package from its GitHub Release.
- Download pre-built OpenHCL kernel packages from their GitHub Release
- Download various pre-built
openvmm-deps
dependencies. - Download OpenVMM VMM test images from Azure Blob Storage.
- Download pre-built mu_msvm package from its GitHub Release.
- Ensures that the OpenVMM repo is checked out, returning references to the repo’s clone directory.
- Install dependencies and set environment variables for cross compiling
- Hyper-V test pre-reqs
- Tweak
.cargo/config.toml
to deny warnings. - Ensure the OpenVMM example linux kernel + initrd are extracted into the correct “magic directory” set by the project-level
[env]
table in.cargo/config.toml
- Ensure the lxutil package is moved into the correct “magic directory” as expected by the project-level
[env]
table in.cargo/config.toml
- Ensure the OpenHCL sysroot is extracted into the correct “magic directory” set by the project-level
[env]
table in.cargo/config.toml
- Ensure protoc is symlinked into the correct “magic directory” set by the project-level
[env]
table in.cargo/config.toml
- Ensure the mu_msvm MSVM.fd file is copied into the “magic directory” to automatically work in the context of the OpenVMM repo.
- Setup the environment variables and directory structure that the VMM tests require to run.
- Globally install the git credential manager
- Globally install a set of dependencies required to build Rust code in the OpenVMM repo.
- Returns well-formed
cargo build
invocations for building crates specifically in the the hvlite repo. - Run cargo-nextest tests in the context of the HvLite repo.
- Raw bindings to
igvmfilegen
, used to build an igvm file from a manifest + set of resources. - Splits debug info from a binary into a separate file using
objcopy
- Run cargo-nextest based unit tests from a pre-built archive.
- Run cargo-nextest based VMM tests from a pre-built archive.