source: chapter08/libffi.xml@ 607ca5a4

multilib
Last change on this file since 607ca5a4 was 607ca5a4, checked in by Thomas Trepl <thomas@…>, 15 months 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 <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
57 <filename class='libraryfile'>libffi</filename> will trigger
58 Illegal Operation Errors.</para>
59 </note>
60
61 <para>Prepare Libffi for compilation:</para>
62
63 <screen><userinput remap="configure">./configure --prefix=/usr \
64 --disable-static \
65 --with-gcc-arch=native</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 </variablelist>
84
85 <para>Compile the package:</para>
86
87<screen><userinput remap="make">make</userinput></screen>
88
89 <para>To test the results, issue:</para>
90
91<screen><userinput remap="test">make check</userinput></screen>
92
93 <para>Install the package:</para>
94
95<screen><userinput remap="install">make install</userinput></screen>
96
97 </sect2>
98
99 <!-- - - - - - - - - - -->
100 <!-- Multilib - 32bit -->
101 <!-- - - - - - - - - - -->
102
103 <sect2 arch="ml_32,ml_all" role="installation">
104 <title>Installation of Libffi - 32bit</title>
105
106 <para>Clean previous build:</para>
107
108<screen><userinput remap="pre">make distclean</userinput></screen>
109
110 <para>Prepare Libffi for compilation:</para>
111
112<screen><userinput remap="configure">CC="gcc -m32" CXX="g++ -m32" ./configure \
113 --host=i686-pc-linux-gnu \
114 --prefix=/usr \
115 --libdir=/usr/lib32 \
116 --disable-static \
117 --with-gcc-arch=i686 \
118 --disable-exec-static-tramp</userinput></screen>
119
120 <para>Compile the package:</para>
121
122<screen><userinput remap="make">make</userinput></screen>
123
124 <para>To test the results, issue:</para>
125
126<screen><userinput remap="test">make check</userinput></screen>
127
128 <para>Install the package:</para>
129
130<screen><userinput remap="install">make DESTDIR=$PWD/DESTDIR install
131cp -Rv DESTDIR/usr/lib32/* /usr/lib32
132rm -rf DESTDIR</userinput></screen>
133
134 </sect2><!-- m32 -->
135
136 <!-- - - - - - - - - - -->
137 <!-- Multilib - x32bit -->
138 <!-- - - - - - - - - - -->
139
140 <sect2 arch="ml_x32,ml_all" role="installation">
141 <title>Installation of Libffi - x32bit</title>
142
143 <para>Clean previous build:</para>
144
145<screen><userinput remap="pre">make distclean</userinput></screen>
146
147 <para>Prepare Libffi for compilation:</para>
148
149<screen><userinput remap="configure">CC="gcc -mx32" CXX="g++ -mx32" ./configure \
150 --host=x86_64-unknown-linux-gnux32 \
151 --prefix=/usr \
152 --libdir=/usr/libx32 \
153 --disable-static \
154 --with-gcc-arch=x86_64 \
155 --disable-exec-static-tramp</userinput></screen>
156
157 <para>Compile the package:</para>
158
159<screen><userinput remap="make">make</userinput></screen>
160
161 <para>To test the results, issue:</para>
162
163<screen><userinput remap="test">make check</userinput></screen>
164
165 <para>Install the package:</para>
166
167<screen><userinput remap="install">make DESTDIR=$PWD/DESTDIR install
168cp -Rv DESTDIR/usr/libx32/* /usr/libx32
169rm -rf DESTDIR</userinput></screen>
170
171 </sect2><!-- mx32 -->
172
173 <sect2 id="contents-libffi" role="content">
174 <title>Contents of Libffi</title>
175
176 <segmentedlist>
177 <segtitle>Installed library</segtitle>
178
179 <seglistitem>
180 <seg>libffi.so</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="libffi">
190 <term><filename class="libraryfile">libffi</filename></term>
191 <listitem>
192 <para>Contains the foreign function interface API functions</para>
193 <indexterm zone="ch-system-libffi">
194 <primary sortas="c-libffi">libffi</primary>
195 </indexterm>
196 </listitem>
197 </varlistentry>
198 </variablelist>
199
200 </sect2>
201
202</sect1>
Note: See TracBrowser for help on using the repository browser.