summaryrefslogtreecommitdiff
path: root/libffi
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@lorry>2015-07-16 11:40:25 +0000
committerLorry Tar Creator <lorry-tar-importer@lorry>2015-07-16 11:40:25 +0000
commit8cd167a5ad8baf4988e07fcbc9c9cc338c02d3d1 (patch)
tree74fd60c507288ef44ed7f786fafeecbb5df0e160 /libffi
parentf80b5ea1605c9f9408c5aa386ba71c16d918ebbf (diff)
downloadgcc-tarball-8cd167a5ad8baf4988e07fcbc9c9cc338c02d3d1.tar.gz
gcc-5.2.0gcc-5.2.0
Diffstat (limited to 'libffi')
-rw-r--r--libffi/ChangeLog4
-rw-r--r--libffi/doc/libffi.info366
2 files changed, 186 insertions, 184 deletions
diff --git a/libffi/ChangeLog b/libffi/ChangeLog
index 306495b108..ba23fd738f 100644
--- a/libffi/ChangeLog
+++ b/libffi/ChangeLog
@@ -1,3 +1,7 @@
+2015-07-16 Release Manager
+
+ * GCC 5.2.0 released.
+
2015-04-22 Release Manager
* GCC 5.1.0 released.
diff --git a/libffi/doc/libffi.info b/libffi/doc/libffi.info
index aa7390f02d..b31b183438 100644
--- a/libffi/doc/libffi.info
+++ b/libffi/doc/libffi.info
@@ -1,4 +1,5 @@
-This is libffi.info, produced by makeinfo version 5.2 from libffi.texi.
+This is doc/libffi.info, produced by makeinfo version 4.12 from
+/space/rguenther/gcc-5.2.0/gcc-5.2.0/libffi/doc/libffi.texi.
This manual is for Libffi, a portable foreign-function interface
library.
@@ -7,9 +8,10 @@ library.
Permission is granted to copy, distribute and/or modify this
document under the terms of the GNU General Public License as
- published by the Free Software Foundation; either version 2, or (at
- your option) any later version. A copy of the license is included
- in the section entitled "GNU General Public License".
+ published by the Free Software Foundation; either version 2, or
+ (at your option) any later version. A copy of the license is
+ included in the section entitled "GNU General Public License".
+
INFO-DIR-SECTION Development
START-INFO-DIR-ENTRY
@@ -29,9 +31,10 @@ library.
Permission is granted to copy, distribute and/or modify this
document under the terms of the GNU General Public License as
- published by the Free Software Foundation; either version 2, or (at
- your option) any later version. A copy of the license is included
- in the section entitled "GNU General Public License".
+ published by the Free Software Foundation; either version 2, or
+ (at your option) any later version. A copy of the license is
+ included in the section entitled "GNU General Public License".
+
* Menu:
@@ -53,25 +56,25 @@ The calling convention is a set of assumptions made by the compiler
about where function arguments will be found on entry to a function. A
calling convention also specifies where the return value for a function
is found. The calling convention is also sometimes called the "ABI" or
-"Application Binary Interface".
+"Application Binary Interface".
Some programs may not know at the time of compilation what arguments
are to be passed to a function. For instance, an interpreter may be
told at run-time about the number and types of arguments used to call a
-given function. 'Libffi' can be used in such programs to provide a
+given function. `Libffi' can be used in such programs to provide a
bridge from the interpreter program to compiled code.
- The 'libffi' library provides a portable, high level programming
+ The `libffi' library provides a portable, high level programming
interface to various calling conventions. This allows a programmer to
call any function specified by a call interface description at run time.
FFI stands for Foreign Function Interface. A foreign function
-interface is the popular name for the interface that allows code written
-in one language to call code written in another language. The 'libffi'
-library really only provides the lowest, machine dependent layer of a
-fully featured foreign function interface. A layer must exist above
-'libffi' that handles type conversions for values passed between the two
-languages.
+interface is the popular name for the interface that allows code
+written in one language to call code written in another language. The
+`libffi' library really only provides the lowest, machine dependent
+layer of a fully featured foreign function interface. A layer must
+exist above `libffi' that handles type conversions for values passed
+between the two languages.

