ffi 1.1.2 → 1.17.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (706) hide show
  1. checksums.yaml +7 -0
  2. checksums.yaml.gz.sig +0 -0
  3. data/CHANGELOG.md +456 -0
  4. data/COPYING +49 -0
  5. data/Gemfile +21 -0
  6. data/LICENSE +21 -11
  7. data/LICENSE.SPECS +22 -0
  8. data/README.md +137 -0
  9. data/Rakefile +166 -156
  10. data/ext/ffi_c/AbstractMemory.c +240 -140
  11. data/ext/ffi_c/AbstractMemory.h +25 -15
  12. data/ext/ffi_c/ArrayType.c +78 -29
  13. data/ext/ffi_c/ArrayType.h +22 -12
  14. data/ext/ffi_c/Buffer.c +121 -60
  15. data/ext/ffi_c/Call.c +184 -137
  16. data/ext/ffi_c/Call.h +46 -22
  17. data/ext/ffi_c/ClosurePool.c +101 -43
  18. data/ext/ffi_c/ClosurePool.h +24 -13
  19. data/ext/ffi_c/DynamicLibrary.c +139 -57
  20. data/ext/ffi_c/DynamicLibrary.h +70 -12
  21. data/ext/ffi_c/Function.c +372 -273
  22. data/ext/ffi_c/Function.h +25 -20
  23. data/ext/ffi_c/FunctionInfo.c +135 -49
  24. data/ext/ffi_c/LastError.c +97 -30
  25. data/ext/ffi_c/LastError.h +21 -12
  26. data/ext/ffi_c/LongDouble.c +15 -9
  27. data/ext/ffi_c/LongDouble.h +21 -16
  28. data/ext/ffi_c/MappedType.c +88 -38
  29. data/ext/ffi_c/MappedType.h +21 -14
  30. data/ext/ffi_c/MemoryPointer.c +91 -38
  31. data/ext/ffi_c/MemoryPointer.h +22 -19
  32. data/ext/ffi_c/MethodHandle.c +52 -51
  33. data/ext/ffi_c/MethodHandle.h +24 -14
  34. data/ext/ffi_c/Platform.c +28 -62
  35. data/ext/ffi_c/Platform.h +21 -12
  36. data/ext/ffi_c/Pointer.c +145 -86
  37. data/ext/ffi_c/Pointer.h +23 -19
  38. data/ext/ffi_c/Struct.c +363 -163
  39. data/ext/ffi_c/Struct.h +39 -21
  40. data/ext/ffi_c/StructByValue.c +72 -37
  41. data/ext/ffi_c/StructByValue.h +21 -12
  42. data/ext/ffi_c/StructLayout.c +308 -94
  43. data/ext/ffi_c/Thread.c +73 -270
  44. data/ext/ffi_c/Thread.h +32 -35
  45. data/ext/ffi_c/Type.c +147 -84
  46. data/ext/ffi_c/Type.h +27 -11
  47. data/ext/ffi_c/Types.c +40 -24
  48. data/ext/ffi_c/Types.h +24 -21
  49. data/ext/ffi_c/Variadic.c +148 -64
  50. data/ext/ffi_c/compat.h +45 -37
  51. data/ext/ffi_c/extconf.rb +86 -32
  52. data/ext/ffi_c/ffi.c +32 -21
  53. data/ext/ffi_c/libffi/.allow-ai-service +0 -0
  54. data/ext/ffi_c/libffi/.appveyor/site.exp +16 -0
  55. data/ext/ffi_c/libffi/.appveyor/unix-noexec.exp +7 -0
  56. data/ext/ffi_c/libffi/.appveyor.yml +84 -0
  57. data/ext/ffi_c/libffi/.ci/ar-lib +270 -0
  58. data/ext/ffi_c/libffi/.ci/bfin-sim.exp +58 -0
  59. data/ext/ffi_c/libffi/.ci/build-cross-in-container.sh +18 -0
  60. data/ext/ffi_c/libffi/.ci/build-in-container.sh +10 -0
  61. data/ext/ffi_c/libffi/.ci/build.sh +124 -0
  62. data/ext/ffi_c/libffi/.ci/compile +351 -0
  63. data/ext/ffi_c/libffi/.ci/install.sh +78 -0
  64. data/ext/ffi_c/libffi/.ci/m32r-sim.exp +58 -0
  65. data/ext/ffi_c/libffi/.ci/moxie-sim.exp +60 -0
  66. data/ext/ffi_c/libffi/.ci/msvs-detect +1103 -0
  67. data/ext/ffi_c/libffi/.ci/or1k-sim.exp +58 -0
  68. data/ext/ffi_c/libffi/.ci/powerpc-eabisim.exp +58 -0
  69. data/ext/ffi_c/libffi/.ci/site.exp +29 -0
  70. data/ext/ffi_c/libffi/.ci/wine-sim.exp +55 -0
  71. data/ext/ffi_c/libffi/.circleci/config.yml +156 -0
  72. data/ext/ffi_c/libffi/.gitattributes +4 -0
  73. data/ext/ffi_c/libffi/.github/issue_template.md +10 -0
  74. data/ext/ffi_c/libffi/.github/workflows/build.yml +479 -0
  75. data/ext/ffi_c/libffi/.github/workflows/emscripten.yml +172 -0
  76. data/ext/ffi_c/libffi/.gitignore +46 -0
  77. data/ext/ffi_c/libffi/{ChangeLog → ChangeLog.old} +6366 -3559
  78. data/ext/ffi_c/libffi/LICENSE +1 -1
  79. data/ext/ffi_c/libffi/LICENSE-BUILDTOOLS +353 -0
  80. data/ext/ffi_c/libffi/Makefile.am +131 -170
  81. data/ext/ffi_c/libffi/Makefile.in +1317 -1010
  82. data/ext/ffi_c/libffi/README.md +531 -0
  83. data/ext/ffi_c/libffi/acinclude.m4 +289 -4
  84. data/ext/ffi_c/libffi/autogen.sh +2 -0
  85. data/ext/ffi_c/libffi/compile +222 -17
  86. data/ext/ffi_c/libffi/config.guess +1033 -780
  87. data/ext/ffi_c/libffi/config.sub +1393 -1206
  88. data/ext/ffi_c/libffi/configure +16340 -10740
  89. data/ext/ffi_c/libffi/configure.ac +226 -271
  90. data/ext/ffi_c/libffi/configure.host +330 -4
  91. data/ext/ffi_c/libffi/doc/Makefile.am +3 -0
  92. data/ext/ffi_c/libffi/doc/Makefile.in +818 -0
  93. data/ext/ffi_c/libffi/doc/libffi.texi +525 -79
  94. data/ext/ffi_c/libffi/doc/version.texi +4 -4
  95. data/ext/ffi_c/libffi/fficonfig.h.in +41 -52
  96. data/ext/ffi_c/libffi/generate-darwin-source-and-headers.py +312 -0
  97. data/ext/ffi_c/libffi/include/Makefile.am +3 -3
  98. data/ext/ffi_c/libffi/include/Makefile.in +201 -79
  99. data/ext/ffi_c/libffi/include/ffi.h.in +190 -99
  100. data/ext/ffi_c/libffi/include/ffi_cfi.h +76 -0
  101. data/ext/ffi_c/libffi/include/ffi_common.h +72 -14
  102. data/ext/ffi_c/libffi/include/tramp.h +45 -0
  103. data/ext/ffi_c/libffi/install-sh +231 -210
  104. data/ext/ffi_c/libffi/libffi.map.in +81 -0
  105. data/ext/ffi_c/libffi/libffi.pc.in +3 -2
  106. data/ext/ffi_c/libffi/libffi.xcodeproj/project.pbxproj +997 -0
  107. data/ext/ffi_c/libffi/libtool-ldflags +106 -0
  108. data/ext/ffi_c/libffi/libtool-version +2 -2
  109. data/ext/ffi_c/libffi/ltmain.sh +3868 -2068
  110. data/ext/ffi_c/libffi/m4/asmcfi.m4 +13 -0
  111. data/ext/ffi_c/libffi/m4/ax_append_flag.m4 +50 -0
  112. data/ext/ffi_c/libffi/m4/ax_cc_maxopt.m4 +47 -25
  113. data/ext/ffi_c/libffi/m4/ax_cflags_warn_all.m4 +110 -147
  114. data/ext/ffi_c/libffi/m4/ax_check_compile_flag.m4 +53 -0
  115. data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +75 -19
  116. data/ext/ffi_c/libffi/m4/ax_configure_args.m4 +8 -29
  117. data/ext/ffi_c/libffi/m4/ax_enable_builddir.m4 +11 -9
  118. data/ext/ffi_c/libffi/m4/ax_gcc_archflag.m4 +104 -52
  119. data/ext/ffi_c/libffi/m4/ax_gcc_x86_cpuid.m4 +18 -8
  120. data/ext/ffi_c/libffi/m4/ax_prepend_flag.m4 +51 -0
  121. data/ext/ffi_c/libffi/m4/ax_require_defined.m4 +37 -0
  122. data/ext/ffi_c/libffi/make_sunver.pl +333 -0
  123. data/ext/ffi_c/libffi/man/Makefile.am +2 -2
  124. data/ext/ffi_c/libffi/man/Makefile.in +156 -57
  125. data/ext/ffi_c/libffi/man/ffi.3 +10 -0
  126. data/ext/ffi_c/libffi/man/ffi_prep_cif.3 +6 -4
  127. data/ext/ffi_c/libffi/man/ffi_prep_cif_var.3 +73 -0
  128. data/ext/ffi_c/libffi/missing +153 -314
  129. data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.sln +33 -0
  130. data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.vcxproj +130 -0
  131. data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.vcxproj.filters +57 -0
  132. data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.vcxproj.user +4 -0
  133. data/ext/ffi_c/libffi/{include/ffi.h.vc64 → msvc_build/aarch64/aarch64_include/ffi.h} +151 -67
  134. data/ext/ffi_c/libffi/msvc_build/aarch64/aarch64_include/fficonfig.h +219 -0
  135. data/ext/ffi_c/libffi/msvcc.sh +176 -20
  136. data/ext/ffi_c/libffi/src/aarch64/ffi.c +1142 -0
  137. data/ext/ffi_c/libffi/src/aarch64/ffitarget.h +97 -0
  138. data/ext/ffi_c/libffi/src/aarch64/internal.h +100 -0
  139. data/ext/ffi_c/libffi/src/aarch64/sysv.S +695 -0
  140. data/ext/ffi_c/libffi/src/aarch64/win64_armasm.S +506 -0
  141. data/ext/ffi_c/libffi/src/alpha/ffi.c +335 -98
  142. data/ext/ffi_c/libffi/src/alpha/ffitarget.h +10 -1
  143. data/ext/ffi_c/libffi/src/alpha/internal.h +23 -0
  144. data/ext/ffi_c/libffi/src/alpha/osf.S +161 -266
  145. data/ext/ffi_c/libffi/src/arc/arcompact.S +210 -0
  146. data/ext/ffi_c/libffi/src/arc/ffi.c +443 -0
  147. data/ext/ffi_c/libffi/src/arc/ffitarget.h +67 -0
  148. data/ext/ffi_c/libffi/src/arm/ffi.c +706 -513
  149. data/ext/ffi_c/libffi/src/arm/ffitarget.h +32 -8
  150. data/ext/ffi_c/libffi/src/arm/internal.h +17 -0
  151. data/ext/ffi_c/libffi/src/arm/sysv.S +372 -413
  152. data/ext/ffi_c/libffi/src/arm/sysv_msvc_arm32.S +311 -0
  153. data/ext/ffi_c/libffi/src/avr32/ffitarget.h +6 -1
  154. data/ext/ffi_c/libffi/src/bfin/ffi.c +196 -0
  155. data/ext/ffi_c/libffi/src/bfin/ffitarget.h +43 -0
  156. data/ext/ffi_c/libffi/src/bfin/sysv.S +179 -0
  157. data/ext/ffi_c/libffi/src/closures.c +565 -73
  158. data/ext/ffi_c/libffi/src/cris/ffi.c +10 -7
  159. data/ext/ffi_c/libffi/src/cris/ffitarget.h +6 -1
  160. data/ext/ffi_c/libffi/src/csky/ffi.c +395 -0
  161. data/ext/ffi_c/libffi/src/csky/ffitarget.h +63 -0
  162. data/ext/ffi_c/libffi/src/csky/sysv.S +371 -0
  163. data/ext/ffi_c/libffi/src/debug.c +8 -3
  164. data/ext/ffi_c/libffi/src/dlmalloc.c +23 -13
  165. data/ext/ffi_c/libffi/src/frv/ffi.c +2 -2
  166. data/ext/ffi_c/libffi/src/frv/ffitarget.h +6 -1
  167. data/ext/ffi_c/libffi/src/ia64/ffi.c +47 -13
  168. data/ext/ffi_c/libffi/src/ia64/ffitarget.h +8 -2
  169. data/ext/ffi_c/libffi/src/ia64/unix.S +28 -3
  170. data/ext/ffi_c/libffi/src/java_raw_api.c +23 -5
  171. data/ext/ffi_c/libffi/src/kvx/asm.h +5 -0
  172. data/ext/ffi_c/libffi/src/kvx/ffi.c +273 -0
  173. data/ext/ffi_c/libffi/src/kvx/ffitarget.h +75 -0
  174. data/ext/ffi_c/libffi/src/kvx/sysv.S +127 -0
  175. data/ext/ffi_c/libffi/src/loongarch64/ffi.c +624 -0
  176. data/ext/ffi_c/libffi/src/loongarch64/ffitarget.h +82 -0
  177. data/ext/ffi_c/libffi/src/loongarch64/sysv.S +327 -0
  178. data/ext/ffi_c/libffi/src/m32r/ffi.c +32 -15
  179. data/ext/ffi_c/libffi/src/m32r/ffitarget.h +6 -1
  180. data/ext/ffi_c/libffi/src/m68k/ffi.c +87 -13
  181. data/ext/ffi_c/libffi/src/m68k/ffitarget.h +6 -1
  182. data/ext/ffi_c/libffi/src/m68k/sysv.S +119 -32
  183. data/ext/ffi_c/libffi/src/m88k/ffi.c +400 -0
  184. data/ext/ffi_c/libffi/src/m88k/ffitarget.h +49 -0
  185. data/ext/ffi_c/libffi/src/m88k/obsd.S +209 -0
  186. data/ext/ffi_c/libffi/src/metag/ffi.c +330 -0
  187. data/ext/ffi_c/libffi/{fficonfig.hw → src/metag/ffitarget.h} +22 -26
  188. data/ext/ffi_c/libffi/src/metag/sysv.S +311 -0
  189. data/ext/ffi_c/libffi/src/microblaze/ffi.c +321 -0
  190. data/ext/ffi_c/libffi/src/microblaze/ffitarget.h +53 -0
  191. data/ext/ffi_c/libffi/src/microblaze/sysv.S +302 -0
  192. data/ext/ffi_c/libffi/src/mips/ffi.c +382 -101
  193. data/ext/ffi_c/libffi/src/mips/ffitarget.h +23 -14
  194. data/ext/ffi_c/libffi/src/mips/n32.S +321 -89
  195. data/ext/ffi_c/libffi/src/mips/o32.S +211 -31
  196. data/ext/ffi_c/libffi/src/moxie/eabi.S +55 -82
  197. data/ext/ffi_c/libffi/src/moxie/ffi.c +100 -66
  198. data/ext/ffi_c/libffi/src/moxie/ffitarget.h +52 -0
  199. data/ext/ffi_c/libffi/src/nios2/ffi.c +304 -0
  200. data/ext/ffi_c/libffi/src/nios2/ffitarget.h +52 -0
  201. data/ext/ffi_c/libffi/src/nios2/sysv.S +136 -0
  202. data/ext/ffi_c/libffi/src/or1k/ffi.c +341 -0
  203. data/ext/ffi_c/libffi/src/or1k/ffitarget.h +58 -0
  204. data/ext/ffi_c/libffi/src/or1k/sysv.S +107 -0
  205. data/ext/ffi_c/libffi/src/pa/ffi.c +62 -108
  206. data/ext/ffi_c/libffi/src/pa/ffi64.c +614 -0
  207. data/ext/ffi_c/libffi/src/pa/ffitarget.h +28 -12
  208. data/ext/ffi_c/libffi/src/pa/hpux32.S +87 -38
  209. data/ext/ffi_c/libffi/src/pa/hpux64.S +681 -0
  210. data/ext/ffi_c/libffi/src/pa/linux.S +109 -39
  211. data/ext/ffi_c/libffi/src/powerpc/aix.S +245 -7
  212. data/ext/ffi_c/libffi/src/powerpc/aix_closure.S +253 -4
  213. data/ext/ffi_c/libffi/src/powerpc/asm.h +2 -2
  214. data/ext/ffi_c/libffi/src/powerpc/darwin.S +2 -7
  215. data/ext/ffi_c/libffi/src/powerpc/darwin_closure.S +22 -26
  216. data/ext/ffi_c/libffi/src/powerpc/ffi.c +105 -1378
  217. data/ext/ffi_c/libffi/src/powerpc/ffi_darwin.c +157 -52
  218. data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +1153 -0
  219. data/ext/ffi_c/libffi/src/powerpc/ffi_powerpc.h +105 -0
  220. data/ext/ffi_c/libffi/src/powerpc/ffi_sysv.c +923 -0
  221. data/ext/ffi_c/libffi/src/powerpc/ffitarget.h +110 -45
  222. data/ext/ffi_c/libffi/src/powerpc/linux64.S +191 -85
  223. data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +438 -108
  224. data/ext/ffi_c/libffi/src/powerpc/ppc_closure.S +138 -68
  225. data/ext/ffi_c/libffi/src/powerpc/sysv.S +73 -119
  226. data/ext/ffi_c/libffi/src/powerpc/t-aix +5 -0
  227. data/ext/ffi_c/libffi/src/prep_cif.c +131 -25
  228. data/ext/ffi_c/libffi/src/raw_api.c +18 -5
  229. data/ext/ffi_c/libffi/src/riscv/ffi.c +514 -0
  230. data/ext/ffi_c/libffi/src/riscv/ffitarget.h +69 -0
  231. data/ext/ffi_c/libffi/src/riscv/sysv.S +293 -0
  232. data/ext/ffi_c/libffi/src/s390/ffi.c +294 -318
  233. data/ext/ffi_c/libffi/src/s390/ffitarget.h +9 -1
  234. data/ext/ffi_c/libffi/src/s390/internal.h +11 -0
  235. data/ext/ffi_c/libffi/src/s390/sysv.S +257 -366
  236. data/ext/ffi_c/libffi/src/sh/ffi.c +4 -3
  237. data/ext/ffi_c/libffi/src/sh/ffitarget.h +6 -1
  238. data/ext/ffi_c/libffi/src/sh64/ffi.c +3 -2
  239. data/ext/ffi_c/libffi/src/sh64/ffitarget.h +6 -1
  240. data/ext/ffi_c/libffi/src/sparc/ffi.c +326 -527
  241. data/ext/ffi_c/libffi/src/sparc/ffi64.c +630 -0
  242. data/ext/ffi_c/libffi/src/sparc/ffitarget.h +20 -7
  243. data/ext/ffi_c/libffi/src/sparc/internal.h +26 -0
  244. data/ext/ffi_c/libffi/src/sparc/v8.S +364 -234
  245. data/ext/ffi_c/libffi/src/sparc/v9.S +340 -207
  246. data/ext/ffi_c/libffi/src/tile/ffi.c +355 -0
  247. data/ext/ffi_c/libffi/src/tile/ffitarget.h +65 -0
  248. data/ext/ffi_c/libffi/src/tile/tile.S +360 -0
  249. data/ext/ffi_c/libffi/src/tramp.c +716 -0
  250. data/ext/ffi_c/libffi/src/types.c +48 -19
  251. data/ext/ffi_c/libffi/src/vax/elfbsd.S +195 -0
  252. data/ext/ffi_c/libffi/src/vax/ffi.c +276 -0
  253. data/ext/ffi_c/libffi/src/vax/ffitarget.h +49 -0
  254. data/ext/ffi_c/libffi/src/wasm32/ffi.c +947 -0
  255. data/ext/ffi_c/libffi/src/wasm32/ffitarget.h +62 -0
  256. data/ext/ffi_c/libffi/src/x86/asmnames.h +30 -0
  257. data/ext/ffi_c/libffi/src/x86/ffi.c +686 -498
  258. data/ext/ffi_c/libffi/src/x86/ffi64.c +444 -129
  259. data/ext/ffi_c/libffi/src/x86/ffitarget.h +79 -36
  260. data/ext/ffi_c/libffi/src/x86/ffiw64.c +361 -0
  261. data/ext/ffi_c/libffi/src/x86/internal.h +43 -0
  262. data/ext/ffi_c/libffi/src/x86/internal64.h +36 -0
  263. data/ext/ffi_c/libffi/src/x86/sysv.S +1198 -394
  264. data/ext/ffi_c/libffi/src/x86/sysv_intel.S +998 -0
  265. data/ext/ffi_c/libffi/src/x86/unix64.S +585 -300
  266. data/ext/ffi_c/libffi/src/x86/win64.S +244 -458
  267. data/ext/ffi_c/libffi/src/x86/win64_intel.S +238 -0
  268. data/ext/ffi_c/libffi/src/xtensa/ffi.c +306 -0
  269. data/ext/ffi_c/libffi/src/xtensa/ffitarget.h +57 -0
  270. data/ext/ffi_c/libffi/src/xtensa/sysv.S +268 -0
  271. data/ext/ffi_c/libffi/stamp-h.in +1 -0
  272. data/ext/ffi_c/libffi/testsuite/Makefile.am +80 -73
  273. data/ext/ffi_c/libffi/testsuite/Makefile.in +233 -117
  274. data/ext/ffi_c/libffi/testsuite/emscripten/build-tests.sh +54 -0
  275. data/ext/ffi_c/libffi/testsuite/emscripten/build.sh +63 -0
  276. data/ext/ffi_c/libffi/testsuite/emscripten/conftest.py +86 -0
  277. data/ext/ffi_c/libffi/testsuite/emscripten/node-tests.sh +48 -0
  278. data/ext/ffi_c/libffi/testsuite/emscripten/test.html +7 -0
  279. data/ext/ffi_c/libffi/testsuite/emscripten/test_libffi.py +51 -0
  280. data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +360 -28
  281. data/ext/ffi_c/libffi/testsuite/lib/target-libpath.exp +22 -2
  282. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/Makefile +28 -0
  283. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/README +78 -0
  284. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/alignof.h +50 -0
  285. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/bhaible.exp +63 -0
  286. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-call.c +1746 -0
  287. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-callback.c +2885 -0
  288. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/testcases.c +747 -0
  289. data/ext/ffi_c/libffi/testsuite/libffi.call/align_mixed.c +46 -0
  290. data/ext/ffi_c/libffi/testsuite/libffi.call/align_stdcall.c +46 -0
  291. data/ext/ffi_c/libffi/testsuite/libffi.call/bpo_38748.c +41 -0
  292. data/ext/ffi_c/libffi/testsuite/libffi.call/call.exp +28 -6
  293. data/ext/ffi_c/libffi/testsuite/libffi.call/callback.c +99 -0
  294. data/ext/ffi_c/libffi/testsuite/libffi.call/callback2.c +108 -0
  295. data/ext/ffi_c/libffi/testsuite/libffi.call/callback3.c +114 -0
  296. data/ext/ffi_c/libffi/testsuite/libffi.call/callback4.c +119 -0
  297. data/ext/ffi_c/libffi/testsuite/libffi.call/err_bad_typedef.c +2 -2
  298. data/ext/ffi_c/libffi/testsuite/libffi.call/ffitest.h +52 -42
  299. data/ext/ffi_c/libffi/testsuite/libffi.call/float1.c +3 -1
  300. data/ext/ffi_c/libffi/testsuite/libffi.call/float2.c +15 -12
  301. data/ext/ffi_c/libffi/testsuite/libffi.call/float3.c +4 -2
  302. data/ext/ffi_c/libffi/testsuite/libffi.call/float_va.c +110 -0
  303. data/ext/ffi_c/libffi/testsuite/libffi.call/many.c +6 -16
  304. data/ext/ffi_c/libffi/testsuite/libffi.call/many2.c +57 -0
  305. data/ext/ffi_c/libffi/testsuite/libffi.call/many_double.c +70 -0
  306. data/ext/ffi_c/libffi/testsuite/libffi.call/many_mixed.c +78 -0
  307. data/ext/ffi_c/libffi/testsuite/libffi.call/negint.c +0 -1
  308. data/ext/ffi_c/libffi/testsuite/libffi.call/offsets.c +46 -0
  309. data/ext/ffi_c/libffi/testsuite/libffi.call/pr1172638.c +127 -0
  310. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl.c +1 -0
  311. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ldl.c +1 -1
  312. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll1.c +5 -0
  313. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sc.c +1 -1
  314. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sl.c +4 -0
  315. data/ext/ffi_c/libffi/testsuite/libffi.call/return_uc.c +1 -1
  316. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ul.c +4 -0
  317. data/ext/ffi_c/libffi/testsuite/libffi.call/s55.c +60 -0
  318. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen.c +9 -10
  319. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen2.c +49 -0
  320. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen3.c +49 -0
  321. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen4.c +55 -0
  322. data/ext/ffi_c/libffi/testsuite/libffi.call/struct1.c +9 -7
  323. data/ext/ffi_c/libffi/testsuite/libffi.call/struct10.c +57 -0
  324. data/ext/ffi_c/libffi/testsuite/libffi.call/struct2.c +7 -7
  325. data/ext/ffi_c/libffi/testsuite/libffi.call/struct3.c +7 -6
  326. data/ext/ffi_c/libffi/testsuite/libffi.call/struct4.c +9 -8
  327. data/ext/ffi_c/libffi/testsuite/libffi.call/struct5.c +9 -8
  328. data/ext/ffi_c/libffi/testsuite/libffi.call/struct6.c +9 -9
  329. data/ext/ffi_c/libffi/testsuite/libffi.call/struct7.c +9 -9
  330. data/ext/ffi_c/libffi/testsuite/libffi.call/struct8.c +9 -8
  331. data/ext/ffi_c/libffi/testsuite/libffi.call/struct9.c +9 -8
  332. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_2.c +63 -0
  333. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_3.c +65 -0
  334. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_3f.c +65 -0
  335. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_4.c +67 -0
  336. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_4f.c +67 -0
  337. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_big.c +93 -0
  338. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_small.c +61 -0
  339. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_return_2H.c +63 -0
  340. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_return_8H.c +90 -0
  341. data/ext/ffi_c/libffi/testsuite/libffi.call/uninitialized.c +61 -0
  342. data/ext/ffi_c/libffi/testsuite/libffi.call/va_1.c +78 -0
  343. data/ext/ffi_c/libffi/testsuite/libffi.call/va_2.c +220 -0
  344. data/ext/ffi_c/libffi/testsuite/libffi.call/va_3.c +154 -0
  345. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct1.c +134 -0
  346. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct2.c +134 -0
  347. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct3.c +140 -0
  348. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure.exp +67 -0
  349. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn0.c +3 -2
  350. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn1.c +2 -0
  351. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn2.c +2 -0
  352. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn3.c +21 -1
  353. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn4.c +2 -0
  354. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn5.c +2 -0
  355. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn6.c +2 -0
  356. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_loc_fn0.c +7 -6
  357. data/ext/ffi_c/libffi/testsuite/{libffi.call/closure_stdcall.c → libffi.closures/closure_simple.c} +13 -16
  358. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_12byte.c +22 -4
  359. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_16byte.c +26 -4
  360. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_18byte.c +28 -4
  361. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_19byte.c +33 -4
  362. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_1_1byte.c +8 -4
  363. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte.c +23 -5
  364. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte1.c +25 -5
  365. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_24byte.c +40 -8
  366. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_2byte.c +17 -4
  367. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3_1byte.c +23 -4
  368. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte1.c +17 -4
  369. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte2.c +17 -4
  370. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3float.c +113 -0
  371. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4_1byte.c +26 -4
  372. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4byte.c +17 -4
  373. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5_1_byte.c +33 -5
  374. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5byte.c +23 -5
  375. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_64byte.c +29 -5
  376. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6_1_byte.c +32 -5
  377. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6byte.c +28 -6
  378. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7_1_byte.c +43 -5
  379. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7byte.c +29 -5
  380. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_8byte.c +18 -4
  381. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte1.c +18 -5
  382. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte2.c +18 -6
  383. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_double.c +23 -5
  384. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_float.c +23 -5
  385. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble.c +24 -5
  386. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split.c +44 -31
  387. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split2.c +44 -9
  388. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_pointer.c +23 -5
  389. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint16.c +22 -5
  390. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint32.c +22 -7
  391. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint64.c +22 -5
  392. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint16.c +22 -5
  393. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint32.c +23 -5
  394. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint64.c +23 -5
  395. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_dbls_struct.c +7 -5
  396. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double_va.c +19 -10
  397. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_float.c +4 -0
  398. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble.c +14 -4
  399. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble_va.c +32 -12
  400. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_many_mixed_args.c +70 -0
  401. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_many_mixed_float_double.c +55 -0
  402. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_schar.c +5 -1
  403. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshort.c +6 -1
  404. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshortchar.c +9 -1
  405. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_uchar.c +9 -1
  406. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushort.c +6 -2
  407. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushortchar.c +9 -1
  408. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer.c +6 -1
  409. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer_stack.c +21 -9
  410. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_schar.c +3 -0
  411. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sint.c +2 -0
  412. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sshort.c +3 -0
  413. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_struct_va1.c +125 -0
  414. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uchar.c +3 -0
  415. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uint.c +4 -0
  416. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uint_va.c +49 -0
  417. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ulong_va.c +49 -0
  418. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ulonglong.c +7 -5
  419. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ushort.c +3 -0
  420. data/ext/ffi_c/libffi/testsuite/libffi.closures/ffitest.h +1 -0
  421. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/huge_struct.c +41 -40
  422. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct.c +38 -15
  423. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct1.c +9 -9
  424. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct10.c +19 -6
  425. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct11.c +137 -0
  426. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct12.c +86 -0
  427. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct13.c +115 -0
  428. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct2.c +15 -6
  429. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct3.c +15 -6
  430. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct4.c +14 -5
  431. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct5.c +14 -5
  432. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct6.c +17 -6
  433. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct7.c +14 -5
  434. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct8.c +17 -6
  435. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct9.c +17 -6
  436. data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs1.c +86 -0
  437. data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs2.c +102 -0
  438. data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs3.c +101 -0
  439. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large.c +7 -7
  440. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large2.c +7 -7
  441. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium.c +6 -6
  442. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium2.c +6 -6
  443. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/testclosure.c +8 -3
  444. data/ext/ffi_c/libffi/testsuite/{libffi.special → libffi.closures}/unwindtest.cc +4 -10
  445. data/ext/ffi_c/libffi/testsuite/{libffi.special → libffi.closures}/unwindtest_ffi_call.cc +4 -2
  446. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex.inc +91 -0
  447. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_double.c +10 -0
  448. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_float.c +10 -0
  449. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_longdouble.c +10 -0
  450. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex.inc +42 -0
  451. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_double.c +10 -0
  452. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_float.c +10 -0
  453. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_longdouble.c +10 -0
  454. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct.inc +71 -0
  455. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_double.c +10 -0
  456. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_float.c +10 -0
  457. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_longdouble.c +10 -0
  458. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va.inc +80 -0
  459. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_double.c +10 -0
  460. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_float.c +16 -0
  461. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_longdouble.c +10 -0
  462. data/ext/ffi_c/libffi/testsuite/{libffi.special/special.exp → libffi.complex/complex.exp} +9 -8
  463. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex.inc +51 -0
  464. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_double.inc +7 -0
  465. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_float.inc +7 -0
  466. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_longdouble.inc +7 -0
  467. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_double.c +10 -0
  468. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_float.c +10 -0
  469. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_int.c +86 -0
  470. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_longdouble.c +10 -0
  471. data/ext/ffi_c/libffi/testsuite/libffi.complex/ffitest.h +1 -0
  472. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex.inc +78 -0
  473. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_double.c +10 -0
  474. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_float.c +10 -0
  475. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_longdouble.c +10 -0
  476. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex.inc +37 -0
  477. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1.inc +41 -0
  478. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_double.c +10 -0
  479. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_float.c +10 -0
  480. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_longdouble.c +10 -0
  481. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2.inc +44 -0
  482. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_double.c +10 -0
  483. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_float.c +10 -0
  484. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_longdouble.c +10 -0
  485. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_double.c +10 -0
  486. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_float.c +10 -0
  487. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_longdouble.c +10 -0
  488. data/ext/ffi_c/libffi/testsuite/libffi.go/aa-direct.c +34 -0
  489. data/ext/ffi_c/libffi/testsuite/libffi.go/closure1.c +28 -0
  490. data/ext/ffi_c/libffi/testsuite/libffi.go/ffitest.h +1 -0
  491. data/ext/ffi_c/libffi/testsuite/libffi.go/go.exp +36 -0
  492. data/ext/ffi_c/libffi/testsuite/libffi.go/static-chain.h +19 -0
  493. data/ext/ffi_c/libffi.bsd.mk +13 -7
  494. data/ext/ffi_c/libffi.darwin.mk +25 -13
  495. data/ext/ffi_c/libffi.gnu.mk +4 -3
  496. data/ext/ffi_c/libffi.mk +11 -6
  497. data/ext/ffi_c/libffi.vc.mk +1 -1
  498. data/ext/ffi_c/libffi.vc64.mk +1 -1
  499. data/ext/ffi_c/rbffi.h +23 -15
  500. data/ext/ffi_c/rbffi_endian.h +11 -2
  501. data/ffi.gemspec +42 -0
  502. data/lib/ffi/abstract_memory.rb +44 -0
  503. data/lib/ffi/autopointer.rb +65 -68
  504. data/lib/ffi/compat.rb +43 -0
  505. data/lib/ffi/data_converter.rb +67 -0
  506. data/lib/ffi/dynamic_library.rb +118 -0
  507. data/lib/ffi/enum.rb +166 -25
  508. data/lib/ffi/errno.rb +21 -11
  509. data/lib/ffi/ffi.rb +28 -11
  510. data/lib/ffi/function.rb +71 -0
  511. data/lib/ffi/io.rb +25 -15
  512. data/lib/ffi/library.rb +227 -136
  513. data/lib/ffi/library_path.rb +109 -0
  514. data/lib/ffi/managedstruct.rb +64 -35
  515. data/lib/ffi/platform/aarch64-darwin/types.conf +130 -0
  516. data/lib/ffi/platform/aarch64-freebsd/types.conf +128 -0
  517. data/lib/ffi/platform/aarch64-freebsd12/types.conf +181 -0
  518. data/lib/ffi/platform/aarch64-linux/types.conf +175 -0
  519. data/lib/ffi/platform/aarch64-openbsd/types.conf +134 -0
  520. data/lib/ffi/platform/aarch64-windows/types.conf +52 -0
  521. data/lib/ffi/platform/arm-freebsd/types.conf +152 -0
  522. data/lib/ffi/platform/arm-freebsd12/types.conf +152 -0
  523. data/lib/ffi/platform/arm-linux/types.conf +110 -82
  524. data/lib/ffi/platform/hppa1.1-linux/types.conf +178 -0
  525. data/lib/ffi/platform/hppa2.0-linux/types.conf +178 -0
  526. data/lib/ffi/platform/i386-cygwin/types.conf +3 -0
  527. data/lib/ffi/platform/i386-darwin/types.conf +63 -63
  528. data/lib/ffi/platform/i386-freebsd/types.conf +89 -89
  529. data/lib/ffi/platform/i386-freebsd12/types.conf +152 -0
  530. data/lib/ffi/platform/i386-linux/types.conf +77 -77
  531. data/lib/ffi/platform/i386-netbsd/types.conf +87 -87
  532. data/lib/ffi/platform/i386-openbsd/types.conf +89 -87
  533. data/lib/ffi/platform/i386-solaris/types.conf +96 -96
  534. data/lib/ffi/platform/i386-windows/types.conf +43 -96
  535. data/lib/ffi/platform/ia64-linux/types.conf +79 -79
  536. data/lib/ffi/platform/loongarch64-linux/types.conf +141 -0
  537. data/lib/ffi/platform/mips-linux/types.conf +79 -79
  538. data/lib/ffi/platform/mips64-linux/types.conf +104 -0
  539. data/lib/ffi/platform/mips64el-linux/types.conf +104 -0
  540. data/lib/ffi/platform/mipsel-linux/types.conf +79 -79
  541. data/lib/ffi/platform/mipsisa32r6-linux/types.conf +102 -0
  542. data/lib/ffi/platform/mipsisa32r6el-linux/types.conf +102 -0
  543. data/lib/ffi/platform/mipsisa64r6-linux/types.conf +104 -0
  544. data/lib/ffi/platform/mipsisa64r6el-linux/types.conf +104 -0
  545. data/lib/ffi/platform/powerpc-aix/types.conf +155 -155
  546. data/lib/ffi/platform/powerpc-darwin/types.conf +63 -63
  547. data/lib/ffi/platform/powerpc-linux/types.conf +108 -78
  548. data/lib/ffi/platform/powerpc-openbsd/types.conf +156 -0
  549. data/lib/ffi/platform/powerpc64-linux/types.conf +104 -0
  550. data/lib/ffi/platform/powerpc64le-linux/types.conf +100 -0
  551. data/lib/ffi/platform/riscv64-linux/types.conf +104 -0
  552. data/lib/ffi/platform/s390-linux/types.conf +79 -79
  553. data/lib/ffi/platform/s390x-linux/types.conf +79 -79
  554. data/lib/ffi/platform/sparc-linux/types.conf +79 -79
  555. data/lib/ffi/platform/sparc-solaris/types.conf +103 -103
  556. data/lib/ffi/platform/sparcv9-linux/types.conf +102 -0
  557. data/lib/ffi/platform/sparcv9-openbsd/types.conf +156 -0
  558. data/lib/ffi/platform/sparcv9-solaris/types.conf +103 -103
  559. data/lib/ffi/platform/sw_64-linux/types.conf +141 -0
  560. data/lib/ffi/platform/x86_64-cygwin/types.conf +3 -0
  561. data/lib/ffi/platform/x86_64-darwin/types.conf +93 -63
  562. data/lib/ffi/platform/x86_64-dragonflybsd/types.conf +130 -0
  563. data/lib/ffi/platform/x86_64-freebsd/types.conf +90 -88
  564. data/lib/ffi/platform/x86_64-freebsd12/types.conf +158 -0
  565. data/lib/ffi/platform/x86_64-haiku/types.conf +117 -0
  566. data/lib/ffi/platform/x86_64-linux/types.conf +107 -77
  567. data/lib/ffi/platform/x86_64-msys/types.conf +119 -0
  568. data/lib/ffi/platform/x86_64-netbsd/types.conf +89 -87
  569. data/lib/ffi/platform/x86_64-openbsd/types.conf +100 -92
  570. data/lib/ffi/platform/x86_64-solaris/types.conf +96 -96
  571. data/lib/ffi/platform/x86_64-windows/types.conf +52 -0
  572. data/lib/ffi/platform.rb +91 -34
  573. data/lib/ffi/pointer.rb +78 -33
  574. data/lib/ffi/struct.rb +100 -66
  575. data/lib/ffi/struct_by_reference.rb +72 -0
  576. data/lib/ffi/struct_layout.rb +96 -0
  577. data/lib/ffi/struct_layout_builder.rb +84 -19
  578. data/lib/ffi/tools/const_generator.rb +11 -8
  579. data/lib/ffi/tools/generator.rb +48 -1
  580. data/lib/ffi/tools/generator_task.rb +13 -16
  581. data/lib/ffi/tools/struct_generator.rb +6 -5
  582. data/lib/ffi/tools/types_generator.rb +14 -10
  583. data/lib/ffi/types.rb +96 -51
  584. data/lib/ffi/union.rb +23 -12
  585. data/lib/ffi/variadic.rb +44 -29
  586. data/lib/ffi/version.rb +3 -0
  587. data/lib/ffi.rb +20 -8
  588. data/rakelib/ffi_gem_helper.rb +65 -0
  589. data/samples/getlogin.rb +8 -0
  590. data/samples/getpid.rb +8 -0
  591. data/samples/gettimeofday.rb +18 -0
  592. data/samples/hello.rb +8 -0
  593. data/samples/hello_ractor.rb +11 -0
  594. data/samples/inotify.rb +60 -0
  595. data/samples/pty.rb +75 -0
  596. data/samples/qsort.rb +20 -0
  597. data/samples/qsort_ractor.rb +28 -0
  598. data/sig/ffi/abstract_memory.rbs +165 -0
  599. data/sig/ffi/auto_pointer.rbs +27 -0
  600. data/sig/ffi/buffer.rbs +18 -0
  601. data/sig/ffi/data_converter.rbs +10 -0
  602. data/sig/ffi/dynamic_library.rbs +9 -0
  603. data/sig/ffi/enum.rbs +38 -0
  604. data/sig/ffi/function.rbs +39 -0
  605. data/sig/ffi/library.rbs +42 -0
  606. data/sig/ffi/native_type.rbs +86 -0
  607. data/sig/ffi/pointer.rbs +42 -0
  608. data/sig/ffi/struct.rbs +76 -0
  609. data/sig/ffi/struct_by_reference.rbs +11 -0
  610. data/sig/ffi/struct_by_value.rbs +7 -0
  611. data/sig/ffi/struct_layout.rbs +9 -0
  612. data/sig/ffi/struct_layout_builder.rbs +5 -0
  613. data/sig/ffi/type.rbs +39 -0
  614. data/sig/ffi.rbs +26 -0
  615. data.tar.gz.sig +0 -0
  616. metadata +508 -268
  617. metadata.gz.sig +1 -0
  618. data/History.txt +0 -1
  619. data/README.rdoc +0 -102
  620. data/ext/ffi_c/DataConverter.c +0 -91
  621. data/ext/ffi_c/Ffi_c.iml +0 -12
  622. data/ext/ffi_c/StructByReference.c +0 -158
  623. data/ext/ffi_c/StructByReference.h +0 -50
  624. data/ext/ffi_c/libffi/ChangeLog.libffi +0 -584
  625. data/ext/ffi_c/libffi/ChangeLog.libgcj +0 -40
  626. data/ext/ffi_c/libffi/ChangeLog.v1 +0 -764
  627. data/ext/ffi_c/libffi/Makefile.vc +0 -141
  628. data/ext/ffi_c/libffi/Makefile.vc64 +0 -141
  629. data/ext/ffi_c/libffi/README +0 -342
  630. data/ext/ffi_c/libffi/aclocal.m4 +0 -1873
  631. data/ext/ffi_c/libffi/build-ios.sh +0 -67
  632. data/ext/ffi_c/libffi/depcomp +0 -630
  633. data/ext/ffi_c/libffi/doc/libffi.info +0 -593
  634. data/ext/ffi_c/libffi/doc/stamp-vti +0 -4
  635. data/ext/ffi_c/libffi/include/ffi.h.vc +0 -427
  636. data/ext/ffi_c/libffi/m4/ax_check_compiler_flags.m4 +0 -76
  637. data/ext/ffi_c/libffi/m4/libtool.m4 +0 -7831
  638. data/ext/ffi_c/libffi/m4/ltoptions.m4 +0 -369
  639. data/ext/ffi_c/libffi/m4/ltsugar.m4 +0 -123
  640. data/ext/ffi_c/libffi/m4/ltversion.m4 +0 -23
  641. data/ext/ffi_c/libffi/m4/lt~obsolete.m4 +0 -98
  642. data/ext/ffi_c/libffi/mdate-sh +0 -201
  643. data/ext/ffi_c/libffi/src/arm/gentramp.sh +0 -118
  644. data/ext/ffi_c/libffi/src/arm/trampoline.S +0 -4450
  645. data/ext/ffi_c/libffi/src/x86/darwin.S +0 -444
  646. data/ext/ffi_c/libffi/src/x86/darwin64.S +0 -416
  647. data/ext/ffi_c/libffi/src/x86/freebsd.S +0 -458
  648. data/ext/ffi_c/libffi/src/x86/win32.S +0 -1065
  649. data/ext/ffi_c/libffi/testsuite/lib/libffi-dg.exp +0 -300
  650. data/ext/ffi_c/libffi/testsuite/libffi.call/many_win32.c +0 -63
  651. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen_win32.c +0 -44
  652. data/ext/ffi_c/libffi/testsuite/libffi.special/ffitestcxx.h +0 -96
  653. data/ext/ffi_c/libffi/texinfo.tex +0 -7210
  654. data/ext/ffi_c/win32/stdint.h +0 -199
  655. data/gen/Rakefile +0 -30
  656. data/lib/Lib.iml +0 -13
  657. data/spec/ffi/Ffi.iml +0 -12
  658. data/spec/ffi/async_callback_spec.rb +0 -46
  659. data/spec/ffi/bool_spec.rb +0 -40
  660. data/spec/ffi/buffer_spec.rb +0 -215
  661. data/spec/ffi/callback_spec.rb +0 -668
  662. data/spec/ffi/custom_param_type.rb +0 -47
  663. data/spec/ffi/custom_type_spec.rb +0 -85
  664. data/spec/ffi/dup_spec.rb +0 -65
  665. data/spec/ffi/enum_spec.rb +0 -227
  666. data/spec/ffi/errno_spec.rb +0 -29
  667. data/spec/ffi/ffi_spec.rb +0 -40
  668. data/spec/ffi/function_spec.rb +0 -87
  669. data/spec/ffi/library_spec.rb +0 -208
  670. data/spec/ffi/long_double.rb +0 -41
  671. data/spec/ffi/managed_struct_spec.rb +0 -72
  672. data/spec/ffi/number_spec.rb +0 -247
  673. data/spec/ffi/pointer_spec.rb +0 -214
  674. data/spec/ffi/rbx/attach_function_spec.rb +0 -28
  675. data/spec/ffi/rbx/memory_pointer_spec.rb +0 -111
  676. data/spec/ffi/rbx/spec_helper.rb +0 -1
  677. data/spec/ffi/rbx/struct_spec.rb +0 -13
  678. data/spec/ffi/spec_helper.rb +0 -35
  679. data/spec/ffi/string_spec.rb +0 -119
  680. data/spec/ffi/strptr_spec.rb +0 -61
  681. data/spec/ffi/struct_callback_spec.rb +0 -80
  682. data/spec/ffi/struct_initialize_spec.rb +0 -46
  683. data/spec/ffi/struct_packed_spec.rb +0 -62
  684. data/spec/ffi/struct_spec.rb +0 -719
  685. data/spec/ffi/typedef_spec.rb +0 -89
  686. data/spec/ffi/union_spec.rb +0 -76
  687. data/spec/ffi/variadic_spec.rb +0 -103
  688. data/spec/spec.opts +0 -4
  689. data/tasks/ann.rake +0 -80
  690. data/tasks/extension.rake +0 -32
  691. data/tasks/gem.rake +0 -199
  692. data/tasks/git.rake +0 -41
  693. data/tasks/notes.rake +0 -27
  694. data/tasks/post_load.rake +0 -34
  695. data/tasks/rdoc.rake +0 -50
  696. data/tasks/rubyforge.rake +0 -55
  697. data/tasks/setup.rb +0 -301
  698. data/tasks/spec.rake +0 -54
  699. data/tasks/svn.rake +0 -47
  700. data/tasks/test.rake +0 -40
  701. data/tasks/yard.rake +0 -11
  702. data/ext/ffi_c/libffi/testsuite/libffi.call/{pyobjc-tc.c → pyobjc_tc.c} +0 -0
  703. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double.c +0 -0
  704. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/err_bad_abi.c +0 -0
  705. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/problem1.c +0 -0
  706. data/lib/ffi/platform/{i486-gnu → i386-gnu}/types.conf +84 -84
