Mesa-24.3.1

Introduction to Mesa

Mesa is an OpenGL compatible 3D graphics library.

[Note]

Note

Mesa is updated relatively often. You may want to use the latest available 24.3.x mesa version.

[Note]

Note

Development versions of BLFS may not build or run some packages properly if LFS or dependencies have been updated since the most recent stable versions of the books.

Package Information

  • Download (HTTP): https://mesa.freedesktop.org/archive/mesa-24.3.1.tar.xz

  • Download MD5 sum: ab0c9a102e6713fca2b8c955b368fe57

  • Download size: 30 MB

  • Estimated disk space required: 1.3 GB (with docs, add 569 MB for tests)

  • Estimated build time: 4.7 SBU (with docs; add 1.5 SBU for tests; both with parallelism=4)

Additional Downloads

Mesa Dependencies

Required

Xorg Libraries, libdrm-2.4.124, Mako-1.3.8, and PyYAML-6.0.2

Recommended

[Note]

Note

Choosing Mesa Drivers

In the instructions below, all the available drivers are built. That will almost always work. However, it is not efficient. Depending on your video hardware, you probably need only specific drivers.

The first thing you need to know is which type of video device you have. In some cases it is built into the CPU. In others it is a separate PCI card. In either case you can tell what video hardware you have by installing pciutils-3.13.0 and running:

lspci | grep VGA

The video device is most likely one of three families: AMD, Intel, or NVIDIA. See the Command Explanations for -D gallium-drivers=auto below to see what options are available for your specific video hardware (or emulated video hardware). You should probably add the softpipe or llvmpipe option as a backup driver.

For 'platforms' you can select x11 and/or wayland. Note that in BLFS currently only Gnome and KDE can use wayland. If you are not going to use one of those desktop environments then you probably only want x11.

For 'vulkan-drivers' you may want to limit the selection to your current hardware. These drivers are used by some specific applications. For example, ffmpeg (including ffplay) will use Vulkan instead of OpenGL for rendering video on the GPU. If you do not want to do this you may or may not want to install them. See the Command Explanations for -D vulkan-drivers=auto below to see what options are available for your specific video hardware (or emulated video hardware). You should probably add the swrast option as a backup driver unless you don't need Vulkan at all.

Optional

libgcrypt-1.11.0, libunwind-1.8.1, lm-sensors-3-6-0, Nettle-3.10, Valgrind-3.24.0, mesa-demos (provides more than 300 extra demos to test Mesa; this includes the same programs added by the patch above), Bellagio OpenMAX Integration Layer (for mobile platforms), and libtizonia,

[Note]

Note

An Internet connection is needed for building this package.

Kernel Configuration

Enable the following options in the kernel configuration and recompile the kernel if necessary:

Device Drivers --->
  Graphics support --->
    <*/M> Direct Rendering Manager (XFree86 4.1.0 and higher DRI support) --->
                                                                      ...  [DRM]
      # For r300 or r600:
      < /*/M> ATI Radeon                                            [DRM_RADEON]
      # For radeonsi:
      < /*/M> AMD GPU                                               [DRM_AMDGPU]
      [*]       Enable amdgpu support for SI parts               [DRM_AMDGPU_SI]
      [*]       Enable amdgpu support for CIK parts             [DRM_AMDGPU_CIK]
        Display Engine Configuration --->
        [*]   AMD DC - Enable new display engine                    [DRM_AMD_DC]
      # For nouveau:
      < /*/M> Nouveau (NVIDIA) cards                               [DRM_NOUVEAU]
      [*]       Use GSP firmware for Turing/Ampere (needs firmware installed)
                                                  ...  [DRM_NOUVEAU_GSP_DEFAULT]
      # For i915, crocus, or iris:
      < /*/M> Intel 8xx/9xx/G3x/G4x/HD Graphics                       [DRM_I915]
      # For llvmpipe or softpipe:
      < /*>   Virtual GEM provider                                    [DRM_VGEM]
      # For svga:
      < /*/M> DRM driver for VMware Virtual GPU                     [DRM_VMWGFX]
[Note]

Note

The corresponding Mesa Gallium3D driver name is provided as the comment for the configuration entries. If you don't know the name of the Mesa Gallium3D driver for your GPU, see Mesa Gallium3D Drivers below.

