ffi 1.11.3 → 1.13.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (210) hide show
  1. checksums.yaml +4 -4
  2. data/.appveyor.yml +3 -0
  3. data/.github/workflows/ci.yml +64 -0
  4. data/.travis.yml +21 -5
  5. data/CHANGELOG.md +68 -0
  6. data/Gemfile +6 -4
  7. data/README.md +10 -1
  8. data/Rakefile +24 -43
  9. data/ext/ffi_c/Buffer.c +2 -2
  10. data/ext/ffi_c/Call.c +1 -7
  11. data/ext/ffi_c/ClosurePool.c +11 -14
  12. data/ext/ffi_c/Function.c +8 -23
  13. data/ext/ffi_c/FunctionInfo.c +1 -2
  14. data/ext/ffi_c/LongDouble.c +5 -3
  15. data/ext/ffi_c/LongDouble.h +0 -4
  16. data/ext/ffi_c/MemoryPointer.c +1 -1
  17. data/ext/ffi_c/MethodHandle.c +18 -24
  18. data/ext/ffi_c/MethodHandle.h +3 -2
  19. data/ext/ffi_c/Platform.c +1 -0
  20. data/ext/ffi_c/Pointer.c +1 -1
  21. data/ext/ffi_c/Struct.c +47 -51
  22. data/ext/ffi_c/Struct.h +12 -6
  23. data/ext/ffi_c/StructLayout.c +20 -14
  24. data/ext/ffi_c/Thread.c +0 -3
  25. data/ext/ffi_c/Thread.h +0 -3
  26. data/ext/ffi_c/compat.h +4 -0
  27. data/ext/ffi_c/extconf.rb +16 -20
  28. data/ext/ffi_c/libffi/.travis.yml +32 -12
  29. data/ext/ffi_c/libffi/.travis/bfin-sim.exp +58 -0
  30. data/ext/ffi_c/libffi/.travis/build-cross-in-container.sh +14 -0
  31. data/ext/ffi_c/libffi/.travis/build-in-container.sh +2 -12
  32. data/ext/ffi_c/libffi/.travis/build.sh +62 -30
  33. data/ext/ffi_c/libffi/.travis/install.sh +65 -37
  34. data/ext/ffi_c/libffi/.travis/m32r-sim.exp +58 -0
  35. data/ext/ffi_c/libffi/.travis/or1k-sim.exp +58 -0
  36. data/ext/ffi_c/libffi/.travis/powerpc-eabisim.exp +58 -0
  37. data/ext/ffi_c/libffi/.travis/site.exp +10 -1
  38. data/ext/ffi_c/libffi/.travis/wine-sim.exp +55 -0
  39. data/ext/ffi_c/libffi/{ChangeLog.libffi-3.1 → ChangeLog.old} +1407 -0
  40. data/ext/ffi_c/libffi/LICENSE +1 -1
  41. data/ext/ffi_c/libffi/Makefile.am +6 -4
  42. data/ext/ffi_c/libffi/README.md +18 -6
  43. data/ext/ffi_c/libffi/configure.ac +26 -10
  44. data/ext/ffi_c/libffi/configure.host +5 -2
  45. data/ext/ffi_c/libffi/generate-darwin-source-and-headers.py +1 -3
  46. data/ext/ffi_c/libffi/include/ffi.h.in +15 -7
  47. data/ext/ffi_c/libffi/libffi.map.in +8 -12
  48. data/ext/ffi_c/libffi/libffi.xcodeproj/project.pbxproj +2 -48
  49. data/ext/ffi_c/libffi/libtool-version +1 -1
  50. data/ext/ffi_c/libffi/m4/ax_append_flag.m4 +5 -26
  51. data/ext/ffi_c/libffi/m4/ax_check_compile_flag.m4 +5 -26
  52. data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +2 -1
  53. data/ext/ffi_c/libffi/m4/ax_configure_args.m4 +5 -26
  54. data/ext/ffi_c/libffi/m4/ax_gcc_archflag.m4 +7 -3
  55. data/ext/ffi_c/libffi/src/aarch64/ffi.c +6 -0
  56. data/ext/ffi_c/libffi/src/aarch64/sysv.S +13 -2
  57. data/ext/ffi_c/libffi/src/closures.c +20 -6
  58. data/ext/ffi_c/libffi/src/mips/o32.S +2 -0
  59. data/ext/ffi_c/libffi/src/pa/ffi.c +46 -91
  60. data/ext/ffi_c/libffi/src/pa/ffitarget.h +1 -6
  61. data/ext/ffi_c/libffi/src/pa/hpux32.S +4 -2
  62. data/ext/ffi_c/libffi/src/pa/linux.S +4 -2
  63. data/ext/ffi_c/libffi/src/powerpc/ffi.c +3 -2
  64. data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +154 -8
  65. data/ext/ffi_c/libffi/src/powerpc/ffi_powerpc.h +18 -7
  66. data/ext/ffi_c/libffi/src/powerpc/ffitarget.h +10 -4
  67. data/ext/ffi_c/libffi/src/powerpc/linux64.S +83 -28
  68. data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +67 -3
  69. data/ext/ffi_c/libffi/src/powerpc/sysv.S +5 -7
  70. data/ext/ffi_c/libffi/src/x86/ffi.c +7 -4
  71. data/ext/ffi_c/libffi/src/x86/ffi64.c +10 -8
  72. data/ext/ffi_c/libffi/src/x86/ffitarget.h +15 -2
  73. data/ext/ffi_c/libffi/src/x86/ffiw64.c +10 -8
  74. data/ext/ffi_c/libffi/src/x86/sysv.S +13 -4
  75. data/ext/ffi_c/libffi/src/x86/unix64.S +58 -2
  76. data/ext/ffi_c/libffi/src/x86/win64.S +4 -1
  77. data/ext/ffi_c/libffi/testsuite/Makefile.am +78 -75
  78. data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +1 -18
  79. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/bhaible.exp +7 -2
  80. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-call.c +1 -1
  81. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-callback.c +1 -1
  82. data/ext/ffi_c/libffi/testsuite/libffi.call/call.exp +12 -1
  83. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure.exp +67 -0
  84. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn0.c +0 -0
  85. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn1.c +0 -0
  86. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn2.c +0 -0
  87. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn3.c +0 -0
  88. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn4.c +0 -0
  89. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn5.c +0 -0
  90. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn6.c +0 -0
  91. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_loc_fn0.c +0 -0
  92. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_simple.c +0 -0
  93. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_12byte.c +0 -0
  94. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_16byte.c +0 -0
  95. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_18byte.c +0 -0
  96. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_19byte.c +0 -0
  97. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_1_1byte.c +0 -0
  98. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte.c +0 -0
  99. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte1.c +0 -0
  100. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_24byte.c +0 -0
  101. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_2byte.c +0 -0
  102. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3_1byte.c +0 -0
  103. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte1.c +0 -0
  104. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte2.c +0 -0
  105. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3float.c +0 -0
  106. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4_1byte.c +0 -0
  107. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4byte.c +0 -0
  108. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5_1_byte.c +0 -0
  109. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5byte.c +0 -0
  110. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_64byte.c +0 -0
  111. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6_1_byte.c +0 -0
  112. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6byte.c +0 -0
  113. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7_1_byte.c +0 -0
  114. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7byte.c +0 -0
  115. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_8byte.c +0 -0
  116. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte1.c +0 -0
  117. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte2.c +0 -0
  118. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_double.c +0 -0
  119. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_float.c +0 -0
  120. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble.c +0 -0
  121. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split.c +0 -0
  122. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split2.c +0 -0
  123. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_pointer.c +0 -0
  124. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint16.c +0 -0
  125. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint32.c +0 -0
  126. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint64.c +0 -0
  127. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint16.c +0 -0
  128. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint32.c +0 -0
  129. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint64.c +0 -0
  130. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_dbls_struct.c +0 -0
  131. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double.c +0 -0
  132. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double_va.c +0 -0
  133. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_float.c +0 -0
  134. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble.c +0 -0
  135. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble_va.c +0 -0
  136. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_many_mixed_args.c +0 -0
  137. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_many_mixed_float_double.c +0 -0
  138. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_schar.c +0 -0
  139. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshort.c +0 -0
  140. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshortchar.c +0 -0
  141. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_uchar.c +0 -0
  142. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushort.c +0 -0
  143. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushortchar.c +0 -0
  144. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer.c +0 -0
  145. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer_stack.c +0 -0
  146. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_schar.c +0 -0
  147. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sint.c +0 -0
  148. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sshort.c +0 -0
  149. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_struct_va1.c +0 -0
  150. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uchar.c +0 -0
  151. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uchar_va.c +0 -0
  152. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uint.c +0 -0
  153. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uint_va.c +0 -0
  154. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ulong_va.c +0 -0
  155. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ulonglong.c +0 -0
  156. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ushort.c +0 -0
  157. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ushort_va.c +0 -0
  158. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/err_bad_abi.c +0 -0
  159. data/ext/ffi_c/libffi/testsuite/libffi.closures/ffitest.h +138 -0
  160. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/huge_struct.c +1 -1
  161. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct.c +0 -0
  162. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct1.c +0 -0
  163. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct10.c +0 -0
  164. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct11.c +0 -0
  165. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct2.c +0 -0
  166. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct3.c +0 -0
  167. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct4.c +0 -0
  168. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct5.c +0 -0
  169. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct6.c +0 -0
  170. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct7.c +0 -0
  171. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct8.c +0 -0
  172. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct9.c +0 -0
  173. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/problem1.c +0 -0
  174. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large.c +0 -0
  175. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large2.c +0 -0
  176. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium.c +0 -0
  177. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium2.c +0 -0
  178. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/testclosure.c +0 -0
  179. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/unwindtest.cc +0 -0
  180. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/unwindtest_ffi_call.cc +0 -0
  181. data/ffi.gemspec +3 -3
  182. data/lib/ffi.rb +10 -2
  183. data/lib/ffi/ffi.rb +1 -0
  184. data/lib/ffi/library.rb +5 -1
  185. data/lib/ffi/platform.rb +6 -2
  186. data/lib/ffi/platform/arm-linux/types.conf +32 -4
  187. data/lib/ffi/platform/i386-windows/types.conf +26 -79
  188. data/lib/ffi/platform/powerpc-linux/types.conf +32 -2
  189. data/lib/ffi/platform/powerpc-openbsd/types.conf +156 -0
  190. data/lib/ffi/platform/sparcv9-openbsd/types.conf +156 -0
  191. data/lib/ffi/platform/x86_64-darwin/types.conf +4 -0
  192. data/lib/ffi/platform/x86_64-dragonflybsd/types.conf +4 -22
  193. data/lib/ffi/platform/x86_64-linux/types.conf +21 -0
  194. data/lib/ffi/platform/x86_64-windows/types.conf +10 -78
  195. data/lib/ffi/pointer.rb +19 -12
  196. data/lib/ffi/struct.rb +10 -5
  197. data/lib/ffi/tools/types_generator.rb +2 -0
  198. data/lib/ffi/version.rb +1 -1
  199. data/samples/getlogin.rb +1 -1
  200. data/samples/getpid.rb +1 -1
  201. data/samples/gettimeofday.rb +8 -8
  202. data/samples/hello.rb +2 -1
  203. data/samples/inotify.rb +1 -1
  204. data/samples/pty.rb +1 -2
  205. data/samples/qsort.rb +0 -1
  206. metadata +116 -110
  207. data/ext/ffi_c/libffi/ChangeLog.libffi +0 -584
  208. data/ext/ffi_c/libffi/ChangeLog.libgcj +0 -40
  209. data/ext/ffi_c/libffi/ChangeLog.v1 +0 -764
  210. 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
- # define E(BASE, X) .balign 8; .org BASE + X * 8
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
- #define ADV(N, P) .byte 2, L(N)-L(P)
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 *%r10
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/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 \
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/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 \
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" "-O2 -fomit-frame-pointer" }
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
  }