ffi 1.15.5 → 1.17.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- checksums.yaml.gz.sig +0 -0
- data/CHANGELOG.md +118 -0
- data/Gemfile +10 -3
- data/README.md +4 -3
- data/Rakefile +25 -10
- data/ext/ffi_c/AbstractMemory.c +99 -74
- data/ext/ffi_c/AbstractMemory.h +3 -2
- data/ext/ffi_c/ArrayType.c +51 -15
- data/ext/ffi_c/ArrayType.h +1 -0
- data/ext/ffi_c/Buffer.c +90 -33
- data/ext/ffi_c/Call.c +29 -12
- data/ext/ffi_c/Call.h +3 -2
- data/ext/ffi_c/DynamicLibrary.c +90 -27
- data/ext/ffi_c/Function.c +244 -98
- data/ext/ffi_c/Function.h +1 -0
- data/ext/ffi_c/FunctionInfo.c +81 -25
- data/ext/ffi_c/LastError.c +29 -11
- data/ext/ffi_c/MappedType.c +66 -23
- data/ext/ffi_c/MappedType.h +0 -2
- data/ext/ffi_c/MemoryPointer.c +36 -9
- data/ext/ffi_c/MethodHandle.c +3 -1
- data/ext/ffi_c/Pointer.c +82 -40
- data/ext/ffi_c/Pointer.h +1 -0
- data/ext/ffi_c/Struct.c +166 -84
- data/ext/ffi_c/Struct.h +7 -4
- data/ext/ffi_c/StructByValue.c +48 -16
- data/ext/ffi_c/StructLayout.c +130 -61
- data/ext/ffi_c/Type.c +120 -51
- data/ext/ffi_c/Type.h +3 -1
- data/ext/ffi_c/Types.c +8 -2
- data/ext/ffi_c/Types.h +0 -1
- data/ext/ffi_c/Variadic.c +71 -26
- data/ext/ffi_c/compat.h +22 -22
- data/ext/ffi_c/extconf.rb +19 -2
- data/ext/ffi_c/ffi.c +4 -0
- data/ext/ffi_c/libffi/.allow-ai-service +0 -0
- data/ext/ffi_c/libffi/.appveyor/site.exp +16 -0
- data/ext/ffi_c/libffi/.appveyor/unix-noexec.exp +7 -0
- data/ext/ffi_c/libffi/.appveyor.yml +27 -9
- data/ext/ffi_c/libffi/.ci/build-cross-in-container.sh +18 -0
- data/ext/ffi_c/libffi/{.travis → .ci}/build-in-container.sh +4 -6
- data/ext/ffi_c/libffi/.ci/build.sh +124 -0
- data/ext/ffi_c/libffi/{.travis → .ci}/install.sh +14 -7
- data/ext/ffi_c/libffi/.ci/msvs-detect +1103 -0
- data/ext/ffi_c/libffi/{.travis → .ci}/site.exp +5 -3
- data/ext/ffi_c/libffi/.circleci/config.yml +156 -0
- data/ext/ffi_c/libffi/.github/workflows/build.yml +479 -0
- data/ext/ffi_c/libffi/.github/workflows/emscripten.yml +172 -0
- data/ext/ffi_c/libffi/.gitignore +10 -2
- data/ext/ffi_c/libffi/LICENSE +1 -1
- data/ext/ffi_c/libffi/Makefile.am +12 -5
- data/ext/ffi_c/libffi/Makefile.in +118 -51
- data/ext/ffi_c/libffi/README.md +150 -105
- data/ext/ffi_c/libffi/acinclude.m4 +10 -112
- data/ext/ffi_c/libffi/compile +348 -0
- data/ext/ffi_c/libffi/config.guess +623 -556
- data/ext/ffi_c/libffi/config.sub +75 -34
- data/ext/ffi_c/libffi/configure +4571 -3830
- data/ext/ffi_c/libffi/configure.ac +64 -28
- data/ext/ffi_c/libffi/configure.host +26 -7
- data/ext/ffi_c/libffi/doc/Makefile.in +9 -6
- data/ext/ffi_c/libffi/doc/libffi.texi +82 -33
- data/ext/ffi_c/libffi/doc/version.texi +4 -4
- data/ext/ffi_c/libffi/fficonfig.h.in +12 -47
- data/ext/ffi_c/libffi/generate-darwin-source-and-headers.py +163 -52
- data/ext/ffi_c/libffi/include/Makefile.am +1 -1
- data/ext/ffi_c/libffi/include/Makefile.in +10 -9
- data/ext/ffi_c/libffi/include/ffi.h.in +55 -60
- data/ext/ffi_c/libffi/include/ffi_cfi.h +21 -0
- data/ext/ffi_c/libffi/include/ffi_common.h +33 -2
- data/ext/ffi_c/libffi/include/tramp.h +45 -0
- data/ext/ffi_c/libffi/install-sh +92 -69
- data/ext/ffi_c/libffi/libffi.map.in +5 -0
- data/ext/ffi_c/libffi/libtool-version +2 -2
- data/ext/ffi_c/libffi/ltmain.sh +518 -333
- data/ext/ffi_c/libffi/m4/ax_cc_maxopt.m4 +18 -14
- data/ext/ffi_c/libffi/m4/ax_cflags_warn_all.m4 +108 -72
- data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +76 -45
- data/ext/ffi_c/libffi/m4/ax_prepend_flag.m4 +51 -0
- data/ext/ffi_c/libffi/man/Makefile.in +9 -6
- data/ext/ffi_c/libffi/missing +1 -1
- data/ext/ffi_c/libffi/msvc_build/aarch64/aarch64_include/ffi.h +2 -2
- data/ext/ffi_c/libffi/msvcc.sh +1 -1
- data/ext/ffi_c/libffi/src/aarch64/ffi.c +172 -55
- data/ext/ffi_c/libffi/src/aarch64/internal.h +32 -0
- data/ext/ffi_c/libffi/src/aarch64/sysv.S +331 -87
- data/ext/ffi_c/libffi/src/arc/arcompact.S +169 -94
- data/ext/ffi_c/libffi/src/arc/ffi.c +325 -148
- data/ext/ffi_c/libffi/src/arc/ffitarget.h +14 -0
- data/ext/ffi_c/libffi/src/arm/ffi.c +62 -17
- data/ext/ffi_c/libffi/src/arm/ffitarget.h +3 -3
- data/ext/ffi_c/libffi/src/arm/internal.h +10 -0
- data/ext/ffi_c/libffi/src/arm/sysv.S +113 -42
- data/ext/ffi_c/libffi/src/closures.c +136 -50
- data/ext/ffi_c/libffi/src/debug.c +2 -2
- data/ext/ffi_c/libffi/src/dlmalloc.c +6 -1
- data/ext/ffi_c/libffi/src/ia64/ffi.c +12 -0
- data/ext/ffi_c/libffi/src/ia64/unix.S +20 -2
- data/ext/ffi_c/libffi/src/loongarch64/ffi.c +624 -0
- data/ext/ffi_c/libffi/src/loongarch64/ffitarget.h +82 -0
- data/ext/ffi_c/libffi/src/loongarch64/sysv.S +327 -0
- data/ext/ffi_c/libffi/src/m32r/ffi.c +31 -14
- data/ext/ffi_c/libffi/src/mips/ffi.c +250 -67
- data/ext/ffi_c/libffi/src/mips/ffitarget.h +7 -0
- data/ext/ffi_c/libffi/src/mips/n32.S +193 -33
- data/ext/ffi_c/libffi/src/mips/o32.S +61 -4
- data/ext/ffi_c/libffi/src/moxie/ffi.c +47 -22
- data/ext/ffi_c/libffi/src/or1k/ffi.c +25 -12
- data/ext/ffi_c/libffi/src/pa/ffi.c +32 -33
- data/ext/ffi_c/libffi/src/pa/ffi64.c +614 -0
- data/ext/ffi_c/libffi/src/pa/ffitarget.h +22 -8
- data/ext/ffi_c/libffi/src/pa/hpux32.S +83 -36
- data/ext/ffi_c/libffi/src/pa/hpux64.S +681 -0
- data/ext/ffi_c/libffi/src/pa/linux.S +82 -35
- data/ext/ffi_c/libffi/src/powerpc/ffi_darwin.c +36 -24
- data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +1 -1
- data/ext/ffi_c/libffi/src/powerpc/linux64.S +2 -0
- data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +2 -0
- data/ext/ffi_c/libffi/src/powerpc/t-aix +5 -0
- data/ext/ffi_c/libffi/src/prep_cif.c +22 -2
- data/ext/ffi_c/libffi/src/riscv/ffi.c +37 -4
- data/ext/ffi_c/libffi/src/sparc/ffi64.c +23 -1
- data/ext/ffi_c/libffi/src/tramp.c +716 -0
- data/ext/ffi_c/libffi/src/types.c +4 -6
- data/ext/ffi_c/libffi/src/wasm32/ffi.c +947 -0
- data/ext/ffi_c/libffi/src/wasm32/ffitarget.h +62 -0
- data/ext/ffi_c/libffi/src/x86/ffi.c +99 -37
- data/ext/ffi_c/libffi/src/x86/ffi64.c +67 -12
- data/ext/ffi_c/libffi/src/x86/ffitarget.h +9 -5
- data/ext/ffi_c/libffi/src/x86/ffiw64.c +44 -1
- data/ext/ffi_c/libffi/src/x86/internal.h +14 -0
- data/ext/ffi_c/libffi/src/x86/internal64.h +14 -0
- data/ext/ffi_c/libffi/src/x86/sysv.S +172 -38
- data/ext/ffi_c/libffi/src/x86/sysv_intel.S +91 -88
- data/ext/ffi_c/libffi/src/x86/unix64.S +96 -6
- data/ext/ffi_c/libffi/src/x86/win64.S +20 -7
- data/ext/ffi_c/libffi/src/xtensa/ffi.c +16 -8
- data/ext/ffi_c/libffi/src/xtensa/ffitarget.h +4 -0
- data/ext/ffi_c/libffi/src/xtensa/sysv.S +26 -16
- data/ext/ffi_c/libffi/testsuite/Makefile.am +79 -114
- data/ext/ffi_c/libffi/testsuite/Makefile.in +89 -121
- data/ext/ffi_c/libffi/testsuite/emscripten/build-tests.sh +54 -0
- data/ext/ffi_c/libffi/testsuite/emscripten/build.sh +63 -0
- data/ext/ffi_c/libffi/testsuite/emscripten/conftest.py +86 -0
- data/ext/ffi_c/libffi/testsuite/emscripten/node-tests.sh +48 -0
- data/ext/ffi_c/libffi/testsuite/emscripten/test.html +7 -0
- data/ext/ffi_c/libffi/testsuite/emscripten/test_libffi.py +51 -0
- data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +43 -21
- data/ext/ffi_c/libffi/testsuite/lib/target-libpath.exp +2 -2
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-call.c +1 -0
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/testcases.c +5 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/bpo_38748.c +41 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/callback.c +99 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/callback2.c +108 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/callback3.c +114 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/callback4.c +119 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/ffitest.h +28 -3
- data/ext/ffi_c/libffi/testsuite/libffi.call/float_va.c +3 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll1.c +5 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_sl.c +4 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_ul.c +4 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/s55.c +60 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/strlen.c +8 -9
- data/ext/ffi_c/libffi/testsuite/libffi.call/strlen2.c +2 -2
- data/ext/ffi_c/libffi/testsuite/libffi.call/strlen3.c +2 -2
- data/ext/ffi_c/libffi/testsuite/libffi.call/strlen4.c +2 -2
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct10.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_2.c +63 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_3.c +65 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_3f.c +65 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_4.c +67 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_4f.c +67 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_big.c +93 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_small.c +61 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_return_2H.c +63 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct_return_8H.c +90 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_1.c +1 -119
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_2.c +220 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_3.c +154 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct1.c +13 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct2.c +11 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct3.c +15 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn0.c +3 -2
- data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn1.c +2 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn2.c +2 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn3.c +21 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn4.c +2 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn5.c +2 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn6.c +2 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_loc_fn0.c +7 -6
- data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_simple.c +6 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_12byte.c +18 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_16byte.c +22 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_18byte.c +24 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_19byte.c +29 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_1_1byte.c +4 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_20byte.c +19 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_20byte1.c +21 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_24byte.c +35 -3
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_2byte.c +13 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3_1byte.c +19 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3byte1.c +13 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3byte2.c +13 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3float.c +18 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_4_1byte.c +22 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_4byte.c +13 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_5_1_byte.c +29 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_5byte.c +19 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_64byte.c +24 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_6_1_byte.c +28 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_6byte.c +24 -2
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_7_1_byte.c +39 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_7byte.c +25 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_8byte.c +14 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_9byte1.c +14 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_9byte2.c +14 -2
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_double.c +19 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_float.c +19 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_longdouble.c +20 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_longdouble_split.c +40 -25
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_longdouble_split2.c +40 -3
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_pointer.c +19 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_sint16.c +18 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_sint32.c +18 -3
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_sint64.c +18 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_uint16.c +18 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_uint32.c +19 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_uint64.c +19 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_dbls_struct.c +3 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_double_va.c +9 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_float.c +4 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_longdouble.c +11 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_longdouble_va.c +22 -3
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_schar.c +5 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_sshort.c +6 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_sshortchar.c +9 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_uchar.c +9 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_ushort.c +6 -2
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_ushortchar.c +9 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_pointer.c +5 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_pointer_stack.c +10 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_schar.c +3 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_sint.c +2 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_sshort.c +3 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_struct_va1.c +11 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uchar.c +3 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uint.c +4 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uint_va.c +4 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ulong_va.c +4 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ulonglong.c +2 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ushort.c +3 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/ffitest.h +1 -138
- data/ext/ffi_c/libffi/testsuite/libffi.closures/huge_struct.c +21 -21
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct.c +32 -9
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct1.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct10.c +12 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct11.c +21 -5
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct12.c +86 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct13.c +115 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct2.c +10 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct3.c +10 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct4.c +9 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct5.c +9 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct6.c +11 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct7.c +9 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct8.c +11 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct9.c +11 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs1.c +86 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs2.c +102 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs3.c +101 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/stret_medium.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/stret_medium2.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/testclosure.c +6 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/unwindtest.cc +2 -1
- data/ext/ffi_c/libffi/testsuite/libffi.closures/unwindtest_ffi_call.cc +1 -0
- data/ext/ffi_c/libffi.bsd.mk +2 -2
- data/ext/ffi_c/libffi.darwin.mk +2 -2
- data/ext/ffi_c/libffi.gnu.mk +2 -2
- data/ext/ffi_c/rbffi.h +1 -1
- data/ffi.gemspec +3 -3
- data/lib/ffi/autopointer.rb +8 -31
- data/lib/ffi/compat.rb +43 -0
- data/lib/ffi/data_converter.rb +2 -2
- data/lib/ffi/dynamic_library.rb +118 -0
- data/lib/ffi/enum.rb +18 -12
- data/lib/ffi/ffi.rb +3 -0
- data/lib/ffi/function.rb +71 -0
- data/lib/ffi/io.rb +2 -2
- data/lib/ffi/library.rb +72 -88
- data/lib/ffi/library_path.rb +109 -0
- data/lib/ffi/managedstruct.rb +1 -1
- data/lib/ffi/platform/aarch64-linux/types.conf +74 -3
- data/lib/ffi/platform/aarch64-windows/types.conf +52 -0
- data/lib/ffi/platform/hppa1.1-linux/types.conf +178 -0
- data/lib/ffi/platform/hppa2.0-linux/types.conf +178 -0
- data/lib/ffi/platform/loongarch64-linux/types.conf +141 -0
- data/lib/ffi/platform/sw_64-linux/types.conf +141 -0
- data/lib/ffi/platform.rb +15 -13
- data/lib/ffi/pointer.rb +6 -6
- data/lib/ffi/struct.rb +6 -5
- data/lib/ffi/struct_layout.rb +3 -3
- data/lib/ffi/struct_layout_builder.rb +9 -9
- data/lib/ffi/types.rb +65 -37
- data/lib/ffi/variadic.rb +19 -8
- data/lib/ffi/version.rb +1 -1
- data/samples/hello_ractor.rb +11 -0
- data/samples/qsort_ractor.rb +28 -0
- data/sig/ffi/abstract_memory.rbs +165 -0
- data/sig/ffi/auto_pointer.rbs +27 -0
- data/sig/ffi/buffer.rbs +18 -0
- data/sig/ffi/data_converter.rbs +10 -0
- data/sig/ffi/dynamic_library.rbs +9 -0
- data/sig/ffi/enum.rbs +38 -0
- data/sig/ffi/function.rbs +39 -0
- data/sig/ffi/library.rbs +42 -0
- data/sig/ffi/native_type.rbs +86 -0
- data/sig/ffi/pointer.rbs +42 -0
- data/sig/ffi/struct.rbs +76 -0
- data/sig/ffi/struct_by_reference.rbs +11 -0
- data/sig/ffi/struct_by_value.rbs +7 -0
- data/sig/ffi/struct_layout.rbs +9 -0
- data/sig/ffi/struct_layout_builder.rbs +5 -0
- data/sig/ffi/type.rbs +39 -0
- data/sig/ffi.rbs +26 -0
- data.tar.gz.sig +0 -0
- metadata +122 -28
- metadata.gz.sig +1 -0
- data/ext/ffi_c/libffi/.travis/build-cross-in-container.sh +0 -14
- data/ext/ffi_c/libffi/.travis/build.sh +0 -142
- data/ext/ffi_c/libffi/.travis.yml +0 -83
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uchar_va.c +0 -44
- data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ushort_va.c +0 -44
- /data/ext/ffi_c/libffi/{.travis → .ci}/ar-lib +0 -0
- /data/ext/ffi_c/libffi/{.travis → .ci}/bfin-sim.exp +0 -0
- /data/ext/ffi_c/libffi/{.travis → .ci}/compile +0 -0
- /data/ext/ffi_c/libffi/{.travis → .ci}/m32r-sim.exp +0 -0
- /data/ext/ffi_c/libffi/{.travis → .ci}/moxie-sim.exp +0 -0
- /data/ext/ffi_c/libffi/{.travis → .ci}/or1k-sim.exp +0 -0
- /data/ext/ffi_c/libffi/{.travis → .ci}/powerpc-eabisim.exp +0 -0
- /data/ext/ffi_c/libffi/{.travis → .ci}/wine-sim.exp +0 -0
- /data/ext/ffi_c/libffi/testsuite/libffi.call/{pyobjc-tc.c → pyobjc_tc.c} +0 -0
- /data/lib/ffi/platform/{sparc64-linux → sparcv9-linux}/types.conf +0 -0
@@ -1,11 +1,11 @@
|
|
1
1
|
dnl Process this with autoconf to create configure
|
2
2
|
|
3
|
-
AC_PREREQ(2.
|
3
|
+
AC_PREREQ([2.71])
|
4
4
|
|
5
|
-
AC_INIT([libffi],
|
5
|
+
AC_INIT([libffi],[3.4.6],[http://github.com/libffi/libffi/issues])
|
6
6
|
AC_CONFIG_HEADERS([fficonfig.h])
|
7
7
|
|
8
|
-
|
8
|
+
AC_CANONICAL_TARGET
|
9
9
|
target_alias=${target_alias-$host_alias}
|
10
10
|
|
11
11
|
case "${host}" in
|
@@ -38,9 +38,12 @@ AC_SUBST(CFLAGS)
|
|
38
38
|
|
39
39
|
AM_PROG_AS
|
40
40
|
AM_PROG_CC_C_O
|
41
|
-
|
41
|
+
AC_PROG_EGREP
|
42
|
+
LT_INIT
|
42
43
|
AC_CONFIG_MACRO_DIR([m4])
|
43
44
|
|
45
|
+
AC_CHECK_TOOL(READELF, readelf)
|
46
|
+
|
44
47
|
# Test for 64-bit build.
|
45
48
|
AC_CHECK_SIZEOF([size_t])
|
46
49
|
|
@@ -59,6 +62,7 @@ fi
|
|
59
62
|
cat > local.exp <<EOF
|
60
63
|
set CC_FOR_TARGET "$CC"
|
61
64
|
set CXX_FOR_TARGET "$CXX"
|
65
|
+
set compiler_vendor "$ax_cv_c_compiler_vendor"
|
62
66
|
EOF
|
63
67
|
|
64
68
|
AM_MAINTAINER_MODE
|
@@ -66,10 +70,6 @@ AM_MAINTAINER_MODE
|
|
66
70
|
AC_CHECK_HEADERS(sys/memfd.h)
|
67
71
|
AC_CHECK_FUNCS([memfd_create])
|
68
72
|
|
69
|
-
AC_CHECK_HEADERS(sys/mman.h)
|
70
|
-
AC_CHECK_FUNCS([mmap mkostemp])
|
71
|
-
AC_FUNC_MMAP_BLACKLIST
|
72
|
-
|
73
73
|
dnl The -no-testsuite modules omit the test subdir.
|
74
74
|
AM_CONDITIONAL(TESTSUBDIR, test -d $srcdir/testsuite)
|
75
75
|
|
@@ -85,9 +85,17 @@ fi
|
|
85
85
|
AC_SUBST(AM_RUNTESTFLAGS)
|
86
86
|
AC_SUBST(AM_LTLDFLAGS)
|
87
87
|
|
88
|
-
|
88
|
+
m4_warn([obsolete],
|
89
|
+
[The preprocessor macro `STDC_HEADERS' is obsolete.
|
90
|
+
Except in unusual embedded environments, you can safely include all
|
91
|
+
ISO C90 headers unconditionally.])dnl
|
92
|
+
# Autoupdate added the next two lines to ensure that your configure
|
93
|
+
# script's behavior did not change. They are probably safe to remove.
|
94
|
+
AC_CHECK_INCLUDES_DEFAULT
|
95
|
+
AC_PROG_EGREP
|
96
|
+
|
89
97
|
AC_CHECK_FUNCS(memcpy)
|
90
|
-
|
98
|
+
AC_CHECK_HEADERS(alloca.h)
|
91
99
|
|
92
100
|
AC_CHECK_SIZEOF(double)
|
93
101
|
AC_CHECK_SIZEOF(long double)
|
@@ -122,9 +130,7 @@ case "$TARGET" in
|
|
122
130
|
save_LDFLAGS="$LDFLAGS"
|
123
131
|
CFLAGS="$CFLAGS -fpic"
|
124
132
|
LDFLAGS="$LDFLAGS -shared"
|
125
|
-
|
126
|
-
[libffi_cv_as_sparc_ua_pcrel=yes],
|
127
|
-
[libffi_cv_as_sparc_ua_pcrel=no])
|
133
|
+
AC_LINK_IFELSE([AC_LANG_PROGRAM([[asm (".text; foo: nop; .data; .align 4; .byte 0; .uaword %r_disp32(foo); .text");]], [[]])],[libffi_cv_as_sparc_ua_pcrel=yes],[libffi_cv_as_sparc_ua_pcrel=no])
|
128
134
|
CFLAGS="$save_CFLAGS"
|
129
135
|
LDFLAGS="$save_LDFLAGS"])
|
130
136
|
if test "x$libffi_cv_as_sparc_ua_pcrel" = xyes; then
|
@@ -136,9 +142,7 @@ case "$TARGET" in
|
|
136
142
|
libffi_cv_as_register_pseudo_op, [
|
137
143
|
libffi_cv_as_register_pseudo_op=unknown
|
138
144
|
# Check if we have .register
|
139
|
-
|
140
|
-
[libffi_cv_as_register_pseudo_op=yes],
|
141
|
-
[libffi_cv_as_register_pseudo_op=no])
|
145
|
+
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[asm (".register %g2, #scratch");]])],[libffi_cv_as_register_pseudo_op=yes],[libffi_cv_as_register_pseudo_op=no])
|
142
146
|
])
|
143
147
|
if test "x$libffi_cv_as_register_pseudo_op" = xyes; then
|
144
148
|
AC_DEFINE(HAVE_AS_REGISTER_PSEUDO_OP, 1,
|
@@ -182,7 +186,7 @@ esac
|
|
182
186
|
AC_CACHE_CHECK([whether compiler supports pointer authentication],
|
183
187
|
libffi_cv_as_ptrauth, [
|
184
188
|
libffi_cv_as_ptrauth=unknown
|
185
|
-
|
189
|
+
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[
|
186
190
|
#ifdef __clang__
|
187
191
|
# if __has_feature(ptrauth_calls)
|
188
192
|
# define HAVE_PTRAUTH 1
|
@@ -192,21 +196,24 @@ AC_CACHE_CHECK([whether compiler supports pointer authentication],
|
|
192
196
|
#ifndef HAVE_PTRAUTH
|
193
197
|
# error Pointer authentication not supported
|
194
198
|
#endif
|
195
|
-
],
|
196
|
-
[libffi_cv_as_ptrauth=yes],
|
197
|
-
[libffi_cv_as_ptrauth=no])
|
199
|
+
]])],[libffi_cv_as_ptrauth=yes],[libffi_cv_as_ptrauth=no])
|
198
200
|
])
|
199
201
|
if test "x$libffi_cv_as_ptrauth" = xyes; then
|
200
202
|
AC_DEFINE(HAVE_PTRAUTH, 1,
|
201
203
|
[Define if your compiler supports pointer authentication.])
|
202
204
|
fi
|
203
205
|
|
204
|
-
# On PaX enable kernels that have MPROTECT enable we can't use PROT_EXEC
|
206
|
+
# On PaX enable kernels that have MPROTECT enable we can't use PROT_EXEC;
|
207
|
+
# if EMUTRAMP is active too ffi could try mapping without PROT_EXEC,
|
208
|
+
# but the kernel needs to recognize the trampoline generated by ffi.
|
209
|
+
# Otherwise fallback to double mmap trick.
|
205
210
|
AC_ARG_ENABLE(pax_emutramp,
|
206
|
-
[ --enable-pax_emutramp enable pax emulated trampolines
|
211
|
+
[ --enable-pax_emutramp enable pax emulated trampolines (experimental)],
|
207
212
|
if test "$enable_pax_emutramp" = "yes"; then
|
213
|
+
AC_MSG_WARN([EMUTRAMP is experimental only. Use --enable-pax_emutramp=experimental to enforce.])
|
214
|
+
elif test "$enable_pax_emutramp" = "experimental"; then
|
208
215
|
AC_DEFINE(FFI_MMAP_EXEC_EMUTRAMP_PAX, 1,
|
209
|
-
[Define this if you want to enable pax emulated trampolines])
|
216
|
+
[Define this if you want to enable pax emulated trampolines (experimental)])
|
210
217
|
fi)
|
211
218
|
|
212
219
|
LT_SYS_SYMBOL_USCORE
|
@@ -270,7 +277,7 @@ if test "x$GCC" = "xyes"; then
|
|
270
277
|
libffi_cv_ro_eh_frame=yes
|
271
278
|
echo 'extern void foo (void); void bar (void) { foo (); foo (); }' > conftest.c
|
272
279
|
if $CC $CFLAGS -c -fpic -fexceptions $libffi_cv_no_lto -o conftest.o conftest.c > /dev/null 2>&1; then
|
273
|
-
if
|
280
|
+
if $READELF -WS conftest.o 2>/dev/null | grep -q -n 'eh_frame .* WA'; then
|
274
281
|
libffi_cv_ro_eh_frame=no
|
275
282
|
fi
|
276
283
|
fi
|
@@ -291,7 +298,7 @@ if test "x$GCC" = "xyes"; then
|
|
291
298
|
echo 'int __attribute__ ((visibility ("hidden"))) foo (void) { return 1 ; }' > conftest.c
|
292
299
|
libffi_cv_hidden_visibility_attribute=no
|
293
300
|
if AC_TRY_COMMAND(${CC-cc} -Werror -S conftest.c -o conftest.s 1>&AS_MESSAGE_LOG_FD); then
|
294
|
-
if
|
301
|
+
if $EGREP '(\.hidden|\.private_extern).*foo|foo.*,hidden' conftest.s >/dev/null; then
|
295
302
|
libffi_cv_hidden_visibility_attribute=yes
|
296
303
|
fi
|
297
304
|
fi
|
@@ -304,8 +311,7 @@ if test "x$GCC" = "xyes"; then
|
|
304
311
|
fi
|
305
312
|
|
306
313
|
AC_ARG_ENABLE(docs,
|
307
|
-
|
308
|
-
[Disable building of docs (default: no)]),
|
314
|
+
AS_HELP_STRING([--disable-docs],[Disable building of docs (default: no)]),
|
309
315
|
[enable_docs=no],
|
310
316
|
[enable_docs=yes])
|
311
317
|
AM_CONDITIONAL(BUILD_DOCS, [test x$enable_docs = xyes])
|
@@ -363,6 +369,26 @@ AC_ARG_ENABLE(raw-api,
|
|
363
369
|
AC_DEFINE(FFI_NO_RAW_API, 1, [Define this if you do not want support for the raw API.])
|
364
370
|
fi)
|
365
371
|
|
372
|
+
AC_ARG_ENABLE(exec-static-tramp,
|
373
|
+
[ --disable-exec-static-tramp disable use of static exec trampolines (enabled by default)])
|
374
|
+
|
375
|
+
if test "$enable_exec_static_tramp" != no; then
|
376
|
+
case "$target" in
|
377
|
+
*-cygwin* | *-msys*)
|
378
|
+
# Only define static trampolines if we are using the cygwin runtime.
|
379
|
+
# Will this need to be changed for mingw?
|
380
|
+
if test "x$GCC" = "xyes"; then
|
381
|
+
AC_DEFINE(FFI_EXEC_STATIC_TRAMP, 1,
|
382
|
+
[Define this if you want statically defined trampolines])
|
383
|
+
fi
|
384
|
+
;;
|
385
|
+
*arm*-*-linux-* | aarch64*-*-linux-* | i*86-*-linux-* | x86_64-*-linux-* | loongarch*-*-linux-*)
|
386
|
+
AC_DEFINE(FFI_EXEC_STATIC_TRAMP, 1,
|
387
|
+
[Define this if you want statically defined trampolines])
|
388
|
+
;;
|
389
|
+
esac
|
390
|
+
fi
|
391
|
+
|
366
392
|
AC_ARG_ENABLE(purify-safety,
|
367
393
|
[ --enable-purify-safety purify-safe mode],
|
368
394
|
if test "$enable_purify_safety" = "yes"; then
|
@@ -372,7 +398,7 @@ AC_ARG_ENABLE(purify-safety,
|
|
372
398
|
AC_ARG_ENABLE(multi-os-directory,
|
373
399
|
[ --disable-multi-os-directory
|
374
400
|
disable use of gcc --print-multi-os-directory to change the library installation directory])
|
375
|
-
|
401
|
+
|
376
402
|
# These variables are only ever used when we cross-build to X86_WIN32.
|
377
403
|
# And we only support this with GCC, so...
|
378
404
|
if test "x$GCC" = "xyes"; then
|
@@ -397,6 +423,16 @@ else
|
|
397
423
|
fi
|
398
424
|
AC_SUBST(toolexeclibdir)
|
399
425
|
|
426
|
+
# Conditionalize the makefile for this target machine.
|
427
|
+
tmake_file_=
|
428
|
+
for f in ${tmake_file}; do
|
429
|
+
if test -f ${srcdir}/src/$TARGETDIR/$f; then
|
430
|
+
tmake_file_="${tmake_file_} \$(srcdir)/src/$TARGETDIR/$f"
|
431
|
+
fi
|
432
|
+
done
|
433
|
+
tmake_file="${tmake_file_}"
|
434
|
+
AC_SUBST(tmake_file)
|
435
|
+
|
400
436
|
# Check linker support.
|
401
437
|
LIBFFI_ENABLE_SYMVERS
|
402
438
|
|
@@ -6,7 +6,7 @@
|
|
6
6
|
# THIS TABLE IS SORTED. KEEP IT THAT WAY.
|
7
7
|
# Most of the time we can define all the variables all at once...
|
8
8
|
case "${host}" in
|
9
|
-
aarch64*-*-cygwin* | aarch64*-*-mingw* | aarch64*-*-win* )
|
9
|
+
aarch64*-*-cygwin* | aarch64*-*-msys* | aarch64*-*-mingw* | aarch64*-*-win* )
|
10
10
|
TARGET=ARM_WIN64; TARGETDIR=aarch64
|
11
11
|
if test "${ax_cv_c_compiler_vendor}" = "microsoft"; then
|
12
12
|
MSVC=1
|
@@ -30,9 +30,11 @@ case "${host}" in
|
|
30
30
|
SOURCES="ffi.c arcompact.S"
|
31
31
|
;;
|
32
32
|
|
33
|
-
arm*-*-cygwin* | arm*-*-mingw* | arm*-*-win* )
|
33
|
+
arm*-*-cygwin* | arm*-*-msys* | arm*-*-mingw* | arm*-*-win* )
|
34
34
|
TARGET=ARM_WIN32; TARGETDIR=arm
|
35
|
-
|
35
|
+
if test "${ax_cv_c_compiler_vendor}" = "microsoft"; then
|
36
|
+
MSVC=1
|
37
|
+
fi
|
36
38
|
;;
|
37
39
|
|
38
40
|
arm*-*-*)
|
@@ -71,6 +73,7 @@ case "${host}" in
|
|
71
73
|
;;
|
72
74
|
hppa*64-*-hpux*)
|
73
75
|
TARGET=PA64_HPUX; TARGETDIR=pa
|
76
|
+
SOURCES="ffi64.c hpux64.S"
|
74
77
|
;;
|
75
78
|
hppa*-*-hpux*)
|
76
79
|
TARGET=PA_HPUX; TARGETDIR=pa
|
@@ -81,8 +84,8 @@ case "${host}" in
|
|
81
84
|
TARGET=X86_FREEBSD; TARGETDIR=x86
|
82
85
|
;;
|
83
86
|
|
84
|
-
i?86-*-cygwin* | i?86-*-mingw* | i?86-*-win* | i?86-*-os2* | i?86-*-interix* \
|
85
|
-
| x86_64-*-cygwin* | x86_64-*-mingw* | x86_64-*-win* )
|
87
|
+
i?86-*-cygwin* | i?86-*-msys* | i?86-*-mingw* | i?86-*-win* | i?86-*-os2* | i?86-*-interix* \
|
88
|
+
| x86_64-*-cygwin* | x86_64-*-msys* | x86_64-*-mingw* | x86_64-*-win* )
|
86
89
|
TARGETDIR=x86
|
87
90
|
if test $ac_cv_sizeof_size_t = 4; then
|
88
91
|
TARGET=X86_WIN32
|
@@ -138,6 +141,11 @@ case "${host}" in
|
|
138
141
|
SOURCES="ffi.c sysv.S"
|
139
142
|
;;
|
140
143
|
|
144
|
+
loongarch64-*-*)
|
145
|
+
TARGET=LOONGARCH64; TARGETDIR=loongarch64
|
146
|
+
SOURCES="ffi.c sysv.S"
|
147
|
+
;;
|
148
|
+
|
141
149
|
m32r*-*-*)
|
142
150
|
TARGET=M32R; TARGETDIR=m32r
|
143
151
|
SOURCES="ffi.c sysv.S"
|
@@ -197,7 +205,7 @@ case "${host}" in
|
|
197
205
|
powerpc-*-eabi*)
|
198
206
|
TARGET=POWERPC; TARGETDIR=powerpc
|
199
207
|
;;
|
200
|
-
powerpc-*-beos*)
|
208
|
+
powerpc-*-beos* | powerpc-*-haiku*)
|
201
209
|
TARGET=POWERPC; TARGETDIR=powerpc
|
202
210
|
;;
|
203
211
|
powerpc-*-darwin* | powerpc64-*-darwin*)
|
@@ -205,6 +213,8 @@ case "${host}" in
|
|
205
213
|
;;
|
206
214
|
powerpc-*-aix* | rs6000-*-aix*)
|
207
215
|
TARGET=POWERPC_AIX; TARGETDIR=powerpc
|
216
|
+
# Create AIX-style "FAT" libraries.
|
217
|
+
tmake_file="t-aix"
|
208
218
|
;;
|
209
219
|
powerpc-*-freebsd* | powerpc-*-openbsd* | powerpc-*-netbsd*)
|
210
220
|
TARGET=POWERPC_FREEBSD; TARGETDIR=powerpc
|
@@ -255,6 +265,11 @@ case "${host}" in
|
|
255
265
|
SOURCES="ffi.c elfbsd.S"
|
256
266
|
;;
|
257
267
|
|
268
|
+
wasm32-*-*)
|
269
|
+
TARGET=wasm32; TARGETDIR=wasm32
|
270
|
+
SOURCES="ffi.c"
|
271
|
+
;;
|
272
|
+
|
258
273
|
xtensa*-*)
|
259
274
|
TARGET=XTENSA; TARGETDIR=xtensa
|
260
275
|
SOURCES="ffi.c sysv.S"
|
@@ -264,7 +279,11 @@ esac
|
|
264
279
|
# ... but some of the cases above share configury.
|
265
280
|
case "${TARGET}" in
|
266
281
|
ARM_WIN32)
|
267
|
-
|
282
|
+
if test "$MSVC" = 1; then
|
283
|
+
SOURCES="ffi.c sysv_msvc_arm32.S"
|
284
|
+
else
|
285
|
+
SOURCES="ffi.c sysv.S"
|
286
|
+
fi
|
268
287
|
;;
|
269
288
|
ARM_WIN64)
|
270
289
|
if test "$MSVC" = 1; then
|
@@ -1,7 +1,7 @@
|
|
1
|
-
# Makefile.in generated by automake 1.16.
|
1
|
+
# Makefile.in generated by automake 1.16.5 from Makefile.am.
|
2
2
|
# @configure_input@
|
3
3
|
|
4
|
-
# Copyright (C) 1994-
|
4
|
+
# Copyright (C) 1994-2021 Free Software Foundation, Inc.
|
5
5
|
|
6
6
|
# This Makefile.in is free software; the Free Software Foundation
|
7
7
|
# gives unlimited permission to copy and/or distribute it,
|
@@ -91,7 +91,6 @@ target_triplet = @target@
|
|
91
91
|
subdir = doc
|
92
92
|
ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
|
93
93
|
am__aclocal_m4_deps = $(top_srcdir)/m4/asmcfi.m4 \
|
94
|
-
$(top_srcdir)/m4/ax_append_flag.m4 \
|
95
94
|
$(top_srcdir)/m4/ax_cc_maxopt.m4 \
|
96
95
|
$(top_srcdir)/m4/ax_cflags_warn_all.m4 \
|
97
96
|
$(top_srcdir)/m4/ax_check_compile_flag.m4 \
|
@@ -100,6 +99,7 @@ am__aclocal_m4_deps = $(top_srcdir)/m4/asmcfi.m4 \
|
|
100
99
|
$(top_srcdir)/m4/ax_enable_builddir.m4 \
|
101
100
|
$(top_srcdir)/m4/ax_gcc_archflag.m4 \
|
102
101
|
$(top_srcdir)/m4/ax_gcc_x86_cpuid.m4 \
|
102
|
+
$(top_srcdir)/m4/ax_prepend_flag.m4 \
|
103
103
|
$(top_srcdir)/m4/ax_require_defined.m4 \
|
104
104
|
$(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \
|
105
105
|
$(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \
|
@@ -204,7 +204,6 @@ am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)
|
|
204
204
|
am__DIST_COMMON = $(srcdir)/Makefile.in mdate-sh texinfo.tex
|
205
205
|
DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
|
206
206
|
ACLOCAL = @ACLOCAL@
|
207
|
-
ALLOCA = @ALLOCA@
|
208
207
|
AMTAR = @AMTAR@
|
209
208
|
AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
|
210
209
|
AM_LTLDFLAGS = @AM_LTLDFLAGS@
|
@@ -220,8 +219,9 @@ CCASDEPMODE = @CCASDEPMODE@
|
|
220
219
|
CCASFLAGS = @CCASFLAGS@
|
221
220
|
CCDEPMODE = @CCDEPMODE@
|
222
221
|
CFLAGS = @CFLAGS@
|
223
|
-
CPP = @CPP@
|
224
222
|
CPPFLAGS = @CPPFLAGS@
|
223
|
+
CSCOPE = @CSCOPE@
|
224
|
+
CTAGS = @CTAGS@
|
225
225
|
CXX = @CXX@
|
226
226
|
CXXCPP = @CXXCPP@
|
227
227
|
CXXDEPMODE = @CXXDEPMODE@
|
@@ -236,9 +236,11 @@ ECHO_C = @ECHO_C@
|
|
236
236
|
ECHO_N = @ECHO_N@
|
237
237
|
ECHO_T = @ECHO_T@
|
238
238
|
EGREP = @EGREP@
|
239
|
+
ETAGS = @ETAGS@
|
239
240
|
EXEEXT = @EXEEXT@
|
240
241
|
FFI_EXEC_TRAMPOLINE_TABLE = @FFI_EXEC_TRAMPOLINE_TABLE@
|
241
242
|
FGREP = @FGREP@
|
243
|
+
FILECMD = @FILECMD@
|
242
244
|
GREP = @GREP@
|
243
245
|
HAVE_LONG_DOUBLE = @HAVE_LONG_DOUBLE@
|
244
246
|
HAVE_LONG_DOUBLE_VARIANT = @HAVE_LONG_DOUBLE_VARIANT@
|
@@ -277,6 +279,7 @@ PACKAGE_VERSION = @PACKAGE_VERSION@
|
|
277
279
|
PATH_SEPARATOR = @PATH_SEPARATOR@
|
278
280
|
PRTDIAG = @PRTDIAG@
|
279
281
|
RANLIB = @RANLIB@
|
282
|
+
READELF = @READELF@
|
280
283
|
SECTION_LDFLAGS = @SECTION_LDFLAGS@
|
281
284
|
SED = @SED@
|
282
285
|
SET_MAKE = @SET_MAKE@
|
@@ -343,6 +346,7 @@ target_alias = @target_alias@
|
|
343
346
|
target_cpu = @target_cpu@
|
344
347
|
target_os = @target_os@
|
345
348
|
target_vendor = @target_vendor@
|
349
|
+
tmake_file = @tmake_file@
|
346
350
|
toolexecdir = @toolexecdir@
|
347
351
|
toolexeclibdir = @toolexeclibdir@
|
348
352
|
top_build_prefix = @top_build_prefix@
|
@@ -555,7 +559,6 @@ ctags CTAGS:
|
|
555
559
|
|
556
560
|
cscope cscopelist:
|
557
561
|
|
558
|
-
|
559
562
|
distdir: $(BUILT_SOURCES)
|
560
563
|
$(MAKE) $(AM_MAKEFLAGS) distdir-am
|
561
564
|
|
@@ -18,7 +18,7 @@
|
|
18
18
|
This manual is for libffi, a portable foreign function interface
|
19
19
|
library.
|
20
20
|
|
21
|
-
Copyright @copyright{} 2008--
|
21
|
+
Copyright @copyright{} 2008--2024 Anthony Green and Red Hat, Inc.
|
22
22
|
|
23
23
|
Permission is hereby granted, free of charge, to any person obtaining
|
24
24
|
a copy of this software and associated documentation files (the
|
@@ -65,6 +65,7 @@ SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
65
65
|
@menu
|
66
66
|
* Introduction:: What is libffi?
|
67
67
|
* Using libffi:: How to use libffi.
|
68
|
+
* Memory Usage:: Where memory for closures comes from.
|
68
69
|
* Missing Features:: Things libffi can't do.
|
69
70
|
* Index:: Index.
|
70
71
|
@end menu
|
@@ -90,10 +91,10 @@ sometimes called the @dfn{ABI} or @dfn{Application Binary Interface}.
|
|
90
91
|
Some programs may not know at the time of compilation what arguments
|
91
92
|
are to be passed to a function. For instance, an interpreter may be
|
92
93
|
told at run-time about the number and types of arguments used to call
|
93
|
-
a given function. @
|
94
|
+
a given function. @code{libffi} can be used in such programs to
|
94
95
|
provide a bridge from the interpreter program to compiled code.
|
95
96
|
|
96
|
-
The @
|
97
|
+
The @code{libffi} library provides a portable, high level programming
|
97
98
|
interface to various calling conventions. This allows a programmer to
|
98
99
|
call any function specified by a call interface description at run
|
99
100
|
time.
|
@@ -101,9 +102,9 @@ time.
|
|
101
102
|
@acronym{FFI} stands for Foreign Function Interface. A foreign
|
102
103
|
function interface is the popular name for the interface that allows
|
103
104
|
code written in one language to call code written in another language.
|
104
|
-
The @
|
105
|
+
The @code{libffi} library really only provides the lowest, machine
|
105
106
|
dependent layer of a fully featured foreign function interface. A
|
106
|
-
layer must exist above @
|
107
|
+
layer must exist above @code{libffi} that handles type conversions for
|
107
108
|
values passed between the two languages.
|
108
109
|
@cindex FFI
|
109
110
|
@cindex Foreign Function Interface
|
@@ -126,7 +127,7 @@ values passed between the two languages.
|
|
126
127
|
@node The Basics
|
127
128
|
@section The Basics
|
128
129
|
|
129
|
-
@
|
130
|
+
@code{libffi} assumes that you have a pointer to the function you wish
|
130
131
|
to call and that you know the number and types of arguments to pass
|
131
132
|
it, as well as the return type of the function.
|
132
133
|
|
@@ -176,6 +177,11 @@ variadic arguments. It must be greater than zero.
|
|
176
177
|
@var{ntotalargs} the total number of arguments, including variadic
|
177
178
|
and fixed arguments. @var{argtypes} must have this many elements.
|
178
179
|
|
180
|
+
@code{ffi_prep_cif_var} will return @code{FFI_BAD_ARGTYPE} if any of
|
181
|
+
the variable argument types are @code{ffi_type_float} (promote to
|
182
|
+
@code{ffi_type_double} first), or any integer type small than an int
|
183
|
+
(promote to an int-sized type first).
|
184
|
+
|
179
185
|
Note that, different cif's must be prepped for calls to the same
|
180
186
|
function when different numbers of arguments are passed.
|
181
187
|
|
@@ -207,22 +213,20 @@ to ensure this. If @var{cif} declares that the function returns
|
|
207
213
|
@code{void} (using @code{ffi_type_void}), then @var{rvalue} is
|
208
214
|
ignored.
|
209
215
|
|
210
|
-
In most situations, @
|
216
|
+
In most situations, @code{libffi} will handle promotion according to
|
211
217
|
the ABI. However, for historical reasons, there is a special case
|
212
218
|
with return values that must be handled by your code. In particular,
|
213
219
|
for integral (not @code{struct}) types that are narrower than the
|
214
220
|
system register size, the return value will be widened by
|
215
|
-
@
|
221
|
+
@code{libffi}. @code{libffi} provides a type, @code{ffi_arg}, that
|
216
222
|
can be used as the return type. For example, if the CIF was defined
|
217
|
-
with a return type of @code{char}, @
|
223
|
+
with a return type of @code{char}, @code{libffi} will try to store a
|
218
224
|
full @code{ffi_arg} into the return value.
|
219
225
|
|
220
226
|
@var{avalues} is a vector of @code{void *} pointers that point to the
|
221
227
|
memory locations holding the argument values for a call. If @var{cif}
|
222
228
|
declares that the function has no arguments (i.e., @var{nargs} was 0),
|
223
|
-
then @var{avalues} is ignored.
|
224
|
-
modified by the callee (for instance, structs passed by value); the
|
225
|
-
burden of copying pass-by-value arguments is placed on the caller.
|
229
|
+
then @var{avalues} is ignored.
|
226
230
|
|
227
231
|
Note that while the return value must be register-sized, arguments
|
228
232
|
should exactly match their declared type. For example, if an argument
|
@@ -249,26 +253,26 @@ int main()
|
|
249
253
|
void *values[1];
|
250
254
|
char *s;
|
251
255
|
ffi_arg rc;
|
252
|
-
|
253
|
-
/* Initialize the argument info vectors */
|
256
|
+
|
257
|
+
/* Initialize the argument info vectors */
|
254
258
|
args[0] = &ffi_type_pointer;
|
255
259
|
values[0] = &s;
|
256
|
-
|
260
|
+
|
257
261
|
/* Initialize the cif */
|
258
|
-
if (ffi_prep_cif(&cif, FFI_DEFAULT_ABI, 1,
|
262
|
+
if (ffi_prep_cif(&cif, FFI_DEFAULT_ABI, 1,
|
259
263
|
&ffi_type_sint, args) == FFI_OK)
|
260
264
|
@{
|
261
265
|
s = "Hello World!";
|
262
266
|
ffi_call(&cif, puts, &rc, values);
|
263
267
|
/* rc now holds the result of the call to puts */
|
264
|
-
|
265
|
-
/* values holds a pointer to the function's arg, so to
|
266
|
-
call puts() again all we need to do is change the
|
268
|
+
|
269
|
+
/* values holds a pointer to the function's arg, so to
|
270
|
+
call puts() again all we need to do is change the
|
267
271
|
value of s */
|
268
272
|
s = "This is cool!";
|
269
273
|
ffi_call(&cif, puts, &rc, values);
|
270
274
|
@}
|
271
|
-
|
275
|
+
|
272
276
|
return 0;
|
273
277
|
@}
|
274
278
|
@end example
|
@@ -406,8 +410,8 @@ when passing to @code{ffi_prep_cif}.
|
|
406
410
|
@node Structures
|
407
411
|
@subsection Structures
|
408
412
|
|
409
|
-
@
|
410
|
-
You must first describe the structure to @
|
413
|
+
@code{libffi} is perfectly happy passing structures back and forth.
|
414
|
+
You must first describe the structure to @code{libffi} by creating a
|
411
415
|
new @code{ffi_type} object for it.
|
412
416
|
|
413
417
|
@tindex ffi_type
|
@@ -427,7 +431,7 @@ For a structure, this should be set to @code{FFI_TYPE_STRUCT}.
|
|
427
431
|
This is a @samp{NULL}-terminated array of pointers to @code{ffi_type}
|
428
432
|
objects. There is one element per field of the struct.
|
429
433
|
|
430
|
-
Note that @
|
434
|
+
Note that @code{libffi} has no special support for bit-fields. You
|
431
435
|
must manage these manually.
|
432
436
|
@end table
|
433
437
|
@end deftp
|
@@ -504,7 +508,7 @@ valid here.
|
|
504
508
|
|
505
509
|
@subsubsection Arrays
|
506
510
|
|
507
|
-
@
|
511
|
+
@code{libffi} does not have direct support for arrays or unions.
|
508
512
|
However, they can be emulated using structures.
|
509
513
|
|
510
514
|
To emulate an array, simply create an @code{ffi_type} using
|
@@ -531,7 +535,7 @@ structure types created like this should only be used to refer to
|
|
531
535
|
members of real @code{FFI_TYPE_STRUCT} objects.
|
532
536
|
|
533
537
|
However, a phony array type like this will not cause any errors from
|
534
|
-
@
|
538
|
+
@code{libffi} if you use it as an argument or return type. This may
|
535
539
|
be confusing.
|
536
540
|
|
537
541
|
@subsubsection Unions
|
@@ -624,7 +628,7 @@ Here is the corresponding code to describe this struct to
|
|
624
628
|
tm_type.size = tm_type.alignment = 0;
|
625
629
|
tm_type.type = FFI_TYPE_STRUCT;
|
626
630
|
tm_type.elements = &tm_type_elements;
|
627
|
-
|
631
|
+
|
628
632
|
for (i = 0; i < 9; i++)
|
629
633
|
tm_type_elements[i] = &ffi_type_sint;
|
630
634
|
|
@@ -640,7 +644,7 @@ Here is the corresponding code to describe this struct to
|
|
640
644
|
@node Complex
|
641
645
|
@subsection Complex Types
|
642
646
|
|
643
|
-
@
|
647
|
+
@code{libffi} supports the complex types defined by the C99
|
644
648
|
standard (@code{_Complex float}, @code{_Complex double} and
|
645
649
|
@code{_Complex long double} with the built-in type descriptors
|
646
650
|
@code{ffi_type_complex_float}, @code{ffi_type_complex_double} and
|
@@ -648,7 +652,7 @@ standard (@code{_Complex float}, @code{_Complex double} and
|
|
648
652
|
|
649
653
|
Custom complex types like @code{_Complex int} can also be used.
|
650
654
|
An @code{ffi_type} object has to be defined to describe the
|
651
|
-
complex type to @
|
655
|
+
complex type to @code{libffi}.
|
652
656
|
|
653
657
|
@tindex ffi_type
|
654
658
|
@deftp {Data type} ffi_type
|
@@ -815,7 +819,6 @@ Free memory allocated using @code{ffi_closure_alloc}. The argument is
|
|
815
819
|
the writable address that was returned.
|
816
820
|
@end defun
|
817
821
|
|
818
|
-
|
819
822
|
Once you have allocated the memory for a closure, you must construct a
|
820
823
|
@code{ffi_cif} describing the function call. Finally you can prepare
|
821
824
|
the closure function:
|
@@ -887,7 +890,7 @@ writable and executable addresses.
|
|
887
890
|
@node Closure Example
|
888
891
|
@section Closure Example
|
889
892
|
|
890
|
-
A trivial example that creates a new @code{puts} by binding
|
893
|
+
A trivial example that creates a new @code{puts} by binding
|
891
894
|
@code{fputs} with @code{stdout}.
|
892
895
|
|
893
896
|
@example
|
@@ -965,6 +968,55 @@ Currently the only affected platform is PowerPC and the only affected
|
|
965
968
|
type is @code{long double}.
|
966
969
|
@end itemize
|
967
970
|
|
971
|
+
@node Memory Usage
|
972
|
+
@chapter Memory Usage
|
973
|
+
|
974
|
+
Note that memory allocated by @code{ffi_closure_alloc} and freed by
|
975
|
+
@code{ffi_closure_free} does not come from the same general pool of
|
976
|
+
memory that @code{malloc} and @code{free} use. To accomodate security
|
977
|
+
settings, @code{libffi} may aquire memory, for example, by mapping
|
978
|
+
temporary files into multiple places in the address space (once to
|
979
|
+
write out the closure, a second to execute it). The search follows
|
980
|
+
this list, using the first that works:
|
981
|
+
|
982
|
+
@itemize @bullet
|
983
|
+
|
984
|
+
@item
|
985
|
+
A anonymous mapping (i.e. not file-backed)
|
986
|
+
|
987
|
+
@item
|
988
|
+
@code{memfd_create()}, if the kernel supports it.
|
989
|
+
|
990
|
+
@item
|
991
|
+
A file created in the directory referenced by the environment variable
|
992
|
+
@code{LIBFFI_TMPDIR}.
|
993
|
+
|
994
|
+
@item
|
995
|
+
Likewise for the environment variable @code{TMPDIR}.
|
996
|
+
|
997
|
+
@item
|
998
|
+
A file created in @code{/tmp}.
|
999
|
+
|
1000
|
+
@item
|
1001
|
+
A file created in @code{/var/tmp}.
|
1002
|
+
|
1003
|
+
@item
|
1004
|
+
A file created in @code{/dev/shm}.
|
1005
|
+
|
1006
|
+
@item
|
1007
|
+
A file created in the user's home directory (@code{$HOME}).
|
1008
|
+
|
1009
|
+
@item
|
1010
|
+
A file created in any directory listed in @code{/etc/mtab}.
|
1011
|
+
|
1012
|
+
@item
|
1013
|
+
A file created in any directory listed in @code{/proc/mounts}.
|
1014
|
+
|
1015
|
+
@end itemize
|
1016
|
+
|
1017
|
+
If security settings prohibit using any of these for closures,
|
1018
|
+
@code{ffi_closure_alloc} will fail.
|
1019
|
+
|
968
1020
|
@node Missing Features
|
969
1021
|
@chapter Missing Features
|
970
1022
|
|
@@ -986,9 +1038,6 @@ The ``raw'' API is undocumented.
|
|
986
1038
|
The Go API is undocumented.
|
987
1039
|
@end itemize
|
988
1040
|
|
989
|
-
Note that variadic support is very new and tested on a relatively
|
990
|
-
small number of platforms.
|
991
|
-
|
992
1041
|
@node Index
|
993
1042
|
@unnumbered Index
|
994
1043
|
|
@@ -1,4 +1,4 @@
|
|
1
|
-
@set UPDATED
|
2
|
-
@set UPDATED-MONTH
|
3
|
-
@set EDITION 3.
|
4
|
-
@set VERSION 3.
|
1
|
+
@set UPDATED 15 February 2024
|
2
|
+
@set UPDATED-MONTH February 2024
|
3
|
+
@set EDITION 3.4.6
|
4
|
+
@set VERSION 3.4.6
|