source: x/installing/mesa.xml@ 09b6c35

11.2 11.3 12.0 12.1 kea ken/TL2024 ken/inkscape-core-mods ken/tuningfonts lazarus lxqt plabs/newcss plabs/python-mods python3.11 qt5new rahul/power-profiles-daemon renodr/vulkan-addition trunk xry111/llvm18 xry111/soup3 xry111/xf86-video-removal
Last change on this file since 09b6c35 was 5190c76b, checked in by Bruce Dubbs <bdubbs@…>, 2 years ago

Update to mesa-22.1.1.

  • Property mode set to 100644
File size: 17.4 KB
RevLine 
[868c7c2]1<?xml version="1.0" encoding="ISO-8859-1"?>
[6732c094]2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
[868c7c2]4 <!ENTITY % general-entities SYSTEM "../../general.ent">
5 %general-entities;
6
[c0a8c0dc]7 <!ENTITY mesa-download-http "https://mesa.freedesktop.org/archive/mesa-&mesa-version;.tar.xz">
8 <!ENTITY mesa-download-ftp "ftp://ftp.freedesktop.org/pub/mesa/mesa-&mesa-version;.tar.xz">
[5190c76b]9 <!ENTITY mesa-md5sum "56d5b4145097ff3b5807a2b16b52d8cf">
[bee072a]10 <!ENTITY mesa-size "15 MB">
11 <!ENTITY mesa-buildsize "419 MB (with docs, add 375 MB for tests)">
12 <!ENTITY mesa-time "2.8 SBU (Using parallelism=4; with docs, add 0.5 SBU for tests)">
[868c7c2]13]>
14
[7a395d1]15<sect1 id="mesa" xreflabel="Mesa-&mesa-version;">
16 <?dbhtml filename="mesa.html"?>
[868c7c2]17
18 <sect1info>
19 <date>$Date$</date>
20 </sect1info>
21
[7a395d1]22 <title>Mesa-&mesa-version;</title>
[868c7c2]23
[7a395d1]24 <indexterm zone="mesa">
25 <primary sortas="a-Mesa">Mesa</primary>
[868c7c2]26 </indexterm>
27
28 <sect2 role="package">
[7a395d1]29 <title>Introduction to Mesa</title>
[868c7c2]30
[eb425b4]31 <para>
32 <application>Mesa</application> is an OpenGL compatible 3D graphics
33 library.
34 </para>
[868c7c2]35
[fdcf97c7]36 <note>
37 <para>
38 <application>Mesa</application> is updated relatively often. You may
39 want to use the latest available &mesa-major-minor;.x mesa version.
40 </para>
41 </note>
42
[f1a479c7]43 &lfs111_checked;
[ca0c29cc]44
[868c7c2]45 <bridgehead renderas="sect3">Package Information</bridgehead>
46 <itemizedlist spacing="compact">
47 <listitem>
[de938a4e]48 <para>
[7a395d1]49 Download (HTTP): <ulink url="&mesa-download-http;"/>
[de938a4e]50 </para>
[868c7c2]51 </listitem>
52 <listitem>
[de938a4e]53 <para>
[7a395d1]54 Download (FTP): <ulink url="&mesa-download-ftp;"/>
[de938a4e]55 </para>
[868c7c2]56 </listitem>
57 <listitem>
[de938a4e]58 <para>
[7a395d1]59 Download MD5 sum: &mesa-md5sum;
[de938a4e]60 </para>
[868c7c2]61 </listitem>
62 <listitem>
[de938a4e]63 <para>
[7a395d1]64 Download size: &mesa-size;
[de938a4e]65 </para>
[868c7c2]66 </listitem>
67 <listitem>
[de938a4e]68 <para>
[7a395d1]69 Estimated disk space required: &mesa-buildsize;
[de938a4e]70 </para>
[868c7c2]71 </listitem>
72 <listitem>
[de938a4e]73 <para>
[7a395d1]74 Estimated build time: &mesa-time;
[de938a4e]75 </para>
[868c7c2]76 </listitem>
77 </itemizedlist>
[1334c9a]78
[625079b6]79 <bridgehead renderas="sect3">Additional Downloads</bridgehead>
[a07e9eb]80 <itemizedlist spacing="compact">
81 <listitem>
[eb425b4]82 <para>
83 Recommended patch:
[1334c9a]84 <ulink url="&patch-root;/mesa-&mesa-version;-add_xdemos-1.patch"/>
[7a395d1]85 (installs 2 demo programs for testing Mesa - not needed if you
[713981db]86 install the <ulink url="https://archive.mesa3d.org/demos/">
[39dd48b]87 mesa-demos</ulink> package)
[ace536a]88 </para>
[eeb29511]89 </listitem>
90 </itemizedlist>
[1334c9a]91
[7a395d1]92 <bridgehead renderas="sect3">Mesa Dependencies</bridgehead>
[868c7c2]93
94 <bridgehead renderas="sect4">Required</bridgehead>
[7b74537e]95 <para role="required">
[df343952]96 <xref linkend="xorg7-lib"/>,
[e2aae21f]97 <xref linkend="libdrm"/>, and
98 <xref linkend="Mako"/>
[eb425b4]99 </para>
[868c7c2]100
[606dfd4]101 <bridgehead renderas="sect4">Recommended</bridgehead>
[eb425b4]102 <para role="recommended">
[d2f50ba]103
[cc405844]104 <xref role="first" linkend="libva"/> (to provide VA-API support for some
105 gallium drivers, note that there is a circular dependency. You must
[df343952]106 build <application>libva</application> first without EGL and GLX support,
[cc405844]107 install this package, and rebuild <application>libva</application>),
[bee072a]108
[9065a56b]109 <xref linkend="libvdpau"/> (to build VDPAU drivers),
[bee072a]110
111 <xref linkend="llvm"/> (required for Gallium3D, nouveau, and radeonsi
[d2f50ba]112 drivers and for swrast, the software rasterizer which is sometimes referred
113 to as llvmpipe. See <ulink role="nodep"
[c6cb93b]114 url="https://docs.mesa3d.org/systems.html"/> for more information), and
[bee072a]115
[8558044]116 <xref linkend="wayland-protocols"/> (required for
[8e17e54]117 <xref role="nodep" linkend='plasma5-build'/>,
[bee072a]118 GNOME, and recommended for <xref role="nodep" linkend='gtk3'/>)
[606dfd4]119 </para>
[60bcf481]120
[07584d8]121 <bridgehead renderas="sect4">Optional</bridgehead>
122 <para role="optional">
[57bcce9]123 <xref linkend="libgcrypt"/>,
[751dd1e]124 <xref linkend="libunwind"/>,
[b4d0b5a]125 <xref linkend="lm_sensors"/> <!-- for libsensors according to Meson -->,
[57bcce9]126 <xref linkend="nettle"/>,
[b4d0b5a]127 <xref linkend="valgrind"/>,
[9dc1c31]128 <ulink url="https://archive.mesa3d.org/demos/">mesa-demos</ulink>
[1cdb1f7]129 (provides more than 300 extra demos to test
[973dabe9]130 <application>Mesa</application>; this includes the same programs added by
[b4d0b5a]131 the patch above),
[c18b8f23]132 <ulink url="http://omxil.sourceforge.net/">Bellagio OpenMAX Integration
[8558044]133 Layer</ulink> (for mobile platforms),
[b4d0b5a]134 <ulink url="https://github.com/tizonia/tizonia-openmax-il/wiki/Tizonia-OpenMAX-IL/">
[ef936e4]135 libtizonia</ulink>, and
[bee072a]136 <ulink url="https://www.vulkan.org/">libvulkan</ulink>
[07584d8]137 </para>
[bee072a]138<!--
[9065a56b]139 <note>
[fd2f9a2]140 <para>
[e4fbb24]141 The instructions below assume that
[d2f50ba]142 <application>LLVM</application> with the r600/amdgpu and host backends
143 and run-time type information (RTTI - needed for nouveau) are installed.
144 You will need to modify the instructions if you
145 choose not to install all of these. For an explanation of Gallium3D see
[e83a3bb]146 <ulink url="https://en.wikipedia.org/wiki/Gallium3D"/>.
[fd2f9a2]147 </para>
[9065a56b]148 </note>
[bee072a]149-->
[c5c2654]150 <para condition="html" role="usernotes">User Notes:
[6ff79cf]151 <ulink url="&blfs-wiki;/mesalib"/>
[2993b2f]152 </para>
[868c7c2]153 </sect2>
154
155 <sect2 role="installation">
[7a395d1]156 <title>Installation of Mesa</title>
[1334c9a]157
[a07e9eb]158 <para>
[51c08f3]159 If you have downloaded the xdemos patch (needed if testing the Xorg
160 installation per BLFS instructions), apply it by running the following
161 command:
[a07e9eb]162 </para>
163
[1334c9a]164<screen><userinput>patch -Np1 -i ../mesa-&mesa-version;-add_xdemos-1.patch</userinput></screen>
165
[054e926]166 <!-- Note that freedreno, vc4, and virgl all need special support from
[d2f50ba]167 libdrm - renodr
168 For me, libdrm does not mention virgl, but mesa accepts it. AFAICS
169 freedreno is for qualcom hardware, libdrm will build for it on suitable
170 systems. VC4 is for the Broadcom VC4 used in the raspberry pi - ken -->
[bee072a]171<!--
[d2f50ba]172 <note>
173 <para>
174 The measurements above, and the Contents below, are for a full build.
175 Many people will not wish to install drivers they cannot use, so the
176 following paragraphs explain how to limit the drivers, and give an
177 example which can be be reduced or amended as necessary.
178 </para>
179 </note>
180
181 <para>
182 Now, select the drivers you wish to install. For the X86 architecture, the
[ef936e4]183 available gallium drivers are auto (<emphasis>in 21.2.1 this does not select
184 crocus </emphasis>), <emphasis>or alternatively a choice from</emphasis>
[9f777e1]185 crocus, i915, iris, nouveau, r300, r600, radeonsi, svga, swrast, and virgl.
186 The latter can provide acceleration in <xref linkend="qemu"/> if that has
187 been linked against
188 <ulink url="https://gitlab.freedesktop.org/virgl/virglrenderer/~/releases/">virglrenderer</ulink>
189 (you will need a freedesktop.org account to get to that page, you can
190 download the 0.9.1 release without an account from
[bee072a]191 <ulink url="https://gitlab.freedesktop.org/virgl/virglrenderer/-/archive/0.9.1/virglrenderer-0.9.1.tar.bz2">virglrenderer-0.9.1</ulink>).-->
192
[9f777e1]193<!-- If you wish to build all available gallium drivers,
[ef936e4]194 use 'auto'. FIXME : does not build crocus in 21.2.1 -->
[6ff79cf]195
196 <!-- crocus was added to the default x86/x86_64 drivers for meson in the
[bee072a]197 master branch on 2021-08-31, at some point it will appear in a stable release
[d2f50ba]198 </para>
[bee072a]199-->
200<!--
[d2f50ba]201 <para>
202 The (non-gallium) DRI drivers available in X86 are auto, <emphasis>or
203 alternatively a choice from</emphasis> i915, i965, nouveau, r100, r200,
204 and swrast. Use 'auto' to build all available DRI drivers, or use an
205 empty string (DRI_DRIVERS="") if you wish to only build gallium drivers.
206 </para>
207
208 <para>
209 The platforms ("window systems") available for X86 linux are x11, wayland,
[bee072a]210 drm, and surfaceless. By not specifying anything, the meson
[17ae4374]211 build-system will build for all these platforms if you have the
212 dependencies, identical to if you had specified '-Dplatforms=auto'.
[d2f50ba]213 </para>
214
215 <para>
216 Modify the commands below for your desired drivers. The drivers listed
217 below will cover most modern video cards and virtual machines. For help in
[c6cb93b]218 selecting drivers see <ulink url="https://docs.mesa3d.org/systems.html"/>.
[bee072a]219-->
[ef936e4]220 <!-- these two don't seem to be mentioned in that mesa link -->
[bee072a]221<!--
[ef936e4]222 For intel drivers, specify crocus for i965 gen 4 through to haswell, iris
223 for broadwell and later.
[d2f50ba]224 </para>
225
226 <note>
227 <para>
228 Although the nouveau drivers can be built for both gallium and dri, the
229 i915 driver can only be built for one or the other.
230 </para>
231 </note>
232
[ef936e4]233<screen><userinput>GALLIUM_DRV="crocus,i915,iris,nouveau,r600,radeonsi,svga,swrast,virgl"
[d2f50ba]234DRI_DRIVERS="i965,nouveau"</userinput></screen>
[bee072a]235-->
[43149b8]236
[eb425b4]237 <para>
[7a395d1]238 Install <application>Mesa</application> by running the following
[eb425b4]239 commands:
240 </para>
[868c7c2]241
[b3f053c5]242<screen><userinput>mkdir build &amp;&amp;
243cd build &amp;&amp;
[a85e5ce]244
[bee072a]245meson --prefix=$XORG_PREFIX \
246 --buildtype=release \
247 -Dplatforms=x11,wayland \
248 -Dgallium-drivers=auto \
249 -Dglx=dri \
250 -Dvalgrind=disabled \
251 -Dlibunwind=disabled \
252 .. &amp;&amp;
[b3f053c5]253
254ninja</userinput></screen>
[868c7c2]255
[b3f053c5]256 <para>
[d2f50ba]257 If you built the tests (see 'Command Explanations'), to run them issue:
[bee072a]258 <command>ninja test</command>.
[b3f053c5]259 </para>
[bee072a]260<!-- All tests passed for me for 21.2.4 [pierre]
261 All 33 subtests tests in the mesa:compiler+glsl / glsl compiler warnings
262 suite are known to fail.
263
264 For 22.1.0:
265 Ok: 74
266 Expected Fail: 0
267 Fail: 0
268 Unexpected Pass: 0
269 Skipped: 0
270 Timeout: 0
271-->
[ef936e4]272
[eb425b4]273 <para>
274 Now, as the <systemitem class="username">root</systemitem> user:
275 </para>
[ff55539b]276
[b3f053c5]277<screen role="root"><userinput>ninja install</userinput></screen>
[a07e9eb]278
[eb425b4]279 <para>
[a07e9eb]280 If desired, install the optional documentation by running
281 the following commands as the
[eb425b4]282 <systemitem class="username">root</systemitem> user:
283 </para>
[91859cf]284
[3713bc71]285<screen role="root"
286 remap="doc"><userinput>install -v -dm755 /usr/share/doc/mesa-&mesa-version; &amp;&amp;
[b3f053c5]287cp -rfv ../docs/* /usr/share/doc/mesa-&mesa-version;</userinput></screen>
[5a883bc4]288
[868c7c2]289 </sect2>
290
[a07e9eb]291 <sect2 role="commands">
292 <title>Command Explanations</title>
[d2f50ba]293
[95e8211]294 <para>
[3918112a]295 <parameter>--buildtype=release</parameter>: This switch ensures a
[d2f50ba]296 fully-optimized build, and disables debug assertions which will
[ec77633]297 severely slow down the libraries in certain use-cases. Without this
298 switch, build sizes can span into the 2GB range.
[95e8211]299 </para>
[bee072a]300<!--
[b642036d]301 <para>
[d2f50ba]302 <parameter>-Ddri-drivers="..."</parameter>: This parameter
303 controls which (non-gallium) dri drivers should be built.
304 </para>
[bee072a]305-->
[d2f50ba]306 <para>
307 <parameter>-Dgallium-drivers="..."</parameter>: This parameter
308 controls which Gallium3D drivers should be built.
309 </para>
310
[d3ad4c0f]311<!--
[d2f50ba]312 <para>
[d3ad4c0f]313 <parameter>-Dosmesa=true</parameter>: This switch enables building
[d2f50ba]314 the <filename class="libraryfile">libOSMesa</filename> library and
[018c4c52]315 provides Gallium3D support in it. It requires the swrast gallium driver.
[b642036d]316 </para>
[d3ad4c0f]317-->
[bee072a]318
[eb425b4]319 <para>
[d2f50ba]320 <parameter>-Dplatforms="..."</parameter>: This parameter
[bee072a]321 controls which windowing systems will be supported. Available
322 linux platforms are x11 and wayland.
[eb425b4]323 </para>
[bee072a]324
325 <para>
326 <parameter>-Degl-native-platform="..."</parameter>: This parameter
327 controls which Embedded Graphics Library support will be built. Available
328 linux options are auto (default), x11, wayland, surfaceless, and drm.
329 </para>
330
[2993b2f]331 <para>
[d7fcae6]332 <parameter>-Dvalgrind=disabled</parameter>: This parameter disables
[d2f50ba]333 the usage of Valgrind during the build process. Remove this parameter
334 if you have Valgrind installed, and wish to check for memory leaks.
[2993b2f]335 </para>
336
[42117d4e]337 <para>
[d7fcae6]338 <parameter>-Dlibunwind=disabled</parameter>: This parameter disables
[42117d4e]339 the usage of libunwind.
340 </para>
341
[a07e9eb]342 <para>
[6a83533]343 <option>-Dbuild-tests=true</option>: This switch will cause the test code
[bee072a]344 to be enabled.
[b4d0b5a]345 </para>
346
[3713bc71]347 <para>
[6a83533]348 <option>-Dvulkan-drivers=...</option>: This switch allows choosing which
349 Vulkan drivers are built. Since BLFS does not use
[bee072a]350 Vulkan, it is safe to leave the list of Vulkan drivers empty. The default
351 is auto.
[3713bc71]352 </para>
353
[371ff30]354 </sect2>
355
[868c7c2]356 <sect2 role="content">
357 <title>Contents</title>
358
359 <segmentedlist>
[1263ab1e]360 <segtitle>Installed Programs</segtitle>
[42117d4e]361 <segtitle>Installed Libraries</segtitle><!-- in /usr/lib -->
362 <segtitle>Installed Drivers</segtitle><!-- in /usr/lib/<subdir> -->
[ba2ac60]363 <segtitle>Installed Directories</segtitle>
[868c7c2]364
365 <seglistitem>
[eb425b4]366 <seg>
367 glxgears and glxinfo
368 </seg>
[42117d4e]369 <seg>
370 libEGL.so,
371 libGL.so,
372 libGLESv1_CM.so,
373 libGLESv2.so,
374 libXvMCnouveau.so,
375 libXvMCr600.so,
376 libgbm.so,
377 libglapi.so,
378 <!-- Begin Vulkan drivers -->
379 libvulkan_intel.so,
380 libvulkan_lvp.so,
381 libvulkan_radeon.so, and
382 <!-- End Vulkan drivers -->
383 libxatracker.so,
384 </seg>
[eb425b4]385 <seg>
[3713bc71]386 <!-- Begin gallium DRI drivers : this is the full set -->
[7e40901]387<!-- d3dadapter9.so (optional), For Windows games. This is DirectX's
[42117d4e]388 Direct3D -->
[ef936e4]389 crocus_dri.so,
[f72bfbe1]390<!-- i830_dri.so,-->
[b3f053c5]391 i915_dri.so,
[db480be]392 iris_dri.so,
[b3f053c5]393 kms_swrast_dri.so,
394 nouveau_dri.so,
[d2f50ba]395 nouveau_drv_video.so,
[bee072a]396 r300_dri.so,
[d2f50ba]397 r600_dri.so,
398 r600_drv_video.so,
[bee072a]399 radeon_dri.so,
[b3f053c5]400 radeonsi_dri.so,
401 radeonsi_drv_video.so,
402 swrast_dri.so,
[d2f50ba]403 virtio_gpu_dri.so,
[696735e]404 vmwgfx_dri.so,
[e4fbb24]405 <!-- End DRI Drivers -->
406 <!-- Begin VDPAU drivers -->
[d2f50ba]407 libvdpau_nouveau.so,
[7e40901]408 libvdpau_r300.so
[d2f50ba]409 libvdpau_r600.so, and
[b3f053c5]410 libvdpau_radeonsi.so
[e4fbb24]411 <!-- End VDPAU drivers -->
[ef936e4]412 (Many of these drivers are hard-linked).
[eb425b4]413 </seg>
414 <seg>
[bee072a]415 $XORG_PREFIX/{include/{EGL,GL,GLES,GLES2,GLES3,KHR},
416 $XORG_PREFIX/lib/{dri,vdpau}},
[d2f50ba]417 $XORG_PREFIX/share/drirc.d (contains workarounds for various applications,
[f72bfbe1]418 particularly browsers and games),
[988edafd]419 $XORG_PREFIX/share/vulkan,
[880727e]420 and
[bee072a]421 /usr/share/doc/mesa-&mesa-version;
[eb425b4]422 </seg>
[868c7c2]423 </seglistitem>
424 </segmentedlist>
[d3ef1e4]425
[4437f63]426 <variablelist>
427 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
428 <?dbfo list-presentation="list"?>
429 <?dbhtml list-presentation="table"?>
430
431 <varlistentry id="glxgears">
[eb50ddde]432 <term><command>glxgears</command></term>
[4437f63]433 <listitem>
[eb425b4]434 <para>
435 is a GL demo useful for troubleshooting graphics
[4c24eb0a]436 problems
[eb425b4]437 </para>
[7a395d1]438 <indexterm zone="mesa glxgears">
[4437f63]439 <primary sortas="b-glxgears">glxgears</primary>
440 </indexterm>
441 </listitem>
442 </varlistentry>
443
444 <varlistentry id="glxinfo">
[eb50ddde]445 <term><command>glxinfo</command></term>
[4437f63]446 <listitem>
[eb425b4]447 <para>
448 is a diagnostic program that displays information about the
[4c24eb0a]449 graphics hardware and installed GL libraries
[eb425b4]450 </para>
[7a395d1]451 <indexterm zone="mesa glxinfo">
[4437f63]452 <primary sortas="b-glxinfo">glxinfo</primary>
453 </indexterm>
454 </listitem>
455 </varlistentry>
456
[25f6d94]457 <varlistentry id="libEGL">
[a07e9eb]458 <term><filename class="libraryfile">libEGL.so</filename></term>
[25f6d94]459 <listitem>
[eb425b4]460 <para>
[a07e9eb]461 provides a native platform graphics interface as
[4c24eb0a]462 defined by the EGL-1.4 specification
[eb425b4]463 </para>
[7a395d1]464 <indexterm zone="mesa libEGL">
[25f6d94]465 <primary sortas="c-libGL">libEGL.so</primary>
466 </indexterm>
467 </listitem>
468 </varlistentry>
469
[a07e9eb]470 <varlistentry id="libgbm">
471 <term><filename class="libraryfile">libgbm.so</filename></term>
472 <listitem>
473 <para>
474 is the <application>Mesa</application> Graphics Buffer
[4c24eb0a]475 Manager library
[a07e9eb]476 </para>
[7a395d1]477 <indexterm zone="mesa libgbm">
[a07e9eb]478 <primary sortas="c-libgbm">libgbm.so</primary>
479 </indexterm>
480 </listitem>
481 </varlistentry>
482
483 <varlistentry id="libGLESv1_CM">
484 <term><filename class="libraryfile">libGLESv1_CM.so</filename></term>
485 <listitem>
486 <para>
[4c24eb0a]487 is the <application>Mesa</application> OpenGL ES 1.1 library
[a07e9eb]488 </para>
[7a395d1]489 <indexterm zone="mesa libGLESv1_CM">
[a07e9eb]490 <primary sortas="c-libGLESv1_CM">libGLESv1_CM.so</primary>
491 </indexterm>
492 </listitem>
493 </varlistentry>
494
495 <varlistentry id="libGLES2">
496 <term><filename class="libraryfile">libGLES2.so</filename></term>
497 <listitem>
498 <para>
[4c24eb0a]499 is the <application>Mesa</application> OpenGL ES 2.0 library
[a07e9eb]500 </para>
[7a395d1]501 <indexterm zone="mesa libGLES2">
[a07e9eb]502 <primary sortas="c-libGLES2">libGLES2.so</primary>
503 </indexterm>
504 </listitem>
505 </varlistentry>
506
[ba2ac60]507 <varlistentry id="libGL">
[a07e9eb]508 <term><filename class="libraryfile">libGL.so</filename></term>
[ba2ac60]509 <listitem>
[eb425b4]510 <para>
[4c24eb0a]511 is the main <application>Mesa</application> OpenGL library
[eb425b4]512 </para>
[7a395d1]513 <indexterm zone="mesa libGL">
[ba2ac60]514 <primary sortas="c-libGL">libGL.so</primary>
515 </indexterm>
516 </listitem>
517 </varlistentry>
[bee072a]518
[4437f63]519 </variablelist>
520
[868c7c2]521 </sect2>
[d3ef1e4]522
[868c7c2]523</sect1>
Note: See TracBrowser for help on using the repository browser.