Fix: enhance NVIDIA configuration for improved performance and compatibility on desktop and laptop

This commit is contained in:
2025-10-28 01:39:52 +00:00
parent 2318dbe18e
commit acb1fe7f2b
6 changed files with 230 additions and 0 deletions

58
NVIDIA-SETUP.md Normal file
View File

@@ -0,0 +1,58 @@
# NVIDIA Setup Notes
## Laptop Bus ID Configuration Required
**File to edit:** `/home/zeph/nix-flake/system/nvidia-laptop.nix`
### Steps:
1. Run this command on your **laptop**:
```bash
sudo lshw -c display
```
2. Look for the `bus info` lines in the output:
- **Intel GPU**: `bus info: pci@0000:00:02.0`
- **NVIDIA GPU**: `bus info: pci@0000:01:00.0`
3. Convert the PCI addresses to NixOS format:
- `pci@0000:00:02.0` → `PCI:0:2:0` (Intel)
- `pci@0000:01:00.0` → `PCI:1:0:0` (NVIDIA)
4. Update the values in `nvidia-laptop.nix`:
```nix
intelBusId = "PCI:0:2:0"; # Replace with your Intel bus ID
nvidiaBusId = "PCI:1:0:0"; # Replace with your NVIDIA bus ID
```
5. Rebuild after updating:
```bash
sudo nixos-rebuild switch --flake /home/zeph/nix-flake#laptop
```
### Format Conversion Example:
```
pci@0000:XX:YY.Z → PCI:XX:YY:Z
```
Remove the `0000:` prefix and convert the `.` to `:`
---
## Testing NVIDIA Setup
### Desktop (RTX 3080):
- `nvidia-smi` - Check if driver is loaded
- `nvtop` - Monitor GPU usage
- `glxinfo | grep NVIDIA` - Verify OpenGL
### Laptop (GTX 1050):
- `nvidia-smi` - Check if driver is loaded
- `nvidia-offload glxgears` - Test offload mode
- `nvtop` - Monitor both Intel and NVIDIA GPUs
### Using NVIDIA on Laptop:
- Normal apps use Intel iGPU (better battery)
- Prefix GPU-intensive apps with `nvidia-offload`:
```bash
nvidia-offload <program>
```

View File

@@ -31,6 +31,15 @@
"HYPRCURSOR_THEME,Bibata-Modern-Ice" "HYPRCURSOR_THEME,Bibata-Modern-Ice"
"HYPRCURSOR_SIZE,24" "HYPRCURSOR_SIZE,24"
"QT_QPA_PLATFORMTHEME,qt5ct" "QT_QPA_PLATFORMTHEME,qt5ct"
# NVIDIA specific environment variables
"LIBVA_DRIVER_NAME,nvidia" # Hardware acceleration
"GBM_BACKEND,nvidia-drm" # Force GBM backend
"__GLX_VENDOR_LIBRARY_NAME,nvidia" # GLX vendor
"__GL_GSYNC_ALLOWED,1" # Enable G-Sync if supported
"__GL_VRR_ALLOWED,0" # Disable VRR to avoid game issues
"WLR_NO_HARDWARE_CURSORS,1" # Fix cursor issues on NVIDIA
"WLR_DRM_NO_ATOMIC,1" # Legacy mode (try disabling if issues)
]; ];
# Input configuration # Input configuration

View File

@@ -1,7 +1,13 @@
{ config, pkgs, inputs, ... }: { config, pkgs, inputs, ... }:
{ {
imports = [
../../system/nvidia.nix
];
# Desktop PC specific configuration # Desktop PC specific configuration
# RTX 3080 - Enable open-source kernel module for better performance
hardware.nvidia.open = true;
networking.hostName = "zeph-desktop"; networking.hostName = "zeph-desktop";
@@ -50,6 +56,11 @@
# discord # discord
# steam # steam
# obs-studio # obs-studio
# NVIDIA utilities
nvtopPackages.full # GPU monitoring tool
vulkan-tools # Vulkan utilities (vulkaninfo, etc.)
glxinfo # OpenGL information
]; ];
# Gaming support (uncomment if needed) # Gaming support (uncomment if needed)

View File

@@ -1,6 +1,10 @@
{ config, pkgs, inputs, ... }: { config, pkgs, inputs, ... }:
{ {
imports = [
../../system/nvidia-laptop.nix
];
# Laptop specific configuration # Laptop specific configuration
networking.hostName = "zeph-laptop"; networking.hostName = "zeph-laptop";
@@ -65,6 +69,11 @@
# Add laptop-specific packages here # Add laptop-specific packages here
brightnessctl # Screen brightness control brightnessctl # Screen brightness control
acpi # Battery info acpi # Battery info
# NVIDIA utilities
nvtopPackages.full # GPU monitoring
vulkan-tools # Vulkan utilities
glxinfo # OpenGL info
]; ];
# Enable touchpad support # Enable touchpad support