CONFIG_DRM_RADEON, CONFIG_DRM_AMDGPU, CONFIG_DRM_NOUVEAU, and CONFIG_DRM_I915 may require firmware. See About Firmware for details.

Selecting CONFIG_DRM_RADEON, CONFIG_DRM_AMDGPU, or CONFIG_DRM_NOUVEAU as y is not recommended. If it is, any required firmware must be built as a part of the kernel image or the initramfs for the driver to function correctly.

The sub-entries under CONFIG_DRM_AMDGPU are used to ensure the AMDGPU kernel driver supports all GPUs using the radeonsi driver. They are not needed if you won't need CONFIG_DRM_AMDGPU itself. They may be unneeded for some GPU models.

For llvmpipe or softpipe, CONFIG_DRM_VGEM is required or X clients may fail to start with a cryptic message Error: couldn't get an RGB, Double-buffered visual. Strictly speaking, it can be compiled as a module. But the module will not be loaded automatically, so it's more convenient to build it as a part of the kernel image.

Installation of Mesa

If you have downloaded the xdemos patch (needed if testing the Xorg installation per BLFS instructions), apply it by running the following command:

patch -Np1 -i ../mesa-add_xdemos-4.patch

Install Mesa by running the following commands:

mkdir build &&
cd    build &&

meson setup ..                 \
      --prefix=$XORG_PREFIX    \
      --buildtype=release      \
      -D platforms=x11,wayland \
      -D gallium-drivers=auto  \
      -D vulkan-drivers=auto   \
      -D valgrind=disabled     \
      -D video-codecs=all      \
      -D libunwind=disabled    &&

ninja
[Warning]

Warning

Please ask your lawyer or remove the -D video-codecs=all option if you will distribute the compiled Mesa libraries and drivers to others.

To test the results, issue: meson configure -D build-tests=true && ninja test.

Now, as the root user:

ninja install

If desired, install the optional documentation by running the following commands as the root user:

cp -rv ../docs -T /usr/share/doc/mesa-24.3.1

Command Explanations

--buildtype=release: This switch ensures a fully-optimized build, and disables debug assertions which will severely slow down the libraries in certain use-cases. Without this switch, build sizes can span into the 2 GB range.