File: libffi.info, Node: Using libffi, Next: Missing Features, Prev: Introduction, Up: Top
@@ -94,45 +97,45 @@ File: libffi.info, Node: The Basics, Next: Simple Example, Up: Using libffi
2.1 The Basics
==============
-'Libffi' assumes that you have a pointer to the function you wish to
+`Libffi' assumes that you have a pointer to the function you wish to
call and that you know the number and types of arguments to pass it, as
well as the return type of the function.
- The first thing you must do is create an 'ffi_cif' object that
+ The first thing you must do is create an `ffi_cif' object that
matches the signature of the function you wish to call. This is a
-separate step because it is common to make multiple calls using a single
-'ffi_cif'. The "cif" in 'ffi_cif' stands for Call InterFace. To
-prepare a call interface object, use the function 'ffi_prep_cif'.
+separate step because it is common to make multiple calls using a
+single `ffi_cif'. The "cif" in `ffi_cif' stands for Call InterFace.
+To prepare a call interface object, use the function `ffi_prep_cif'.
-- Function: ffi_status ffi_prep_cif (ffi_cif *CIF, ffi_abi ABI,
unsigned int NARGS, ffi_type *RTYPE, ffi_type **ARGTYPES)
This initializes CIF according to the given parameters.
- ABI is the ABI to use; normally 'FFI_DEFAULT_ABI' is what you want.
- *note Multiple ABIs:: for more information.
+ ABI is the ABI to use; normally `FFI_DEFAULT_ABI' is what you
+ want. *note Multiple ABIs:: for more information.
NARGS is the number of arguments that this function accepts.
- RTYPE is a pointer to an 'ffi_type' structure that describes the
+ RTYPE is a pointer to an `ffi_type' structure that describes the
return type of the function. *Note Types::.
- ARGTYPES is a vector of 'ffi_type' pointers. ARGTYPES must have
+ ARGTYPES is a vector of `ffi_type' pointers. ARGTYPES must have
NARGS elements. If NARGS is 0, this argument is ignored.
- 'ffi_prep_cif' returns a 'libffi' status code, of type
- 'ffi_status'. This will be either 'FFI_OK' if everything worked
- properly; 'FFI_BAD_TYPEDEF' if one of the 'ffi_type' objects is
- incorrect; or 'FFI_BAD_ABI' if the ABI parameter is invalid.
+ `ffi_prep_cif' returns a `libffi' status code, of type
+ `ffi_status'. This will be either `FFI_OK' if everything worked
+ properly; `FFI_BAD_TYPEDEF' if one of the `ffi_type' objects is
+ incorrect; or `FFI_BAD_ABI' if the ABI parameter is invalid.
If the function being called is variadic (varargs) then
-'ffi_prep_cif_var' must be used instead of 'ffi_prep_cif'.
+`ffi_prep_cif_var' must be used instead of `ffi_prep_cif'.
- -- Function: ffi_status ffi_prep_cif_var (ffi_cif *CIF, ffi_abi varabi,
- unsigned int NFIXEDARGS, unsigned int varntotalargs, ffi_type
- *RTYPE, ffi_type **ARGTYPES)
+ -- Function: ffi_status ffi_prep_cif_var (ffi_cif *CIF, ffi_abi
+ varabi, unsigned int NFIXEDARGS, unsigned int varntotalargs,
+ ffi_type *RTYPE, ffi_type **ARGTYPES)
This initializes CIF according to the given parameters for a call
to a variadic function. In general it's operation is the same as
- for 'ffi_prep_cif' except that:
+ for `ffi_prep_cif' except that:
NFIXEDARGS is the number of fixed arguments, prior to any variadic
arguments. It must be greater than zero.
@@ -143,26 +146,27 @@ prepare a call interface object, use the function 'ffi_prep_cif'.
Note that, different cif's must be prepped for calls to the same
function when different numbers of arguments are passed.
- Also note that a call to 'ffi_prep_cif_var' with
+ Also note that a call to `ffi_prep_cif_var' with
NFIXEDARGS=NOTOTALARGS is NOT equivalent to a call to
- 'ffi_prep_cif'.
+ `ffi_prep_cif'.
- To call a function using an initialized 'ffi_cif', use the 'ffi_call'
-function:
+
+ To call a function using an initialized `ffi_cif', use the
+`ffi_call' function:
-- Function: void ffi_call (ffi_cif *CIF, void *FN, void *RVALUE, void
**AVALUES)
This calls the function FN according to the description given in
- CIF. CIF must have already been prepared using 'ffi_prep_cif'.
+ CIF. CIF must have already been prepared using `ffi_prep_cif'.
RVALUE is a pointer to a chunk of memory that will hold the result
of the function call. This must be large enough to hold the
result, no smaller than the system register size (generally 32 or
64 bits), and must be suitably aligned; it is the caller's
responsibility to ensure this. If CIF declares that the function
- returns 'void' (using 'ffi_type_void'), then RVALUE is ignored.
+ returns `void' (using `ffi_type_void'), then RVALUE is ignored.
- AVALUES is a vector of 'void *' pointers that point to the memory
+ AVALUES is a vector of `void *' pointers that point to the memory
locations holding the argument values for a call. If CIF declares
that the function has no arguments (i.e., NARGS was 0), then
AVALUES is ignored. Note that argument values may be modified by
@@ -175,7 +179,7 @@ File: libffi.info, Node: Simple Example, Next: Types, Prev: The Basics, Up:
2.2 Simple Example
==================
-Here is a trivial example that calls 'puts' a few times.
+Here is a trivial example that calls `puts' a few times.
#include <stdio.h>
#include <ffi.h>
@@ -230,91 +234,91 @@ File: libffi.info, Node: Primitive Types, Next: Structures, Up: Types
2.3.1 Primitive Types
---------------------
-'Libffi' provides a number of built-in type descriptors that can be used
-to describe argument and return types:
+`Libffi' provides a number of built-in type descriptors that can be
+used to describe argument and return types:
-'ffi_type_void'
- The type 'void'. This cannot be used for argument types, only for
+`ffi_type_void'
+ The type `void'. This cannot be used for argument types, only for
return values.
-'ffi_type_uint8'
+`ffi_type_uint8'
An unsigned, 8-bit integer type.
-'ffi_type_sint8'
+`ffi_type_sint8'
A signed, 8-bit integer type.
-'ffi_type_uint16'
+`ffi_type_uint16'
An unsigned, 16-bit integer type.
-'ffi_type_sint16'
+`ffi_type_sint16'
A signed, 16-bit integer type.
-'ffi_type_uint32'
+`ffi_type_uint32'
An unsigned, 32-bit integer type.
-'ffi_type_sint32'
+`ffi_type_sint32'
A signed, 32-bit integer type.
-'ffi_type_uint64'
+`ffi_type_uint64'
An unsigned, 64-bit integer type.
-'ffi_type_sint64'
+`ffi_type_sint64'
A signed, 64-bit integer type.
-'ffi_type_float'
- The C 'float' type.
+`ffi_type_float'
+ The C `float' type.
-'ffi_type_double'
- The C 'double' type.
+`ffi_type_double'
+ The C `double' type.
-'ffi_type_uchar'
- The C 'unsigned char' type.
+`ffi_type_uchar'
+ The C `unsigned char' type.
-'ffi_type_schar'
- The C 'signed char' type. (Note that there is not an exact
- equivalent to the C 'char' type in 'libffi'; ordinarily you should
- either use 'ffi_type_schar' or 'ffi_type_uchar' depending on
- whether 'char' is signed.)
+`ffi_type_schar'
+ The C `signed char' type. (Note that there is not an exact
+ equivalent to the C `char' type in `libffi'; ordinarily you should
+ either use `ffi_type_schar' or `ffi_type_uchar' depending on
+ whether `char' is signed.)
-'ffi_type_ushort'
- The C 'unsigned short' type.
+`ffi_type_ushort'
+ The C `unsigned short' type.
-'ffi_type_sshort'
- The C 'short' type.
+`ffi_type_sshort'
+ The C `short' type.
-'ffi_type_uint'
- The C 'unsigned int' type.
+`ffi_type_uint'
+ The C `unsigned int' type.
-'ffi_type_sint'
- The C 'int' type.
+`ffi_type_sint'
+ The C `int' type.
-'ffi_type_ulong'
- The C 'unsigned long' type.
+`ffi_type_ulong'
+ The C `unsigned long' type.
-'ffi_type_slong'
- The C 'long' type.
+`ffi_type_slong'
+ The C `long' type.
-'ffi_type_longdouble'
- On platforms that have a C 'long double' type, this is defined. On
- other platforms, it is not.
+`ffi_type_longdouble'
+ On platforms that have a C `long double' type, this is defined.
+ On other platforms, it is not.
-'ffi_type_pointer'
- A generic 'void *' pointer. You should use this for all pointers,
+`ffi_type_pointer'
+ A generic `void *' pointer. You should use this for all pointers,
regardless of their real type.
-'ffi_type_complex_float'
- The C '_Complex float' type.
+`ffi_type_complex_float'
+ The C `_Complex float' type.
-'ffi_type_complex_double'
- The C '_Complex double' type.
+`ffi_type_complex_double'
+ The C `_Complex double' type.
-'ffi_type_complex_longdouble'
- The C '_Complex long double' type. On platforms that have a C
- 'long double' type, this is defined. On other platforms, it is
+`ffi_type_complex_longdouble'
+ The C `_Complex long double' type. On platforms that have a C
+ `long double' type, this is defined. On other platforms, it is
not.
- Each of these is of type 'ffi_type', so you must take the address
-when passing to 'ffi_prep_cif'.
+ Each of these is of type `ffi_type', so you must take the address
+when passing to `ffi_prep_cif'.

