ffi 1.9.24 → 1.16.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- checksums.yaml.gz.sig +0 -0
- data/CHANGELOG.md +348 -0
- data/Gemfile +4 -5
- data/README.md +44 -17
- data/Rakefile +74 -148
- data/ext/ffi_c/AbstractMemory.c +89 -70
- data/ext/ffi_c/AbstractMemory.h +3 -2
- data/ext/ffi_c/ArrayType.c +49 -13
- data/ext/ffi_c/ArrayType.h +1 -0
- data/ext/ffi_c/Buffer.c +90 -38
- data/ext/ffi_c/Call.c +55 -56
- data/ext/ffi_c/Call.h +12 -6
- data/ext/ffi_c/ClosurePool.c +333 -0
- data/ext/ffi_c/{Closure.h → ClosurePool.h} +25 -13
- data/ext/ffi_c/DynamicLibrary.c +91 -33
- data/ext/ffi_c/Function.c +306 -235
- data/ext/ffi_c/Function.h +3 -5
- data/ext/ffi_c/FunctionInfo.c +87 -32
- data/ext/ffi_c/LastError.c +74 -15
- data/ext/ffi_c/LongDouble.c +12 -10
- data/ext/ffi_c/LongDouble.h +0 -4
- data/ext/ffi_c/MappedType.c +66 -23
- data/ext/ffi_c/MappedType.h +0 -2
- data/ext/ffi_c/MemoryPointer.c +37 -15
- data/ext/ffi_c/MemoryPointer.h +0 -4
- data/ext/ffi_c/MethodHandle.c +265 -38
- data/ext/ffi_c/MethodHandle.h +3 -2
- data/ext/ffi_c/Platform.c +5 -56
- data/ext/ffi_c/Pointer.c +93 -55
- data/ext/ffi_c/Pointer.h +1 -4
- data/ext/ffi_c/Struct.c +202 -134
- data/ext/ffi_c/Struct.h +18 -9
- data/ext/ffi_c/StructByValue.c +50 -23
- data/ext/ffi_c/StructLayout.c +135 -64
- data/ext/ffi_c/Thread.c +4 -228
- data/ext/ffi_c/Thread.h +1 -20
- data/ext/ffi_c/Type.c +105 -55
- data/ext/ffi_c/Type.h +3 -2
- data/ext/ffi_c/Types.c +8 -9
- data/ext/ffi_c/Types.h +3 -4
- data/ext/ffi_c/Variadic.c +88 -47
- data/ext/ffi_c/compat.h +26 -22
- data/ext/ffi_c/extconf.rb +75 -32
- data/ext/ffi_c/ffi.c +9 -10
- 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 +53 -19
- data/ext/ffi_c/libffi/.ci/bfin-sim.exp +58 -0
- data/ext/ffi_c/libffi/.ci/build-cross-in-container.sh +18 -0
- data/ext/ffi_c/libffi/.ci/build-in-container.sh +10 -0
- data/ext/ffi_c/libffi/.ci/build.sh +124 -0
- data/ext/ffi_c/libffi/.ci/install.sh +78 -0
- data/ext/ffi_c/libffi/.ci/m32r-sim.exp +58 -0
- data/ext/ffi_c/libffi/{.travis → .ci}/moxie-sim.exp +1 -1
- data/ext/ffi_c/libffi/.ci/msvs-detect +1103 -0
- data/ext/ffi_c/libffi/.ci/or1k-sim.exp +58 -0
- data/ext/ffi_c/libffi/.ci/powerpc-eabisim.exp +58 -0
- data/ext/ffi_c/libffi/.ci/site.exp +29 -0
- data/ext/ffi_c/libffi/.ci/wine-sim.exp +55 -0
- data/ext/ffi_c/libffi/.circleci/config.yml +156 -0
- data/ext/ffi_c/libffi/.gitattributes +4 -0
- data/ext/ffi_c/libffi/.github/workflows/build.yml +460 -0
- data/ext/ffi_c/libffi/.github/workflows/emscripten.yml +171 -0
- data/ext/ffi_c/libffi/.gitignore +10 -2
- data/ext/ffi_c/libffi/{ChangeLog.libffi-3.1 → ChangeLog.old} +1407 -0
- data/ext/ffi_c/libffi/LICENSE +1 -1
- data/ext/ffi_c/libffi/LICENSE-BUILDTOOLS +5 -4
- data/ext/ffi_c/libffi/Makefile.am +64 -73
- data/ext/ffi_c/libffi/Makefile.in +553 -235
- data/ext/ffi_c/libffi/README.md +165 -100
- data/ext/ffi_c/libffi/acinclude.m4 +10 -112
- data/ext/ffi_c/libffi/compile +348 -0
- data/ext/ffi_c/libffi/config.guess +950 -662
- data/ext/ffi_c/libffi/config.sub +1362 -1306
- data/ext/ffi_c/libffi/configure +4909 -4096
- data/ext/ffi_c/libffi/configure.ac +93 -32
- data/ext/ffi_c/libffi/configure.host +76 -28
- data/ext/ffi_c/libffi/doc/Makefile.in +15 -8
- data/ext/ffi_c/libffi/doc/libffi.texi +107 -46
- data/ext/ffi_c/libffi/doc/version.texi +4 -4
- data/ext/ffi_c/libffi/fficonfig.h.in +22 -44
- data/ext/ffi_c/libffi/generate-darwin-source-and-headers.py +165 -56
- data/ext/ffi_c/libffi/include/Makefile.am +1 -1
- data/ext/ffi_c/libffi/include/Makefile.in +17 -12
- data/ext/ffi_c/libffi/include/ffi.h.in +64 -48
- data/ext/ffi_c/libffi/include/ffi_cfi.h +21 -0
- data/ext/ffi_c/libffi/include/ffi_common.h +34 -1
- data/ext/ffi_c/libffi/include/tramp.h +45 -0
- data/ext/ffi_c/libffi/install-sh +107 -74
- data/ext/ffi_c/libffi/libffi.map.in +8 -12
- data/ext/ffi_c/libffi/libffi.xcodeproj/project.pbxproj +2 -48
- data/ext/ffi_c/libffi/libtool-version +2 -2
- data/ext/ffi_c/libffi/ltmain.sh +576 -284
- data/ext/ffi_c/libffi/m4/asmcfi.m4 +1 -1
- data/ext/ffi_c/libffi/m4/ax_append_flag.m4 +5 -26
- 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_check_compile_flag.m4 +5 -26
- data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +76 -44
- data/ext/ffi_c/libffi/m4/ax_configure_args.m4 +5 -26
- data/ext/ffi_c/libffi/m4/ax_gcc_archflag.m4 +7 -3
- data/ext/ffi_c/libffi/m4/ax_prepend_flag.m4 +51 -0
- data/ext/ffi_c/libffi/make_sunver.pl +333 -0
- data/ext/ffi_c/libffi/man/Makefile.in +15 -8
- data/ext/ffi_c/libffi/missing +8 -8
- data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.sln +33 -0
- data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.vcxproj +130 -0
- data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.vcxproj.filters +57 -0
- data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.vcxproj.user +4 -0
- data/ext/ffi_c/libffi/msvc_build/aarch64/aarch64_include/ffi.h +511 -0
- data/ext/ffi_c/libffi/msvc_build/aarch64/aarch64_include/fficonfig.h +219 -0
- data/ext/ffi_c/libffi/msvcc.sh +39 -14
- data/ext/ffi_c/libffi/src/aarch64/ffi.c +286 -98
- data/ext/ffi_c/libffi/src/aarch64/ffitarget.h +19 -3
- data/ext/ffi_c/libffi/src/aarch64/internal.h +33 -0
- data/ext/ffi_c/libffi/src/aarch64/sysv.S +142 -37
- data/ext/ffi_c/libffi/src/aarch64/win64_armasm.S +506 -0
- 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 +112 -10
- data/ext/ffi_c/libffi/src/arm/ffitarget.h +8 -1
- data/ext/ffi_c/libffi/src/arm/internal.h +10 -0
- data/ext/ffi_c/libffi/src/arm/sysv.S +117 -44
- data/ext/ffi_c/libffi/src/arm/sysv_msvc_arm32.S +311 -0
- data/ext/ffi_c/libffi/src/closures.c +189 -48
- data/ext/ffi_c/libffi/src/csky/ffi.c +395 -0
- data/ext/ffi_c/libffi/src/csky/ffitarget.h +63 -0
- data/ext/ffi_c/libffi/src/csky/sysv.S +371 -0
- data/ext/ffi_c/libffi/src/dlmalloc.c +6 -1
- data/ext/ffi_c/libffi/src/frv/ffi.c +1 -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/kvx/asm.h +5 -0
- data/ext/ffi_c/libffi/src/kvx/ffi.c +273 -0
- data/ext/ffi_c/libffi/src/kvx/ffitarget.h +75 -0
- data/ext/ffi_c/libffi/src/kvx/sysv.S +127 -0
- data/ext/ffi_c/libffi/src/loongarch64/ffi.c +621 -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/metag/ffi.c +1 -1
- data/ext/ffi_c/libffi/src/mips/ffi.c +245 -66
- data/ext/ffi_c/libffi/src/mips/ffitarget.h +8 -1
- data/ext/ffi_c/libffi/src/mips/n32.S +137 -28
- data/ext/ffi_c/libffi/src/mips/o32.S +63 -4
- data/ext/ffi_c/libffi/src/moxie/ffi.c +48 -23
- data/ext/ffi_c/libffi/src/or1k/ffi.c +25 -12
- data/ext/ffi_c/libffi/src/pa/ffi.c +62 -108
- data/ext/ffi_c/libffi/src/pa/ffi64.c +614 -0
- data/ext/ffi_c/libffi/src/pa/ffitarget.h +20 -11
- data/ext/ffi_c/libffi/src/pa/hpux32.S +87 -38
- data/ext/ffi_c/libffi/src/pa/hpux64.S +681 -0
- data/ext/ffi_c/libffi/src/pa/linux.S +109 -39
- data/ext/ffi_c/libffi/src/powerpc/ffi.c +6 -4
- data/ext/ffi_c/libffi/src/powerpc/ffi_darwin.c +13 -1
- data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +211 -32
- data/ext/ffi_c/libffi/src/powerpc/ffi_powerpc.h +18 -7
- data/ext/ffi_c/libffi/src/powerpc/ffitarget.h +10 -4
- data/ext/ffi_c/libffi/src/powerpc/linux64.S +93 -28
- data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +83 -5
- data/ext/ffi_c/libffi/src/powerpc/sysv.S +5 -7
- data/ext/ffi_c/libffi/src/powerpc/t-aix +5 -0
- data/ext/ffi_c/libffi/src/prep_cif.c +26 -4
- data/ext/ffi_c/libffi/src/riscv/ffi.c +79 -10
- data/ext/ffi_c/libffi/src/riscv/ffitarget.h +1 -0
- data/ext/ffi_c/libffi/src/riscv/sysv.S +86 -7
- data/ext/ffi_c/libffi/src/sparc/ffi64.c +16 -0
- data/ext/ffi_c/libffi/src/tramp.c +716 -0
- data/ext/ffi_c/libffi/src/wasm32/ffi.c +934 -0
- data/ext/ffi_c/libffi/src/wasm32/ffitarget.h +62 -0
- data/ext/ffi_c/libffi/src/x86/ffi.c +128 -49
- data/ext/ffi_c/libffi/src/x86/ffi64.c +89 -23
- data/ext/ffi_c/libffi/src/x86/ffitarget.h +21 -4
- data/ext/ffi_c/libffi/src/x86/ffiw64.c +63 -10
- 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 +274 -45
- data/ext/ffi_c/libffi/src/x86/sysv_intel.S +998 -0
- data/ext/ffi_c/libffi/src/x86/unix64.S +190 -4
- data/ext/ffi_c/libffi/src/x86/win64.S +32 -10
- data/ext/ffi_c/libffi/src/x86/win64_intel.S +3 -2
- 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 +127 -109
- data/ext/ffi_c/libffi/testsuite/Makefile.in +144 -88
- 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 +80 -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 +71 -25
- data/ext/ffi_c/libffi/testsuite/lib/target-libpath.exp +2 -2
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/bhaible.exp +7 -2
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-call.c +5 -4
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-callback.c +2 -2
- 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/call.exp +12 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/ffitest.h +28 -3
- data/ext/ffi_c/libffi/testsuite/libffi.call/float2.c +9 -8
- 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.exp +67 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn0.c +3 -2
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn1.c +2 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn2.c +2 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn3.c +21 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn4.c +2 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn5.c +2 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn6.c +2 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_loc_fn0.c +7 -6
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_simple.c +6 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_12byte.c +18 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_16byte.c +22 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_18byte.c +24 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_19byte.c +29 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_1_1byte.c +4 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte.c +19 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte1.c +21 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_24byte.c +35 -3
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_2byte.c +13 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3_1byte.c +19 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte1.c +13 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte2.c +13 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3float.c +18 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4_1byte.c +22 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4byte.c +13 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5_1_byte.c +29 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5byte.c +19 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_64byte.c +24 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6_1_byte.c +28 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6byte.c +24 -2
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7_1_byte.c +39 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7byte.c +25 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_8byte.c +14 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte1.c +14 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte2.c +14 -2
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_double.c +19 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_float.c +19 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble.c +20 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split.c +40 -25
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split2.c +40 -3
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_pointer.c +19 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint16.c +18 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint32.c +18 -3
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint64.c +18 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint16.c +18 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint32.c +19 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint64.c +19 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_dbls_struct.c +3 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double_va.c +9 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_float.c +4 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble.c +11 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble_va.c +22 -3
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_schar.c +5 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshort.c +6 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshortchar.c +9 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_uchar.c +9 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushort.c +6 -2
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushortchar.c +9 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer.c +5 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer_stack.c +10 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_schar.c +3 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sint.c +2 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sshort.c +3 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_struct_va1.c +11 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uchar.c +3 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uint.c +4 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uint_va.c +4 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ulong_va.c +4 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ulonglong.c +2 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ushort.c +3 -0
- data/ext/ffi_c/libffi/testsuite/libffi.closures/ffitest.h +1 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/huge_struct.c +24 -22
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct.c +32 -9
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct1.c +1 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct10.c +12 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → 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.call → libffi.closures}/nested_struct2.c +10 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct3.c +10 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct4.c +9 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct5.c +9 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct6.c +11 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct7.c +9 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct8.c +11 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → 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.call → libffi.closures}/stret_medium.c +1 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium2.c +1 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/testclosure.c +6 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/unwindtest.cc +2 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/unwindtest_ffi_call.cc +1 -0
- data/ext/ffi_c/libffi.bsd.mk +2 -2
- data/ext/ffi_c/libffi.darwin.mk +1 -1
- data/ext/ffi_c/libffi.gnu.mk +2 -2
- data/ext/ffi_c/rbffi.h +1 -3
- data/ffi.gemspec +15 -9
- data/lib/ffi/abstract_memory.rb +44 -0
- data/lib/ffi/autopointer.rb +8 -23
- data/lib/ffi/compat.rb +43 -0
- data/lib/ffi/data_converter.rb +67 -0
- data/lib/ffi/dynamic_library.rb +89 -0
- data/lib/ffi/enum.rb +18 -11
- data/lib/ffi/ffi.rb +6 -0
- data/lib/ffi/function.rb +71 -0
- data/lib/ffi/io.rb +3 -3
- data/lib/ffi/library.rb +65 -77
- data/lib/ffi/library_path.rb +109 -0
- data/lib/ffi/managedstruct.rb +3 -3
- data/lib/ffi/platform/aarch64-darwin/types.conf +130 -0
- data/lib/ffi/platform/aarch64-freebsd/types.conf +128 -0
- data/lib/ffi/platform/aarch64-freebsd12/types.conf +181 -0
- data/lib/ffi/platform/aarch64-linux/types.conf +81 -81
- data/lib/ffi/platform/aarch64-openbsd/types.conf +134 -0
- data/lib/ffi/platform/aarch64-windows/types.conf +52 -0
- data/lib/ffi/platform/arm-freebsd/types.conf +152 -0
- data/lib/ffi/platform/arm-freebsd12/types.conf +152 -0
- data/lib/ffi/platform/arm-linux/types.conf +110 -82
- 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/i386-cygwin/types.conf +1 -1
- data/lib/ffi/platform/i386-darwin/types.conf +63 -63
- data/lib/ffi/platform/i386-freebsd/types.conf +89 -89
- data/lib/ffi/platform/i386-freebsd12/types.conf +152 -0
- data/lib/ffi/platform/i386-gnu/types.conf +84 -84
- data/lib/ffi/platform/i386-linux/types.conf +77 -77
- data/lib/ffi/platform/i386-netbsd/types.conf +87 -87
- data/lib/ffi/platform/i386-openbsd/types.conf +89 -89
- data/lib/ffi/platform/i386-solaris/types.conf +96 -96
- data/lib/ffi/platform/i386-windows/types.conf +43 -96
- data/lib/ffi/platform/ia64-linux/types.conf +79 -79
- data/lib/ffi/platform/loongarch64-linux/types.conf +141 -0
- data/lib/ffi/platform/mips-linux/types.conf +79 -79
- data/lib/ffi/platform/mips64-linux/types.conf +81 -81
- data/lib/ffi/platform/mips64el-linux/types.conf +81 -81
- data/lib/ffi/platform/mipsel-linux/types.conf +79 -79
- data/lib/ffi/platform/mipsisa32r6-linux/types.conf +79 -79
- data/lib/ffi/platform/mipsisa32r6el-linux/types.conf +79 -79
- data/lib/ffi/platform/mipsisa64r6-linux/types.conf +81 -81
- data/lib/ffi/platform/mipsisa64r6el-linux/types.conf +81 -81
- data/lib/ffi/platform/powerpc-aix/types.conf +155 -155
- data/lib/ffi/platform/powerpc-darwin/types.conf +63 -63
- data/lib/ffi/platform/powerpc-linux/types.conf +108 -78
- data/lib/ffi/platform/powerpc-openbsd/types.conf +156 -0
- data/lib/ffi/platform/powerpc64-linux/types.conf +81 -81
- data/lib/ffi/platform/powerpc64le-linux/types.conf +100 -0
- data/lib/ffi/platform/riscv64-linux/types.conf +104 -0
- data/lib/ffi/platform/s390-linux/types.conf +79 -79
- data/lib/ffi/platform/s390x-linux/types.conf +79 -79
- data/lib/ffi/platform/sparc-linux/types.conf +79 -79
- data/lib/ffi/platform/sparc-solaris/types.conf +103 -103
- data/lib/ffi/platform/sparcv9-openbsd/types.conf +156 -0
- data/lib/ffi/platform/sparcv9-solaris/types.conf +103 -103
- data/lib/ffi/platform/sw_64-linux/types.conf +141 -0
- data/lib/ffi/platform/x86_64-cygwin/types.conf +1 -1
- data/lib/ffi/platform/x86_64-darwin/types.conf +88 -84
- data/lib/ffi/platform/x86_64-dragonflybsd/types.conf +130 -0
- data/lib/ffi/platform/x86_64-freebsd/types.conf +90 -90
- data/lib/ffi/platform/x86_64-freebsd12/types.conf +158 -0
- data/lib/ffi/platform/x86_64-haiku/types.conf +117 -0
- data/lib/ffi/platform/x86_64-linux/types.conf +107 -77
- data/lib/ffi/platform/x86_64-msys/types.conf +119 -0
- data/lib/ffi/platform/x86_64-netbsd/types.conf +89 -89
- data/lib/ffi/platform/x86_64-openbsd/types.conf +86 -86
- data/lib/ffi/platform/x86_64-solaris/types.conf +96 -96
- data/lib/ffi/platform/x86_64-windows/types.conf +42 -110
- data/lib/ffi/platform.rb +43 -20
- data/lib/ffi/pointer.rb +26 -20
- data/lib/ffi/struct.rb +14 -68
- data/lib/ffi/struct_by_reference.rb +72 -0
- data/lib/ffi/struct_layout.rb +96 -0
- data/lib/ffi/struct_layout_builder.rb +1 -1
- data/lib/ffi/tools/const_generator.rb +11 -8
- data/lib/ffi/tools/generator.rb +47 -2
- data/lib/ffi/tools/generator_task.rb +13 -17
- data/lib/ffi/tools/struct_generator.rb +6 -5
- data/lib/ffi/tools/types_generator.rb +7 -4
- data/lib/ffi/types.rb +33 -7
- data/lib/ffi/variadic.rb +20 -18
- data/lib/ffi/version.rb +1 -1
- data/lib/ffi.rb +10 -3
- data/rakelib/ffi_gem_helper.rb +65 -0
- data/samples/getlogin.rb +1 -1
- data/samples/getpid.rb +1 -1
- data/samples/gettimeofday.rb +8 -8
- data/samples/hello.rb +2 -1
- data/samples/hello_ractor.rb +11 -0
- data/samples/inotify.rb +1 -1
- data/samples/pty.rb +1 -2
- data/samples/qsort.rb +0 -1
- data/samples/qsort_ractor.rb +28 -0
- data.tar.gz.sig +0 -0
- metadata +252 -153
- metadata.gz.sig +0 -0
- data/.gitignore +0 -22
- data/.gitmodules +0 -3
- data/.travis.yml +0 -52
- data/.yardopts +0 -5
- data/appveyor.yml +0 -22
- data/ext/ffi_c/Closure.c +0 -54
- data/ext/ffi_c/DataConverter.c +0 -91
- data/ext/ffi_c/StructByReference.c +0 -190
- data/ext/ffi_c/StructByReference.h +0 -50
- data/ext/ffi_c/libffi/.travis/build.sh +0 -34
- data/ext/ffi_c/libffi/.travis/install.sh +0 -22
- data/ext/ffi_c/libffi/.travis/site.exp +0 -18
- data/ext/ffi_c/libffi/.travis.yml +0 -34
- data/ext/ffi_c/libffi/ChangeLog.libffi +0 -584
- data/ext/ffi_c/libffi/ChangeLog.libgcj +0 -40
- data/ext/ffi_c/libffi/ChangeLog.v1 +0 -764
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uchar_va.c +0 -44
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ushort_va.c +0 -44
- data/ext/ffi_c/win32/stdbool.h +0 -8
- data/ext/ffi_c/win32/stdint.h +0 -201
- data/samples/sample_helper.rb +0 -6
- data/ext/ffi_c/libffi/{.travis → .ci}/ar-lib +0 -0
- data/ext/ffi_c/libffi/{.travis → .ci}/compile +0 -0
- data/ext/ffi_c/libffi/testsuite/libffi.call/{pyobjc-tc.c → pyobjc_tc.c} +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_many_mixed_args.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_many_mixed_float_double.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/err_bad_abi.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/problem1.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large2.c +0 -0
- data/lib/ffi/platform/{sparc64-linux → sparcv9-linux}/types.conf +79 -79
data/ext/ffi_c/Types.h
CHANGED
@@ -51,20 +51,19 @@ typedef enum {
|
|
51
51
|
NATIVE_FLOAT64,
|
52
52
|
NATIVE_LONGDOUBLE,
|
53
53
|
NATIVE_POINTER,
|
54
|
-
NATIVE_CALLBACK,
|
55
54
|
NATIVE_FUNCTION,
|
56
55
|
NATIVE_BUFFER_IN,
|
57
56
|
NATIVE_BUFFER_OUT,
|
58
57
|
NATIVE_BUFFER_INOUT,
|
59
58
|
NATIVE_CHAR_ARRAY,
|
60
59
|
NATIVE_BOOL,
|
61
|
-
|
60
|
+
|
62
61
|
/** An immutable string. Nul terminated, but only copies in to the native function */
|
63
62
|
NATIVE_STRING,
|
64
|
-
|
63
|
+
|
65
64
|
/** The function takes a variable number of arguments */
|
66
65
|
NATIVE_VARARGS,
|
67
|
-
|
66
|
+
|
68
67
|
/** Struct-by-value param or result */
|
69
68
|
NATIVE_STRUCT,
|
70
69
|
|
data/ext/ffi_c/Variadic.c
CHANGED
@@ -33,14 +33,12 @@
|
|
33
33
|
#include <sys/types.h>
|
34
34
|
|
35
35
|
#include <stdio.h>
|
36
|
-
#
|
37
|
-
#
|
38
|
-
# include <stdbool.h>
|
39
|
-
#else
|
40
|
-
# include "win32/stdbool.h"
|
41
|
-
# include "win32/stdint.h"
|
42
|
-
#endif
|
36
|
+
#include <stdint.h>
|
37
|
+
#include <stdbool.h>
|
43
38
|
#include <ruby.h>
|
39
|
+
#if HAVE_RB_EXT_RACTOR_SAFE
|
40
|
+
#include <ruby/ractor.h>
|
41
|
+
#endif
|
44
42
|
|
45
43
|
#include <ffi.h>
|
46
44
|
#include "rbffi.h"
|
@@ -67,35 +65,65 @@ typedef struct VariadicInvoker_ {
|
|
67
65
|
bool blocking;
|
68
66
|
} VariadicInvoker;
|
69
67
|
|
70
|
-
|
71
68
|
static VALUE variadic_allocate(VALUE klass);
|
72
69
|
static VALUE variadic_initialize(VALUE self, VALUE rbFunction, VALUE rbParameterTypes,
|
73
70
|
VALUE rbReturnType, VALUE options);
|
74
|
-
static void variadic_mark(
|
71
|
+
static void variadic_mark(void *);
|
72
|
+
static void variadic_compact(void *);
|
73
|
+
static size_t variadic_memsize(const void *);
|
75
74
|
|
76
75
|
static VALUE classVariadicInvoker = Qnil;
|
77
76
|
|
77
|
+
static const rb_data_type_t variadic_data_type = {
|
78
|
+
.wrap_struct_name = "FFI::VariadicInvoker",
|
79
|
+
.function = {
|
80
|
+
.dmark = variadic_mark,
|
81
|
+
.dfree = RUBY_TYPED_DEFAULT_FREE,
|
82
|
+
.dsize = variadic_memsize,
|
83
|
+
ffi_compact_callback( variadic_compact )
|
84
|
+
},
|
85
|
+
// IMPORTANT: WB_PROTECTED objects must only use the RB_OBJ_WRITE()
|
86
|
+
// macro to update VALUE references, as to trigger write barriers.
|
87
|
+
.flags = RUBY_TYPED_FREE_IMMEDIATELY | RUBY_TYPED_WB_PROTECTED | FFI_RUBY_TYPED_FROZEN_SHAREABLE
|
88
|
+
};
|
89
|
+
|
78
90
|
|
79
91
|
static VALUE
|
80
92
|
variadic_allocate(VALUE klass)
|
81
93
|
{
|
82
94
|
VariadicInvoker *invoker;
|
83
|
-
VALUE obj =
|
95
|
+
VALUE obj = TypedData_Make_Struct(klass, VariadicInvoker, &variadic_data_type, invoker);
|
84
96
|
|
85
|
-
invoker->rbAddress
|
86
|
-
invoker->rbEnums
|
87
|
-
invoker->rbReturnType
|
97
|
+
RB_OBJ_WRITE(obj, &invoker->rbAddress, Qnil);
|
98
|
+
RB_OBJ_WRITE(obj, &invoker->rbEnums, Qnil);
|
99
|
+
RB_OBJ_WRITE(obj, &invoker->rbReturnType, Qnil);
|
88
100
|
invoker->blocking = false;
|
89
101
|
|
90
102
|
return obj;
|
91
103
|
}
|
92
104
|
|
93
105
|
static void
|
94
|
-
variadic_mark(
|
106
|
+
variadic_mark(void *data)
|
107
|
+
{
|
108
|
+
VariadicInvoker *invoker = (VariadicInvoker *)data;
|
109
|
+
rb_gc_mark_movable(invoker->rbEnums);
|
110
|
+
rb_gc_mark_movable(invoker->rbAddress);
|
111
|
+
rb_gc_mark_movable(invoker->rbReturnType);
|
112
|
+
}
|
113
|
+
|
114
|
+
static void
|
115
|
+
variadic_compact(void *data)
|
116
|
+
{
|
117
|
+
VariadicInvoker *invoker = (VariadicInvoker *)data;
|
118
|
+
ffi_gc_location(invoker->rbEnums);
|
119
|
+
ffi_gc_location(invoker->rbAddress);
|
120
|
+
ffi_gc_location(invoker->rbReturnType);
|
121
|
+
}
|
122
|
+
|
123
|
+
static size_t
|
124
|
+
variadic_memsize(const void *data)
|
95
125
|
{
|
96
|
-
|
97
|
-
rb_gc_mark(invoker->rbAddress);
|
98
|
-
rb_gc_mark(invoker->rbReturnType);
|
126
|
+
return sizeof(VariadicInvoker);
|
99
127
|
}
|
100
128
|
|
101
129
|
static VALUE
|
@@ -113,10 +141,10 @@ variadic_initialize(VALUE self, VALUE rbFunction, VALUE rbParameterTypes, VALUE
|
|
113
141
|
Check_Type(options, T_HASH);
|
114
142
|
convention = rb_hash_aref(options, ID2SYM(rb_intern("convention")));
|
115
143
|
|
116
|
-
|
117
|
-
invoker->rbEnums
|
118
|
-
invoker->rbAddress
|
119
|
-
invoker->function = rbffi_AbstractMemory_Cast(rbFunction,
|
144
|
+
TypedData_Get_Struct(self, VariadicInvoker, &variadic_data_type, invoker);
|
145
|
+
RB_OBJ_WRITE(self, &invoker->rbEnums, rb_hash_aref(options, ID2SYM(rb_intern("enums"))));
|
146
|
+
RB_OBJ_WRITE(self, &invoker->rbAddress, rbFunction);
|
147
|
+
invoker->function = rbffi_AbstractMemory_Cast(rbFunction, &rbffi_pointer_data_type)->address;
|
120
148
|
invoker->blocking = RTEST(rb_hash_aref(options, ID2SYM(rb_intern("blocking"))));
|
121
149
|
|
122
150
|
#if defined(X86_WIN32)
|
@@ -127,13 +155,13 @@ variadic_initialize(VALUE self, VALUE rbFunction, VALUE rbParameterTypes, VALUE
|
|
127
155
|
invoker->abi = FFI_DEFAULT_ABI;
|
128
156
|
#endif
|
129
157
|
|
130
|
-
invoker->rbReturnType
|
158
|
+
RB_OBJ_WRITE(self, &invoker->rbReturnType, rbffi_Type_Lookup(rbReturnType));
|
131
159
|
if (!RTEST(invoker->rbReturnType)) {
|
132
160
|
VALUE typeName = rb_funcall2(rbReturnType, rb_intern("inspect"), 0, NULL);
|
133
161
|
rb_raise(rb_eTypeError, "Invalid return type (%s)", RSTRING_PTR(typeName));
|
134
162
|
}
|
135
163
|
|
136
|
-
|
164
|
+
TypedData_Get_Struct(rbReturnType, Type, &rbffi_type_data_type, invoker->returnType);
|
137
165
|
|
138
166
|
invoker->paramCount = -1;
|
139
167
|
|
@@ -147,7 +175,7 @@ variadic_initialize(VALUE self, VALUE rbFunction, VALUE rbParameterTypes, VALUE
|
|
147
175
|
VALUE typeName = rb_funcall2(entry, rb_intern("inspect"), 0, NULL);
|
148
176
|
rb_raise(rb_eTypeError, "Invalid parameter type (%s)", RSTRING_PTR(typeName));
|
149
177
|
}
|
150
|
-
|
178
|
+
TypedData_Get_Struct(rbType, Type, &rbffi_type_data_type, type);
|
151
179
|
if (type->nativeType != NATIVE_VARARGS) {
|
152
180
|
rb_ary_push(fixed, entry);
|
153
181
|
}
|
@@ -155,7 +183,7 @@ variadic_initialize(VALUE self, VALUE rbFunction, VALUE rbParameterTypes, VALUE
|
|
155
183
|
/*
|
156
184
|
* @fixed and @type_map are used by the parameter mangling ruby code
|
157
185
|
*/
|
158
|
-
rb_iv_set(self, "@fixed", fixed);
|
186
|
+
rb_iv_set(self, "@fixed", rb_obj_freeze(fixed));
|
159
187
|
rb_iv_set(self, "@type_map", rb_hash_aref(options, ID2SYM(rb_intern("type_map"))));
|
160
188
|
|
161
189
|
return retval;
|
@@ -173,54 +201,64 @@ variadic_invoke(VALUE self, VALUE parameterTypes, VALUE parameterValues)
|
|
173
201
|
ffi_type* ffiReturnType;
|
174
202
|
Type** paramTypes;
|
175
203
|
VALUE* argv;
|
176
|
-
|
204
|
+
VALUE* callbackParameters;
|
205
|
+
int paramCount = 0, fixedCount = 0, callbackCount = 0, i;
|
177
206
|
ffi_status ffiStatus;
|
178
207
|
rbffi_frame_t frame = { 0 };
|
179
208
|
|
180
209
|
Check_Type(parameterTypes, T_ARRAY);
|
181
210
|
Check_Type(parameterValues, T_ARRAY);
|
182
211
|
|
183
|
-
|
212
|
+
TypedData_Get_Struct(self, VariadicInvoker, &variadic_data_type, invoker);
|
184
213
|
paramCount = (int) RARRAY_LEN(parameterTypes);
|
185
214
|
paramTypes = ALLOCA_N(Type *, paramCount);
|
186
215
|
ffiParamTypes = ALLOCA_N(ffi_type *, paramCount);
|
187
216
|
params = ALLOCA_N(FFIStorage, paramCount);
|
188
217
|
ffiValues = ALLOCA_N(void*, paramCount);
|
189
218
|
argv = ALLOCA_N(VALUE, paramCount);
|
219
|
+
callbackParameters = ALLOCA_N(VALUE, paramCount);
|
190
220
|
retval = alloca(MAX(invoker->returnType->ffiType->size, FFI_SIZEOF_ARG));
|
191
221
|
|
192
222
|
for (i = 0; i < paramCount; ++i) {
|
193
223
|
VALUE rbType = rb_ary_entry(parameterTypes, i);
|
194
|
-
|
224
|
+
|
195
225
|
if (!rb_obj_is_kind_of(rbType, rbffi_TypeClass)) {
|
196
226
|
rb_raise(rb_eTypeError, "wrong type. Expected (FFI::Type)");
|
197
227
|
}
|
198
|
-
|
228
|
+
TypedData_Get_Struct(rbType, Type, &rbffi_type_data_type, paramTypes[i]);
|
199
229
|
|
200
230
|
switch (paramTypes[i]->nativeType) {
|
201
231
|
case NATIVE_INT8:
|
202
232
|
case NATIVE_INT16:
|
203
233
|
case NATIVE_INT32:
|
204
234
|
rbType = rb_const_get(rbffi_TypeClass, rb_intern("INT32"));
|
205
|
-
|
235
|
+
TypedData_Get_Struct(rbType, Type, &rbffi_type_data_type, paramTypes[i]);
|
206
236
|
break;
|
207
237
|
case NATIVE_UINT8:
|
208
238
|
case NATIVE_UINT16:
|
209
239
|
case NATIVE_UINT32:
|
210
240
|
rbType = rb_const_get(rbffi_TypeClass, rb_intern("UINT32"));
|
211
|
-
|
241
|
+
TypedData_Get_Struct(rbType, Type, &rbffi_type_data_type, paramTypes[i]);
|
212
242
|
break;
|
213
|
-
|
243
|
+
|
214
244
|
case NATIVE_FLOAT32:
|
215
245
|
rbType = rb_const_get(rbffi_TypeClass, rb_intern("DOUBLE"));
|
216
|
-
|
246
|
+
TypedData_Get_Struct(rbType, Type, &rbffi_type_data_type, paramTypes[i]);
|
247
|
+
break;
|
248
|
+
|
249
|
+
case NATIVE_FUNCTION:
|
250
|
+
if (!rb_obj_is_kind_of(rbType, rbffi_FunctionTypeClass)) {
|
251
|
+
VALUE typeName = rb_funcall2(rbType, rb_intern("inspect"), 0, NULL);
|
252
|
+
rb_raise(rb_eTypeError, "Incorrect parameter type (%s)", RSTRING_PTR(typeName));
|
253
|
+
}
|
254
|
+
callbackParameters[callbackCount++] = rbType;
|
217
255
|
break;
|
218
256
|
|
219
257
|
default:
|
220
258
|
break;
|
221
259
|
}
|
222
|
-
|
223
|
-
|
260
|
+
|
261
|
+
|
224
262
|
ffiParamTypes[i] = paramTypes[i]->ffiType;
|
225
263
|
if (ffiParamTypes[i] == NULL) {
|
226
264
|
rb_raise(rb_eArgError, "Invalid parameter type #%x", paramTypes[i]->nativeType);
|
@@ -253,14 +291,10 @@ variadic_invoke(VALUE self, VALUE parameterTypes, VALUE parameterValues)
|
|
253
291
|
}
|
254
292
|
|
255
293
|
rbffi_SetupCallParams(paramCount, argv, -1, paramTypes, params,
|
256
|
-
ffiValues,
|
257
|
-
|
294
|
+
ffiValues, callbackParameters, callbackCount, invoker->rbEnums);
|
295
|
+
|
258
296
|
rbffi_frame_push(&frame);
|
259
|
-
|
260
|
-
/* In Call.c, blocking: true is supported on older ruby variants
|
261
|
-
* without rb_thread_call_without_gvl by allocating on the heap instead
|
262
|
-
* of the stack. Since this functionality is being added later,
|
263
|
-
* we’re skipping support for old rubies here. */
|
297
|
+
|
264
298
|
if(unlikely(invoker->blocking)) {
|
265
299
|
rbffi_blocking_call_t* bc;
|
266
300
|
bc = ALLOCA_N(rbffi_blocking_call_t, 1);
|
@@ -275,13 +309,11 @@ variadic_invoke(VALUE self, VALUE parameterTypes, VALUE parameterValues)
|
|
275
309
|
} else {
|
276
310
|
ffi_call(&cif, FFI_FN(invoker->function), retval, ffiValues);
|
277
311
|
}
|
278
|
-
|
279
|
-
ffi_call(&cif, FFI_FN(invoker->function), retval, ffiValues);
|
280
|
-
#endif
|
312
|
+
|
281
313
|
rbffi_frame_pop(&frame);
|
282
|
-
|
314
|
+
|
283
315
|
rbffi_save_errno();
|
284
|
-
|
316
|
+
|
285
317
|
if (RTEST(frame.exc) && frame.exc != Qnil) {
|
286
318
|
rb_exc_raise(frame.exc);
|
287
319
|
}
|
@@ -289,6 +321,14 @@ variadic_invoke(VALUE self, VALUE parameterTypes, VALUE parameterValues)
|
|
289
321
|
return rbffi_NativeValue_ToRuby(invoker->returnType, invoker->rbReturnType, retval);
|
290
322
|
}
|
291
323
|
|
324
|
+
static VALUE
|
325
|
+
variadic_return_type(VALUE self)
|
326
|
+
{
|
327
|
+
VariadicInvoker* invoker;
|
328
|
+
|
329
|
+
TypedData_Get_Struct(self, VariadicInvoker, &variadic_data_type, invoker);
|
330
|
+
return invoker->rbReturnType;
|
331
|
+
}
|
292
332
|
|
293
333
|
void
|
294
334
|
rbffi_Variadic_Init(VALUE moduleFFI)
|
@@ -300,5 +340,6 @@ rbffi_Variadic_Init(VALUE moduleFFI)
|
|
300
340
|
|
301
341
|
rb_define_method(classVariadicInvoker, "initialize", variadic_initialize, 4);
|
302
342
|
rb_define_method(classVariadicInvoker, "invoke", variadic_invoke, 2);
|
343
|
+
rb_define_method(classVariadicInvoker, "return_type", variadic_return_type, 0);
|
303
344
|
}
|
304
345
|
|
data/ext/ffi_c/compat.h
CHANGED
@@ -32,26 +32,6 @@
|
|
32
32
|
|
33
33
|
#include <ruby.h>
|
34
34
|
|
35
|
-
#ifndef RARRAY_LEN
|
36
|
-
# define RARRAY_LEN(ary) RARRAY(ary)->len
|
37
|
-
#endif
|
38
|
-
|
39
|
-
#ifndef RARRAY_PTR
|
40
|
-
# define RARRAY_PTR(ary) RARRAY(ary)->ptr
|
41
|
-
#endif
|
42
|
-
|
43
|
-
#ifndef RSTRING_LEN
|
44
|
-
# define RSTRING_LEN(s) RSTRING(s)->len
|
45
|
-
#endif
|
46
|
-
|
47
|
-
#ifndef RSTRING_PTR
|
48
|
-
# define RSTRING_PTR(s) RSTRING(s)->ptr
|
49
|
-
#endif
|
50
|
-
|
51
|
-
#ifndef NUM2ULL
|
52
|
-
# define NUM2ULL(x) rb_num2ull((VALUE)x)
|
53
|
-
#endif
|
54
|
-
|
55
35
|
#ifndef roundup
|
56
36
|
# define roundup(x, y) ((((x)+((y)-1))/(y))*(y))
|
57
37
|
#endif
|
@@ -64,6 +44,10 @@
|
|
64
44
|
# define unlikely(x) (x)
|
65
45
|
#endif
|
66
46
|
|
47
|
+
#ifdef _MSC_VER
|
48
|
+
#define ffi_type_longdouble ffi_type_double
|
49
|
+
#endif
|
50
|
+
|
67
51
|
#ifndef MAX
|
68
52
|
# define MAX(a, b) ((a) < (b) ? (b) : (a))
|
69
53
|
#endif
|
@@ -71,8 +55,28 @@
|
|
71
55
|
# define MIN(a, b) ((a) < (b) ? (a) : (b))
|
72
56
|
#endif
|
73
57
|
|
74
|
-
|
75
|
-
|
58
|
+
|
59
|
+
|
60
|
+
/* For compatibility with ruby < 2.7 */
|
61
|
+
#ifdef HAVE_RB_GC_MARK_MOVABLE
|
62
|
+
#define ffi_compact_callback(x) .dcompact = (x),
|
63
|
+
#define ffi_gc_location(x) x = rb_gc_location(x)
|
64
|
+
#else
|
65
|
+
#define rb_gc_mark_movable(x) rb_gc_mark(x)
|
66
|
+
#define ffi_compact_callback(x)
|
67
|
+
#define ffi_gc_location(x)
|
68
|
+
#endif
|
69
|
+
|
70
|
+
|
71
|
+
/* For compatibility with ruby < 3.0 */
|
72
|
+
#ifndef RUBY_TYPED_FROZEN_SHAREABLE
|
73
|
+
#define FFI_RUBY_TYPED_FROZEN_SHAREABLE 0
|
74
|
+
#else
|
75
|
+
#define FFI_RUBY_TYPED_FROZEN_SHAREABLE RUBY_TYPED_FROZEN_SHAREABLE
|
76
|
+
#endif
|
77
|
+
|
78
|
+
#ifndef HAVE_RB_EXT_RACTOR_SAFE
|
79
|
+
#define rb_ractor_make_shareable(self) rb_obj_freeze(self);
|
76
80
|
#endif
|
77
81
|
|
78
82
|
#endif /* RBFFI_COMPAT_H */
|
data/ext/ffi_c/extconf.rb
CHANGED
@@ -1,8 +1,31 @@
|
|
1
1
|
#!/usr/bin/env ruby
|
2
2
|
|
3
|
-
if
|
3
|
+
if RUBY_ENGINE == 'ruby' || RUBY_ENGINE == 'rbx'
|
4
4
|
require 'mkmf'
|
5
5
|
require 'rbconfig'
|
6
|
+
|
7
|
+
def system_libffi_usable?
|
8
|
+
# We need pkg_config or ffi.h
|
9
|
+
libffi_ok = pkg_config("libffi") ||
|
10
|
+
have_header("ffi.h") ||
|
11
|
+
find_header("ffi.h", "/usr/local/include", "/usr/include/ffi",
|
12
|
+
"/Library/Developer/CommandLineTools/SDKs/MacOSX.sdk/usr/include/ffi",
|
13
|
+
"/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include/ffi") ||
|
14
|
+
(find_header("ffi.h", `xcrun --sdk macosx --show-sdk-path`.strip + "/usr/include/ffi") rescue false)
|
15
|
+
|
16
|
+
# Ensure we can link to ffi_prep_closure_loc
|
17
|
+
libffi_ok &&= have_library("ffi", "ffi_prep_closure_loc", [ "ffi.h" ]) ||
|
18
|
+
have_library("libffi", "ffi_prep_closure_loc", [ "ffi.h" ]) ||
|
19
|
+
have_library("libffi-8", "ffi_prep_closure_loc", [ "ffi.h" ])
|
20
|
+
|
21
|
+
if RbConfig::CONFIG['host_os'] =~ /mswin/
|
22
|
+
have_library('libffi_convenience')
|
23
|
+
have_library('shlwapi')
|
24
|
+
end
|
25
|
+
|
26
|
+
libffi_ok
|
27
|
+
end
|
28
|
+
|
6
29
|
dir_config("ffi_c")
|
7
30
|
|
8
31
|
# recent versions of ruby add restrictive ansi and warning flags on a whim - kill them all
|
@@ -10,60 +33,80 @@ if !defined?(RUBY_ENGINE) || RUBY_ENGINE == 'ruby' || RUBY_ENGINE == 'rbx'
|
|
10
33
|
$CFLAGS.gsub!(/[\s+]-ansi/, '')
|
11
34
|
$CFLAGS.gsub!(/[\s+]-std=[^\s]+/, '')
|
12
35
|
# solaris 10 needs -c99 for <stdbool.h>
|
13
|
-
$CFLAGS << " -std=c99" if RbConfig::CONFIG['host_os'] =~ /solaris(!?2\.11)/
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
36
|
+
$CFLAGS << " -g -std=c99" if RbConfig::CONFIG['host_os'] =~ /solaris(!?2\.11)/
|
37
|
+
if enable_config("debug")
|
38
|
+
$CPPFLAGS += " #{RbConfig::CONFIG["debugflags"]}"
|
39
|
+
$LDFLAGS += " #{RbConfig::CONFIG["debugflags"]}"
|
40
|
+
end
|
18
41
|
|
19
|
-
|
20
|
-
|
21
|
-
have_library("libffi", "ffi_call", [ "ffi.h" ])
|
22
|
-
libffi_ok &&= have_func("ffi_closure_alloc")
|
42
|
+
# Check whether we use system libffi
|
43
|
+
system_libffi = enable_config('system-libffi', :try)
|
23
44
|
|
24
|
-
|
25
|
-
|
45
|
+
if system_libffi == :try
|
46
|
+
system_libffi = ENV['RUBY_CC_VERSION'].nil? && system_libffi_usable?
|
47
|
+
elsif system_libffi
|
48
|
+
abort "system libffi is not usable" unless system_libffi_usable?
|
26
49
|
end
|
27
50
|
|
28
|
-
|
29
|
-
have_header('ruby/thread.h') # for compat with ruby < 2.0
|
30
|
-
have_func('rb_thread_blocking_region')
|
31
|
-
have_func('rb_thread_call_with_gvl')
|
32
|
-
have_func('rb_thread_call_without_gvl')
|
33
|
-
|
34
|
-
if libffi_ok
|
51
|
+
if system_libffi
|
35
52
|
have_func('ffi_prep_cif_var')
|
53
|
+
$defs << "-DHAVE_RAW_API" if have_func("ffi_raw_call") && have_func("ffi_prep_raw_closure")
|
36
54
|
else
|
37
55
|
$defs << "-DHAVE_FFI_PREP_CIF_VAR"
|
56
|
+
$defs << "-DUSE_INTERNAL_LIBFFI"
|
57
|
+
|
58
|
+
# Ensure libffi symbols aren't exported when using static libffi.
|
59
|
+
# This is to avoid interference with other gems like fiddle.
|
60
|
+
# See https://github.com/ffi/ffi/issues/835
|
61
|
+
append_ldflags "-Wl,--exclude-libs,ALL"
|
62
|
+
end
|
63
|
+
|
64
|
+
have_func 'rb_gc_mark_movable' # since ruby-2.7
|
65
|
+
|
66
|
+
# Some linux archs need explicit linking to pthread, see https://github.com/ffi/ffi/issues/893
|
67
|
+
append_ldflags "-pthread"
|
68
|
+
|
69
|
+
ffi_alloc_default = RbConfig::CONFIG['host_os'] =~ /darwin/i && RbConfig::CONFIG['host'] =~ /arm|aarch64/i
|
70
|
+
ffi_alloc_default = ffi_alloc_default || RbConfig::CONFIG['host'] =~ /hppa/i
|
71
|
+
if enable_config('libffi-alloc', ffi_alloc_default)
|
72
|
+
$defs << "-DUSE_FFI_ALLOC"
|
38
73
|
end
|
39
74
|
|
40
75
|
$defs << "-DHAVE_EXTCONF_H" if $defs.empty? # needed so create_header works
|
41
|
-
$defs << "-DUSE_INTERNAL_LIBFFI" unless libffi_ok
|
42
|
-
$defs << "-DRUBY_1_9" if RUBY_VERSION >= "1.9.0"
|
43
|
-
$defs << "-DFFI_BUILDING" if RbConfig::CONFIG['host_os'] =~ /mswin/ # for compatibility with newer libffi
|
44
76
|
|
45
77
|
create_header
|
46
|
-
|
47
|
-
$LOCAL_LIBS << " ./libffi/.libs/libffi_convenience.lib" if !libffi_ok && RbConfig::CONFIG['host_os'] =~ /mswin/
|
48
|
-
|
49
78
|
create_makefile("ffi_c")
|
50
|
-
|
79
|
+
|
80
|
+
unless system_libffi
|
51
81
|
File.open("Makefile", "a") do |mf|
|
52
|
-
|
53
|
-
|
82
|
+
if enable_config("debug")
|
83
|
+
mf.puts "LIBFFI_DEBUG=--enable-debug CPPFLAGS='#{RbConfig::CONFIG["debugflags"]}' LDFLAGS='#{RbConfig::CONFIG["debugflags"]}'"
|
84
|
+
end
|
85
|
+
|
86
|
+
if RbConfig::CONFIG['host_alias'] == "i386-w64-mingw32"
|
87
|
+
host = "i686-w64-mingw32" # Work around host name without matching compiler name in rake-compiler-dock-1.3.0 on platform x86-mingw32
|
88
|
+
elsif RbConfig::CONFIG.has_key?("host_alias")
|
89
|
+
host = RbConfig::CONFIG['host_alias']
|
90
|
+
end
|
91
|
+
mf.puts "LIBFFI_HOST=--host=#{host}" if host
|
92
|
+
|
93
|
+
if RbConfig::CONFIG['host_os'] =~ /darwin/i
|
94
|
+
if RbConfig::CONFIG['host'] =~ /arm|aarch64/i
|
95
|
+
mf.puts "LIBFFI_HOST=--host=aarch64-apple-#{RbConfig::CONFIG['host_os']}"
|
96
|
+
end
|
54
97
|
mf.puts "include ${srcdir}/libffi.darwin.mk"
|
55
|
-
elsif RbConfig::CONFIG['host_os']
|
98
|
+
elsif RbConfig::CONFIG['host_os'] =~ /bsd/i
|
56
99
|
mf.puts '.include "${srcdir}/libffi.bsd.mk"'
|
57
|
-
elsif RbConfig::CONFIG['host_os']
|
100
|
+
elsif RbConfig::CONFIG['host_os'] =~ /mswin64/i
|
58
101
|
mf.puts '!include $(srcdir)/libffi.vc64.mk'
|
59
|
-
elsif RbConfig::CONFIG['host_os']
|
102
|
+
elsif RbConfig::CONFIG['host_os'] =~ /mswin32/i
|
60
103
|
mf.puts '!include $(srcdir)/libffi.vc.mk'
|
61
104
|
else
|
62
105
|
mf.puts "include ${srcdir}/libffi.mk"
|
63
106
|
end
|
64
107
|
end
|
65
108
|
end
|
66
|
-
|
109
|
+
|
67
110
|
else
|
68
111
|
File.open("Makefile", "w") do |mf|
|
69
112
|
mf.puts "# Dummy makefile for non-mri rubies"
|
data/ext/ffi_c/ffi.c
CHANGED
@@ -40,13 +40,12 @@
|
|
40
40
|
#include "MemoryPointer.h"
|
41
41
|
#include "Struct.h"
|
42
42
|
#include "StructByValue.h"
|
43
|
-
#include "StructByReference.h"
|
44
43
|
#include "DynamicLibrary.h"
|
45
44
|
#include "Platform.h"
|
46
45
|
#include "Types.h"
|
47
46
|
#include "LastError.h"
|
48
47
|
#include "Function.h"
|
49
|
-
#include "
|
48
|
+
#include "ClosurePool.h"
|
50
49
|
#include "MethodHandle.h"
|
51
50
|
#include "Call.h"
|
52
51
|
#include "ArrayType.h"
|
@@ -59,9 +58,13 @@ VALUE rbffi_FFIModule = Qnil;
|
|
59
58
|
static VALUE moduleFFI = Qnil;
|
60
59
|
|
61
60
|
void
|
62
|
-
Init_ffi_c(void)
|
61
|
+
Init_ffi_c(void)
|
63
62
|
{
|
64
|
-
|
63
|
+
#ifdef HAVE_RB_EXT_RACTOR_SAFE
|
64
|
+
rb_ext_ractor_safe(1);
|
65
|
+
#endif
|
66
|
+
|
67
|
+
/*
|
65
68
|
* Document-module: FFI
|
66
69
|
*
|
67
70
|
* This module embbed type constants from {FFI::NativeType}.
|
@@ -70,16 +73,14 @@ Init_ffi_c(void)
|
|
70
73
|
rb_global_variable(&rbffi_FFIModule);
|
71
74
|
|
72
75
|
rbffi_Thread_Init(rbffi_FFIModule);
|
73
|
-
|
76
|
+
|
74
77
|
/* FFI::Type needs to be initialized before most other classes */
|
75
78
|
rbffi_Type_Init(moduleFFI);
|
76
79
|
|
77
|
-
rbffi_DataConverter_Init(moduleFFI);
|
78
|
-
|
79
80
|
rbffi_ArrayType_Init(moduleFFI);
|
80
81
|
rbffi_LastError_Init(moduleFFI);
|
81
82
|
rbffi_Call_Init(moduleFFI);
|
82
|
-
|
83
|
+
rbffi_ClosurePool_Init(moduleFFI);
|
83
84
|
rbffi_MethodHandle_Init(moduleFFI);
|
84
85
|
rbffi_Platform_Init(moduleFFI);
|
85
86
|
rbffi_AbstractMemory_Init(moduleFFI);
|
@@ -88,11 +89,9 @@ Init_ffi_c(void)
|
|
88
89
|
rbffi_MemoryPointer_Init(moduleFFI);
|
89
90
|
rbffi_Buffer_Init(moduleFFI);
|
90
91
|
rbffi_StructByValue_Init(moduleFFI);
|
91
|
-
rbffi_StructByReference_Init(moduleFFI);
|
92
92
|
rbffi_Struct_Init(moduleFFI);
|
93
93
|
rbffi_DynamicLibrary_Init(moduleFFI);
|
94
94
|
rbffi_Variadic_Init(moduleFFI);
|
95
95
|
rbffi_Types_Init(moduleFFI);
|
96
96
|
rbffi_MappedType_Init(moduleFFI);
|
97
97
|
}
|
98
|
-
|
@@ -0,0 +1,16 @@
|
|
1
|
+
# Copyright (C) 2021 Anthony Green
|
2
|
+
|
3
|
+
lappend boards_dir $::env(SITEDIR)
|
4
|
+
|
5
|
+
verbose "Global Config File: target_triplet is $target_triplet" 1
|
6
|
+
global target_list
|
7
|
+
|
8
|
+
case "$target_triplet" in {
|
9
|
+
{ "aarch*cygwin*" } {
|
10
|
+
set target_list "unix-noexec"
|
11
|
+
}
|
12
|
+
{ "arm*cygwin*" } {
|
13
|
+
set target_list "unix-noexec"
|
14
|
+
}
|
15
|
+
}
|
16
|
+
|