@@ -1,5 +1,6 @@
1
1
  /* -----------------------------------------------------------------------
2
- ffi.c - Copyright (c) 1996, 1998, 1999, 2001, 2007, 2008 Red Hat, Inc.
2
+ ffi.c - Copyright (c) 2017, 2022 Anthony Green
3
+ Copyright (c) 1996, 1998, 1999, 2001, 2007, 2008 Red Hat, Inc.
3
4
  Copyright (c) 2002 Ranjit Mathew
4
5
  Copyright (c) 2002 Bo Thorsen
5
6
  Copyright (c) 2002 Roger Sayle
@@ -28,478 +29,534 @@
28
29
  DEALINGS IN THE SOFTWARE.
29
30
  ----------------------------------------------------------------------- */
30
31
 
31
- #if !defined(__x86_64__) || defined(_WIN64)
32
-
33
- #ifdef _WIN64
34
- #include <windows.h>
35
- #endif
36
-
32
+ #if defined(__i386__) || defined(_M_IX86)
37
33
  #include <ffi.h>
38
34
  #include <ffi_common.h>
39
-
35
+ #include <stdint.h>
40
36
  #include <stdlib.h>
41
-
42
- /* ffi_prep_args is called by the assembly routine once stack space
43
- has been allocated for the function's arguments */
44
-
45
- void ffi_prep_args(char *stack, extended_cif *ecif)
46
- {
47
- register unsigned int i;
48
- register void **p_argv;
49
- register char *argp;
50
- register ffi_type **p_arg;
51
-
52
- argp = stack;
53
-
54
- if (ecif->cif->flags == FFI_TYPE_STRUCT
55
- #ifdef X86_WIN64
56
- && (ecif->cif->rtype->size != 1 && ecif->cif->rtype->size != 2
57
- && ecif->cif->rtype->size != 4 && ecif->cif->rtype->size != 8)
37
+ #include <tramp.h>
38
+ #include "internal.h"
39
+
40
+ /* Force FFI_TYPE_LONGDOUBLE to be different than FFI_TYPE_DOUBLE;
41
+ all further uses in this file will refer to the 80-bit type. */
42
+ #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
43
+ # if FFI_TYPE_LONGDOUBLE != 4
44
+ # error FFI_TYPE_LONGDOUBLE out of date
45
+ # endif
46
+ #else
47
+ # undef FFI_TYPE_LONGDOUBLE
48
+ # define FFI_TYPE_LONGDOUBLE 4
58
49
  #endif
59
- )
60
- {
61
- *(void **) argp = ecif->rvalue;
62
- argp += sizeof(void*);
63
- }
64
50
 
65
- p_argv = ecif->avalue;
66
-
67
- for (i = ecif->cif->nargs, p_arg = ecif->cif->arg_types;
68
- i != 0;
69
- i--, p_arg++)
70
- {
71
- size_t z;
72
-
73
- /* Align if necessary */
74
- if ((sizeof(void*) - 1) & (size_t) argp)
75
- argp = (char *) ALIGN(argp, sizeof(void*));
76
-
77
- z = (*p_arg)->size;
78
- #ifdef X86_WIN64
79
- if (z > sizeof(ffi_arg)
80
- || ((*p_arg)->type == FFI_TYPE_STRUCT
81
- && (z != 1 && z != 2 && z != 4 && z != 8))
82
- #if FFI_TYPE_DOUBLE != FFI_TYPE_LONGDOUBLE
83
- || ((*p_arg)->type == FFI_TYPE_LONGDOUBLE)
84
- #endif
85
- )
86
- {
87
- z = sizeof(ffi_arg);
88
- *(void **)argp = *p_argv;
89
- }
90
- else if ((*p_arg)->type == FFI_TYPE_FLOAT)
91
- {
92
- memcpy(argp, *p_argv, z);
93
- }
94
- else
51
+ #if defined(__GNUC__) && !defined(__declspec)
52
+ # define __declspec(x) __attribute__((x))
95
53
  #endif
96
- if (z < sizeof(ffi_arg))
97
- {
98
- z = sizeof(ffi_arg);
99
- switch ((*p_arg)->type)
100
- {
101
- case FFI_TYPE_SINT8:
102
- *(ffi_sarg *) argp = (ffi_sarg)*(SINT8 *)(* p_argv);
103
- break;
104
-
105
- case FFI_TYPE_UINT8:
106
- *(ffi_arg *) argp = (ffi_arg)*(UINT8 *)(* p_argv);
107
- break;
108
-
109
- case FFI_TYPE_SINT16:
110
- *(ffi_sarg *) argp = (ffi_sarg)*(SINT16 *)(* p_argv);
111
- break;
112
-
113
- case FFI_TYPE_UINT16:
114
- *(ffi_arg *) argp = (ffi_arg)*(UINT16 *)(* p_argv);
115
- break;
116
-
117
- case FFI_TYPE_SINT32:
118
- *(ffi_sarg *) argp = (ffi_sarg)*(SINT32 *)(* p_argv);
119
- break;
120
-
121
- case FFI_TYPE_UINT32:
122
- *(ffi_arg *) argp = (ffi_arg)*(UINT32 *)(* p_argv);
123
- break;
124
-
125
- case FFI_TYPE_STRUCT:
126
- *(ffi_arg *) argp = *(ffi_arg *)(* p_argv);
127
- break;
128
-
129
- default:
130
- FFI_ASSERT(0);
131
- }
132
- }
133
- else
134
- {
135
- memcpy(argp, *p_argv, z);
136
- }
137
- p_argv++;
138
- #ifdef X86_WIN64
139
- argp += (z + sizeof(void*) - 1) & ~(sizeof(void*) - 1);
54
+
55
+ #if defined(_MSC_VER) && defined(_M_IX86)
56
+ /* Stack is not 16-byte aligned on Windows. */
57
+ #define STACK_ALIGN(bytes) (bytes)
140
58
  #else
141
- argp += z;
59
+ #define STACK_ALIGN(bytes) FFI_ALIGN (bytes, 16)
142
60
  #endif
143
- }
144
-
145
- return;
146
- }
147
61
 