File: libffi.info, Node: Structures, Next: Type Example, Prev: Primitive Types, Up: Types
@@ -322,24 +326,24 @@ File: libffi.info, Node: Structures, Next: Type Example, Prev: Primitive Type
2.3.2 Structures
----------------
-Although 'libffi' has no special support for unions or bit-fields, it is
-perfectly happy passing structures back and forth. You must first
-describe the structure to 'libffi' by creating a new 'ffi_type' object
+Although `libffi' has no special support for unions or bit-fields, it
+is perfectly happy passing structures back and forth. You must first
+describe the structure to `libffi' by creating a new `ffi_type' object
for it.
-- Data type: ffi_type
- The 'ffi_type' has the following members:
- 'size_t size'
- This is set by 'libffi'; you should initialize it to zero.
+ The `ffi_type' has the following members:
+ `size_t size'
+ This is set by `libffi'; you should initialize it to zero.
- 'unsigned short alignment'
- This is set by 'libffi'; you should initialize it to zero.
+ `unsigned short alignment'
+ This is set by `libffi'; you should initialize it to zero.
- 'unsigned short type'
- For a structure, this should be set to 'FFI_TYPE_STRUCT'.
+ `unsigned short type'
+ For a structure, this should be set to `FFI_TYPE_STRUCT'.
- 'ffi_type **elements'
- This is a 'NULL'-terminated array of pointers to 'ffi_type'
+ `ffi_type **elements'
+ This is a `NULL'-terminated array of pointers to `ffi_type'
objects. There is one element per field of the struct.

@@ -348,8 +352,8 @@ File: libffi.info, Node: Type Example, Next: Complex, Prev: Structures, Up:
2.3.3 Type Example
------------------
-The following example initializes a 'ffi_type' object representing the
-'tm' struct from Linux's 'time.h'.
+The following example initializes a `ffi_type' object representing the
+`tm' struct from Linux's `time.h'.
Here is how the struct is defined:
@@ -368,7 +372,7 @@ The following example initializes a 'ffi_type' object representing the
__const char *__tm_zone__;
};
- Here is the corresponding code to describe this struct to 'libffi':
+ Here is the corresponding code to describe this struct to `libffi':
{
ffi_type tm_type;
@@ -396,38 +400,37 @@ File: libffi.info, Node: Complex, Next: Complex Type Example, Prev: Type Exam
2.3.4 Complex Types
-------------------
-'libffi' supports the complex types defined by the C99 standard
-('_Complex float', '_Complex double' and '_Complex long double' with the
-built-in type descriptors 'ffi_type_complex_float',
-'ffi_type_complex_double' and 'ffi_type_complex_longdouble'.
+`libffi' supports the complex types defined by the C99 standard
+(`_Complex float', `_Complex double' and `_Complex long double' with
+the built-in type descriptors `ffi_type_complex_float',
+`ffi_type_complex_double' and `ffi_type_complex_longdouble'.
- Custom complex types like '_Complex int' can also be used. An
-'ffi_type' object has to be defined to describe the complex type to
-'libffi'.
+ Custom complex types like `_Complex int' can also be used. An
+`ffi_type' object has to be defined to describe the complex type to
+`libffi'.
-- Data type: ffi_type
- 'size_t size'
+ `size_t size'
This must be manually set to the size of the complex type.
- 'unsigned short alignment'
+ `unsigned short alignment'
This must be manually set to the alignment of the complex
type.
- 'unsigned short type'
- For a complex type, this must be set to 'FFI_TYPE_COMPLEX'.
-
- 'ffi_type **elements'
+ `unsigned short type'
+ For a complex type, this must be set to `FFI_TYPE_COMPLEX'.
- This is a 'NULL'-terminated array of pointers to 'ffi_type'
- objects. The first element is set to the 'ffi_type' of the
+ `ffi_type **elements'
+ This is a `NULL'-terminated array of pointers to `ffi_type'
+ objects. The first element is set to the `ffi_type' of the
complex's base type. The second element must be set to
- 'NULL'.
+ `NULL'.
- The section *note Complex Type Example:: shows a way to determine the
-'size' and 'alignment' members in a platform independent way.
+ The section *note Complex Type Example:: shows a way to determine
+the `size' and `alignment' members in a platform independent way.
- For platforms that have no complex support in 'libffi' yet, the
-functions 'ffi_prep_cif' and 'ffi_prep_args' abort the program if they
+ For platforms that have no complex support in `libffi' yet, the
+functions `ffi_prep_cif' and `ffi_prep_args' abort the program if they
encounter a complex type.

@@ -524,9 +527,9 @@ File: libffi.info, Node: Multiple ABIs, Next: The Closure API, Prev: Types,
=================
A given platform may provide multiple different ABIs at once. For
-instance, the x86 platform has both 'stdcall' and 'fastcall' functions.
+instance, the x86 platform has both `stdcall' and `fastcall' functions.
- 'libffi' provides some support for this. However, this is
+ `libffi' provides some support for this. However, this is
necessarily platform-specific.

@@ -535,32 +538,32 @@ File: libffi.info, Node: The Closure API, Next: Closure Example, Prev: Multip
2.5 The Closure API
===================
-'libffi' also provides a way to write a generic function - a function
+`libffi' also provides a way to write a generic function - a function
that can accept and decode any combination of arguments. This can be
-useful when writing an interpreter, or to provide wrappers for arbitrary
-functions.
+useful when writing an interpreter, or to provide wrappers for
+arbitrary functions.
- This facility is called the "closure API". Closures are not supported
-on all platforms; you can check the 'FFI_CLOSURES' define to determine
-whether they are supported on the current platform.
+ This facility is called the "closure API". Closures are not
+supported on all platforms; you can check the `FFI_CLOSURES' define to
+determine whether they are supported on the current platform.
Because closures work by assembling a tiny function at runtime, they
-require special allocation on platforms that have a non-executable heap.
-Memory management for closures is handled by a pair of functions:
+require special allocation on platforms that have a non-executable
+heap. Memory management for closures is handled by a pair of functions:
-- Function: void *ffi_closure_alloc (size_t SIZE, void **CODE)
Allocate a chunk of memory holding SIZE bytes. This returns a
pointer to the writable address, and sets *CODE to the
corresponding executable address.
- SIZE should be sufficient to hold a 'ffi_closure' object.
+ SIZE should be sufficient to hold a `ffi_closure' object.
-- Function: void ffi_closure_free (void *WRITABLE)
- Free memory allocated using 'ffi_closure_alloc'. The argument is
+ Free memory allocated using `ffi_closure_alloc'. The argument is
the writable address that was returned.
Once you have allocated the memory for a closure, you must construct
-a 'ffi_cif' describing the function call. Finally you can prepare the
+a `ffi_cif' describing the function call. Finally you can prepare the
closure function:
-- Function: ffi_status ffi_prep_closure_loc (ffi_closure *CLOSURE,
@@ -568,40 +571,40 @@ closure function:
**ARGS, void *USER_DATA), void *USER_DATA, void *CODELOC)
Prepare a closure function.
- CLOSURE is the address of a 'ffi_closure' object; this is the
- writable address returned by 'ffi_closure_alloc'.
+ CLOSURE is the address of a `ffi_closure' object; this is the
+ writable address returned by `ffi_closure_alloc'.
- CIF is the 'ffi_cif' describing the function parameters.
+ CIF is the `ffi_cif' describing the function parameters.
USER_DATA is an arbitrary datum that is passed, uninterpreted, to
your closure function.
- CODELOC is the executable address returned by 'ffi_closure_alloc'.
+ CODELOC is the executable address returned by `ffi_closure_alloc'.
FUN is the function which will be called when the closure is
invoked. It is called with the arguments:
- CIF
- The 'ffi_cif' passed to 'ffi_prep_closure_loc'.
+ CIF
+ The `ffi_cif' passed to `ffi_prep_closure_loc'.
- RET
+ RET
A pointer to the memory used for the function's return value.
FUN must fill this, unless the function is declared as
- returning 'void'.
+ returning `void'.
- ARGS
+ ARGS
A vector of pointers to memory holding the arguments to the
function.
- USER_DATA
- The same USER_DATA that was passed to 'ffi_prep_closure_loc'.
+ USER_DATA
+ The same USER_DATA that was passed to `ffi_prep_closure_loc'.
- 'ffi_prep_closure_loc' will return 'FFI_OK' if everything went ok,
+ `ffi_prep_closure_loc' will return `FFI_OK' if everything went ok,
and something else on error.
- After calling 'ffi_prep_closure_loc', you can cast CODELOC to the
+ After calling `ffi_prep_closure_loc', you can cast CODELOC to the
appropriate pointer-to-function type.
- You may see old code referring to 'ffi_prep_closure'. This function
+ You may see old code referring to `ffi_prep_closure'. This function
is deprecated, as it cannot handle the need for separate writable and
executable addresses.
@@ -611,8 +614,8 @@ File: libffi.info, Node: Closure Example, Prev: The Closure API, Up: Using li
2.6 Closure Example
===================
-A trivial example that creates a new 'puts' by binding 'fputs' with
-'stdout'.
+A trivial example that creates a new `puts' by binding `fputs' with
+`stdout'.
#include <stdio.h>
#include <ffi.h>
@@ -663,14 +666,13 @@ A trivial example that creates a new 'puts' by binding 'fputs' with
return 0;
}
-

File: libffi.info, Node: Missing Features, Next: Index, Prev: Using libffi, Up: Top
3 Missing Features
******************
-'libffi' is missing a few features. We welcome patches to add support
+`libffi' is missing a few features. We welcome patches to add support
for these.
* Variadic closures.
@@ -698,20 +700,17 @@ Index
* closure API: The Closure API. (line 13)
* closures: The Closure API. (line 13)
* FFI: Introduction. (line 31)
-* ffi_call: The Basics. (line 62)
-* FFI_CLOSURES: The Closure API. (line 13)
+* ffi_call: The Basics. (line 63)
* ffi_closure_alloc: The Closure API. (line 19)
* ffi_closure_free: The Closure API. (line 26)
+* FFI_CLOSURES: The Closure API. (line 13)
* ffi_prep_cif: The Basics. (line 16)
* ffi_prep_cif_var: The Basics. (line 39)
* ffi_prep_closure_loc: The Closure API. (line 34)
-* ffi_status: The Basics. (line 16)
-* ffi_status <1>: The Basics. (line 39)
-* ffi_status <2>: The Closure API. (line 34)
+* ffi_status <1>: The Closure API. (line 37)
+* ffi_status: The Basics. (line 18)
+* ffi_type <1>: Complex. (line 15)
* ffi_type: Structures. (line 11)
-* ffi_type <1>: Structures. (line 11)
-* ffi_type <2>: Complex. (line 15)
-* ffi_type <3>: Complex. (line 15)
* ffi_type_complex_double: Primitive Types. (line 82)
* ffi_type_complex_float: Primitive Types. (line 79)
* ffi_type_complex_longdouble: Primitive Types. (line 85)
@@ -737,28 +736,27 @@ Index
* ffi_type_ushort: Primitive Types. (line 53)
* ffi_type_void: Primitive Types. (line 10)
* Foreign Function Interface: Introduction. (line 31)
-* void: The Basics. (line 62)
-* void <1>: The Closure API. (line 19)
-* void <2>: The Closure API. (line 26)
+* void <1>: The Closure API. (line 20)
+* void: The Basics. (line 65)

Tag Table:
-Node: Top682
-Node: Introduction1429
-Node: Using libffi3061
-Node: The Basics3547
-Node: Simple Example7198
-Node: Types8229
-Node: Primitive Types8613
-Node: Structures10734
-Node: Type Example11608
-Node: Complex12890
-Node: Complex Type Example14308
-Node: Multiple ABIs17360
-Node: The Closure API17731
-Node: Closure Example20675
-Node: Missing Features22285
-Node: Index22713
+Node: Top736
+Node: Introduction1484
+Node: Using libffi3120
+Node: The Basics3606
+Node: Simple Example7260
+Node: Types8291
+Node: Primitive Types8675
+Node: Structures10795
+Node: Type Example11665
+Node: Complex12947
+Node: Complex Type Example14360
+Node: Multiple ABIs17412
+Node: The Closure API17783
+Node: Closure Example20727
+Node: Missing Features22336
+Node: Index22764

End Tag Table