ffi 1.0.0 → 1.17.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (694) hide show
  1. checksums.yaml +7 -0
  2. checksums.yaml.gz.sig +4 -0
  3. data/CHANGELOG.md +465 -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 +165 -148
  10. data/ext/ffi_c/AbstractMemory.c +716 -97
  11. data/ext/ffi_c/AbstractMemory.h +38 -17
  12. data/ext/ffi_c/ArrayType.c +102 -33
  13. data/ext/ffi_c/ArrayType.h +20 -18
  14. data/ext/ffi_c/Buffer.c +229 -54
  15. data/ext/ffi_c/Call.c +211 -100
  16. data/ext/ffi_c/Call.h +46 -28
  17. data/ext/ffi_c/ClosurePool.c +110 -81
  18. data/ext/ffi_c/ClosurePool.h +31 -1
  19. data/ext/ffi_c/DynamicLibrary.c +216 -54
  20. data/ext/ffi_c/DynamicLibrary.h +76 -0
  21. data/ext/ffi_c/Function.c +527 -164
  22. data/ext/ffi_c/Function.h +24 -20
  23. data/ext/ffi_c/FunctionInfo.c +151 -50
  24. data/ext/ffi_c/LastError.c +112 -28
  25. data/ext/ffi_c/LastError.h +29 -0
  26. data/ext/ffi_c/LongDouble.c +65 -0
  27. data/ext/ffi_c/LongDouble.h +47 -0
  28. data/ext/ffi_c/MappedType.c +107 -42
  29. data/ext/ffi_c/MappedType.h +20 -20
  30. data/ext/ffi_c/MemoryPointer.c +108 -46
  31. data/ext/ffi_c/MemoryPointer.h +33 -4
  32. data/ext/ffi_c/MethodHandle.c +71 -67
  33. data/ext/ffi_c/MethodHandle.h +26 -23
  34. data/ext/ffi_c/Platform.c +42 -25
  35. data/ext/ffi_c/Platform.h +32 -3
  36. data/ext/ffi_c/Pointer.c +324 -51
  37. data/ext/ffi_c/Pointer.h +29 -18
  38. data/ext/ffi_c/Struct.c +434 -161
  39. data/ext/ffi_c/Struct.h +47 -27
  40. data/ext/ffi_c/StructByValue.c +74 -37
  41. data/ext/ffi_c/StructByValue.h +20 -18
  42. data/ext/ffi_c/StructLayout.c +358 -87
  43. data/ext/ffi_c/Thread.c +129 -0
  44. data/ext/ffi_c/Thread.h +76 -0
  45. data/ext/ffi_c/Type.c +241 -76
  46. data/ext/ffi_c/Type.h +27 -11
  47. data/ext/ffi_c/Types.c +54 -34
  48. data/ext/ffi_c/Types.h +24 -24
  49. data/ext/ffi_c/Variadic.c +151 -55
  50. data/ext/ffi_c/compat.h +48 -38
  51. data/ext/ffi_c/extconf.rb +106 -34
  52. data/ext/ffi_c/ffi.c +35 -26
  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} +6528 -3180
  78. data/ext/ffi_c/libffi/LICENSE +3 -3
  79. data/ext/ffi_c/libffi/LICENSE-BUILDTOOLS +353 -0
  80. data/ext/ffi_c/libffi/Makefile.am +132 -162
  81. data/ext/ffi_c/libffi/Makefile.in +1339 -1003
  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 +227 -21
  86. data/ext/ffi_c/libffi/config.guess +1034 -778
  87. data/ext/ffi_c/libffi/config.sub +1394 -1204
  88. data/ext/ffi_c/libffi/configure +14327 -8503
  89. data/ext/ffi_c/libffi/configure.ac +294 -247
  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 +572 -67
  94. data/ext/ffi_c/libffi/doc/version.texi +4 -4
  95. data/ext/ffi_c/libffi/fficonfig.h.in +53 -46
  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 +219 -79
  99. data/ext/ffi_c/libffi/include/ffi.h.in +230 -111
  100. data/ext/ffi_c/libffi/include/ffi_cfi.h +76 -0
  101. data/ext/ffi_c/libffi/include/ffi_common.h +78 -16
  102. data/ext/ffi_c/libffi/include/tramp.h +45 -0
  103. data/ext/ffi_c/libffi/install-sh +402 -184
  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 +5752 -2722
  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 +198 -0
  113. data/ext/ffi_c/libffi/m4/ax_cflags_warn_all.m4 +158 -0
  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 +119 -0
  116. data/ext/ffi_c/libffi/m4/ax_configure_args.m4 +49 -0
  117. data/ext/ffi_c/libffi/m4/ax_enable_builddir.m4 +302 -0
  118. data/ext/ffi_c/libffi/m4/ax_gcc_archflag.m4 +267 -0
  119. data/ext/ffi_c/libffi/m4/ax_gcc_x86_cpuid.m4 +89 -0
  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 +174 -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 +155 -300
  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/msvc_build/aarch64/aarch64_include/ffi.h +511 -0
  134. data/ext/ffi_c/libffi/msvc_build/aarch64/aarch64_include/fficonfig.h +219 -0
  135. data/ext/ffi_c/libffi/msvcc.sh +353 -0
  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 +162 -246
  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 +806 -194
  149. data/ext/ffi_c/libffi/src/arm/ffitarget.h +43 -3
  150. data/ext/ffi_c/libffi/src/arm/internal.h +17 -0
  151. data/ext/ffi_c/libffi/src/arm/sysv.S +381 -231
  152. data/ext/ffi_c/libffi/src/arm/sysv_msvc_arm32.S +311 -0
  153. data/ext/ffi_c/libffi/src/avr32/ffi.c +4 -2
  154. data/ext/ffi_c/libffi/src/avr32/ffitarget.h +8 -3
  155. data/ext/ffi_c/libffi/src/bfin/ffi.c +196 -0
  156. data/ext/ffi_c/libffi/src/bfin/ffitarget.h +43 -0
  157. data/ext/ffi_c/libffi/src/bfin/sysv.S +179 -0
  158. data/ext/ffi_c/libffi/src/closures.c +574 -100
  159. data/ext/ffi_c/libffi/src/cris/ffi.c +11 -8
  160. data/ext/ffi_c/libffi/src/cris/ffitarget.h +8 -3
  161. data/ext/ffi_c/libffi/src/csky/ffi.c +395 -0
  162. data/ext/ffi_c/libffi/src/csky/ffitarget.h +63 -0
  163. data/ext/ffi_c/libffi/src/csky/sysv.S +371 -0
  164. data/ext/ffi_c/libffi/src/debug.c +8 -3
  165. data/ext/ffi_c/libffi/src/dlmalloc.c +89 -17
  166. data/ext/ffi_c/libffi/src/frv/ffi.c +2 -2
  167. data/ext/ffi_c/libffi/src/frv/ffitarget.h +8 -7
  168. data/ext/ffi_c/libffi/src/ia64/ffi.c +48 -12
  169. data/ext/ffi_c/libffi/src/ia64/ffitarget.h +10 -4
  170. data/ext/ffi_c/libffi/src/ia64/unix.S +28 -3
  171. data/ext/ffi_c/libffi/src/java_raw_api.c +24 -6
  172. data/ext/ffi_c/libffi/src/kvx/asm.h +5 -0
  173. data/ext/ffi_c/libffi/src/kvx/ffi.c +273 -0
  174. data/ext/ffi_c/libffi/src/kvx/ffitarget.h +75 -0
  175. data/ext/ffi_c/libffi/src/kvx/sysv.S +127 -0
  176. data/ext/ffi_c/libffi/src/loongarch64/ffi.c +624 -0
  177. data/ext/ffi_c/libffi/src/loongarch64/ffitarget.h +82 -0
  178. data/ext/ffi_c/libffi/src/loongarch64/sysv.S +327 -0
  179. data/ext/ffi_c/libffi/src/m32r/ffi.c +32 -15
  180. data/ext/ffi_c/libffi/src/m32r/ffitarget.h +8 -3
  181. data/ext/ffi_c/libffi/src/m68k/ffi.c +97 -13
  182. data/ext/ffi_c/libffi/src/m68k/ffitarget.h +8 -3
  183. data/ext/ffi_c/libffi/src/m68k/sysv.S +148 -25
  184. data/ext/ffi_c/libffi/src/m88k/ffi.c +400 -0
  185. data/ext/ffi_c/libffi/src/m88k/ffitarget.h +49 -0
  186. data/ext/ffi_c/libffi/src/m88k/obsd.S +209 -0
  187. data/ext/ffi_c/libffi/src/metag/ffi.c +330 -0
  188. data/ext/ffi_c/libffi/src/metag/ffitarget.h +53 -0
  189. data/ext/ffi_c/libffi/src/metag/sysv.S +311 -0
  190. data/ext/ffi_c/libffi/src/microblaze/ffi.c +321 -0
  191. data/ext/ffi_c/libffi/src/microblaze/ffitarget.h +53 -0
  192. data/ext/ffi_c/libffi/src/microblaze/sysv.S +302 -0
  193. data/ext/ffi_c/libffi/src/mips/ffi.c +392 -104
  194. data/ext/ffi_c/libffi/src/mips/ffitarget.h +40 -24
  195. data/ext/ffi_c/libffi/src/mips/n32.S +325 -93
  196. data/ext/ffi_c/libffi/src/mips/o32.S +211 -31
  197. data/ext/ffi_c/libffi/src/moxie/eabi.S +101 -0
  198. data/ext/ffi_c/libffi/src/moxie/ffi.c +310 -0
  199. data/ext/ffi_c/libffi/src/moxie/ffitarget.h +52 -0
  200. data/ext/ffi_c/libffi/src/nios2/ffi.c +304 -0
  201. data/ext/ffi_c/libffi/src/nios2/ffitarget.h +52 -0
  202. data/ext/ffi_c/libffi/src/nios2/sysv.S +136 -0
  203. data/ext/ffi_c/libffi/src/or1k/ffi.c +341 -0
  204. data/ext/ffi_c/libffi/src/or1k/ffitarget.h +58 -0
  205. data/ext/ffi_c/libffi/src/or1k/sysv.S +107 -0
  206. data/ext/ffi_c/libffi/src/pa/ffi.c +68 -111
  207. data/ext/ffi_c/libffi/src/pa/ffi64.c +614 -0
  208. data/ext/ffi_c/libffi/src/pa/ffitarget.h +34 -17
  209. data/ext/ffi_c/libffi/src/pa/hpux32.S +87 -38
  210. data/ext/ffi_c/libffi/src/pa/hpux64.S +681 -0
  211. data/ext/ffi_c/libffi/src/pa/linux.S +109 -39
  212. data/ext/ffi_c/libffi/src/powerpc/aix.S +250 -8
  213. data/ext/ffi_c/libffi/src/powerpc/aix_closure.S +255 -4
  214. data/ext/ffi_c/libffi/src/powerpc/asm.h +3 -3
  215. data/ext/ffi_c/libffi/src/powerpc/darwin.S +211 -78
  216. data/ext/ffi_c/libffi/src/powerpc/darwin_closure.S +356 -102
  217. data/ext/ffi_c/libffi/src/powerpc/ffi.c +108 -1375
  218. data/ext/ffi_c/libffi/src/powerpc/ffi_darwin.c +746 -210
  219. data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +1153 -0
  220. data/ext/ffi_c/libffi/src/powerpc/ffi_powerpc.h +105 -0
  221. data/ext/ffi_c/libffi/src/powerpc/ffi_sysv.c +923 -0
  222. data/ext/ffi_c/libffi/src/powerpc/ffitarget.h +126 -48
  223. data/ext/ffi_c/libffi/src/powerpc/linux64.S +191 -85
  224. data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +438 -108
  225. data/ext/ffi_c/libffi/src/powerpc/ppc_closure.S +138 -68
  226. data/ext/ffi_c/libffi/src/powerpc/sysv.S +73 -119
  227. data/ext/ffi_c/libffi/src/powerpc/t-aix +5 -0
  228. data/ext/ffi_c/libffi/src/prep_cif.c +141 -32
  229. data/ext/ffi_c/libffi/src/raw_api.c +18 -5
  230. data/ext/ffi_c/libffi/src/riscv/ffi.c +514 -0
  231. data/ext/ffi_c/libffi/src/riscv/ffitarget.h +69 -0
  232. data/ext/ffi_c/libffi/src/riscv/sysv.S +293 -0
  233. data/ext/ffi_c/libffi/src/s390/ffi.c +294 -318
  234. data/ext/ffi_c/libffi/src/s390/ffitarget.h +13 -3
  235. data/ext/ffi_c/libffi/src/s390/internal.h +11 -0
  236. data/ext/ffi_c/libffi/src/s390/sysv.S +257 -366
  237. data/ext/ffi_c/libffi/src/sh/ffi.c +4 -3
  238. data/ext/ffi_c/libffi/src/sh/ffitarget.h +8 -3
  239. data/ext/ffi_c/libffi/src/sh64/ffi.c +3 -2
  240. data/ext/ffi_c/libffi/src/sh64/ffitarget.h +8 -3
  241. data/ext/ffi_c/libffi/src/sparc/ffi.c +334 -491
  242. data/ext/ffi_c/libffi/src/sparc/ffi64.c +630 -0
  243. data/ext/ffi_c/libffi/src/sparc/ffitarget.h +20 -5
  244. data/ext/ffi_c/libffi/src/sparc/internal.h +26 -0
  245. data/ext/ffi_c/libffi/src/sparc/v8.S +364 -234
  246. data/ext/ffi_c/libffi/src/sparc/v9.S +340 -207
  247. data/ext/ffi_c/libffi/src/tile/ffi.c +355 -0
  248. data/ext/ffi_c/libffi/src/tile/ffitarget.h +65 -0
  249. data/ext/ffi_c/libffi/src/tile/tile.S +360 -0
  250. data/ext/ffi_c/libffi/src/tramp.c +716 -0
  251. data/ext/ffi_c/libffi/src/types.c +48 -19
  252. data/ext/ffi_c/libffi/src/vax/elfbsd.S +195 -0
  253. data/ext/ffi_c/libffi/src/vax/ffi.c +276 -0
  254. data/ext/ffi_c/libffi/src/vax/ffitarget.h +49 -0
  255. data/ext/ffi_c/libffi/src/wasm32/ffi.c +947 -0
  256. data/ext/ffi_c/libffi/src/wasm32/ffitarget.h +62 -0
  257. data/ext/ffi_c/libffi/src/x86/asmnames.h +30 -0
  258. data/ext/ffi_c/libffi/src/x86/ffi.c +690 -540
  259. data/ext/ffi_c/libffi/src/x86/ffi64.c +450 -126
  260. data/ext/ffi_c/libffi/src/x86/ffitarget.h +86 -42
  261. data/ext/ffi_c/libffi/src/x86/ffiw64.c +361 -0
  262. data/ext/ffi_c/libffi/src/x86/internal.h +43 -0
  263. data/ext/ffi_c/libffi/src/x86/internal64.h +36 -0
  264. data/ext/ffi_c/libffi/src/x86/sysv.S +1199 -381
  265. data/ext/ffi_c/libffi/src/x86/sysv_intel.S +998 -0
  266. data/ext/ffi_c/libffi/src/x86/unix64.S +587 -298
  267. data/ext/ffi_c/libffi/src/x86/win64.S +251 -457
  268. data/ext/ffi_c/libffi/src/x86/win64_intel.S +238 -0
  269. data/ext/ffi_c/libffi/src/xtensa/ffi.c +306 -0
  270. data/ext/ffi_c/libffi/src/xtensa/ffitarget.h +57 -0
  271. data/ext/ffi_c/libffi/src/xtensa/sysv.S +268 -0
  272. data/ext/ffi_c/libffi/stamp-h.in +1 -0
  273. data/ext/ffi_c/libffi/testsuite/Makefile.am +80 -73
  274. data/ext/ffi_c/libffi/testsuite/Makefile.in +251 -117
  275. data/ext/ffi_c/libffi/testsuite/emscripten/build-tests.sh +54 -0
  276. data/ext/ffi_c/libffi/testsuite/emscripten/build.sh +63 -0
  277. data/ext/ffi_c/libffi/testsuite/emscripten/conftest.py +86 -0
  278. data/ext/ffi_c/libffi/testsuite/emscripten/node-tests.sh +48 -0
  279. data/ext/ffi_c/libffi/testsuite/emscripten/test.html +7 -0
  280. data/ext/ffi_c/libffi/testsuite/emscripten/test_libffi.py +51 -0
  281. data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +682 -0
  282. data/ext/ffi_c/libffi/testsuite/lib/target-libpath.exp +22 -2
  283. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/Makefile +28 -0
  284. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/README +78 -0
  285. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/alignof.h +50 -0
  286. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/bhaible.exp +63 -0
  287. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-call.c +1746 -0
  288. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-callback.c +2885 -0
  289. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/testcases.c +747 -0
  290. data/ext/ffi_c/libffi/testsuite/libffi.call/align_mixed.c +46 -0
  291. data/ext/ffi_c/libffi/testsuite/libffi.call/align_stdcall.c +46 -0
  292. data/ext/ffi_c/libffi/testsuite/libffi.call/bpo_38748.c +41 -0
  293. data/ext/ffi_c/libffi/testsuite/libffi.call/call.exp +28 -10
  294. data/ext/ffi_c/libffi/testsuite/libffi.call/callback.c +99 -0
  295. data/ext/ffi_c/libffi/testsuite/libffi.call/callback2.c +108 -0
  296. data/ext/ffi_c/libffi/testsuite/libffi.call/callback3.c +114 -0
  297. data/ext/ffi_c/libffi/testsuite/libffi.call/callback4.c +119 -0
  298. data/ext/ffi_c/libffi/testsuite/libffi.call/err_bad_typedef.c +4 -3
  299. data/ext/ffi_c/libffi/testsuite/libffi.call/ffitest.h +88 -42
  300. data/ext/ffi_c/libffi/testsuite/libffi.call/float1.c +3 -1
  301. data/ext/ffi_c/libffi/testsuite/libffi.call/float2.c +15 -12
  302. data/ext/ffi_c/libffi/testsuite/libffi.call/float3.c +4 -2
  303. data/ext/ffi_c/libffi/testsuite/libffi.call/float_va.c +110 -0
  304. data/ext/ffi_c/libffi/testsuite/libffi.call/many.c +6 -16
  305. data/ext/ffi_c/libffi/testsuite/libffi.call/many2.c +57 -0
  306. data/ext/ffi_c/libffi/testsuite/libffi.call/many_double.c +70 -0
  307. data/ext/ffi_c/libffi/testsuite/libffi.call/many_mixed.c +78 -0
  308. data/ext/ffi_c/libffi/testsuite/libffi.call/negint.c +0 -1
  309. data/ext/ffi_c/libffi/testsuite/libffi.call/offsets.c +46 -0
  310. data/ext/ffi_c/libffi/testsuite/libffi.call/pr1172638.c +127 -0
  311. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl.c +1 -0
  312. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ldl.c +1 -1
  313. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll1.c +6 -0
  314. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sc.c +1 -1
  315. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sl.c +4 -0
  316. data/ext/ffi_c/libffi/testsuite/libffi.call/return_uc.c +1 -1
  317. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ul.c +4 -0
  318. data/ext/ffi_c/libffi/testsuite/libffi.call/s55.c +60 -0
  319. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen.c +9 -10
  320. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen2.c +49 -0
  321. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen3.c +49 -0
  322. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen4.c +55 -0
  323. data/ext/ffi_c/libffi/testsuite/libffi.call/struct1.c +9 -7
  324. data/ext/ffi_c/libffi/testsuite/libffi.call/struct10.c +57 -0
  325. data/ext/ffi_c/libffi/testsuite/libffi.call/struct2.c +7 -7
  326. data/ext/ffi_c/libffi/testsuite/libffi.call/struct3.c +7 -6
  327. data/ext/ffi_c/libffi/testsuite/libffi.call/struct4.c +9 -8
  328. data/ext/ffi_c/libffi/testsuite/libffi.call/struct5.c +9 -8
  329. data/ext/ffi_c/libffi/testsuite/libffi.call/struct6.c +9 -9
  330. data/ext/ffi_c/libffi/testsuite/libffi.call/struct7.c +9 -9
  331. data/ext/ffi_c/libffi/testsuite/libffi.call/struct8.c +9 -8
  332. data/ext/ffi_c/libffi/testsuite/libffi.call/struct9.c +9 -8
  333. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_2.c +63 -0
  334. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_3.c +65 -0
  335. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_3f.c +65 -0
  336. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_4.c +67 -0
  337. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_4f.c +67 -0
  338. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_big.c +93 -0
  339. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_by_value_small.c +61 -0
  340. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_return_2H.c +63 -0
  341. data/ext/ffi_c/libffi/testsuite/libffi.call/struct_return_8H.c +90 -0
  342. data/ext/ffi_c/libffi/testsuite/libffi.call/uninitialized.c +61 -0
  343. data/ext/ffi_c/libffi/testsuite/libffi.call/va_1.c +78 -0
  344. data/ext/ffi_c/libffi/testsuite/libffi.call/va_2.c +220 -0
  345. data/ext/ffi_c/libffi/testsuite/libffi.call/va_3.c +154 -0
  346. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct1.c +134 -0
  347. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct2.c +134 -0
  348. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct3.c +140 -0
  349. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure.exp +67 -0
  350. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn0.c +3 -2
  351. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn1.c +2 -0
  352. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn2.c +2 -0
  353. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn3.c +21 -1
  354. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn4.c +2 -0
  355. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn5.c +2 -0
  356. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn6.c +2 -0
  357. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_loc_fn0.c +7 -6
  358. data/ext/ffi_c/libffi/testsuite/{libffi.call/closure_stdcall.c → libffi.closures/closure_simple.c} +13 -16
  359. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_12byte.c +22 -4
  360. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_16byte.c +26 -4
  361. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_18byte.c +28 -4
  362. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_19byte.c +33 -4
  363. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_1_1byte.c +8 -4
  364. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte.c +23 -5
  365. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte1.c +25 -5
  366. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_24byte.c +40 -8
  367. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_2byte.c +17 -4
  368. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3_1byte.c +23 -4
  369. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte1.c +17 -4
  370. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte2.c +17 -4
  371. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3float.c +113 -0
  372. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4_1byte.c +26 -4
  373. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4byte.c +17 -4
  374. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5_1_byte.c +33 -5
  375. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5byte.c +23 -5
  376. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_64byte.c +29 -5
  377. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6_1_byte.c +32 -5
  378. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6byte.c +28 -6
  379. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7_1_byte.c +43 -5
  380. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7byte.c +29 -5
  381. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_8byte.c +18 -4
  382. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte1.c +18 -5
  383. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte2.c +18 -6
  384. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_double.c +23 -5
  385. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_float.c +23 -5
  386. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble.c +24 -5
  387. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split.c +44 -31
  388. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split2.c +44 -9
  389. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_pointer.c +23 -5
  390. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint16.c +22 -5
  391. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint32.c +22 -7
  392. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint64.c +23 -5
  393. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint16.c +22 -5
  394. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint32.c +23 -5
  395. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint64.c +24 -5
  396. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_dbls_struct.c +7 -5
  397. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double_va.c +21 -9
  398. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_float.c +4 -0
  399. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble.c +13 -3
  400. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble_va.c +34 -11
  401. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_many_mixed_args.c +70 -0
  402. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_many_mixed_float_double.c +55 -0
  403. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_schar.c +5 -1
  404. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshort.c +6 -1
  405. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshortchar.c +9 -1
  406. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_uchar.c +9 -1
  407. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushort.c +6 -2
  408. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushortchar.c +9 -1
  409. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer.c +7 -2
  410. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer_stack.c +22 -10
  411. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_schar.c +3 -0
  412. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sint.c +2 -0
  413. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sshort.c +3 -0
  414. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_struct_va1.c +125 -0
  415. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uchar.c +3 -0
  416. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uint.c +4 -0
  417. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uint_va.c +49 -0
  418. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ulong_va.c +49 -0
  419. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ulonglong.c +8 -5
  420. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ushort.c +3 -0
  421. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/err_bad_abi.c +2 -3
  422. data/ext/ffi_c/libffi/testsuite/libffi.closures/ffitest.h +1 -0
  423. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/huge_struct.c +57 -56
  424. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct.c +38 -15
  425. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct1.c +9 -9
  426. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct10.c +19 -6
  427. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct11.c +137 -0
  428. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct12.c +86 -0
  429. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct13.c +115 -0
  430. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct2.c +15 -6
  431. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct3.c +15 -6
  432. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct4.c +14 -5
  433. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct5.c +14 -5
  434. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct6.c +17 -6
  435. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct7.c +14 -5
  436. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct8.c +17 -6
  437. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct9.c +17 -6
  438. data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs1.c +86 -0
  439. data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs2.c +102 -0
  440. data/ext/ffi_c/libffi/testsuite/libffi.closures/single_entry_structs3.c +101 -0
  441. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large.c +7 -7
  442. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large2.c +7 -7
  443. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium.c +6 -6
  444. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium2.c +7 -6
  445. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/testclosure.c +8 -3
  446. data/ext/ffi_c/libffi/testsuite/{libffi.special → libffi.closures}/unwindtest.cc +4 -10
  447. data/ext/ffi_c/libffi/testsuite/{libffi.special → libffi.closures}/unwindtest_ffi_call.cc +4 -2
  448. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex.inc +91 -0
  449. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_double.c +10 -0
  450. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_float.c +10 -0
  451. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_longdouble.c +10 -0
  452. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex.inc +42 -0
  453. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_double.c +10 -0
  454. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_float.c +10 -0
  455. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_longdouble.c +10 -0
  456. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct.inc +71 -0
  457. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_double.c +10 -0
  458. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_float.c +10 -0
  459. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_longdouble.c +10 -0
  460. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va.inc +80 -0
  461. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_double.c +10 -0
  462. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_float.c +16 -0
  463. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_longdouble.c +10 -0
  464. data/ext/ffi_c/libffi/testsuite/{libffi.special/special.exp → libffi.complex/complex.exp} +9 -10
  465. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex.inc +51 -0
  466. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_double.inc +7 -0
  467. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_float.inc +7 -0
  468. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_longdouble.inc +7 -0
  469. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_double.c +10 -0
  470. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_float.c +10 -0
  471. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_int.c +86 -0
  472. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_longdouble.c +10 -0
  473. data/ext/ffi_c/libffi/testsuite/libffi.complex/ffitest.h +1 -0
  474. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex.inc +78 -0
  475. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_double.c +10 -0
  476. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_float.c +10 -0
  477. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_longdouble.c +10 -0
  478. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex.inc +37 -0
  479. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1.inc +41 -0
  480. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_double.c +10 -0
  481. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_float.c +10 -0
  482. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_longdouble.c +10 -0
  483. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2.inc +44 -0
  484. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_double.c +10 -0
  485. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_float.c +10 -0
  486. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_longdouble.c +10 -0
  487. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_double.c +10 -0
  488. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_float.c +10 -0
  489. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_longdouble.c +10 -0
  490. data/ext/ffi_c/libffi/testsuite/libffi.go/aa-direct.c +34 -0
  491. data/ext/ffi_c/libffi/testsuite/libffi.go/closure1.c +28 -0
  492. data/ext/ffi_c/libffi/testsuite/libffi.go/ffitest.h +1 -0
  493. data/ext/ffi_c/libffi/testsuite/libffi.go/go.exp +36 -0
  494. data/ext/ffi_c/libffi/testsuite/libffi.go/static-chain.h +19 -0
  495. data/ext/ffi_c/libffi.bsd.mk +14 -8
  496. data/ext/ffi_c/libffi.darwin.mk +56 -26
  497. data/ext/ffi_c/libffi.gnu.mk +9 -6
  498. data/ext/ffi_c/libffi.mk +13 -8
  499. data/ext/ffi_c/libffi.vc.mk +26 -0
  500. data/ext/ffi_c/libffi.vc64.mk +26 -0
  501. data/ext/ffi_c/rbffi.h +34 -6
  502. data/ext/ffi_c/{endian.h → rbffi_endian.h} +21 -2
  503. data/ffi.gemspec +42 -0
  504. data/lib/ffi/abstract_memory.rb +44 -0
  505. data/lib/ffi/autopointer.rb +111 -52
  506. data/lib/ffi/compat.rb +43 -0
  507. data/lib/ffi/data_converter.rb +67 -0
  508. data/lib/ffi/dynamic_library.rb +118 -0
  509. data/lib/ffi/enum.rb +203 -22
  510. data/lib/ffi/errno.rb +27 -12
  511. data/lib/ffi/ffi.rb +88 -11
  512. data/lib/ffi/function.rb +71 -0
  513. data/lib/ffi/io.rb +35 -14
  514. data/lib/ffi/library.rb +382 -96
  515. data/lib/ffi/library_path.rb +109 -0
  516. data/lib/ffi/managedstruct.rb +64 -35
  517. data/lib/ffi/memorypointer.rb +1 -33
  518. data/lib/ffi/platform/aarch64-darwin/types.conf +130 -0
  519. data/lib/ffi/platform/aarch64-freebsd/types.conf +128 -0
  520. data/lib/ffi/platform/aarch64-freebsd12/types.conf +181 -0
  521. data/lib/ffi/platform/aarch64-linux/types.conf +175 -0
  522. data/lib/ffi/platform/aarch64-openbsd/types.conf +134 -0
  523. data/lib/ffi/platform/aarch64-windows/types.conf +52 -0
  524. data/lib/ffi/platform/arm-freebsd/types.conf +152 -0
  525. data/lib/ffi/platform/arm-freebsd12/types.conf +152 -0
  526. data/lib/ffi/platform/arm-linux/types.conf +132 -0
  527. data/lib/ffi/platform/hppa1.1-linux/types.conf +178 -0
  528. data/lib/ffi/platform/hppa2.0-linux/types.conf +178 -0
  529. data/lib/ffi/platform/i386-cygwin/types.conf +3 -0
  530. data/lib/ffi/platform/i386-darwin/types.conf +100 -0
  531. data/lib/ffi/platform/i386-freebsd/types.conf +152 -0
  532. data/lib/ffi/platform/i386-freebsd12/types.conf +152 -0
  533. data/lib/ffi/platform/i386-gnu/types.conf +107 -0
  534. data/lib/ffi/platform/i386-linux/types.conf +103 -0
  535. data/lib/ffi/platform/i386-netbsd/types.conf +126 -0
  536. data/lib/ffi/platform/i386-openbsd/types.conf +128 -0
  537. data/lib/ffi/platform/i386-solaris/types.conf +122 -0
  538. data/lib/ffi/platform/i386-windows/types.conf +52 -0
  539. data/lib/ffi/platform/ia64-linux/types.conf +104 -0
  540. data/lib/ffi/platform/loongarch64-linux/types.conf +141 -0
  541. data/lib/ffi/platform/mips-linux/types.conf +102 -0
  542. data/lib/ffi/platform/mips64-linux/types.conf +104 -0
  543. data/lib/ffi/platform/mips64el-linux/types.conf +104 -0
  544. data/lib/ffi/platform/mipsel-linux/types.conf +102 -0
  545. data/lib/ffi/platform/mipsisa32r6-linux/types.conf +102 -0
  546. data/lib/ffi/platform/mipsisa32r6el-linux/types.conf +102 -0
  547. data/lib/ffi/platform/mipsisa64r6-linux/types.conf +104 -0
  548. data/lib/ffi/platform/mipsisa64r6el-linux/types.conf +104 -0
  549. data/lib/ffi/platform/powerpc-aix/types.conf +180 -0
  550. data/lib/ffi/platform/powerpc-darwin/types.conf +100 -0
  551. data/lib/ffi/platform/powerpc-linux/types.conf +130 -0
  552. data/lib/ffi/platform/powerpc-openbsd/types.conf +156 -0
  553. data/lib/ffi/platform/powerpc64-linux/types.conf +104 -0
  554. data/lib/ffi/platform/powerpc64le-linux/types.conf +100 -0
  555. data/lib/ffi/platform/riscv64-linux/types.conf +104 -0
  556. data/lib/ffi/platform/s390-linux/types.conf +102 -0
  557. data/lib/ffi/platform/s390x-linux/types.conf +102 -0
  558. data/lib/ffi/platform/sparc-linux/types.conf +102 -0
  559. data/lib/ffi/platform/sparc-solaris/types.conf +128 -0
  560. data/lib/ffi/platform/sparcv9-linux/types.conf +102 -0
  561. data/lib/ffi/platform/sparcv9-openbsd/types.conf +156 -0
  562. data/lib/ffi/platform/sparcv9-solaris/types.conf +128 -0
  563. data/lib/ffi/platform/sw_64-linux/types.conf +141 -0
  564. data/lib/ffi/platform/x86_64-cygwin/types.conf +3 -0
  565. data/lib/ffi/platform/x86_64-darwin/types.conf +130 -0
  566. data/lib/ffi/platform/x86_64-dragonflybsd/types.conf +130 -0
  567. data/lib/ffi/platform/x86_64-freebsd/types.conf +128 -0
  568. data/lib/ffi/platform/x86_64-freebsd12/types.conf +158 -0
  569. data/lib/ffi/platform/x86_64-haiku/types.conf +117 -0
  570. data/lib/ffi/platform/x86_64-linux/types.conf +132 -0
  571. data/lib/ffi/platform/x86_64-msys/types.conf +119 -0
  572. data/lib/ffi/platform/x86_64-netbsd/types.conf +128 -0
  573. data/lib/ffi/platform/x86_64-openbsd/types.conf +134 -0
  574. data/lib/ffi/platform/x86_64-solaris/types.conf +122 -0
  575. data/lib/ffi/platform/x86_64-windows/types.conf +52 -0
  576. data/lib/ffi/platform.rb +110 -34
  577. data/lib/ffi/pointer.rb +117 -90
  578. data/lib/ffi/struct.rb +101 -70
  579. data/lib/ffi/struct_by_reference.rb +72 -0
  580. data/lib/ffi/struct_layout.rb +96 -0
  581. data/lib/ffi/struct_layout_builder.rb +90 -21
  582. data/lib/ffi/tools/const_generator.rb +86 -31
  583. data/lib/ffi/tools/generator.rb +49 -2
  584. data/lib/ffi/tools/generator_task.rb +13 -16
  585. data/lib/ffi/tools/struct_generator.rb +6 -5
  586. data/lib/ffi/tools/types_generator.rb +25 -11
  587. data/lib/ffi/types.rb +105 -36
  588. data/lib/ffi/union.rb +23 -12
  589. data/lib/ffi/variadic.rb +44 -29
  590. data/lib/ffi/version.rb +3 -0
  591. data/lib/ffi.rb +25 -9
  592. data/rakelib/ffi_gem_helper.rb +65 -0
  593. data/samples/getlogin.rb +8 -0
  594. data/samples/getpid.rb +8 -0
  595. data/samples/gettimeofday.rb +18 -0
  596. data/samples/hello.rb +8 -0
  597. data/samples/hello_ractor.rb +11 -0
  598. data/samples/inotify.rb +60 -0
  599. data/samples/pty.rb +75 -0
  600. data/samples/qsort.rb +20 -0
  601. data/samples/qsort_ractor.rb +28 -0
  602. data/sig/ffi/abstract_memory.rbs +165 -0
  603. data/sig/ffi/auto_pointer.rbs +26 -0
  604. data/sig/ffi/buffer.rbs +18 -0
  605. data/sig/ffi/data_converter.rbs +10 -0
  606. data/sig/ffi/dynamic_library.rbs +9 -0
  607. data/sig/ffi/enum.rbs +38 -0
  608. data/sig/ffi/function.rbs +39 -0
  609. data/sig/ffi/library.rbs +42 -0
  610. data/sig/ffi/native_type.rbs +86 -0
  611. data/sig/ffi/pointer.rbs +42 -0
  612. data/sig/ffi/struct.rbs +76 -0
  613. data/sig/ffi/struct_by_reference.rbs +11 -0
  614. data/sig/ffi/struct_by_value.rbs +7 -0
  615. data/sig/ffi/struct_layout.rbs +9 -0
  616. data/sig/ffi/struct_layout_builder.rbs +5 -0
  617. data/sig/ffi/type.rbs +39 -0
  618. data/sig/ffi.rbs +26 -0
  619. data.tar.gz.sig +0 -0
  620. metadata +547 -248
  621. metadata.gz.sig +0 -0
  622. data/History.txt +0 -109
  623. data/README.rdoc +0 -70
  624. data/ext/ffi_c/DataConverter.c +0 -62
  625. data/ext/ffi_c/StructByReference.c +0 -150
  626. data/ext/ffi_c/StructByReference.h +0 -50
  627. data/ext/ffi_c/libffi/ChangeLog.libffi +0 -658
  628. data/ext/ffi_c/libffi/ChangeLog.libgcj +0 -40
  629. data/ext/ffi_c/libffi/ChangeLog.v1 +0 -764
  630. data/ext/ffi_c/libffi/README +0 -306
  631. data/ext/ffi_c/libffi/aclocal.m4 +0 -8998
  632. data/ext/ffi_c/libffi/depcomp +0 -584
  633. data/ext/ffi_c/libffi/doc/libffi.info +0 -533
  634. data/ext/ffi_c/libffi/doc/stamp-vti +0 -4
  635. data/ext/ffi_c/libffi/m4/libtool.m4 +0 -7360
  636. data/ext/ffi_c/libffi/m4/ltoptions.m4 +0 -368
  637. data/ext/ffi_c/libffi/m4/ltsugar.m4 +0 -123
  638. data/ext/ffi_c/libffi/m4/ltversion.m4 +0 -23
  639. data/ext/ffi_c/libffi/m4/lt~obsolete.m4 +0 -92
  640. data/ext/ffi_c/libffi/mdate-sh +0 -201
  641. data/ext/ffi_c/libffi/src/x86/darwin.S +0 -444
  642. data/ext/ffi_c/libffi/src/x86/darwin64.S +0 -416
  643. data/ext/ffi_c/libffi/src/x86/freebsd.S +0 -458
  644. data/ext/ffi_c/libffi/src/x86/win32.S +0 -877
  645. data/ext/ffi_c/libffi/testsuite/lib/libffi-dg.exp +0 -300
  646. data/ext/ffi_c/libffi/testsuite/libffi.call/many_win32.c +0 -63
  647. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen_win32.c +0 -44
  648. data/ext/ffi_c/libffi/testsuite/libffi.special/ffitestcxx.h +0 -96
  649. data/ext/ffi_c/libffi/texinfo.tex +0 -7210
  650. data/gen/Rakefile +0 -14
  651. data/spec/ffi/async_callback_spec.rb +0 -23
  652. data/spec/ffi/bool_spec.rb +0 -24
  653. data/spec/ffi/buffer_spec.rb +0 -202
  654. data/spec/ffi/callback_spec.rb +0 -653
  655. data/spec/ffi/custom_param_type.rb +0 -31
  656. data/spec/ffi/custom_type_spec.rb +0 -73
  657. data/spec/ffi/enum_spec.rb +0 -183
  658. data/spec/ffi/errno_spec.rb +0 -13
  659. data/spec/ffi/ffi_spec.rb +0 -24
  660. data/spec/ffi/function_spec.rb +0 -73
  661. data/spec/ffi/library_spec.rb +0 -174
  662. data/spec/ffi/managed_struct_spec.rb +0 -56
  663. data/spec/ffi/number_spec.rb +0 -231
  664. data/spec/ffi/pointer_spec.rb +0 -210
  665. data/spec/ffi/rbx/attach_function_spec.rb +0 -28
  666. data/spec/ffi/rbx/memory_pointer_spec.rb +0 -109
  667. data/spec/ffi/rbx/spec_helper.rb +0 -1
  668. data/spec/ffi/rbx/struct_spec.rb +0 -13
  669. data/spec/ffi/spec_helper.rb +0 -21
  670. data/spec/ffi/string_spec.rb +0 -103
  671. data/spec/ffi/strptr_spec.rb +0 -36
  672. data/spec/ffi/struct_callback_spec.rb +0 -64
  673. data/spec/ffi/struct_initialize_spec.rb +0 -30
  674. data/spec/ffi/struct_packed_spec.rb +0 -46
  675. data/spec/ffi/struct_spec.rb +0 -638
  676. data/spec/ffi/typedef_spec.rb +0 -62
  677. data/spec/ffi/union_spec.rb +0 -60
  678. data/spec/ffi/variadic_spec.rb +0 -84
  679. data/spec/spec.opts +0 -4
  680. data/tasks/ann.rake +0 -80
  681. data/tasks/extension.rake +0 -25
  682. data/tasks/gem.rake +0 -200
  683. data/tasks/git.rake +0 -41
  684. data/tasks/notes.rake +0 -27
  685. data/tasks/post_load.rake +0 -34
  686. data/tasks/rdoc.rake +0 -50
  687. data/tasks/rubyforge.rake +0 -55
  688. data/tasks/setup.rb +0 -301
  689. data/tasks/spec.rake +0 -54
  690. data/tasks/svn.rake +0 -47
  691. data/tasks/test.rake +0 -40
  692. /data/ext/ffi_c/libffi/testsuite/libffi.call/{pyobjc-tc.c → pyobjc_tc.c} +0 -0
  693. /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double.c +0 -0
  694. /data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/problem1.c +0 -0
