X-Git-Url: http://git.scottworley.com/nixos-qemu-vm-isolation/blobdiff_plain/328f87c12f4f1961a525d05ce435bfce4ab07e7c..b2cb606e5daf3b4825d2d9e423fe40ba90d755f1:/modules/qemu-vm-isolation.nix?ds=sidebyside diff --git a/modules/qemu-vm-isolation.nix b/modules/qemu-vm-isolation.nix index 5467f29..ed6800e 100644 --- a/modules/qemu-vm-isolation.nix +++ b/modules/qemu-vm-isolation.nix @@ -49,17 +49,15 @@ let }/nix-store.img"; squashfs = "${hostPkgs.callPackage (modulesPath + "/../lib/make-squashfs.nix") { - squashfsTools = hostPkgs.squashfsTools.overrideAttrs (old: { - # We patch in support for squashfs labels because - # https://github.com/NixOS/nixpkgs/pull/236656 requires filesystems to have labels and - # https://github.com/plougher/squashfs-tools/issues/59 squashfs doesn't support labels - patches = (old.patches or []) ++ [ ./squashfs-tools-label.patch ]; - buildInputs = (old.buildInputs or []) ++ [ hostPkgs.makeWrapper ]; - postInstall = (old.postInstall or "") + '' - wrapProgram "$out/bin/mksquashfs" \ - --append-flags "-label nix-store" - ''; - }); + squashfsTools = + (hostPkgs.extend (import ../overlays/squashfs-labels)).squashfsTools.overrideAttrs + (old: { + buildInputs = (old.buildInputs or [ ]) ++ [ hostPkgs.makeWrapper ]; + postInstall = (old.postInstall or "") + '' + wrapProgram "$out/bin/mksquashfs" \ + --append-flags "-label nix-store" + ''; + }); storeContents = config.virtualisation.additionalPaths; }}"; }; @@ -84,14 +82,7 @@ in { optional (cfg.nixStoreFilesystemType == "erofs") "erofs"; nixpkgs.overlays = optional (cfg.nixStoreFilesystemType == "squashfs") - (final: prev: { - util-linux = prev.util-linux.overrideAttrs (old: { - # We patch in support for squashfs labels because - # https://github.com/NixOS/nixpkgs/pull/236656 requires filesystems to have labels and - # https://github.com/plougher/squashfs-tools/issues/59 squashfs doesn't support labels - patches = (old.patches or [ ]) ++ [ ./util-linux-squashfs-label.patch ]; - }); - }); + (import ../overlays/squashfs-labels); fileSystems = mkVMOverride { "${storeMountPath}" = {