source: chapter08/libffi.xml@ 051c160

multilib
Last change on this file since 051c160 was 051c160, checked in by Thomas Trepl (Moody) <thomas@…>, 2 years ago

Automatic merge of trunk into multilib

  • Property mode set to 100644
File size: 6.2 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
8<sect1 id="ch-system-libffi" role="wrap">
9 <?dbhtml filename="libffi.html"?>
10
11 <sect1info condition="script">
12 <productname>libffi</productname>
13 <productnumber>&libffi-version;</productnumber>
14 <address>&libffi-url;</address>
15 </sect1info>
16
17 <title>Libffi-&libffi-version;</title>
18
19 <indexterm zone="ch-system-libffi">
20 <primary sortas="a-libffi">libffi</primary>
21 </indexterm>
22
23 <sect2 role="package">
24 <title/>
25
26 <para>The Libffi library provides a portable, high level programming
27 interface to various calling conventions. This allows a programmer to call
28 any function specified by a call interface description at run time.</para>
29
30 <segmentedlist>
31 <segtitle>&buildtime;</segtitle>
32 <segtitle>&diskspace;</segtitle>
33
34 <seglistitem>
35 <seg>&libffi-fin-sbu;</seg>
36 <seg>&libffi-fin-du;</seg>
37 </seglistitem>
38 </segmentedlist>
39
40 </sect2>
41
42 <sect2 role="installation">
43 <title>Installation of Libffi</title>
44
45 <note>
46 <para>Similar to GMP, libffi builds with optimizations specific
47 to the processor in use. If building for another system, export
48 CFLAGS and CXXFLAGS to specify a generic build for your architecture.
49 If this is not done, all applications that link to libffi will trigger
50 Illegal Operation Errors.</para>
51 </note>
52
53 <para>Prepare libffi for compilation:</para>
54
55 <screen><userinput remap="configure">./configure --prefix=/usr \
56 --disable-static \
57 --with-gcc-arch=native \
58 --disable-exec-static-tramp</userinput></screen>
59
60 <variablelist>
61 <title>The meaning of the configure option:</title>
62
63 <varlistentry>
64 <term><parameter>--with-gcc-arch=native</parameter></term>
65 <listitem>
66 <para>Ensure GCC optimizes for the current system. If this
67 is not specified, the system is guessed and the code generated
68 may not be correct for some systems. If the generated code
69 will be copied from the native system to a less capable
70 system, use the less capable system as a parameter. For details
71 about alternative system types, see <ulink
72 url='https://gcc.gnu.org/onlinedocs/gcc-&gcc-version;/gcc/x86-Options.html'>
73 the x86 options in the GCC manual</ulink>.</para>
74 </listitem>
75 </varlistentry>
76
77 <varlistentry>
78 <!-- To editors: try to remove it once GJS fixed (at GNOME 43) -->
79 <term><parameter>--disable-exec-static-tramp</parameter></term>
80 <listitem>
81 <para>Disable static trampoline support. It's a new security
82 feature in libffi, but some BLFS packages (notably
83 <application>GJS</application>) have not been adapted for it.</para>
84 </listitem>
85 </varlistentry>
86
87 </variablelist>
88
89 <para>Compile the package:</para>
90
91<screen><userinput remap="make">make</userinput></screen>
92
93 <para>To test the results, issue:</para>
94
95<screen><userinput remap="test">make check</userinput></screen>
96
97 <para>Install the package:</para>
98
99<screen><userinput remap="install">make install</userinput></screen>
100
101 </sect2>
102
103 <!-- - - - - - - - - - -->
104 <!-- Multilib - 32bit -->
105 <!-- - - - - - - - - - -->
106
107 <sect2 arch="ml_32,ml_all" role="installation">
108 <title>Installation of Libffi - 32bit</title>
109
110 <para>Clean previous build:</para>
111
112<screen><userinput remap="pre">make distclean</userinput></screen>
113
114 <para>Prepare Libffi for compilation:</para>
115
116<screen><userinput remap="configure">CC="gcc -m32" CXX="g++ -m32" ./configure \
117 --host=i686-pc-linux-gnu \
118 --prefix=/usr \
119 --libdir=/usr/lib32 \
120 --disable-static \
121 --with-gcc-arch=i686 \
122 --disable-exec-static-tramp</userinput></screen>
123
124 <para>Compile the package:</para>
125
126<screen><userinput remap="make">make</userinput></screen>
127
128 <para>To test the results, issue:</para>
129
130<screen><userinput remap="test">make check</userinput></screen>
131
132 <para>Install the package:</para>
133
134<screen><userinput remap="install">make DESTDIR=$PWD/DESTDIR install
135cp -Rv DESTDIR/usr/lib32/* /usr/lib32
136rm -rf DESTDIR</userinput></screen>
137
138 </sect2><!-- m32 -->
139
140 <!-- - - - - - - - - - -->
141 <!-- Multilib - x32bit -->
142 <!-- - - - - - - - - - -->
143
144 <sect2 arch="ml_x32,ml_all" role="installation">
145 <title>Installation of Libffi - x32bit</title>
146
147 <para>Clean previous build:</para>
148
149<screen><userinput remap="pre">make distclean</userinput></screen>
150
151 <para>Prepare Libffi for compilation:</para>
152
153<screen><userinput remap="configure">CC="gcc -mx32" CXX="g++ -mx32" ./configure \
154 --host=x86_64-unknown-linux-gnux32 \
155 --prefix=/usr \
156 --libdir=/usr/libx32 \
157 --disable-static \
158 --with-gcc-arch=x86_64 \
159 --disable-exec-static-tramp</userinput></screen>
160
161 <para>Compile the package:</para>
162
163<screen><userinput remap="make">make</userinput></screen>
164
165 <para>To test the results, issue:</para>
166
167<screen><userinput remap="test">make check</userinput></screen>
168
169 <para>Install the package:</para>
170
171<screen><userinput remap="install">make DESTDIR=$PWD/DESTDIR install
172cp -Rv DESTDIR/usr/libx32/* /usr/libx32
173rm -rf DESTDIR</userinput></screen>
174
175 </sect2><!-- mx32 -->
176
177 <sect2 id="contents-libffi" role="content">
178 <title>Contents of Libffi</title>
179
180 <segmentedlist>
181 <segtitle>Installed library</segtitle>
182
183 <seglistitem>
184 <seg>libffi.so</seg>
185 </seglistitem>
186 </segmentedlist>
187
188 <variablelist>
189 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
190 <?dbfo list-presentation="list"?>
191 <?dbhtml list-presentation="table"?>
192
193 <varlistentry id="libffi">
194 <term><filename class="libraryfile">libffi</filename></term>
195 <listitem>
196 <para>contains the foreign function interface API functions</para>
197 <indexterm zone="ch-system-libffi">
198 <primary sortas="c-libffi">libffi</primary>
199 </indexterm>
200 </listitem>
201 </varlistentry>
202 </variablelist>
203
204 </sect2>
205
206</sect1>
Note: See TracBrowser for help on using the repository browser.