source: x/installing/mesa.xml@ 696735e

10.0 10.1 11.0 11.1 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 upgradedb xry111/intltool xry111/llvm18 xry111/soup3 xry111/test-20220226 xry111/xf86-video-removal
Last change on this file since 696735e was 696735e, checked in by Douglas R. Reno <renodr@…>, 4 years ago

Update to icu-67.1
Update to Mesa-20.0.5
Update to vala-0.48.5

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

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