ffi 1.15.5 → 1.17.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (343) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data/CHANGELOG.md +118 -0
  4. data/Gemfile +10 -3
  5. data/README.md +4 -3
  6. data/Rakefile +25 -10
  7. data/ext/ffi_c/AbstractMemory.c +99 -74
  8. data/ext/ffi_c/AbstractMemory.h +3 -2
  9. data/ext/ffi_c/ArrayType.c +51 -15
  10. data/ext/ffi_c/ArrayType.h +1 -0
  11. data/ext/ffi_c/Buffer.c +90 -33
  12. data/ext/ffi_c/Call.c +29 -12
  13. data/ext/ffi_c/Call.h +3 -2
  14. data/ext/ffi_c/DynamicLibrary.c +90 -27
  15. data/ext/ffi_c/Function.c +244 -98
  16. data/ext/ffi_c/Function.h +1 -0
  17. data/ext/ffi_c/FunctionInfo.c +81 -25
  18. data/ext/ffi_c/LastError.c +29 -11
  19. data/ext/ffi_c/MappedType.c +66 -23
  20. data/ext/ffi_c/MappedType.h +0 -2
  21. data/ext/ffi_c/MemoryPointer.c +36 -9
  22. data/ext/ffi_c/MethodHandle.c +3 -1
  23. data/ext/ffi_c/Pointer.c +82 -40
  24. data/ext/ffi_c/Pointer.h +1 -0
  25. data/ext/ffi_c/Struct.c +166 -84
  26. data/ext/ffi_c/Struct.h +7 -4
  27. data/ext/ffi_c/StructByValue.c +48 -16
  28. data/ext/ffi_c/StructLayout.c +130 -61
  29. data/ext/ffi_c/Type.c +120 -51
  30. data/ext/ffi_c/Type.h +3 -1
  31. data/ext/ffi_c/Types.c +8 -2
  32. data/ext/ffi_c/Types.h +0 -1
  33. data/ext/ffi_c/Variadic.c +71 -26
  34. data/ext/ffi_c/compat.h +22 -22
  35. data/ext/ffi_c/extconf.rb +19 -2
  36. data/ext/ffi_c/ffi.c +4 -0
  37. data/ext/ffi_c/libffi/.allow-ai-service +0 -0
  38. data/ext/ffi_c/libffi/.appveyor/site.exp +16 -0
  39. data/ext/ffi_c/libffi/.appveyor/unix-noexec.exp +7 -0
  40. data/ext/ffi_c/libffi/.appveyor.yml +27 -9
  41. data/ext/ffi_c/libffi/.ci/build-cross-in-container.sh +18 -0
  42. data/ext/ffi_c/libffi/{.travis → .ci}/build-in-container.sh +4 -6
  43. data/ext/ffi_c/libffi/.ci/build.sh +124 -0
  44. data/ext/ffi_c/libffi/{.travis → .ci}/install.sh +14 -7
  45. data/ext/ffi_c/libffi/.ci/msvs-detect +1103 -0
  46. data/ext/ffi_c/libffi/{.travis → .ci}/site.exp +5 -3
  47. data/ext/ffi_c/libffi/.circleci/config.yml +156 -0
  48. data/ext/ffi_c/libffi/.github/workflows/build.yml +479 -0
  49. data/ext/ffi_c/libffi/.github/workflows/emscripten.yml +172 -0
  50. data/ext/ffi_c/libffi/.gitignore +10 -2
  51. data/ext/ffi_c/libffi/LICENSE +1 -1
  52. data/ext/ffi_c/libffi/Makefile.am +12 -5
  53. data/ext/ffi_c/libffi/Makefile.in +118 -51
  54. data/ext/ffi_c/libffi/README.md +150 -105
  55. data/ext/ffi_c/libffi/acinclude.m4 +10 -112
  56. data/ext/ffi_c/libffi/compile +348 -0
  57. data/ext/ffi_c/libffi/config.guess +623 -556
  58. data/ext/ffi_c/libffi/config.sub +75 -34
  59. data/ext/ffi_c/libffi/configure +4571 -3830
  60. data/ext/ffi_c/libffi/configure.ac +64 -28
  61. data/ext/ffi_c/libffi/configure.host +26 -7
  62. data/ext/ffi_c/libffi/doc/Makefile.in +9 -6
  63. data/ext/ffi_c/libffi/doc/libffi.texi +82 -33
  64. data/ext/ffi_c/libffi/doc/version.texi +4 -4
  65. data/ext/ffi_c/libffi/fficonfig.h.in +12 -47
  66. data/ext/ffi_c/libffi/generate-darwin-source-and-headers.py +163 -52
  67. data/ext/ffi_c/libffi/include/Makefile.am +1 -1
  68. data/ext/ffi_c/libffi/include/Makefile.in +10 -9
  69. data/ext/ffi_c/libffi/include/ffi.h.in +55 -60
  70. data/ext/ffi_c/libffi/include/ffi_cfi.h +21 -0
  71. data/ext/ffi_c/libffi/include/ffi_common.h +33 -2
  72. data/ext/ffi_c/libffi/include/tramp.h +45 -0
  73. data/ext/ffi_c/libffi/install-sh +92 -69
  74. data/ext/ffi_c/libffi/libffi.map.in +5 -0
  75. data/ext/ffi_c/libffi/libtool-version +2 -2
  76. data/ext/ffi_c/libffi/ltmain.sh +518 -333
  77. data/ext/ffi_c/libffi/m4/ax_cc_maxopt.m4 +18 -14
  78. data/ext/ffi_c/libffi/m4/ax_cflags_warn_all.m4 +108 -72
  79. data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +76 -45
  80. data/ext/ffi_c/libffi/m4/ax_prepend_flag.m4 +51 -0
  81. data/ext/ffi_c/libffi/man/Makefile.in +9 -6
  82. data/ext/ffi_c/libffi/missing +1 -1
  83. data/ext/ffi_c/libffi/msvc_build/aarch64/aarch64_include/ffi.h +2 -2
  84. data/ext/ffi_c/libffi/msvcc.sh +1 -1
  85. data/ext/ffi_c/libffi/src/aarch64/ffi.c +172 -55
  86. data/ext/ffi_c/libffi/src/aarch64/internal.h +32 -0
  87. data/ext/ffi_c/libffi/src/aarch64/sysv.S +331 -87
  88. data/ext/ffi_c/libffi/src/arc/arcompact.S +169 -94
  89. data/ext/ffi_c/libffi/src/arc/ffi.c +325 -148
  90. data/ext/ffi_c/libffi/src/arc/ffitarget.h +14 -0
  91. data/ext/ffi_c/libffi/src/arm/ffi.c +62 -17
  92. data/ext/ffi_c/libffi/src/arm/ffitarget.h +3 -3
  93. data/ext/ffi_c/libffi/src/arm/internal.h +10 -0
  94. data/ext/ffi_c/libffi/src/arm/sysv.S +113 -42
  95. data/ext/ffi_c/libffi/src/closures.c +136 -50
  96. data/ext/ffi_c/libffi/src/debug.c +2 -2
  97. data/ext/ffi_c/libffi/src/dlmalloc.c +6 -1
  98. data/ext/ffi_c/libffi/src/ia64/ffi.c +12 -0
  99. data/ext/ffi_c/libffi/src/ia64/unix.S +20 -2
  100. data/ext/ffi_c/libffi/src/loongarch64/ffi.c +624 -0
  101. data/ext/ffi_c/libffi/src/loongarch64/ffitarget.h +82 -0
  102. data/ext/ffi_c/libffi/src/loongarch64/sysv.S +327 -0
  103. data/ext/ffi_c/libffi/src/m32r/ffi.c +31 -14
  104. data/ext/ffi_c/libffi/src/mips/ffi.c +250 -67
  105. data/ext/ffi_c/libffi/src/mips/ffitarget.h +7 -0
  106. data/ext/ffi_c/libffi/src/mips/n32.S +193 -33
  107. data/ext/ffi_c/libffi/src/mips/o32.S +61 -4
  108. data/ext/ffi_c/libffi/src/moxie/ffi.c +47 -22
  109. data/ext/ffi_c/libffi/src/or1k/ffi.c +25 -12
  110. data/ext/ffi_c/libffi/src/pa/ffi.c +32 -33
  111. data/ext/ffi_c/libffi/src/pa/ffi64.c +614 -0
  112. data/ext/ffi_c/libffi/src/pa/ffitarget.h +22 -8
  113. data/ext/ffi_c/libffi/src/pa/hpux32.S +83 -36
  114. data/ext/ffi_c/libffi/src/pa/hpux64.S +681 -0
  115. data/ext/ffi_c/libffi/src/pa/linux.S +82 -35
  116. data/ext/ffi_c/libffi/src/powerpc/ffi_darwin.c +36 -24
  117. data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +1 -1
  118. data/ext/ffi_c/libffi/src/powerpc/linux64.S +2 -0
  119. data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +2 -0
  120. data/ext/ffi_c/libffi/src/powerpc/t-aix +5 -0
  121. data/ext/ffi_c/libffi/src/prep_cif.c +22 -2
  122. data/ext/ffi_c/libffi/src/riscv/ffi.c +37 -4
  123. data/ext/ffi_c/libffi/src/sparc/ffi64.c +23 -1
  124. data/ext/ffi_c/libffi/src/tramp.c +716 -0
  125. data/ext/ffi_c/libffi/src/types.c +4 -6
  126. data/ext/ffi_c/libffi/src/wasm32/ffi.c +947 -0
  127. data/ext/ffi_c/libffi/src/wasm32/ffitarget.h +62 -0
  128. data/ext/ffi_c/libffi/src/x86/ffi.c +99 -37
  129. data/ext/ffi_c/libffi/src/x86/ffi64.c +67 -12
  130. data/ext/ffi_c/libffi/src/x86/ffitarget.h +9 -5
  131. data/ext/ffi_c/libffi/src/x86/ffiw64.c +44 -1
  132. data/ext/ffi_c/libffi/src/x86/internal.h +14 -0
  133. data/ext/ffi_c/libffi/src/x86/internal64.h +14 -0
  134. data/ext/ffi_c/libffi/src/x86/sysv.S +172 -38
  135. data/ext/ffi_c/libffi/src/x86/sysv_intel.S +91 -88
  136. data/ext/ffi_c/libffi/src/x86/unix64.S +96 -6
  137. data/ext/ffi_c/libffi/src/x86/win64.S +20 -7
  138. data/ext/ffi_c/libffi/src/xtensa/ffi.c +16 -8
  139. data/ext/ffi_c/libffi/src/xtensa/ffitarget.h +4 -0
  140. data/ext/ffi_c/libffi/src/xtensa/sysv.S +26 -16
  141. data/ext/ffi_c/libffi/testsuite/Makefile.am +79 -114
  142. data/ext/ffi_c/libffi/testsuite/Makefile.in +89 -121
  143. data/ext/ffi_c/libffi/testsuite/emscripten/build-tests.sh +54 -0
  144. data/ext/ffi_c/libffi/testsuite/emscripten/build.sh +63 -0
  145. data/ext/ffi_c/libffi/testsuite/emscripten/conftest.py +86 -0
  146. data/ext/ffi_c/libffi/testsuite/emscripten/node-tests.sh +48 -0
  147. data/ext/ffi_c/libffi/testsuite/emscripten/test.html +7 -0
  148. data/ext/ffi_c/libffi/testsuite/emscripten/test_libffi.py +51 -0
  149. data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +43 -21
  150. data/ext/ffi_c/libffi/testsuite/lib/target-libpath.exp +2 -2
  151. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-call.c +1 -0
  152. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/testcases.c +5 -1
  153. data/ext/ffi_c/libffi/testsuite/libffi.call/bpo_38748.c +41 -0
  154. data/ext/ffi_c/libffi/testsuite/libffi.call/callback.c +99 -0
  155. data/ext/ffi_c/libffi/testsuite/libffi.call/callback2.c +108 -0
  156. data/ext/ffi_c/libffi/testsuite/libffi.call/callback3.c +114 -0
  157. data/ext/ffi_c/libffi/testsuite/libffi.call/callback4.c +119 -0
  158. data/ext/ffi_c/libffi/testsuite/libffi.call/ffitest.h +28 -3
  159. data/ext/ffi_c/libffi/testsuite/libffi.call/float_va.c +3 -0
  160. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll1.c +5 -0
  161. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sl.c +4 -0
  162. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ul.c +4 -0
  163. data/ext/ffi_c/libffi/testsuite/libffi.call/s55.c +60 -0
  164. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen.c +8 -9
  165. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen2.c +2 -2
  166. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen3.c +2 -2
  167. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen4.c +2 -2
  168. data/ext/ffi_c/libffi/testsuite/libffi.call/struct10.c +1 -1
  169. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_2.c +63 -0
  170. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_3.c +65 -0
  171. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_3f.c +65 -0
  172. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_4.c +67 -0
  173. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_4f.c +67 -0
  174. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_big.c +93 -0
  175. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_small.c +61 -0
  176. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_return_2H.c +63 -0
  177. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_return_8H.c +90 -0
  178. data/ext/ffi_c/libffi/testsuite/libffi.call/va_1.c +1 -119
  179. data/ext/ffi_c/libffi/testsuite/libffi.call/va_2.c +220 -0
  180. data/ext/ffi_c/libffi/testsuite/libffi.call/va_3.c +154 -0
  181. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct1.c +13 -0
  182. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct2.c +11 -0
  183. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct3.c +15 -0
  184. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn0.c +3 -2
  185. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn1.c +2 -0
  186. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn2.c +2 -0
  187. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn3.c +21 -1
  188. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn4.c +2 -0
  189. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn5.c +2 -0
  190. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_fn6.c +2 -0
  191. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_loc_fn0.c +7 -6
  192. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure_simple.c +6 -0
  193. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_12byte.c +18 -0
  194. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_16byte.c +22 -0
  195. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_18byte.c +24 -0
  196. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_19byte.c +29 -0
  197. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_1_1byte.c +4 -0
  198. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_20byte.c +19 -1
  199. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_20byte1.c +21 -1
  200. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_24byte.c +35 -3
  201. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_2byte.c +13 -0
  202. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3_1byte.c +19 -0
  203. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3byte1.c +13 -0
  204. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3byte2.c +13 -0
  205. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3float.c +18 -0
  206. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_4_1byte.c +22 -0
  207. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_4byte.c +13 -0
  208. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_5_1_byte.c +29 -1
  209. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_5byte.c +19 -1
  210. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_64byte.c +24 -0
  211. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_6_1_byte.c +28 -1
  212. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_6byte.c +24 -2
  213. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_7_1_byte.c +39 -1
  214. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_7byte.c +25 -1
  215. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_8byte.c +14 -0
  216. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_9byte1.c +14 -1
  217. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_9byte2.c +14 -2
  218. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_double.c +19 -1
  219. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_float.c +19 -1
  220. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_longdouble.c +20 -1
  221. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_longdouble_split.c +40 -25
  222. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_longdouble_split2.c +40 -3
  223. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_pointer.c +19 -1
  224. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_sint16.c +18 -1
  225. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_sint32.c +18 -3
  226. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_sint64.c +18 -1
  227. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_uint16.c +18 -1
  228. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_uint32.c +19 -1
  229. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_align_uint64.c +19 -1
  230. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_dbls_struct.c +3 -1
  231. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_double_va.c +9 -1
  232. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_float.c +4 -0
  233. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_longdouble.c +11 -1
  234. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_longdouble_va.c +22 -3
  235. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_schar.c +5 -1
  236. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_sshort.c +6 -1
  237. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_sshortchar.c +9 -1
  238. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_uchar.c +9 -1
  239. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_ushort.c +6 -2
  240. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_multi_ushortchar.c +9 -1
  241. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_pointer.c +5 -0
  242. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_pointer_stack.c +10 -0
  243. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_schar.c +3 -0
  244. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_sint.c +2 -0
  245. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_sshort.c +3 -0
  246. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_struct_va1.c +11 -0
  247. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uchar.c +3 -0
  248. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uint.c +4 -0
  249. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uint_va.c +4 -0
  250. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ulong_va.c +4 -0
  251. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ulonglong.c +2 -0
  252. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ushort.c +3 -0
  253. data/ext/ffi_c/libffi/testsuite/libffi.closures/ffitest.h +1 -138
  254. data/ext/ffi_c/libffi/testsuite/libffi.closures/huge_struct.c +21 -21
  255. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct.c +32 -9
  256. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct1.c +1 -1
  257. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct10.c +12 -0
  258. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct11.c +21 -5
  259. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct12.c +86 -0
  260. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct13.c +115 -0
  261. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct2.c +10 -1
  262. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct3.c +10 -1
  263. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct4.c +9 -0
  264. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct5.c +9 -0
  265. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct6.c +11 -0
  266. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct7.c +9 -0
  267. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct8.c +11 -0
  268. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct9.c +11 -0
  269. data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs1.c +86 -0
  270. data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs2.c +102 -0
  271. data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs3.c +101 -0
  272. data/ext/ffi_c/libffi/testsuite/libffi.closures/stret_medium.c +1 -1
  273. data/ext/ffi_c/libffi/testsuite/libffi.closures/stret_medium2.c +1 -1
  274. data/ext/ffi_c/libffi/testsuite/libffi.closures/testclosure.c +6 -1
  275. data/ext/ffi_c/libffi/testsuite/libffi.closures/unwindtest.cc +2 -1
  276. data/ext/ffi_c/libffi/testsuite/libffi.closures/unwindtest_ffi_call.cc +1 -0
  277. data/ext/ffi_c/libffi.bsd.mk +2 -2
  278. data/ext/ffi_c/libffi.darwin.mk +2 -2
  279. data/ext/ffi_c/libffi.gnu.mk +2 -2
  280. data/ext/ffi_c/rbffi.h +1 -1
  281. data/ffi.gemspec +3 -3
  282. data/lib/ffi/autopointer.rb +8 -31
  283. data/lib/ffi/compat.rb +43 -0
  284. data/lib/ffi/data_converter.rb +2 -2
  285. data/lib/ffi/dynamic_library.rb +118 -0
  286. data/lib/ffi/enum.rb +18 -12
  287. data/lib/ffi/ffi.rb +3 -0
  288. data/lib/ffi/function.rb +71 -0
  289. data/lib/ffi/io.rb +2 -2
  290. data/lib/ffi/library.rb +72 -88
  291. data/lib/ffi/library_path.rb +109 -0
  292. data/lib/ffi/managedstruct.rb +1 -1
  293. data/lib/ffi/platform/aarch64-linux/types.conf +74 -3
  294. data/lib/ffi/platform/aarch64-windows/types.conf +52 -0
  295. data/lib/ffi/platform/hppa1.1-linux/types.conf +178 -0
  296. data/lib/ffi/platform/hppa2.0-linux/types.conf +178 -0
  297. data/lib/ffi/platform/loongarch64-linux/types.conf +141 -0
  298. data/lib/ffi/platform/sw_64-linux/types.conf +141 -0
  299. data/lib/ffi/platform.rb +15 -13
  300. data/lib/ffi/pointer.rb +6 -6
  301. data/lib/ffi/struct.rb +6 -5
  302. data/lib/ffi/struct_layout.rb +3 -3
  303. data/lib/ffi/struct_layout_builder.rb +9 -9
  304. data/lib/ffi/types.rb +65 -37
  305. data/lib/ffi/variadic.rb +19 -8
  306. data/lib/ffi/version.rb +1 -1
  307. data/samples/hello_ractor.rb +11 -0
  308. data/samples/qsort_ractor.rb +28 -0
  309. data/sig/ffi/abstract_memory.rbs +165 -0
  310. data/sig/ffi/auto_pointer.rbs +27 -0
  311. data/sig/ffi/buffer.rbs +18 -0
  312. data/sig/ffi/data_converter.rbs +10 -0
  313. data/sig/ffi/dynamic_library.rbs +9 -0
  314. data/sig/ffi/enum.rbs +38 -0
  315. data/sig/ffi/function.rbs +39 -0
  316. data/sig/ffi/library.rbs +42 -0
  317. data/sig/ffi/native_type.rbs +86 -0
  318. data/sig/ffi/pointer.rbs +42 -0
  319. data/sig/ffi/struct.rbs +76 -0
  320. data/sig/ffi/struct_by_reference.rbs +11 -0
  321. data/sig/ffi/struct_by_value.rbs +7 -0
  322. data/sig/ffi/struct_layout.rbs +9 -0
  323. data/sig/ffi/struct_layout_builder.rbs +5 -0
  324. data/sig/ffi/type.rbs +39 -0
  325. data/sig/ffi.rbs +26 -0
  326. data.tar.gz.sig +0 -0
  327. metadata +122 -28
  328. metadata.gz.sig +1 -0
  329. data/ext/ffi_c/libffi/.travis/build-cross-in-container.sh +0 -14
  330. data/ext/ffi_c/libffi/.travis/build.sh +0 -142
  331. data/ext/ffi_c/libffi/.travis.yml +0 -83
  332. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uchar_va.c +0 -44
  333. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ushort_va.c +0 -44
  334. /data/ext/ffi_c/libffi/{.travis → .ci}/ar-lib +0 -0
  335. /data/ext/ffi_c/libffi/{.travis → .ci}/bfin-sim.exp +0 -0
  336. /data/ext/ffi_c/libffi/{.travis → .ci}/compile +0 -0
  337. /data/ext/ffi_c/libffi/{.travis → .ci}/m32r-sim.exp +0 -0
  338. /data/ext/ffi_c/libffi/{.travis → .ci}/moxie-sim.exp +0 -0
  339. /data/ext/ffi_c/libffi/{.travis → .ci}/or1k-sim.exp +0 -0
  340. /data/ext/ffi_c/libffi/{.travis → .ci}/powerpc-eabisim.exp +0 -0
  341. /data/ext/ffi_c/libffi/{.travis → .ci}/wine-sim.exp +0 -0
  342. /data/ext/ffi_c/libffi/testsuite/libffi.call/{pyobjc-tc.c → pyobjc_tc.c} +0 -0
  343. /data/lib/ffi/platform/{sparc64-linux → sparcv9-linux}/types.conf +0 -0
