source: chapter08/libffi.xml@ 9a9655b3

12.0 12.0-rc1 12.1 12.1-rc1 bdubbs/gcc13 multilib renodr/libudev-from-systemd trunk xry111/arm64 xry111/arm64-12.0 xry111/clfs-ng xry111/loongarch xry111/loongarch-12.0 xry111/loongarch-12.1 xry111/mips64el xry111/update-glibc
Last change on this file since 9a9655b3 was 0f4ec34, checked in by Xi Ruoyao <xry111@…>, 17 months ago

libffi: Remove --disable-exec-static-tramp

It's not needed now since gjs-1.74 supports static trampoline.

  • Property mode set to 100644
File size: 4.1 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 \
[0f4ec34]65 --with-gcc-arch=native</userinput></screen>
[b8b65b7]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>
[77d2cd8d]73 <para>Ensure GCC optimizes for the current system. If this
[b8b65b7]74 is not specified, the system is guessed and the code generated
[e9c46b3]75 may not be correct. If the generated code
[d672ab7]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
[2c53f52]79 url='https://gcc.gnu.org/onlinedocs/gcc-&gcc-version;/gcc/x86-Options.html'>
[77d2cd8d]80 the x86 options in the GCC manual</ulink>.</para>
[b8b65b7]81 </listitem>
82 </varlistentry>
83 </variablelist>
[b0aabe0]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 <sect2 id="contents-libffi" role="content">
[e03d5e49]100 <title>Contents of Libffi</title>
[b0aabe0]101
102 <segmentedlist>
103 <segtitle>Installed library</segtitle>
104
105 <seglistitem>
106 <seg>libffi.so</seg>
107 </seglistitem>
108 </segmentedlist>
109
110 <variablelist>
111 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
112 <?dbfo list-presentation="list"?>
113 <?dbhtml list-presentation="table"?>
114
115 <varlistentry id="libffi">
116 <term><filename class="libraryfile">libffi</filename></term>
117 <listitem>
[e9c46b3]118 <para>Contains the foreign function interface API functions</para>
[b0aabe0]119 <indexterm zone="ch-system-libffi">
120 <primary sortas="c-libffi">libffi</primary>
121 </indexterm>
122 </listitem>
123 </varlistentry>
124 </variablelist>
125
126 </sect2>
127
128</sect1>
129
Note: See TracBrowser for help on using the repository browser.