source: chapter08/libffi.xml@ 20d6b70

11.3 11.3-rc1 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 20d6b70 was 20d6b70, checked in by Xi Ruoyao <xry111@…>, 17 months ago

libffi: style "libffi" (library name) with XML tag

As we are using "Libffi" for package name, I guess "libffi" (lower case)
means the library. So decorate it like how we handle other library
names.

  • Property mode set to 100644
File size: 4.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
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 \
66 --disable-exec-static-tramp</userinput></screen>
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>
74 <para>Ensure GCC optimizes for the current system. If this
75 is not specified, the system is guessed and the code generated
76 may not be correct. If the generated code
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
80 url='https://gcc.gnu.org/onlinedocs/gcc-&gcc-version;/gcc/x86-Options.html'>
81 the x86 options in the GCC manual</ulink>.</para>
82 </listitem>
83 </varlistentry>
84
85 <varlistentry>
86 <!-- To editors: try to remove it once GJS fixed (at GNOME 43) -->
87 <term><parameter>--disable-exec-static-tramp</parameter></term>
88 <listitem>
89 <para>Disable static trampoline support, a new security
90 feature in Libffi. Some BLFS packages (notably
91 <application>GJS</application>) have not been adapted for it.</para>
92 </listitem>
93 </varlistentry>
94
95 </variablelist>
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
105 <para>Install the package:</para>
106
107<screen><userinput remap="install">make install</userinput></screen>
108
109 </sect2>
110
111 <sect2 id="contents-libffi" role="content">
112 <title>Contents of Libffi</title>
113
114 <segmentedlist>
115 <segtitle>Installed library</segtitle>
116
117 <seglistitem>
118 <seg>libffi.so</seg>
119 </seglistitem>
120 </segmentedlist>
121
122 <variablelist>
123 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
124 <?dbfo list-presentation="list"?>
125 <?dbhtml list-presentation="table"?>
126
127 <varlistentry id="libffi">
128 <term><filename class="libraryfile">libffi</filename></term>
129 <listitem>
130 <para>Contains the foreign function interface API functions</para>
131 <indexterm zone="ch-system-libffi">
132 <primary sortas="c-libffi">libffi</primary>
133 </indexterm>
134 </listitem>
135 </varlistentry>
136 </variablelist>
137
138 </sect2>
139
140</sect1>
141
Note: See TracBrowser for help on using the repository browser.