libffi is a foreign function interface library. It provides a C programming language interface for calling natively compiled functions given information about the target function at run time instead of compile time. It also implements the opposite functionality: libffi can produce a pointer to a function that can accept and decode any combination of arguments defined at run time.
Developer(s) | Anthony Green |
---|---|
Initial release | October 7, 1996 |
Stable release | 3.4.6[1]
/ 18 February 2024 |
Repository | |
Written in | C, Assembly language |
Operating system | Unix-like, Microsoft Windows, OS X, iOS, bare metal |
Type | Runtime library |
License | MIT License[2] |
Website | sourceware |
libffi is most often used as a bridging technology between compiled and interpreted language implementations. libffi may also be used to implement plug-ins, where the plug-in's function signatures are not known at the time of creating the host application.
Notable users include Python, Haskell, Dalvik, F-Script, PyPy, PyObjC, RubyCocoa, JRuby, Rubinius, MacRuby, gcj, GNU Smalltalk, IcedTea, Cycript, Pawn, Java Native Access, Common Lisp (via CFFI), Racket,[3] Embeddable Common Lisp and Mozilla.[4]
On Mac OS X, libffi is commonly used with BridgeSupport, which provides programming language neutral descriptions of framework interfaces, and Nu which binds direct Objective-C access from Lisp.
libffi has been widely ported and is released under a MIT license.
Background
editAlthough the C programming language is ubiquitous among platforms, the ways function calls are implemented in machine code – the calling convention – vary. When one wants to load a subroutine dynamically at run-time, a knowledge of these conventions is required.
libffi has knowledge of the calling convention on many platforms (processor–OS combinations). Its C API, which is shared on all builds of libffi regardless of platform, abstracts over the complexity of loading code on different platforms. In addition to regular functions, it also supports C-style variadic functions.
The C calling convention is not only used by the C language: due to the amount of existing code written in C, most newer compiled languages also allow writing and calling functions in such a convention. As a result, libffi is able to interact with some functions written in these languages too.
History
editThis section is missing information about year of gencall.(January 2021) |
libffi, originally developed by Anthony Green, was inspired by the Gencall library from Silicon Graphics. Gencall was developed by Gianni Mariani, then employed by SGI, for the purpose of allowing calls to functions by address and creating a call frame for the particular calling convention (MIPS O32). Anthony Green refined the idea and extended it to other architectures and calling conventions and open sourcing libffi.
Adoption
editThe libffi library is useful in building a bridge between interpreted and natively compiled code. Some notable users include:
D
editF-Script
edit- F-Script
- Dynamically generates Cocoa classes written in F-Script.
Guile
edit- GNU Guile
- libffi is used in Guile 1.9.8 and onwards
Haskell
edit- GHC
- libffi has been used for the majority of the FFI performed by the GHC since late 2009.
Java
edit- OpenJDK
- The open-source implementation of the Java Platform Standard Edition uses libffi to bridge between the interpreter and native code for Zero-Assembly port.
- Java Native Access (JNA)
- The JNI-free way to call native code from Java.
- gcj
- The runtime library for the GNU Compiler for the Java Programming Language uses libffi to handle calls back and forth between interpreted and natively compiled code. gcj was a part of the GCC, the GNU Compiler Collection.
JavaScript
edit- JSCocoa
- Call Objective-C code from javascript on Mac OS X and the iPhone (via the libffi-iphone port).
Lisp
edit- cffi-libffi
- The standard foreign function interface library for Common Lisp CFFI includes the cffi-libffi system to include support for passing and returning structure arguments by value.
Perl
edit- FFI::Raw
- A thin wrapper around libffi.
- FFI::Platypus
- Newer, more convenient wrapper around libffi.
Python
edit- CPython
- The default, most-widely used implementation of the Python programming language uses libffi in the standard ctypes library.
- PyObjC
- Call Objective-C code from Python on Mac OS X.
Racket
edit- Racket
- Call C code from this popular Scheme implementation.
Ruby
edit- Fiddle
- A libffi wrapper in the Ruby Standard Library
- Ruby-FFI
- A Foreign Function Interface extension for Ruby.
- RubyCocoa
- Call Objective-C code from Ruby on Mac OS X.
References
edit- ^ "Release 3.4.6". 18 February 2024. Retrieved 20 February 2024.
- ^ "Status". GitHub. 25 April 2022.
- ^ "Archived copy" (PDF). Archived from the original (PDF) on 2009-09-02. Retrieved 2009-08-02.
{{cite web}}
: CS1 maint: archived copy as title (link) - ^ "Mozilla-central @ 2dc00d4b379a files manifest".
- ^ https://developer.mozilla.org/en/js-ctypes, js-ctypes reference