source: x/lib/libdrm.xml@ adaaba2

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/xf86-video-removal
Last change on this file since adaaba2 was a0e08b2, checked in by David Bryant <david@…>, 18 months ago

Standardized the spelling of "userspace".

Also corrected the capitalization of titles and cleaned up some
grammatical errors. Note that a few modules quote the "config"
menu for the Linux kernel, whch says "user-space". Those
modules were not altered; directly quoted material should be
reproduced verbatim.

  • Property mode set to 100644
File size: 8.4 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
4 <!ENTITY % general-entities SYSTEM "../../general.ent">
5 %general-entities;
6
7 <!ENTITY libdrm-download-http "https://dri.freedesktop.org/libdrm/libdrm-&libdrm-version;.tar.xz">
8 <!ENTITY libdrm-download-ftp " ">
9 <!ENTITY libdrm-md5sum "07759750351465e5dd39f4fe40f000ea">
10 <!ENTITY libdrm-size "464 KB">
11 <!ENTITY libdrm-buildsize "8.2 MB (with tests)">
12 <!ENTITY libdrm-time "0.1 SBU (with tests)">
13 <!-- With version 2.4.102, the tests add 1 second to my build. -->
14 <!-- The 'threaded' test adds about 15 seconds if you're on an NVIDIA system
15 due to it directly interacting with the GPU. -->
16]>
17
18<sect1 id="libdrm" xreflabel="libdrm-&libdrm-version;">
19 <?dbhtml filename="libdrm.html"?>
20
21
22 <title>Libdrm-&libdrm-version;</title>
23
24 <indexterm zone="libdrm">
25 <primary sortas="a-libdrm">libdrm</primary>
26 </indexterm>
27
28 <sect2 role="package">
29 <title>Introduction to Libdrm</title>
30
31 <para>
32 <application>Libdrm</application> provides a userspace library for
33 accessing the direct rendering manager (DRM) on operating systems that
34 support the ioctl interface. Libdrm is a low-level library, typically used
35 by graphics drivers such as the Mesa DRI drivers, the X drivers, libva and
36 similar projects.
37 </para>
38
39 &lfs112_checked;
40
41 <bridgehead renderas="sect3">Package Information</bridgehead>
42 <itemizedlist spacing="compact">
43 <listitem>
44 <para>
45 Download (HTTP): <ulink url="&libdrm-download-http;"/>
46 </para>
47 </listitem>
48 <listitem>
49 <para>
50 Download (FTP): <ulink url="&libdrm-download-ftp;"/>
51 </para>
52 </listitem>
53 <listitem>
54 <para>
55 Download MD5 sum: &libdrm-md5sum;
56 </para>
57 </listitem>
58 <listitem>
59 <para>
60 Download size: &libdrm-size;
61 </para>
62 </listitem>
63 <listitem>
64 <para>
65 Estimated disk space required: &libdrm-buildsize;
66 </para>
67 </listitem>
68 <listitem>
69 <para>
70 Estimated build time: &libdrm-time;
71 </para>
72 </listitem>
73 </itemizedlist>
74
75 <bridgehead renderas="sect3">libdrm Dependencies</bridgehead>
76
77 <bridgehead renderas="sect4">Recommended</bridgehead>
78 <para role="recommended">
79 <xref linkend="xorg7-lib"/> (for Intel KMS API support required by Mesa)
80 </para>
81
82 <bridgehead renderas="sect4">Optional</bridgehead>
83 <para role="optional">
84 <xref linkend="cairo"/> (for tests),
85 <xref linkend="cmake"/> (could be used to find dependencies without pkgconfig files),
86 <xref linkend="DocBook"/>,
87 <xref linkend="docbook-xsl"/>,
88 <xref linkend="docutils"/>, and
89 <xref linkend="libxslt"/> (to build manual pages),
90 <xref linkend="libatomic_ops"/> (required by architectures without native atomic operations),
91 <xref linkend="valgrind"/>, and
92 <ulink url="http://cunit.sourceforge.net/">CUNIT</ulink> (for AMDGPU tests)
93 </para>
94
95 <para condition="html" role="usernotes">User Notes:
96 <ulink url="&blfs-wiki;/libdrm"/>
97 </para>
98 </sect2>
99
100 <sect2 role="installation">
101 <title>Installation of Libdrm</title>
102
103 <para>
104 Install <application>libdrm</application> by running the following
105 commands:
106 </para>
107
108<screen><userinput>mkdir build &amp;&amp;
109cd build &amp;&amp;
110
111meson --prefix=$XORG_PREFIX \
112 --buildtype=release \
113 -Dudev=true \
114 -Dvalgrind=disabled &amp;&amp;
115ninja</userinput></screen>
116
117 <para>
118 To check the results, issue <command>ninja test</command>. <!--One test,
119 'threaded' in the nouveau subdirectory, is known to fail with a
120 30 second timeout.-->
121 <!-- Regarding the 'threaded' test, it's now skipped by default (2.4.102)
122 -renodr -->
123
124 <!-- Tests may hang
125 for unknown reasons. --><!-- If nouveau threaded test hangs, you can disable it
126 with
127 <command>sed -i 's/^TESTS/#&amp;/' tests/nouveau/Makefile.in</command>.
128
129 Now that tests are run with ninja, the test merely times out after 30 seconds.
130 -->
131 </para>
132
133 <para>
134 Now, as the <systemitem class="username">root</systemitem> user:
135 </para>
136
137<screen role="root"><userinput>ninja install</userinput></screen>
138
139 </sect2>
140
141 <sect2 role="commands">
142 <title>Command Explanations</title>
143
144 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
145 href="../../xincludes/meson-buildtype-release.xml"/>
146
147 <para>
148 <parameter>-Dudev=true</parameter>: This parameter enables support for using
149 <application>Udev</application> instead of <command>mknod</command>.
150 </para>
151
152 <para>
153 <parameter>-Dvalgrind=disabled</parameter>: This parameter disables
154 building libdrm with valgrind support. This fixes building sysprof and
155 other packages that use libdrm. Change this parameter to "enabled"
156 (or remove it) if you need support for valgrind.
157 </para>
158
159 </sect2>
160
161 <sect2 role="content">
162 <title>Contents</title>
163
164 <segmentedlist>
165 <segtitle>Installed Programs</segtitle>
166 <segtitle>Installed Libraries</segtitle>
167 <segtitle>Installed Directories</segtitle>
168
169 <seglistitem>
170 <seg>
171 None
172 </seg>
173 <seg>
174 libdrm_amdgpu.so, libdrm_intel.so, libdrm_nouveau.so,
175 libdrm_radeon.so, and libdrm.so<!--, and libkms.so-->
176 </seg>
177 <seg>
178 /usr/include/libdrm <!--,/usr/include/libkms,-->
179 and /usr/share/libdrm
180 </seg>
181 </seglistitem>
182 </segmentedlist>
183
184 <variablelist>
185 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
186 <?dbfo list-presentation="list"?>
187 <?dbhtml list-presentation="table"?>
188
189 <varlistentry id="libdrm_amdgpu">
190 <term><filename class="libraryfile">libdrm_amdgpu.so</filename></term>
191 <listitem>
192 <para>
193 contains the AMDGPU specific Direct Rendering Manager functions
194 </para>
195 <indexterm zone="libdrm libdrm_amdgpu">
196 <primary sortas="c-libdrm_amdgpu">libdrm_amdgpu.so</primary>
197 </indexterm>
198 </listitem>
199 </varlistentry>
200
201 <varlistentry id="libdrm_intel">
202 <term><filename class="libraryfile">libdrm_intel.so</filename></term>
203 <listitem>
204 <para>
205 contains the Intel specific Direct Rendering Manager
206 functions
207 </para>
208 <indexterm zone="libdrm libdrm_intel">
209 <primary sortas="c-libdrm_intel">libdrm_intel.so</primary>
210 </indexterm>
211 </listitem>
212 </varlistentry>
213
214 <varlistentry id="libdrm_nouveau">
215 <term><filename class="libraryfile">libdrm_nouveau.so</filename></term>
216 <listitem>
217 <para>
218 contains the open source nVidia (Nouveau) specific Direct
219 Rendering Manager functions
220 </para>
221 <indexterm zone="libdrm libdrm_nouveau">
222 <primary sortas="c-libdrm_nouveau">libdrm_nouveau.so</primary>
223 </indexterm>
224 </listitem>
225 </varlistentry>
226
227 <varlistentry id="libdrm_radeon">
228 <term><filename class="libraryfile">libdrm_radeon.so</filename></term>
229 <listitem>
230 <para>
231 contains the AMD Radeon specific Direct Rendering Manager
232 functions
233 </para>
234 <indexterm zone="libdrm libdrm_radeon">
235 <primary sortas="c-libdrm_radeon">libdrm_radeon.so</primary>
236 </indexterm>
237 </listitem>
238 </varlistentry>
239
240 <varlistentry id="libdrm-lib">
241 <term><filename class="libraryfile">libdrm.so</filename></term>
242 <listitem>
243 <para>
244 contains the Direct Rendering Manager API functions
245 </para>
246 <indexterm zone="libdrm libdrm-lib">
247 <primary sortas="c-libdrm">libdrm.so</primary>
248 </indexterm>
249 </listitem>
250 </varlistentry>
251
252 <!-- Removed in 2.4.111
253 <varlistentry id="libkms">
254 <term><filename class="libraryfile">libkms.so</filename></term>
255 <listitem>
256 <para>
257 contains API functions for kernel mode setting abstraction
258 </para>
259 <indexterm zone="libdrm libkms">
260 <primary sortas="c-libkms">libkms.so</primary>
261 </indexterm>
262 </listitem>
263 </varlistentry>
264 -->
265
266 </variablelist>
267
268 </sect2>
269
270</sect1>
Note: See TracBrowser for help on using the repository browser.