mirror of
https://github.com/aviallon/nixos-lib.git
synced 2026-04-05 17:27:50 +00:00
[Hardware/AMD] Add kernelDriver option and split config between amdgpu and radeon
This commit is contained in:
parent
233f95153e
commit
81860dbe21
3 changed files with 97 additions and 48 deletions
|
|
@ -14,70 +14,31 @@ in {
|
|||
type = with types; enum [ "amdvlk" "radv" ];
|
||||
default = "radv";
|
||||
};
|
||||
kernelDriver = mkOption {
|
||||
description = "wether to use radeon or amdgpu kernel driver";
|
||||
type = with types; enum [ "radeon" "amdgpu" ];
|
||||
default = "amdgpu";
|
||||
};
|
||||
};
|
||||
|
||||
imports = [
|
||||
./cpu.nix
|
||||
./amdgpu.nix
|
||||
./radeon.nix
|
||||
];
|
||||
|
||||
config = mkIf (cfg.enable) {
|
||||
boot.initrd.kernelModules = [ "amdgpu" ];
|
||||
|
||||
aviallon.boot.cmdline = {
|
||||
# for Southern Islands (SI ie. GCN 1) cards
|
||||
"radeon.si_support" = 0;
|
||||
"amdgpu.si_support" = 1;
|
||||
# for Sea Islands (CIK ie. GCN 2) cards
|
||||
"radeon.cik_support" = 0;
|
||||
"amdgpu.cik_support" = 1;
|
||||
|
||||
"amdgpu.ppfeaturemask" = mkIf generalCfg.unsafeOptimizations "0xfff7ffff";
|
||||
"amdgpu.freesync_video" = 1;
|
||||
#"amdgpu.mes" = mkIf generalCfg.unsafeOptimizations 1;
|
||||
};
|
||||
|
||||
environment.systemPackages = with pkgs; []
|
||||
++ [
|
||||
rocm-smi
|
||||
]
|
||||
++ optionals devCfg.enable ([]
|
||||
++ [ rocminfo ]
|
||||
)
|
||||
;
|
||||
|
||||
services.xserver.videoDrivers = []
|
||||
++ optional cfg.useProprietary "amdgpu-pro"
|
||||
++ [
|
||||
"amdgpu"
|
||||
"radeon"
|
||||
];
|
||||
|
||||
config = mkIf cfg.enable {
|
||||
programs.corectrl.enable = mkIf generalCfg.unsafeOptimizations true;
|
||||
|
||||
hardware.opengl = {
|
||||
enable = true;
|
||||
package = with pkgs; myMesa.drivers;
|
||||
extraPackages = with pkgs; mkIf (!cfg.useProprietary) (mkAfter [
|
||||
rocm-opencl-icd
|
||||
rocm-opencl-runtime
|
||||
(hiPrio myMesa)
|
||||
amdvlk
|
||||
]);
|
||||
extraPackages32 = with pkgs.driversi686Linux; mkIf (!cfg.useProprietary) [
|
||||
mesa
|
||||
amdvlk
|
||||
(hiPrio myMesa)
|
||||
];
|
||||
};
|
||||
|
||||
environment.variables = {
|
||||
"AMD_VULKAN_ICD" = strings.toUpper cfg.defaultVulkanImplementation;
|
||||
};
|
||||
|
||||
# Make rocblas and rocfft work
|
||||
nix.settings.extra-sandbox-paths = [
|
||||
"/dev/kfd?"
|
||||
"/sys/devices/virtual/kfd?"
|
||||
"/dev/dri/renderD128?"
|
||||
];
|
||||
};
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue