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
@@ -0,0 +1,923 @@
1
+ /* -----------------------------------------------------------------------
2
+ ffi_sysv.c - Copyright (C) 2013 IBM
3
+ Copyright (C) 2011 Anthony Green
4
+ Copyright (C) 2011 Kyle Moffett
5
+ Copyright (C) 2008 Red Hat, Inc
6
+ Copyright (C) 2007, 2008 Free Software Foundation, Inc
7
+ Copyright (c) 1998 Geoffrey Keating
8
+
9
+ PowerPC Foreign Function Interface
10
+
11
+ Permission is hereby granted, free of charge, to any person obtaining
12
+ a copy of this software and associated documentation files (the
13
+ ``Software''), to deal in the Software without restriction, including
14
+ without limitation the rights to use, copy, modify, merge, publish,
15
+ distribute, sublicense, and/or sell copies of the Software, and to
16
+ permit persons to whom the Software is furnished to do so, subject to
17
+ the following conditions:
18
+
19
+ The above copyright notice and this permission notice shall be included
20
+ in all copies or substantial portions of the Software.
21
+
22
+ THE SOFTWARE IS PROVIDED ``AS IS'', WITHOUT WARRANTY OF ANY KIND, EXPRESS
23
+ OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
24
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
25
+ IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR
26
+ OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
27
+ ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
28
+ OTHER DEALINGS IN THE SOFTWARE.
29
+ ----------------------------------------------------------------------- */
30
+
31
+ #include "ffi.h"
32
+
33
+ #ifndef POWERPC64
34
+ #include "ffi_common.h"
35
+ #include "ffi_powerpc.h"
36
+
37
+
38
+ /* About the SYSV ABI. */
39
+ #define ASM_NEEDS_REGISTERS 6
40
+ #define NUM_GPR_ARG_REGISTERS 8
41
+ #define NUM_FPR_ARG_REGISTERS 8
42
+
43
+
44
+ #if HAVE_LONG_DOUBLE_VARIANT && FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
45
+ /* Adjust size of ffi_type_longdouble. */
46
+ void FFI_HIDDEN
47
+ ffi_prep_types_sysv (ffi_abi abi)
48
+ {
49
+ if ((abi & (FFI_SYSV | FFI_SYSV_LONG_DOUBLE_128)) == FFI_SYSV)
50
+ {
51
+ ffi_type_longdouble.size = 8;
52
+ ffi_type_longdouble.alignment = 8;
53
+ }
54
+ else
55
+ {
56
+ ffi_type_longdouble.size = 16;
57
+ ffi_type_longdouble.alignment = 16;
58
+ }
59
+ }
60
+ #endif
61
+
62
+ /* Transform long double, double and float to other types as per abi. */
63
+ static int
64
+ translate_float (int abi, int type)
65
+ {
66
+ #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
67
+ if (type == FFI_TYPE_LONGDOUBLE
68
+ && (abi & FFI_SYSV_LONG_DOUBLE_128) == 0)
69
+ type = FFI_TYPE_DOUBLE;
70
+ #endif
71
+ if ((abi & FFI_SYSV_SOFT_FLOAT) != 0)
72
+ {
73
+ if (type == FFI_TYPE_FLOAT)
74
+ type = FFI_TYPE_UINT32;
75
+ else if (type == FFI_TYPE_DOUBLE)
76
+ type = FFI_TYPE_UINT64;
77
+ #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
78
+ else if (type == FFI_TYPE_LONGDOUBLE)
79
+ type = FFI_TYPE_UINT128;
80
+ }
81
+ else if ((abi & FFI_SYSV_IBM_LONG_DOUBLE) == 0)
82
+ {
83
+ if (type == FFI_TYPE_LONGDOUBLE)
84
+ type = FFI_TYPE_STRUCT;
85
+ #endif
86
+ }
87
+ return type;
88
+ }
89
+
90
+ /* Perform machine dependent cif processing */
91
+ static ffi_status
92
+ ffi_prep_cif_sysv_core (ffi_cif *cif)
93
+ {
94
+ ffi_type **ptr;
95
+ unsigned bytes;
96
+ unsigned i, fpr_count = 0, gpr_count = 0, stack_count = 0;
97
+ unsigned flags = cif->flags;
98
+ unsigned struct_copy_size = 0;
99
+ unsigned type = cif->rtype->type;
100
+ unsigned size = cif->rtype->size;
101
+
102
+ /* The machine-independent calculation of cif->bytes doesn't work
103
+ for us. Redo the calculation. */
104
+
105
+ /* Space for the frame pointer, callee's LR, and the asm's temp regs. */
106
+ bytes = (2 + ASM_NEEDS_REGISTERS) * sizeof (int);
107
+
108
+ /* Space for the GPR registers. */
109
+ bytes += NUM_GPR_ARG_REGISTERS * sizeof (int);
110
+
111
+ /* Return value handling. The rules for SYSV are as follows:
112
+ - 32-bit (or less) integer values are returned in gpr3;
113
+ - Structures of size <= 4 bytes also returned in gpr3;
114
+ - 64-bit integer values and structures between 5 and 8 bytes are returned
115
+ in gpr3 and gpr4;
116
+ - Larger structures are allocated space and a pointer is passed as
117
+ the first argument.
118
+ - Single/double FP values are returned in fpr1;
119
+ - long doubles (if not equivalent to double) are returned in
120
+ fpr1,fpr2 for Linux and as for large structs for SysV. */
121
+
122
+ type = translate_float (cif->abi, type);
123
+
124
+ switch (type)
125
+ {
126
+ #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
127
+ case FFI_TYPE_LONGDOUBLE:
128
+ flags |= FLAG_RETURNS_128BITS;
129
+ /* Fall through. */
130
+ #endif
131
+ case FFI_TYPE_DOUBLE:
132
+ flags |= FLAG_RETURNS_64BITS;
133
+ /* Fall through. */
134
+ case FFI_TYPE_FLOAT:
135
+ flags |= FLAG_RETURNS_FP;
136
+ #ifdef __NO_FPRS__
137
+ return FFI_BAD_ABI;
138
+ #endif
139
+ break;
140
+
141
+ case FFI_TYPE_UINT128:
142
+ flags |= FLAG_RETURNS_128BITS;
143
+ /* Fall through. */
144
+ case FFI_TYPE_UINT64:
145
+ case FFI_TYPE_SINT64:
146
+ flags |= FLAG_RETURNS_64BITS;
147
+ break;
148
+
149
+ case FFI_TYPE_STRUCT:
150
+ /* The final SYSV ABI says that structures smaller or equal 8 bytes
151
+ are returned in r3/r4. A draft ABI used by linux instead
152
+ returns them in memory. */
153
+ if ((cif->abi & FFI_SYSV_STRUCT_RET) != 0 && size <= 8)
154
+ {
155
+ flags |= FLAG_RETURNS_SMST;
156
+ break;
157
+ }
158
+ gpr_count++;
159
+ flags |= FLAG_RETVAL_REFERENCE;
160
+ /* Fall through. */
161
+ case FFI_TYPE_VOID:
162
+ flags |= FLAG_RETURNS_NOTHING;
163
+ break;
164
+
165
+ default:
166
+ /* Returns 32-bit integer, or similar. Nothing to do here. */
167
+ break;
168
+ }
169
+
170
+ /* The first NUM_GPR_ARG_REGISTERS words of integer arguments, and the
171
+ first NUM_FPR_ARG_REGISTERS fp arguments, go in registers; the rest
172
+ goes on the stack. Structures and long doubles (if not equivalent
173
+ to double) are passed as a pointer to a copy of the structure.
174
+ Stuff on the stack needs to keep proper alignment. */
175
+ for (ptr = cif->arg_types, i = cif->nargs; i > 0; i--, ptr++)
176
+ {
177
+ unsigned short typenum = (*ptr)->type;
178
+
179
+ typenum = translate_float (cif->abi, typenum);
180
+
181
+ switch (typenum)
182
+ {
183
+ #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
184
+ case FFI_TYPE_LONGDOUBLE:
185
+ if (fpr_count >= NUM_FPR_ARG_REGISTERS - 1)
186
+ {
187
+ fpr_count = NUM_FPR_ARG_REGISTERS;
188
+ /* 8-byte align long doubles. */
189
+ stack_count += stack_count & 1;
190
+ stack_count += 4;
191
+ }
192
+ else
193
+ fpr_count += 2;
194
+ #ifdef __NO_FPRS__
195
+ return FFI_BAD_ABI;
196
+ #endif
197
+ break;
198
+ #endif
199
+
200
+ case FFI_TYPE_DOUBLE:
201
+ if (fpr_count >= NUM_FPR_ARG_REGISTERS)
202
+ {
203
+ /* 8-byte align doubles. */
204
+ stack_count += stack_count & 1;
205
+ stack_count += 2;
206
+ }
207
+ else
208
+ fpr_count += 1;
209
+ #ifdef __NO_FPRS__
210
+ return FFI_BAD_ABI;
211
+ #endif
212
+ break;
213
+
214
+ case FFI_TYPE_FLOAT:
215
+ if (fpr_count >= NUM_FPR_ARG_REGISTERS)
216
+ /* Yes, we don't follow the ABI, but neither does gcc. */
217
+ stack_count += 1;
218
+ else
219
+ fpr_count += 1;
220
+ #ifdef __NO_FPRS__
221
+ return FFI_BAD_ABI;
222
+ #endif
223
+ break;
224
+
225
+ case FFI_TYPE_UINT128:
226
+ /* A long double in FFI_LINUX_SOFT_FLOAT can use only a set
227
+ of four consecutive gprs. If we do not have enough, we
228
+ have to adjust the gpr_count value. */
229
+ if (gpr_count >= NUM_GPR_ARG_REGISTERS - 3)
230
+ gpr_count = NUM_GPR_ARG_REGISTERS;
231
+ if (gpr_count >= NUM_GPR_ARG_REGISTERS)
232
+ stack_count += 4;
233
+ else
234
+ gpr_count += 4;
235
+ break;
236
+
237
+ case FFI_TYPE_UINT64:
238
+ case FFI_TYPE_SINT64:
239
+ /* 'long long' arguments are passed as two words, but
240
+ either both words must fit in registers or both go
241
+ on the stack. If they go on the stack, they must
242
+ be 8-byte-aligned.
243
+
244
+ Also, only certain register pairs can be used for
245
+ passing long long int -- specifically (r3,r4), (r5,r6),
246
+ (r7,r8), (r9,r10). */
247
+ gpr_count += gpr_count & 1;
248
+ if (gpr_count >= NUM_GPR_ARG_REGISTERS)
249
+ {
250
+ stack_count += stack_count & 1;
251
+ stack_count += 2;
252
+ }
253
+ else
254
+ gpr_count += 2;
255
+ break;
256
+
257
+ case FFI_TYPE_STRUCT:
258
+ /* We must allocate space for a copy of these to enforce
259
+ pass-by-value. Pad the space up to a multiple of 16
260
+ bytes (the maximum alignment required for anything under
261
+ the SYSV ABI). */
262
+ struct_copy_size += ((*ptr)->size + 15) & ~0xF;
263
+ /* Fall through (allocate space for the pointer). */
264
+
265
+ case FFI_TYPE_POINTER:
266
+ case FFI_TYPE_INT:
267
+ case FFI_TYPE_UINT32:
268
+ case FFI_TYPE_SINT32:
269
+ case FFI_TYPE_UINT16:
270
+ case FFI_TYPE_SINT16:
271
+ case FFI_TYPE_UINT8:
272
+ case FFI_TYPE_SINT8:
273
+ /* Everything else is passed as a 4-byte word in a GPR, either
274
+ the object itself or a pointer to it. */
275
+ if (gpr_count >= NUM_GPR_ARG_REGISTERS)
276
+ stack_count += 1;
277
+ else
278
+ gpr_count += 1;
279
+ break;
280
+
281
+ default:
282
+ FFI_ASSERT (0);
283
+ }
284
+ }
285
+
286
+ if (fpr_count != 0)
287
+ flags |= FLAG_FP_ARGUMENTS;
288
+ if (gpr_count > 4)
289
+ flags |= FLAG_4_GPR_ARGUMENTS;
290
+ if (struct_copy_size != 0)
291
+ flags |= FLAG_ARG_NEEDS_COPY;
292
+
293
+ /* Space for the FPR registers, if needed. */
294
+ if (fpr_count != 0)
295
+ bytes += NUM_FPR_ARG_REGISTERS * sizeof (double);
296
+
297
+ /* Stack space. */
298
+ bytes += stack_count * sizeof (int);
299
+
300
+ /* The stack space allocated needs to be a multiple of 16 bytes. */
301
+ bytes = (bytes + 15) & ~0xF;
302
+
303
+ /* Add in the space for the copied structures. */
304
+ bytes += struct_copy_size;
305
+
306
+ cif->flags = flags;
307
+ cif->bytes = bytes;
308
+
309
+ return FFI_OK;
310
+ }
311
+
312
+ ffi_status FFI_HIDDEN
313
+ ffi_prep_cif_sysv (ffi_cif *cif)
314
+ {
315
+ if ((cif->abi & FFI_SYSV) == 0)
316
+ {
317
+ /* This call is from old code. Translate to new ABI values. */
318
+ cif->flags |= FLAG_COMPAT;
319
+ switch (cif->abi)
320
+ {
321
+ default:
322
+ return FFI_BAD_ABI;
323
+
324
+ case FFI_COMPAT_SYSV:
325
+ cif->abi = FFI_SYSV | FFI_SYSV_STRUCT_RET | FFI_SYSV_LONG_DOUBLE_128;
326
+ break;
327
+
328
+ case FFI_COMPAT_GCC_SYSV:
329
+ cif->abi = FFI_SYSV | FFI_SYSV_LONG_DOUBLE_128;
330
+ break;
331
+
332
+ case FFI_COMPAT_LINUX:
333
+ cif->abi = (FFI_SYSV | FFI_SYSV_IBM_LONG_DOUBLE
334
+ | FFI_SYSV_LONG_DOUBLE_128);
335
+ break;
336
+
337
+ case FFI_COMPAT_LINUX_SOFT_FLOAT:
338
+ cif->abi = (FFI_SYSV | FFI_SYSV_SOFT_FLOAT | FFI_SYSV_IBM_LONG_DOUBLE
339
+ | FFI_SYSV_LONG_DOUBLE_128);
340
+ break;
341
+ }
342
+ }
343
+ return ffi_prep_cif_sysv_core (cif);
344
+ }
345
+
346
+ /* ffi_prep_args_SYSV is called by the assembly routine once stack space
347
+ has been allocated for the function's arguments.
348
+
349
+ The stack layout we want looks like this:
350
+
351
+ | Return address from ffi_call_SYSV 4bytes | higher addresses
352
+ |--------------------------------------------|
353
+ | Previous backchain pointer 4 | stack pointer here
354
+ |--------------------------------------------|<+ <<< on entry to
355
+ | Saved r28-r31 4*4 | | ffi_call_SYSV
356
+ |--------------------------------------------| |
357
+ | GPR registers r3-r10 8*4 | | ffi_call_SYSV
358
+ |--------------------------------------------| |
359
+ | FPR registers f1-f8 (optional) 8*8 | |
360
+ |--------------------------------------------| | stack |
361
+ | Space for copied structures | | grows |
362
+ |--------------------------------------------| | down V
363
+ | Parameters that didn't fit in registers | |
364
+ |--------------------------------------------| | lower addresses
365
+ | Space for callee's LR 4 | |
366
+ |--------------------------------------------| | stack pointer here
367
+ | Current backchain pointer 4 |-/ during
368
+ |--------------------------------------------| <<< ffi_call_SYSV
369
+
370
+ */
371
+
372
+ void FFI_HIDDEN
373
+ ffi_prep_args_SYSV (extended_cif *ecif, unsigned *const stack)
374
+ {
375
+ const unsigned bytes = ecif->cif->bytes;
376
+ const unsigned flags = ecif->cif->flags;
377
+
378
+ typedef union
379
+ {
380
+ char *c;
381
+ unsigned *u;
382
+ long long *ll;
383
+ float *f;
384
+ double *d;
385
+ } valp;
386
+
387
+ /* 'stacktop' points at the previous backchain pointer. */
388
+ valp stacktop;
389
+
390
+ /* 'gpr_base' points at the space for gpr3, and grows upwards as
391
+ we use GPR registers. */
392
+ valp gpr_base;
393
+ valp gpr_end;
394
+
395
+ #ifndef __NO_FPRS__
396
+ /* 'fpr_base' points at the space for fpr1, and grows upwards as
397
+ we use FPR registers. */
398
+ valp fpr_base;
399
+ valp fpr_end;
400
+ #endif
401
+
402
+ /* 'copy_space' grows down as we put structures in it. It should
403
+ stay 16-byte aligned. */
404
+ valp copy_space;
405
+
406
+ /* 'next_arg' grows up as we put parameters in it. */
407
+ valp next_arg;
408
+
409
+ int i;
410
+ ffi_type **ptr;
411
+ #ifndef __NO_FPRS__
412
+ double double_tmp;
413
+ #endif
414
+ union
415
+ {
416
+ void **v;
417
+ char **c;
418
+ signed char **sc;
419
+ unsigned char **uc;
420
+ signed short **ss;
421
+ unsigned short **us;
422
+ unsigned int **ui;
423
+ long long **ll;
424
+ float **f;
425
+ double **d;
426
+ } p_argv;
427
+ size_t struct_copy_size;
428
+ unsigned gprvalue;
429
+
430
+ stacktop.c = (char *) stack + bytes;
431
+ gpr_end.u = stacktop.u - ASM_NEEDS_REGISTERS;
432
+ gpr_base.u = gpr_end.u - NUM_GPR_ARG_REGISTERS;
433
+ #ifndef __NO_FPRS__
434
+ fpr_end.d = gpr_base.d;
435
+ fpr_base.d = fpr_end.d - NUM_FPR_ARG_REGISTERS;
436
+ copy_space.c = ((flags & FLAG_FP_ARGUMENTS) ? fpr_base.c : gpr_base.c);
437
+ #else
438
+ copy_space.c = gpr_base.c;
439
+ #endif
440
+ next_arg.u = stack + 2;
441
+
442
+ /* Check that everything starts aligned properly. */
443
+ FFI_ASSERT (((unsigned long) (char *) stack & 0xF) == 0);
444
+ FFI_ASSERT (((unsigned long) copy_space.c & 0xF) == 0);
445
+ FFI_ASSERT (((unsigned long) stacktop.c & 0xF) == 0);
446
+ FFI_ASSERT ((bytes & 0xF) == 0);
447
+ FFI_ASSERT (copy_space.c >= next_arg.c);
448
+
449
+ /* Deal with return values that are actually pass-by-reference. */
450
+ if (flags & FLAG_RETVAL_REFERENCE)
451
+ *gpr_base.u++ = (unsigned) (char *) ecif->rvalue;
452
+
453
+ /* Now for the arguments. */
454
+ p_argv.v = ecif->avalue;
455
+ for (ptr = ecif->cif->arg_types, i = ecif->cif->nargs;
456
+ i > 0;
457
+ i--, ptr++, p_argv.v++)
458
+ {
459
+ unsigned int typenum = (*ptr)->type;
460
+
461
+ typenum = translate_float (ecif->cif->abi, typenum);
462
+
463
+ /* Now test the translated value */
464
+ switch (typenum)
465
+ {
466
+ #ifndef __NO_FPRS__
467
+ # if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
468
+ case FFI_TYPE_LONGDOUBLE:
469
+ double_tmp = (*p_argv.d)[0];
470
+
471
+ if (fpr_base.d >= fpr_end.d - 1)
472
+ {
473
+ fpr_base.d = fpr_end.d;
474
+ if (((next_arg.u - stack) & 1) != 0)
475
+ next_arg.u += 1;
476
+ *next_arg.d = double_tmp;
477
+ next_arg.u += 2;
478
+ double_tmp = (*p_argv.d)[1];
479
+ *next_arg.d = double_tmp;
480
+ next_arg.u += 2;
481
+ }
482
+ else
483
+ {
484
+ *fpr_base.d++ = double_tmp;
485
+ double_tmp = (*p_argv.d)[1];
486
+ *fpr_base.d++ = double_tmp;
487
+ }
488
+ FFI_ASSERT (flags & FLAG_FP_ARGUMENTS);
489
+ break;
490
+ # endif
491
+ case FFI_TYPE_DOUBLE:
492
+ double_tmp = **p_argv.d;
493
+
494
+ if (fpr_base.d >= fpr_end.d)
495
+ {
496
+ if (((next_arg.u - stack) & 1) != 0)
497
+ next_arg.u += 1;
498
+ *next_arg.d = double_tmp;
499
+ next_arg.u += 2;
500
+ }
501
+ else
502
+ *fpr_base.d++ = double_tmp;
503
+ FFI_ASSERT (flags & FLAG_FP_ARGUMENTS);
504
+ break;
505
+
506
+ case FFI_TYPE_FLOAT:
507
+ double_tmp = **p_argv.f;
508
+ if (fpr_base.d >= fpr_end.d)
509
+ {
510
+ *next_arg.f = (float) double_tmp;
511
+ next_arg.u += 1;
512
+ }
513
+ else
514
+ *fpr_base.d++ = double_tmp;
515
+ FFI_ASSERT (flags & FLAG_FP_ARGUMENTS);
516
+ break;
517
+ #endif /* have FPRs */
518
+
519
+ case FFI_TYPE_UINT128:
520
+ /* The soft float ABI for long doubles works like this, a long double
521
+ is passed in four consecutive GPRs if available. A maximum of 2
522
+ long doubles can be passed in gprs. If we do not have 4 GPRs
523
+ left, the long double is passed on the stack, 4-byte aligned. */
524
+ if (gpr_base.u >= gpr_end.u - 3)
525
+ {
526
+ unsigned int ii;
527
+ gpr_base.u = gpr_end.u;
528
+ for (ii = 0; ii < 4; ii++)
529
+ {
530
+ unsigned int int_tmp = (*p_argv.ui)[ii];
531
+ *next_arg.u++ = int_tmp;
532
+ }
533
+ }
534
+ else
535
+ {
536
+ unsigned int ii;
537
+ for (ii = 0; ii < 4; ii++)
538
+ {
539
+ unsigned int int_tmp = (*p_argv.ui)[ii];
540
+ *gpr_base.u++ = int_tmp;
541
+ }
542
+ }
543
+ break;
544
+
545
+ case FFI_TYPE_UINT64:
546
+ case FFI_TYPE_SINT64:
547
+ if (gpr_base.u >= gpr_end.u - 1)
548
+ {
549
+ gpr_base.u = gpr_end.u;
550
+ if (((next_arg.u - stack) & 1) != 0)
551
+ next_arg.u++;
552
+ *next_arg.ll = **p_argv.ll;
553
+ next_arg.u += 2;
554
+ }
555
+ else
556
+ {
557
+ /* The abi states only certain register pairs can be
558
+ used for passing long long int specifically (r3,r4),
559
+ (r5,r6), (r7,r8), (r9,r10). If next arg is long long
560
+ but not correct starting register of pair then skip
561
+ until the proper starting register. */
562
+ if (((gpr_end.u - gpr_base.u) & 1) != 0)
563
+ gpr_base.u++;
564
+ *gpr_base.ll++ = **p_argv.ll;
565
+ }
566
+ break;
567
+
568
+ case FFI_TYPE_STRUCT:
569
+ struct_copy_size = ((*ptr)->size + 15) & ~0xF;
570
+ copy_space.c -= struct_copy_size;
571
+ memcpy (copy_space.c, *p_argv.c, (*ptr)->size);
572
+
573
+ gprvalue = (unsigned long) copy_space.c;
574
+
575
+ FFI_ASSERT (copy_space.c > next_arg.c);
576
+ FFI_ASSERT (flags & FLAG_ARG_NEEDS_COPY);
577
+ goto putgpr;
578
+
579
+ case FFI_TYPE_UINT8:
580
+ gprvalue = **p_argv.uc;
581
+ goto putgpr;
582
+ case FFI_TYPE_SINT8:
583
+ gprvalue = **p_argv.sc;
584
+ goto putgpr;
585
+ case FFI_TYPE_UINT16:
586
+ gprvalue = **p_argv.us;
587
+ goto putgpr;
588
+ case FFI_TYPE_SINT16:
589
+ gprvalue = **p_argv.ss;
590
+ goto putgpr;
591
+
592
+ case FFI_TYPE_INT:
593
+ case FFI_TYPE_UINT32:
594
+ case FFI_TYPE_SINT32:
595
+ case FFI_TYPE_POINTER:
596
+
597
+ gprvalue = **p_argv.ui;
598
+
599
+ putgpr:
600
+ if (gpr_base.u >= gpr_end.u)
601
+ *next_arg.u++ = gprvalue;
602
+ else
603
+ *gpr_base.u++ = gprvalue;
604
+ break;
605
+ }
606
+ }
607
+
608
+ /* Check that we didn't overrun the stack... */
609
+ FFI_ASSERT (copy_space.c >= next_arg.c);
610
+ FFI_ASSERT (gpr_base.u <= gpr_end.u);
611
+ #ifndef __NO_FPRS__
612
+ FFI_ASSERT (fpr_base.u <= fpr_end.u);
613
+ #endif
614
+ FFI_ASSERT (((flags & FLAG_4_GPR_ARGUMENTS) != 0)
615
+ == (gpr_end.u - gpr_base.u < 4));
616
+ }
617
+
618
+ #define MIN_CACHE_LINE_SIZE 8
619
+
620
+ static void
621
+ flush_icache (char *wraddr, char *xaddr, int size)
622
+ {
623
+ int i;
624
+ for (i = 0; i < size; i += MIN_CACHE_LINE_SIZE)
625
+ __asm__ volatile ("icbi 0,%0;" "dcbf 0,%1;"
626
+ : : "r" (xaddr + i), "r" (wraddr + i) : "memory");
627
+ __asm__ volatile ("icbi 0,%0;" "dcbf 0,%1;" "sync;" "isync;"
628
+ : : "r"(xaddr + size - 1), "r"(wraddr + size - 1)
629
+ : "memory");
630
+ }
631
+
632
+ ffi_status FFI_HIDDEN
633
+ ffi_prep_closure_loc_sysv (ffi_closure *closure,
634
+ ffi_cif *cif,
635
+ void (*fun) (ffi_cif *, void *, void **, void *),
636
+ void *user_data,
637
+ void *codeloc)
638
+ {
639
+ unsigned int *tramp;
640
+
641
+ if (cif->abi < FFI_SYSV || cif->abi >= FFI_LAST_ABI)
642
+ return FFI_BAD_ABI;
643
+
644
+ tramp = (unsigned int *) &closure->tramp[0];
645
+ tramp[0] = 0x7c0802a6; /* mflr r0 */
646
+ tramp[1] = 0x429f0005; /* bcl 20,31,.+4 */
647
+ tramp[2] = 0x7d6802a6; /* mflr r11 */
648
+ tramp[3] = 0x7c0803a6; /* mtlr r0 */
649
+ tramp[4] = 0x800b0018; /* lwz r0,24(r11) */
650
+ tramp[5] = 0x816b001c; /* lwz r11,28(r11) */
651
+ tramp[6] = 0x7c0903a6; /* mtctr r0 */
652
+ tramp[7] = 0x4e800420; /* bctr */
653
+ *(void **) &tramp[8] = (void *) ffi_closure_SYSV; /* function */
654
+ *(void **) &tramp[9] = codeloc; /* context */
655
+
656
+ /* Flush the icache. */
657
+ flush_icache ((char *)tramp, (char *)codeloc, 8 * 4);
658
+
659
+ closure->cif = cif;
660
+ closure->fun = fun;
661
+ closure->user_data = user_data;
662
+
663
+ return FFI_OK;
664
+ }
665
+
666
+ /* Basically the trampoline invokes ffi_closure_SYSV, and on
667
+ entry, r11 holds the address of the closure.
668
+ After storing the registers that could possibly contain
669
+ parameters to be passed into the stack frame and setting
670
+ up space for a return value, ffi_closure_SYSV invokes the
671
+ following helper function to do most of the work. */
672
+
673
+ int
674
+ ffi_closure_helper_SYSV (ffi_cif *cif,
675
+ void (*fun) (ffi_cif *, void *, void **, void *),
676
+ void *user_data,
677
+ void *rvalue,
678
+ unsigned long *pgr,
679
+ ffi_dblfl *pfr,
680
+ unsigned long *pst)
681
+ {
682
+ /* rvalue is the pointer to space for return value in closure assembly */
683
+ /* pgr is the pointer to where r3-r10 are stored in ffi_closure_SYSV */
684
+ /* pfr is the pointer to where f1-f8 are stored in ffi_closure_SYSV */
685
+ /* pst is the pointer to outgoing parameter stack in original caller */
686
+
687
+ void ** avalue;
688
+ ffi_type ** arg_types;
689
+ long i, avn;
690
+ #ifndef __NO_FPRS__
691
+ long nf = 0; /* number of floating registers already used */
692
+ #endif
693
+ long ng = 0; /* number of general registers already used */
694
+
695
+ unsigned size = cif->rtype->size;
696
+ unsigned short rtypenum = cif->rtype->type;
697
+
698
+ avalue = alloca (cif->nargs * sizeof (void *));
699
+
700
+ /* First translate for softfloat/nonlinux */
701
+ rtypenum = translate_float (cif->abi, rtypenum);
702
+
703
+ /* Copy the caller's structure return value address so that the closure
704
+ returns the data directly to the caller.
705
+ For FFI_SYSV the result is passed in r3/r4 if the struct size is less
706
+ or equal 8 bytes. */
707
+ if (rtypenum == FFI_TYPE_STRUCT
708
+ && !((cif->abi & FFI_SYSV_STRUCT_RET) != 0 && size <= 8))
709
+ {
710
+ rvalue = (void *) *pgr;
711
+ ng++;
712
+ pgr++;
713
+ }
714
+
715
+ i = 0;
716
+ avn = cif->nargs;
717
+ arg_types = cif->arg_types;
718
+
719
+ /* Grab the addresses of the arguments from the stack frame. */
720
+ while (i < avn) {
721
+ unsigned short typenum = arg_types[i]->type;
722
+
723
+ /* We may need to handle some values depending on ABI. */
724
+ typenum = translate_float (cif->abi, typenum);
725
+
726
+ switch (typenum)
727
+ {
728
+ #ifndef __NO_FPRS__
729
+ case FFI_TYPE_FLOAT:
730
+ /* Unfortunately float values are stored as doubles
731
+ in the ffi_closure_SYSV code (since we don't check
732
+ the type in that routine). */
733
+ if (nf < NUM_FPR_ARG_REGISTERS)
734
+ {
735
+ /* FIXME? here we are really changing the values
736
+ stored in the original calling routines outgoing
737
+ parameter stack. This is probably a really
738
+ naughty thing to do but... */
739
+ double temp = pfr->d;
740
+ pfr->f = (float) temp;
741
+ avalue[i] = pfr;
742
+ nf++;
743
+ pfr++;
744
+ }
745
+ else
746
+ {
747
+ avalue[i] = pst;
748
+ pst += 1;
749
+ }
750
+ break;
751
+
752
+ case FFI_TYPE_DOUBLE:
753
+ if (nf < NUM_FPR_ARG_REGISTERS)
754
+ {
755
+ avalue[i] = pfr;
756
+ nf++;
757
+ pfr++;
758
+ }
759
+ else
760
+ {
761
+ if (((long) pst) & 4)
762
+ pst++;
763
+ avalue[i] = pst;
764
+ pst += 2;
765
+ }
766
+ break;
767
+
768
+ # if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
769
+ case FFI_TYPE_LONGDOUBLE:
770
+ if (nf < NUM_FPR_ARG_REGISTERS - 1)
771
+ {
772
+ avalue[i] = pfr;
773
+ pfr += 2;
774
+ nf += 2;
775
+ }
776
+ else
777
+ {
778
+ if (((long) pst) & 4)
779
+ pst++;
780
+ avalue[i] = pst;
781
+ pst += 4;
782
+ nf = 8;
783
+ }
784
+ break;
785
+ # endif
786
+ #endif
787
+
788
+ case FFI_TYPE_UINT128:
789
+ /* Test if for the whole long double, 4 gprs are available.
790
+ otherwise the stuff ends up on the stack. */
791
+ if (ng < NUM_GPR_ARG_REGISTERS - 3)
792
+ {
793
+ avalue[i] = pgr;
794
+ pgr += 4;
795
+ ng += 4;
796
+ }
797
+ else
798
+ {
799
+ avalue[i] = pst;
800
+ pst += 4;
801
+ ng = 8+4;
802
+ }
803
+ break;
804
+
805
+ case FFI_TYPE_SINT8:
806
+ case FFI_TYPE_UINT8:
807
+ #ifndef __LITTLE_ENDIAN__
808
+ if (ng < NUM_GPR_ARG_REGISTERS)
809
+ {
810
+ avalue[i] = (char *) pgr + 3;
811
+ ng++;
812
+ pgr++;
813
+ }
814
+ else
815
+ {
816
+ avalue[i] = (char *) pst + 3;
817
+ pst++;
818
+ }
819
+ break;
820
+ #endif
821
+
822
+ case FFI_TYPE_SINT16:
823
+ case FFI_TYPE_UINT16:
824
+ #ifndef __LITTLE_ENDIAN__
825
+ if (ng < NUM_GPR_ARG_REGISTERS)
826
+ {
827
+ avalue[i] = (char *) pgr + 2;
828
+ ng++;
829
+ pgr++;
830
+ }
831
+ else
832
+ {
833
+ avalue[i] = (char *) pst + 2;
834
+ pst++;
835
+ }
836
+ break;
837
+ #endif
838
+
839
+ case FFI_TYPE_SINT32:
840
+ case FFI_TYPE_UINT32:
841
+ case FFI_TYPE_POINTER:
842
+ if (ng < NUM_GPR_ARG_REGISTERS)
843
+ {
844
+ avalue[i] = pgr;
845
+ ng++;
846
+ pgr++;
847
+ }
848
+ else
849
+ {
850
+ avalue[i] = pst;
851
+ pst++;
852
+ }
853
+ break;
854
+
855
+ case FFI_TYPE_STRUCT:
856
+ /* Structs are passed by reference. The address will appear in a
857
+ gpr if it is one of the first 8 arguments. */
858
+ if (ng < NUM_GPR_ARG_REGISTERS)
859
+ {
860
+ avalue[i] = (void *) *pgr;
861
+ ng++;
862
+ pgr++;
863
+ }
864
+ else
865
+ {
866
+ avalue[i] = (void *) *pst;
867
+ pst++;
868
+ }
869
+ break;
870
+
871
+ case FFI_TYPE_SINT64:
872
+ case FFI_TYPE_UINT64:
873
+ /* Passing long long ints are complex, they must
874
+ be passed in suitable register pairs such as
875
+ (r3,r4) or (r5,r6) or (r6,r7), or (r7,r8) or (r9,r10)
876
+ and if the entire pair aren't available then the outgoing
877
+ parameter stack is used for both but an alignment of 8
878
+ must will be kept. So we must either look in pgr
879
+ or pst to find the correct address for this type
880
+ of parameter. */
881
+ if (ng < NUM_GPR_ARG_REGISTERS - 1)
882
+ {
883
+ if (ng & 1)
884
+ {
885
+ /* skip r4, r6, r8 as starting points */
886
+ ng++;
887
+ pgr++;
888
+ }
889
+ avalue[i] = pgr;
890
+ ng += 2;
891
+ pgr += 2;
892
+ }
893
+ else
894
+ {
895
+ if (((long) pst) & 4)
896
+ pst++;
897
+ avalue[i] = pst;
898
+ pst += 2;
899
+ ng = NUM_GPR_ARG_REGISTERS;
900
+ }
901
+ break;
902
+
903
+ default:
904
+ FFI_ASSERT (0);
905
+ }
906
+
907
+ i++;
908
+ }
909
+
910
+ (*fun) (cif, rvalue, avalue, user_data);
911
+
912
+ /* Tell ffi_closure_SYSV how to perform return type promotions.
913
+ Because the FFI_SYSV ABI returns the structures <= 8 bytes in
914
+ r3/r4 we have to tell ffi_closure_SYSV how to treat them. We
915
+ combine the base type FFI_SYSV_TYPE_SMALL_STRUCT with the size of
916
+ the struct less one. We never have a struct with size zero.
917
+ See the comment in ffitarget.h about ordering. */
918
+ if (rtypenum == FFI_TYPE_STRUCT
919
+ && (cif->abi & FFI_SYSV_STRUCT_RET) != 0 && size <= 8)
920
+ return FFI_SYSV_TYPE_SMALL_STRUCT - 1 + size;
921
+ return rtypenum;
922
+ }
923
+ #endif