@@ -0,0 +1,54 @@
1
+ #!/usr/bin/env bash
2
+ emcc_exists="$(command -v emcc)"
3
+ if [ ! "${emcc_exists}" ]; then
4
+ echo "Emscripten not on path"
5
+ exit 1
6
+ fi
7
+
8
+ set -e
9
+
10
+ cd "$1"
11
+ shift
12
+
13
+ # Parse arguments
14
+ while [ $# -gt 0 ]; do
15
+ case $1 in
16
+ --wasm-bigint) WASM_BIGINT=true ;;
17
+ *)
18
+ echo "ERROR: Unknown parameter: $1" >&2
19
+ exit 1
20
+ ;;
21
+ esac
22
+ shift
23
+ done
24
+
25
+
26
+ export CFLAGS="-fPIC -O2 -I../../target/include $EXTRA_CFLAGS"
27
+ export CXXFLAGS="$CFLAGS -sNO_DISABLE_EXCEPTION_CATCHING $EXTRA_CXXFLAGS"
28
+ export LDFLAGS=" \
29
+ -L../../target/lib/ -lffi \
30
+ -sEXPORT_ALL \
31
+ -sMODULARIZE \
32
+ -sMAIN_MODULE \
33
+ -sNO_DISABLE_EXCEPTION_CATCHING \
34
+ $EXTRA_LD_FLAGS \
35
+ "
36
+
37
+ # This needs to test false if there exists an environment variable called
38
+ # WASM_BIGINT whose contents are empty. Don't use +x.
39
+ if [ -n "${WASM_BIGINT}" ] ; then
40
+ export LDFLAGS+=" -sWASM_BIGINT"
41
+ else
42
+ export LDFLAGS+=" -sEXPORTED_RUNTIME_METHODS='getTempRet0,setTempRet0'"
43
+ fi
44
+
45
+ # Rename main functions to test__filename so we can link them together
46
+ ls *c | sed 's!\(.*\)\.c!sed -i "s/main/test__\1/g" \0!g' | bash
47
+
48
+ # Compile
49
+ ls *.c | sed 's/\(.*\)\.c/emcc $CFLAGS -c \1.c -o \1.o /g' | bash
50
+ ls *.cc | sed 's/\(.*\)\.cc/em++ $CXXFLAGS -c \1.cc -o \1.o /g' | bash
51
+
52
+ # Link
53
+ em++ $LDFLAGS *.o -o test.js
54
+ cp ../emscripten/test.html .
@@ -0,0 +1,63 @@
1
+ #!/usr/bin/env bash
2
+ command -v emcc >/dev/null 2>&1 || {
3
+ echo >&2 "emsdk could not be found. Aborting."
4
+ exit 1
5
+ }
6
+
7
+ set -e
8
+
9
+ SOURCE_DIR=$PWD
10
+
11
+ # Working directories
12
+ TARGET=$SOURCE_DIR/target
13
+ mkdir -p "$TARGET"
14
+
15
+ # Define default arguments
16
+
17
+ # JS BigInt to Wasm i64 integration, disabled by default
18
+ # This needs to test false if there exists an environment variable called
19
+ # WASM_BIGINT whose contents are empty. Don't use +x.
20
+ if [ -n "${WASM_BIGINT}" ]; then
21
+ WASM_BIGINT=true
22
+ else
23
+ WASM_BIGINT=false
24
+ fi
25
+
26
+ # Parse arguments
27
+ while [ $# -gt 0 ]; do
28
+ case $1 in
29
+ --wasm-bigint) WASM_BIGINT=true ;;
30
+ --debug) DEBUG=true ;;
31
+ *)
32
+ echo "ERROR: Unknown parameter: $1" >&2
33
+ exit 1
34
+ ;;
35
+ esac
36
+ shift
37
+ done
38
+
39
+ # Common compiler flags
40
+ export CFLAGS="-O3 -fPIC"
41
+ if [ "$WASM_BIGINT" = "true" ]; then
42
+ # We need to detect WASM_BIGINT support at compile time
43
+ export CFLAGS+=" -DWASM_BIGINT"
44
+ fi
45
+ if [ "$DEBUG" = "true" ]; then
46
+ export CFLAGS+=" -DDEBUG_F"
47
+ fi
48
+ export CXXFLAGS="$CFLAGS"
49
+
50
+ # Build paths
51
+ export CPATH="$TARGET/include"
52
+ export PKG_CONFIG_PATH="$TARGET/lib/pkgconfig"
53
+ export EM_PKG_CONFIG_PATH="$PKG_CONFIG_PATH"
54
+
55
+ # Specific variables for cross-compilation
56
+ export CHOST="wasm32-unknown-linux" # wasm32-unknown-emscripten
57
+
58
+ autoreconf -fiv
59
+ emconfigure ./configure --host=$CHOST --prefix="$TARGET" --enable-static --disable-shared --disable-dependency-tracking \
60
+ --disable-builddir --disable-multi-os-directory --disable-raw-api --disable-docs
61
+ make install
62
+ cp fficonfig.h target/include/
63
+ cp include/ffi_common.h target/include/
@@ -0,0 +1,86 @@
1
+ from pathlib import Path
2
+ from pytest import fixture
3
+ from pytest_pyodide.server import spawn_web_server
4
+ from pytest_pyodide import runner
5
+
6
+ import logging
7
+
8
+ TEST_PATH = Path(__file__).parents[1].resolve()
9
+
10
+
11
+ class BaseRunner(runner._BrowserBaseRunner):
12
+ def __init__(
13
+ self,
14
+ *args,
15
+ test_dir,
16
+ **kwargs,
17
+ ):
18
+ self.test_dir = test_dir
19
+ super().__init__(
20
+ *args,
21
+ **kwargs,
22
+ load_pyodide=False,
23
+ )
24
+
25
+ def prepare_driver(self):
26
+ self.base_url = (
27
+ f"http://{self.server_hostname}:{self.server_port}/{self.test_dir}/"
28
+ )
29
+ self.goto(f"{self.base_url}/test.html")
30
+
31
+ def javascript_setup(self):
32
+ self.run_js("globalThis.TestModule = await globalThis.Module();")
33
+
34
+
35
+ class FirefoxRunner(BaseRunner, runner.SeleniumFirefoxRunner):
36
+ pass
37
+
38
+
39
+ class ChromeRunner(BaseRunner, runner.SeleniumChromeRunner):
40
+ pass
41
+
42
+
43
+ # TODO: Figure out how to get NodeRunner to work.
44
+
45
+ RUNNER_DICT = {x.browser: x for x in [FirefoxRunner, ChromeRunner]}
46
+
47
+
48
+ @fixture(params=list(RUNNER_DICT), scope="class")
49
+ def selenium_class_scope(request, web_server_main):
50
+ server_hostname, server_port, server_log = web_server_main
51
+ assert request.param in RUNNER_DICT
52
+
53
+ logger = logging.getLogger('selenium')
54
+ logger.setLevel(logging.DEBUG)
55
+
56
+ cls = RUNNER_DICT[request.param]
57
+ selenium = cls(
58
+ test_dir=request.cls.TEST_BUILD_DIR,
59
+ server_port=server_port,
60
+ server_hostname=server_hostname,
61
+ server_log=server_log,
62
+ )
63
+ request.cls.call_number = 0
64
+ try:
65
+ yield selenium
66
+ finally:
67
+ print(selenium.logs)
68
+ selenium.driver.quit()
69
+
70
+
71
+ @fixture(scope="function")
72
+ def selenium(selenium_class_scope, request):
73
+ selenium = selenium_class_scope
74
+ request.cls.call_number += 1
75
+ # Refresh page every 50 calls to prevent firefox out of memory errors
76
+ if request.cls.call_number % 50 == 0:
77
+ selenium.driver.refresh()
78
+ selenium.javascript_setup()
79
+ selenium.clean_logs()
80
+ yield selenium
81
+
82
+
83
+ @fixture(scope="session")
84
+ def web_server_main(request):
85
+ with spawn_web_server(TEST_PATH) as output:
86
+ yield output
@@ -0,0 +1,48 @@
1
+ #!/bin/bash
2
+
3
+ # JS BigInt to Wasm i64 integration, disabled by default
4
+ WASM_BIGINT=false
5
+
6
+ emcc_exists="$(command -v emcc)"
7
+ if [ ! "${emcc_exists}" ]; then
8
+ echo "Emscripten not on path"
9
+ exit 1
10
+ fi
11
+
12
+ # Parse arguments
13
+ while [ $# -gt 0 ]; do
14
+ case $1 in
15
+ --wasm-bigint) WASM_BIGINT=true ;;
16
+ *)
17
+ echo "ERROR: Unknown parameter: $1" >&2
18
+ exit 1
19
+ ;;
20
+ esac
21
+ shift
22
+ done
23
+
24
+ # Common compiler flags
25
+ export CFLAGS="-fPIC $EXTRA_CFLAGS"
26
+ if [ "$WASM_BIGINT" = "true" ]; then
27
+ # We need to detect WASM_BIGINT support at compile time
28
+ export CFLAGS+=" -DWASM_BIGINT"
29
+ fi
30
+ export CXXFLAGS="$CFLAGS -sNO_DISABLE_EXCEPTION_CATCHING $EXTRA_CXXFLAGS"
31
+ export LDFLAGS="-sEXPORTED_FUNCTIONS=_main,_malloc,_free -sALLOW_TABLE_GROWTH -sASSERTIONS -sNO_DISABLE_EXCEPTION_CATCHING"
32
+ if [ "$WASM_BIGINT" = "true" ]; then
33
+ export LDFLAGS+=" -sWASM_BIGINT"
34
+ else
35
+ export LDFLAGS+=" -sEXPORTED_RUNTIME_METHODS='getTempRet0,setTempRet0'"
36
+ fi
37
+
38
+ # Specific variables for cross-compilation
39
+ export CHOST="wasm32-unknown-linux" # wasm32-unknown-emscripten
40
+
41
+ autoreconf -fiv
42
+ emconfigure ./configure --prefix="$(pwd)/target" --host=$CHOST --enable-static --disable-shared \
43
+ --disable-builddir --disable-multi-os-directory --disable-raw-api --disable-docs ||
44
+ (cat config.log && exit 1)
45
+ make
46
+
47
+ EMMAKEN_JUST_CONFIGURE=1 emmake make check \
48
+ RUNTESTFLAGS="LDFLAGS_FOR_TARGET='$LDFLAGS'" || (cat testsuite/libffi.log && exit 1)
@@ -0,0 +1,7 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <script src="test.js"></script>
5
+ </head>
6
+ <body></body>
7
+ </html>
@@ -0,0 +1,51 @@
1
+ import subprocess
2
+ import pathlib
3
+ import pytest
4
+
5
+ TEST_PATH = pathlib.Path(__file__).parents[1].resolve()
6
+
7
+ xfails = {}
8
+
9
+
10
+ def libffi_tests(self, selenium, libffi_test):
11
+ if libffi_test in xfails:
12
+ pytest.xfail(f'known failure with code "{xfails[libffi_test]}"')
13
+ res = selenium.run_js(
14
+ """
15
+ window.TestModule = await Module();
16
+ """
17
+ )
18
+ selenium.run_js(
19
+ f"""
20
+ try {{
21
+ TestModule._test__{libffi_test}();
22
+ }} catch(e){{
23
+ if(e.name !== "ExitStatus"){{
24
+ throw e;
25
+ }}
26
+ if(e.status !== 0){{
27
+ throw new Error(`Terminated with nonzero status code ${{e.status}}: ` + e.message);
28
+ }}
29
+ }}
30
+ """
31
+ )
32
+
33
+
34
+ class TestCall:
35
+ TEST_BUILD_DIR = "libffi.call.test"
36
+ test_call = libffi_tests
37
+
38
+
39
+ class TestClosures:
40
+ TEST_BUILD_DIR = "libffi.closures.test"
41
+ test_closures = libffi_tests
42
+
43
+
44
+ def pytest_generate_tests(metafunc):
45
+ test_build_dir = metafunc.cls.TEST_BUILD_DIR
46
+ test_names = [x.stem for x in (TEST_PATH / test_build_dir).glob("*.o")]
47
+ metafunc.parametrize("libffi_test", test_names)
48
+
49
+
50
+ if __name__ == "__main__":
51
+ subprocess.call(["build-tests.sh", "libffi.call"])
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2003, 2005, 2008, 2009, 2010, 2011, 2014, 2019 Free Software Foundation, Inc.
1
+ # Copyright (C) 2003, 2005, 2008, 2009, 2010, 2011, 2014, 2019, 2022 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
@@ -45,7 +45,7 @@ proc is-effective-target { arg } {
45
45
  if { [info procs check_effective_target_${arg}] != [list] } {
46
46
  set selected [check_effective_target_${arg}]
47
47
  } else {
48
- error "unknown effective target keyword `$arg'"
48
+ error "unknown effective target keyword `$arg'"
49
49
  }
50
50
  verbose "is-effective-target: $arg $selected" 2
51
51
  return $selected
@@ -196,7 +196,7 @@ if { [info procs saved-dg-process-target] == [list] } {
196
196
  return "N"
197
197
  }
198
198
  return [dg-process-target-1 $xfail_selector]
199
-
199
+
200
200
  }
