ffi 1.11.1 → 1.11.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/{appveyor.yml → .appveyor.yml} +1 -1
- data/.gitmodules +2 -2
- data/CHANGELOG.md +16 -0
- data/Rakefile +1 -0
- data/ext/ffi_c/Call.c +3 -3
- data/ext/ffi_c/Call.h +2 -2
- data/ext/ffi_c/Function.c +4 -4
- data/ext/ffi_c/LongDouble.c +7 -7
- data/ext/ffi_c/libffi.darwin.mk +1 -1
- data/ext/ffi_c/libffi/.appveyor.yml +29 -13
- data/ext/ffi_c/libffi/.gitattributes +4 -0
- data/ext/ffi_c/libffi/.travis.yml +31 -2
- data/ext/ffi_c/libffi/.travis/build-in-container.sh +22 -0
- data/ext/ffi_c/libffi/.travis/build.sh +83 -7
- data/ext/ffi_c/libffi/.travis/install.sh +32 -11
- data/ext/ffi_c/libffi/LICENSE +1 -1
- data/ext/ffi_c/libffi/LICENSE-BUILDTOOLS +5 -4
- data/ext/ffi_c/libffi/Makefile.am +30 -38
- data/ext/ffi_c/libffi/README.md +15 -6
- data/ext/ffi_c/libffi/configure.ac +1 -1
- data/ext/ffi_c/libffi/configure.host +21 -7
- data/ext/ffi_c/libffi/include/ffi.h.in +4 -0
- data/ext/ffi_c/libffi/include/ffi_common.h +4 -0
- data/ext/ffi_c/libffi/m4/asmcfi.m4 +1 -1
- data/ext/ffi_c/libffi/make_sunver.pl +333 -0
- 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/msvcc.sh +27 -2
- data/ext/ffi_c/libffi/src/aarch64/ffi.c +124 -56
- data/ext/ffi_c/libffi/src/aarch64/ffitarget.h +13 -2
- data/ext/ffi_c/libffi/src/aarch64/sysv.S +8 -6
- data/ext/ffi_c/libffi/src/aarch64/win64_armasm.S +506 -0
- data/ext/ffi_c/libffi/src/arm/ffi.c +40 -5
- data/ext/ffi_c/libffi/src/arm/ffitarget.h +8 -1
- data/ext/ffi_c/libffi/src/arm/sysv.S +2 -0
- data/ext/ffi_c/libffi/src/arm/sysv_msvc_arm32.S +311 -0
- data/ext/ffi_c/libffi/src/closures.c +32 -8
- data/ext/ffi_c/libffi/src/pa/linux.S +23 -2
- data/ext/ffi_c/libffi/src/powerpc/ffi.c +3 -2
- data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +58 -25
- data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +1 -1
- data/ext/ffi_c/libffi/src/prep_cif.c +4 -2
- data/ext/ffi_c/libffi/src/x86/ffi.c +13 -6
- data/ext/ffi_c/libffi/src/x86/ffi64.c +5 -3
- data/ext/ffi_c/libffi/src/x86/ffiw64.c +6 -3
- data/ext/ffi_c/libffi/src/x86/sysv.S +2 -2
- data/ext/ffi_c/libffi/src/x86/sysv_intel.S +995 -0
- data/ext/ffi_c/libffi/src/x86/win64.S +5 -0
- data/ext/ffi_c/libffi/testsuite/Makefile.am +111 -109
- data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +26 -5
- data/ext/ffi_c/libffi/testsuite/libffi.call/float2.c +9 -8
- data/ext/ffi_c/libffi/testsuite/libffi.call/va_1.c +1 -1
- data/ffi.gemspec +1 -1
- data/lib/ffi/library.rb +5 -5
- data/lib/ffi/platform.rb +4 -1
- data/lib/ffi/platform/aarch64-freebsd/types.conf +89 -89
- data/lib/ffi/platform/aarch64-freebsd12/types.conf +89 -89
- data/lib/ffi/platform/aarch64-linux/types.conf +81 -81
- data/lib/ffi/platform/arm-freebsd/types.conf +87 -87
- data/lib/ffi/platform/arm-freebsd12/types.conf +87 -87
- data/lib/ffi/platform/arm-linux/types.conf +79 -79
- 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 +87 -87
- data/lib/ffi/platform/i386-freebsd12/types.conf +87 -87
- 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 +84 -84
- data/lib/ffi/platform/ia64-linux/types.conf +79 -79
- 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 +77 -77
- data/lib/ffi/platform/powerpc64-linux/types.conf +81 -81
- 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/sparc64-linux/types.conf +79 -79
- data/lib/ffi/platform/sparcv9-solaris/types.conf +103 -103
- data/lib/ffi/platform/x86_64-cygwin/types.conf +1 -1
- data/lib/ffi/platform/x86_64-darwin/types.conf +84 -84
- data/lib/ffi/platform/x86_64-dragonflybsd/types.conf +148 -0
- data/lib/ffi/platform/x86_64-freebsd/types.conf +89 -89
- data/lib/ffi/platform/x86_64-freebsd12/types.conf +139 -109
- data/lib/ffi/platform/x86_64-linux/types.conf +86 -77
- 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 +99 -99
- data/lib/ffi/tools/types_generator.rb +5 -4
- data/lib/ffi/version.rb +1 -1
- metadata +19 -5
@@ -1,3 +1,4 @@
|
|
1
|
+
#ifdef __x86_64__
|
1
2
|
#define LIBFFI_ASM
|
2
3
|
#include <fficonfig.h>
|
3
4
|
#include <ffi.h>
|
@@ -42,6 +43,7 @@
|
|
42
43
|
|
43
44
|
.align 8
|
44
45
|
.globl C(ffi_call_win64)
|
46
|
+
FFI_HIDDEN(C(ffi_call_win64))
|
45
47
|
|
46
48
|
SEH(.seh_proc ffi_call_win64)
|
47
49
|
C(ffi_call_win64):
|
@@ -169,6 +171,7 @@ E(0b, FFI_TYPE_SMALL_STRUCT_4B)
|
|
169
171
|
|
170
172
|
.align 8
|
171
173
|
.globl C(ffi_go_closure_win64)
|
174
|
+
FFI_HIDDEN(C(ffi_go_closure_win64))
|
172
175
|
|
173
176
|
SEH(.seh_proc ffi_go_closure_win64)
|
174
177
|
C(ffi_go_closure_win64):
|
@@ -188,6 +191,7 @@ C(ffi_go_closure_win64):
|
|
188
191
|
|
189
192
|
.align 8
|
190
193
|
.globl C(ffi_closure_win64)
|
194
|
+
FFI_HIDDEN(C(ffi_closure_win64))
|
191
195
|
|
192
196
|
SEH(.seh_proc ffi_closure_win64)
|
193
197
|
C(ffi_closure_win64):
|
@@ -226,6 +230,7 @@ C(ffi_closure_win64):
|
|
226
230
|
|
227
231
|
cfi_endproc
|
228
232
|
SEH(.seh_endproc)
|
233
|
+
#endif /* __x86_64__ */
|
229
234
|
|
230
235
|
#if defined __ELF__ && defined __linux__
|
231
236
|
.section .note.GNU-stack,"",@progbits
|
@@ -6,112 +6,114 @@ EXTRA_DEJAGNU_SITE_CONFIG=../local.exp
|
|
6
6
|
|
7
7
|
CLEANFILES = *.exe core* *.log *.sum
|
8
8
|
|
9
|
-
EXTRA_DIST = lib/target-libpath.exp lib/libffi.exp lib/wrapper.exp
|
10
|
-
libffi.call/strlen4.c libffi.call/cls_multi_sshort.c
|
11
|
-
libffi.call/cls_align_longdouble_split2.c libffi.call/cls_1_1byte.c
|
12
|
-
libffi.call/struct10.c libffi.call/cls_uint_va.c
|
13
|
-
libffi.call/many_mixed.c libffi.call/float.c libffi.call/struct5.c
|
14
|
-
libffi.call/return_fl3.c libffi.call/cls_3_1byte.c
|
15
|
-
libffi.call/return_fl1.c libffi.call/cls_many_mixed_args.c
|
16
|
-
libffi.call/cls_20byte1.c libffi.call/cls_pointer_stack.c
|
17
|
-
libffi.call/cls_align_float.c libffi.call/call.exp
|
18
|
-
libffi.call/pyobjc-tc.c libffi.call/float_va.c
|
19
|
-
libffi.call/cls_5_1_byte.c libffi.call/cls_9byte1.c
|
20
|
-
libffi.call/cls_align_uint32.c libffi.call/stret_medium.c
|
21
|
-
libffi.call/cls_3byte1.c libffi.call/cls_align_uint64.c
|
22
|
-
libffi.call/cls_longdouble_va.c libffi.call/cls_align_pointer.c
|
23
|
-
libffi.call/cls_19byte.c libffi.call/cls_ushort.c
|
24
|
-
libffi.call/cls_align_sint32.c libffi.call/struct8.c
|
25
|
-
libffi.call/pr1172638.c libffi.call/cls_ulonglong.c
|
26
|
-
libffi.call/cls_struct_va1.c libffi.call/cls_9byte2.c
|
27
|
-
libffi.call/closure_fn5.c libffi.call/cls_5byte.c
|
28
|
-
libffi.call/cls_3float.c libffi.call/return_sc.c
|
29
|
-
libffi.call/cls_schar.c libffi.call/closure_fn4.c
|
30
|
-
libffi.call/cls_uchar_va.c libffi.call/closure_fn0.c
|
31
|
-
libffi.call/huge_struct.c libffi.call/va_struct1.c
|
32
|
-
libffi.call/cls_ushort_va.c libffi.call/struct9.c libffi.call/va_1.c
|
33
|
-
libffi.call/cls_64byte.c libffi.call/va_struct2.c
|
34
|
-
libffi.call/cls_longdouble.c libffi.call/return_fl2.c
|
35
|
-
libffi.call/cls_ulong_va.c libffi.call/cls_6_1_byte.c
|
36
|
-
libffi.call/cls_align_uint16.c libffi.call/closure_fn2.c
|
37
|
-
libffi.call/align_mixed.c libffi.call/unwindtest_ffi_call.cc
|
38
|
-
libffi.call/cls_multi_ushortchar.c libffi.call/cls_8byte.c
|
39
|
-
libffi.call/ffitest.h libffi.call/nested_struct8.c
|
40
|
-
libffi.call/cls_pointer.c libffi.call/nested_struct2.c
|
41
|
-
libffi.call/nested_struct.c libffi.call/struct4.c
|
42
|
-
libffi.call/cls_multi_schar.c
|
43
|
-
libffi.call/
|
44
|
-
libffi.call/
|
45
|
-
libffi.call/
|
46
|
-
libffi.call/
|
47
|
-
libffi.call/
|
48
|
-
libffi.call/
|
49
|
-
libffi.call/
|
50
|
-
libffi.call/
|
51
|
-
libffi.call/
|
52
|
-
libffi.call/
|
53
|
-
libffi.call/
|
54
|
-
libffi.call/
|
55
|
-
libffi.call/
|
56
|
-
libffi.call/
|
57
|
-
libffi.call/
|
58
|
-
libffi.call/
|
59
|
-
libffi.call/
|
60
|
-
libffi.call/
|
61
|
-
libffi.call/
|
62
|
-
libffi.call/
|
63
|
-
libffi.call/
|
64
|
-
libffi.call/
|
65
|
-
libffi.call/
|
66
|
-
libffi.call/
|
67
|
-
libffi.call/
|
68
|
-
libffi.call/
|
69
|
-
libffi.call/
|
70
|
-
libffi.call/
|
71
|
-
libffi.call/
|
72
|
-
libffi.call/
|
73
|
-
libffi.call/
|
74
|
-
libffi.call/
|
75
|
-
libffi.call/
|
76
|
-
libffi.call/
|
77
|
-
libffi.call/
|
78
|
-
libffi.call/
|
79
|
-
libffi.call/
|
80
|
-
libffi.
|
81
|
-
libffi.complex/
|
82
|
-
libffi.complex/
|
83
|
-
libffi.complex/
|
84
|
-
libffi.complex/
|
85
|
-
libffi.complex/
|
86
|
-
libffi.complex/
|
87
|
-
libffi.complex/
|
88
|
-
libffi.complex/
|
89
|
-
libffi.complex/
|
90
|
-
libffi.complex/
|
91
|
-
libffi.complex/
|
92
|
-
libffi.complex/
|
93
|
-
libffi.complex/
|
94
|
-
libffi.complex/
|
95
|
-
libffi.complex/
|
96
|
-
libffi.complex/
|
97
|
-
libffi.complex/
|
98
|
-
libffi.complex/
|
99
|
-
libffi.complex/
|
100
|
-
libffi.complex/
|
101
|
-
libffi.complex/
|
102
|
-
libffi.complex/
|
103
|
-
libffi.complex/
|
104
|
-
libffi.complex/
|
105
|
-
libffi.complex/
|
106
|
-
libffi.complex/
|
107
|
-
libffi.complex/
|
108
|
-
libffi.complex/
|
109
|
-
libffi.complex/
|
110
|
-
libffi.complex/
|
111
|
-
libffi.complex/
|
112
|
-
libffi.complex/
|
113
|
-
libffi.
|
114
|
-
libffi.
|
115
|
-
libffi.
|
116
|
-
libffi.
|
117
|
-
libffi.bhaible/
|
9
|
+
EXTRA_DIST = lib/target-libpath.exp lib/libffi.exp lib/wrapper.exp \
|
10
|
+
libffi.call/strlen4.c libffi.call/cls_multi_sshort.c \
|
11
|
+
libffi.call/cls_align_longdouble_split2.c libffi.call/cls_1_1byte.c \
|
12
|
+
libffi.call/struct10.c libffi.call/cls_uint_va.c \
|
13
|
+
libffi.call/many_mixed.c libffi.call/float.c libffi.call/struct5.c \
|
14
|
+
libffi.call/return_fl3.c libffi.call/cls_3_1byte.c \
|
15
|
+
libffi.call/return_fl1.c libffi.call/cls_many_mixed_args.c \
|
16
|
+
libffi.call/cls_20byte1.c libffi.call/cls_pointer_stack.c \
|
17
|
+
libffi.call/cls_align_float.c libffi.call/call.exp \
|
18
|
+
libffi.call/pyobjc-tc.c libffi.call/float_va.c \
|
19
|
+
libffi.call/cls_5_1_byte.c libffi.call/cls_9byte1.c \
|
20
|
+
libffi.call/cls_align_uint32.c libffi.call/stret_medium.c \
|
21
|
+
libffi.call/cls_3byte1.c libffi.call/cls_align_uint64.c \
|
22
|
+
libffi.call/cls_longdouble_va.c libffi.call/cls_align_pointer.c \
|
23
|
+
libffi.call/cls_19byte.c libffi.call/cls_ushort.c \
|
24
|
+
libffi.call/cls_align_sint32.c libffi.call/struct8.c \
|
25
|
+
libffi.call/pr1172638.c libffi.call/cls_ulonglong.c \
|
26
|
+
libffi.call/cls_struct_va1.c libffi.call/cls_9byte2.c \
|
27
|
+
libffi.call/closure_fn5.c libffi.call/cls_5byte.c \
|
28
|
+
libffi.call/cls_3float.c libffi.call/return_sc.c \
|
29
|
+
libffi.call/cls_schar.c libffi.call/closure_fn4.c \
|
30
|
+
libffi.call/cls_uchar_va.c libffi.call/closure_fn0.c \
|
31
|
+
libffi.call/huge_struct.c libffi.call/va_struct1.c \
|
32
|
+
libffi.call/cls_ushort_va.c libffi.call/struct9.c libffi.call/va_1.c \
|
33
|
+
libffi.call/cls_64byte.c libffi.call/va_struct2.c \
|
34
|
+
libffi.call/cls_longdouble.c libffi.call/return_fl2.c \
|
35
|
+
libffi.call/cls_ulong_va.c libffi.call/cls_6_1_byte.c \
|
36
|
+
libffi.call/cls_align_uint16.c libffi.call/closure_fn2.c \
|
37
|
+
libffi.call/align_mixed.c libffi.call/unwindtest_ffi_call.cc \
|
38
|
+
libffi.call/cls_multi_ushortchar.c libffi.call/cls_8byte.c \
|
39
|
+
libffi.call/ffitest.h libffi.call/nested_struct8.c \
|
40
|
+
libffi.call/cls_pointer.c libffi.call/nested_struct2.c \
|
41
|
+
libffi.call/nested_struct.c libffi.call/struct4.c \
|
42
|
+
libffi.call/cls_multi_schar.c \
|
43
|
+
libffi.call/cls_align_longdouble_split.c libffi.call/cls_uchar.c \
|
44
|
+
libffi.call/return_ldl.c libffi.call/nested_struct9.c \
|
45
|
+
libffi.call/cls_float.c libffi.call/stret_medium2.c \
|
46
|
+
libffi.call/closure_loc_fn0.c libffi.call/float3.c \
|
47
|
+
libffi.call/cls_6byte.c libffi.call/return_sl.c \
|
48
|
+
libffi.call/closure_simple.c libffi.call/return_dbl1.c \
|
49
|
+
libffi.call/cls_align_double.c libffi.call/cls_multi_uchar.c \
|
50
|
+
libffi.call/err_bad_typedef.c libffi.call/cls_4_1byte.c \
|
51
|
+
libffi.call/closure_fn3.c libffi.call/return_ll1.c \
|
52
|
+
libffi.call/return_dbl2.c libffi.call/cls_align_sint64.c \
|
53
|
+
libffi.call/nested_struct1.c libffi.call/negint.c \
|
54
|
+
libffi.call/nested_struct3.c libffi.call/unwindtest.cc \
|
55
|
+
libffi.call/struct2.c libffi.call/struct3.c libffi.call/return_fl.c \
|
56
|
+
libffi.call/nested_struct5.c libffi.call/cls_multi_ushort.c \
|
57
|
+
libffi.call/nested_struct11.c libffi.call/cls_multi_sshortchar.c \
|
58
|
+
libffi.call/cls_align_longdouble.c libffi.call/cls_dbls_struct.c \
|
59
|
+
libffi.call/cls_many_mixed_float_double.c libffi.call/stret_large.c \
|
60
|
+
libffi.call/stret_large2.c libffi.call/cls_align_sint16.c \
|
61
|
+
libffi.call/cls_2byte.c libffi.call/offsets.c libffi.call/struct7.c \
|
62
|
+
libffi.call/nested_struct4.c libffi.call/problem1.c \
|
63
|
+
libffi.call/va_struct3.c libffi.call/testclosure.c \
|
64
|
+
libffi.call/float1.c libffi.call/nested_struct6.c \
|
65
|
+
libffi.call/cls_4byte.c libffi.call/cls_24byte.c \
|
66
|
+
libffi.call/uninitialized.c libffi.call/many2.c \
|
67
|
+
libffi.call/nested_struct10.c libffi.call/struct6.c \
|
68
|
+
libffi.call/strlen2.c libffi.call/float2.c libffi.call/cls_uint.c \
|
69
|
+
libffi.call/cls_12byte.c libffi.call/return_ul.c \
|
70
|
+
libffi.call/cls_sint.c libffi.call/cls_7_1_byte.c \
|
71
|
+
libffi.call/struct1.c libffi.call/cls_sshort.c \
|
72
|
+
libffi.call/cls_16byte.c libffi.call/strlen3.c \
|
73
|
+
libffi.call/nested_struct7.c libffi.call/cls_double_va.c \
|
74
|
+
libffi.call/return_dbl.c libffi.call/cls_3byte2.c \
|
75
|
+
libffi.call/float4.c libffi.call/cls_double.c libffi.call/many.c \
|
76
|
+
libffi.call/cls_7byte.c libffi.call/strlen.c \
|
77
|
+
libffi.call/closure_fn6.c libffi.call/return_uc.c \
|
78
|
+
libffi.call/closure_fn1.c libffi.call/cls_20byte.c \
|
79
|
+
libffi.call/cls_18byte.c libffi.call/err_bad_abi.c \
|
80
|
+
libffi.call/many_double.c libffi.call/return_ll.c \
|
81
|
+
libffi.call/promotion.c libffi.complex/complex_defs_longdouble.inc \
|
82
|
+
libffi.call/align_stdcall.c libffi.complex/cls_align_complex_float.c \
|
83
|
+
libffi.complex/cls_complex_va_float.c \
|
84
|
+
libffi.complex/cls_complex_struct_float.c \
|
85
|
+
libffi.complex/return_complex2_longdouble.c \
|
86
|
+
libffi.complex/cls_complex_float.c \
|
87
|
+
libffi.complex/return_complex_longdouble.c \
|
88
|
+
libffi.complex/return_complex2_float.c libffi.complex/cls_complex.inc \
|
89
|
+
libffi.complex/cls_complex_va_longdouble.c \
|
90
|
+
libffi.complex/return_complex_double.c \
|
91
|
+
libffi.complex/return_complex.inc libffi.complex/many_complex.inc \
|
92
|
+
libffi.complex/complex_float.c libffi.complex/cls_align_complex.inc \
|
93
|
+
libffi.complex/return_complex2_double.c \
|
94
|
+
libffi.complex/many_complex_float.c libffi.complex/ffitest.h \
|
95
|
+
libffi.complex/return_complex1_double.c \
|
96
|
+
libffi.complex/cls_complex_struct_longdouble.c \
|
97
|
+
libffi.complex/complex_defs_double.inc \
|
98
|
+
libffi.complex/cls_complex_va_double.c \
|
99
|
+
libffi.complex/many_complex_double.c \
|
100
|
+
libffi.complex/return_complex2.inc \
|
101
|
+
libffi.complex/return_complex1_float.c \
|
102
|
+
libffi.complex/complex_longdouble.c \
|
103
|
+
libffi.complex/complex_defs_float.inc \
|
104
|
+
libffi.complex/cls_complex_double.c \
|
105
|
+
libffi.complex/cls_align_complex_double.c \
|
106
|
+
libffi.complex/cls_align_complex_longdouble.c \
|
107
|
+
libffi.complex/complex_double.c libffi.complex/cls_complex_va.inc \
|
108
|
+
libffi.complex/many_complex_longdouble.c libffi.complex/complex.inc \
|
109
|
+
libffi.complex/return_complex1_longdouble.c \
|
110
|
+
libffi.complex/complex_int.c libffi.complex/cls_complex_longdouble.c \
|
111
|
+
libffi.complex/cls_complex_struct_double.c \
|
112
|
+
libffi.complex/return_complex1.inc libffi.complex/complex.exp \
|
113
|
+
libffi.complex/cls_complex_struct.inc \
|
114
|
+
libffi.complex/return_complex_float.c libffi.go/closure1.c \
|
115
|
+
libffi.go/aa-direct.c libffi.go/ffitest.h libffi.go/go.exp \
|
116
|
+
libffi.go/static-chain.h libffi.bhaible/bhaible.exp \
|
117
|
+
libffi.bhaible/test-call.c libffi.bhaible/alignof.h \
|
118
|
+
libffi.bhaible/testcases.c libffi.bhaible/test-callback.c \
|
119
|
+
libffi.bhaible/Makefile libffi.bhaible/README config/default.exp
|
@@ -1,4 +1,4 @@
|
|
1
|
-
# Copyright (C) 2003, 2005, 2008, 2009, 2010, 2011, 2014 Free Software Foundation, Inc.
|
1
|
+
# Copyright (C) 2003, 2005, 2008, 2009, 2010, 2011, 2014, 2019 Free Software Foundation, Inc.
|
2
2
|
|
3
3
|
# This program is free software; you can redistribute it and/or modify
|
4
4
|
# it under the terms of the GNU General Public License as published by
|
@@ -266,6 +266,12 @@ proc libffi-dg-test { prog do_what extra_tool_flags } {
|
|
266
266
|
return [libffi-dg-test-1 target_compile $prog $do_what $extra_tool_flags]
|
267
267
|
}
|
268
268
|
|
269
|
+
proc libffi-dg-prune { target_triplet text } {
|
270
|
+
# We get this with some qemu emulated systems (eg. ppc64le-linux-gnu)
|
271
|
+
regsub -all "(^|\n)\[^\n\]*unable to perform all requested operations" $text "" text
|
272
|
+
return $text
|
273
|
+
}
|
274
|
+
|
269
275
|
proc libffi-init { args } {
|
270
276
|
global gluefile wrap_flags;
|
271
277
|
global srcdir
|
@@ -477,22 +483,37 @@ proc libffi-dg-runtest { testcases default-extra-flags } {
|
|
477
483
|
proc run-many-tests { testcases extra_flags } {
|
478
484
|
global compiler_vendor
|
479
485
|
global has_gccbug
|
486
|
+
global env
|
480
487
|
switch $compiler_vendor {
|
481
488
|
"clang" {
|
482
|
-
|
483
|
-
|
489
|
+
set common "-W -Wall"
|
490
|
+
if [info exists env(LIBFFI_TEST_OPTIMIZATION)] {
|
491
|
+
set optimizations [ list $env(LIBFFI_TEST_OPTIMIZATION) ]
|
492
|
+
} else {
|
493
|
+
set optimizations { "-O0" "-O2" }
|
494
|
+
}
|
484
495
|
}
|
485
496
|
"gnu" {
|
486
497
|
set common "-W -Wall -Wno-psabi"
|
487
|
-
|
498
|
+
if [info exists env(LIBFFI_TEST_OPTIMIZATION)] {
|
499
|
+
set optimizations [ list $env(LIBFFI_TEST_OPTIMIZATION) ]
|
500
|
+
} else {
|
501
|
+
set optimizations { "-O0" "-O2" "-O2 -fomit-frame-pointer" }
|
502
|
+
}
|
488
503
|
}
|
489
504
|
default {
|
490
505
|
# Assume we are using the vendor compiler.
|
491
506
|
set common ""
|
492
|
-
|
507
|
+
if [info exists env(LIBFFI_TEST_OPTIMIZATION)] {
|
508
|
+
set optimizations [ list $env(LIBFFI_TEST_OPTIMIZATION) ]
|
509
|
+
} else {
|
510
|
+
set optimizations { "" }
|
511
|
+
}
|
493
512
|
}
|
494
513
|
}
|
495
514
|
|
515
|
+
info exists env(LD_LIBRARY_PATH)
|
516
|
+
|
496
517
|
set targetabis { "" }
|
497
518
|
if [string match $compiler_vendor "gnu"] {
|
498
519
|
if [libffi_feature_test "#ifdef __i386__"] {
|
@@ -33,19 +33,20 @@ int main (void)
|
|
33
33
|
|
34
34
|
f = 3.14159;
|
35
35
|
|
36
|
-
#if
|
37
|
-
/*
|
38
|
-
|
39
|
-
|
36
|
+
#if defined(__sun) && defined(__GNUC__)
|
37
|
+
/* long double support under SunOS/gcc is pretty much non-existent.
|
38
|
+
You'll get the odd bus error in library routines like printf() */
|
39
|
+
#else
|
40
40
|
printf ("%Lf\n", ldblit(f));
|
41
41
|
#endif
|
42
|
+
|
42
43
|
ld = 666;
|
43
44
|
ffi_call(&cif, FFI_FN(ldblit), &ld, values);
|
44
45
|
|
45
|
-
#if
|
46
|
-
/*
|
47
|
-
|
48
|
-
|
46
|
+
#if defined(__sun) && defined(__GNUC__)
|
47
|
+
/* long double support under SunOS/gcc is pretty much non-existent.
|
48
|
+
You'll get the odd bus error in library routines like printf() */
|
49
|
+
#else
|
49
50
|
printf ("%Lf, %Lf, %Lf, %Lf\n", ld, ldblit(f), ld - ldblit(f), LDBL_EPSILON);
|
50
51
|
#endif
|
51
52
|
|
data/ffi.gemspec
CHANGED
@@ -5,7 +5,7 @@ Gem::Specification.new do |s|
|
|
5
5
|
s.version = FFI::VERSION
|
6
6
|
s.author = 'Wayne Meissner'
|
7
7
|
s.email = 'wmeissner@gmail.com'
|
8
|
-
s.homepage = '
|
8
|
+
s.homepage = 'https://github.com/ffi/ffi/wiki'
|
9
9
|
s.summary = 'Ruby FFI'
|
10
10
|
s.description = 'Ruby FFI library'
|
11
11
|
if s.respond_to?(:metadata)
|
data/lib/ffi/library.rb
CHANGED
@@ -47,7 +47,7 @@ module FFI
|
|
47
47
|
|
48
48
|
if lib && File.basename(lib) == lib
|
49
49
|
lib = Platform::LIBPREFIX + lib unless lib =~ /^#{Platform::LIBPREFIX}/
|
50
|
-
r = Platform::
|
50
|
+
r = Platform::IS_WINDOWS || Platform::IS_MAC ? "\\.#{Platform::LIBSUFFIX}$" : "\\.so($|\\.[1234567890]+)"
|
51
51
|
lib += ".#{Platform::LIBSUFFIX}" unless lib =~ /#{r}/
|
52
52
|
end
|
53
53
|
|
@@ -65,16 +65,16 @@ module FFI
|
|
65
65
|
#
|
66
66
|
# A basic usage may be:
|
67
67
|
# require 'ffi'
|
68
|
-
#
|
68
|
+
#
|
69
69
|
# module Hello
|
70
70
|
# extend FFI::Library
|
71
71
|
# ffi_lib FFI::Library::LIBC
|
72
72
|
# attach_function 'puts', [ :string ], :int
|
73
73
|
# end
|
74
|
-
#
|
74
|
+
#
|
75
75
|
# Hello.puts("Hello, World")
|
76
76
|
#
|
77
|
-
#
|
77
|
+
#
|
78
78
|
module Library
|
79
79
|
CURRENT_PROCESS = FFI::CURRENT_PROCESS
|
80
80
|
LIBC = FFI::Platform::LIBC
|
@@ -87,7 +87,7 @@ module FFI
|
|
87
87
|
raise RuntimeError.new("must only be extended by module") unless mod.kind_of?(Module)
|
88
88
|
end
|
89
89
|
|
90
|
-
|
90
|
+
|
91
91
|
# @param [Array] names names of libraries to load
|
92
92
|
# @return [Array<DynamicLibrary>]
|
93
93
|
# @raise {LoadError} if a library cannot be opened
|
data/lib/ffi/platform.rb
CHANGED
@@ -46,6 +46,8 @@ module FFI
|
|
46
46
|
"netbsd"
|
47
47
|
when /openbsd/
|
48
48
|
"openbsd"
|
49
|
+
when /dragonfly/
|
50
|
+
"dragonflybsd"
|
49
51
|
when /sunos|solaris/
|
50
52
|
"solaris"
|
51
53
|
when /mingw|mswin/
|
@@ -92,9 +94,10 @@ module FFI
|
|
92
94
|
IS_FREEBSD = is_os("freebsd")
|
93
95
|
IS_NETBSD = is_os("netbsd")
|
94
96
|
IS_OPENBSD = is_os("openbsd")
|
97
|
+
IS_DRAGONFLYBSD = is_os("dragonfly")
|
95
98
|
IS_SOLARIS = is_os("solaris")
|
96
99
|
IS_WINDOWS = is_os("windows")
|
97
|
-
IS_BSD = IS_MAC || IS_FREEBSD || IS_NETBSD || IS_OPENBSD
|
100
|
+
IS_BSD = IS_MAC || IS_FREEBSD || IS_NETBSD || IS_OPENBSD || IS_DRAGONFLYBSD
|
98
101
|
|
99
102
|
# Add the version for known ABI breaks
|
100
103
|
name_version = "12" if IS_FREEBSD && OSVERSION >= 12 # 64-bit inodes
|
@@ -1,128 +1,128 @@
|
|
1
|
-
rbx.platform.typedef.__int8_t = char
|
2
|
-
rbx.platform.typedef.__uint8_t = uchar
|
3
|
-
rbx.platform.typedef.__int16_t = short
|
4
|
-
rbx.platform.typedef.__uint16_t = ushort
|
5
|
-
rbx.platform.typedef.__int32_t = int
|
6
|
-
rbx.platform.typedef.__uint32_t = uint
|
7
|
-
rbx.platform.typedef.__int64_t = long_long
|
8
|
-
rbx.platform.typedef.__uint64_t = ulong_long
|
9
|
-
rbx.platform.typedef.__int_least8_t = char
|
10
|
-
rbx.platform.typedef.__uint_least8_t = uchar
|
11
|
-
rbx.platform.typedef.__int_least16_t = short
|
12
|
-
rbx.platform.typedef.__uint_least16_t = ushort
|
13
|
-
rbx.platform.typedef.__int_least32_t = int
|
14
|
-
rbx.platform.typedef.__uint_least32_t = uint
|
15
|
-
rbx.platform.typedef.__int_least64_t = long_long
|
16
|
-
rbx.platform.typedef.__uint_least64_t = ulong_long
|
17
|
-
rbx.platform.typedef.__int_fast8_t = int
|
18
|
-
rbx.platform.typedef.__uint_fast8_t = uint
|
19
|
-
rbx.platform.typedef.__int_fast16_t = int
|
20
|
-
rbx.platform.typedef.__uint_fast16_t = uint
|
21
|
-
rbx.platform.typedef.__int_fast32_t = int
|
22
|
-
rbx.platform.typedef.__uint_fast32_t = uint
|
23
|
-
rbx.platform.typedef.__int_fast64_t = long_long
|
24
|
-
rbx.platform.typedef.__uint_fast64_t = ulong_long
|
25
|
-
rbx.platform.typedef.__intptr_t = long
|
26
|
-
rbx.platform.typedef.__uintptr_t = ulong
|
27
|
-
rbx.platform.typedef.__intmax_t = long_long
|
28
|
-
rbx.platform.typedef.__uintmax_t = ulong_long
|
29
|
-
rbx.platform.typedef.__register_t = long_long
|
30
|
-
rbx.platform.typedef.__vaddr_t = ulong
|
31
|
-
rbx.platform.typedef.__paddr_t = ulong
|
32
|
-
rbx.platform.typedef.__vsize_t = ulong
|
33
|
-
rbx.platform.typedef.__psize_t = ulong
|
34
1
|
rbx.platform.typedef.__clock_t = int
|
35
2
|
rbx.platform.typedef.__clockid_t = int
|
36
|
-
rbx.platform.typedef.__off_t = long_long
|
37
|
-
rbx.platform.typedef.__ptrdiff_t = long
|
38
|
-
rbx.platform.typedef.__size_t = ulong
|
39
|
-
rbx.platform.typedef.__ssize_t = long
|
40
|
-
rbx.platform.typedef.__time_t = int
|
41
|
-
rbx.platform.typedef.__timer_t = int
|
42
|
-
rbx.platform.typedef.__wchar_t = int
|
43
|
-
rbx.platform.typedef.__wint_t = int
|
44
|
-
rbx.platform.typedef.__rune_t = int
|
45
|
-
rbx.platform.typedef.__wctrans_t = pointer
|
46
|
-
rbx.platform.typedef.__wctype_t = pointer
|
47
3
|
rbx.platform.typedef.__cpuid_t = ulong
|
48
4
|
rbx.platform.typedef.__dev_t = int
|
5
|
+
rbx.platform.typedef.__fd_mask = int
|
49
6
|
rbx.platform.typedef.__fixpt_t = uint
|
50
7
|
rbx.platform.typedef.__gid_t = uint
|
51
8
|
rbx.platform.typedef.__id_t = uint
|
52
9
|
rbx.platform.typedef.__in_addr_t = uint
|
53
10
|
rbx.platform.typedef.__in_port_t = ushort
|
54
11
|
rbx.platform.typedef.__ino_t = uint
|
12
|
+
rbx.platform.typedef.__int16_t = short
|
13
|
+
rbx.platform.typedef.__int32_t = int
|
14
|
+
rbx.platform.typedef.__int64_t = long_long
|
15
|
+
rbx.platform.typedef.__int8_t = char
|
16
|
+
rbx.platform.typedef.__int_fast16_t = int
|
17
|
+
rbx.platform.typedef.__int_fast32_t = int
|
18
|
+
rbx.platform.typedef.__int_fast64_t = long_long
|
19
|
+
rbx.platform.typedef.__int_fast8_t = int
|
20
|
+
rbx.platform.typedef.__int_least16_t = short
|
21
|
+
rbx.platform.typedef.__int_least32_t = int
|
22
|
+
rbx.platform.typedef.__int_least64_t = long_long
|
23
|
+
rbx.platform.typedef.__int_least8_t = char
|
24
|
+
rbx.platform.typedef.__intmax_t = long_long
|
25
|
+
rbx.platform.typedef.__intptr_t = long
|
55
26
|
rbx.platform.typedef.__key_t = long
|
56
27
|
rbx.platform.typedef.__mode_t = uint
|
57
28
|
rbx.platform.typedef.__nlink_t = uint
|
29
|
+
rbx.platform.typedef.__off_t = long_long
|
30
|
+
rbx.platform.typedef.__paddr_t = ulong
|
58
31
|
rbx.platform.typedef.__pid_t = int
|
32
|
+
rbx.platform.typedef.__psize_t = ulong
|
33
|
+
rbx.platform.typedef.__ptrdiff_t = long
|
34
|
+
rbx.platform.typedef.__register_t = long_long
|
59
35
|
rbx.platform.typedef.__rlim_t = ulong_long
|
36
|
+
rbx.platform.typedef.__rune_t = int
|
60
37
|
rbx.platform.typedef.__sa_family_t = uchar
|
61
38
|
rbx.platform.typedef.__segsz_t = int
|
39
|
+
rbx.platform.typedef.__size_t = ulong
|
62
40
|
rbx.platform.typedef.__socklen_t = uint
|
41
|
+
rbx.platform.typedef.__ssize_t = long
|
42
|
+
rbx.platform.typedef.__suseconds_t = int
|
63
43
|
rbx.platform.typedef.__swblk_t = int
|
44
|
+
rbx.platform.typedef.__time_t = int
|
45
|
+
rbx.platform.typedef.__timer_t = int
|
64
46
|
rbx.platform.typedef.__uid_t = uint
|
47
|
+
rbx.platform.typedef.__uint16_t = ushort
|
48
|
+
rbx.platform.typedef.__uint32_t = uint
|
49
|
+
rbx.platform.typedef.__uint64_t = ulong_long
|
50
|
+
rbx.platform.typedef.__uint8_t = uchar
|
51
|
+
rbx.platform.typedef.__uint_fast16_t = uint
|
52
|
+
rbx.platform.typedef.__uint_fast32_t = uint
|
53
|
+
rbx.platform.typedef.__uint_fast64_t = ulong_long
|
54
|
+
rbx.platform.typedef.__uint_fast8_t = uint
|
55
|
+
rbx.platform.typedef.__uint_least16_t = ushort
|
56
|
+
rbx.platform.typedef.__uint_least32_t = uint
|
57
|
+
rbx.platform.typedef.__uint_least64_t = ulong_long
|
58
|
+
rbx.platform.typedef.__uint_least8_t = uchar
|
59
|
+
rbx.platform.typedef.__uintmax_t = ulong_long
|
60
|
+
rbx.platform.typedef.__uintptr_t = ulong
|
65
61
|
rbx.platform.typedef.__useconds_t = uint
|
66
|
-
rbx.platform.typedef.
|
67
|
-
rbx.platform.typedef.
|
68
|
-
rbx.platform.typedef.
|
69
|
-
rbx.platform.typedef.
|
70
|
-
rbx.platform.typedef.
|
71
|
-
rbx.platform.typedef.
|
72
|
-
rbx.platform.typedef.ushort = ushort
|
73
|
-
rbx.platform.typedef.uint = uint
|
74
|
-
rbx.platform.typedef.ulong = ulong
|
75
|
-
rbx.platform.typedef.cpuid_t = ulong
|
76
|
-
rbx.platform.typedef.register_t = long_long
|
77
|
-
rbx.platform.typedef.int8_t = char
|
78
|
-
rbx.platform.typedef.uint8_t = uchar
|
79
|
-
rbx.platform.typedef.int16_t = short
|
80
|
-
rbx.platform.typedef.uint16_t = ushort
|
81
|
-
rbx.platform.typedef.int32_t = int
|
82
|
-
rbx.platform.typedef.uint32_t = uint
|
83
|
-
rbx.platform.typedef.int64_t = long_long
|
84
|
-
rbx.platform.typedef.uint64_t = ulong_long
|
85
|
-
rbx.platform.typedef.intptr_t = long
|
86
|
-
rbx.platform.typedef.uintptr_t = ulong
|
87
|
-
rbx.platform.typedef.u_int8_t = uchar
|
88
|
-
rbx.platform.typedef.u_int16_t = ushort
|
89
|
-
rbx.platform.typedef.u_int32_t = uint
|
90
|
-
rbx.platform.typedef.u_int64_t = ulong_long
|
91
|
-
rbx.platform.typedef.quad_t = long_long
|
92
|
-
rbx.platform.typedef.u_quad_t = ulong_long
|
93
|
-
rbx.platform.typedef.qaddr_t = pointer
|
94
|
-
rbx.platform.typedef.vaddr_t = ulong
|
95
|
-
rbx.platform.typedef.paddr_t = ulong
|
96
|
-
rbx.platform.typedef.vsize_t = ulong
|
97
|
-
rbx.platform.typedef.psize_t = ulong
|
62
|
+
rbx.platform.typedef.__vaddr_t = ulong
|
63
|
+
rbx.platform.typedef.__vsize_t = ulong
|
64
|
+
rbx.platform.typedef.__wchar_t = int
|
65
|
+
rbx.platform.typedef.__wctrans_t = pointer
|
66
|
+
rbx.platform.typedef.__wctype_t = pointer
|
67
|
+
rbx.platform.typedef.__wint_t = int
|
98
68
|
rbx.platform.typedef.caddr_t = string
|
99
|
-
rbx.platform.typedef.
|
69
|
+
rbx.platform.typedef.clock_t = int
|
70
|
+
rbx.platform.typedef.clockid_t = int
|
71
|
+
rbx.platform.typedef.cpuid_t = ulong
|
100
72
|
rbx.platform.typedef.daddr32_t = int
|
101
73
|
rbx.platform.typedef.daddr64_t = long_long
|
74
|
+
rbx.platform.typedef.daddr_t = int
|
102
75
|
rbx.platform.typedef.dev_t = int
|
103
76
|
rbx.platform.typedef.fixpt_t = uint
|
104
77
|
rbx.platform.typedef.gid_t = uint
|
105
78
|
rbx.platform.typedef.id_t = uint
|
79
|
+
rbx.platform.typedef.in_addr_t = uint
|
80
|
+
rbx.platform.typedef.in_port_t = ushort
|
106
81
|
rbx.platform.typedef.ino_t = uint
|
82
|
+
rbx.platform.typedef.int16_t = short
|
83
|
+
rbx.platform.typedef.int32_t = int
|
84
|
+
rbx.platform.typedef.int64_t = long_long
|
85
|
+
rbx.platform.typedef.int8_t = char
|
86
|
+
rbx.platform.typedef.intptr_t = long
|
107
87
|
rbx.platform.typedef.key_t = long
|
108
88
|
rbx.platform.typedef.mode_t = uint
|
109
89
|
rbx.platform.typedef.nlink_t = uint
|
90
|
+
rbx.platform.typedef.off_t = long_long
|
91
|
+
rbx.platform.typedef.paddr_t = ulong
|
110
92
|
rbx.platform.typedef.pid_t = int
|
93
|
+
rbx.platform.typedef.psize_t = ulong
|
94
|
+
rbx.platform.typedef.qaddr_t = pointer
|
95
|
+
rbx.platform.typedef.quad_t = long_long
|
96
|
+
rbx.platform.typedef.register_t = long_long
|
111
97
|
rbx.platform.typedef.rlim_t = ulong_long
|
112
|
-
rbx.platform.typedef.segsz_t = int
|
113
|
-
rbx.platform.typedef.swblk_t = int
|
114
|
-
rbx.platform.typedef.uid_t = uint
|
115
|
-
rbx.platform.typedef.useconds_t = uint
|
116
|
-
rbx.platform.typedef.suseconds_t = int
|
117
|
-
rbx.platform.typedef.in_addr_t = uint
|
118
|
-
rbx.platform.typedef.in_port_t = ushort
|
119
98
|
rbx.platform.typedef.sa_family_t = uchar
|
120
|
-
rbx.platform.typedef.
|
121
|
-
rbx.platform.typedef.clock_t = int
|
122
|
-
rbx.platform.typedef.clockid_t = int
|
99
|
+
rbx.platform.typedef.segsz_t = int
|
123
100
|
rbx.platform.typedef.size_t = ulong
|
101
|
+
rbx.platform.typedef.socklen_t = uint
|
124
102
|
rbx.platform.typedef.ssize_t = long
|
103
|
+
rbx.platform.typedef.suseconds_t = int
|
104
|
+
rbx.platform.typedef.swblk_t = int
|
125
105
|
rbx.platform.typedef.time_t = int
|
126
106
|
rbx.platform.typedef.timer_t = int
|
127
|
-
rbx.platform.typedef.
|
128
|
-
rbx.platform.typedef.
|
107
|
+
rbx.platform.typedef.u_char = uchar
|
108
|
+
rbx.platform.typedef.u_int = uint
|
109
|
+
rbx.platform.typedef.u_int16_t = ushort
|
110
|
+
rbx.platform.typedef.u_int32_t = uint
|
111
|
+
rbx.platform.typedef.u_int64_t = ulong_long
|
112
|
+
rbx.platform.typedef.u_int8_t = uchar
|
113
|
+
rbx.platform.typedef.u_long = ulong
|
114
|
+
rbx.platform.typedef.u_quad_t = ulong_long
|
115
|
+
rbx.platform.typedef.u_short = ushort
|
116
|
+
rbx.platform.typedef.uid_t = uint
|
117
|
+
rbx.platform.typedef.uint = uint
|
118
|
+
rbx.platform.typedef.uint16_t = ushort
|
119
|
+
rbx.platform.typedef.uint32_t = uint
|
120
|
+
rbx.platform.typedef.uint64_t = ulong_long
|
121
|
+
rbx.platform.typedef.uint8_t = uchar
|
122
|
+
rbx.platform.typedef.uintptr_t = ulong
|
123
|
+
rbx.platform.typedef.ulong = ulong
|
124
|
+
rbx.platform.typedef.unchar = uchar
|
125
|
+
rbx.platform.typedef.useconds_t = uint
|
126
|
+
rbx.platform.typedef.ushort = ushort
|
127
|
+
rbx.platform.typedef.vaddr_t = ulong
|
128
|
+
rbx.platform.typedef.vsize_t = ulong
|