source: chapter08/libffi.xml@ d270248

xry111/arm64 xry111/arm64-12.0
Last change on this file since d270248 was ca4faad, checked in by Xi Ruoyao <xry111@…>, 22 months ago

Merge remote-tracking branch 'origin/trunk' into xry111/arm64

  • Property mode set to 100644
File size: 4.7 KB
RevLine 
[b0aabe0]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
[e03d5e49]17 <title>Libffi-&libffi-version;</title>
[b0aabe0]18
19 <indexterm zone="ch-system-libffi">
20 <primary sortas="a-libffi">libffi</primary>
21 </indexterm>
22
23 <sect2 role="package">
24 <title/>
25
[e03d5e49]26 <para>The Libffi library provides a portable, high level programming
[b0aabe0]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>
[e9c46b3]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>
[b0aabe0]34
35 <segmentedlist>
36 <segtitle>&buildtime;</segtitle>
37 <segtitle>&diskspace;</segtitle>
38
39 <seglistitem>
[fb386e0]40 <seg>&libffi-fin-sbu;</seg>
41 <seg>&libffi-fin-du;</seg>
[b0aabe0]42 </seglistitem>
43 </segmentedlist>
44
45 </sect2>
46
47 <sect2 role="installation">
[e03d5e49]48 <title>Installation of Libffi</title>
[b0aabe0]49
[8dbae30]50 <note>
[e9c46b3]51 <para>Like GMP, Libffi builds with optimizations specific
[ab7af9e]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.
[20d6b70]56 If this is not done, all applications that link to
57 <filename class='libraryfile'>libffi</filename> will trigger
[8dbae30]58 Illegal Operation Errors.</para>
59 </note>
[6a156bab]60
[e9c46b3]61 <para>Prepare Libffi for compilation:</para>
[b0aabe0]62
[3ba82a8]63 <screen><userinput remap="configure">./configure --prefix=/usr \
64 --disable-static \
65 --with-gcc-arch=native \
[c3f8922]66 --disable-exec-static-tramp</userinput></screen>
[b8b65b7]67
68 <variablelist>
69 <title>The meaning of the configure option:</title>
70
71 <varlistentry>
72 <term><parameter>--with-gcc-arch=native</parameter></term>
73 <listitem>
[77d2cd8d]74 <para>Ensure GCC optimizes for the current system. If this
[b8b65b7]75 is not specified, the system is guessed and the code generated
[e9c46b3]76 may not be correct. If the generated code
[d672ab7]77 will be copied from the native system to a less capable
78 system, use the less capable system as a parameter. For details
79 about alternative system types, see <ulink
[c8bc743]80 url='https://gcc.gnu.org/onlinedocs/gcc-&gcc-version;/gcc/AArch64-Options.html'>
81 the AArch64 options in the GCC manual</ulink>.</para>
[b8b65b7]82 </listitem>
83 </varlistentry>
84
[c3f8922]85 <varlistentry>
[0a99387]86 <!-- To editors: try to remove it once GJS fixed (at GNOME 43) -->
[c3f8922]87 <term><parameter>--disable-exec-static-tramp</parameter></term>
88 <listitem>
[e9c46b3]89 <para>Disable static trampoline support, a new security
90 feature in Libffi. Some BLFS packages (notably
[0a99387]91 <application>GJS</application>) have not been adapted for it.</para>
[c3f8922]92 </listitem>
93 </varlistentry>
94
[b8b65b7]95 </variablelist>
[b0aabe0]96
97 <para>Compile the package:</para>
98
99<screen><userinput remap="make">make</userinput></screen>
100
101 <para>To test the results, issue:</para>
102
103<screen><userinput remap="test">make check</userinput></screen>
104
[88804786]105 <!-- https://github.com/libffi/libffi/actions/runs/3084390461/jobs/4986488117 -->
106 <para>90 tests are known to fail on ARM64.</para>
107
[b0aabe0]108 <para>Install the package:</para>
109
110<screen><userinput remap="install">make install</userinput></screen>
111
112 </sect2>
113
114 <sect2 id="contents-libffi" role="content">
[e03d5e49]115 <title>Contents of Libffi</title>
[b0aabe0]116
117 <segmentedlist>
118 <segtitle>Installed library</segtitle>
119
120 <seglistitem>
121 <seg>libffi.so</seg>
122 </seglistitem>
123 </segmentedlist>
124
125 <variablelist>
126 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
127 <?dbfo list-presentation="list"?>
128 <?dbhtml list-presentation="table"?>
129
130 <varlistentry id="libffi">
131 <term><filename class="libraryfile">libffi</filename></term>
132 <listitem>
[e9c46b3]133 <para>Contains the foreign function interface API functions</para>
[b0aabe0]134 <indexterm zone="ch-system-libffi">
135 <primary sortas="c-libffi">libffi</primary>
136 </indexterm>
137 </listitem>
138 </varlistentry>
139 </variablelist>
140
141 </sect2>
142
143</sect1>
144
Note: See TracBrowser for help on using the repository browser.