148
- /* Perform machine dependent cif processing */
149
- ffi_status ffi_prep_cif_machdep(ffi_cif *cif)
62
+ /* Perform machine dependent cif processing. */
63
+ ffi_status FFI_HIDDEN
64
+ ffi_prep_cif_machdep(ffi_cif *cif)
150
65
  {
151
- unsigned int i;
152
- ffi_type **ptr;
66
+ size_t bytes = 0;
67
+ int i, n, flags, cabi = cif->abi;
68
+
69
+ switch (cabi)
70
+ {
71
+ case FFI_SYSV:
72
+ case FFI_STDCALL:
73
+ case FFI_THISCALL:
74
+ case FFI_FASTCALL:
75
+ case FFI_MS_CDECL:
76
+ case FFI_PASCAL:
77
+ case FFI_REGISTER:
78
+ break;
79
+ default:
80
+ return FFI_BAD_ABI;
81
+ }
153
82
 
154
- /* Set the return type flag */
155
83
  switch (cif->rtype->type)
156
84
  {
157
85
  case FFI_TYPE_VOID:
86
+ flags = X86_RET_VOID;
87
+ break;
88
+ case FFI_TYPE_FLOAT:
89
+ flags = X86_RET_FLOAT;
90
+ break;
91
+ case FFI_TYPE_DOUBLE:
92
+ flags = X86_RET_DOUBLE;
93
+ break;
94
+ case FFI_TYPE_LONGDOUBLE:
95
+ flags = X86_RET_LDOUBLE;
96
+ break;
158
97
  case FFI_TYPE_UINT8:
98
+ flags = X86_RET_UINT8;
99
+ break;
159
100
  case FFI_TYPE_UINT16:
101
+ flags = X86_RET_UINT16;
102
+ break;
160
103
  case FFI_TYPE_SINT8:
104
+ flags = X86_RET_SINT8;
105
+ break;
161
106
  case FFI_TYPE_SINT16:
162
- #ifdef X86_WIN64
163
- case FFI_TYPE_UINT32:
107
+ flags = X86_RET_SINT16;
108
+ break;
109
+ case FFI_TYPE_INT:
164
110
  case FFI_TYPE_SINT32:
165
- #endif
166
- case FFI_TYPE_SINT64:
167
- case FFI_TYPE_FLOAT:
168
- case FFI_TYPE_DOUBLE:
169
- #ifndef X86_WIN64
170
- #if FFI_TYPE_DOUBLE != FFI_TYPE_LONGDOUBLE
171
- case FFI_TYPE_LONGDOUBLE:
172
- #endif
173
- #endif
174
- cif->flags = (unsigned) cif->rtype->type;
111
+ case FFI_TYPE_UINT32:
112
+ case FFI_TYPE_POINTER:
113
+ flags = X86_RET_INT32;
175
114
  break;
176
-
115
+ case FFI_TYPE_SINT64:
177
116
  case FFI_TYPE_UINT64:
178
- #ifdef X86_WIN64
179
- case FFI_TYPE_POINTER:
180
- #endif
181
- cif->flags = FFI_TYPE_SINT64;
117
+ flags = X86_RET_INT64;
182
118
  break;
183
-
184
119
  case FFI_TYPE_STRUCT:
185
- #ifndef X86
186
- if (cif->rtype->size == 1)
187
- {
188
- cif->flags = FFI_TYPE_SMALL_STRUCT_1B; /* same as char size */
189
- }
190
- else if (cif->rtype->size == 2)
191
- {
192
- cif->flags = FFI_TYPE_SMALL_STRUCT_2B; /* same as short size */
193
- }
194
- else if (cif->rtype->size == 4)
195
- {
196
- #ifdef X86_WIN64
197
- cif->flags = FFI_TYPE_SMALL_STRUCT_4B;
198
- #else
199
- cif->flags = FFI_TYPE_INT; /* same as int type */
200
- #endif
201
- }
202
- else if (cif->rtype->size == 8)
203
- {
204
- cif->flags = FFI_TYPE_SINT64; /* same as int64 type */
205
- }
206
- else
120
+ {
121
+ #ifdef X86_WIN32
122
+ size_t size = cif->rtype->size;
123
+ if (size == 1)
124
+ flags = X86_RET_STRUCT_1B;
125
+ else if (size == 2)
126
+ flags = X86_RET_STRUCT_2B;
127
+ else if (size == 4)
128
+ flags = X86_RET_INT32;
129
+ else if (size == 8)
130
+ flags = X86_RET_INT64;
131
+ else
207
132
  #endif
208
- {
209
- cif->flags = FFI_TYPE_STRUCT;
210
- /* allocate space for return value pointer */
211
- cif->bytes += ALIGN(sizeof(void*), FFI_SIZEOF_ARG);
212
- }
213
- break;
214
-
215
- default:
216
- #ifdef X86_WIN64
217
- cif->flags = FFI_TYPE_SINT64;
133
+ {
134
+ do_struct:
135
+ switch (cabi)
136
+ {
137
+ case FFI_THISCALL:
138
+ case FFI_FASTCALL:
139
+ case FFI_STDCALL:
140
+ case FFI_MS_CDECL:
141
+ flags = X86_RET_STRUCTARG;
142
+ break;
143
+ default:
144
+ flags = X86_RET_STRUCTPOP;
145
+ break;
146
+ }
147
+ /* Allocate space for return value pointer. */
148
+ bytes += FFI_ALIGN (sizeof(void*), FFI_SIZEOF_ARG);
149
+ }
150
+ }
218
151
  break;
219
- case FFI_TYPE_INT:
220
- cif->flags = FFI_TYPE_SINT32;
221
- #else
222
- cif->flags = FFI_TYPE_INT;
223
- #endif
152
+ case FFI_TYPE_COMPLEX:
153
+ switch (cif->rtype->elements[0]->type)
154
+ {
155
+ case FFI_TYPE_DOUBLE:
156
+ case FFI_TYPE_LONGDOUBLE:
157
+ case FFI_TYPE_SINT64:
158
+ case FFI_TYPE_UINT64:
159
+ goto do_struct;
160
+ case FFI_TYPE_FLOAT:
161
+ case FFI_TYPE_INT:
162
+ case FFI_TYPE_SINT32:
163
+ case FFI_TYPE_UINT32:
164
+ flags = X86_RET_INT64;
165
+ break;
166
+ case FFI_TYPE_SINT16:
167
+ case FFI_TYPE_UINT16:
168
+ flags = X86_RET_INT32;
169
+ break;
170
+ case FFI_TYPE_SINT8:
171
+ case FFI_TYPE_UINT8:
172
+ flags = X86_RET_STRUCT_2B;
173
+ break;
174
+ default:
175
+ return FFI_BAD_TYPEDEF;
176
+ }
224
177
  break;
178
+ default:
179
+ return FFI_BAD_TYPEDEF;
225
180
  }
181
+ cif->flags = flags;
226
182
 
227
- for (ptr = cif->arg_types, i = cif->nargs; i > 0; i--, ptr++)
183
+ for (i = 0, n = cif->nargs; i < n; i++)
228
184
  {
229
- if (((*ptr)->alignment - 1) & cif->bytes)
230
- cif->bytes = ALIGN(cif->bytes, (*ptr)->alignment);
231
- cif->bytes += ALIGN((*ptr)->size, FFI_SIZEOF_ARG);
232
- }
233
-
234
- #ifdef X86_WIN64
235
- /* ensure space for storing four registers */
236
- cif->bytes += 4 * sizeof(ffi_arg);
237
- #endif
185
+ ffi_type *t = cif->arg_types[i];
238
186
 
239
- #ifdef X86_DARWIN
240
- cif->bytes = (cif->bytes + 15) & ~0xF;
187
+ #if defined(X86_WIN32)
188
+ if (cabi == FFI_STDCALL)
189
+ bytes = FFI_ALIGN (bytes, FFI_SIZEOF_ARG);
190
+ else
241
191
  #endif
192
+ bytes = FFI_ALIGN (bytes, t->alignment);
193
+ bytes += FFI_ALIGN (t->size, FFI_SIZEOF_ARG);
194
+ }
195
+ cif->bytes = bytes;
242
196
 
243
197
  return FFI_OK;
244
198
  }
245
199
 
246
- #ifdef X86_WIN64
247
- extern int
248
- ffi_call_win64(void (*)(char *, extended_cif *), extended_cif *,
249
- unsigned, unsigned, unsigned *, void (*fn)(void));
250
- #elif defined(X86_WIN32)
251
- extern void
252
- ffi_call_win32(void (*)(char *, extended_cif *), extended_cif *,
253
- unsigned, unsigned, unsigned *, void (*fn)(void));
254
- #else
255
- extern void ffi_call_SYSV(void (*)(char *, extended_cif *), extended_cif *,
256
- unsigned, unsigned, unsigned *, void (*fn)(void));
257
- #endif
258
-
259
- void ffi_call(ffi_cif *cif, void (*fn)(void), void *rvalue, void **avalue)
200
+ static ffi_arg
201
+ extend_basic_type(void *arg, int type)
260
202
  {
261
- extended_cif ecif;
262
-
263
- ecif.cif = cif;
264
- ecif.avalue = avalue;
265
-
266
- /* If the return value is a struct and we don't have a return */
267
- /* value address then we need to make one */
268
-
269
- #ifdef X86_WIN64
270
- if (rvalue == NULL
271
- && cif->flags == FFI_TYPE_STRUCT
272
- && cif->rtype->size != 1 && cif->rtype->size != 2
273
- && cif->rtype->size != 4 && cif->rtype->size != 8)
203
+ switch (type)
274
204
  {
275
- ecif.rvalue = alloca((cif->rtype->size + 0xF) & ~0xF);
276
- }
277
- #else
278
- if (rvalue == NULL
279
- && cif->flags == FFI_TYPE_STRUCT)
280
- {
281
- ecif.rvalue = alloca(cif->rtype->size);
282
- }
283
- #endif
284
- else
285
- ecif.rvalue = rvalue;
286
-
287
-
288
- switch (cif->abi)
289
- {
290
- #ifdef X86_WIN64
291
- case FFI_WIN64:
292
- ffi_call_win64(ffi_prep_args, &ecif, cif->bytes,
293
- cif->flags, ecif.rvalue, fn);
294
- break;
295
- #elif defined(X86_WIN32)
296
- case FFI_SYSV:
297
- case FFI_STDCALL:
298
- ffi_call_win32(ffi_prep_args, &ecif, cif->bytes, cif->flags,
299
- ecif.rvalue, fn);
300
- break;
301
- #else
302
- case FFI_SYSV:
303
- ffi_call_SYSV(ffi_prep_args, &ecif, cif->bytes, cif->flags, ecif.rvalue,
304
- fn);
305
- break;
306
- #endif
205
+ case FFI_TYPE_SINT8:
206
+ return *(SINT8 *)arg;
207
+ case FFI_TYPE_UINT8:
208
+ return *(UINT8 *)arg;
209
+ case FFI_TYPE_SINT16:
210
+ return *(SINT16 *)arg;
211
+ case FFI_TYPE_UINT16:
212
+ return *(UINT16 *)arg;
213
+
214
+ case FFI_TYPE_SINT32:
215
+ case FFI_TYPE_UINT32:
216
+ case FFI_TYPE_POINTER:
217
+ case FFI_TYPE_FLOAT:
218
+ return *(UINT32 *)arg;
219
+
307
220
  default:
308
- FFI_ASSERT(0);
309
- break;
221
+ abort();
310
222
  }
311
223
  }
312
224
 
225
+ struct call_frame
226
+ {
227
+ void *ebp; /* 0 */
228
+ void *retaddr; /* 4 */
229
+ void (*fn)(void); /* 8 */
230
+ int flags; /* 12 */
231
+ void *rvalue; /* 16 */
232
+ unsigned regs[3]; /* 20-28 */
233
+ };
234
+
235
+ struct abi_params
236
+ {
237
+ int dir; /* parameter growth direction */
238
+ int static_chain; /* the static chain register used by gcc */
239
+ int nregs; /* number of register parameters */
240
+ int regs[3];
241
+ };
242
+
243
+ static const struct abi_params abi_params[FFI_LAST_ABI] = {
244
+ [FFI_SYSV] = { 1, R_ECX, 0 },
245
+ [FFI_THISCALL] = { 1, R_EAX, 1, { R_ECX } },
246
+ [FFI_FASTCALL] = { 1, R_EAX, 2, { R_ECX, R_EDX } },
247
+ [FFI_STDCALL] = { 1, R_ECX, 0 },
248
+ [FFI_PASCAL] = { -1, R_ECX, 0 },
249
+ /* ??? No defined static chain; gcc does not support REGISTER. */
250
+ [FFI_REGISTER] = { -1, R_ECX, 3, { R_EAX, R_EDX, R_ECX } },
251
+ [FFI_MS_CDECL] = { 1, R_ECX, 0 }
252
+ };
253
+
254
+ #ifdef HAVE_FASTCALL
255
+ #ifdef _MSC_VER
256
+ #define FFI_DECLARE_FASTCALL __fastcall
257
+ #else
258
+ #define FFI_DECLARE_FASTCALL __declspec(fastcall)
259
+ #endif
260
+ #else
261
+ #define FFI_DECLARE_FASTCALL
262
+ #endif
313
263
 
314
- /** private members **/
264
+ extern void FFI_DECLARE_FASTCALL ffi_call_i386(struct call_frame *, char *) FFI_HIDDEN;
315
265
 
316
- /* The following __attribute__((regparm(1))) decorations will have no effect
317
- on MSVC - standard cdecl convention applies. */
318
- static void ffi_prep_incoming_args_SYSV (char *stack, void **ret,
319
- void** args, ffi_cif* cif);
320
- void FFI_HIDDEN ffi_closure_SYSV (ffi_closure *)
321
- __attribute__ ((regparm(1)));
322
- unsigned int FFI_HIDDEN ffi_closure_SYSV_inner (ffi_closure *, void **, void *)
323
- __attribute__ ((regparm(1)));
324
- void FFI_HIDDEN ffi_closure_raw_SYSV (ffi_raw_closure *)
325
- __attribute__ ((regparm(1)));
326
- #ifdef X86_WIN32
327
- void FFI_HIDDEN ffi_closure_STDCALL (ffi_closure *)
328
- __attribute__ ((regparm(1)));
329
- #endif
330
- #ifdef X86_WIN64
331
- void FFI_HIDDEN ffi_closure_win64 (ffi_closure *);
266
+ /* We perform some black magic here to use some of the parent's stack frame in
267
+ * ffi_call_i386() that breaks with the MSVC compiler with the /RTCs or /GZ
268
+ * flags. Disable the 'Stack frame run time error checking' for this function
269
+ * so we don't hit weird exceptions in debug builds. */
270
+ #if defined(_MSC_VER)
271
+ #pragma runtime_checks("s", off)
332
272
  #endif
