source: x/installing/mesa.xml@ 6d90301

12.0 12.1 12.2 gimp3 ken/TL2024 ken/tuningfonts lazarus lxqt plabs/newcss python3.11 rahul/power-profiles-daemon renodr/vulkan-addition trunk xry111/for-12.3 xry111/llvm18 xry111/spidermonkey128
Last change on this file since 6d90301 was 14891a90, checked in by Xi Ruoyao <xry111@…>, 15 months ago

treewide: More "User Notes" clean up

Remove links to pages w/o real contents.

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