source: chapter08/libffi.xml@ 88804786

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

arm64: libffi: document known test failures

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