Skip to content
This repository has been archived by the owner on Jun 1, 2020. It is now read-only.
/ nvidia-xrun Public archive
forked from Witko/nvidia-xrun

Utility to run separate X with discrete nvidia graphics with full performance (with various patches for Ubuntu).

License

Notifications You must be signed in to change notification settings

BobbyWibowo/nvidia-xrun

 
 

Repository files navigation

nvidia-xrun

These utility scripts aim to make the life easier for nvidia cards users. It started with a revelation that bumblebee in current state offers very poor performance. This solution offers a bit more complicated procedure but offers a full GPU utilization(in terms of linux drivers)

Usage:

  1. switch to free tty
  2. login
  3. run nvidia-xrun [app]
  4. enjoy

Passwordless sudo

Whitelisting nvidia-toggle in your sudoer's file allows you to use nvidia-xrun without entering your password:

%users ALL=(root) NOPASSWD:/usr/bin/nvidia-toggle

...where /usr/bin/nvidia-toggle is the full path to the nvidia-toggle script.

Note: it is a good practice to ensure binaries/scripts/etc. that are whitelisted for passwordless sudo are owned by root.

The systemd service can be used to completely remove the card from the kernel device tree (so that it won't even show in lspci output), and this will prevent the nvidia module to be loaded, so that we can take advantage of the kernel PM features to keep the card switched off.

The service can be enabled with this command:

# systemctl enable nvidia-xrun-pm

When the nvidia-xrun command is used, the device is added again to the tree so that the nvidia module can be loaded properly: nvidia-xrun will remove the device and enable PM again after the application terminates.

Structure

  • nvidia-xrun: /usr/bin/nvidia-xrun - the executable script
  • nvidia-xorg.conf: /etc/X11/nvidia-xorg.conf - the main X confing file
  • nvidia-xinitrc: /etc/X11/xinit/nvidia-xinitrc - xinitrc config file (contains the setting of provider output source)
  • /etc/X11/xinit/nvidia-xinitrc.d - custom xinitrc scripts directory
  • /etc/X11/nvidia-xinitrc.d - custom X config directory
  • nvidia-xrun-pm.service: /etc/systemd/system/nvidia-xrun-pm.service - systemd service
  • blacklist-nvidia-xrun.conf: /etc/modprobe.d/blacklist-nvidia-xrun.conf - avoid nvidia driver to load on boot (this file should be sufficient for Ubuntu)
  • config/nvidia-xrun: /etc/default/nvidia-xrun - nvidia-xrun config file
  • launchers/nvidia-xrun-openbox.desktop: /usr/share/xsessions/nvidia-xrun-openbox.desktop - xsession file for openbox
  • launchers/nvidia-xrun-plasma.desktop: /usr/share/xsessions/nvidia-xrun-plasma.desktop - xsession file for plasma

Optional

  • user-config/autostart: $XDG_CONFIG_HOME/openbox/autostart - programs to launch after Openbox (contains a bit of my own tinkers, feel free to modify)
  • user-config/nvidia-xinitrc: $XDG_CONFIG_HOME/X11/nvidia-xinitrc - user-level custom xinit script file (contains a bit of my own tinkers, feel free to modify)

Setting the right bus id

Usually the 1:0:0 bus is correct. If this is not your case(you can find out through lspci or bbswitch output mesages) you can create a conf script for example nano /etc/X11/nvidia-xorg.conf.d/30-nvidia.conf to set the proper bus id:

Section "Device"
  Identifier "nvidia"
  Driver "nvidia"
  BusID "PCI:2:0:0"
EndSection

You can use this command to get the bus id:

lspci | grep -i nvidia | awk '{print $1}'

Also this way you can adjust some nvidia settings if you encounter issues:

Section "Screen"
  Identifier "nvidia"
  Device "nvidia"
#  Option "AllowEmptyInitialConfiguration" "Yes"
#  Option "UseDisplayDevice" "none"
EndSection

In order to make power management features work properly, you need to make sure that bus ids in /etc/default/nvidia-xrun are correctly set for both the NVIDIA graphic card and the PCI express controller that hosts it. You should be able to find both the ids in the output of lshw: the PCIe controller is usually displayed right before the graphic card.

Automatically run window manager

For convenience you can create $XDG_CONFIG_HOME/X11/nvidia-xinitrc and put there your favourite window manager:

if [ $# -gt 0 ]; then
    $*
else
    openbox-session
#   startkde
fi

With this you do not need to specify the app and you can simply run:

nvidia-xrun

AUR Package

The Arch Linux User Repository package can be found here.

COPR Repository for Enterprise Linux, Fedora, Mageia, and openSUSE

The RPM packages and repository details for all supported distributions can be found on the ekultails/nvidia-xrun COPR overview page.

Install (Enterprise Linux and Fedora)

sudo dnf copr enable ekultails/nvidia-xrun
sudo dnf install nvidia-xrun

Troubleshooting

Steam issues

Yes unfortunately running Steam directly with nvidia-xrun does not work well - I recommend to use some window manager like openbox.

HiDPI issue

When using openbox on a HiDPI (i.e. 4k) display, everything could be so small that is difficult to read. To fix, you can change the DPI settings in ~/.Xresources (~/.Xdefaults) file by adding/changing Xft.dpi setting. For example :

Xft.dpi: 192

nouveau driver conflict

nouveau driver should be automatically blacklisted by nvidia but in case it is not, nvidia might not get access to GPU. Then you need to manually blacklist nouveau following Arch wiki https://wiki.archlinux.org/index.php/kernel_modules#Blacklisting.

avoid nvidia driver to load on boot

nvidia driver may load itself on boot, then nvidia-xrun will fail to start Xorg session. To avoid that, you should blacklist it (see link above). Also sometimes, blacklisting is not enough and you should use some hack to really avoid it to load. For example, adding install nvidia /bin/false to /etc/modprobe.d/nvidia.conf will make every load to fail. In that case, you should add --ignore-install to modprobe calls in nvidia-xrun script.

Vulkan does not work

Check https://wiki.archlinux.org/index.php/Vulkan. Try any of the following:

  • Remove package vulkan-intel.
  • Set VK_ICD_FILENAMES=/usr/share/vulkan/icd.d/nvidia_icd.json (also used in user-config/nvidia-xinitrc).
  • Run sudo vulkaninfo on your terminal once on every boot (necessary if using nvidia-drm.modeset=1 due to a bug; also used in user-config/autostart).

About

Utility to run separate X with discrete nvidia graphics with full performance (with various patches for Ubuntu).

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Shell 100.0%