source: x/installing/mesa.xml@ 5d51e9d8

10.0 10.1 11.0 11.1 11.2 11.3 12.0 12.1 9.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 upgradedb xry111/intltool xry111/llvm18 xry111/soup3 xry111/test-20220226 xry111/xf86-video-removal
Last change on this file since 5d51e9d8 was 5d51e9d8, checked in by Bruce Dubbs <bdubbs@…>, 4 years ago

Update to mesa-19.3.3.
Update to lxml-4.4.3 (Python Module).

git-svn-id: svn://svn.linuxfromscratch.org/BLFS/trunk/BOOK@22613 af4574ff-66df-0310-9fd7-8a98e5e911e0

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