-D gallium-drivers=auto: This parameter controls which Gallium3D drivers should be built:

  • auto selects all Gallium3D drivers available for x86. With a comma-separated list, only a subset of these drivers will be built. If you precisely know which drivers you need, you can select them explicitly. For example, -D gallium-drivers=radeonsi,iris,llvmpipe.

  • r300 (for ATI Radeon 9000 or Radeon X series)

  • r600 (for AMD/ATI Radeon HD 2000-6000 series)

  • radeonsi (for AMD Radeon HD 7000 or newer AMD GPU models)

  • nouveau (for supported NVIDIA GPUs, they are listed as all 3D features either DONE or N/A in the Nouveau status page)

  • virgl (for a QEMU virtual GPU with virglrender support; note that BLFS qemu-9.2.0 is not built with virglrender)

  • svga (for a VMWare virtual GPU)

  • llvmpipe (using CPU for 3D rasterization. Note that it's much slower than using a modern 3D-capable GPU, so it should be only used if the GPU is not supported by other drivers)

  • softpipe (also using CPU for 3D rasterization, but slower than llvmpipe. There is not much reason to use it unless LLVM is not available)

  • iris (for Intel GPUs shipped with Broadwell or newer CPUs, or as a dedicated PCIe card)

  • crocus (for Intel GMA 3000, X3000 series, 4000 series, or X4000 series GPUs shipped with chipsets, or Intel HD GPUs shipped with pre-Broadwell CPUs)

  • i915 (for Intel GMA 900, 950, 3100, or 3150 GPUs shipped with chipsets or Atom D/N 4xx/5xx CPUs)

  • zink (uses Vulkan to implement OpenGL, and while unstable at times, it can be a decent replacement for non-performant gallium drivers like nouveau)

-D vulkan-drivers=auto: This parameter controls which Vulkan drivers should be built:

  • auto selects all Vulkan drivers available for x86. With a comma-separated list, only a subset of these drivers will be built. If you precisely know which drivers you need, you can select them explicitly. For example, -D vulkan-drivers=amd,nouveau,swrast.

  • amd (for AMD Radeon HD 7730 or newer AMD GPUs)

  • intel (for Intel GPUs shipped with Skylake or newer CPUs, or as a dedicated PCIe card)

  • intel_hasvk (for Intel GPUs shipped with Ivy Bridge, Haswell, or Broadwell CPUs)

  • nouveau (for GTX 16XX, RTX 20XX, or newer NVIDIA GPUs)

  • swrast (for using the CPU for 3D rasterization) Note that it's much slower than using a modern 3D-capable GPU, so it should be only used if the GPU is not supported by other drivers.

  • "" (empty list, use -D vulkan-drivers="" if you've not installed and you don't plan to install Vulkan-Loader-1.3.301)

-D platforms=...: This parameter controls which windowing systems will be supported. Available linux platforms are x11 and wayland.

-D valgrind=disabled: This parameter disables the usage of Valgrind during the build process. Remove this parameter if you have Valgrind installed, and wish to check for memory leaks.

-D video-codecs=all: This parameter enables building codecs for video formats covered by third-party patents.

-D libunwind=disabled: This parameter disables the usage of libunwind.

meson configure -D build-tests=true: This command will reconfigure the build to set -D build-tests=true, but keep the other options specified in the meson setup command unchanged. It allows ninja test to build and run unit tests.

-D egl-native-platform="...": This parameter controls which Embedded Graphics Library support will be built. Available linux options are auto (default), x11, wayland, surfaceless, and drm.

-D legacy-x11="..." This parameter controls which legacy X11 features get built-in support. Available linux options are none (default) and dri2. These features are rarely needed anymore.

Contents

Installed Programs: glxgears, glxinfo, mme_fermi_sim_hw_test, and mme_tu104_sim_hw_test
Installed Libraries: libEGL.so, libGL.so, libGLESv1_CM.so, libGLESv2.so, libgbm.so, libglapi.so, libgallium-24.3.1.so, and libxatracker.so
Installed DRI Driver Stubs: libdril_dri.so and symlinks to it: crocus_dri.so, i915_dri.so, iris_dri.so, kms_swrast_dri.so, nouveau_dri.so, r300_dri.so, r600_dri.so, r600_drv_video.so, radeonsi_dri.so, swrast_dri.so, virtio_gpu_dri.so, vmwgfx_dri.so, and zink_dri.so
Installed VA-API Drivers: nouveau_drv_video.so, radeonsi_drv_video.so, and virtio_gpu_drv_video.so,
Installed GBM Backends: dri_gbm.so
Installed VDPAU Drivers: libvdpau_nouveau.so, libvdpau_r600.so, libvdpau_radeonsi.so, and libvdpau_virtio_gpu.so (Many of these drivers are hard-linked).
Installed Vulkan Drivers: libvulkan_intel_hasvk.so, libvulkan_intel.so, libvulkan_lvp.so, libvulkan_nouveau.so, and libvulkan_radeon.so
Installed Directories: $XORG_PREFIX/{include/{EGL,GLES,GLES2,GLES3,KHR}, $XORG_PREFIX/lib/{dri,gbm,vdpau}}, $XORG_PREFIX/share/drirc.d (contains workarounds for various applications, particularly browsers and games), $XORG_PREFIX/share/vulkan, and /usr/share/doc/mesa-24.3.1

Short Descriptions

glxgears

is a GL demo useful for troubleshooting graphics problems

glxinfo

is a diagnostic program that displays information about the graphics hardware and installed GL libraries

dri_gbm.so

implements Graphics Buffer Management functions needed by libgbm on top of libdrm

libdril_dri.so

is a stub allowing Xorg server to co-operate with the Gallium3D drivers

libEGL.so

provides a native platform graphics interface as defined by the EGL-1.4 specification

libgallium-24.3.1.so

contains all the Gallium3D drivers

libgbm.so

is the Mesa Graphics Buffer Manager library

libglapi.so

is the Mesa implementation of the OpenGL API

libGLESv1_CM.so

is the Mesa OpenGL ES 1.1 library

libGLES2.so

is the Mesa OpenGL ES 2.0 library

libGL.so

is the main Mesa OpenGL library

libxatracker.so

is the XA state tracker for the VMWare vmwgfx driver