This is Gentoo's testing wiki. It is a non-operational environment and its textual content is outdated.
Please visit our production wiki at https://wiki.gentoo.org
Xorg/Hardware 3D acceleration guide
This document is a guide to getting 3D acceleration working using the DRM with Xorg in Gentoo.
Introduction
What is hardware 3D acceleration and why do I want it?
With hardware 3D acceleration, three-dimensional rendering uses the graphics processor on the video card instead of taking up valuable CPU resources drawing 3D images. It's also referred to as "hardware acceleration" instead of "software acceleration" because without this 3D acceleration the CPU is forced to draw everything itself using the Mesa software rendering libraries, which takes up quite a bit of processing power.
While Xorg typically supports 2D hardware acceleration, it often lacks hardware 3D acceleration. Three-dimensional hardware acceleration is valuable in situations requiring rendering of 3D objects such as games, 3D CAD, and modeling.
Getting 3D acceleration
In many cases, both binary and open-source drivers exist. Open source drivers are preferable since we're using Linux and open source is one of its underlying principles. Sometimes, binary drivers are the only option, especially if the graphics card is so new that open source drivers have not yet been written to support its features. Binary drivers include x11-drivers/nvidia-drivers for nVidia cards and x11-drivers/xf86-video-ati (used to be x11-drivers/ati-drivers) for older AMD/ATI cards, dev-libs/amdgpu-pro-opencl for newer AMD cards.
What is DRI?
The Direct Rendering Infrastructure, also known as the DRI, is a framework for allowing direct access to graphics hardware in a safe and efficient manner. It includes changes to the X server, to several client libraries and to the kernel. The first major use for the DRI is to create fast OpenGL implementations.
What is the DRM and how does it relate to regular Xorg?
The DRM (Direct Rendering Manager) is an enhancement to Xorg that adds 3D acceleration for cards by adding the kernel module necessary for direct rendering.
Purpose
This guide is for people who can't get direct rendering working with just Xorg. The DRM works for the following drivers:
- 3dfx
- amdgpu
- amdgpu-pro (closed source)
- fglrx (closed source; deprecated)
- intel
- matrox
- nouveau
- nvidia-drivers (closed source)
- rage128
- radeon
- radeonhd (deprecated)
- mach64
- sis300
- via
See the DRI homepage for more info and documentation.
Install Xorg and configure the kernel
Install Xorg
Please read our Xorg Configuration Guide to get Xorg up and running.
Configure the kernel
Probe for the chipset and enable just that one.
root #
emerge --ask sys-apps/pciutils
root #
lspci | grep AGP
# 00:01.0 PCI bridge: Intel Corp. 440BX/ZX/DX - 82443BX/ZX/DX AGP bridge (rev 03)
The output may not match the above due to different hardware.
If the chipset is not supported by the kernel, some success may be obtained by passing agp=try_unsupported
as a kernel parameter. This will use Intel's generic routines for AGP support. To add this parameter, edit the bootloader's configuration file.
Most, if not all, kernels should have these options. This was configured using a standard sys-kernel/gentoo-sources kernel.
root #
ls -l /usr/src/linux
lrwxrwxrwx 1 root root 22 2007-02-14 20:12 /usr/src/linux -> linux-2.6.18-gentoo-r4
Make sure /usr/src/linux links to the current kernel:
user $
eselect kernel list
OR
root #
cd /usr/src/linux
root #
make menuconfig
'"`UNIQ--pre-00000003-QINU`"'
Compile and install the kernel
root #
make && make install && make modules_install
Don't forget to set up grub.conf or lilo.conf.
When using LILO, issue:
root #
lilo
When using GRUB 2, run:
root #
grub-mkconfig -o /boot/grub/grub.cfg
Add appropriate user(s) to the video group
Next, add the appropriate user(s) to the video group:
root #
gpasswd -a $USER video
Configure direct rendering
Configure Xorg
Hopefully just adding the appropriate user to the video
group is sufficient to enable direct rendering. However, Xorg may need some additional configuration via the /etc/X11/xorg.conf.d/ directory. New configuration files created in this directory may be named any alpha-numeric file name, as long as the file suffix ends in .conf. Open up a favorite text editor and create a file with this inside it:
Section "Device" Driver "radeon" EndSection Section "dri" Mode 0666 EndSection
Replace radeon
with the name of the appropriate driver.
Changes to /etc/conf.d/modules
You will need to add the module name that your card uses to /etc/conf.d/modules to ensure that the module is loaded automatically when the system starts up.
modules="intel-agp" # Substitute with your driver
If you compiled
agpgart
as a module, you will also need to add it to /etc/conf.d/modules.Test 3D acceleration
Reboot to the new kernel
Reboot your computer to your new kernel and login as a normal user. It's time to see if you have direct rendering and how good it is. glxinfo
and glxgears
are part of the x11-apps/mesa-progs package, so make sure it is installed before you attempt to run these commands.
user $
startx
No need to load modules for your driver or agpgart, even if you compiled them as a module. They will be loaded automatically.
user $
glxinfo | grep rendering
direct rendering: Yes
If it outputs "No", you don't have 3D acceleration.
user $
glxgears
Test your frames per second (FPS) at the default size. The number should be significantly higher than before configuring DRM. Do this while the CPU is as idle as possible.
FPS may be limited by your screen's refresh rate, so keep this in mind if
glxgears
reports only about 70-100 FPS. games-fps/xonotic or other 3D games are better benchmarking tools, as they give you real-world performance results.Get the most out of direct rendering
If you want to set more features, for performance or other reasons, check out the feature matrix on the DRI web site or the features listing on Sourceforge.
Troubleshooting
Problem with rendering
Try modprobe radeon
before you start the X server (replace radeon
with the name of your driver). Also, try building agpgart into the kernel instead of as a module.
Failed to load kernel module agpgart when running startx
error: "[drm] failed to load kernel module agpgart" after invoking `startx` is caused by presents of compiled agpgart in the kernel instead of as a module. Ignore it unless you're having problems.
TV-Out on Radeon GPU
The drivers originally developed by the GATOS project have been merged into Xorg's codebase. You don't need anything special for TV-Out; x11-drivers/xf86-video-ati will work just fine.
Compatibility for freshly released GPUs
Try out the binary drivers. For AMD cards, use ati-drivers
. If those don't support it, use fbdev. It's slow, but it works.
PCI card doesn't work properly
Create a config file in /etc/X11/xorg.conf.d/; name it anything you want as long as it ends in .conf. Add the following to it:
Section "Device" Option "ForcePCIMode" "True" EndSection
External resources
- Direct rendering (DRI) using X11-DRM HOWTO on the Gentoo forums
- Radeon 7000-9700 DRI CVS Install Guide on the Gentoo forums
- https://dri.freedesktop.org/
This page is based on a document formerly found on our main website gentoo.org.
The following people contributed to the original document: Donnie Berkholz (dberkholz), peesh, Joshua Saddler (nightmorph)
They are listed here because wiki history does not allow for any external attribution. If you edit the wiki article, please do not add yourself here; your contributions are recorded on each article's associated history page.