Skip to content

Commit

Permalink
packages/buildVerityMicroVM: init
Browse files Browse the repository at this point in the history
This adds a Nix builder to build a micro VM image for direct Linux boot, specifically for the bare-metal Kata image where this is necessary to satisfy Contrast's security assumptions made on the SNP launch digest computation.
  • Loading branch information
msanft committed Nov 29, 2024
1 parent 1435b47 commit d7eb68a
Showing 1 changed file with 58 additions and 0 deletions.
58 changes: 58 additions & 0 deletions packages/by-name/buildVerityMicroVM/package.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
# Copyright 2024 Edgeless Systems GmbH
# SPDX-License-Identifier: AGPL-3.0-only

# Builds a micro VM image (i.e. rootfs, kernel and kernel cmdline) from a NixOS
# configuration. These components can then be booted in a microVM-fashion
# with QEMU's direct Linux boot feature.
# See: https://qemu-project.gitlab.io/qemu/system/linuxboot.html

{
symlinkJoin,
lib,
}:

nixos-config:

let
image = nixos-config.image.overrideAttrs (oldAttrs: {
passthru = oldAttrs.passthru // {
imageFile = "${oldAttrs.pname}_${oldAttrs.version}.raw";
};
});
in

lib.throwIf
(lib.foldlAttrs (
acc: _: partConfig:
acc || (partConfig.repartConfig.Type == "esp")
) false nixos-config.config.image.repart.partitions)
"MicroVM images should not contain an ESP."

symlinkJoin
{
pname = "microvm-image";
inherit (nixos-config.config.system.image) version;

paths = [
nixos-config.config.system.build.kernel
nixos-config.config.system.build.initialRamdisk
image
];

passthru =
let
roothash = builtins.head (
lib.map (e: e.roothash) (builtins.fromJSON (builtins.readFile "${image}/repart-output.json"))
);
in
{
cmdline = lib.concatStringsSep " " (
nixos-config.config.boot.kernelParams
++ [
"init=${nixos-config.config.system.build.toplevel}/init"
"roothash=${roothash}"
]
);
inherit (image) imageFile;
};
}

0 comments on commit d7eb68a

Please sign in to comment.