81
system/nvidia-laptop.nix Normal file
View File

@@ -0,0 +1,81 @@
{ config, pkgs, ... }:
{
# NVIDIA Configuration for Laptop with Hybrid Graphics (Intel + GTX 1050)
# Enable OpenGL and NVIDIA drivers
hardware.graphics = {
enable = true;
enable32Bit = true;
};
# Load NVIDIA driver
services.xserver.videoDrivers = [ "nvidia" ];
hardware.nvidia = {
# Modesetting required for Wayland
modesetting.enable = true;
# NVIDIA power management
# Recommended for laptops to save battery
powerManagement.enable = true;
# Fine-grained power management
# Turns off GPU when not in use - EXPERIMENTAL
# Can help with battery life but may cause issues
powerManagement.finegrained = false;
# GTX 1050 is Pascal architecture - must use proprietary driver
open = false;
# Enable nvidia-settings
nvidiaSettings = true;
# Use stable driver
package = config.boot.kernelPackages.nvidiaPackages.stable;
# PRIME configuration for hybrid graphics
prime = {
# Offload mode: Intel for regular use, NVIDIA on-demand
# This saves battery by keeping NVIDIA GPU off most of the time
offload = {
enable = true;
enableOffloadCmd = true; # Adds nvidia-offload command
};
# IMPORTANT: Find your actual Bus IDs with: sudo lshw -c display
# Then update these values accordingly
# Example output:
# Intel: bus info: pci@0000:00:02.0 → intelBusId = "PCI:0:2:0"
# NVIDIA: bus info: pci@0000:01:00.0 → nvidiaBusId = "PCI:1:0:0"
# Placeholder values - UPDATE THESE!
intelBusId = "PCI:0:2:0"; # Usually correct for Intel iGPU
nvidiaBusId = "PCI:1:0:0"; # Common for laptop discrete GPU
# Alternative: Use sync mode instead of offload
# This runs everything on NVIDIA (worse battery, better performance)
# Uncomment to enable:
# sync.enable = true;
# offload.enable = false; # Disable offload if using sync
};
};
# Kernel parameters for better NVIDIA support
boot.kernelParams = [
"nvidia-drm.modeset=1" # Required for Wayland
];
# Create nvidia-offload command for easy GPU switching
# Usage: nvidia-offload <program>
# Example: nvidia-offload glxgears
environment.systemPackages = with pkgs; [
(writeShellScriptBin "nvidia-offload" ''
export __NV_PRIME_RENDER_OFFLOAD=1
export __NV_PRIME_RENDER_OFFLOAD_PROVIDER=NVIDIA-G0
export __GLX_VENDOR_LIBRARY_NAME=nvidia
export __VK_LAYER_NV_optimus=NVIDIA_only
exec "$@"
'')
];
}

62
system/nvidia.nix Normal file
View File

@@ -0,0 +1,62 @@
{ config, pkgs, ... }:
{
# NVIDIA Driver Configuration for NixOS
# Enable OpenGL and NVIDIA drivers
hardware.graphics = {
enable = true;
enable32Bit = true; # For 32-bit applications (games, Wine, etc.)
};
# Load NVIDIA driver for Xorg and Wayland
services.xserver.videoDrivers = [ "nvidia" ];
hardware.nvidia = {
# Modesetting is required for Wayland
modesetting.enable = true;
# Enable power management (experimental)
# Helps with suspend/resume and may reduce power consumption
powerManagement.enable = false;
# Fine-grained power management (turns off GPU when not in use)
# Experimental and can cause sleep/suspend issues
powerManagement.finegrained = false;
# Use the open source kernel module (not nouveau, but nvidia-open)
# Only works on Turing and newer (RTX 20 series+, GTX 16 series+)
# RTX 3080 supports this, but GTX 1050 does not
# This can be overridden per-host
open = false;
# Enable the Nvidia settings menu (nvidia-settings)
nvidiaSettings = true;
# Select the appropriate driver version
# Options: stable, beta, legacy_470, legacy_390, legacy_340
package = config.boot.kernelPackages.nvidiaPackages.stable;
};
# Optional: For laptop with hybrid graphics (Intel/AMD + NVIDIA)
# Uncomment the following lines if you have a hybrid setup:
# hardware.nvidia.prime = {
# # Make sure to use the correct Bus ID values for your system!
# # Find them with: sudo lshw -c display
# offload = {
# enable = true;
# enableOffloadCmd = true;
# };
# # Bus ID of the Intel GPU (example)
# intelBusId = "PCI:0:2:0";
# # Bus ID of the NVIDIA GPU (example)
# nvidiaBusId = "PCI:1:0:0";
# };
# Kernel parameters
boot.kernelParams = [
# Uncomment if you experience issues:
# "nvidia-drm.modeset=1"
];
}