ffi 1.9.21-x86-mingw32 → 1.9.22-x86-mingw32
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of ffi might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/.gitignore +22 -0
- data/.gitmodules +3 -0
- data/.travis.yml +52 -0
- data/.yardopts +5 -0
- data/Gemfile +15 -0
- data/{spec/ffi/LICENSE.SPECS → LICENSE.SPECS} +1 -1
- data/README.md +1 -1
- data/Rakefile +28 -3
- data/appveyor.yml +22 -0
- data/ffi.gemspec +14 -1
- data/lib/2.0/ffi_c.so +0 -0
- data/lib/2.1/ffi_c.so +0 -0
- data/lib/2.2/ffi_c.so +0 -0
- data/lib/2.3/ffi_c.so +0 -0
- data/lib/2.4/ffi_c.so +0 -0
- data/lib/2.5/ffi_c.so +0 -0
- data/lib/ffi/library.rb +1 -1
- data/lib/ffi/version.rb +1 -1
- data/samples/getlogin.rb +8 -0
- data/samples/getpid.rb +8 -0
- data/samples/gettimeofday.rb +18 -0
- data/samples/hello.rb +7 -0
- data/samples/inotify.rb +60 -0
- data/samples/pty.rb +76 -0
- data/samples/qsort.rb +21 -0
- data/samples/sample_helper.rb +6 -0
- metadata +17 -526
- data/ext/ffi_c/AbstractMemory.c +0 -1109
- data/ext/ffi_c/AbstractMemory.h +0 -175
- data/ext/ffi_c/ArrayType.c +0 -162
- data/ext/ffi_c/ArrayType.h +0 -59
- data/ext/ffi_c/Buffer.c +0 -365
- data/ext/ffi_c/Call.c +0 -517
- data/ext/ffi_c/Call.h +0 -110
- data/ext/ffi_c/ClosurePool.c +0 -283
- data/ext/ffi_c/ClosurePool.h +0 -57
- data/ext/ffi_c/DataConverter.c +0 -91
- data/ext/ffi_c/DynamicLibrary.c +0 -339
- data/ext/ffi_c/DynamicLibrary.h +0 -98
- data/ext/ffi_c/Function.c +0 -998
- data/ext/ffi_c/Function.h +0 -87
- data/ext/ffi_c/FunctionInfo.c +0 -271
- data/ext/ffi_c/LastError.c +0 -184
- data/ext/ffi_c/LastError.h +0 -47
- data/ext/ffi_c/LongDouble.c +0 -63
- data/ext/ffi_c/LongDouble.h +0 -51
- data/ext/ffi_c/MappedType.c +0 -168
- data/ext/ffi_c/MappedType.h +0 -59
- data/ext/ffi_c/MemoryPointer.c +0 -197
- data/ext/ffi_c/MemoryPointer.h +0 -53
- data/ext/ffi_c/MethodHandle.c +0 -358
- data/ext/ffi_c/MethodHandle.h +0 -55
- data/ext/ffi_c/Platform.c +0 -129
- data/ext/ffi_c/Platform.h +0 -45
- data/ext/ffi_c/Pointer.c +0 -508
- data/ext/ffi_c/Pointer.h +0 -63
- data/ext/ffi_c/Struct.c +0 -829
- data/ext/ffi_c/Struct.h +0 -106
- data/ext/ffi_c/StructByReference.c +0 -190
- data/ext/ffi_c/StructByReference.h +0 -50
- data/ext/ffi_c/StructByValue.c +0 -150
- data/ext/ffi_c/StructByValue.h +0 -55
- data/ext/ffi_c/StructLayout.c +0 -698
- data/ext/ffi_c/Thread.c +0 -352
- data/ext/ffi_c/Thread.h +0 -95
- data/ext/ffi_c/Type.c +0 -397
- data/ext/ffi_c/Type.h +0 -62
- data/ext/ffi_c/Types.c +0 -139
- data/ext/ffi_c/Types.h +0 -89
- data/ext/ffi_c/Variadic.c +0 -304
- data/ext/ffi_c/compat.h +0 -78
- data/ext/ffi_c/extconf.rb +0 -71
- data/ext/ffi_c/ffi.c +0 -98
- data/ext/ffi_c/libffi.bsd.mk +0 -40
- data/ext/ffi_c/libffi.darwin.mk +0 -105
- data/ext/ffi_c/libffi.gnu.mk +0 -32
- data/ext/ffi_c/libffi.mk +0 -18
- data/ext/ffi_c/libffi.vc.mk +0 -26
- data/ext/ffi_c/libffi.vc64.mk +0 -26
- data/ext/ffi_c/libffi/ChangeLog.libffi +0 -584
- data/ext/ffi_c/libffi/ChangeLog.libffi-3.1 +0 -6000
- data/ext/ffi_c/libffi/ChangeLog.libgcj +0 -40
- data/ext/ffi_c/libffi/ChangeLog.v1 +0 -764
- data/ext/ffi_c/libffi/LICENSE +0 -21
- data/ext/ffi_c/libffi/Makefile.am +0 -205
- data/ext/ffi_c/libffi/Makefile.in +0 -1805
- data/ext/ffi_c/libffi/README +0 -454
- data/ext/ffi_c/libffi/acinclude.m4 +0 -473
- data/ext/ffi_c/libffi/aclocal.m4 +0 -2134
- data/ext/ffi_c/libffi/autogen.sh +0 -2
- data/ext/ffi_c/libffi/autom4te.cache/output.0 +0 -21972
- data/ext/ffi_c/libffi/autom4te.cache/output.1 +0 -21972
- data/ext/ffi_c/libffi/autom4te.cache/output.2 +0 -21972
- data/ext/ffi_c/libffi/autom4te.cache/output.3 +0 -21972
- data/ext/ffi_c/libffi/autom4te.cache/requests +0 -331
- data/ext/ffi_c/libffi/autom4te.cache/traces.0 +0 -4010
- data/ext/ffi_c/libffi/autom4te.cache/traces.1 +0 -1005
- data/ext/ffi_c/libffi/autom4te.cache/traces.2 +0 -4010
- data/ext/ffi_c/libffi/autom4te.cache/traces.3 +0 -4010
- data/ext/ffi_c/libffi/compile +0 -347
- data/ext/ffi_c/libffi/config.guess +0 -1462
- data/ext/ffi_c/libffi/config.sub +0 -1825
- data/ext/ffi_c/libffi/configure +0 -21972
- data/ext/ffi_c/libffi/configure.ac +0 -388
- data/ext/ffi_c/libffi/configure.host +0 -272
- data/ext/ffi_c/libffi/depcomp +0 -791
- data/ext/ffi_c/libffi/doc/Makefile.am +0 -3
- data/ext/ffi_c/libffi/doc/Makefile.in +0 -811
- data/ext/ffi_c/libffi/doc/libffi.texi +0 -985
- data/ext/ffi_c/libffi/doc/mdate-sh +0 -228
- data/ext/ffi_c/libffi/doc/texinfo.tex +0 -10079
- data/ext/ffi_c/libffi/doc/version.texi +0 -4
- data/ext/ffi_c/libffi/fficonfig.h.in +0 -210
- data/ext/ffi_c/libffi/fficonfig.h.in~ +0 -210
- data/ext/ffi_c/libffi/generate-darwin-source-and-headers.py +0 -207
- data/ext/ffi_c/libffi/include/Makefile.am +0 -9
- data/ext/ffi_c/libffi/include/Makefile.in +0 -604
- data/ext/ffi_c/libffi/include/ffi.h.in +0 -484
- data/ext/ffi_c/libffi/include/ffi_cfi.h +0 -55
- data/ext/ffi_c/libffi/include/ffi_common.h +0 -147
- data/ext/ffi_c/libffi/install-sh +0 -508
- data/ext/ffi_c/libffi/libffi.map.in +0 -80
- data/ext/ffi_c/libffi/libffi.pc.in +0 -11
- data/ext/ffi_c/libffi/libffi.xcodeproj/project.pbxproj +0 -637
- data/ext/ffi_c/libffi/libtool-ldflags +0 -106
- data/ext/ffi_c/libffi/libtool-version +0 -29
- data/ext/ffi_c/libffi/ltmain.sh +0 -11156
- data/ext/ffi_c/libffi/m4/asmcfi.m4 +0 -13
- data/ext/ffi_c/libffi/m4/ax_append_flag.m4 +0 -69
- data/ext/ffi_c/libffi/m4/ax_cc_maxopt.m4 +0 -181
- data/ext/ffi_c/libffi/m4/ax_cflags_warn_all.m4 +0 -122
- data/ext/ffi_c/libffi/m4/ax_check_compile_flag.m4 +0 -72
- data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +0 -84
- data/ext/ffi_c/libffi/m4/ax_configure_args.m4 +0 -70
- data/ext/ffi_c/libffi/m4/ax_enable_builddir.m4 +0 -301
- data/ext/ffi_c/libffi/m4/ax_gcc_archflag.m4 +0 -225
- data/ext/ffi_c/libffi/m4/ax_gcc_x86_cpuid.m4 +0 -79
- data/ext/ffi_c/libffi/m4/libtool.m4 +0 -8387
- data/ext/ffi_c/libffi/m4/ltoptions.m4 +0 -437
- data/ext/ffi_c/libffi/m4/ltsugar.m4 +0 -124
- data/ext/ffi_c/libffi/m4/ltversion.m4 +0 -23
- data/ext/ffi_c/libffi/m4/lt~obsolete.m4 +0 -99
- data/ext/ffi_c/libffi/man/Makefile.am +0 -8
- data/ext/ffi_c/libffi/man/Makefile.in +0 -558
- data/ext/ffi_c/libffi/man/ffi.3 +0 -41
- data/ext/ffi_c/libffi/man/ffi_call.3 +0 -103
- data/ext/ffi_c/libffi/man/ffi_prep_cif.3 +0 -68
- data/ext/ffi_c/libffi/man/ffi_prep_cif_var.3 +0 -73
- data/ext/ffi_c/libffi/missing +0 -215
- data/ext/ffi_c/libffi/msvcc.sh +0 -260
- data/ext/ffi_c/libffi/src/aarch64/ffi.c +0 -941
- data/ext/ffi_c/libffi/src/aarch64/ffitarget.h +0 -81
- data/ext/ffi_c/libffi/src/aarch64/internal.h +0 -67
- data/ext/ffi_c/libffi/src/aarch64/sysv.S +0 -438
- data/ext/ffi_c/libffi/src/alpha/ffi.c +0 -521
- data/ext/ffi_c/libffi/src/alpha/ffitarget.h +0 -57
- data/ext/ffi_c/libffi/src/alpha/internal.h +0 -23
- data/ext/ffi_c/libffi/src/alpha/osf.S +0 -282
- data/ext/ffi_c/libffi/src/arc/arcompact.S +0 -135
- data/ext/ffi_c/libffi/src/arc/ffi.c +0 -266
- data/ext/ffi_c/libffi/src/arc/ffitarget.h +0 -53
- data/ext/ffi_c/libffi/src/arm/ffi.c +0 -808
- data/ext/ffi_c/libffi/src/arm/ffitarget.h +0 -82
- data/ext/ffi_c/libffi/src/arm/internal.h +0 -7
- data/ext/ffi_c/libffi/src/arm/sysv.S +0 -383
- data/ext/ffi_c/libffi/src/avr32/ffi.c +0 -423
- data/ext/ffi_c/libffi/src/avr32/ffitarget.h +0 -55
- data/ext/ffi_c/libffi/src/avr32/sysv.S +0 -208
- data/ext/ffi_c/libffi/src/bfin/ffi.c +0 -196
- data/ext/ffi_c/libffi/src/bfin/ffitarget.h +0 -43
- data/ext/ffi_c/libffi/src/bfin/sysv.S +0 -179
- data/ext/ffi_c/libffi/src/closures.c +0 -890
- data/ext/ffi_c/libffi/src/cris/ffi.c +0 -386
- data/ext/ffi_c/libffi/src/cris/ffitarget.h +0 -56
- data/ext/ffi_c/libffi/src/cris/sysv.S +0 -215
- data/ext/ffi_c/libffi/src/debug.c +0 -64
- data/ext/ffi_c/libffi/src/dlmalloc.c +0 -5166
- data/ext/ffi_c/libffi/src/frv/eabi.S +0 -128
- data/ext/ffi_c/libffi/src/frv/ffi.c +0 -292
- data/ext/ffi_c/libffi/src/frv/ffitarget.h +0 -62
- data/ext/ffi_c/libffi/src/ia64/ffi.c +0 -586
- data/ext/ffi_c/libffi/src/ia64/ffitarget.h +0 -55
- data/ext/ffi_c/libffi/src/ia64/ia64_flags.h +0 -40
- data/ext/ffi_c/libffi/src/ia64/unix.S +0 -560
- data/ext/ffi_c/libffi/src/java_raw_api.c +0 -374
- data/ext/ffi_c/libffi/src/m32r/ffi.c +0 -232
- data/ext/ffi_c/libffi/src/m32r/ffitarget.h +0 -53
- data/ext/ffi_c/libffi/src/m32r/sysv.S +0 -121
- data/ext/ffi_c/libffi/src/m68k/ffi.c +0 -362
- data/ext/ffi_c/libffi/src/m68k/ffitarget.h +0 -54
- data/ext/ffi_c/libffi/src/m68k/sysv.S +0 -357
- data/ext/ffi_c/libffi/src/m88k/ffi.c +0 -400
- data/ext/ffi_c/libffi/src/m88k/ffitarget.h +0 -49
- data/ext/ffi_c/libffi/src/m88k/obsd.S +0 -209
- data/ext/ffi_c/libffi/src/metag/ffi.c +0 -330
- data/ext/ffi_c/libffi/src/metag/ffitarget.h +0 -53
- data/ext/ffi_c/libffi/src/metag/sysv.S +0 -311
- data/ext/ffi_c/libffi/src/microblaze/ffi.c +0 -321
- data/ext/ffi_c/libffi/src/microblaze/ffitarget.h +0 -53
- data/ext/ffi_c/libffi/src/microblaze/sysv.S +0 -302
- data/ext/ffi_c/libffi/src/mips/ffi.c +0 -1105
- data/ext/ffi_c/libffi/src/mips/ffitarget.h +0 -249
- data/ext/ffi_c/libffi/src/mips/n32.S +0 -661
- data/ext/ffi_c/libffi/src/mips/o32.S +0 -502
- data/ext/ffi_c/libffi/src/moxie/eabi.S +0 -101
- data/ext/ffi_c/libffi/src/moxie/ffi.c +0 -272
- data/ext/ffi_c/libffi/src/moxie/ffitarget.h +0 -52
- data/ext/ffi_c/libffi/src/nios2/ffi.c +0 -304
- data/ext/ffi_c/libffi/src/nios2/ffitarget.h +0 -52
- data/ext/ffi_c/libffi/src/nios2/sysv.S +0 -136
- data/ext/ffi_c/libffi/src/or1k/ffi.c +0 -328
- data/ext/ffi_c/libffi/src/or1k/ffitarget.h +0 -58
- data/ext/ffi_c/libffi/src/or1k/sysv.S +0 -107
- data/ext/ffi_c/libffi/src/pa/ffi.c +0 -719
- data/ext/ffi_c/libffi/src/pa/ffitarget.h +0 -85
- data/ext/ffi_c/libffi/src/pa/hpux32.S +0 -368
- data/ext/ffi_c/libffi/src/pa/linux.S +0 -357
- data/ext/ffi_c/libffi/src/powerpc/aix.S +0 -328
- data/ext/ffi_c/libffi/src/powerpc/aix_closure.S +0 -447
- data/ext/ffi_c/libffi/src/powerpc/asm.h +0 -125
- data/ext/ffi_c/libffi/src/powerpc/darwin.S +0 -378
- data/ext/ffi_c/libffi/src/powerpc/darwin_closure.S +0 -571
- data/ext/ffi_c/libffi/src/powerpc/ffi.c +0 -173
- data/ext/ffi_c/libffi/src/powerpc/ffi_darwin.c +0 -1359
- data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +0 -945
- data/ext/ffi_c/libffi/src/powerpc/ffi_powerpc.h +0 -94
- data/ext/ffi_c/libffi/src/powerpc/ffi_sysv.c +0 -923
- data/ext/ffi_c/libffi/src/powerpc/ffitarget.h +0 -195
- data/ext/ffi_c/libffi/src/powerpc/linux64.S +0 -228
- data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +0 -488
- data/ext/ffi_c/libffi/src/powerpc/ppc_closure.S +0 -397
- data/ext/ffi_c/libffi/src/powerpc/sysv.S +0 -175
- data/ext/ffi_c/libffi/src/prep_cif.c +0 -261
- data/ext/ffi_c/libffi/src/raw_api.c +0 -267
- data/ext/ffi_c/libffi/src/s390/ffi.c +0 -756
- data/ext/ffi_c/libffi/src/s390/ffitarget.h +0 -70
- data/ext/ffi_c/libffi/src/s390/internal.h +0 -11
- data/ext/ffi_c/libffi/src/s390/sysv.S +0 -325
- data/ext/ffi_c/libffi/src/sh/ffi.c +0 -717
- data/ext/ffi_c/libffi/src/sh/ffitarget.h +0 -54
- data/ext/ffi_c/libffi/src/sh/sysv.S +0 -850
- data/ext/ffi_c/libffi/src/sh64/ffi.c +0 -469
- data/ext/ffi_c/libffi/src/sh64/ffitarget.h +0 -58
- data/ext/ffi_c/libffi/src/sh64/sysv.S +0 -539
- data/ext/ffi_c/libffi/src/sparc/ffi.c +0 -468
- data/ext/ffi_c/libffi/src/sparc/ffi64.c +0 -608
- data/ext/ffi_c/libffi/src/sparc/ffitarget.h +0 -81
- data/ext/ffi_c/libffi/src/sparc/internal.h +0 -26
- data/ext/ffi_c/libffi/src/sparc/v8.S +0 -443
- data/ext/ffi_c/libffi/src/sparc/v9.S +0 -440
- data/ext/ffi_c/libffi/src/tile/ffi.c +0 -355
- data/ext/ffi_c/libffi/src/tile/ffitarget.h +0 -65
- data/ext/ffi_c/libffi/src/tile/tile.S +0 -360
- data/ext/ffi_c/libffi/src/types.c +0 -106
- data/ext/ffi_c/libffi/src/vax/elfbsd.S +0 -195
- data/ext/ffi_c/libffi/src/vax/ffi.c +0 -276
- data/ext/ffi_c/libffi/src/vax/ffitarget.h +0 -49
- data/ext/ffi_c/libffi/src/x86/asmnames.h +0 -30
- data/ext/ffi_c/libffi/src/x86/ffi.c +0 -733
- data/ext/ffi_c/libffi/src/x86/ffi64.c +0 -857
- data/ext/ffi_c/libffi/src/x86/ffitarget.h +0 -141
- data/ext/ffi_c/libffi/src/x86/ffiw64.c +0 -287
- data/ext/ffi_c/libffi/src/x86/internal.h +0 -29
- data/ext/ffi_c/libffi/src/x86/internal64.h +0 -22
- data/ext/ffi_c/libffi/src/x86/sysv.S +0 -1043
- data/ext/ffi_c/libffi/src/x86/unix64.S +0 -525
- data/ext/ffi_c/libffi/src/x86/win64.S +0 -232
- data/ext/ffi_c/libffi/src/x86/win64_intel.S +0 -237
- data/ext/ffi_c/libffi/src/xtensa/ffi.c +0 -298
- data/ext/ffi_c/libffi/src/xtensa/ffitarget.h +0 -53
- data/ext/ffi_c/libffi/src/xtensa/sysv.S +0 -253
- data/ext/ffi_c/libffi/stamp-h.in +0 -1
- data/ext/ffi_c/libffi/testsuite/Makefile.am +0 -85
- data/ext/ffi_c/libffi/testsuite/Makefile.in +0 -607
- data/ext/ffi_c/libffi/testsuite/config/default.exp +0 -1
- data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +0 -445
- data/ext/ffi_c/libffi/testsuite/lib/target-libpath.exp +0 -283
- data/ext/ffi_c/libffi/testsuite/lib/wrapper.exp +0 -45
- data/ext/ffi_c/libffi/testsuite/libffi.call/align_mixed.c +0 -46
- data/ext/ffi_c/libffi/testsuite/libffi.call/call.exp +0 -30
- data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn0.c +0 -89
- data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn1.c +0 -81
- data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn2.c +0 -81
- data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn3.c +0 -82
- data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn4.c +0 -89
- data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn5.c +0 -92
- data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn6.c +0 -90
- data/ext/ffi_c/libffi/testsuite/libffi.call/closure_loc_fn0.c +0 -95
- data/ext/ffi_c/libffi/testsuite/libffi.call/closure_simple.c +0 -55
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_12byte.c +0 -94
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_16byte.c +0 -95
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_18byte.c +0 -96
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_19byte.c +0 -102
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_1_1byte.c +0 -89
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_20byte.c +0 -91
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_20byte1.c +0 -93
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_24byte.c +0 -113
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_2byte.c +0 -90
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3_1byte.c +0 -95
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3byte1.c +0 -90
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3byte2.c +0 -90
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_4_1byte.c +0 -98
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_4byte.c +0 -90
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_5_1_byte.c +0 -109
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_5byte.c +0 -98
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_64byte.c +0 -124
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_6_1_byte.c +0 -113
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_6byte.c +0 -99
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_7_1_byte.c +0 -117
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_7byte.c +0 -97
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_8byte.c +0 -88
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_9byte1.c +0 -90
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_9byte2.c +0 -91
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_double.c +0 -93
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_float.c +0 -91
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_longdouble.c +0 -92
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_longdouble_split.c +0 -132
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_longdouble_split2.c +0 -115
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_pointer.c +0 -95
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint16.c +0 -91
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint32.c +0 -91
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint64.c +0 -92
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint16.c +0 -91
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint32.c +0 -91
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint64.c +0 -93
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_dbls_struct.c +0 -66
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_double.c +0 -43
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_double_va.c +0 -61
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_float.c +0 -42
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_longdouble.c +0 -105
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_longdouble_va.c +0 -61
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_many_mixed_args.c +0 -70
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_many_mixed_float_double.c +0 -55
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_schar.c +0 -74
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_sshort.c +0 -74
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_sshortchar.c +0 -86
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_uchar.c +0 -91
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_ushort.c +0 -74
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_ushortchar.c +0 -86
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_pointer.c +0 -74
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_pointer_stack.c +0 -142
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_schar.c +0 -44
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_sint.c +0 -42
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_sshort.c +0 -42
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_struct_va1.c +0 -114
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uchar.c +0 -42
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uchar_va.c +0 -44
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uint.c +0 -43
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uint_va.c +0 -45
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ulong_va.c +0 -45
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ulonglong.c +0 -47
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ushort.c +0 -43
- data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ushort_va.c +0 -44
- data/ext/ffi_c/libffi/testsuite/libffi.call/err_bad_abi.c +0 -36
- data/ext/ffi_c/libffi/testsuite/libffi.call/err_bad_typedef.c +0 -26
- data/ext/ffi_c/libffi/testsuite/libffi.call/ffitest.h +0 -136
- data/ext/ffi_c/libffi/testsuite/libffi.call/float.c +0 -59
- data/ext/ffi_c/libffi/testsuite/libffi.call/float1.c +0 -60
- data/ext/ffi_c/libffi/testsuite/libffi.call/float2.c +0 -60
- data/ext/ffi_c/libffi/testsuite/libffi.call/float3.c +0 -74
- data/ext/ffi_c/libffi/testsuite/libffi.call/float4.c +0 -62
- data/ext/ffi_c/libffi/testsuite/libffi.call/float_va.c +0 -107
- data/ext/ffi_c/libffi/testsuite/libffi.call/huge_struct.c +0 -341
- data/ext/ffi_c/libffi/testsuite/libffi.call/many.c +0 -59
- data/ext/ffi_c/libffi/testsuite/libffi.call/many2.c +0 -57
- data/ext/ffi_c/libffi/testsuite/libffi.call/many_double.c +0 -70
- data/ext/ffi_c/libffi/testsuite/libffi.call/many_mixed.c +0 -78
- data/ext/ffi_c/libffi/testsuite/libffi.call/negint.c +0 -52
- data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct.c +0 -152
- data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct1.c +0 -161
- data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct10.c +0 -133
- data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct11.c +0 -121
- data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct2.c +0 -110
- data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct3.c +0 -111
- data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct4.c +0 -111
- data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct5.c +0 -112
- data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct6.c +0 -131
- data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct7.c +0 -111
- data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct8.c +0 -131
- data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct9.c +0 -131
- data/ext/ffi_c/libffi/testsuite/libffi.call/offsets.c +0 -46
- data/ext/ffi_c/libffi/testsuite/libffi.call/pr1172638.c +0 -127
- data/ext/ffi_c/libffi/testsuite/libffi.call/problem1.c +0 -90
- data/ext/ffi_c/libffi/testsuite/libffi.call/promotion.c +0 -59
- data/ext/ffi_c/libffi/testsuite/libffi.call/pyobjc-tc.c +0 -114
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl.c +0 -36
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl1.c +0 -43
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl2.c +0 -42
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl.c +0 -35
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl1.c +0 -36
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl2.c +0 -49
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl3.c +0 -42
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_ldl.c +0 -34
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll.c +0 -41
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll1.c +0 -43
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_sc.c +0 -36
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_sl.c +0 -38
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_uc.c +0 -38
- data/ext/ffi_c/libffi/testsuite/libffi.call/return_ul.c +0 -38
- data/ext/ffi_c/libffi/testsuite/libffi.call/stret_large.c +0 -145
- data/ext/ffi_c/libffi/testsuite/libffi.call/stret_large2.c +0 -148
- data/ext/ffi_c/libffi/testsuite/libffi.call/stret_medium.c +0 -124
- data/ext/ffi_c/libffi/testsuite/libffi.call/stret_medium2.c +0 -125
- data/ext/ffi_c/libffi/testsuite/libffi.call/strlen.c +0 -44
- data/ext/ffi_c/libffi/testsuite/libffi.call/strlen2.c +0 -49
- data/ext/ffi_c/libffi/testsuite/libffi.call/strlen3.c +0 -49
- data/ext/ffi_c/libffi/testsuite/libffi.call/strlen4.c +0 -55
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct1.c +0 -67
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct2.c +0 -67
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct3.c +0 -60
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct4.c +0 -64
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct5.c +0 -66
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct6.c +0 -64
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct7.c +0 -74
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct8.c +0 -81
- data/ext/ffi_c/libffi/testsuite/libffi.call/struct9.c +0 -68
- data/ext/ffi_c/libffi/testsuite/libffi.call/testclosure.c +0 -70
- data/ext/ffi_c/libffi/testsuite/libffi.call/uninitialized.c +0 -61
- data/ext/ffi_c/libffi/testsuite/libffi.call/unwindtest.cc +0 -117
- data/ext/ffi_c/libffi/testsuite/libffi.call/unwindtest_ffi_call.cc +0 -54
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_1.c +0 -196
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct1.c +0 -121
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct2.c +0 -123
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct3.c +0 -125
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex.inc +0 -91
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_double.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_float.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_longdouble.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex.inc +0 -42
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_double.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_float.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_longdouble.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct.inc +0 -71
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_double.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_float.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_longdouble.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va.inc +0 -80
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_double.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_float.c +0 -16
- data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_longdouble.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex.exp +0 -36
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex.inc +0 -51
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_double.inc +0 -7
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_float.inc +0 -7
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_longdouble.inc +0 -7
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_double.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_float.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_int.c +0 -86
- data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_longdouble.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/ffitest.h +0 -1
- data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex.inc +0 -78
- data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_double.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_float.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_longdouble.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex.inc +0 -37
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1.inc +0 -41
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_double.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_float.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_longdouble.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2.inc +0 -44
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_double.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_float.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_longdouble.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_double.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_float.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_longdouble.c +0 -10
- data/ext/ffi_c/libffi/testsuite/libffi.go/aa-direct.c +0 -34
- data/ext/ffi_c/libffi/testsuite/libffi.go/closure1.c +0 -28
- data/ext/ffi_c/libffi/testsuite/libffi.go/ffitest.h +0 -1
- data/ext/ffi_c/libffi/testsuite/libffi.go/go.exp +0 -36
- data/ext/ffi_c/libffi/testsuite/libffi.go/static-chain.h +0 -19
- data/ext/ffi_c/rbffi.h +0 -57
- data/ext/ffi_c/rbffi_endian.h +0 -59
- data/ext/ffi_c/win32/stdbool.h +0 -8
- data/ext/ffi_c/win32/stdint.h +0 -201
- data/gen/Rakefile +0 -30
- data/libtest/Benchmark.c +0 -52
- data/libtest/BoolTest.c +0 -34
- data/libtest/BufferTest.c +0 -31
- data/libtest/ClosureTest.c +0 -205
- data/libtest/EnumTest.c +0 -51
- data/libtest/FunctionTest.c +0 -70
- data/libtest/GNUmakefile +0 -149
- data/libtest/GlobalVariable.c +0 -62
- data/libtest/LastErrorTest.c +0 -21
- data/libtest/NumberTest.c +0 -132
- data/libtest/PointerTest.c +0 -63
- data/libtest/ReferenceTest.c +0 -23
- data/libtest/StringTest.c +0 -34
- data/libtest/StructTest.c +0 -243
- data/libtest/UnionTest.c +0 -43
- data/libtest/VariadicTest.c +0 -99
- data/spec/ffi/async_callback_spec.rb +0 -35
- data/spec/ffi/bitmask_spec.rb +0 -575
- data/spec/ffi/bool_spec.rb +0 -32
- data/spec/ffi/buffer_spec.rb +0 -279
- data/spec/ffi/callback_spec.rb +0 -773
- data/spec/ffi/custom_param_type.rb +0 -37
- data/spec/ffi/custom_type_spec.rb +0 -74
- data/spec/ffi/dup_spec.rb +0 -52
- data/spec/ffi/embed-test/ext/Makefile +0 -242
- data/spec/ffi/enum_spec.rb +0 -423
- data/spec/ffi/errno_spec.rb +0 -20
- data/spec/ffi/ffi_spec.rb +0 -28
- data/spec/ffi/fixtures/Benchmark.c +0 -52
- data/spec/ffi/fixtures/BitmaskTest.c +0 -51
- data/spec/ffi/fixtures/BoolTest.c +0 -34
- data/spec/ffi/fixtures/BufferTest.c +0 -31
- data/spec/ffi/fixtures/ClosureTest.c +0 -205
- data/spec/ffi/fixtures/EnumTest.c +0 -51
- data/spec/ffi/fixtures/FunctionTest.c +0 -142
- data/spec/ffi/fixtures/GNUmakefile +0 -149
- data/spec/ffi/fixtures/GlobalVariable.c +0 -62
- data/spec/ffi/fixtures/LastErrorTest.c +0 -21
- data/spec/ffi/fixtures/NumberTest.c +0 -132
- data/spec/ffi/fixtures/PipeHelper.h +0 -21
- data/spec/ffi/fixtures/PipeHelperPosix.c +0 -41
- data/spec/ffi/fixtures/PipeHelperWindows.c +0 -72
- data/spec/ffi/fixtures/PointerTest.c +0 -63
- data/spec/ffi/fixtures/ReferenceTest.c +0 -23
- data/spec/ffi/fixtures/StringTest.c +0 -34
- data/spec/ffi/fixtures/StructTest.c +0 -243
- data/spec/ffi/fixtures/UnionTest.c +0 -43
- data/spec/ffi/fixtures/VariadicTest.c +0 -99
- data/spec/ffi/fixtures/classes.rb +0 -438
- data/spec/ffi/function_spec.rb +0 -97
- data/spec/ffi/io_spec.rb +0 -16
- data/spec/ffi/library_spec.rb +0 -286
- data/spec/ffi/long_double.rb +0 -30
- data/spec/ffi/managed_struct_spec.rb +0 -68
- data/spec/ffi/memorypointer_spec.rb +0 -78
- data/spec/ffi/number_spec.rb +0 -247
- data/spec/ffi/platform_spec.rb +0 -114
- data/spec/ffi/pointer_spec.rb +0 -285
- data/spec/ffi/rbx/attach_function_spec.rb +0 -34
- data/spec/ffi/rbx/memory_pointer_spec.rb +0 -198
- data/spec/ffi/rbx/spec_helper.rb +0 -6
- data/spec/ffi/rbx/struct_spec.rb +0 -18
- data/spec/ffi/spec_helper.rb +0 -93
- data/spec/ffi/string_spec.rb +0 -118
- data/spec/ffi/strptr_spec.rb +0 -50
- data/spec/ffi/struct_by_ref_spec.rb +0 -43
- data/spec/ffi/struct_callback_spec.rb +0 -69
- data/spec/ffi/struct_initialize_spec.rb +0 -35
- data/spec/ffi/struct_packed_spec.rb +0 -50
- data/spec/ffi/struct_spec.rb +0 -882
- data/spec/ffi/typedef_spec.rb +0 -91
- data/spec/ffi/union_spec.rb +0 -67
- data/spec/ffi/variadic_spec.rb +0 -132
- data/spec/spec.opts +0 -4
@@ -1,473 +0,0 @@
|
|
1
|
-
# mmap(2) blacklisting. Some platforms provide the mmap library routine
|
2
|
-
# but don't support all of the features we need from it.
|
3
|
-
AC_DEFUN([AC_FUNC_MMAP_BLACKLIST],
|
4
|
-
[
|
5
|
-
AC_CHECK_HEADER([sys/mman.h],
|
6
|
-
[libffi_header_sys_mman_h=yes], [libffi_header_sys_mman_h=no])
|
7
|
-
AC_CHECK_FUNC([mmap], [libffi_func_mmap=yes], [libffi_func_mmap=no])
|
8
|
-
if test "$libffi_header_sys_mman_h" != yes \
|
9
|
-
|| test "$libffi_func_mmap" != yes; then
|
10
|
-
ac_cv_func_mmap_file=no
|
11
|
-
ac_cv_func_mmap_dev_zero=no
|
12
|
-
ac_cv_func_mmap_anon=no
|
13
|
-
else
|
14
|
-
AC_CACHE_CHECK([whether read-only mmap of a plain file works],
|
15
|
-
ac_cv_func_mmap_file,
|
16
|
-
[# Add a system to this blacklist if
|
17
|
-
# mmap(0, stat_size, PROT_READ, MAP_PRIVATE, fd, 0) doesn't return a
|
18
|
-
# memory area containing the same data that you'd get if you applied
|
19
|
-
# read() to the same fd. The only system known to have a problem here
|
20
|
-
# is VMS, where text files have record structure.
|
21
|
-
case "$host_os" in
|
22
|
-
vms* | ultrix*)
|
23
|
-
ac_cv_func_mmap_file=no ;;
|
24
|
-
*)
|
25
|
-
ac_cv_func_mmap_file=yes;;
|
26
|
-
esac])
|
27
|
-
AC_CACHE_CHECK([whether mmap from /dev/zero works],
|
28
|
-
ac_cv_func_mmap_dev_zero,
|
29
|
-
[# Add a system to this blacklist if it has mmap() but /dev/zero
|
30
|
-
# does not exist, or if mmapping /dev/zero does not give anonymous
|
31
|
-
# zeroed pages with both the following properties:
|
32
|
-
# 1. If you map N consecutive pages in with one call, and then
|
33
|
-
# unmap any subset of those pages, the pages that were not
|
34
|
-
# explicitly unmapped remain accessible.
|
35
|
-
# 2. If you map two adjacent blocks of memory and then unmap them
|
36
|
-
# both at once, they must both go away.
|
37
|
-
# Systems known to be in this category are Windows (all variants),
|
38
|
-
# VMS, and Darwin.
|
39
|
-
case "$host_os" in
|
40
|
-
vms* | cygwin* | pe | mingw* | darwin* | ultrix* | hpux10* | hpux11.00)
|
41
|
-
ac_cv_func_mmap_dev_zero=no ;;
|
42
|
-
*)
|
43
|
-
ac_cv_func_mmap_dev_zero=yes;;
|
44
|
-
esac])
|
45
|
-
|
46
|
-
# Unlike /dev/zero, the MAP_ANON(YMOUS) defines can be probed for.
|
47
|
-
AC_CACHE_CHECK([for MAP_ANON(YMOUS)], ac_cv_decl_map_anon,
|
48
|
-
[AC_TRY_COMPILE(
|
49
|
-
[#include <sys/types.h>
|
50
|
-
#include <sys/mman.h>
|
51
|
-
#include <unistd.h>
|
52
|
-
|
53
|
-
#ifndef MAP_ANONYMOUS
|
54
|
-
#define MAP_ANONYMOUS MAP_ANON
|
55
|
-
#endif
|
56
|
-
],
|
57
|
-
[int n = MAP_ANONYMOUS;],
|
58
|
-
ac_cv_decl_map_anon=yes,
|
59
|
-
ac_cv_decl_map_anon=no)])
|
60
|
-
|
61
|
-
if test $ac_cv_decl_map_anon = no; then
|
62
|
-
ac_cv_func_mmap_anon=no
|
63
|
-
else
|
64
|
-
AC_CACHE_CHECK([whether mmap with MAP_ANON(YMOUS) works],
|
65
|
-
ac_cv_func_mmap_anon,
|
66
|
-
[# Add a system to this blacklist if it has mmap() and MAP_ANON or
|
67
|
-
# MAP_ANONYMOUS, but using mmap(..., MAP_PRIVATE|MAP_ANONYMOUS, -1, 0)
|
68
|
-
# doesn't give anonymous zeroed pages with the same properties listed
|
69
|
-
# above for use of /dev/zero.
|
70
|
-
# Systems known to be in this category are Windows, VMS, and SCO Unix.
|
71
|
-
case "$host_os" in
|
72
|
-
vms* | cygwin* | pe | mingw* | sco* | udk* )
|
73
|
-
ac_cv_func_mmap_anon=no ;;
|
74
|
-
*)
|
75
|
-
ac_cv_func_mmap_anon=yes;;
|
76
|
-
esac])
|
77
|
-
fi
|
78
|
-
fi
|
79
|
-
|
80
|
-
if test $ac_cv_func_mmap_file = yes; then
|
81
|
-
AC_DEFINE(HAVE_MMAP_FILE, 1,
|
82
|
-
[Define if read-only mmap of a plain file works.])
|
83
|
-
fi
|
84
|
-
if test $ac_cv_func_mmap_dev_zero = yes; then
|
85
|
-
AC_DEFINE(HAVE_MMAP_DEV_ZERO, 1,
|
86
|
-
[Define if mmap of /dev/zero works.])
|
87
|
-
fi
|
88
|
-
if test $ac_cv_func_mmap_anon = yes; then
|
89
|
-
AC_DEFINE(HAVE_MMAP_ANON, 1,
|
90
|
-
[Define if mmap with MAP_ANON(YMOUS) works.])
|
91
|
-
fi
|
92
|
-
])
|
93
|
-
|
94
|
-
dnl ----------------------------------------------------------------------
|
95
|
-
dnl This whole bit snagged from libstdc++-v3, via libatomic.
|
96
|
-
|
97
|
-
dnl
|
98
|
-
dnl LIBFFI_ENABLE
|
99
|
-
dnl (FEATURE, DEFAULT, HELP-ARG, HELP-STRING)
|
100
|
-
dnl (FEATURE, DEFAULT, HELP-ARG, HELP-STRING, permit a|b|c)
|
101
|
-
dnl (FEATURE, DEFAULT, HELP-ARG, HELP-STRING, SHELL-CODE-HANDLER)
|
102
|
-
dnl
|
103
|
-
dnl See docs/html/17_intro/configury.html#enable for documentation.
|
104
|
-
dnl
|
105
|
-
m4_define([LIBFFI_ENABLE],[dnl
|
106
|
-
m4_define([_g_switch],[--enable-$1])dnl
|
107
|
-
m4_define([_g_help],[AC_HELP_STRING(_g_switch$3,[$4 @<:@default=$2@:>@])])dnl
|
108
|
-
AC_ARG_ENABLE($1,_g_help,
|
109
|
-
m4_bmatch([$5],
|
110
|
-
[^permit ],
|
111
|
-
[[
|
112
|
-
case "$enableval" in
|
113
|
-
m4_bpatsubst([$5],[permit ])) ;;
|
114
|
-
*) AC_MSG_ERROR(Unknown argument to enable/disable $1) ;;
|
115
|
-
dnl Idea for future: generate a URL pointing to
|
116
|
-
dnl "onlinedocs/configopts.html#whatever"
|
117
|
-
esac
|
118
|
-
]],
|
119
|
-
[^$],
|
120
|
-
[[
|
121
|
-
case "$enableval" in
|
122
|
-
yes|no) ;;
|
123
|
-
*) AC_MSG_ERROR(Argument to enable/disable $1 must be yes or no) ;;
|
124
|
-
esac
|
125
|
-
]],
|
126
|
-
[[$5]]),
|
127
|
-
[enable_]m4_bpatsubst([$1],-,_)[=][$2])
|
128
|
-
m4_undefine([_g_switch])dnl
|
129
|
-
m4_undefine([_g_help])dnl
|
130
|
-
])
|
131
|
-
|
132
|
-
dnl
|
133
|
-
dnl If GNU ld is in use, check to see if tricky linker opts can be used. If
|
134
|
-
dnl the native linker is in use, all variables will be defined to something
|
135
|
-
dnl safe (like an empty string).
|
136
|
-
dnl
|
137
|
-
dnl Defines:
|
138
|
-
dnl SECTION_LDFLAGS='-Wl,--gc-sections' if possible
|
139
|
-
dnl OPT_LDFLAGS='-Wl,-O1' if possible
|
140
|
-
dnl LD (as a side effect of testing)
|
141
|
-
dnl Sets:
|
142
|
-
dnl with_gnu_ld
|
143
|
-
dnl libat_ld_is_gold (possibly)
|
144
|
-
dnl libat_gnu_ld_version (possibly)
|
145
|
-
dnl
|
146
|
-
dnl The last will be a single integer, e.g., version 1.23.45.0.67.89 will
|
147
|
-
dnl set libat_gnu_ld_version to 12345. Zeros cause problems.
|
148
|
-
dnl
|
149
|
-
AC_DEFUN([LIBFFI_CHECK_LINKER_FEATURES], [
|
150
|
-
# If we're not using GNU ld, then there's no point in even trying these
|
151
|
-
# tests. Check for that first. We should have already tested for gld
|
152
|
-
# by now (in libtool), but require it now just to be safe...
|
153
|
-
test -z "$SECTION_LDFLAGS" && SECTION_LDFLAGS=''
|
154
|
-
test -z "$OPT_LDFLAGS" && OPT_LDFLAGS=''
|
155
|
-
AC_REQUIRE([AC_PROG_LD])
|
156
|
-
AC_REQUIRE([AC_PROG_AWK])
|
157
|
-
|
158
|
-
# The name set by libtool depends on the version of libtool. Shame on us
|
159
|
-
# for depending on an impl detail, but c'est la vie. Older versions used
|
160
|
-
# ac_cv_prog_gnu_ld, but now it's lt_cv_prog_gnu_ld, and is copied back on
|
161
|
-
# top of with_gnu_ld (which is also set by --with-gnu-ld, so that actually
|
162
|
-
# makes sense). We'll test with_gnu_ld everywhere else, so if that isn't
|
163
|
-
# set (hence we're using an older libtool), then set it.
|
164
|
-
if test x${with_gnu_ld+set} != xset; then
|
165
|
-
if test x${ac_cv_prog_gnu_ld+set} != xset; then
|
166
|
-
# We got through "ac_require(ac_prog_ld)" and still not set? Huh?
|
167
|
-
with_gnu_ld=no
|
168
|
-
else
|
169
|
-
with_gnu_ld=$ac_cv_prog_gnu_ld
|
170
|
-
fi
|
171
|
-
fi
|
172
|
-
|
173
|
-
# Start by getting the version number. I think the libtool test already
|
174
|
-
# does some of this, but throws away the result.
|
175
|
-
libat_ld_is_gold=no
|
176
|
-
if $LD --version 2>/dev/null | grep 'GNU gold'> /dev/null 2>&1; then
|
177
|
-
libat_ld_is_gold=yes
|
178
|
-
fi
|
179
|
-
changequote(,)
|
180
|
-
ldver=`$LD --version 2>/dev/null |
|
181
|
-
sed -e 's/GNU gold /GNU ld /;s/GNU ld version /GNU ld /;s/GNU ld ([^)]*) /GNU ld /;s/GNU ld \([0-9.][0-9.]*\).*/\1/; q'`
|
182
|
-
changequote([,])
|
183
|
-
libat_gnu_ld_version=`echo $ldver | \
|
184
|
-
$AWK -F. '{ if (NF<3) [$]3=0; print ([$]1*100+[$]2)*100+[$]3 }'`
|
185
|
-
|
186
|
-
# Set --gc-sections.
|
187
|
-
if test "$with_gnu_ld" = "notbroken"; then
|
188
|
-
# GNU ld it is! Joy and bunny rabbits!
|
189
|
-
|
190
|
-
# All these tests are for C++; save the language and the compiler flags.
|
191
|
-
# Need to do this so that g++ won't try to link in libstdc++
|
192
|
-
ac_test_CFLAGS="${CFLAGS+set}"
|
193
|
-
ac_save_CFLAGS="$CFLAGS"
|
194
|
-
CFLAGS='-x c++ -Wl,--gc-sections'
|
195
|
-
|
196
|
-
# Check for -Wl,--gc-sections
|
197
|
-
# XXX This test is broken at the moment, as symbols required for linking
|
198
|
-
# are now in libsupc++ (not built yet). In addition, this test has
|
199
|
-
# cored on solaris in the past. In addition, --gc-sections doesn't
|
200
|
-
# really work at the moment (keeps on discarding used sections, first
|
201
|
-
# .eh_frame and now some of the glibc sections for iconv).
|
202
|
-
# Bzzzzt. Thanks for playing, maybe next time.
|
203
|
-
AC_MSG_CHECKING([for ld that supports -Wl,--gc-sections])
|
204
|
-
AC_TRY_RUN([
|
205
|
-
int main(void)
|
206
|
-
{
|
207
|
-
try { throw 1; }
|
208
|
-
catch (...) { };
|
209
|
-
return 0;
|
210
|
-
}
|
211
|
-
], [ac_sectionLDflags=yes],[ac_sectionLDflags=no], [ac_sectionLDflags=yes])
|
212
|
-
if test "$ac_test_CFLAGS" = set; then
|
213
|
-
CFLAGS="$ac_save_CFLAGS"
|
214
|
-
else
|
215
|
-
# this is the suspicious part
|
216
|
-
CFLAGS=''
|
217
|
-
fi
|
218
|
-
if test "$ac_sectionLDflags" = "yes"; then
|
219
|
-
SECTION_LDFLAGS="-Wl,--gc-sections $SECTION_LDFLAGS"
|
220
|
-
fi
|
221
|
-
AC_MSG_RESULT($ac_sectionLDflags)
|
222
|
-
fi
|
223
|
-
|
224
|
-
# Set linker optimization flags.
|
225
|
-
if test x"$with_gnu_ld" = x"yes"; then
|
226
|
-
OPT_LDFLAGS="-Wl,-O1 $OPT_LDFLAGS"
|
227
|
-
fi
|
228
|
-
|
229
|
-
AC_SUBST(SECTION_LDFLAGS)
|
230
|
-
AC_SUBST(OPT_LDFLAGS)
|
231
|
-
])
|
232
|
-
|
233
|
-
|
234
|
-
dnl
|
235
|
-
dnl If GNU ld is in use, check to see if tricky linker opts can be used. If
|
236
|
-
dnl the native linker is in use, all variables will be defined to something
|
237
|
-
dnl safe (like an empty string).
|
238
|
-
dnl
|
239
|
-
dnl Defines:
|
240
|
-
dnl SECTION_LDFLAGS='-Wl,--gc-sections' if possible
|
241
|
-
dnl OPT_LDFLAGS='-Wl,-O1' if possible
|
242
|
-
dnl LD (as a side effect of testing)
|
243
|
-
dnl Sets:
|
244
|
-
dnl with_gnu_ld
|
245
|
-
dnl libat_ld_is_gold (possibly)
|
246
|
-
dnl libat_gnu_ld_version (possibly)
|
247
|
-
dnl
|
248
|
-
dnl The last will be a single integer, e.g., version 1.23.45.0.67.89 will
|
249
|
-
dnl set libat_gnu_ld_version to 12345. Zeros cause problems.
|
250
|
-
dnl
|
251
|
-
AC_DEFUN([LIBFFI_CHECK_LINKER_FEATURES], [
|
252
|
-
# If we're not using GNU ld, then there's no point in even trying these
|
253
|
-
# tests. Check for that first. We should have already tested for gld
|
254
|
-
# by now (in libtool), but require it now just to be safe...
|
255
|
-
test -z "$SECTION_LDFLAGS" && SECTION_LDFLAGS=''
|
256
|
-
test -z "$OPT_LDFLAGS" && OPT_LDFLAGS=''
|
257
|
-
AC_REQUIRE([AC_PROG_LD])
|
258
|
-
AC_REQUIRE([AC_PROG_AWK])
|
259
|
-
|
260
|
-
# The name set by libtool depends on the version of libtool. Shame on us
|
261
|
-
# for depending on an impl detail, but c'est la vie. Older versions used
|
262
|
-
# ac_cv_prog_gnu_ld, but now it's lt_cv_prog_gnu_ld, and is copied back on
|
263
|
-
# top of with_gnu_ld (which is also set by --with-gnu-ld, so that actually
|
264
|
-
# makes sense). We'll test with_gnu_ld everywhere else, so if that isn't
|
265
|
-
# set (hence we're using an older libtool), then set it.
|
266
|
-
if test x${with_gnu_ld+set} != xset; then
|
267
|
-
if test x${ac_cv_prog_gnu_ld+set} != xset; then
|
268
|
-
# We got through "ac_require(ac_prog_ld)" and still not set? Huh?
|
269
|
-
with_gnu_ld=no
|
270
|
-
else
|
271
|
-
with_gnu_ld=$ac_cv_prog_gnu_ld
|
272
|
-
fi
|
273
|
-
fi
|
274
|
-
|
275
|
-
# Start by getting the version number. I think the libtool test already
|
276
|
-
# does some of this, but throws away the result.
|
277
|
-
libat_ld_is_gold=no
|
278
|
-
if $LD --version 2>/dev/null | grep 'GNU gold'> /dev/null 2>&1; then
|
279
|
-
libat_ld_is_gold=yes
|
280
|
-
fi
|
281
|
-
changequote(,)
|
282
|
-
ldver=`$LD --version 2>/dev/null |
|
283
|
-
sed -e 's/GNU gold /GNU ld /;s/GNU ld version /GNU ld /;s/GNU ld ([^)]*) /GNU ld /;s/GNU ld \([0-9.][0-9.]*\).*/\1/; q'`
|
284
|
-
changequote([,])
|
285
|
-
libat_gnu_ld_version=`echo $ldver | \
|
286
|
-
$AWK -F. '{ if (NF<3) [$]3=0; print ([$]1*100+[$]2)*100+[$]3 }'`
|
287
|
-
|
288
|
-
# Set --gc-sections.
|
289
|
-
if test "$with_gnu_ld" = "notbroken"; then
|
290
|
-
# GNU ld it is! Joy and bunny rabbits!
|
291
|
-
|
292
|
-
# All these tests are for C++; save the language and the compiler flags.
|
293
|
-
# Need to do this so that g++ won't try to link in libstdc++
|
294
|
-
ac_test_CFLAGS="${CFLAGS+set}"
|
295
|
-
ac_save_CFLAGS="$CFLAGS"
|
296
|
-
CFLAGS='-x c++ -Wl,--gc-sections'
|
297
|
-
|
298
|
-
# Check for -Wl,--gc-sections
|
299
|
-
# XXX This test is broken at the moment, as symbols required for linking
|
300
|
-
# are now in libsupc++ (not built yet). In addition, this test has
|
301
|
-
# cored on solaris in the past. In addition, --gc-sections doesn't
|
302
|
-
# really work at the moment (keeps on discarding used sections, first
|
303
|
-
# .eh_frame and now some of the glibc sections for iconv).
|
304
|
-
# Bzzzzt. Thanks for playing, maybe next time.
|
305
|
-
AC_MSG_CHECKING([for ld that supports -Wl,--gc-sections])
|
306
|
-
AC_TRY_RUN([
|
307
|
-
int main(void)
|
308
|
-
{
|
309
|
-
try { throw 1; }
|
310
|
-
catch (...) { };
|
311
|
-
return 0;
|
312
|
-
}
|
313
|
-
], [ac_sectionLDflags=yes],[ac_sectionLDflags=no], [ac_sectionLDflags=yes])
|
314
|
-
if test "$ac_test_CFLAGS" = set; then
|
315
|
-
CFLAGS="$ac_save_CFLAGS"
|
316
|
-
else
|
317
|
-
# this is the suspicious part
|
318
|
-
CFLAGS=''
|
319
|
-
fi
|
320
|
-
if test "$ac_sectionLDflags" = "yes"; then
|
321
|
-
SECTION_LDFLAGS="-Wl,--gc-sections $SECTION_LDFLAGS"
|
322
|
-
fi
|
323
|
-
AC_MSG_RESULT($ac_sectionLDflags)
|
324
|
-
fi
|
325
|
-
|
326
|
-
# Set linker optimization flags.
|
327
|
-
if test x"$with_gnu_ld" = x"yes"; then
|
328
|
-
OPT_LDFLAGS="-Wl,-O1 $OPT_LDFLAGS"
|
329
|
-
fi
|
330
|
-
|
331
|
-
AC_SUBST(SECTION_LDFLAGS)
|
332
|
-
AC_SUBST(OPT_LDFLAGS)
|
333
|
-
])
|
334
|
-
|
335
|
-
|
336
|
-
dnl
|
337
|
-
dnl Add version tags to symbols in shared library (or not), additionally
|
338
|
-
dnl marking other symbols as private/local (or not).
|
339
|
-
dnl
|
340
|
-
dnl --enable-symvers=style adds a version script to the linker call when
|
341
|
-
dnl creating the shared library. The choice of version script is
|
342
|
-
dnl controlled by 'style'.
|
343
|
-
dnl --disable-symvers does not.
|
344
|
-
dnl + Usage: LIBFFI_ENABLE_SYMVERS[(DEFAULT)]
|
345
|
-
dnl Where DEFAULT is either 'yes' or 'no'. Passing `yes' tries to
|
346
|
-
dnl choose a default style based on linker characteristics. Passing
|
347
|
-
dnl 'no' disables versioning.
|
348
|
-
dnl
|
349
|
-
AC_DEFUN([LIBFFI_ENABLE_SYMVERS], [
|
350
|
-
|
351
|
-
LIBFFI_ENABLE(symvers,yes,[=STYLE],
|
352
|
-
[enables symbol versioning of the shared library],
|
353
|
-
[permit yes|no|gnu*|sun])
|
354
|
-
|
355
|
-
# If we never went through the LIBFFI_CHECK_LINKER_FEATURES macro, then we
|
356
|
-
# don't know enough about $LD to do tricks...
|
357
|
-
AC_REQUIRE([LIBFFI_CHECK_LINKER_FEATURES])
|
358
|
-
|
359
|
-
# Turn a 'yes' into a suitable default.
|
360
|
-
if test x$enable_symvers = xyes ; then
|
361
|
-
# FIXME The following test is too strict, in theory.
|
362
|
-
if test $enable_shared = no || test "x$LD" = x; then
|
363
|
-
enable_symvers=no
|
364
|
-
else
|
365
|
-
if test $with_gnu_ld = yes ; then
|
366
|
-
enable_symvers=gnu
|
367
|
-
else
|
368
|
-
case ${target_os} in
|
369
|
-
# Sun symbol versioning exists since Solaris 2.5.
|
370
|
-
solaris2.[[5-9]]* | solaris2.1[[0-9]]*)
|
371
|
-
enable_symvers=sun ;;
|
372
|
-
*)
|
373
|
-
enable_symvers=no ;;
|
374
|
-
esac
|
375
|
-
fi
|
376
|
-
fi
|
377
|
-
fi
|
378
|
-
|
379
|
-
# Check if 'sun' was requested on non-Solaris 2 platforms.
|
380
|
-
if test x$enable_symvers = xsun ; then
|
381
|
-
case ${target_os} in
|
382
|
-
solaris2*)
|
383
|
-
# All fine.
|
384
|
-
;;
|
385
|
-
*)
|
386
|
-
# Unlikely to work.
|
387
|
-
AC_MSG_WARN([=== You have requested Sun symbol versioning, but])
|
388
|
-
AC_MSG_WARN([=== you are not targetting Solaris 2.])
|
389
|
-
AC_MSG_WARN([=== Symbol versioning will be disabled.])
|
390
|
-
enable_symvers=no
|
391
|
-
;;
|
392
|
-
esac
|
393
|
-
fi
|
394
|
-
|
395
|
-
# Check to see if libgcc_s exists, indicating that shared libgcc is possible.
|
396
|
-
if test $enable_symvers != no; then
|
397
|
-
AC_MSG_CHECKING([for shared libgcc])
|
398
|
-
ac_save_CFLAGS="$CFLAGS"
|
399
|
-
CFLAGS=' -lgcc_s'
|
400
|
-
AC_TRY_LINK(, [return 0;], libat_shared_libgcc=yes, libat_shared_libgcc=no)
|
401
|
-
CFLAGS="$ac_save_CFLAGS"
|
402
|
-
if test $libat_shared_libgcc = no; then
|
403
|
-
cat > conftest.c <<EOF
|
404
|
-
int main (void) { return 0; }
|
405
|
-
EOF
|
406
|
-
changequote(,)dnl
|
407
|
-
libat_libgcc_s_suffix=`${CC-cc} $CFLAGS $CPPFLAGS $LDFLAGS \
|
408
|
-
-shared -shared-libgcc -o conftest.so \
|
409
|
-
conftest.c -v 2>&1 >/dev/null \
|
410
|
-
| sed -n 's/^.* -lgcc_s\([^ ]*\) .*$/\1/p'`
|
411
|
-
changequote([,])dnl
|
412
|
-
rm -f conftest.c conftest.so
|
413
|
-
if test x${libat_libgcc_s_suffix+set} = xset; then
|
414
|
-
CFLAGS=" -lgcc_s$libat_libgcc_s_suffix"
|
415
|
-
AC_TRY_LINK(, [return 0;], libat_shared_libgcc=yes)
|
416
|
-
CFLAGS="$ac_save_CFLAGS"
|
417
|
-
fi
|
418
|
-
fi
|
419
|
-
AC_MSG_RESULT($libat_shared_libgcc)
|
420
|
-
fi
|
421
|
-
|
422
|
-
# For GNU ld, we need at least this version. The format is described in
|
423
|
-
# LIBFFI_CHECK_LINKER_FEATURES above.
|
424
|
-
libat_min_gnu_ld_version=21400
|
425
|
-
# XXXXXXXXXXX libat_gnu_ld_version=21390
|
426
|
-
|
427
|
-
# Check to see if unspecified "yes" value can win, given results above.
|
428
|
-
# Change "yes" into either "no" or a style name.
|
429
|
-
if test $enable_symvers != no && test $libat_shared_libgcc = yes; then
|
430
|
-
if test $with_gnu_ld = yes; then
|
431
|
-
if test $libat_gnu_ld_version -ge $libat_min_gnu_ld_version ; then
|
432
|
-
enable_symvers=gnu
|
433
|
-
elif test $libat_ld_is_gold = yes ; then
|
434
|
-
enable_symvers=gnu
|
435
|
-
else
|
436
|
-
# The right tools, the right setup, but too old. Fallbacks?
|
437
|
-
AC_MSG_WARN(=== Linker version $libat_gnu_ld_version is too old for)
|
438
|
-
AC_MSG_WARN(=== full symbol versioning support in this release of GCC.)
|
439
|
-
AC_MSG_WARN(=== You would need to upgrade your binutils to version)
|
440
|
-
AC_MSG_WARN(=== $libat_min_gnu_ld_version or later and rebuild GCC.)
|
441
|
-
if test $libat_gnu_ld_version -ge 21200 ; then
|
442
|
-
# Globbing fix is present, proper block support is not.
|
443
|
-
dnl AC_MSG_WARN([=== Dude, you are soooo close. Maybe we can fake it.])
|
444
|
-
dnl enable_symvers=???
|
445
|
-
AC_MSG_WARN([=== Symbol versioning will be disabled.])
|
446
|
-
enable_symvers=no
|
447
|
-
else
|
448
|
-
# 2.11 or older.
|
449
|
-
AC_MSG_WARN([=== Symbol versioning will be disabled.])
|
450
|
-
enable_symvers=no
|
451
|
-
fi
|
452
|
-
fi
|
453
|
-
elif test $enable_symvers = sun; then
|
454
|
-
: All interesting versions of Sun ld support sun style symbol versioning.
|
455
|
-
else
|
456
|
-
# just fail for now
|
457
|
-
AC_MSG_WARN([=== You have requested some kind of symbol versioning, but])
|
458
|
-
AC_MSG_WARN([=== either you are not using a supported linker, or you are])
|
459
|
-
AC_MSG_WARN([=== not building a shared libgcc_s (which is required).])
|
460
|
-
AC_MSG_WARN([=== Symbol versioning will be disabled.])
|
461
|
-
enable_symvers=no
|
462
|
-
fi
|
463
|
-
fi
|
464
|
-
if test $enable_symvers = gnu; then
|
465
|
-
AC_DEFINE(LIBFFI_GNU_SYMBOL_VERSIONING, 1,
|
466
|
-
[Define to 1 if GNU symbol versioning is used for libatomic.])
|
467
|
-
fi
|
468
|
-
|
469
|
-
AM_CONDITIONAL(LIBFFI_BUILD_VERSIONED_SHLIB, test $enable_symvers != no)
|
470
|
-
AM_CONDITIONAL(LIBFFI_BUILD_VERSIONED_SHLIB_GNU, test $enable_symvers = gnu)
|
471
|
-
AM_CONDITIONAL(LIBFFI_BUILD_VERSIONED_SHLIB_SUN, test $enable_symvers = sun)
|
472
|
-
AC_MSG_NOTICE(versioning on shared library symbols is $enable_symvers)
|
473
|
-
])
|