273
+ static void
274
+ ffi_call_int (ffi_cif *cif, void (*fn)(void), void *rvalue,
275
+ void **avalue, void *closure)
276
+ {
277
+ size_t rsize, bytes;
278
+ struct call_frame *frame;
279
+ char *stack, *argp;
280
+ ffi_type **arg_types;
281
+ int flags, cabi, i, n, dir, narg_reg;
282
+ const struct abi_params *pabi;
283
+
284
+ flags = cif->flags;
285
+ cabi = cif->abi;
286
+ pabi = &abi_params[cabi];
287
+ dir = pabi->dir;
288
+
289
+ rsize = 0;
290
+ if (rvalue == NULL)
291
+ {
292
+ switch (flags)
293
+ {
294
+ case X86_RET_FLOAT:
295
+ case X86_RET_DOUBLE:
296
+ case X86_RET_LDOUBLE:
297
+ case X86_RET_STRUCTPOP:
298
+ case X86_RET_STRUCTARG:
299
+ /* The float cases need to pop the 387 stack.
300
+ The struct cases need to pass a valid pointer to the callee. */
301
+ rsize = cif->rtype->size;
302
+ break;
303
+ default:
304
+ /* We can pretend that the callee returns nothing. */
305
+ flags = X86_RET_VOID;
306
+ break;
307
+ }
308
+ }
333
309
 
334
- /* This function is jumped to by the trampoline */
335
-
336
- #ifdef X86_WIN64
337
- void * FFI_HIDDEN
338
- ffi_closure_win64_inner (ffi_closure *closure, void *args) {
339
- ffi_cif *cif;
340
- void **arg_area;
341
- void *result;
342
- void *resp = &result;
343
-
344
- cif = closure->cif;
345
- arg_area = (void**) alloca (cif->nargs * sizeof (void*));
346
-
347
- /* this call will initialize ARG_AREA, such that each
348
- * element in that array points to the corresponding
349
- * value on the stack; and if the function returns
350
- * a structure, it will change RESP to point to the
351
- * structure return address. */
352
-
353
- ffi_prep_incoming_args_SYSV(args, &resp, arg_area, cif);
354
-
355
- (closure->fun) (cif, resp, arg_area, closure->user_data);
356
-
357
- /* The result is returned in rax. This does the right thing for
358
- result types except for floats; we have to 'mov xmm0, rax' in the
359
- caller to correct this.
360
- TODO: structure sizes of 3 5 6 7 are returned by reference, too!!!
361
- */
362
- return cif->rtype->size > sizeof(void *) ? resp : *(void **)resp;
363
- }
310
+ bytes = STACK_ALIGN (cif->bytes);
311
+ stack = alloca(bytes + sizeof(*frame) + rsize);
312
+ argp = (dir < 0 ? stack + bytes : stack);
313
+ frame = (struct call_frame *)(stack + bytes);
314
+ if (rsize)
315
+ rvalue = frame + 1;
364
316
 
365
- #else
366
- unsigned int FFI_HIDDEN __attribute__ ((regparm(1)))
367
- ffi_closure_SYSV_inner (ffi_closure *closure, void **respp, void *args)
368
- {
369
- /* our various things... */
370
- ffi_cif *cif;
371
- void **arg_area;
317
+ frame->fn = fn;
318
+ frame->flags = flags;
319
+ frame->rvalue = rvalue;
320
+ frame->regs[pabi->static_chain] = (unsigned)closure;
372
321
 
373
- cif = closure->cif;
374
- arg_area = (void**) alloca (cif->nargs * sizeof (void*));
322
+ narg_reg = 0;
323
+ switch (flags)
324
+ {
325
+ case X86_RET_STRUCTARG:
326
+ /* The pointer is passed as the first argument. */
327
+ if (pabi->nregs > 0)
328
+ {
329
+ frame->regs[pabi->regs[0]] = (unsigned)rvalue;
330
+ narg_reg = 1;
331
+ break;
332
+ }
333
+ /* fallthru */
334
+ case X86_RET_STRUCTPOP:
335
+ *(void **)argp = rvalue;
336
+ argp += sizeof(void *);
337
+ break;
338
+ }
375
339
 
376
- /* this call will initialize ARG_AREA, such that each
377
- * element in that array points to the corresponding
378
- * value on the stack; and if the function returns
379
- * a structure, it will change RESP to point to the
380
- * structure return address. */
340
+ arg_types = cif->arg_types;
341
+ for (i = 0, n = cif->nargs; i < n; i++)
342
+ {
343
+ ffi_type *ty = arg_types[i];
344
+ void *valp = avalue[i];
345
+ size_t z = ty->size;
346
+ int t = ty->type;
381
347
 
382
- ffi_prep_incoming_args_SYSV(args, respp, arg_area, cif);
348
+ if (z <= FFI_SIZEOF_ARG && t != FFI_TYPE_STRUCT)
349
+ {
350
+ ffi_arg val = extend_basic_type (valp, t);
351
+
352
+ if (t != FFI_TYPE_FLOAT && narg_reg < pabi->nregs)
353
+ frame->regs[pabi->regs[narg_reg++]] = val;
354
+ else if (dir < 0)
355
+ {
356
+ argp -= 4;
357
+ *(ffi_arg *)argp = val;
358
+ }
359
+ else
360
+ {
361
+ *(ffi_arg *)argp = val;
362
+ argp += 4;
363
+ }
364
+ }
365
+ else
366
+ {
367
+ size_t za = FFI_ALIGN (z, FFI_SIZEOF_ARG);
368
+ size_t align = FFI_SIZEOF_ARG;
369
+
370
+ /* Issue 434: For thiscall and fastcall, if the paramter passed
371
+ as 64-bit integer or struct, all following integer parameters
372
+ will be passed on stack. */
373
+ if ((cabi == FFI_THISCALL || cabi == FFI_FASTCALL)
374
+ && (t == FFI_TYPE_SINT64
375
+ || t == FFI_TYPE_UINT64
376
+ || t == FFI_TYPE_STRUCT))
377
+ narg_reg = 2;
378
+
379
+ /* Alignment rules for arguments are quite complex. Vectors and
380
+ structures with 16 byte alignment get it. Note that long double
381
+ on Darwin does have 16 byte alignment, and does not get this
382
+ alignment if passed directly; a structure with a long double
383
+ inside, however, would get 16 byte alignment. Since libffi does
384
+ not support vectors, we need non concern ourselves with other
385
+ cases. */
386
+ if (t == FFI_TYPE_STRUCT && ty->alignment >= 16)
387
+ align = 16;
388
+
389
+ if (dir < 0)
390
+ {
391
+ /* ??? These reverse argument ABIs are probably too old
392
+ to have cared about alignment. Someone should check. */
393
+ argp -= za;
394
+ memcpy (argp, valp, z);
395
+ }
396
+ else
397
+ {
398
+ argp = (char *)FFI_ALIGN (argp, align);
399
+ memcpy (argp, valp, z);
400
+ argp += za;
401
+ }
402
+ }
403
+ }
404
+ FFI_ASSERT (dir > 0 || argp == stack);
383
405
 
384
- (closure->fun) (cif, *respp, arg_area, closure->user_data);
406
+ ffi_call_i386 (frame, stack);
407
+ }
408
+ #if defined(_MSC_VER)
409
+ #pragma runtime_checks("s", restore)
410
+ #endif
385
411
 
386
- return cif->flags;
412
+ void
413
+ ffi_call (ffi_cif *cif, void (*fn)(void), void *rvalue, void **avalue)
414
+ {
415
+ ffi_call_int (cif, fn, rvalue, avalue, NULL);
387
416
  }
388
- #endif /* !X86_WIN64 */
389
417
 
390
- static void
391
- ffi_prep_incoming_args_SYSV(char *stack, void **rvalue, void **avalue,
392
- ffi_cif *cif)
418
+ #ifdef FFI_GO_CLOSURES
419
+ void
420
+ ffi_call_go (ffi_cif *cif, void (*fn)(void), void *rvalue,
421
+ void **avalue, void *closure)
393
422
  {
394
- register unsigned int i;
395
- register void **p_argv;
396
- register char *argp;
397
- register ffi_type **p_arg;
398
-
399
- argp = stack;
400
-
401
- #ifdef X86_WIN64
402
- if (cif->rtype->size > sizeof(ffi_arg)
403
- || (cif->flags == FFI_TYPE_STRUCT
404
- && (cif->rtype->size != 1 && cif->rtype->size != 2
405
- && cif->rtype->size != 4 && cif->rtype->size != 8))) {
406
- *rvalue = *(void **) argp;
407
- argp += sizeof(void *);
408
- }
409
- #else
410
- if ( cif->flags == FFI_TYPE_STRUCT ) {
411
- *rvalue = *(void **) argp;
412
- argp += sizeof(void *);
413
- }
423
+ ffi_call_int (cif, fn, rvalue, avalue, closure);
424
+ }
414
425
  #endif
415
426
 
416
- p_argv = avalue;
427
+ /** private members **/
428
+
429
+ void FFI_HIDDEN ffi_closure_i386(void);
430
+ void FFI_HIDDEN ffi_closure_STDCALL(void);
431
+ void FFI_HIDDEN ffi_closure_REGISTER(void);
432
+ #if defined(FFI_EXEC_STATIC_TRAMP)
433
+ void FFI_HIDDEN ffi_closure_i386_alt(void);
434
+ void FFI_HIDDEN ffi_closure_STDCALL_alt(void);
435
+ void FFI_HIDDEN ffi_closure_REGISTER_alt(void);
436
+ #endif
417
437
 
418
- for (i = cif->nargs, p_arg = cif->arg_types; (i != 0); i--, p_arg++)
438
+ struct closure_frame
439
+ {
440
+ unsigned rettemp[4]; /* 0 */
441
+ unsigned regs[3]; /* 16-24 */
442
+ ffi_cif *cif; /* 28 */
443
+ void (*fun)(ffi_cif*,void*,void**,void*); /* 32 */
444
+ void *user_data; /* 36 */
445
+ };
446
+
447
+ int FFI_HIDDEN FFI_DECLARE_FASTCALL
448
+ ffi_closure_inner (struct closure_frame *frame, char *stack)
449
+ {
450
+ ffi_cif *cif = frame->cif;
451
+ int cabi, i, n, flags, dir, narg_reg;
452
+ const struct abi_params *pabi;
453
+ ffi_type **arg_types;
454
+ char *argp;
455
+ void *rvalue;
456
+ void **avalue;
457
+
458
+ cabi = cif->abi;
459
+ flags = cif->flags;
460
+ narg_reg = 0;
461
+ rvalue = frame->rettemp;
462
+ pabi = &abi_params[cabi];
463
+ dir = pabi->dir;
464
+ argp = (dir < 0 ? stack + STACK_ALIGN (cif->bytes) : stack);
465
+
466
+ switch (flags)
419
467
  {
420
- size_t z;
468
+ case X86_RET_STRUCTARG:
469
+ if (pabi->nregs > 0)
470
+ {
471
+ rvalue = (void *)frame->regs[pabi->regs[0]];
472
+ narg_reg = 1;
473
+ frame->rettemp[0] = (unsigned)rvalue;
474
+ break;
475
+ }
476
+ /* fallthru */
477
+ case X86_RET_STRUCTPOP:
478
+ rvalue = *(void **)argp;
479
+ argp += sizeof(void *);
480
+ frame->rettemp[0] = (unsigned)rvalue;
481
+ break;
482
+ }
421
483
 
422
- /* Align if necessary */
423
- if ((sizeof(void*) - 1) & (size_t) argp) {
424
- argp = (char *) ALIGN(argp, sizeof(void*));
425
- }
484
+ n = cif->nargs;
485
+ avalue = alloca(sizeof(void *) * n);
426
486
 
427
- #ifdef X86_WIN64
428
- if ((*p_arg)->size > sizeof(ffi_arg)
429
- || ((*p_arg)->type == FFI_TYPE_STRUCT
430
- && ((*p_arg)->size != 1 && (*p_arg)->size != 2
431
- && (*p_arg)->size != 4 && (*p_arg)->size != 8)))
432
- {
433
- z = sizeof(void *);
434
- *p_argv = *(void **)argp;
435
- }
487
+ arg_types = cif->arg_types;
488
+ for (i = 0; i < n; ++i)
489
+ {
490
+ ffi_type *ty = arg_types[i];
491
+ size_t z = ty->size;
492
+ int t = ty->type;
493
+ void *valp;
494
+
495
+ if (z <= FFI_SIZEOF_ARG && t != FFI_TYPE_STRUCT)
496
+ {
497
+ if (t != FFI_TYPE_FLOAT && narg_reg < pabi->nregs)
498
+ valp = &frame->regs[pabi->regs[narg_reg++]];
499
+ else if (dir < 0)
500
+ {
501
+ argp -= 4;
502
+ valp = argp;
503
+ }
504
+ else
505
+ {
506
+ valp = argp;
507
+ argp += 4;
508
+ }
509
+ }
436
510
  else
437
- #endif
438
- {
439
- z = (*p_arg)->size;
440
-
441
- /* because we're little endian, this is what it turns into. */
442
-
443
- *p_argv = (void*) argp;
444
- }
445
-
446
- p_argv++;
447
- #ifdef X86_WIN64
448
- argp += (z + sizeof(void*) - 1) & ~(sizeof(void*) - 1);
449
- #else
450
- argp += z;
451
- #endif
511
+ {
512
+ size_t za = FFI_ALIGN (z, FFI_SIZEOF_ARG);
513
+ size_t align = FFI_SIZEOF_ARG;
514
+
515
+ /* See the comment in ffi_call_int. */
516
+ if (t == FFI_TYPE_STRUCT && ty->alignment >= 16)
517
+ align = 16;
518
+
519
+ /* Issue 434: For thiscall and fastcall, if the paramter passed
520
+ as 64-bit integer or struct, all following integer parameters
521
+ will be passed on stack. */
522
+ if ((cabi == FFI_THISCALL || cabi == FFI_FASTCALL)
523
+ && (t == FFI_TYPE_SINT64
524
+ || t == FFI_TYPE_UINT64
525
+ || t == FFI_TYPE_STRUCT))
526
+ narg_reg = 2;
527
+
528
+ if (dir < 0)
529
+ {
530
+ /* ??? These reverse argument ABIs are probably too old
531
+ to have cared about alignment. Someone should check. */
532
+ argp -= za;
533
+ valp = argp;
534
+ }
535
+ else
536
+ {
537
+ argp = (char *)FFI_ALIGN (argp, align);
538
+ valp = argp;
539
+ argp += za;
540
+ }
541
+ }
542
+
543
+ avalue[i] = valp;
452
544
  }
453
-
454
- return;
455
- }
456
545
 
457
- #define FFI_INIT_TRAMPOLINE_WIN64(TRAMP,FUN,CTX,MASK) \
458
- { unsigned char *__tramp = (unsigned char*)(TRAMP); \
459
- void* __fun = (void*)(FUN); \
460
- void* __ctx = (void*)(CTX); \
461
- *(unsigned char*) &__tramp[0] = 0x41; \
462
- *(unsigned char*) &__tramp[1] = 0xbb; \
463
- *(unsigned int*) &__tramp[2] = MASK; /* mov $mask, %r11 */ \
464
- *(unsigned char*) &__tramp[6] = 0x48; \
465
- *(unsigned char*) &__tramp[7] = 0xb8; \
466
- *(void**) &__tramp[8] = __ctx; /* mov __ctx, %rax */ \
467
- *(unsigned char *) &__tramp[16] = 0x49; \
468
- *(unsigned char *) &__tramp[17] = 0xba; \
469
- *(void**) &__tramp[18] = __fun; /* mov __fun, %r10 */ \
470
- *(unsigned char *) &__tramp[26] = 0x41; \
471
- *(unsigned char *) &__tramp[27] = 0xff; \
472
- *(unsigned char *) &__tramp[28] = 0xe2; /* jmp %r10 */ \
473
- }
474
-
475
- /* How to make a trampoline. Derived from gcc/config/i386/i386.c. */
476
-
477
- #define FFI_INIT_TRAMPOLINE(TRAMP,FUN,CTX) \
478
- { unsigned char *__tramp = (unsigned char*)(TRAMP); \
479
- unsigned int __fun = (unsigned int)(FUN); \
480
- unsigned int __ctx = (unsigned int)(CTX); \
481
- unsigned int __dis = __fun - (__ctx + 10); \
482
- *(unsigned char*) &__tramp[0] = 0xb8; \
483
- *(unsigned int*) &__tramp[1] = __ctx; /* movl __ctx, %eax */ \
484
- *(unsigned char *) &__tramp[5] = 0xe9; \
485
- *(unsigned int*) &__tramp[6] = __dis; /* jmp __fun */ \
486
- }
487
-
488
- #define FFI_INIT_TRAMPOLINE_STDCALL(TRAMP,FUN,CTX,SIZE) \
489
- { unsigned char *__tramp = (unsigned char*)(TRAMP); \
490
- unsigned int __fun = (unsigned int)(FUN); \
491
- unsigned int __ctx = (unsigned int)(CTX); \
492
- unsigned int __dis = __fun - (__ctx + 10); \
493
- unsigned short __size = (unsigned short)(SIZE); \
494
- *(unsigned char*) &__tramp[0] = 0xb8; \
495
- *(unsigned int*) &__tramp[1] = __ctx; /* movl __ctx, %eax */ \
496
- *(unsigned char *) &__tramp[5] = 0xe8; \
497
- *(unsigned int*) &__tramp[6] = __dis; /* call __fun */ \
498
- *(unsigned char *) &__tramp[10] = 0xc2; \
499
- *(unsigned short*) &__tramp[11] = __size; /* ret __size */ \
500
- }
501
-
502
- /* the cif must already be prep'ed */
546
+ frame->fun (cif, rvalue, avalue, frame->user_data);
547
+
548
+ switch (cabi)
549
+ {
550
+ case FFI_STDCALL:
551
+ return flags | (cif->bytes << X86_RET_POP_SHIFT);
552
+ case FFI_THISCALL:
553
+ case FFI_FASTCALL:
554
+ return flags | ((cif->bytes - (narg_reg * FFI_SIZEOF_ARG))
555
+ << X86_RET_POP_SHIFT);
556
+ default:
557
+ return flags;
558
+ }
559
+ }
503
560
 
504
561
  ffi_status