201
201
  return [dg-process-target-1 $selector]
202
202
  }
@@ -221,6 +221,13 @@ proc libffi-dg-test-1 { target_compile prog do_what extra_tool_flags } {
221
221
  set output_match [lreplace $output_match 1 1 $x]
222
222
  }
223
223
 
224
+ if { [ istarget "wasm32-*-*" ] } {
225
+ # emscripten will get confused if told to build as .exe
226
+ set exec_suffix ""
227
+ } else {
228
+ set exec_suffix ".exe"
229
+ }
230
+
224
231
  # Set up the compiler flags, based on what we're going to do.
225
232
 
226
233
  set options [list]
@@ -231,7 +238,7 @@ proc libffi-dg-test-1 { target_compile prog do_what extra_tool_flags } {
231
238
  }
232
239
  "link" {
233
240
  set compile_type "executable"
234
- set output_file "[file rootname [file tail $prog]].exe"
241
+ set output_file "[file rootname [file tail $prog]]$exec_suffix"
235
242
  # The following line is needed for targets like the i960 where
236
243
  # the default output file is b.out. Sigh.
237
244
  }
@@ -240,7 +247,7 @@ proc libffi-dg-test-1 { target_compile prog do_what extra_tool_flags } {
240
247
  # FIXME: "./" is to cope with "." not being in $PATH.
241
248
  # Should this be handled elsewhere?
242
249
  # YES.
243
- set output_file "./[file rootname [file tail $prog]].exe"
250
+ set output_file "./[file rootname [file tail $prog]]$exec_suffix"
244
251
  # This is the only place where we care if an executable was
245
252
  # created or not. If it was, dg.exp will try to run it.
246
253
  remote_file build delete $output_file;
@@ -269,6 +276,10 @@ proc libffi-dg-test { prog do_what extra_tool_flags } {
269
276
  proc libffi-dg-prune { target_triplet text } {
270
277
  # We get this with some qemu emulated systems (eg. ppc64le-linux-gnu)
271
278
  regsub -all "(^|\n)\[^\n\]*unable to perform all requested operations" $text "" text
279
+ # We get this from sparc64 linux systems
280
+ regsub -all "(^|\n)\[^\n\]*warning: .* has a LOAD segment with RWX permissions" $text "" text
281
+ # Ignore Emscripten INFO messages
282
+ regsub -all "(^|\n)(cache|shared):INFO:\[^\n\]*" $text "" text
272
283
  return $text
273
284
  }
274
285
 
@@ -292,9 +303,6 @@ proc libffi-init { args } {
292
303
  verbose "libffi $blddirffi"
293
304
 
294
305
  # Which compiler are we building with?
295
- set tmp [grep "$blddirffi/config.log" "^ax_cv_c_compiler_vendor.*$"]
296
- regexp -- {^[^=]*=(.*)$} $tmp nil compiler_vendor
297
-
298
306
  if { [string match $compiler_vendor "gnu"] } {
299
307
  set gccdir [lookfor_file $tool_root_dir gcc/libgcc.a]
300
308
  if {$gccdir != ""} {
@@ -379,7 +387,9 @@ proc libffi_target_compile { source dest type options } {
379
387
 
380
388
  if { [istarget "*-*-darwin9*"] || [istarget "*-*-darwin1*"]
381
389
  || [istarget "*-*-darwin2*"] } {
382
- lappend options "additional_flags=-Wl,-allow_stack_execute"
390
+ # lappend options "additional_flags=-Wl,-allow_stack_execute"
391
+ lappend options "additional_flags=-Wno-unused-command-line-argument"
392
+ lappend options "additional_flags=-Wl,-search_paths_first"
383
393
  }
384
394
 
385
395
  # If you're building the compiler with --prefix set to a place
@@ -397,17 +407,29 @@ proc libffi_target_compile { source dest type options } {
397
407
 
398
408
  lappend options "libs= -lffi"
399
409
 
400
- if { [string match "aarch64*-*-linux*" $target_triplet] } {
401
- lappend options "libs= -lpthread"
402
- }
410
+ if { ![string match "*android*" $target_triplet] } {
411
+
412
+ if { [string match "aarch64*-*-linux*" $target_triplet] } {
413
+ lappend options "libs= -lpthread"
414
+ }
403
415
 
404
- # this may be required for g++, but just confused clang.
405
- if { [string match "*.cc" $source] } {
406
- lappend options "c++"
416
+ # this may be required for g++, but just confused clang.
417
+ if { [string match "*.cc" $source] } {
418
+ lappend options "c++"
419
+ if { [string match "*-*-darwin*" $target_triplet] } {
420
+ lappend options "libs= -lc++"
421
+ }
422
+ }
423
+
424
+ if { [string match "arc*-*-linux*" $target_triplet] } {
425
+ lappend options "libs= -lpthread"
426
+ }
407
427
  }
408
428
 
409
- if { [string match "arc*-*-linux*" $target_triplet] } {
410
- lappend options "libs= -lpthread"
429
+ # emscripten emits this warning while building the feature test
430
+ # which causes it to be seen as unsupported.
431
+ if { [string match "wasm32-*" $target_triplet] } {
432
+ lappend options "additional_flags=-Wno-unused-command-line-argument"
411
433
  }
412
434
 
413
435
  verbose "options: $options"
@@ -489,7 +511,7 @@ proc run-many-tests { testcases extra_flags } {
489
511
  set common "-W -Wall"
490
512
  if [info exists env(LIBFFI_TEST_OPTIMIZATION)] {
491
513
  set optimizations [ list $env(LIBFFI_TEST_OPTIMIZATION) ]
492
- } else {
514
+ } else {
493
515
  set optimizations { "-O0" "-O2" }
494
516
  }
495
517
  }
@@ -497,7 +519,7 @@ proc run-many-tests { testcases extra_flags } {
497
519
  set common "-W -Wall -Wno-psabi"
498
520
  if [info exists env(LIBFFI_TEST_OPTIMIZATION)] {
499
521
  set optimizations [ list $env(LIBFFI_TEST_OPTIMIZATION) ]
500
- } else {
522
+ } else {
501
523
  set optimizations { "-O0" "-O2" }
502
524
  }
503
525
  }
@@ -506,7 +528,7 @@ proc run-many-tests { testcases extra_flags } {
506
528
  set common ""
507
529
  if [info exists env(LIBFFI_TEST_OPTIMIZATION)] {
508
530
  set optimizations [ list $env(LIBFFI_TEST_OPTIMIZATION) ]
509
- } else {
531
+ } else {
510
532
  set optimizations { "" }
511
533
  }
512
534
  }
@@ -595,7 +617,7 @@ proc check-flags { args } {
595
617
  # compare them to the actual options.
596
618
  if { [string compare [lindex $args 2] "*"] == 0
597
619
  && [string compare [lindex $args 3] "" ] == 0 } {
598
- set result 1
620
+ set result 1
599
621
  } else {
600
622
  # The target list might be an effective-target keyword, so replace
601
623
  # the original list with "*-*-*", since we already know it matches.
@@ -175,7 +175,7 @@ proc set_ld_library_path_env_vars { } {
175
175
  } else {
176
176
  setenv DYLD_LIBRARY_PATH "$ld_library_path"
177
177
  }
178
- if { [istarget *-*-cygwin*] || [istarget *-*-mingw*] } {
178
+ if { [istarget *-*-cygwin*] || [ istarget *-*-msys* ] || [istarget *-*-mingw*] } {
179
179
  if { $orig_path_saved } {
180
180
  setenv PATH "$ld_library_path:$orig_path"
181
181
  } else {
@@ -271,7 +271,7 @@ proc get_shlib_extension { } {
271
271
 
272
272
  if { [ istarget *-*-darwin* ] } {
273
273
  set shlib_ext "dylib"
274
- } elseif { [ istarget *-*-cygwin* ] || [ istarget *-*-mingw* ] } {
274
+ } elseif { [ istarget *-*-cygwin* ] || [ istarget *-*-msys* ] || [ istarget *-*-mingw* ] } {
275
275
  set shlib_ext "dll"
276
276
  } elseif { [ istarget hppa*-*-hpux* ] } {
277
277
  set shlib_ext "sl"
@@ -50,6 +50,7 @@ int _fprintf(FILE *stream, const char *format, ...)
50
50
  case 3:
51
51
  vsprintf(&rbuf2[strlen(rbuf2)], format, args);
52
52
  printf("%s", rbuf2);
53
+ fflush (stdout);
53
54
  if (strcmp (rbuf1, rbuf2)) abort();
54
55
  break;
55
56
  }
@@ -64,7 +64,11 @@ typedef struct {
64
64
  typedef struct { char c[3]; } T;
65
65
  typedef struct { char c[33],c1; } X;
66
66
 
67
- char c1='a', c2=127, c3=(char)128, c4=(char)255, c5=-1;
67
+ /* Don't use a number over 127, as some systems use signed chars and
68
+ the test case 25 doesn't account for this, resulting in undefined
69
+ behavior. See https://github.com/libffi/libffi/issues/598. */
70
+ char c1='a', c2=127, c3=(char)1;
71
+
68
72
  short s1=32767, s2=(short)32768, s3=3, s4=4, s5=5, s6=6, s7=7, s8=8, s9=9;
69
73
  int i1=1, i2=2, i3=3, i4=4, i5=5, i6=6, i7=7, i8=8, i9=9,
70
74
  i10=11, i11=12, i12=13, i13=14, i14=15, i15=16, i16=17;
@@ -0,0 +1,41 @@
1
+ /* Area: bpo-38748
2
+ Purpose: test for stdcall alignment problem
3
+ Source: github.com/python/cpython/pull/26204 */
4
+
5
+ /* { dg-do run } */
6
+
7
+ #include "ffitest.h"
8
+ #include "ffi_common.h"
9
+
10
+ static UINT32 ABI_ATTR align_arguments(UINT32 l1,
11
+ UINT64 l2)
12
+ {
13
+ return l1 + (UINT32) l2;
14
+ }
15
+
16
+ int main(void)
17
+ {
18
+ ffi_cif cif;
19
+ ffi_type *args[4] = {
20
+ &ffi_type_uint32,
21
+ &ffi_type_uint64
22
+ };
23
+ ffi_arg lr1, lr2;
24
+ UINT32 l1 = 1;
25
+ UINT64 l2 = 2;
26
+ void *values[2] = {&l1, &l2};
27
+
28
+ /* Initialize the cif */
29
+ CHECK(ffi_prep_cif(&cif, ABI_NUM, 2,
30
+ &ffi_type_uint32, args) == FFI_OK);
31
+
32
+ lr1 = align_arguments(l1, l2);
33
+
34
+ ffi_call(&cif, FFI_FN(align_arguments), &lr2, values);
35
+
36
+ if (lr1 == lr2)
37
+ printf("bpo-38748 arguments tests ok!\n");
38
+ else
39
+ CHECK(0);
40
+ exit(0);
41
+ }
@@ -0,0 +1,99 @@
1
+ /* Area: ffi_call
2
+ Purpose: Check structures with array and callback.
3
+ Limitations: none.
4
+ PR: none.
5
+ Originator: David Tenty <daltenty@ibm.com> */
6
+
7
+ /* { dg-do run } */
8
+ #include "ffitest.h"
9
+
10
+ int i=5;
11
+
12
+ void callback(void) { i++; }
13
+
14
+ typedef struct
15
+ {
16
+ unsigned char c1;
17
+ double s[2];
18
+ unsigned char c2;
19
+ } test_structure_12;
20
+
21
+ static test_structure_12 ABI_ATTR struct12 (test_structure_12 ts, void (*func)(void))
22
+ {
23
+ ts.c1 += 1;
24
+ ts.c2 += 1;
25
+ ts.s[0] += 1;
26
+ ts.s[1] += 1;
27
+
28
+ func();
29
+ return ts;
30
+ }
31
+
32
+ int main (void)
33
+ {
34
+ ffi_cif cif;
35
+ ffi_type *args[MAX_ARGS];
36
+ void *values[MAX_ARGS];
37
+ ffi_type ts12_type,ts12a_type;
38
+ ffi_type *ts12_type_elements[4];
39
+ ffi_type *ts12a_type_elements[3];
40
+
41
+ test_structure_12 ts12_arg;
42
+ void (*ptr)(void)=&callback;
43
+
44
+ test_structure_12 *ts12_result =
45
+ (test_structure_12 *) malloc (sizeof(test_structure_12));
46
+
47
+ ts12a_type.size = 0;
48
+ ts12a_type.alignment = 0;
49
+ ts12a_type.type = FFI_TYPE_STRUCT;
50
+ ts12a_type.elements = ts12a_type_elements;
51
+ ts12a_type_elements[0] = &ffi_type_double;
52
+ ts12a_type_elements[1] = &ffi_type_double;
53
+ ts12a_type_elements[2] = NULL;
54
+
55
+ ts12_type.size = 0;
56
+ ts12_type.alignment = 0;
57
+ ts12_type.type = FFI_TYPE_STRUCT;
58
+ ts12_type.elements = ts12_type_elements;
59
+ ts12_type_elements[0] = &ffi_type_uchar;
60
+ ts12_type_elements[1] = &ts12a_type;
61
+ ts12_type_elements[2] = &ffi_type_uchar;
62
+ ts12_type_elements[3] = NULL;
63
+
64
+
65
+ args[0] = &ts12_type;
66
+ args[1] = &ffi_type_pointer;
67
+ values[0] = &ts12_arg;
68
+ values[1] = &ptr;
69
+
70
+ CHECK(ffi_prep_cif(&cif, ABI_NUM, 2, &ts12_type, args) == FFI_OK);
71
+
72
+ ts12_arg.c1 = 5;
73
+ ts12_arg.c2 = 6;
74
+ ts12_arg.s[0] = 7.77;
75
+ ts12_arg.s[1] = 8.88;
76
+
77
+ printf ("%u\n", ts12_arg.c1);
78
+ printf ("%u\n", ts12_arg.c2);
79
+ printf ("%g\n", ts12_arg.s[0]);
80
+ printf ("%g\n", ts12_arg.s[1]);
81
+ printf ("%d\n", i);
82
+
83
+ ffi_call(&cif, FFI_FN(struct12), ts12_result, values);
84
+
85
+ printf ("%u\n", ts12_result->c1);
86
+ printf ("%u\n", ts12_result->c2);
87
+ printf ("%g\n", ts12_result->s[0]);
88
+ printf ("%g\n", ts12_result->s[1]);
89
+ printf ("%d\n", i);
90
+ CHECK(ts12_result->c1 == 5 + 1);
91
+ CHECK(ts12_result->c2 == 6 + 1);
92
+ CHECK(ts12_result->s[0] == 7.77 + 1);
93
+ CHECK(ts12_result->s[1] == 8.88 + 1);
94
+ CHECK(i == 5 + 1);
95
+ CHECK(ts12_type.size == sizeof(test_structure_12));
96
+
97
+ free (ts12_result);
98
+ exit(0);
99
+ }