42adeef9ec
Since e791519f0f
("nixos/qemu-vm: use qemu_kvm"), VMs generated with
nixos-rebuild build-vm use the qemu_kvm package instead of the qemu
package. (The difference between them is that qemu_kvm is only built
with support for the host architecture, not all architectures.)
But with this change, nixos-rebuild build-vm would now depend on
_both_ QEMUs, because the guest agent module was still using the one
from the full QEMU package. There's no need for it to use this
instead of the lighter qemu_kvm, because the guest agent shouldn't be
affected by which platforms QEMU can emulate.
46 lines
1.1 KiB
Nix
46 lines
1.1 KiB
Nix
{ config, lib, pkgs, ... }:
|
|
|
|
with lib;
|
|
|
|
let
|
|
cfg = config.services.qemuGuest;
|
|
in {
|
|
|
|
options.services.qemuGuest = {
|
|
enable = mkOption {
|
|
type = types.bool;
|
|
default = false;
|
|
description = "Whether to enable the qemu guest agent.";
|
|
};
|
|
package = mkOption {
|
|
type = types.package;
|
|
default = pkgs.qemu_kvm.ga;
|
|
defaultText = literalExpression "pkgs.qemu_kvm.ga";
|
|
description = "The QEMU guest agent package.";
|
|
};
|
|
};
|
|
|
|
config = mkIf cfg.enable (
|
|
mkMerge [
|
|
{
|
|
|
|
services.udev.extraRules = ''
|
|
SUBSYSTEM=="virtio-ports", ATTR{name}=="org.qemu.guest_agent.0", TAG+="systemd" ENV{SYSTEMD_WANTS}="qemu-guest-agent.service"
|
|
'';
|
|
|
|
systemd.services.qemu-guest-agent = {
|
|
description = "Run the QEMU Guest Agent";
|
|
serviceConfig = {
|
|
ExecStart = "${cfg.package}/bin/qemu-ga --statedir /run/qemu-ga";
|
|
Restart = "always";
|
|
RestartSec = 0;
|
|
# Runtime directory and mode
|
|
RuntimeDirectory = "qemu-ga";
|
|
RuntimeDirectoryMode = "0755";
|
|
};
|
|
};
|
|
}
|
|
]
|
|
);
|
|
}
|