source: x/installing/mesa.xml@ 0cc9262

10.0 10.1 11.0 11.1 11.2 11.3 12.0 12.1 8.1 8.2 8.3 8.4 9.0 9.1 basic bdubbs/svn elogind kea ken/TL2024 ken/inkscape-core-mods ken/tuningfonts lazarus lxqt perl-modules 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 0cc9262 was 0cc9262, checked in by Bruce Dubbs <bdubbs@…>, 7 years ago

Update to libinput-1.6.2.
Update to mesa-17.0.0.
Update to harfbuzz-1.4.3.
Update to libX11-1.6.5 (xorg library).
Update to libwww-perl-6.21 (Perl module).
Update to Log-Log4perl-1.49 (Perl module).
Update to Net-DNS-1.08 (Perl module).

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

  • Property mode set to 100644
File size: 15.0 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
[464f030]7 <!ENTITY mesa-download-http "https://mesa.freedesktop.org/archive/&mesa-version;/mesa-&mesa-version;.tar.xz">
[7a395d1]8 <!ENTITY mesa-download-ftp "ftp://ftp.freedesktop.org/pub/mesa/&mesa-version;/mesa-&mesa-version;.tar.xz">
[0cc9262]9 <!ENTITY mesa-md5sum "932e4171a86b14940c06812356486155">
10 <!ENTITY mesa-size "9.0 MB">
11 <!ENTITY mesa-buildsize "304 MB (with demos and docs, add 50 MB for tests)">
12 <!ENTITY mesa-time "2.6 SBU (with demos and docs, add 0.6 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
[8b0eef4]37 &lfs80_checked;
[ca0c29cc]38
[868c7c2]39 <bridgehead renderas="sect3">Package Information</bridgehead>
40 <itemizedlist spacing="compact">
41 <listitem>
[de938a4e]42 <para>
[7a395d1]43 Download (HTTP): <ulink url="&mesa-download-http;"/>
[de938a4e]44 </para>
[868c7c2]45 </listitem>
46 <listitem>
[de938a4e]47 <para>
[7a395d1]48 Download (FTP): <ulink url="&mesa-download-ftp;"/>
[de938a4e]49 </para>
[868c7c2]50 </listitem>
51 <listitem>
[de938a4e]52 <para>
[7a395d1]53 Download MD5 sum: &mesa-md5sum;
[de938a4e]54 </para>
[868c7c2]55 </listitem>
56 <listitem>
[de938a4e]57 <para>
[7a395d1]58 Download size: &mesa-size;
[de938a4e]59 </para>
[868c7c2]60 </listitem>
61 <listitem>
[de938a4e]62 <para>
[7a395d1]63 Estimated disk space required: &mesa-buildsize;
[de938a4e]64 </para>
[868c7c2]65 </listitem>
66 <listitem>
[de938a4e]67 <para>
[7a395d1]68 Estimated build time: &mesa-time;
[de938a4e]69 </para>
[868c7c2]70 </listitem>
71 </itemizedlist>
72
[625079b6]73 <bridgehead renderas="sect3">Additional Downloads</bridgehead>
[a07e9eb]74 <itemizedlist spacing="compact">
75 <listitem>
[eb425b4]76 <para>
77 Recommended patch:
[39dd48b]78 <ulink
[27747668]79 url="&patch-root;/mesa-&mesa-version;-add_xdemos-1.patch"/>
[7a395d1]80 (installs 2 demo programs for testing Mesa - not needed if you
[39dd48b]81 install the <ulink url="ftp://ftp.freedesktop.org/pub/mesa/demos/">
82 mesa-demos</ulink> package)
[ace536a]83 </para>
[eeb29511]84 </listitem>
85 </itemizedlist>
86
[7a395d1]87 <bridgehead renderas="sect3">Mesa Dependencies</bridgehead>
[868c7c2]88
89 <bridgehead renderas="sect4">Required</bridgehead>
[7b74537e]90 <para role="required">
[df343952]91 <xref linkend="xorg7-lib"/>,
92 <xref linkend="libdrm"/>, and
93 <xref linkend="python2"/>
[eb425b4]94 </para>
[868c7c2]95
[606dfd4]96 <bridgehead renderas="sect4">Recommended</bridgehead>
[eb425b4]97 <para role="recommended">
[973dabe9]98 <xref linkend="elfutils"/> (required for the radeonsi driver),
99
[df343952]100 <phrase revision="systemd"><xref linkend="libva"/> (to build drivers for
101 supported hardware, note that there is a circular dependency. You must
102 build <application>libva</application> first without EGL and GLX support,
103 install this package, and rebuild <application>libva</application>.),</phrase>
[973dabe9]104
[9065a56b]105 <xref linkend="libvdpau"/> (to build VDPAU drivers),
[973dabe9]106
[8a154834]107 <xref linkend="llvm"/> (required for Gallium3D, r300, and radeonsi
[973dabe9]108 drivers and for the llvmpipe software rasterizer. See
109 <ulink url="http://www.mesa3d.org/systems.html"/> for more information.)
[606dfd4]110 </para>
[60bcf481]111
[07584d8]112 <bridgehead renderas="sect4">Optional</bridgehead>
113 <para role="optional">
[57bcce9]114 <xref linkend="libgcrypt"/>,
115 <xref linkend="nettle"/>,
[8b5a6f57]116 <xref linkend="wayland"/> (required for
[973dabe9]117 <xref linkend='plasma5-build'/>
118 <phrase revision="systemd">,</phrase>
119 <phrase revision="sysv">and</phrase>
120 <xref linkend='lxqt'/>
121 <phrase revision="systemd">, and GNOME</phrase>),
122
[58720a7b]123 <ulink url="ftp://ftp.freedesktop.org/pub/mesa/demos/">mesa-demos</ulink>
[1cdb1f7]124 (provides more than 300 extra demos to test
[973dabe9]125 <application>Mesa</application>; this includes the same programs added by
126 the patch above), and
127
[c18b8f23]128 <ulink url="http://omxil.sourceforge.net/">Bellagio OpenMAX Integration
[f3429309]129 Layer</ulink> (for mobile platforms)
[07584d8]130 </para>
131
[9065a56b]132 <note>
[fd2f9a2]133 <para>
[dae25ca5]134 The instructions below assume that <application>elfutils</application>
[df343952]135 and <application>LLVM</application> with the r600/amdgpu and host
136 backends are installed. You will need to modify the instructions if you
[973dabe9]137 choose not to install them. For an explanation of Gallium3D see
[e83a3bb]138 <ulink url="https://en.wikipedia.org/wiki/Gallium3D"/>.
[fd2f9a2]139 </para>
[9065a56b]140 </note>
[fd2f9a2]141
[c5c2654]142 <para condition="html" role="usernotes">User Notes:
[7a395d1]143 <ulink url="&blfs-wiki;/mesa"/>
[2993b2f]144 </para>
[868c7c2]145 </sect2>
146
147 <sect2 role="installation">
[7a395d1]148 <title>Installation of Mesa</title>
[868c7c2]149
[a07e9eb]150 <para>
[51c08f3]151 If you have downloaded the xdemos patch (needed if testing the Xorg
152 installation per BLFS instructions), apply it by running the following
153 command:
[a07e9eb]154 </para>
155
[27747668]156<screen><userinput>patch -Np1 -i ../mesa-&mesa-version;-add_xdemos-1.patch</userinput></screen>
[a07e9eb]157
[054e926]158 <!-- Note that freedreno, vc4, and virgl all need special support from
159 libdrm - renodr -->
[f9f0ea92]160 <para>Now, select the drivers you wish to install. The available drivers
161 are i915, ilo, nouveau, r300, r600, radeonsi, freedreno, svga, swrast, vc4,
162 and virgl. If the Gallium drivers are not specified, the default is
163 'r300,r600,svga,swrast'. Modify the command below for any desired drivers.
164 The listed drivers below will cover most modern video cards. For help in
165 selecting drivers see
166 <ulink url='http://www.mesa3d.org/systems.html'/>.</para>
[973dabe9]167
[f2afe02]168<screen><userinput>GLL_DRV="i915,r600,nouveau,radeonsi,svga,swrast"</userinput></screen>
[973dabe9]169
[eb425b4]170 <para>
[7a395d1]171 Install <application>Mesa</application> by running the following
[eb425b4]172 commands:
173 </para>
[868c7c2]174
[f97d5f6]175 <note>
[4e845a4]176 <para>
177 Add wayland to the <parameter>--with-egl-platforms</parameter> switch
178 below if you plan on building
179 <xref linkend='plasma5-build'/><phrase revision="systemd">,</phrase>
180 <phrase revision="sysv">or</phrase>
181 <xref linkend='lxqt'/><phrase revision="systemd">, or GNOME</phrase>.
182 </para>
[f97d5f6]183 </note>
184
[72f0b9c]185<screen><userinput>sed -i "/pthread_stubs_possible=/s/yes/no/" configure.ac &amp;&amp;
[8a154834]186
[b3b7e36]187./autogen.sh CFLAGS='-O2' CXXFLAGS='-O2' \
[5ee1266]188 --prefix=$XORG_PREFIX \
189 --sysconfdir=/etc \
190 --enable-texture-float \
191 --enable-osmesa \
192 --enable-xa \
193 --enable-glx-tls \
194 --with-egl-platforms="drm,x11" \
195 --with-gallium-drivers=$GLL_DRV &amp;&amp;
196
197unset GLL_DRV &amp;&amp;
198
[1199613]199make</userinput></screen>
[868c7c2]200
[a07e9eb]201 <para>
[7dd7061]202 If you have applied the xdemos patch, build the demo programs by
[a07e9eb]203 running the following command:
204 </para>
205
[5f26d66f]206<screen><userinput>make -C xdemos DEMOS_PREFIX=$XORG_PREFIX</userinput></screen>
[a07e9eb]207
[eb425b4]208 <para>
[6ec7963]209 To test the results, issue: <command>make check</command>.
[eb425b4]210 </para>
[ff55539b]211
[eb425b4]212 <para>
213 Now, as the <systemitem class="username">root</systemitem> user:
214 </para>
[ff55539b]215
[dae25ca5]216<screen role="root"><userinput>make install</userinput></screen>
[a07e9eb]217
218 <para>
[5f91dfd]219 If you have built the demo programs, install them by running the
[a07e9eb]220 following command as the
221 <systemitem class="username">root</systemitem> user:
222 </para>
223
[5f26d66f]224<screen role="root"><userinput>make -C xdemos DEMOS_PREFIX=$XORG_PREFIX install</userinput></screen>
[a07e9eb]225
[eb425b4]226 <para>
[a07e9eb]227 If desired, install the optional documentation by running
228 the following commands as the
[eb425b4]229 <systemitem class="username">root</systemitem> user:
230 </para>
[91859cf]231
[7a395d1]232<screen role="root"><userinput>install -v -dm755 /usr/share/doc/mesa-&mesa-version; &amp;&amp;
233cp -rfv docs/* /usr/share/doc/mesa-&mesa-version;</userinput></screen>
[5a883bc4]234
[868c7c2]235 </sect2>
236
[a07e9eb]237 <sect2 role="commands">
238 <title>Command Explanations</title>
239
[df343952]240 <para>
[9d11b8a5]241 <command>sed -i ... configure.ac</command>: This sed removes a dependency
242 on the <application>libpthread-stubs</application> package which is
243 useless on Linux.
[df343952]244 </para>
245
[95e8211]246 <para>
247 <parameter>CFLAGS="-O2" CXXFLAGS="-O2"</parameter>: By default,
248 <application>Autoconf</application> sets CFLAGS and CXXFLAGS to
249 "-g -O2". That results in binaries and libraries being built with
[fd2f9a2]250 debugging symbols which make them bigger. Override the default
[8b5a6f57]251 flags to omit the -g compiler flag so the final libraries are smaller.
[95e8211]252 </para>
253
[eb425b4]254 <para>
[6825eb89]255 <parameter>--enable-texture-float</parameter>: This switch enables
[a07e9eb]256 floating-point textures and render buffers. Please consult
[eb425b4]257 <filename>docs/patents.txt</filename> to see if there are
258 any legal issues if you use this feature.
259 </para>
260
[2993b2f]261 <para>
[df343952]262 <parameter>--enable-osmesa</parameter>: This switch enables building
[abdc2e6]263 the <filename class="libraryfile">libOSMesa</filename> library.
[2993b2f]264 </para>
265
[eb425b4]266 <para>
[8b5a6f57]267 <parameter>--enable-xa</parameter>: This switch enables building the
[eb425b4]268 XA X Acceleration API (Required for VMware 3D Driver).
269 </para>
270
271 <para>
[8b5a6f57]272 <parameter>--enable-gbm</parameter>: This switch enables building the
[a07e9eb]273 <application>Mesa</application> Graphics Buffer Manager library.
274 </para>
275
[eb425b4]276 <para>
[6825eb89]277 <parameter>--enable-glx-tls</parameter>: This switch enables TLS (Thread Local
[4d92247]278 Storage) support in GLX.
[eb425b4]279 </para>
280
[a07e9eb]281 <para>
282 <parameter>--with-egl-platforms="..."</parameter>: This parameter
[e56f38b]283 controls which platforms EGL will be built for. Available
[a07e9eb]284 platforms are drm, x11 and wayland.
285 </para>
286
[eb425b4]287 <para>
288 <parameter>--with-gallium-drivers="..."</parameter>: This parameter
[973dabe9]289 controls which Gallium3D drivers should be built.
[1f44775e]290 </para>
291
[df343952]292 <para revision="sysv">
[625079b6]293 <option>--enable-sysfs</option>: Use this switch to enable simple PCI
294 identification method, required for building DRI on systems without udev.
295 </para>
296
[371ff30]297 </sect2>
298
[868c7c2]299 <sect2 role="content">
300 <title>Contents</title>
301
302 <segmentedlist>
[1263ab1e]303 <segtitle>Installed Programs</segtitle>
[868c7c2]304 <segtitle>Installed Libraries</segtitle>
[ba2ac60]305 <segtitle>Installed Directories</segtitle>
[868c7c2]306
307 <seglistitem>
[eb425b4]308 <seg>
309 glxgears and glxinfo
310 </seg>
311 <seg>
[ed6d075]312 libEGL.so,
[c5f6157a]313 libgbm.so,
314 libglapi.so,
[ed6d075]315 libGLESv1_CM.so,
[5a14a19]316 libGLESv2.so,
[c5f6157a]317 libGL.so,
[a640d58]318 libOSMesa.so,
[464f030]319<!-- Those libraries are associated with the "swr" gallium driver,
320 which has been removed at r17757. Keeping as a comment in case we
321 reintroduce that driver.
[df343952]322 libswrAVX.so,
[464f030]323 libswrAVX2.so,-->
[8b5a6f57]324 libwayland-egl.so (if built with <application>Wayland</application>)
[b3be1cd]325 libxatracker.so,
[a640d58]326 libXvMCnouveau.so,
327 and libXvMCr600.so
[eb425b4]328 </seg>
329 <seg>
[880727e]330 $XORG_PREFIX/{include/{EGL,GL,GLES,GLES2,GLES3,KHR},lib/{dri,vdpau}}
331 and
[7a395d1]332 /usr/share/doc/mesa-&mesa-version; (optional)
[eb425b4]333 </seg>
[868c7c2]334 </seglistitem>
335 </segmentedlist>
[d3ef1e4]336
[4437f63]337 <variablelist>
338 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
339 <?dbfo list-presentation="list"?>
340 <?dbhtml list-presentation="table"?>
341
342 <varlistentry id="glxgears">
[eb50ddde]343 <term><command>glxgears</command></term>
[4437f63]344 <listitem>
[eb425b4]345 <para>
346 is a GL demo useful for troubleshooting graphics
347 problems.
348 </para>
[7a395d1]349 <indexterm zone="mesa glxgears">
[4437f63]350 <primary sortas="b-glxgears">glxgears</primary>
351 </indexterm>
352 </listitem>
353 </varlistentry>
354
355 <varlistentry id="glxinfo">
[eb50ddde]356 <term><command>glxinfo</command></term>
[4437f63]357 <listitem>
[eb425b4]358 <para>
359 is a diagnostic program that displays information about the
360 graphics hardware and installed GL libraries.
361 </para>
[7a395d1]362 <indexterm zone="mesa glxinfo">
[4437f63]363 <primary sortas="b-glxinfo">glxinfo</primary>
364 </indexterm>
365 </listitem>
366 </varlistentry>
367
[25f6d94]368 <varlistentry id="libEGL">
[a07e9eb]369 <term><filename class="libraryfile">libEGL.so</filename></term>
[25f6d94]370 <listitem>
[eb425b4]371 <para>
[a07e9eb]372 provides a native platform graphics interface as
373 defined by the EGL-1.4 specification.
[eb425b4]374 </para>
[7a395d1]375 <indexterm zone="mesa libEGL">
[25f6d94]376 <primary sortas="c-libGL">libEGL.so</primary>
377 </indexterm>
378 </listitem>
379 </varlistentry>
380
[a07e9eb]381 <varlistentry id="libgbm">
382 <term><filename class="libraryfile">libgbm.so</filename></term>
383 <listitem>
384 <para>
385 is the <application>Mesa</application> Graphics Buffer
[0d7900a]386 Manager library.
[a07e9eb]387 </para>
[7a395d1]388 <indexterm zone="mesa libgbm">
[a07e9eb]389 <primary sortas="c-libgbm">libgbm.so</primary>
390 </indexterm>
391 </listitem>
392 </varlistentry>
393
394 <varlistentry id="libGLESv1_CM">
395 <term><filename class="libraryfile">libGLESv1_CM.so</filename></term>
396 <listitem>
397 <para>
398 is the <application>Mesa</application> OpenGL ES 1.1 library.
399 </para>
[7a395d1]400 <indexterm zone="mesa libGLESv1_CM">
[a07e9eb]401 <primary sortas="c-libGLESv1_CM">libGLESv1_CM.so</primary>
402 </indexterm>
403 </listitem>
404 </varlistentry>
405
406 <varlistentry id="libGLES2">
407 <term><filename class="libraryfile">libGLES2.so</filename></term>
408 <listitem>
409 <para>
410 is the <application>Mesa</application> OpenGL ES 2.0 library.
411 </para>
[7a395d1]412 <indexterm zone="mesa libGLES2">
[a07e9eb]413 <primary sortas="c-libGLES2">libGLES2.so</primary>
414 </indexterm>
415 </listitem>
416 </varlistentry>
417
[ba2ac60]418 <varlistentry id="libGL">
[a07e9eb]419 <term><filename class="libraryfile">libGL.so</filename></term>
[ba2ac60]420 <listitem>
[eb425b4]421 <para>
[a07e9eb]422 is the main <application>Mesa</application> OpenGL library.
[eb425b4]423 </para>
[7a395d1]424 <indexterm zone="mesa libGL">
[ba2ac60]425 <primary sortas="c-libGL">libGL.so</primary>
426 </indexterm>
427 </listitem>
428 </varlistentry>
429
[2993b2f]430 <varlistentry id="libOSMesa">
431 <term><filename class="libraryfile">libOSMesa.so</filename></term>
432 <listitem>
433 <para>
434 is the <application>Mesa</application> Off-screen Rendering library.
435 </para>
[7a395d1]436 <indexterm zone="mesa libOSMesa">
[2993b2f]437 <primary sortas="c-libOSMesa">libOSMesa.so</primary>
438 </indexterm>
439 </listitem>
440 </varlistentry>
441
[bad6be19]442 <varlistentry id="libxatracker">
[a07e9eb]443 <term><filename class="libraryfile">libxatracker.so</filename></term>
[ba2ac60]444 <listitem>
[eb425b4]445 <para>
[a07e9eb]446 is the Xorg Gallium3D acceleration library.
[eb425b4]447 </para>
[7a395d1]448 <indexterm zone="mesa libxatracker">
[bad6be19]449 <primary sortas="c-libxatracker">libxatracker.so</primary>
[ba2ac60]450 </indexterm>
451 </listitem>
452 </varlistentry>
[4437f63]453 </variablelist>
454
[868c7c2]455 </sect2>
[d3ef1e4]456
[868c7c2]457</sect1>
Note: See TracBrowser for help on using the repository browser.