source: chapter08/libffi.xml@ f8c7e95

multilib
Last change on this file since f8c7e95 was 156a414e, checked in by Thomas Trepl <thomas@…>, 18 months ago

Automatic merge of trunk into multilib

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