nixdots/options/device/hardware.nix

43 lines
1.6 KiB
Nix
Raw Normal View History

2024-03-21 20:47:25 +00:00
{ lib, ... }: with lib; let
in
{
options.myOptions.device = {
cpu.type = mkOption {
2024-03-23 20:35:29 +00:00
type = with types; nullOr (enum [ "intel" "amd" ]);
2024-03-21 20:47:25 +00:00
default = null;
description = ''
The manifaturer/type of the primary system CPU.
Determines which ucode services will be enabled and provides additional kernel packages.
2024-03-23 20:35:29 +00:00
If running in a virtual machine with forwarded/shared cores (CPU passthrough), use the
cpu type of the host machine.
2024-03-21 20:47:25 +00:00
'';
};
2024-03-23 20:35:29 +00:00
2024-05-15 18:29:28 +00:00
gpu.type = mkOption {
2024-06-10 11:54:03 +00:00
type = with types; nullOr (enum [ "nvidia" "amd" "intel" "hybrid-nvidia" "hybrid-amd" ]);
2024-05-15 18:29:28 +00:00
default = null;
description = ''
The manifaturer/type of the primary system GPU.
Allows the correct GPU drivers to be loaded, potentially optimizing video output performance.
2024-06-10 11:54:03 +00:00
If you're on a hybrid system (intel/amd igpu + nvidia/amd dgpu) make sure to use
the hybrid options, only specifying the dgpu will not work properly.
Note that if using hybrid-nvidia, you will need to set `hardware.nvidia.prime.nvidiaBusId`
and `intelBusId` (or `amdgpuBusId`) to "PCI:x:y:z". To find the correct bus IDs, you can
use `sudo lshw -c display`. Note that you will need to convert the bus ID format from
hexadecimal to decimal, remove the padding (leading zeroes) and replace the dot with a
colon (so for example 0e:00.0 -> PCI:14:0:0).
2024-05-15 18:29:28 +00:00
'';
};
2024-04-12 19:38:05 +00:00
hasTPM = mkOption {
type = lib.types.bool;
default = false;
2024-04-12 21:29:29 +00:00
description = "Does this device have a TPM (Trusted Platform Module)?";
};
2024-03-21 20:47:25 +00:00
};
}