fixes for multi gpu

This commit is contained in:
2025-07-19 11:55:49 +02:00
parent 15793a2c42
commit 79aba60947
6 changed files with 86 additions and 75 deletions

View File

@@ -20,7 +20,7 @@
}; };
graphics = { graphics = {
enable = true; enable = true;
vendor = "amd"; vendors = ["amd"];
}; };
logitech = { logitech = {
enable = false; enable = false;

View File

@@ -21,7 +21,7 @@
}; };
graphics = { graphics = {
enable = true; enable = true;
vendor = "amd"; vendors = ["amd"];
}; };
logitech = { logitech = {
enable = true; enable = true;

View File

@@ -21,7 +21,7 @@
}; };
graphics = { graphics = {
enable = true; enable = true;
vendor = "intel"; vendors = ["intel" "amd"];
}; };
logitech = { logitech = {
enable = false; enable = false;

View File

@@ -20,7 +20,7 @@
}; };
graphics = { graphics = {
enable = true; enable = true;
vendor = "nvidia"; vendors = ["nvidia"];
nvidia = { nvidia = {
package = "beta"; package = "beta";
open = { open = {

View File

@@ -1,28 +1,26 @@
{ {
pkgs,
config, config,
lib, lib,
pkgs,
... ...
}: let }: let
inherit (lib) mkEnableOption mkOption types mkIf mkMerge; inherit (lib) mkEnableOption mkOption types mkIf mkMerge flatten concatMap;
cfg = config.nixos.hardware.graphics; cfg = config.nixos.hardware.graphics;
vendor = cfg.vendor;
# Common packages used across all vendors
commonPackages = with pkgs; [ commonPackages = with pkgs; [
libva libva
vaapiVdpau vaapiVdpau
libvdpau-va-gl libvdpau-va-gl
libGL libGL
]; ];
commonPackages32 = with pkgs.pkgsi686Linux; [ commonPackages32 = with pkgs.pkgsi686Linux; [
libva libva
vaapiVdpau vaapiVdpau
libvdpau-va-gl libvdpau-va-gl
]; ];
# Mesa Vulkan packages (used by AMD & Intel only)
mesaVulkanPackages = with pkgs; [ mesaVulkanPackages = with pkgs; [
vulkan-loader vulkan-loader
vulkan-validation-layers vulkan-validation-layers
@@ -30,7 +28,6 @@
vulkan-utility-libraries vulkan-utility-libraries
]; ];
# Extra desktop utilities
tools = with pkgs; [ tools = with pkgs; [
vulkan-tools vulkan-tools
wayland wayland
@@ -48,18 +45,21 @@
export ELECTRON_OZONE_PLATFORM_HINT=auto export ELECTRON_OZONE_PLATFORM_HINT=auto
exec "$@" exec "$@"
''; '';
hasVendor = vendor: builtins.elem vendor cfg.vendors;
in { in {
options.nixos.hardware.graphics = { options.nixos.hardware.graphics = {
enable = mkEnableOption "Enable general graphics support"; enable = mkEnableOption "Enable general graphics support";
vendor = mkOption { vendors = mkOption {
type = types.enum ["amd" "intel" "nvidia"]; type = types.listOf (types.enum ["amd" "intel" "nvidia"]);
default = "amd"; default = ["amd"];
description = "GPU vendor to configure support for."; description = "List of GPU vendors to configure support for.";
}; };
nvidia = { nvidia = {
open.enable = mkEnableOption "Enable NVidia open drivers"; open.enable = mkEnableOption "Enable NVidia open drivers";
package = mkOption { package = mkOption {
type = types.enum ["stable" "beta" "production" "latest"]; type = types.enum ["stable" "beta" "production" "latest"];
default = "stable"; default = "stable";
@@ -68,53 +68,63 @@ in {
}; };
}; };
config = mkIf cfg.enable ( config = mkIf cfg.enable (mkMerge [
mkMerge [
{ {
hardware.graphics = { hardware.graphics = {
enable = true; enable = true;
enable32Bit = true; enable32Bit = true;
}; extraPackages = flatten (concatMap (
} vendor:
if vendor == "amd"
# AMD-specific configuration then commonPackages ++ mesaVulkanPackages
(mkIf (vendor == "amd") { else if vendor == "intel"
hardware.amdgpu.overdrive.enable = true; then
hardware.graphics.extraPackages = commonPackages ++ mesaVulkanPackages;
hardware.graphics.extraPackages32 = commonPackages32;
environment.systemPackages = tools;
})
# Intel-specific configuration
(mkIf (vendor == "intel") {
hardware.graphics.extraPackages =
commonPackages commonPackages
++ mesaVulkanPackages ++ mesaVulkanPackages
++ (with pkgs; [ ++ (with pkgs; [
vpl-gpu-rt vpl-gpu-rt
intel-media-driver intel-media-driver
intel-compute-runtime intel-compute-runtime
]); ])
hardware.graphics.extraPackages32 = commonPackages32; else if vendor == "nvidia"
environment.systemPackages = tools; then
})
# Nvidia-specific configuration
(mkIf (vendor == "nvidia") {
hardware.graphics.extraPackages =
commonPackages commonPackages
++ (with pkgs; [ ++ (with pkgs; [
nvidiaOffloadScript nvidiaOffloadScript
intel-media-driver intel-media-driver
nvidia-vaapi-driver nvidia-vaapi-driver
vulkan-tools vulkan-tools
]); ])
hardware.graphics.extraPackages32 = commonPackages32; else []
environment.systemPackages = with pkgs; [ )
egl-wayland cfg.vendors);
libGL
];
extraPackages32 = flatten (concatMap (_: commonPackages32) cfg.vendors);
};
environment.systemPackages = flatten (concatMap (
vendor:
if vendor == "amd"
then
tools
++ (with pkgs; [
# rocmPackages.rpp
# rocmPackages.clr
])
else if vendor == "intel"
then tools
else if vendor == "nvidia"
then with pkgs; [egl-wayland libGL]
else []
)
cfg.vendors);
}
(mkIf (hasVendor "amd") {
hardware.amdgpu.overdrive.enable = true;
})
(mkIf (hasVendor "nvidia") {
hardware.nvidia = { hardware.nvidia = {
package = package =
if cfg.nvidia.package == "beta" if cfg.nvidia.package == "beta"
@@ -132,6 +142,5 @@ in {
nvidiaSettings = true; nvidiaSettings = true;
}; };
}) })
] ]);
);
} }

View File

@@ -63,6 +63,8 @@ in {
cloudflared cloudflared
libargon2 libargon2
openssl openssl
xmrig
ocl-icd
] ]
(mkIf cfg.common.enable [ (mkIf cfg.common.enable [