@@ -0,0 +1,1153 @@
1
+ /* -----------------------------------------------------------------------
2
+ ffi_linux64.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
+ #ifdef POWERPC64
34
+ #include "ffi_common.h"
35
+ #include "ffi_powerpc.h"
36
+
37
+
38
+ /* About the LINUX64 ABI. */
39
+ enum {
40
+ NUM_GPR_ARG_REGISTERS64 = 8,
41
+ NUM_FPR_ARG_REGISTERS64 = 13,
42
+ NUM_VEC_ARG_REGISTERS64 = 12,
43
+ };
44
+ enum { ASM_NEEDS_REGISTERS64 = 4 };
45
+
46
+
47
+ #if HAVE_LONG_DOUBLE_VARIANT && FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
48
+ /* Adjust size of ffi_type_longdouble. */
49
+ void FFI_HIDDEN
50
+ ffi_prep_types_linux64 (ffi_abi abi)
51
+ {
52
+ if ((abi & (FFI_LINUX | FFI_LINUX_LONG_DOUBLE_128)) == FFI_LINUX)
53
+ {
54
+ ffi_type_longdouble.size = 8;
55
+ ffi_type_longdouble.alignment = 8;
56
+ }
57
+ else
58
+ {
59
+ ffi_type_longdouble.size = 16;
60
+ ffi_type_longdouble.alignment = 16;
61
+ }
62
+ }
63
+ #endif
64
+
65
+
66
+ static unsigned int
67
+ discover_homogeneous_aggregate (ffi_abi abi,
68
+ const ffi_type *t,
69
+ unsigned int *elnum)
70
+ {
71
+ switch (t->type)
72
+ {
73
+ #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
74
+ case FFI_TYPE_LONGDOUBLE:
75
+ /* 64-bit long doubles are equivalent to doubles. */
76
+ if ((abi & FFI_LINUX_LONG_DOUBLE_128) == 0)
77
+ {
78
+ *elnum = 1;
79
+ return FFI_TYPE_DOUBLE;
80
+ }
81
+ /* IBM extended precision values use unaligned pairs
82
+ of FPRs, but according to the ABI must be considered
83
+ distinct from doubles. They are also limited to a
84
+ maximum of four members in a homogeneous aggregate. */
85
+ else if ((abi & FFI_LINUX_LONG_DOUBLE_IEEE128) == 0)
86
+ {
87
+ *elnum = 2;
88
+ return FFI_TYPE_LONGDOUBLE;
89
+ }
90
+ /* Fall through. */
91
+ #endif
92
+ case FFI_TYPE_FLOAT:
93
+ case FFI_TYPE_DOUBLE:
94
+ *elnum = 1;
95
+ return (int) t->type;
96
+
97
+ case FFI_TYPE_STRUCT:;
98
+ {
99
+ unsigned int base_elt = 0, total_elnum = 0;
100
+ ffi_type **el = t->elements;
101
+ while (*el)
102
+ {
103
+ unsigned int el_elt, el_elnum = 0;
104
+ el_elt = discover_homogeneous_aggregate (abi, *el, &el_elnum);
105
+ if (el_elt == 0
106
+ || (base_elt && base_elt != el_elt))
107
+ return 0;
108
+ base_elt = el_elt;
109
+ total_elnum += el_elnum;
110
+ #if _CALL_ELF == 2
111
+ if (total_elnum > 8)
112
+ return 0;
113
+ #else
114
+ if (total_elnum > 1)
115
+ return 0;
116
+ #endif
117
+ el++;
118
+ }
119
+ *elnum = total_elnum;
120
+ return base_elt;
121
+ }
122
+
123
+ default:
124
+ return 0;
125
+ }
126
+ }
127
+
128
+
129
+ /* Perform machine dependent cif processing */
130
+ static ffi_status
131
+ ffi_prep_cif_linux64_core (ffi_cif *cif)
132
+ {
133
+ ffi_type **ptr;
134
+ unsigned bytes;
135
+ unsigned i, fparg_count = 0, intarg_count = 0, vecarg_count = 0;
136
+ unsigned flags = cif->flags;
137
+ unsigned elt, elnum, rtype;
138
+
139
+ #if FFI_TYPE_LONGDOUBLE == FFI_TYPE_DOUBLE
140
+ /* If compiled without long double support... */
141
+ if ((cif->abi & FFI_LINUX_LONG_DOUBLE_128) != 0 ||
142
+ (cif->abi & FFI_LINUX_LONG_DOUBLE_IEEE128) != 0)
143
+ return FFI_BAD_ABI;
144
+ #elif !defined(__VEC__)
145
+ /* If compiled without vector register support (used by assembly)... */
146
+ if ((cif->abi & FFI_LINUX_LONG_DOUBLE_IEEE128) != 0)
147
+ return FFI_BAD_ABI;
148
+ #else
149
+ /* If the IEEE128 flag is set, but long double is only 64 bits wide... */
150
+ if ((cif->abi & FFI_LINUX_LONG_DOUBLE_128) == 0 &&
151
+ (cif->abi & FFI_LINUX_LONG_DOUBLE_IEEE128) != 0)
152
+ return FFI_BAD_ABI;
153
+ #endif
154
+
155
+ /* The machine-independent calculation of cif->bytes doesn't work
156
+ for us. Redo the calculation. */
157
+ #if _CALL_ELF == 2
158
+ /* Space for backchain, CR, LR, TOC and the asm's temp regs. */
159
+ bytes = (4 + ASM_NEEDS_REGISTERS64) * sizeof (long);
160
+
161
+ /* Space for the general registers. */
162
+ bytes += NUM_GPR_ARG_REGISTERS64 * sizeof (long);
163
+ #else
164
+ /* Space for backchain, CR, LR, cc/ld doubleword, TOC and the asm's temp
165
+ regs. */
166
+ bytes = (6 + ASM_NEEDS_REGISTERS64) * sizeof (long);
167
+
168
+ /* Space for the mandatory parm save area and general registers. */
169
+ bytes += 2 * NUM_GPR_ARG_REGISTERS64 * sizeof (long);
170
+ #endif
171
+
172
+ /* Return value handling. */
173
+ rtype = cif->rtype->type;
174
+ #if _CALL_ELF == 2
175
+ homogeneous:
176
+ #endif
177
+ switch (rtype)
178
+ {
179
+ #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
180
+ case FFI_TYPE_LONGDOUBLE:
181
+ if ((cif->abi & FFI_LINUX_LONG_DOUBLE_IEEE128) != 0)
182
+ {
183
+ flags |= FLAG_RETURNS_VEC;
184
+ break;
185
+ }
186
+ if ((cif->abi & FFI_LINUX_LONG_DOUBLE_128) != 0)
187
+ flags |= FLAG_RETURNS_128BITS;
188
+ /* Fall through. */
189
+ #endif
190
+ case FFI_TYPE_DOUBLE:
191
+ flags |= FLAG_RETURNS_64BITS;
192
+ /* Fall through. */
193
+ case FFI_TYPE_FLOAT:
194
+ flags |= FLAG_RETURNS_FP;
195
+ break;
196
+
197
+ case FFI_TYPE_UINT128:
198
+ flags |= FLAG_RETURNS_128BITS;
199
+ /* Fall through. */
200
+ case FFI_TYPE_UINT64:
201
+ case FFI_TYPE_SINT64:
202
+ case FFI_TYPE_POINTER:
203
+ flags |= FLAG_RETURNS_64BITS;
204
+ break;
205
+
206
+ case FFI_TYPE_STRUCT:
207
+ #if _CALL_ELF == 2
208
+ elt = discover_homogeneous_aggregate (cif->abi, cif->rtype, &elnum);
209
+ if (elt)
210
+ {
211
+ flags |= FLAG_RETURNS_SMST;
212
+ rtype = elt;
213
+ goto homogeneous;
214
+ }
215
+ if (cif->rtype->size <= 16)
216
+ {
217
+ flags |= FLAG_RETURNS_SMST;
218
+ break;
219
+ }
220
+ #endif
221
+ intarg_count++;
222
+ flags |= FLAG_RETVAL_REFERENCE;
223
+ /* Fall through. */
224
+ case FFI_TYPE_VOID:
225
+ flags |= FLAG_RETURNS_NOTHING;
226
+ break;
227
+
228
+ default:
229
+ /* Returns 32-bit integer, or similar. Nothing to do here. */
230
+ break;
231
+ }
232
+
233
+ for (ptr = cif->arg_types, i = cif->nargs; i > 0; i--, ptr++)
234
+ {
235
+ unsigned int align;
236
+
237
+ switch ((*ptr)->type)
238
+ {
239
+ #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
240
+ case FFI_TYPE_LONGDOUBLE:
241
+ if ((cif->abi & FFI_LINUX_LONG_DOUBLE_IEEE128) != 0)
242
+ {
243
+ vecarg_count++;
244
+ /* Align to 16 bytes, plus the 16-byte argument. */
245
+ intarg_count = (intarg_count + 3) & ~0x1;
246
+ if (vecarg_count > NUM_VEC_ARG_REGISTERS64)
247
+ flags |= FLAG_ARG_NEEDS_PSAVE;
248
+ break;
249
+ }
250
+ if ((cif->abi & FFI_LINUX_LONG_DOUBLE_128) != 0)
251
+ {
252
+ fparg_count++;
253
+ intarg_count++;
254
+ }
255
+ /* Fall through. */
256
+ #endif
257
+ case FFI_TYPE_DOUBLE:
258
+ case FFI_TYPE_FLOAT:
259
+ fparg_count++;
260
+ intarg_count++;
261
+ if (fparg_count > NUM_FPR_ARG_REGISTERS64)
262
+ flags |= FLAG_ARG_NEEDS_PSAVE;
263
+ break;
264
+
265
+ case FFI_TYPE_STRUCT:
266
+ if ((cif->abi & FFI_LINUX_STRUCT_ALIGN) != 0)
267
+ {
268
+ align = (*ptr)->alignment;
269
+ if (align > 16)
270
+ align = 16;
271
+ align = align / 8;
272
+ if (align > 1)
273
+ intarg_count = FFI_ALIGN (intarg_count, align);
274
+ }
275
+ intarg_count += ((*ptr)->size + 7) / 8;
276
+ elt = discover_homogeneous_aggregate (cif->abi, *ptr, &elnum);
277
+ #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
278
+ if (elt == FFI_TYPE_LONGDOUBLE &&
279
+ (cif->abi & FFI_LINUX_LONG_DOUBLE_IEEE128) != 0)
280
+ {
281
+ vecarg_count += elnum;
282
+ if (vecarg_count > NUM_VEC_ARG_REGISTERS64)
283
+ flags |= FLAG_ARG_NEEDS_PSAVE;
284
+ break;
285
+ }
286
+ else
287
+ #endif
288
+ if (elt)
289
+ {
290
+ fparg_count += elnum;
291
+ if (fparg_count > NUM_FPR_ARG_REGISTERS64)
292
+ flags |= FLAG_ARG_NEEDS_PSAVE;
293
+ }
294
+ else
295
+ {
296
+ if (intarg_count > NUM_GPR_ARG_REGISTERS64)
297
+ flags |= FLAG_ARG_NEEDS_PSAVE;
298
+ }
299
+ break;
300
+
301
+ case FFI_TYPE_POINTER:
302
+ case FFI_TYPE_UINT64:
303
+ case FFI_TYPE_SINT64:
304
+ case FFI_TYPE_INT:
305
+ case FFI_TYPE_UINT32:
306
+ case FFI_TYPE_SINT32:
307
+ case FFI_TYPE_UINT16:
308
+ case FFI_TYPE_SINT16:
309
+ case FFI_TYPE_UINT8:
310
+ case FFI_TYPE_SINT8:
311
+ /* Everything else is passed as a 8-byte word in a GPR, either
312
+ the object itself or a pointer to it. */
313
+ intarg_count++;
314
+ if (intarg_count > NUM_GPR_ARG_REGISTERS64)
315
+ flags |= FLAG_ARG_NEEDS_PSAVE;
316
+ break;
317
+ default:
318
+ FFI_ASSERT (0);
319
+ }
320
+ }
321
+
322
+ if (fparg_count != 0)
323
+ flags |= FLAG_FP_ARGUMENTS;
324
+ if (intarg_count > 4)
325
+ flags |= FLAG_4_GPR_ARGUMENTS;
326
+ if (vecarg_count != 0)
327
+ flags |= FLAG_VEC_ARGUMENTS;
328
+
329
+ /* Space for the FPR registers, if needed. */
330
+ if (fparg_count != 0)
331
+ bytes += NUM_FPR_ARG_REGISTERS64 * sizeof (double);
332
+ /* Space for the vector registers, if needed, aligned to 16 bytes. */
333
+ if (vecarg_count != 0) {
334
+ bytes = (bytes + 15) & ~0xF;
335
+ bytes += NUM_VEC_ARG_REGISTERS64 * sizeof (float128);
336
+ }
337
+
338
+ /* Stack space. */
339
+ #if _CALL_ELF == 2
340
+ if ((flags & FLAG_ARG_NEEDS_PSAVE) != 0)
341
+ bytes += intarg_count * sizeof (long);
342
+ #else
343
+ if (intarg_count > NUM_GPR_ARG_REGISTERS64)
344
+ bytes += (intarg_count - NUM_GPR_ARG_REGISTERS64) * sizeof (long);
345
+ #endif
346
+
347
+ /* The stack space allocated needs to be a multiple of 16 bytes. */
348
+ bytes = (bytes + 15) & ~0xF;
349
+
350
+ cif->flags = flags;
351
+ cif->bytes = bytes;
352
+
353
+ return FFI_OK;
354
+ }
355
+
356
+ ffi_status FFI_HIDDEN
357
+ ffi_prep_cif_linux64 (ffi_cif *cif)
358
+ {
359
+ if ((cif->abi & FFI_LINUX) != 0)
360
+ cif->nfixedargs = cif->nargs;
361
+ #if _CALL_ELF != 2
362
+ else if (cif->abi == FFI_COMPAT_LINUX64)
363
+ {
364
+ /* This call is from old code. Don't touch cif->nfixedargs
365
+ since old code will be using a smaller cif. */
366
+ cif->flags |= FLAG_COMPAT;
367
+ /* Translate to new abi value. */
368
+ cif->abi = FFI_LINUX | FFI_LINUX_LONG_DOUBLE_128;
369
+ }
370
+ #endif
371
+ else
372
+ return FFI_BAD_ABI;
373
+ return ffi_prep_cif_linux64_core (cif);
374
+ }
375
+
376
+ ffi_status FFI_HIDDEN
377
+ ffi_prep_cif_linux64_var (ffi_cif *cif,
378
+ unsigned int nfixedargs,
379
+ unsigned int ntotalargs MAYBE_UNUSED)
380
+ {
381
+ if ((cif->abi & FFI_LINUX) != 0)
382
+ cif->nfixedargs = nfixedargs;
383
+ #if _CALL_ELF != 2
384
+ else if (cif->abi == FFI_COMPAT_LINUX64)
385
+ {
386
+ /* This call is from old code. Don't touch cif->nfixedargs
387
+ since old code will be using a smaller cif. */
388
+ cif->flags |= FLAG_COMPAT;
389
+ /* Translate to new abi value. */
390
+ cif->abi = FFI_LINUX | FFI_LINUX_LONG_DOUBLE_128;
391
+ }
392
+ #endif
393
+ else
394
+ return FFI_BAD_ABI;
395
+ #if _CALL_ELF == 2
396
+ cif->flags |= FLAG_ARG_NEEDS_PSAVE;
397
+ #endif
398
+ return ffi_prep_cif_linux64_core (cif);
399
+ }
400
+
401
+
402
+ /* ffi_prep_args64 is called by the assembly routine once stack space
403
+ has been allocated for the function's arguments.
404
+
405
+ The stack layout we want looks like this:
406
+
407
+ | Ret addr from ffi_call_LINUX64 8bytes | higher addresses
408
+ |--------------------------------------------|
409
+ | CR save area 8bytes |
410
+ |--------------------------------------------|
411
+ | Previous backchain pointer 8 | stack pointer here
412
+ |--------------------------------------------|<+ <<< on entry to
413
+ | Saved r28-r31 4*8 | | ffi_call_LINUX64
414
+ |--------------------------------------------| |
415
+ | GPR registers r3-r10 8*8 | |
416
+ |--------------------------------------------| |
417
+ | FPR registers f1-f13 (optional) 13*8 | |
418
+ |--------------------------------------------| |
419
+ | VEC registers v2-v13 (optional) 12*16 | |
420
+ |--------------------------------------------| |
421
+ | Parameter save area | |
422
+ |--------------------------------------------| |
423
+ | TOC save area 8 | |
424
+ |--------------------------------------------| | stack |
425
+ | Linker doubleword 8 | | grows |
426
+ |--------------------------------------------| | down V
427
+ | Compiler doubleword 8 | |
428
+ |--------------------------------------------| | lower addresses
429
+ | Space for callee's LR 8 | |
430
+ |--------------------------------------------| |
431
+ | CR save area 8 | |
432
+ |--------------------------------------------| | stack pointer here
433
+ | Current backchain pointer 8 |-/ during
434
+ |--------------------------------------------| <<< ffi_call_LINUX64
435
+
436
+ */
437
+
438
+ void FFI_HIDDEN
439
+ ffi_prep_args64 (extended_cif *ecif, unsigned long *const stack)
440
+ {
441
+ const unsigned long bytes = ecif->cif->bytes;
442
+ const unsigned long flags = ecif->cif->flags;
443
+
444
+ typedef union
445
+ {
446
+ char *c;
447
+ unsigned long *ul;
448
+ float *f;
449
+ double *d;
450
+ float128 *f128;
451
+ size_t p;
452
+ } valp;
453
+
454
+ /* 'stacktop' points at the previous backchain pointer. */
455
+ valp stacktop;
456
+
457
+ /* 'next_arg' points at the space for gpr3, and grows upwards as
458
+ we use GPR registers, then continues at rest. */
459
+ valp gpr_base;
460
+ valp gpr_end;
461
+ valp rest;
462
+ valp next_arg;
463
+
464
+ /* 'fpr_base' points at the space for f1, and grows upwards as
465
+ we use FPR registers. */
466
+ valp fpr_base;
467
+ unsigned int fparg_count;
468
+
469
+ /* 'vec_base' points at the space for v2, and grows upwards as
470
+ we use vector registers. */
471
+ valp vec_base;
472
+ unsigned int vecarg_count;
473
+
474
+ unsigned int i, words, nargs, nfixedargs;
475
+ ffi_type **ptr;
476
+ double double_tmp;
477
+ union
478
+ {
479
+ void **v;
480
+ char **c;
481
+ signed char **sc;
482
+ unsigned char **uc;
483
+ signed short **ss;
484
+ unsigned short **us;
485
+ signed int **si;
486
+ unsigned int **ui;
487
+ unsigned long **ul;
488
+ float **f;
489
+ double **d;
490
+ float128 **f128;
491
+ } p_argv;
492
+ unsigned long gprvalue;
493
+ unsigned long align;
494
+
495
+ stacktop.c = (char *) stack + bytes;
496
+ gpr_base.ul = stacktop.ul - ASM_NEEDS_REGISTERS64 - NUM_GPR_ARG_REGISTERS64;
497
+ gpr_end.ul = gpr_base.ul + NUM_GPR_ARG_REGISTERS64;
498
+ #if _CALL_ELF == 2
499
+ rest.ul = stack + 4 + NUM_GPR_ARG_REGISTERS64;
500
+ #else
501
+ rest.ul = stack + 6 + NUM_GPR_ARG_REGISTERS64;
502
+ #endif
503
+ fpr_base.d = gpr_base.d - NUM_FPR_ARG_REGISTERS64;
504
+ fparg_count = 0;
505
+ /* Place the vector args below the FPRs, if used, else the GPRs. */
506
+ if (ecif->cif->flags & FLAG_FP_ARGUMENTS)
507
+ vec_base.p = fpr_base.p & ~0xF;
508
+ else
509
+ vec_base.p = gpr_base.p;
510
+ vec_base.f128 -= NUM_VEC_ARG_REGISTERS64;
511
+ vecarg_count = 0;
512
+ next_arg.ul = gpr_base.ul;
513
+
514
+ /* Check that everything starts aligned properly. */
515
+ FFI_ASSERT (((unsigned long) (char *) stack & 0xF) == 0);
516
+ FFI_ASSERT (((unsigned long) stacktop.c & 0xF) == 0);
517
+ FFI_ASSERT (((unsigned long) gpr_base.c & 0xF) == 0);
518
+ FFI_ASSERT (((unsigned long) gpr_end.c & 0xF) == 0);
519
+ FFI_ASSERT (((unsigned long) vec_base.c & 0xF) == 0);
520
+ FFI_ASSERT ((bytes & 0xF) == 0);
521
+
522
+ /* Deal with return values that are actually pass-by-reference. */
523
+ if (flags & FLAG_RETVAL_REFERENCE)
524
+ *next_arg.ul++ = (unsigned long) (char *) ecif->rvalue;
525
+
526
+ /* Now for the arguments. */
527
+ p_argv.v = ecif->avalue;
528
+ nargs = ecif->cif->nargs;
529
+ #if _CALL_ELF != 2
530
+ nfixedargs = (unsigned) -1;
531
+ if ((flags & FLAG_COMPAT) == 0)
532
+ #endif
533
+ nfixedargs = ecif->cif->nfixedargs;
534
+ for (ptr = ecif->cif->arg_types, i = 0;
535
+ i < nargs;
536
+ i++, ptr++, p_argv.v++)
537
+ {
538
+ unsigned int elt, elnum;
539
+
540
+ switch ((*ptr)->type)
541
+ {
542
+ #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
543
+ case FFI_TYPE_LONGDOUBLE:
544
+ if ((ecif->cif->abi & FFI_LINUX_LONG_DOUBLE_IEEE128) != 0)
545
+ {
546
+ next_arg.p = FFI_ALIGN (next_arg.p, 16);
547
+ if (next_arg.ul == gpr_end.ul)
548
+ next_arg.ul = rest.ul;
549
+ if (vecarg_count < NUM_VEC_ARG_REGISTERS64 && i < nfixedargs)
550
+ memcpy (vec_base.f128++, *p_argv.f128, sizeof (float128));
551
+ else
552
+ memcpy (next_arg.f128, *p_argv.f128, sizeof (float128));
553
+ if (++next_arg.f128 == gpr_end.f128)
554
+ next_arg.f128 = rest.f128;
555
+ vecarg_count++;
556
+ FFI_ASSERT (__LDBL_MANT_DIG__ == 113);
557
+ FFI_ASSERT (flags & FLAG_VEC_ARGUMENTS);
558
+ break;
559
+ }
560
+ if ((ecif->cif->abi & FFI_LINUX_LONG_DOUBLE_128) != 0)
561
+ {
562
+ double_tmp = (*p_argv.d)[0];
563
+ if (fparg_count < NUM_FPR_ARG_REGISTERS64 && i < nfixedargs)
564
+ {
565
+ *fpr_base.d++ = double_tmp;
566
+ # if _CALL_ELF != 2
567
+ if ((flags & FLAG_COMPAT) != 0)
568
+ *next_arg.d = double_tmp;
569
+ # endif
570
+ }
571
+ else
572
+ *next_arg.d = double_tmp;
573
+ if (++next_arg.ul == gpr_end.ul)
574
+ next_arg.ul = rest.ul;
575
+ fparg_count++;
576
+ double_tmp = (*p_argv.d)[1];
577
+ if (fparg_count < NUM_FPR_ARG_REGISTERS64 && i < nfixedargs)
578
+ {
579
+ *fpr_base.d++ = double_tmp;
580
+ # if _CALL_ELF != 2
581
+ if ((flags & FLAG_COMPAT) != 0)
582
+ *next_arg.d = double_tmp;
583
+ # endif
584
+ }
585
+ else
586
+ *next_arg.d = double_tmp;
587
+ if (++next_arg.ul == gpr_end.ul)
588
+ next_arg.ul = rest.ul;
589
+ fparg_count++;
590
+ FFI_ASSERT (__LDBL_MANT_DIG__ == 106);
591
+ FFI_ASSERT (flags & FLAG_FP_ARGUMENTS);
592
+ break;
593
+ }
594
+ /* Fall through. */
595
+ #endif
596
+ case FFI_TYPE_DOUBLE:
597
+ #if _CALL_ELF != 2
598
+ do_double:
599
+ #endif
600
+ double_tmp = **p_argv.d;
601
+ if (fparg_count < NUM_FPR_ARG_REGISTERS64 && i < nfixedargs)
602
+ {
603
+ *fpr_base.d++ = double_tmp;
604
+ #if _CALL_ELF != 2
605
+ if ((flags & FLAG_COMPAT) != 0)
606
+ *next_arg.d = double_tmp;
607
+ #endif
608
+ }
609
+ else
610
+ *next_arg.d = double_tmp;
611
+ if (++next_arg.ul == gpr_end.ul)
612
+ next_arg.ul = rest.ul;
613
+ fparg_count++;
614
+ FFI_ASSERT (flags & FLAG_FP_ARGUMENTS);
615
+ break;
616
+
617
+ case FFI_TYPE_FLOAT:
618
+ #if _CALL_ELF != 2
619
+ do_float:
620
+ #endif
621
+ double_tmp = **p_argv.f;
622
+ if (fparg_count < NUM_FPR_ARG_REGISTERS64 && i < nfixedargs)
623
+ {
624
+ *fpr_base.d++ = double_tmp;
625
+ #if _CALL_ELF != 2
626
+ if ((flags & FLAG_COMPAT) != 0)
627
+ {
628
+ # ifndef __LITTLE_ENDIAN__
629
+ next_arg.f[1] = (float) double_tmp;
630
+ # else
631
+ next_arg.f[0] = (float) double_tmp;
632
+ # endif
633
+ }
634
+ #endif
635
+ }
636
+ else
637
+ {
638
+ # ifndef __LITTLE_ENDIAN__
639
+ next_arg.f[1] = (float) double_tmp;
640
+ # else
641
+ next_arg.f[0] = (float) double_tmp;
642
+ # endif
643
+ }
644
+ if (++next_arg.ul == gpr_end.ul)
645
+ next_arg.ul = rest.ul;
646
+ fparg_count++;
647
+ FFI_ASSERT (flags & FLAG_FP_ARGUMENTS);
648
+ break;
649
+
650
+ case FFI_TYPE_STRUCT:
651
+ if ((ecif->cif->abi & FFI_LINUX_STRUCT_ALIGN) != 0)
652
+ {
653
+ align = (*ptr)->alignment;
654
+ if (align > 16)
655
+ align = 16;
656
+ if (align > 1)
657
+ {
658
+ next_arg.p = FFI_ALIGN (next_arg.p, align);
659
+ if (next_arg.ul == gpr_end.ul)
660
+ next_arg.ul = rest.ul;
661
+ }
662
+ }
663
+ elt = discover_homogeneous_aggregate (ecif->cif->abi, *ptr, &elnum);
664
+ if (elt)
665
+ {
666
+ #if _CALL_ELF == 2
667
+ union {
668
+ void *v;
669
+ float *f;
670
+ double *d;
671
+ float128 *f128;
672
+ } arg;
673
+
674
+ arg.v = *p_argv.v;
675
+ #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
676
+ if (elt == FFI_TYPE_LONGDOUBLE &&
677
+ (ecif->cif->abi & FFI_LINUX_LONG_DOUBLE_IEEE128) != 0)
678
+ {
679
+ do
680
+ {
681
+ if (vecarg_count < NUM_VEC_ARG_REGISTERS64
682
+ && i < nfixedargs)
683
+ memcpy (vec_base.f128++, arg.f128++, sizeof (float128));
684
+ else
685
+ memcpy (next_arg.f128, arg.f128++, sizeof (float128));
686
+ if (++next_arg.f128 == gpr_end.f128)
687
+ next_arg.f128 = rest.f128;
688
+ vecarg_count++;
689
+ }
690
+ while (--elnum != 0);
691
+ }
692
+ else
693
+ #endif
694
+ if (elt == FFI_TYPE_FLOAT)
695
+ {
696
+ do
697
+ {
698
+ double_tmp = *arg.f++;
699
+ if (fparg_count < NUM_FPR_ARG_REGISTERS64
700
+ && i < nfixedargs)
701
+ *fpr_base.d++ = double_tmp;
702
+ else
703
+ *next_arg.f = (float) double_tmp;
704
+ if (++next_arg.f == gpr_end.f)
705
+ next_arg.f = rest.f;
706
+ fparg_count++;
707
+ }
708
+ while (--elnum != 0);
709
+ if ((next_arg.p & 7) != 0)
710
+ if (++next_arg.f == gpr_end.f)
711
+ next_arg.f = rest.f;
712
+ }
713
+ else
714
+ do
715
+ {
716
+ double_tmp = *arg.d++;
717
+ if (fparg_count < NUM_FPR_ARG_REGISTERS64 && i < nfixedargs)
718
+ *fpr_base.d++ = double_tmp;
719
+ else
720
+ *next_arg.d = double_tmp;
721
+ if (++next_arg.d == gpr_end.d)
722
+ next_arg.d = rest.d;
723
+ fparg_count++;
724
+ }
725
+ while (--elnum != 0);
726
+ #else
727
+ if (elt == FFI_TYPE_FLOAT)
728
+ goto do_float;
729
+ else
730
+ goto do_double;
731
+ #endif
732
+ }
733
+ else
734
+ {
735
+ words = ((*ptr)->size + 7) / 8;
736
+ if (next_arg.ul >= gpr_base.ul && next_arg.ul + words > gpr_end.ul)
737
+ {
738
+ size_t first = gpr_end.c - next_arg.c;
739
+ memcpy (next_arg.c, *p_argv.c, first);
740
+ memcpy (rest.c, *p_argv.c + first, (*ptr)->size - first);
741
+ next_arg.c = rest.c + words * 8 - first;
742
+ }
743
+ else
744
+ {
745
+ char *where = next_arg.c;
746
+
747
+ #ifndef __LITTLE_ENDIAN__
748
+ /* Structures with size less than eight bytes are passed
749
+ left-padded. */
750
+ if ((*ptr)->size < 8)
751
+ where += 8 - (*ptr)->size;
752
+ #endif
753
+ memcpy (where, *p_argv.c, (*ptr)->size);
754
+ next_arg.ul += words;
755
+ if (next_arg.ul == gpr_end.ul)
756
+ next_arg.ul = rest.ul;
757
+ }
758
+ }
759
+ break;
760
+
761
+ case FFI_TYPE_UINT8:
762
+ gprvalue = **p_argv.uc;
763
+ goto putgpr;
764
+ case FFI_TYPE_SINT8:
765
+ gprvalue = **p_argv.sc;
766
+ goto putgpr;
767
+ case FFI_TYPE_UINT16:
768
+ gprvalue = **p_argv.us;
769
+ goto putgpr;
770
+ case FFI_TYPE_SINT16:
771
+ gprvalue = **p_argv.ss;
772
+ goto putgpr;
773
+ case FFI_TYPE_UINT32:
774
+ gprvalue = **p_argv.ui;
775
+ goto putgpr;
776
+ case FFI_TYPE_INT:
777
+ case FFI_TYPE_SINT32:
778
+ gprvalue = **p_argv.si;
779
+ goto putgpr;
780
+
781
+ case FFI_TYPE_UINT64:
782
+ case FFI_TYPE_SINT64:
783
+ case FFI_TYPE_POINTER:
784
+ gprvalue = **p_argv.ul;
785
+ putgpr:
786
+ *next_arg.ul++ = gprvalue;
787
+ if (next_arg.ul == gpr_end.ul)
788
+ next_arg.ul = rest.ul;
789
+ break;
790
+ }
791
+ }
792
+
793
+ FFI_ASSERT (flags & FLAG_4_GPR_ARGUMENTS
794
+ || (next_arg.ul >= gpr_base.ul
795
+ && next_arg.ul <= gpr_base.ul + 4));
796
+ }
797
+
798
+
799
+ #if _CALL_ELF == 2
800
+ #define MIN_CACHE_LINE_SIZE 8
801
+
802
+ static void
803
+ flush_icache (char *wraddr, char *xaddr, int size)
804
+ {
805
+ int i;
806
+ for (i = 0; i < size; i += MIN_CACHE_LINE_SIZE)
807
+ __asm__ volatile ("icbi 0,%0;" "dcbf 0,%1;"
808
+ : : "r" (xaddr + i), "r" (wraddr + i) : "memory");
809
+ __asm__ volatile ("icbi 0,%0;" "dcbf 0,%1;" "sync;" "isync;"
810
+ : : "r"(xaddr + size - 1), "r"(wraddr + size - 1)
811
+ : "memory");
812
+ }
813
+ #endif
814
+
815
+
816
+ ffi_status FFI_HIDDEN
817
+ ffi_prep_closure_loc_linux64 (ffi_closure *closure,
818
+ ffi_cif *cif,
819
+ void (*fun) (ffi_cif *, void *, void **, void *),
820
+ void *user_data,
821
+ void *codeloc)
822
+ {
823
+ #if _CALL_ELF == 2
824
+ unsigned int *tramp = (unsigned int *) &closure->tramp[0];
825
+
826
+ if (cif->abi < FFI_LINUX || cif->abi >= FFI_LAST_ABI)
827
+ return FFI_BAD_ABI;
828
+
829
+ tramp[0] = 0xe96c0018; /* 0: ld 11,2f-0b(12) */
830
+ tramp[1] = 0xe98c0010; /* ld 12,1f-0b(12) */
831
+ tramp[2] = 0x7d8903a6; /* mtctr 12 */
832
+ tramp[3] = 0x4e800420; /* bctr */
833
+ /* 1: .quad function_addr */
834
+ /* 2: .quad context */
835
+ *(void **) &tramp[4] = (void *) ffi_closure_LINUX64;
836
+ *(void **) &tramp[6] = codeloc;
837
+ flush_icache ((char *) tramp, (char *) codeloc, 4 * 4);
838
+ #else
839
+ void **tramp = (void **) &closure->tramp[0];
840
+
841
+ if (cif->abi < FFI_LINUX || cif->abi >= FFI_LAST_ABI)
842
+ return FFI_BAD_ABI;
843
+
844
+ /* Copy function address and TOC from ffi_closure_LINUX64 OPD. */
845
+ memcpy (&tramp[0], (void **) ffi_closure_LINUX64, sizeof (void *));
846
+ tramp[1] = codeloc;
847
+ memcpy (&tramp[2], (void **) ffi_closure_LINUX64 + 1, sizeof (void *));
848
+ #endif
849
+
850
+ closure->cif = cif;
851
+ closure->fun = fun;
852
+ closure->user_data = user_data;
853
+
854
+ return FFI_OK;
855
+ }
856
+
857
+
858
+ int FFI_HIDDEN
859
+ ffi_closure_helper_LINUX64 (ffi_cif *cif,
860
+ void (*fun) (ffi_cif *, void *, void **, void *),
861
+ void *user_data,
862
+ void *rvalue,
863
+ unsigned long *pst,
864
+ ffi_dblfl *pfr,
865
+ float128 *pvec)
866
+ {
867
+ /* rvalue is the pointer to space for return value in closure assembly */
868
+ /* pst is the pointer to parameter save area
869
+ (r3-r10 are stored into its first 8 slots by ffi_closure_LINUX64) */
870
+ /* pfr is the pointer to where f1-f13 are stored in ffi_closure_LINUX64 */
871
+ /* pvec is the pointer to where v2-v13 are stored in ffi_closure_LINUX64 */
872
+
873
+ void **avalue;
874
+ ffi_type **arg_types;
875
+ unsigned long i, avn, nfixedargs;
876
+ ffi_dblfl *end_pfr = pfr + NUM_FPR_ARG_REGISTERS64;
877
+ float128 *end_pvec = pvec + NUM_VEC_ARG_REGISTERS64;
878
+ unsigned long align;
879
+
880
+ avalue = alloca (cif->nargs * sizeof (void *));
881
+
882
+ /* Copy the caller's structure return value address so that the
883
+ closure returns the data directly to the caller. */
884
+ if (cif->rtype->type == FFI_TYPE_STRUCT
885
+ && (cif->flags & FLAG_RETURNS_SMST) == 0)
886
+ {
887
+ rvalue = (void *) *pst;
888
+ pst++;
889
+ }
890
+
891
+ i = 0;
892
+ avn = cif->nargs;
893
+ #if _CALL_ELF != 2
894
+ nfixedargs = (unsigned) -1;
895
+ if ((cif->flags & FLAG_COMPAT) == 0)
896
+ #endif
897
+ nfixedargs = cif->nfixedargs;
898
+ arg_types = cif->arg_types;
899
+
900
+ /* Grab the addresses of the arguments from the stack frame. */
901
+ while (i < avn)
902
+ {
903
+ unsigned int elt, elnum;
904
+
905
+ switch (arg_types[i]->type)
906
+ {
907
+ case FFI_TYPE_SINT8:
908
+ case FFI_TYPE_UINT8:
909
+ #ifndef __LITTLE_ENDIAN__
910
+ avalue[i] = (char *) pst + 7;
911
+ pst++;
912
+ break;
913
+ #endif
914
+
915
+ case FFI_TYPE_SINT16:
916
+ case FFI_TYPE_UINT16:
917
+ #ifndef __LITTLE_ENDIAN__
918
+ avalue[i] = (char *) pst + 6;
919
+ pst++;
920
+ break;
921
+ #endif
922
+
923
+ case FFI_TYPE_SINT32:
924
+ case FFI_TYPE_UINT32:
925
+ #ifndef __LITTLE_ENDIAN__
926
+ avalue[i] = (char *) pst + 4;
927
+ pst++;
928
+ break;
929
+ #endif
930
+
931
+ case FFI_TYPE_SINT64:
932
+ case FFI_TYPE_UINT64:
933
+ case FFI_TYPE_POINTER:
934
+ avalue[i] = pst;
935
+ pst++;
936
+ break;
937
+
938
+ case FFI_TYPE_STRUCT:
939
+ if ((cif->abi & FFI_LINUX_STRUCT_ALIGN) != 0)
940
+ {
941
+ align = arg_types[i]->alignment;
942
+ if (align > 16)
943
+ align = 16;
944
+ if (align > 1)
945
+ pst = (unsigned long *) FFI_ALIGN ((size_t) pst, align);
946
+ }
947
+ elt = discover_homogeneous_aggregate (cif->abi, arg_types[i], &elnum);
948
+ if (elt)
949
+ {
950
+ #if _CALL_ELF == 2
951
+ union {
952
+ void *v;
953
+ unsigned long *ul;
954
+ float *f;
955
+ double *d;
956
+ float128 *f128;
957
+ size_t p;
958
+ } to, from;
959
+
960
+ /* Repackage the aggregate from its parts. The
961
+ aggregate size is not greater than the space taken by
962
+ the registers so store back to the register/parameter
963
+ save arrays. */
964
+ #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
965
+ if (elt == FFI_TYPE_LONGDOUBLE &&
966
+ (cif->abi & FFI_LINUX_LONG_DOUBLE_IEEE128) != 0)
967
+ {
968
+ if (pvec + elnum <= end_pvec)
969
+ to.v = pvec;
970
+ else
971
+ to.v = pst;
972
+ }
973
+ else
974
+ #endif
975
+ if (pfr + elnum <= end_pfr)
976
+ to.v = pfr;
977
+ else
978
+ to.v = pst;
979
+
980
+ avalue[i] = to.v;
981
+ from.ul = pst;
982
+ #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
983
+ if (elt == FFI_TYPE_LONGDOUBLE &&
984
+ (cif->abi & FFI_LINUX_LONG_DOUBLE_IEEE128) != 0)
985
+ {
986
+ do
987
+ {
988
+ if (pvec < end_pvec && i < nfixedargs)
989
+ memcpy (to.f128, pvec++, sizeof (float128));
990
+ else
991
+ memcpy (to.f128, from.f128, sizeof (float128));
992
+ to.f128++;
993
+ from.f128++;
994
+ }
995
+ while (--elnum != 0);
996
+ }
997
+ else
998
+ #endif
999
+ if (elt == FFI_TYPE_FLOAT)
1000
+ {
1001
+ do
1002
+ {
1003
+ if (pfr < end_pfr && i < nfixedargs)
1004
+ {
1005
+ *to.f = (float) pfr->d;
1006
+ pfr++;
1007
+ }
1008
+ else
1009
+ *to.f = *from.f;
1010
+ to.f++;
1011
+ from.f++;
1012
+ }
1013
+ while (--elnum != 0);
1014
+ }
1015
+ else
1016
+ {
1017
+ do
1018
+ {
1019
+ if (pfr < end_pfr && i < nfixedargs)
1020
+ {
1021
+ *to.d = pfr->d;
1022
+ pfr++;
1023
+ }
1024
+ else
1025
+ *to.d = *from.d;
1026
+ to.d++;
1027
+ from.d++;
1028
+ }
1029
+ while (--elnum != 0);
1030
+ }
1031
+ #else
1032
+ if (elt == FFI_TYPE_FLOAT)
1033
+ goto do_float;
1034
+ else
1035
+ goto do_double;
1036
+ #endif
1037
+ }
1038
+ else
1039
+ {
1040
+ #ifndef __LITTLE_ENDIAN__
1041
+ /* Structures with size less than eight bytes are passed
1042
+ left-padded. */
1043
+ if (arg_types[i]->size < 8)
1044
+ avalue[i] = (char *) pst + 8 - arg_types[i]->size;
1045
+ else
1046
+ #endif
1047
+ avalue[i] = pst;
1048
+ }
1049
+ pst += (arg_types[i]->size + 7) / 8;
1050
+ break;
1051
+
1052
+ #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
1053
+ case FFI_TYPE_LONGDOUBLE:
1054
+ if ((cif->abi & FFI_LINUX_LONG_DOUBLE_IEEE128) != 0)
1055
+ {
1056
+ if (((unsigned long) pst & 0xF) != 0)
1057
+ ++pst;
1058
+ if (pvec < end_pvec && i < nfixedargs)
1059
+ avalue[i] = pvec++;
1060
+ else
1061
+ avalue[i] = pst;
1062
+ pst += 2;
1063
+ break;
1064
+ }
1065
+ else if ((cif->abi & FFI_LINUX_LONG_DOUBLE_128) != 0)
1066
+ {
1067
+ if (pfr + 1 < end_pfr && i + 1 < nfixedargs)
1068
+ {
1069
+ avalue[i] = pfr;
1070
+ pfr += 2;
1071
+ }
1072
+ else
1073
+ {
1074
+ if (pfr < end_pfr && i < nfixedargs)
1075
+ {
1076
+ /* Passed partly in f13 and partly on the stack.
1077
+ Move it all to the stack. */
1078
+ *pst = *(unsigned long *) pfr;
1079
+ pfr++;
1080
+ }
1081
+ avalue[i] = pst;
1082
+ }
1083
+ pst += 2;
1084
+ break;
1085
+ }
1086
+ /* Fall through. */
1087
+ #endif
1088
+ case FFI_TYPE_DOUBLE:
1089
+ #if _CALL_ELF != 2
1090
+ do_double:
1091
+ #endif
1092
+ /* On the outgoing stack all values are aligned to 8 */
1093
+ /* there are 13 64bit floating point registers */
1094
+
1095
+ if (pfr < end_pfr && i < nfixedargs)
1096
+ {
1097
+ avalue[i] = pfr;
1098
+ pfr++;
1099
+ }
1100
+ else
1101
+ avalue[i] = pst;
1102
+ pst++;
1103
+ break;
1104
+
1105
+ case FFI_TYPE_FLOAT:
1106
+ #if _CALL_ELF != 2
1107
+ do_float:
1108
+ #endif
1109
+ if (pfr < end_pfr && i < nfixedargs)
1110
+ {
1111
+ /* Float values are stored as doubles in the
1112
+ ffi_closure_LINUX64 code. Fix them here. */
1113
+ pfr->f = (float) pfr->d;
1114
+ avalue[i] = pfr;
1115
+ pfr++;
1116
+ }
1117
+ else
1118
+ {
1119
+ #ifndef __LITTLE_ENDIAN__
1120
+ avalue[i] = (char *) pst + 4;
1121
+ #else
1122
+ avalue[i] = pst;
1123
+ #endif
1124
+ }
1125
+ pst++;
1126
+ break;
1127
+
1128
+ default:
1129
+ FFI_ASSERT (0);
1130
+ }
1131
+
1132
+ i++;
1133
+ }
1134
+
1135
+ (*fun) (cif, rvalue, avalue, user_data);
1136
+
1137
+ /* Tell ffi_closure_LINUX64 how to perform return type promotions. */
1138
+ if ((cif->flags & FLAG_RETURNS_SMST) != 0)
1139
+ {
1140
+ if ((cif->flags & (FLAG_RETURNS_FP | FLAG_RETURNS_VEC)) == 0)
1141
+ return FFI_V2_TYPE_SMALL_STRUCT + cif->rtype->size - 1;
1142
+ else if ((cif->flags & FLAG_RETURNS_VEC) != 0)
1143
+ return FFI_V2_TYPE_VECTOR_HOMOG;
1144
+ else if ((cif->flags & FLAG_RETURNS_64BITS) != 0)
1145
+ return FFI_V2_TYPE_DOUBLE_HOMOG;
1146
+ else
1147
+ return FFI_V2_TYPE_FLOAT_HOMOG;
1148
+ }
1149
+ if ((cif->flags & FLAG_RETURNS_VEC) != 0)
1150
+ return FFI_V2_TYPE_VECTOR;
1151
+ return cif->rtype->type;
1152
+ }
1153
+ #endif