505
562
  ffi_prep_closure_loc (ffi_closure* closure,
@@ -508,137 +565,268 @@ ffi_prep_closure_loc (ffi_closure* closure,
508
565
  void *user_data,
509
566
  void *codeloc)
510
567
  {
511
- #ifdef X86_WIN64
512
- #define ISFLOAT(IDX) (cif->arg_types[IDX]->type == FFI_TYPE_FLOAT || cif->arg_types[IDX]->type == FFI_TYPE_DOUBLE)
513
- #define FLAG(IDX) (cif->nargs>(IDX)&&ISFLOAT(IDX)?(1<<(IDX)):0)
514
- if (cif->abi == FFI_WIN64)
515
- {
516
- int mask = FLAG(0)|FLAG(1)|FLAG(2)|FLAG(3);
517
- FFI_INIT_TRAMPOLINE_WIN64 (&closure->tramp[0],
518
- &ffi_closure_win64,
519
- codeloc, mask);
520
- /* make sure we can execute here */
521
- }
522
- #else
523
- if (cif->abi == FFI_SYSV)
568
+ char *tramp = closure->tramp;
569
+ void (*dest)(void);
570
+ int op = 0xb8; /* movl imm, %eax */
571
+
572
+ switch (cif->abi)
524
573
  {
525
- FFI_INIT_TRAMPOLINE (&closure->tramp[0],
526
- &ffi_closure_SYSV,
527
- (void*)codeloc);
574
+ case FFI_SYSV:
575
+ case FFI_MS_CDECL:
576
+ dest = ffi_closure_i386;
577
+ break;
578
+ case FFI_STDCALL:
579
+ case FFI_THISCALL:
580
+ case FFI_FASTCALL:
581
+ case FFI_PASCAL:
582
+ dest = ffi_closure_STDCALL;
583
+ break;
584
+ case FFI_REGISTER:
585
+ dest = ffi_closure_REGISTER;
586
+ op = 0x68; /* pushl imm */
587
+ break;
588
+ default:
589
+ return FFI_BAD_ABI;
528
590
  }
529
- #ifdef X86_WIN32
530
- else if (cif->abi == FFI_STDCALL)
591
+
592
+ #if defined(FFI_EXEC_STATIC_TRAMP)
593
+ if (ffi_tramp_is_present(closure))
531
594
  {
532
- FFI_INIT_TRAMPOLINE_STDCALL (&closure->tramp[0],
533
- &ffi_closure_STDCALL,
534
- (void*)codeloc, cif->bytes);
595
+ /* Initialize the static trampoline's parameters. */
596
+ if (dest == ffi_closure_i386)
597
+ dest = ffi_closure_i386_alt;
598
+ else if (dest == ffi_closure_STDCALL)
599
+ dest = ffi_closure_STDCALL_alt;
600
+ else
601
+ dest = ffi_closure_REGISTER_alt;
602
+ ffi_tramp_set_parms (closure->ftramp, dest, closure);
603
+ goto out;
535
604
  }
536
- #endif /* X86_WIN32 */
537
- #endif /* !X86_WIN64 */
538
- else
605
+ #endif
606
+
607
+ /* Initialize the dynamic trampoline. */
608
+ /* endbr32. */
609
+ *(UINT32 *) tramp = 0xfb1e0ff3;
610
+
611
+ /* movl or pushl immediate. */
612
+ tramp[4] = op;
613
+ *(void **)(tramp + 5) = codeloc;
614
+
615
+ /* jmp dest */
616
+ tramp[9] = 0xe9;
617
+ *(unsigned *)(tramp + 10) = (unsigned)dest - ((unsigned)codeloc + 14);
618
+
619
+ #if defined(FFI_EXEC_STATIC_TRAMP)
620
+ out:
621
+ #endif
622
+ closure->cif = cif;
623
+ closure->fun = fun;
624
+ closure->user_data = user_data;
625
+
626
+ return FFI_OK;
627
+ }
628
+
629
+ #ifdef FFI_GO_CLOSURES
630
+
631
+ void FFI_HIDDEN ffi_go_closure_EAX(void);
632
+ void FFI_HIDDEN ffi_go_closure_ECX(void);
633
+ void FFI_HIDDEN ffi_go_closure_STDCALL(void);
634
+
635
+ ffi_status
636
+ ffi_prep_go_closure (ffi_go_closure* closure, ffi_cif* cif,
637
+ void (*fun)(ffi_cif*,void*,void**,void*))
638
+ {
639
+ void (*dest)(void);
640
+
641
+ switch (cif->abi)
539
642
  {
643
+ case FFI_SYSV:
644
+ case FFI_MS_CDECL:
645
+ dest = ffi_go_closure_ECX;
646
+ break;
647
+ case FFI_THISCALL:
648
+ case FFI_FASTCALL:
649
+ dest = ffi_go_closure_EAX;
650
+ break;
651
+ case FFI_STDCALL:
652
+ case FFI_PASCAL:
653
+ dest = ffi_go_closure_STDCALL;
654
+ break;
655
+ case FFI_REGISTER:
656
+ default:
540
657
  return FFI_BAD_ABI;
541
658
  }
542
-
543
- closure->cif = cif;
544
- closure->user_data = user_data;
545
- closure->fun = fun;
659
+
660
+ closure->tramp = dest;
661
+ closure->cif = cif;
662
+ closure->fun = fun;
546
663
 
547
664
  return FFI_OK;
548
665
  }
549
666
 
667
+ #endif /* FFI_GO_CLOSURES */
668
+
550
669
  /* ------- Native raw API support -------------------------------- */
551
670
 
552
671
  #if !FFI_NO_RAW_API
553
672
 
673
+ void FFI_HIDDEN ffi_closure_raw_SYSV(void);
674
+ void FFI_HIDDEN ffi_closure_raw_THISCALL(void);
675
+
554
676
  ffi_status
555
- ffi_prep_raw_closure_loc (ffi_raw_closure* closure,
556
- ffi_cif* cif,
677
+ ffi_prep_raw_closure_loc (ffi_raw_closure *closure,
678
+ ffi_cif *cif,
557
679
  void (*fun)(ffi_cif*,void*,ffi_raw*,void*),
558
680
  void *user_data,
559
681
  void *codeloc)
560
682
  {
683
+ char *tramp = closure->tramp;
684
+ void (*dest)(void);
561
685
  int i;
562
686
 
563
- if (cif->abi != FFI_SYSV) {
564
- return FFI_BAD_ABI;
565
- }
566
-
567
- /* we currently don't support certain kinds of arguments for raw
687
+ /* We currently don't support certain kinds of arguments for raw
568
688
  closures. This should be implemented by a separate assembly
569
689
  language routine, since it would require argument processing,
570
690
  something we don't do now for performance. */
571
-
572
691
  for (i = cif->nargs-1; i >= 0; i--)
692
+ switch (cif->arg_types[i]->type)
693
+ {
694
+ case FFI_TYPE_STRUCT:
695
+ case FFI_TYPE_LONGDOUBLE:
696
+ return FFI_BAD_TYPEDEF;
697
+ }
698
+
699
+ switch (cif->abi)
573
700
  {
574
- FFI_ASSERT (cif->arg_types[i]->type != FFI_TYPE_STRUCT);
575
- FFI_ASSERT (cif->arg_types[i]->type != FFI_TYPE_LONGDOUBLE);
701
+ case FFI_THISCALL:
702
+ dest = ffi_closure_raw_THISCALL;
703
+ break;
704
+ case FFI_SYSV:
705
+ dest = ffi_closure_raw_SYSV;
706
+ break;
707
+ default:
708
+ return FFI_BAD_ABI;
576
709
  }
577
-
578
710
 
579
- FFI_INIT_TRAMPOLINE (&closure->tramp[0], &ffi_closure_raw_SYSV,
580
- codeloc);
581
-
582
- closure->cif = cif;
711
+ /* movl imm, %eax. */
712
+ tramp[0] = 0xb8;
713
+ *(void **)(tramp + 1) = codeloc;
714
+
715
+ /* jmp dest */
716
+ tramp[5] = 0xe9;
717
+ *(unsigned *)(tramp + 6) = (unsigned)dest - ((unsigned)codeloc + 10);
718
+
719
+ closure->cif = cif;
720
+ closure->fun = fun;
583
721
  closure->user_data = user_data;
584
- closure->fun = fun;
585
722
 
586
723
  return FFI_OK;
587
724
  }
588
725
 
589
- static void
590
- ffi_prep_args_raw(char *stack, extended_cif *ecif)
591
- {
592
- memcpy (stack, ecif->avalue, ecif->cif->bytes);
593
- }
594
-
595
- /* we borrow this routine from libffi (it must be changed, though, to
596
- * actually call the function passed in the first argument. as of
597
- * libffi-1.20, this is not the case.)
598
- */
599
-
600
726
  void
601
- ffi_raw_call(ffi_cif *cif, void (*fn)(void), void *rvalue, ffi_raw *fake_avalue)
727
+ ffi_raw_call(ffi_cif *cif, void (*fn)(void), void *rvalue, ffi_raw *avalue)
602
728
  {
603
- extended_cif ecif;
604
- void **avalue = (void **)fake_avalue;
729
+ size_t rsize, bytes;
730
+ struct call_frame *frame;
731
+ char *stack, *argp;
732
+ ffi_type **arg_types;
733
+ int flags, cabi, i, n, narg_reg;
734
+ const struct abi_params *pabi;
735
+
736
+ flags = cif->flags;
737
+ cabi = cif->abi;
738
+ pabi = &abi_params[cabi];
739
+
740
+ rsize = 0;
741
+ if (rvalue == NULL)
742
+ {
743
+ switch (flags)
744
+ {
745
+ case X86_RET_FLOAT:
746
+ case X86_RET_DOUBLE:
747
+ case X86_RET_LDOUBLE:
748
+ case X86_RET_STRUCTPOP:
749
+ case X86_RET_STRUCTARG:
750
+ /* The float cases need to pop the 387 stack.
751
+ The struct cases need to pass a valid pointer to the callee. */
752
+ rsize = cif->rtype->size;
753
+ break;
754
+ default:
755
+ /* We can pretend that the callee returns nothing. */
756
+ flags = X86_RET_VOID;
757
+ break;
758
+ }
759
+ }
605
760
 
606
- ecif.cif = cif;
607
- ecif.avalue = avalue;
608
-
609
- /* If the return value is a struct and we don't have a return */
610
- /* value address then we need to make one */
761
+ bytes = STACK_ALIGN (cif->bytes);
762
+ argp = stack =
763
+ (void *)((uintptr_t)alloca(bytes + sizeof(*frame) + rsize + 15) & ~16);
764
+ frame = (struct call_frame *)(stack + bytes);
765
+ if (rsize)
766
+ rvalue = frame + 1;
611
767
 
612
- if ((rvalue == NULL) &&
613
- (cif->rtype->type == FFI_TYPE_STRUCT))
768
+ frame->fn = fn;
769
+ frame->flags = flags;
770
+ frame->rvalue = rvalue;
771
+
772
+ narg_reg = 0;
773
+ switch (flags)
614
774
  {
615
- ecif.rvalue = alloca(cif->rtype->size);
775
+ case X86_RET_STRUCTARG:
776
+ /* The pointer is passed as the first argument. */
777
+ if (pabi->nregs > 0)
778
+ {
779
+ frame->regs[pabi->regs[0]] = (unsigned)rvalue;
780
+ narg_reg = 1;
781
+ break;
782
+ }
783
+ /* fallthru */
784
+ case X86_RET_STRUCTPOP:
785
+ *(void **)argp = rvalue;
786
+ argp += sizeof(void *);
787
+ bytes -= sizeof(void *);
788
+ break;
616
789
  }
617
- else
618
- ecif.rvalue = rvalue;
619
-
620
-
621
- switch (cif->abi)
790
+
791
+ arg_types = cif->arg_types;
792
+ for (i = 0, n = cif->nargs; narg_reg < pabi->nregs && i < n; i++)
622
793
  {
623
- #ifdef X86_WIN32
624
- case FFI_SYSV:
625
- case FFI_STDCALL:
626
- ffi_call_win32(ffi_prep_args_raw, &ecif, cif->bytes, cif->flags,
627
- ecif.rvalue, fn);
628
- break;
629
- #else
630
- case FFI_SYSV:
631
- ffi_call_SYSV(ffi_prep_args_raw, &ecif, cif->bytes, cif->flags,
632
- ecif.rvalue, fn);
633
- break;
634
- #endif
635
- default:
636
- FFI_ASSERT(0);
637
- break;
794
+ ffi_type *ty = arg_types[i];
795
+ size_t z = ty->size;
796
+ int t = ty->type;
797
+
798
+ if (z <= FFI_SIZEOF_ARG && t != FFI_TYPE_STRUCT && t != FFI_TYPE_FLOAT)
799
+ {
800
+ ffi_arg val = extend_basic_type (avalue, t);
801
+ frame->regs[pabi->regs[narg_reg++]] = val;
802
+ z = FFI_SIZEOF_ARG;
803
+ }
804
+ else
805
+ {
806
+ memcpy (argp, avalue, z);
807
+ z = FFI_ALIGN (z, FFI_SIZEOF_ARG);
808
+ argp += z;
809
+ }
810
+ avalue += z;
811
+ bytes -= z;
638
812
  }
813
+ if (i < n)
814
+ memcpy (argp, avalue, bytes);
815
+
816
+ ffi_call_i386 (frame, stack);
639
817
  }
818
+ #endif /* !FFI_NO_RAW_API */
640
819
 
641
- #endif
820
+ #if defined(FFI_EXEC_STATIC_TRAMP)
821
+ void *
822
+ ffi_tramp_arch (size_t *tramp_size, size_t *map_size)
823
+ {
824
+ extern void *trampoline_code_table;
642
825
 
643
- #endif /* !__x86_64__ || X86_WIN64 */
826
+ *map_size = X86_TRAMP_MAP_SIZE;
827
+ *tramp_size = X86_TRAMP_SIZE;
828
+ return &trampoline_code_table;
829
+ }
830
+ #endif
644
831
 
832
+ #endif /* __i386__ */