summaryrefslogtreecommitdiffstats
path: root/nixos/modules/hardware
diff options
context:
space:
mode:
authorK900 <me@0upti.me>2024-06-16 13:50:18 +0300
committerK900 <me@0upti.me>2024-06-16 14:11:33 +0300
commit98cef4c27326d0f9e521654441929c1c7c64f8e9 (patch)
tree7306c7495664017475f03f36c4efd878a79bb836 /nixos/modules/hardware
parent951601ccab7c3e8f9afa3ed78f2046863e6fa81d (diff)
treewide: big opengl cleanup
- rename hardware.opengl to hardware.graphics - remove hardware.opengl.driSupport, which does nothing - remove hardware.opengl.setLdLibraryPath, which should never be done - rename hardware.opengl.driSupport32Bit to hardware.graphics.enable32Bit - lost of small docs / formatting cleanups
Diffstat (limited to 'nixos/modules/hardware')
-rw-r--r--nixos/modules/hardware/graphics.nix132
-rw-r--r--nixos/modules/hardware/opengl.nix158
-rw-r--r--nixos/modules/hardware/video/nvidia.nix4
3 files changed, 134 insertions, 160 deletions
diff --git a/nixos/modules/hardware/graphics.nix b/nixos/modules/hardware/graphics.nix
new file mode 100644
index 000000000000..df41ee175d3d
--- /dev/null
+++ b/nixos/modules/hardware/graphics.nix
@@ -0,0 +1,132 @@
+{ config, lib, pkgs, ... }:
+let
+ cfg = config.hardware.graphics;
+
+ kernelPackages = config.boot.kernelPackages;
+
+ videoDrivers = config.services.xserver.videoDrivers;
+
+ driversEnv = pkgs.buildEnv {
+ name = "graphics-drivers";
+ paths = [ cfg.package ] ++ cfg.extraPackages;
+ };
+
+ driversEnv32 = pkgs.buildEnv {
+ name = "graphics-drivers-32bit";
+ paths = [ cfg.package32 ] ++ cfg.extraPackages32;
+ };
+in
+{
+ imports = [
+ (lib.mkRenamedOptionModule [ "services" "xserver" "vaapiDrivers" ] [ "hardware" "opengl" "extraPackages" ])
+ (lib.mkRemovedOptionModule [ "hardware" "opengl" "s3tcSupport" ] "S3TC support is now always enabled in Mesa.")
+ (lib.mkRemovedOptionModule [ "hardware" "opengl" "driSupport"] "The setting can be removed.")
+
+ (lib.mkRenamedOptionModule [ "hardware" "opengl" "enable"] [ "hardware" "graphics" "enable" ])
+ (lib.mkRenamedOptionModule [ "hardware" "opengl" "driSupport32Bit"] [ "hardware" "graphics" "enable32Bit" ])
+ (lib.mkRenamedOptionModule [ "hardware" "opengl" "package"] [ "hardware" "graphics" "package" ])
+ (lib.mkRenamedOptionModule [ "hardware" "opengl" "package32"] [ "hardware" "graphics" "package32" ])
+ (lib.mkRenamedOptionModule [ "hardware" "opengl" "extraPackages"] [ "hardware" "graphics" "extraPackages" ])
+ (lib.mkRenamedOptionModule [ "hardware" "opengl" "extraPackages32"] [ "hardware" "graphics" "extraPackages32" ])
+ ];
+
+ options.hardware.graphics = {
+ enable = lib.mkOption {
+ description = ''
+ Whether to enable hardware accelerated graphics drivers.
+
+ This is required to allow most graphical applications and
+ environments to use hardware rendering, video encode/decode
+ acceleration, etc.
+
+ This option should be enabled by default by the corresponding modules,
+ so you do not usually have to set it yourself.
+ '';
+ type = lib.types.bool;
+ default = false;
+ };
+
+ enable32Bit = lib.mkOption {
+ description = ''
+ On 64-bit systems, whether to also install 32-bit drivers for
+ 32-bit applications (such as Wine).
+ '';
+ type = lib.types.bool;
+ default = false;
+ };
+
+ package = lib.mkOption {
+ description = ''
+ The package that provides the default driver set.
+ '';
+ type = lib.types.package;
+ internal = true;
+ };
+
+ package32 = lib.mkOption {
+ description = ''
+ The package that provides the 32-bit driver set. Used when {option}`enable32Bit` is enabled.
+ set.
+ '';
+ type = lib.types.package;
+ internal = true;
+ };
+
+ extraPackages = lib.mkOption {
+ description = ''
+ Additional packages to add to the default graphics driver lookup path.
+ This can be used to add OpenCL drivers, VA-API/VDPAU drivers, etc.
+
+ ::: {.note}
+ intel-media-driver supports hardware Broadwell (2014) or newer. Older hardware should use the mostly unmaintained intel-vaapi-driver driver.
+ :::
+ '';
+ type = lib.types.listOf lib.types.package;
+ default = [];
+ example = lib.literalExpression "with pkgs; [ intel-media-driver intel-ocl intel-vaapi-driver ]";
+ };
+
+ extraPackages32 = lib.mkOption {
+ description = ''
+ Additional packages to add to 32-bit graphics driver lookup path on 64-bit systems.
+ Used when {option}`enable32Bit` is set. This can be used to add OpenCL drivers, VA-API/VDPAU drivers, etc.
+
+ ::: {.note}
+ intel-media-driver supports hardware Broadwell (2014) or newer. Older hardware should use the mostly unmaintained intel-vaapi-driver driver.
+ :::
+ '';
+ type = lib.types.listOf lib.types.package;
+ default = [];
+ example = lib.literalExpression "with pkgs.pkgsi686Linux; [ intel-media-driver intel-vaapi-driver ]";
+ };
+ };
+
+ config = lib.mkIf cfg.enable {
+ assertions = [
+ {
+ assertion = cfg.enable32Bit -> pkgs.stdenv.isx86_64;
+ message = "`hardware.graphics.enable32Bit` only makes sense on a 64-bit system.";
+ }
+ {
+ assertion = cfg.enable32Bit -> (config.boot.kernelPackages.kernel.features.ia32Emulation or false);
+ message = "`hardware.graphics.enable32Bit` requires a kernel that supports 32-bit emulation";
+ }
+ ];
+
+ systemd.tmpfiles.settings.graphics-driver = {
+ "/run/opengl-driver"."L+".argument = toString driversEnv;
+ "/run/opengl-driver-32" =
+ if pkgs.stdenv.isi686 then
+ { "L+".argument = "opengl-driver"; }
+ else if cfg.enable32Bit then
+ { "L+".argument = toString driversEnv32; }
+ else
+ { "r" = {}; };
+ };
+
+ hardware.graphics.package = lib.mkDefault pkgs.mesa.drivers;
+ hardware.graphics.package32 = lib.mkDefault pkgs.pkgsi686Linux.mesa.drivers;
+
+ boot.extraModulePackages = lib.optional (lib.elem "virtualbox" videoDrivers) kernelPackages.virtualboxGuestAdditions;
+ };
+}
diff --git a/nixos/modules/hardware/opengl.nix b/nixos/modules/hardware/opengl.nix
deleted file mode 100644
index 3ca9deec8961..000000000000
--- a/nixos/modules/hardware/opengl.nix
+++ /dev/null
@@ -1,158 +0,0 @@
-{ config, lib, pkgs, ... }:
-
-let
-
- cfg = config.hardware.opengl;
-
- kernelPackages = config.boot.kernelPackages;
-
- videoDrivers = config.services.xserver.videoDrivers;
-
- package = pkgs.buildEnv {
- name = "opengl-drivers";
- paths = [ cfg.package ] ++ cfg.extraPackages;
- };
-
- package32 = pkgs.buildEnv {
- name = "opengl-drivers-32bit";
- paths = [ cfg.package32 ] ++ cfg.extraPackages32;
- };
-
-in
-
-{
-
- imports = [
- (lib.mkRenamedOptionModule [ "services" "xserver" "vaapiDrivers" ] [ "hardware" "opengl" "extraPackages" ])
- (lib.mkRemovedOptionModule [ "hardware" "opengl" "s3tcSupport" ] "S3TC support is now always enabled in Mesa.")
- ];
-
- options = {
-
- hardware.opengl = {
- enable = lib.mkOption {
- description = ''
- Whether to enable OpenGL drivers. This is needed to enable
- OpenGL support in X11 systems, as well as for Wayland compositors
- like sway and Weston. It is enabled by default
- by the corresponding modules, so you do not usually have to
- set it yourself, only if there is no module for your wayland
- compositor of choice. See services.xserver.enable and
- programs.sway.enable.
- '';
- type = lib.types.bool;
- default = false;
- };
-
- driSupport = lib.mkOption {
- type = lib.types.bool;
- default = true;
- description = ''
- Whether to enable accelerated OpenGL rendering through the
- Direct Rendering Interface (DRI).
- '';
- };
-
- driSupport32Bit = lib.mkOption {
- type = lib.types.bool;
- default = false;
- description = ''
- On 64-bit systems, whether to support Direct Rendering for
- 32-bit applications (such as Wine). This is currently only
- supported for the `nvidia` as well as
- `Mesa`.
- '';
- };
-
- package = lib.mkOption {
- type = lib.types.package;
- internal = true;
- description = ''
- The package that provides the OpenGL implementation.
- '';
- };
-
- package32 = lib.mkOption {
- type = lib.types.package;
- internal = true;
- description = ''
- The package that provides the 32-bit OpenGL implementation on
- 64-bit systems. Used when {option}`driSupport32Bit` is
- set.
- '';
- };
-
- extraPackages = lib.mkOption {
- type = lib.types.listOf lib.types.package;
- default = [];
- example = lib.literalExpression "with pkgs; [ intel-media-driver intel-ocl intel-vaapi-driver ]";
- description = ''
- Additional packages to add to OpenGL drivers.
- This can be used to add OpenCL drivers, VA-API/VDPAU drivers etc.
-
- ::: {.note}
- intel-media-driver supports hardware Broadwell (2014) or newer. Older hardware should use the mostly unmaintained intel-vaapi-driver driver.
- :::
- '';
- };
-
- extraPackages32 =lib. mkOption {
- type = lib.types.listOf lib.types.package;
- default = [];
- example = lib.literalExpression "with pkgs.pkgsi686Linux; [ intel-media-driver intel-vaapi-driver ]";
- description = ''
- Additional packages to add to 32-bit OpenGL drivers on 64-bit systems.
- Used when {option}`driSupport32Bit` is set. This can be used to add OpenCL drivers, VA-API/VDPAU drivers etc.
-
- ::: {.note}
- intel-media-driver supports hardware Broadwell (2014) or newer. Older hardware should use the mostly unmaintained intel-vaapi-driver driver.
- :::
- '';
- };
-
- setLdLibraryPath = lib.mkOption {
- type = lib.types.bool;
- internal = true;
- default = false;
- description = ''
- Whether the `LD_LIBRARY_PATH` environment variable
- should be set to the locations of driver libraries. Drivers which
- rely on overriding libraries should set this to true. Drivers which
- support `libglvnd` and other dispatch libraries
- instead of overriding libraries should not set this.
- '';
- };
- };
-
- };
-
- config = lib.mkIf cfg.enable {
- assertions = [
- { assertion = cfg.driSupport32Bit -> pkgs.stdenv.isx86_64;
- message = "Option driSupport32Bit only makes sense on a 64-bit system.";
- }
- { assertion = cfg.driSupport32Bit -> (config.boot.kernelPackages.kernel.features.ia32Emulation or false);
- message = "Option driSupport32Bit requires a kernel that supports 32bit emulation";
- }
- ];
-
- systemd.tmpfiles.settings.opengl = {
- "/run/opengl-driver"."L+".argument = toString package;
- "/run/opengl-driver-32" =
- if pkgs.stdenv.isi686 then
- { "L+".argument = "opengl-driver"; }
- else if cfg.driSupport32Bit then
- { "L+".argument = toString package32; }
- else
- { "r" = {}; };
- };
-
- environment.sessionVariables.LD_LIBRARY_PATH = lib.mkIf cfg.setLdLibraryPath
- ([ "/run/opengl-driver/lib" ] ++ lib.optional cfg.driSupport32Bit "/run/opengl-driver-32/lib");
-
- hardware.opengl.package = lib.mkDefault pkgs.mesa.drivers;
- hardware.opengl.package32 = lib.mkDefault pkgs.pkgsi686Linux.mesa.drivers;
-
- boot.extraModulePackages = lib.optional (lib.elem "virtualbox" videoDrivers) kernelPackages.virtualboxGuestAdditions;
- };
-}
diff --git a/nixos/modules/hardware/video/nvidia.nix b/nixos/modules/hardware/video/nvidia.nix
index ae5c2aa7a034..0274dfcaa70f 100644
--- a/nixos/modules/hardware/video/nvidia.nix
+++ b/nixos/modules/hardware/video/nvidia.nix
@@ -297,7 +297,7 @@ in
KERNEL=="nvidia_uvm", RUN+="${pkgs.runtimeShell} -c 'mknod -m 666 /dev/nvidia-uvm c $$(grep nvidia-uvm /proc/devices | cut -d \ -f 1) 0'"
KERNEL=="nvidia_uvm", RUN+="${pkgs.runtimeShell} -c 'mknod -m 666 /dev/nvidia-uvm-tools c $$(grep nvidia-uvm /proc/devices | cut -d \ -f 1) 1'"
'';
- hardware.opengl = {
+ hardware.graphics = {
extraPackages = [ nvidia_x11.out ];
extraPackages32 = [ nvidia_x11.lib32 ];
};
@@ -467,7 +467,7 @@ in
"egl/egl_external_platform.d".source = "/run/opengl-driver/share/egl/egl_external_platform.d/";
};
- hardware.opengl = {
+ hardware.graphics = {
extraPackages = [ pkgs.nvidia-vaapi-driver ];
extraPackages32 = [ pkgs.pkgsi686Linux.nvidia-vaapi-driver ];
};