ffi 1.11.3 → 1.13.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.appveyor.yml +3 -0
- data/.github/workflows/ci.yml +64 -0
- data/.travis.yml +21 -5
- data/CHANGELOG.md +68 -0
- data/Gemfile +6 -4
- data/README.md +10 -1
- data/Rakefile +24 -43
- data/ext/ffi_c/Buffer.c +2 -2
- data/ext/ffi_c/Call.c +1 -7
- data/ext/ffi_c/ClosurePool.c +11 -14
- data/ext/ffi_c/Function.c +8 -23
- data/ext/ffi_c/FunctionInfo.c +1 -2
- data/ext/ffi_c/LongDouble.c +5 -3
- data/ext/ffi_c/LongDouble.h +0 -4
- data/ext/ffi_c/MemoryPointer.c +1 -1
- data/ext/ffi_c/MethodHandle.c +18 -24
- data/ext/ffi_c/MethodHandle.h +3 -2
- data/ext/ffi_c/Platform.c +1 -0
- data/ext/ffi_c/Pointer.c +1 -1
- data/ext/ffi_c/Struct.c +47 -51
- data/ext/ffi_c/Struct.h +12 -6
- data/ext/ffi_c/StructLayout.c +20 -14
- data/ext/ffi_c/Thread.c +0 -3
- data/ext/ffi_c/Thread.h +0 -3
- data/ext/ffi_c/compat.h +4 -0
- data/ext/ffi_c/extconf.rb +16 -20
- data/ext/ffi_c/libffi/.travis.yml +32 -12
- data/ext/ffi_c/libffi/.travis/bfin-sim.exp +58 -0
- data/ext/ffi_c/libffi/.travis/build-cross-in-container.sh +14 -0
- data/ext/ffi_c/libffi/.travis/build-in-container.sh +2 -12
- data/ext/ffi_c/libffi/.travis/build.sh +62 -30
- data/ext/ffi_c/libffi/.travis/install.sh +65 -37
- data/ext/ffi_c/libffi/.travis/m32r-sim.exp +58 -0
- data/ext/ffi_c/libffi/.travis/or1k-sim.exp +58 -0
- data/ext/ffi_c/libffi/.travis/powerpc-eabisim.exp +58 -0
- data/ext/ffi_c/libffi/.travis/site.exp +10 -1
- data/ext/ffi_c/libffi/.travis/wine-sim.exp +55 -0
- 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/Makefile.am +6 -4
- data/ext/ffi_c/libffi/README.md +18 -6
- data/ext/ffi_c/libffi/configure.ac +26 -10
- data/ext/ffi_c/libffi/configure.host +5 -2
- data/ext/ffi_c/libffi/generate-darwin-source-and-headers.py +1 -3
- data/ext/ffi_c/libffi/include/ffi.h.in +15 -7
- 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 +1 -1
- data/ext/ffi_c/libffi/m4/ax_append_flag.m4 +5 -26
- data/ext/ffi_c/libffi/m4/ax_check_compile_flag.m4 +5 -26
- data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +2 -1
- 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/src/aarch64/ffi.c +6 -0
- data/ext/ffi_c/libffi/src/aarch64/sysv.S +13 -2
- data/ext/ffi_c/libffi/src/closures.c +20 -6
- data/ext/ffi_c/libffi/src/mips/o32.S +2 -0
- data/ext/ffi_c/libffi/src/pa/ffi.c +46 -91
- data/ext/ffi_c/libffi/src/pa/ffitarget.h +1 -6
- data/ext/ffi_c/libffi/src/pa/hpux32.S +4 -2
- data/ext/ffi_c/libffi/src/pa/linux.S +4 -2
- data/ext/ffi_c/libffi/src/powerpc/ffi.c +3 -2
- data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +154 -8
- 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 +83 -28
- data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +67 -3
- data/ext/ffi_c/libffi/src/powerpc/sysv.S +5 -7
- data/ext/ffi_c/libffi/src/x86/ffi.c +7 -4
- data/ext/ffi_c/libffi/src/x86/ffi64.c +10 -8
- data/ext/ffi_c/libffi/src/x86/ffitarget.h +15 -2
- data/ext/ffi_c/libffi/src/x86/ffiw64.c +10 -8
- data/ext/ffi_c/libffi/src/x86/sysv.S +13 -4
- data/ext/ffi_c/libffi/src/x86/unix64.S +58 -2
- data/ext/ffi_c/libffi/src/x86/win64.S +4 -1
- data/ext/ffi_c/libffi/testsuite/Makefile.am +78 -75
- data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +1 -18
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/bhaible.exp +7 -2
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-call.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-callback.c +1 -1
- data/ext/ffi_c/libffi/testsuite/libffi.call/call.exp +12 -1
- 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 +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn1.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn2.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn3.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn4.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn5.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn6.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_loc_fn0.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_simple.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_12byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_16byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_18byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_19byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_1_1byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte1.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_24byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_2byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3_1byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte1.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte2.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3float.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4_1byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5_1_byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_64byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6_1_byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7_1_byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_8byte.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte1.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte2.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_double.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_float.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split2.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_pointer.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint16.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint32.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint64.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint16.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint32.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint64.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_dbls_struct.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_double_va.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_float.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble_va.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}/cls_multi_schar.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshort.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshortchar.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_uchar.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushort.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushortchar.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer_stack.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_schar.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sint.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sshort.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_struct_va1.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uchar.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uchar_va.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uint.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uint_va.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ulong_va.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ulonglong.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ushort.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ushort_va.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.closures/ffitest.h +138 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/huge_struct.c +1 -1
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct1.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct10.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct11.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct2.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct3.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct4.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct5.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct6.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct7.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct8.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct9.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/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium2.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/testclosure.c +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/unwindtest.cc +0 -0
- data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/unwindtest_ffi_call.cc +0 -0
- data/ffi.gemspec +3 -3
- data/lib/ffi.rb +10 -2
- data/lib/ffi/ffi.rb +1 -0
- data/lib/ffi/library.rb +5 -1
- data/lib/ffi/platform.rb +6 -2
- data/lib/ffi/platform/arm-linux/types.conf +32 -4
- data/lib/ffi/platform/i386-windows/types.conf +26 -79
- data/lib/ffi/platform/powerpc-linux/types.conf +32 -2
- data/lib/ffi/platform/powerpc-openbsd/types.conf +156 -0
- data/lib/ffi/platform/sparcv9-openbsd/types.conf +156 -0
- data/lib/ffi/platform/x86_64-darwin/types.conf +4 -0
- data/lib/ffi/platform/x86_64-dragonflybsd/types.conf +4 -22
- data/lib/ffi/platform/x86_64-linux/types.conf +21 -0
- data/lib/ffi/platform/x86_64-windows/types.conf +10 -78
- data/lib/ffi/pointer.rb +19 -12
- data/lib/ffi/struct.rb +10 -5
- data/lib/ffi/tools/types_generator.rb +2 -0
- data/lib/ffi/version.rb +1 -1
- 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/inotify.rb +1 -1
- data/samples/pty.rb +1 -2
- data/samples/qsort.rb +0 -1
- metadata +116 -110
- 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/samples/sample_helper.rb +0 -6
@@ -42,7 +42,11 @@
|
|
42
42
|
#if defined(__clang__) || defined(__APPLE__) || (defined (__sun__) && defined(__svr4__))
|
43
43
|
# define E(BASE, X) .balign 8
|
44
44
|
#else
|
45
|
-
#
|
45
|
+
# ifdef __CET__
|
46
|
+
# define E(BASE, X) .balign 8; .org BASE + X * 16
|
47
|
+
# else
|
48
|
+
# define E(BASE, X) .balign 8; .org BASE + X * 8
|
49
|
+
# endif
|
46
50
|
#endif
|
47
51
|
|
48
52
|
/* ffi_call_unix64 (void *args, unsigned long bytes, unsigned flags,
|
@@ -58,6 +62,7 @@
|
|
58
62
|
|
59
63
|
C(ffi_call_unix64):
|
60
64
|
L(UW0):
|
65
|
+
_CET_ENDBR
|
61
66
|
movq (%rsp), %r10 /* Load return address. */
|
62
67
|
leaq (%rdi, %rsi), %rax /* Find local stack base. */
|
63
68
|
movq %rdx, (%rax) /* Save flags. */
|
@@ -116,6 +121,11 @@ L(UW2):
|
|
116
121
|
movzbl %cl, %r10d
|
117
122
|
leaq L(store_table)(%rip), %r11
|
118
123
|
ja L(sa)
|
124
|
+
#ifdef __CET__
|
125
|
+
/* NB: Originally, each slot is 8 byte. 4 bytes of ENDBR64 +
|
126
|
+
4 bytes NOP padding double slot size to 16 bytes. */
|
127
|
+
addl %r10d, %r10d
|
128
|
+
#endif
|
119
129
|
leaq (%r11, %r10, 8), %r10
|
120
130
|
|
121
131
|
/* Prep for the structure cases: scratch area in redzone. */
|
@@ -125,57 +135,73 @@ L(UW2):
|
|
125
135
|
.balign 8
|
126
136
|
L(store_table):
|
127
137
|
E(L(store_table), UNIX64_RET_VOID)
|
138
|
+
_CET_ENDBR
|
128
139
|
ret
|
129
140
|
E(L(store_table), UNIX64_RET_UINT8)
|
141
|
+
_CET_ENDBR
|
130
142
|
movzbl %al, %eax
|
131
143
|
movq %rax, (%rdi)
|
132
144
|
ret
|
133
145
|
E(L(store_table), UNIX64_RET_UINT16)
|
146
|
+
_CET_ENDBR
|
134
147
|
movzwl %ax, %eax
|
135
148
|
movq %rax, (%rdi)
|
136
149
|
ret
|
137
150
|
E(L(store_table), UNIX64_RET_UINT32)
|
151
|
+
_CET_ENDBR
|
138
152
|
movl %eax, %eax
|
139
153
|
movq %rax, (%rdi)
|
140
154
|
ret
|
141
155
|
E(L(store_table), UNIX64_RET_SINT8)
|
156
|
+
_CET_ENDBR
|
142
157
|
movsbq %al, %rax
|
143
158
|
movq %rax, (%rdi)
|
144
159
|
ret
|
145
160
|
E(L(store_table), UNIX64_RET_SINT16)
|
161
|
+
_CET_ENDBR
|
146
162
|
movswq %ax, %rax
|
147
163
|
movq %rax, (%rdi)
|
148
164
|
ret
|
149
165
|
E(L(store_table), UNIX64_RET_SINT32)
|
166
|
+
_CET_ENDBR
|
150
167
|
cltq
|
151
168
|
movq %rax, (%rdi)
|
152
169
|
ret
|
153
170
|
E(L(store_table), UNIX64_RET_INT64)
|
171
|
+
_CET_ENDBR
|
154
172
|
movq %rax, (%rdi)
|
155
173
|
ret
|
156
174
|
E(L(store_table), UNIX64_RET_XMM32)
|
175
|
+
_CET_ENDBR
|
157
176
|
movd %xmm0, (%rdi)
|
158
177
|
ret
|
159
178
|
E(L(store_table), UNIX64_RET_XMM64)
|
179
|
+
_CET_ENDBR
|
160
180
|
movq %xmm0, (%rdi)
|
161
181
|
ret
|
162
182
|
E(L(store_table), UNIX64_RET_X87)
|
183
|
+
_CET_ENDBR
|
163
184
|
fstpt (%rdi)
|
164
185
|
ret
|
165
186
|
E(L(store_table), UNIX64_RET_X87_2)
|
187
|
+
_CET_ENDBR
|
166
188
|
fstpt (%rdi)
|
167
189
|
fstpt 16(%rdi)
|
168
190
|
ret
|
169
191
|
E(L(store_table), UNIX64_RET_ST_XMM0_RAX)
|
192
|
+
_CET_ENDBR
|
170
193
|
movq %rax, 8(%rsi)
|
171
194
|
jmp L(s3)
|
172
195
|
E(L(store_table), UNIX64_RET_ST_RAX_XMM0)
|
196
|
+
_CET_ENDBR
|
173
197
|
movq %xmm0, 8(%rsi)
|
174
198
|
jmp L(s2)
|
175
199
|
E(L(store_table), UNIX64_RET_ST_XMM0_XMM1)
|
200
|
+
_CET_ENDBR
|
176
201
|
movq %xmm1, 8(%rsi)
|
177
202
|
jmp L(s3)
|
178
203
|
E(L(store_table), UNIX64_RET_ST_RAX_RDX)
|
204
|
+
_CET_ENDBR
|
179
205
|
movq %rdx, 8(%rsi)
|
180
206
|
L(s2):
|
181
207
|
movq %rax, (%rsi)
|
@@ -227,6 +253,7 @@ ENDF(C(ffi_call_unix64))
|
|
227
253
|
|
228
254
|
C(ffi_closure_unix64_sse):
|
229
255
|
L(UW5):
|
256
|
+
_CET_ENDBR
|
230
257
|
subq $ffi_closure_FS, %rsp
|
231
258
|
L(UW6):
|
232
259
|
/* cfi_adjust_cfa_offset(ffi_closure_FS) */
|
@@ -250,6 +277,7 @@ ENDF(C(ffi_closure_unix64_sse))
|
|
250
277
|
|
251
278
|
C(ffi_closure_unix64):
|
252
279
|
L(UW8):
|
280
|
+
_CET_ENDBR
|
253
281
|
subq $ffi_closure_FS, %rsp
|
254
282
|
L(UW9):
|
255
283
|
/* cfi_adjust_cfa_offset(ffi_closure_FS) */
|
@@ -286,6 +314,11 @@ L(UW10):
|
|
286
314
|
movzbl %al, %r10d
|
287
315
|
leaq L(load_table)(%rip), %r11
|
288
316
|
ja L(la)
|
317
|
+
#ifdef __CET__
|
318
|
+
/* NB: Originally, each slot is 8 byte. 4 bytes of ENDBR64 +
|
319
|
+
4 bytes NOP padding double slot size to 16 bytes. */
|
320
|
+
addl %r10d, %r10d
|
321
|
+
#endif
|
289
322
|
leaq (%r11, %r10, 8), %r10
|
290
323
|
leaq ffi_closure_RED_RVALUE(%rsp), %rsi
|
291
324
|
jmp *%r10
|
@@ -293,51 +326,67 @@ L(UW10):
|
|
293
326
|
.balign 8
|
294
327
|
L(load_table):
|
295
328
|
E(L(load_table), UNIX64_RET_VOID)
|
329
|
+
_CET_ENDBR
|
296
330
|
ret
|
297
331
|
E(L(load_table), UNIX64_RET_UINT8)
|
332
|
+
_CET_ENDBR
|
298
333
|
movzbl (%rsi), %eax
|
299
334
|
ret
|
300
335
|
E(L(load_table), UNIX64_RET_UINT16)
|
336
|
+
_CET_ENDBR
|
301
337
|
movzwl (%rsi), %eax
|
302
338
|
ret
|
303
339
|
E(L(load_table), UNIX64_RET_UINT32)
|
340
|
+
_CET_ENDBR
|
304
341
|
movl (%rsi), %eax
|
305
342
|
ret
|
306
343
|
E(L(load_table), UNIX64_RET_SINT8)
|
344
|
+
_CET_ENDBR
|
307
345
|
movsbl (%rsi), %eax
|
308
346
|
ret
|
309
347
|
E(L(load_table), UNIX64_RET_SINT16)
|
348
|
+
_CET_ENDBR
|
310
349
|
movswl (%rsi), %eax
|
311
350
|
ret
|
312
351
|
E(L(load_table), UNIX64_RET_SINT32)
|
352
|
+
_CET_ENDBR
|
313
353
|
movl (%rsi), %eax
|
314
354
|
ret
|
315
355
|
E(L(load_table), UNIX64_RET_INT64)
|
356
|
+
_CET_ENDBR
|
316
357
|
movq (%rsi), %rax
|
317
358
|
ret
|
318
359
|
E(L(load_table), UNIX64_RET_XMM32)
|
360
|
+
_CET_ENDBR
|
319
361
|
movd (%rsi), %xmm0
|
320
362
|
ret
|
321
363
|
E(L(load_table), UNIX64_RET_XMM64)
|
364
|
+
_CET_ENDBR
|
322
365
|
movq (%rsi), %xmm0
|
323
366
|
ret
|
324
367
|
E(L(load_table), UNIX64_RET_X87)
|
368
|
+
_CET_ENDBR
|
325
369
|
fldt (%rsi)
|
326
370
|
ret
|
327
371
|
E(L(load_table), UNIX64_RET_X87_2)
|
372
|
+
_CET_ENDBR
|
328
373
|
fldt 16(%rsi)
|
329
374
|
fldt (%rsi)
|
330
375
|
ret
|
331
376
|
E(L(load_table), UNIX64_RET_ST_XMM0_RAX)
|
377
|
+
_CET_ENDBR
|
332
378
|
movq 8(%rsi), %rax
|
333
379
|
jmp L(l3)
|
334
380
|
E(L(load_table), UNIX64_RET_ST_RAX_XMM0)
|
381
|
+
_CET_ENDBR
|
335
382
|
movq 8(%rsi), %xmm0
|
336
383
|
jmp L(l2)
|
337
384
|
E(L(load_table), UNIX64_RET_ST_XMM0_XMM1)
|
385
|
+
_CET_ENDBR
|
338
386
|
movq 8(%rsi), %xmm1
|
339
387
|
jmp L(l3)
|
340
388
|
E(L(load_table), UNIX64_RET_ST_RAX_RDX)
|
389
|
+
_CET_ENDBR
|
341
390
|
movq 8(%rsi), %rdx
|
342
391
|
L(l2):
|
343
392
|
movq (%rsi), %rax
|
@@ -358,6 +407,7 @@ ENDF(C(ffi_closure_unix64))
|
|
358
407
|
|
359
408
|
C(ffi_go_closure_unix64_sse):
|
360
409
|
L(UW12):
|
410
|
+
_CET_ENDBR
|
361
411
|
subq $ffi_closure_FS, %rsp
|
362
412
|
L(UW13):
|
363
413
|
/* cfi_adjust_cfa_offset(ffi_closure_FS) */
|
@@ -381,6 +431,7 @@ ENDF(C(ffi_go_closure_unix64_sse))
|
|
381
431
|
|
382
432
|
C(ffi_go_closure_unix64):
|
383
433
|
L(UW15):
|
434
|
+
_CET_ENDBR
|
384
435
|
subq $ffi_closure_FS, %rsp
|
385
436
|
L(UW16):
|
386
437
|
/* cfi_adjust_cfa_offset(ffi_closure_FS) */
|
@@ -424,7 +475,12 @@ EHFrame0:
|
|
424
475
|
#endif
|
425
476
|
|
426
477
|
/* Simplify advancing between labels. Assume DW_CFA_advance_loc1 fits. */
|
427
|
-
#
|
478
|
+
#ifdef __CET__
|
479
|
+
/* Use DW_CFA_advance_loc2 when IBT is enabled. */
|
480
|
+
# define ADV(N, P) .byte 3; .2byte L(N)-L(P)
|
481
|
+
#else
|
482
|
+
# define ADV(N, P) .byte 2, L(N)-L(P)
|
483
|
+
#endif
|
428
484
|
|
429
485
|
.balign 8
|
430
486
|
L(CIE):
|
@@ -48,6 +48,7 @@
|
|
48
48
|
SEH(.seh_proc ffi_call_win64)
|
49
49
|
C(ffi_call_win64):
|
50
50
|
cfi_startproc
|
51
|
+
_CET_ENDBR
|
51
52
|
/* Set up the local stack frame and install it in rbp/rsp. */
|
52
53
|
movq (%rsp), %rax
|
53
54
|
movq %rbp, (arg1)
|
@@ -80,7 +81,7 @@ C(ffi_call_win64):
|
|
80
81
|
cmpl $FFI_TYPE_SMALL_STRUCT_4B, %ecx
|
81
82
|
leaq (%r10, %rcx, 8), %r10
|
82
83
|
ja 99f
|
83
|
-
jmp
|
84
|
+
_CET_NOTRACK jmp *%r10
|
84
85
|
|
85
86
|
/* Below, we're space constrained most of the time. Thus we eschew the
|
86
87
|
modern "mov, pop, ret" sequence (5 bytes) for "leave, ret" (2 bytes). */
|
@@ -176,6 +177,7 @@ E(0b, FFI_TYPE_SMALL_STRUCT_4B)
|
|
176
177
|
SEH(.seh_proc ffi_go_closure_win64)
|
177
178
|
C(ffi_go_closure_win64):
|
178
179
|
cfi_startproc
|
180
|
+
_CET_ENDBR
|
179
181
|
/* Save all integer arguments into the incoming reg stack space. */
|
180
182
|
movq %rcx, 8(%rsp)
|
181
183
|
movq %rdx, 16(%rsp)
|
@@ -196,6 +198,7 @@ C(ffi_go_closure_win64):
|
|
196
198
|
SEH(.seh_proc ffi_closure_win64)
|
197
199
|
C(ffi_closure_win64):
|
198
200
|
cfi_startproc
|
201
|
+
_CET_ENDBR
|
199
202
|
/* Save all integer arguments into the incoming reg stack space. */
|
200
203
|
movq %rcx, 8(%rsp)
|
201
204
|
movq %rdx, 16(%rsp)
|
@@ -7,79 +7,28 @@ EXTRA_DEJAGNU_SITE_CONFIG=../local.exp
|
|
7
7
|
CLEANFILES = *.exe core* *.log *.sum
|
8
8
|
|
9
9
|
EXTRA_DIST = lib/target-libpath.exp lib/libffi.exp lib/wrapper.exp \
|
10
|
-
libffi.call/strlen4.c libffi.call/
|
11
|
-
libffi.call/
|
12
|
-
libffi.call/
|
13
|
-
libffi.call/
|
14
|
-
libffi.call/
|
15
|
-
libffi.call/
|
16
|
-
libffi.call/
|
17
|
-
libffi.call/
|
18
|
-
libffi.call/
|
19
|
-
libffi.call/
|
20
|
-
libffi.call/
|
21
|
-
libffi.call/
|
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 \
|
10
|
+
libffi.call/strlen4.c libffi.call/struct10.c libffi.call/many_mixed.c \
|
11
|
+
libffi.call/float.c libffi.call/struct5.c libffi.call/return_fl3.c \
|
12
|
+
libffi.call/return_fl1.c libffi.call/call.exp libffi.call/pyobjc-tc.c \
|
13
|
+
libffi.call/float_va.c libffi.call/struct8.c libffi.call/pr1172638.c \
|
14
|
+
libffi.call/return_sc.c libffi.call/va_struct1.c \
|
15
|
+
libffi.call/align_stdcall.c libffi.call/struct9.c libffi.call/va_1.c \
|
16
|
+
libffi.call/va_struct2.c libffi.call/return_fl2.c \
|
17
|
+
libffi.call/align_mixed.c libffi.call/ffitest.h libffi.call/struct4.c \
|
18
|
+
libffi.call/return_ldl.c libffi.call/float3.c libffi.call/return_sl.c \
|
19
|
+
libffi.call/return_dbl1.c libffi.call/err_bad_typedef.c \
|
20
|
+
libffi.call/return_ll1.c libffi.call/return_dbl2.c \
|
21
|
+
libffi.call/negint.c libffi.closures/nested_struct3.c \
|
55
22
|
libffi.call/struct2.c libffi.call/struct3.c libffi.call/return_fl.c \
|
56
|
-
libffi.call/
|
57
|
-
libffi.call/
|
58
|
-
libffi.call/
|
59
|
-
libffi.call/
|
60
|
-
libffi.call/
|
61
|
-
libffi.call/
|
62
|
-
libffi.call/
|
63
|
-
libffi.
|
64
|
-
libffi.
|
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 \
|
23
|
+
libffi.call/offsets.c libffi.call/struct7.c libffi.call/va_struct3.c \
|
24
|
+
libffi.call/float1.c libffi.call/uninitialized.c libffi.call/many2.c \
|
25
|
+
libffi.call/struct6.c libffi.call/strlen2.c libffi.call/float2.c \
|
26
|
+
libffi.call/return_ul.c libffi.call/struct1.c libffi.call/strlen3.c \
|
27
|
+
libffi.call/return_dbl.c libffi.call/float4.c libffi.call/many.c \
|
28
|
+
libffi.call/strlen.c libffi.call/return_uc.c libffi.call/many_double.c \
|
29
|
+
libffi.call/return_ll.c libffi.call/promotion.c \
|
30
|
+
libffi.complex/complex_defs_longdouble.inc \
|
31
|
+
libffi.complex/cls_align_complex_float.c \
|
83
32
|
libffi.complex/cls_complex_va_float.c \
|
84
33
|
libffi.complex/cls_complex_struct_float.c \
|
85
34
|
libffi.complex/return_complex2_longdouble.c \
|
@@ -90,9 +39,9 @@ libffi.complex/cls_complex_va_longdouble.c \
|
|
90
39
|
libffi.complex/return_complex_double.c \
|
91
40
|
libffi.complex/return_complex.inc libffi.complex/many_complex.inc \
|
92
41
|
libffi.complex/complex_float.c libffi.complex/cls_align_complex.inc \
|
93
|
-
libffi.complex/return_complex2_double.c
|
42
|
+
libffi.complex/return_complex2_double.c \
|
94
43
|
libffi.complex/many_complex_float.c libffi.complex/ffitest.h \
|
95
|
-
libffi.complex/return_complex1_double.c
|
44
|
+
libffi.complex/return_complex1_double.c \
|
96
45
|
libffi.complex/cls_complex_struct_longdouble.c \
|
97
46
|
libffi.complex/complex_defs_double.inc \
|
98
47
|
libffi.complex/cls_complex_va_double.c \
|
@@ -116,4 +65,58 @@ libffi.go/aa-direct.c libffi.go/ffitest.h libffi.go/go.exp \
|
|
116
65
|
libffi.go/static-chain.h libffi.bhaible/bhaible.exp \
|
117
66
|
libffi.bhaible/test-call.c libffi.bhaible/alignof.h \
|
118
67
|
libffi.bhaible/testcases.c libffi.bhaible/test-callback.c \
|
119
|
-
libffi.bhaible/Makefile libffi.bhaible/README config/default.exp
|
68
|
+
libffi.bhaible/Makefile libffi.bhaible/README config/default.exp \
|
69
|
+
libffi.closures/cls_multi_sshort.c \
|
70
|
+
libffi.closures/cls_align_longdouble_split2.c \
|
71
|
+
libffi.closures/cls_1_1byte.c libffi.closures/cls_uint_va.c \
|
72
|
+
libffi.closures/cls_3_1byte.c libffi.closures/cls_many_mixed_args.c \
|
73
|
+
libffi.closures/cls_20byte1.c libffi.closures/cls_pointer_stack.c \
|
74
|
+
libffi.closures/cls_align_float.c libffi.closures/cls_5_1_byte.c \
|
75
|
+
libffi.closures/cls_9byte1.c libffi.closures/cls_align_uint32.c \
|
76
|
+
libffi.closures/stret_medium.c libffi.closures/cls_3byte1.c \
|
77
|
+
libffi.closures/cls_align_uint64.c libffi.closures/cls_longdouble_va.c \
|
78
|
+
libffi.closures/cls_align_pointer.c libffi.closures/cls_19byte.c \
|
79
|
+
libffi.closures/cls_ushort.c libffi.closures/cls_align_sint32.c \
|
80
|
+
libffi.closures/cls_ulonglong.c libffi.closures/cls_struct_va1.c \
|
81
|
+
libffi.closures/cls_9byte2.c libffi.closures/closure_fn5.c \
|
82
|
+
libffi.closures/cls_5byte.c libffi.closures/cls_3float.c \
|
83
|
+
libffi.closures/closure.exp libffi.closures/cls_schar.c \
|
84
|
+
libffi.closures/closure_fn4.c libffi.closures/cls_uchar_va.c \
|
85
|
+
libffi.closures/closure_fn0.c libffi.closures/huge_struct.c \
|
86
|
+
libffi.closures/cls_ushort_va.c \
|
87
|
+
libffi.closures/cls_64byte.c libffi.closures/cls_longdouble.c \
|
88
|
+
libffi.closures/cls_ulong_va.c libffi.closures/cls_6_1_byte.c \
|
89
|
+
libffi.closures/cls_align_uint16.c libffi.closures/closure_fn2.c \
|
90
|
+
libffi.closures/unwindtest_ffi_call.cc \
|
91
|
+
libffi.closures/cls_multi_ushortchar.c libffi.closures/cls_8byte.c \
|
92
|
+
libffi.closures/ffitest.h libffi.closures/nested_struct8.c \
|
93
|
+
libffi.closures/cls_pointer.c libffi.closures/nested_struct2.c \
|
94
|
+
libffi.closures/nested_struct.c libffi.closures/cls_multi_schar.c \
|
95
|
+
libffi.closures/cls_align_longdouble_split.c \
|
96
|
+
libffi.closures/cls_uchar.c libffi.closures/nested_struct9.c \
|
97
|
+
libffi.closures/cls_float.c libffi.closures/stret_medium2.c \
|
98
|
+
libffi.closures/closure_loc_fn0.c libffi.closures/cls_6byte.c \
|
99
|
+
libffi.closures/closure_simple.c libffi.closures/cls_align_double.c \
|
100
|
+
libffi.closures/cls_multi_uchar.c libffi.closures/cls_4_1byte.c \
|
101
|
+
libffi.closures/closure_fn3.c libffi.closures/cls_align_sint64.c \
|
102
|
+
libffi.closures/nested_struct1.c libffi.closures/unwindtest.cc \
|
103
|
+
libffi.closures/nested_struct5.c libffi.closures/cls_multi_ushort.c \
|
104
|
+
libffi.closures/nested_struct11.c \
|
105
|
+
libffi.closures/cls_multi_sshortchar.c \
|
106
|
+
libffi.closures/cls_align_longdouble.c \
|
107
|
+
libffi.closures/cls_dbls_struct.c \
|
108
|
+
libffi.closures/cls_many_mixed_float_double.c \
|
109
|
+
libffi.closures/stret_large.c libffi.closures/stret_large2.c \
|
110
|
+
libffi.closures/cls_align_sint16.c libffi.closures/cls_2byte.c \
|
111
|
+
libffi.closures/nested_struct4.c libffi.closures/problem1.c \
|
112
|
+
libffi.closures/testclosure.c libffi.closures/nested_struct6.c \
|
113
|
+
libffi.closures/cls_4byte.c libffi.closures/cls_24byte.c \
|
114
|
+
libffi.closures/nested_struct10.c libffi.closures/cls_uint.c \
|
115
|
+
libffi.closures/cls_12byte.c libffi.closures/cls_sint.c \
|
116
|
+
libffi.closures/cls_7_1_byte.c libffi.closures/cls_sshort.c \
|
117
|
+
libffi.closures/cls_16byte.c libffi.closures/nested_struct7.c \
|
118
|
+
libffi.closures/cls_double_va.c libffi.closures/cls_3byte2.c \
|
119
|
+
libffi.closures/cls_double.c libffi.closures/cls_7byte.c \
|
120
|
+
libffi.closures/closure_fn6.c libffi.closures/closure_fn1.c \
|
121
|
+
libffi.closures/cls_20byte.c libffi.closures/cls_18byte.c \
|
122
|
+
libffi.closures/err_bad_abi.c
|
@@ -24,11 +24,6 @@ load_lib libgloss.exp
|
|
24
24
|
load_gcc_lib target-libpath.exp
|
25
25
|
load_gcc_lib wrapper.exp
|
26
26
|
|
27
|
-
proc check_effective_target_gccbug { } {
|
28
|
-
global has_gccbug
|
29
|
-
return $has_gccbug
|
30
|
-
}
|
31
|
-
|
32
27
|
# Return 1 if the target matches the effective target 'arg', 0 otherwise.
|
33
28
|
# This can be used with any check_* proc that takes no argument and
|
34
29
|
# returns only 1 or 0. It could be used with check_* procs that take
|
@@ -482,7 +477,6 @@ proc libffi-dg-runtest { testcases default-extra-flags } {
|
|
482
477
|
|
483
478
|
proc run-many-tests { testcases extra_flags } {
|
484
479
|
global compiler_vendor
|
485
|
-
global has_gccbug
|
486
480
|
global env
|
487
481
|
switch $compiler_vendor {
|
488
482
|
"clang" {
|
@@ -498,7 +492,7 @@ proc run-many-tests { testcases extra_flags } {
|
|
498
492
|
if [info exists env(LIBFFI_TEST_OPTIMIZATION)] {
|
499
493
|
set optimizations [ list $env(LIBFFI_TEST_OPTIMIZATION) ]
|
500
494
|
} else {
|
501
|
-
set optimizations { "-O0" "-O2"
|
495
|
+
set optimizations { "-O0" "-O2" }
|
502
496
|
}
|
503
497
|
}
|
504
498
|
default {
|
@@ -544,17 +538,6 @@ proc run-many-tests { testcases extra_flags } {
|
|
544
538
|
foreach opt $optimizations {
|
545
539
|
foreach abi $abis {
|
546
540
|
set options [concat $common $opt $abi]
|
547
|
-
set has_gccbug false;
|
548
|
-
if { [string match $compiler_vendor "gnu"] \
|
549
|
-
&& [string match "*MSABI*" $abi] \
|
550
|
-
&& ( ( [string match "*DGTEST=57 *" $common] \
|
551
|
-
&& [string match "*call.c*" $testname] ) \
|
552
|
-
|| ( [string match "*DGTEST=54 *" $common] \
|
553
|
-
&& [string match "*callback*" $testname] ) \
|
554
|
-
|| [string match "*DGTEST=55 *" $common] \
|
555
|
-
|| [string match "*DGTEST=56 *" $common] ) } then {
|
556
|
-
set has_gccbug true;
|
557
|
-
}
|
558
541
|
verbose "Testing $testname, $options" 1
|
559
542
|
dg-test $test $options ""
|
560
543
|
}
|