ffi 1.1.5 → 1.15.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (629) hide show
  1. checksums.yaml +7 -0
  2. data/CHANGELOG.md +338 -0
  3. data/COPYING +49 -0
  4. data/Gemfile +14 -0
  5. data/LICENSE +21 -11
  6. data/LICENSE.SPECS +22 -0
  7. data/README.md +136 -0
  8. data/Rakefile +149 -154
  9. data/ext/ffi_c/AbstractMemory.c +133 -57
  10. data/ext/ffi_c/AbstractMemory.h +21 -12
  11. data/ext/ffi_c/ArrayType.c +27 -14
  12. data/ext/ffi_c/ArrayType.h +21 -12
  13. data/ext/ffi_c/Buffer.c +29 -25
  14. data/ext/ffi_c/Call.c +154 -125
  15. data/ext/ffi_c/Call.h +43 -20
  16. data/ext/ffi_c/ClosurePool.c +100 -42
  17. data/ext/ffi_c/ClosurePool.h +24 -13
  18. data/ext/ffi_c/DynamicLibrary.c +47 -28
  19. data/ext/ffi_c/DynamicLibrary.h +70 -12
  20. data/ext/ffi_c/Function.c +119 -167
  21. data/ext/ffi_c/Function.h +23 -19
  22. data/ext/ffi_c/FunctionInfo.c +55 -25
  23. data/ext/ffi_c/LastError.c +70 -21
  24. data/ext/ffi_c/LastError.h +21 -12
  25. data/ext/ffi_c/LongDouble.c +15 -9
  26. data/ext/ffi_c/LongDouble.h +21 -16
  27. data/ext/ffi_c/MappedType.c +22 -15
  28. data/ext/ffi_c/MappedType.h +21 -12
  29. data/ext/ffi_c/MemoryPointer.c +58 -33
  30. data/ext/ffi_c/MemoryPointer.h +22 -19
  31. data/ext/ffi_c/MethodHandle.c +49 -50
  32. data/ext/ffi_c/MethodHandle.h +24 -14
  33. data/ext/ffi_c/Platform.c +28 -62
  34. data/ext/ffi_c/Platform.h +21 -12
  35. data/ext/ffi_c/Pointer.c +63 -46
  36. data/ext/ffi_c/Pointer.h +22 -19
  37. data/ext/ffi_c/Struct.c +198 -80
  38. data/ext/ffi_c/Struct.h +33 -18
  39. data/ext/ffi_c/StructByValue.c +23 -20
  40. data/ext/ffi_c/StructByValue.h +21 -12
  41. data/ext/ffi_c/StructLayout.c +184 -39
  42. data/ext/ffi_c/Thread.c +73 -270
  43. data/ext/ffi_c/Thread.h +32 -35
  44. data/ext/ffi_c/Type.c +26 -32
  45. data/ext/ffi_c/Type.h +24 -10
  46. data/ext/ffi_c/Types.c +28 -20
  47. data/ext/ffi_c/Types.h +25 -16
  48. data/ext/ffi_c/Variadic.c +78 -39
  49. data/ext/ffi_c/compat.h +25 -17
  50. data/ext/ffi_c/extconf.rb +68 -31
  51. data/ext/ffi_c/ffi.c +27 -20
  52. data/ext/ffi_c/libffi/.appveyor.yml +66 -0
  53. data/ext/ffi_c/libffi/.gitattributes +4 -0
  54. data/ext/ffi_c/libffi/.github/issue_template.md +10 -0
  55. data/ext/ffi_c/libffi/.gitignore +38 -0
  56. data/ext/ffi_c/libffi/.travis/ar-lib +270 -0
  57. data/ext/ffi_c/libffi/.travis/bfin-sim.exp +58 -0
  58. data/ext/ffi_c/libffi/.travis/build-cross-in-container.sh +14 -0
  59. data/ext/ffi_c/libffi/.travis/build-in-container.sh +12 -0
  60. data/ext/ffi_c/libffi/.travis/build.sh +142 -0
  61. data/ext/ffi_c/libffi/.travis/compile +351 -0
  62. data/ext/ffi_c/libffi/.travis/install.sh +71 -0
  63. data/ext/ffi_c/libffi/.travis/m32r-sim.exp +58 -0
  64. data/ext/ffi_c/libffi/.travis/moxie-sim.exp +60 -0
  65. data/ext/ffi_c/libffi/.travis/or1k-sim.exp +58 -0
  66. data/ext/ffi_c/libffi/.travis/powerpc-eabisim.exp +58 -0
  67. data/ext/ffi_c/libffi/.travis/site.exp +27 -0
  68. data/ext/ffi_c/libffi/.travis/wine-sim.exp +55 -0
  69. data/ext/ffi_c/libffi/.travis.yml +83 -0
  70. data/ext/ffi_c/libffi/{ChangeLog → ChangeLog.old} +6366 -3559
  71. data/ext/ffi_c/libffi/LICENSE +1 -1
  72. data/ext/ffi_c/libffi/LICENSE-BUILDTOOLS +353 -0
  73. data/ext/ffi_c/libffi/Makefile.am +123 -169
  74. data/ext/ffi_c/libffi/Makefile.in +1243 -1003
  75. data/ext/ffi_c/libffi/README.md +486 -0
  76. data/ext/ffi_c/libffi/acinclude.m4 +387 -0
  77. data/ext/ffi_c/libffi/autogen.sh +2 -0
  78. data/ext/ffi_c/libffi/config.guess +690 -504
  79. data/ext/ffi_c/libffi/config.sub +1353 -1207
  80. data/ext/ffi_c/libffi/configure +7308 -2449
  81. data/ext/ffi_c/libffi/configure.ac +178 -259
  82. data/ext/ffi_c/libffi/configure.host +311 -4
  83. data/ext/ffi_c/libffi/doc/Makefile.am +3 -0
  84. data/ext/ffi_c/libffi/doc/Makefile.in +815 -0
  85. data/ext/ffi_c/libffi/doc/libffi.texi +455 -58
  86. data/ext/ffi_c/libffi/doc/version.texi +4 -4
  87. data/ext/ffi_c/libffi/fficonfig.h.in +37 -13
  88. data/ext/ffi_c/libffi/generate-darwin-source-and-headers.py +201 -0
  89. data/ext/ffi_c/libffi/include/Makefile.am +3 -3
  90. data/ext/ffi_c/libffi/include/Makefile.in +196 -75
  91. data/ext/ffi_c/libffi/include/ffi.h.in +163 -67
  92. data/ext/ffi_c/libffi/include/ffi_cfi.h +55 -0
  93. data/ext/ffi_c/libffi/include/ffi_common.h +39 -12
  94. data/ext/ffi_c/libffi/install-sh +207 -209
  95. data/ext/ffi_c/libffi/libffi.map.in +76 -0
  96. data/ext/ffi_c/libffi/libffi.pc.in +3 -2
  97. data/ext/ffi_c/libffi/libffi.xcodeproj/project.pbxproj +997 -0
  98. data/ext/ffi_c/libffi/libtool-ldflags +106 -0
  99. data/ext/ffi_c/libffi/libtool-version +1 -1
  100. data/ext/ffi_c/libffi/ltmain.sh +3641 -2026
  101. data/ext/ffi_c/libffi/m4/asmcfi.m4 +13 -0
  102. data/ext/ffi_c/libffi/m4/ax_append_flag.m4 +50 -0
  103. data/ext/ffi_c/libffi/m4/ax_cc_maxopt.m4 +32 -14
  104. data/ext/ffi_c/libffi/m4/ax_cflags_warn_all.m4 +33 -106
  105. data/ext/ffi_c/libffi/m4/ax_check_compile_flag.m4 +53 -0
  106. data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +38 -13
  107. data/ext/ffi_c/libffi/m4/ax_configure_args.m4 +8 -29
  108. data/ext/ffi_c/libffi/m4/ax_enable_builddir.m4 +11 -9
  109. data/ext/ffi_c/libffi/m4/ax_gcc_archflag.m4 +104 -52
  110. data/ext/ffi_c/libffi/m4/ax_gcc_x86_cpuid.m4 +18 -8
  111. data/ext/ffi_c/libffi/m4/ax_require_defined.m4 +37 -0
  112. data/ext/ffi_c/libffi/make_sunver.pl +333 -0
  113. data/ext/ffi_c/libffi/man/Makefile.am +2 -2
  114. data/ext/ffi_c/libffi/man/Makefile.in +151 -55
  115. data/ext/ffi_c/libffi/man/ffi.3 +10 -0
  116. data/ext/ffi_c/libffi/man/ffi_prep_cif.3 +6 -4
  117. data/ext/ffi_c/libffi/man/ffi_prep_cif_var.3 +73 -0
  118. data/ext/ffi_c/libffi/missing +153 -314
  119. data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.sln +33 -0
  120. data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.vcxproj +130 -0
  121. data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.vcxproj.filters +57 -0
  122. data/ext/ffi_c/libffi/msvc_build/aarch64/Ffi_staticLib.vcxproj.user +4 -0
  123. data/ext/ffi_c/libffi/{include/ffi.h.vc64 → msvc_build/aarch64/aarch64_include/ffi.h} +151 -67
  124. data/ext/ffi_c/libffi/msvc_build/aarch64/aarch64_include/fficonfig.h +219 -0
  125. data/ext/ffi_c/libffi/msvcc.sh +176 -20
  126. data/ext/ffi_c/libffi/src/aarch64/ffi.c +1025 -0
  127. data/ext/ffi_c/libffi/src/aarch64/ffitarget.h +97 -0
  128. data/ext/ffi_c/libffi/src/aarch64/internal.h +68 -0
  129. data/ext/ffi_c/libffi/src/aarch64/sysv.S +451 -0
  130. data/ext/ffi_c/libffi/src/aarch64/win64_armasm.S +506 -0
  131. data/ext/ffi_c/libffi/src/alpha/ffi.c +335 -98
  132. data/ext/ffi_c/libffi/src/alpha/ffitarget.h +10 -1
  133. data/ext/ffi_c/libffi/src/alpha/internal.h +23 -0
  134. data/ext/ffi_c/libffi/src/alpha/osf.S +161 -266
  135. data/ext/ffi_c/libffi/src/arc/arcompact.S +135 -0
  136. data/ext/ffi_c/libffi/src/arc/ffi.c +266 -0
  137. data/ext/ffi_c/libffi/src/arc/ffitarget.h +53 -0
  138. data/ext/ffi_c/libffi/src/arm/ffi.c +663 -515
  139. data/ext/ffi_c/libffi/src/arm/ffitarget.h +32 -8
  140. data/ext/ffi_c/libffi/src/arm/internal.h +7 -0
  141. data/ext/ffi_c/libffi/src/arm/sysv.S +305 -417
  142. data/ext/ffi_c/libffi/src/arm/sysv_msvc_arm32.S +311 -0
  143. data/ext/ffi_c/libffi/src/avr32/ffitarget.h +6 -1
  144. data/ext/ffi_c/libffi/src/bfin/ffi.c +196 -0
  145. data/ext/ffi_c/libffi/src/bfin/ffitarget.h +43 -0
  146. data/ext/ffi_c/libffi/src/bfin/sysv.S +179 -0
  147. data/ext/ffi_c/libffi/src/closures.c +465 -59
  148. data/ext/ffi_c/libffi/src/cris/ffi.c +10 -7
  149. data/ext/ffi_c/libffi/src/cris/ffitarget.h +6 -1
  150. data/ext/ffi_c/libffi/src/csky/ffi.c +395 -0
  151. data/ext/ffi_c/libffi/src/csky/ffitarget.h +63 -0
  152. data/ext/ffi_c/libffi/src/csky/sysv.S +371 -0
  153. data/ext/ffi_c/libffi/src/debug.c +6 -1
  154. data/ext/ffi_c/libffi/src/dlmalloc.c +17 -12
  155. data/ext/ffi_c/libffi/src/frv/ffi.c +2 -2
  156. data/ext/ffi_c/libffi/src/frv/ffitarget.h +6 -1
  157. data/ext/ffi_c/libffi/src/ia64/ffi.c +35 -13
  158. data/ext/ffi_c/libffi/src/ia64/ffitarget.h +8 -2
  159. data/ext/ffi_c/libffi/src/ia64/unix.S +8 -1
  160. data/ext/ffi_c/libffi/src/java_raw_api.c +23 -5
  161. data/ext/ffi_c/libffi/src/kvx/asm.h +5 -0
  162. data/ext/ffi_c/libffi/src/kvx/ffi.c +273 -0
  163. data/ext/ffi_c/libffi/src/kvx/ffitarget.h +75 -0
  164. data/ext/ffi_c/libffi/src/kvx/sysv.S +127 -0
  165. data/ext/ffi_c/libffi/src/m32r/ffi.c +1 -1
  166. data/ext/ffi_c/libffi/src/m32r/ffitarget.h +6 -1
  167. data/ext/ffi_c/libffi/src/m68k/ffi.c +87 -13
  168. data/ext/ffi_c/libffi/src/m68k/ffitarget.h +6 -1
  169. data/ext/ffi_c/libffi/src/m68k/sysv.S +119 -32
  170. data/ext/ffi_c/libffi/src/m88k/ffi.c +400 -0
  171. data/ext/ffi_c/libffi/src/m88k/ffitarget.h +49 -0
  172. data/ext/ffi_c/libffi/src/m88k/obsd.S +209 -0
  173. data/ext/ffi_c/libffi/src/metag/ffi.c +330 -0
  174. data/ext/ffi_c/libffi/{fficonfig.hw → src/metag/ffitarget.h} +22 -26
  175. data/ext/ffi_c/libffi/src/metag/sysv.S +311 -0
  176. data/ext/ffi_c/libffi/src/microblaze/ffi.c +321 -0
  177. data/ext/ffi_c/libffi/src/microblaze/ffitarget.h +53 -0
  178. data/ext/ffi_c/libffi/src/microblaze/sysv.S +302 -0
  179. data/ext/ffi_c/libffi/src/mips/ffi.c +135 -37
  180. data/ext/ffi_c/libffi/src/mips/ffitarget.h +16 -14
  181. data/ext/ffi_c/libffi/src/mips/n32.S +128 -56
  182. data/ext/ffi_c/libffi/src/mips/o32.S +150 -27
  183. data/ext/ffi_c/libffi/src/moxie/eabi.S +55 -82
  184. data/ext/ffi_c/libffi/src/moxie/ffi.c +55 -46
  185. data/ext/ffi_c/libffi/src/moxie/ffitarget.h +52 -0
  186. data/ext/ffi_c/libffi/src/nios2/ffi.c +304 -0
  187. data/ext/ffi_c/libffi/src/nios2/ffitarget.h +52 -0
  188. data/ext/ffi_c/libffi/src/nios2/sysv.S +136 -0
  189. data/ext/ffi_c/libffi/src/or1k/ffi.c +328 -0
  190. data/ext/ffi_c/libffi/src/or1k/ffitarget.h +58 -0
  191. data/ext/ffi_c/libffi/src/or1k/sysv.S +107 -0
  192. data/ext/ffi_c/libffi/src/pa/ffi.c +46 -91
  193. data/ext/ffi_c/libffi/src/pa/ffitarget.h +9 -7
  194. data/ext/ffi_c/libffi/src/pa/hpux32.S +4 -2
  195. data/ext/ffi_c/libffi/src/pa/linux.S +27 -4
  196. data/ext/ffi_c/libffi/src/powerpc/aix.S +245 -7
  197. data/ext/ffi_c/libffi/src/powerpc/aix_closure.S +253 -4
  198. data/ext/ffi_c/libffi/src/powerpc/asm.h +2 -2
  199. data/ext/ffi_c/libffi/src/powerpc/darwin.S +2 -7
  200. data/ext/ffi_c/libffi/src/powerpc/darwin_closure.S +22 -26
  201. data/ext/ffi_c/libffi/src/powerpc/ffi.c +105 -1378
  202. data/ext/ffi_c/libffi/src/powerpc/ffi_darwin.c +123 -30
  203. data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +1153 -0
  204. data/ext/ffi_c/libffi/src/powerpc/ffi_powerpc.h +105 -0
  205. data/ext/ffi_c/libffi/src/powerpc/ffi_sysv.c +923 -0
  206. data/ext/ffi_c/libffi/src/powerpc/ffitarget.h +110 -45
  207. data/ext/ffi_c/libffi/src/powerpc/linux64.S +189 -85
  208. data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +436 -108
  209. data/ext/ffi_c/libffi/src/powerpc/ppc_closure.S +138 -68
  210. data/ext/ffi_c/libffi/src/powerpc/sysv.S +73 -119
  211. data/ext/ffi_c/libffi/src/prep_cif.c +111 -25
  212. data/ext/ffi_c/libffi/src/raw_api.c +18 -5
  213. data/ext/ffi_c/libffi/src/riscv/ffi.c +481 -0
  214. data/ext/ffi_c/libffi/src/riscv/ffitarget.h +69 -0
  215. data/ext/ffi_c/libffi/src/riscv/sysv.S +293 -0
  216. data/ext/ffi_c/libffi/src/s390/ffi.c +294 -318
  217. data/ext/ffi_c/libffi/src/s390/ffitarget.h +9 -1
  218. data/ext/ffi_c/libffi/src/s390/internal.h +11 -0
  219. data/ext/ffi_c/libffi/src/s390/sysv.S +257 -366
  220. data/ext/ffi_c/libffi/src/sh/ffi.c +4 -3
  221. data/ext/ffi_c/libffi/src/sh/ffitarget.h +6 -1
  222. data/ext/ffi_c/libffi/src/sh64/ffi.c +3 -2
  223. data/ext/ffi_c/libffi/src/sh64/ffitarget.h +6 -1
  224. data/ext/ffi_c/libffi/src/sparc/ffi.c +326 -527
  225. data/ext/ffi_c/libffi/src/sparc/ffi64.c +608 -0
  226. data/ext/ffi_c/libffi/src/sparc/ffitarget.h +20 -7
  227. data/ext/ffi_c/libffi/src/sparc/internal.h +26 -0
  228. data/ext/ffi_c/libffi/src/sparc/v8.S +364 -234
  229. data/ext/ffi_c/libffi/src/sparc/v9.S +340 -207
  230. data/ext/ffi_c/libffi/src/tile/ffi.c +355 -0
  231. data/ext/ffi_c/libffi/src/tile/ffitarget.h +65 -0
  232. data/ext/ffi_c/libffi/src/tile/tile.S +360 -0
  233. data/ext/ffi_c/libffi/src/types.c +46 -15
  234. data/ext/ffi_c/libffi/src/vax/elfbsd.S +195 -0
  235. data/ext/ffi_c/libffi/src/vax/ffi.c +276 -0
  236. data/ext/ffi_c/libffi/src/vax/ffitarget.h +49 -0
  237. data/ext/ffi_c/libffi/src/x86/asmnames.h +30 -0
  238. data/ext/ffi_c/libffi/src/x86/ffi.c +624 -498
  239. data/ext/ffi_c/libffi/src/x86/ffi64.c +379 -119
  240. data/ext/ffi_c/libffi/src/x86/ffitarget.h +74 -35
  241. data/ext/ffi_c/libffi/src/x86/ffiw64.c +318 -0
  242. data/ext/ffi_c/libffi/src/x86/internal.h +29 -0
  243. data/ext/ffi_c/libffi/src/x86/internal64.h +22 -0
  244. data/ext/ffi_c/libffi/src/x86/sysv.S +1070 -400
  245. data/ext/ffi_c/libffi/src/x86/sysv_intel.S +995 -0
  246. data/ext/ffi_c/libffi/src/x86/unix64.S +494 -299
  247. data/ext/ffi_c/libffi/src/x86/win64.S +231 -458
  248. data/ext/ffi_c/libffi/src/x86/win64_intel.S +238 -0
  249. data/ext/ffi_c/libffi/src/xtensa/ffi.c +298 -0
  250. data/ext/ffi_c/libffi/src/xtensa/ffitarget.h +53 -0
  251. data/ext/ffi_c/libffi/src/xtensa/sysv.S +258 -0
  252. data/ext/ffi_c/libffi/stamp-h.in +1 -0
  253. data/ext/ffi_c/libffi/testsuite/Makefile.am +115 -73
  254. data/ext/ffi_c/libffi/testsuite/Makefile.in +262 -114
  255. data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +334 -24
  256. data/ext/ffi_c/libffi/testsuite/lib/target-libpath.exp +21 -1
  257. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/Makefile +28 -0
  258. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/README +78 -0
  259. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/alignof.h +50 -0
  260. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/bhaible.exp +63 -0
  261. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-call.c +1745 -0
  262. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-callback.c +2885 -0
  263. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/testcases.c +743 -0
  264. data/ext/ffi_c/libffi/testsuite/libffi.call/align_mixed.c +46 -0
  265. data/ext/ffi_c/libffi/testsuite/libffi.call/align_stdcall.c +46 -0
  266. data/ext/ffi_c/libffi/testsuite/libffi.call/call.exp +28 -6
  267. data/ext/ffi_c/libffi/testsuite/libffi.call/err_bad_typedef.c +2 -2
  268. data/ext/ffi_c/libffi/testsuite/libffi.call/ffitest.h +25 -40
  269. data/ext/ffi_c/libffi/testsuite/libffi.call/float1.c +3 -1
  270. data/ext/ffi_c/libffi/testsuite/libffi.call/float2.c +15 -12
  271. data/ext/ffi_c/libffi/testsuite/libffi.call/float3.c +4 -2
  272. data/ext/ffi_c/libffi/testsuite/libffi.call/float_va.c +107 -0
  273. data/ext/ffi_c/libffi/testsuite/libffi.call/many.c +6 -16
  274. data/ext/ffi_c/libffi/testsuite/libffi.call/many2.c +57 -0
  275. data/ext/ffi_c/libffi/testsuite/libffi.call/many_double.c +70 -0
  276. data/ext/ffi_c/libffi/testsuite/libffi.call/many_mixed.c +78 -0
  277. data/ext/ffi_c/libffi/testsuite/libffi.call/negint.c +0 -1
  278. data/ext/ffi_c/libffi/testsuite/libffi.call/offsets.c +46 -0
  279. data/ext/ffi_c/libffi/testsuite/libffi.call/pr1172638.c +127 -0
  280. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl.c +1 -0
  281. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ldl.c +1 -1
  282. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sc.c +1 -1
  283. data/ext/ffi_c/libffi/testsuite/libffi.call/return_uc.c +1 -1
  284. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen.c +2 -2
  285. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen2.c +49 -0
  286. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen3.c +49 -0
  287. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen4.c +55 -0
  288. data/ext/ffi_c/libffi/testsuite/libffi.call/struct1.c +9 -7
  289. data/ext/ffi_c/libffi/testsuite/libffi.call/struct10.c +57 -0
  290. data/ext/ffi_c/libffi/testsuite/libffi.call/struct2.c +7 -7
  291. data/ext/ffi_c/libffi/testsuite/libffi.call/struct3.c +7 -6
  292. data/ext/ffi_c/libffi/testsuite/libffi.call/struct4.c +9 -8
  293. data/ext/ffi_c/libffi/testsuite/libffi.call/struct5.c +9 -8
  294. data/ext/ffi_c/libffi/testsuite/libffi.call/struct6.c +9 -9
  295. data/ext/ffi_c/libffi/testsuite/libffi.call/struct7.c +9 -9
  296. data/ext/ffi_c/libffi/testsuite/libffi.call/struct8.c +9 -8
  297. data/ext/ffi_c/libffi/testsuite/libffi.call/struct9.c +9 -8
  298. data/ext/ffi_c/libffi/testsuite/libffi.call/uninitialized.c +61 -0
  299. data/ext/ffi_c/libffi/testsuite/libffi.call/va_1.c +196 -0
  300. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct1.c +121 -0
  301. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct2.c +123 -0
  302. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct3.c +125 -0
  303. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure.exp +67 -0
  304. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn0.c +0 -0
  305. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn1.c +0 -0
  306. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn2.c +0 -0
  307. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn3.c +0 -0
  308. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn4.c +0 -0
  309. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn5.c +0 -0
  310. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn6.c +0 -0
  311. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_loc_fn0.c +0 -0
  312. data/ext/ffi_c/libffi/testsuite/{libffi.call/closure_stdcall.c → libffi.closures/closure_simple.c} +7 -16
  313. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_12byte.c +4 -4
  314. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_16byte.c +4 -4
  315. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_18byte.c +4 -4
  316. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_19byte.c +4 -4
  317. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_1_1byte.c +4 -4
  318. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte.c +4 -4
  319. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte1.c +4 -4
  320. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_24byte.c +5 -5
  321. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_2byte.c +4 -4
  322. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3_1byte.c +4 -4
  323. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte1.c +4 -4
  324. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte2.c +4 -4
  325. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_3float.c +95 -0
  326. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4_1byte.c +4 -4
  327. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4byte.c +4 -4
  328. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5_1_byte.c +4 -4
  329. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5byte.c +4 -4
  330. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_64byte.c +5 -5
  331. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6_1_byte.c +4 -4
  332. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6byte.c +4 -4
  333. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7_1_byte.c +4 -4
  334. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7byte.c +4 -4
  335. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_8byte.c +4 -4
  336. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte1.c +4 -4
  337. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte2.c +4 -4
  338. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_double.c +4 -4
  339. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_float.c +4 -4
  340. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble.c +4 -4
  341. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split.c +4 -6
  342. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split2.c +4 -6
  343. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_pointer.c +4 -4
  344. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint16.c +4 -4
  345. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint32.c +4 -4
  346. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint64.c +4 -4
  347. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint16.c +4 -4
  348. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint32.c +4 -4
  349. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint64.c +4 -4
  350. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_dbls_struct.c +4 -4
  351. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double.c +0 -0
  352. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double_va.c +10 -9
  353. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_float.c +0 -0
  354. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble.c +3 -3
  355. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble_va.c +10 -9
  356. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_many_mixed_args.c +70 -0
  357. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_many_mixed_float_double.c +55 -0
  358. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_schar.c +0 -0
  359. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshort.c +0 -0
  360. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshortchar.c +0 -0
  361. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_uchar.c +0 -0
  362. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushort.c +0 -0
  363. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushortchar.c +0 -0
  364. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer.c +1 -1
  365. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer_stack.c +11 -9
  366. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_schar.c +0 -0
  367. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sint.c +0 -0
  368. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sshort.c +0 -0
  369. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_struct_va1.c +114 -0
  370. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uchar.c +0 -0
  371. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uchar_va.c +44 -0
  372. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uint.c +0 -0
  373. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_uint_va.c +45 -0
  374. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ulong_va.c +45 -0
  375. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ulonglong.c +5 -5
  376. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ushort.c +0 -0
  377. data/ext/ffi_c/libffi/testsuite/libffi.closures/cls_ushort_va.c +44 -0
  378. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/err_bad_abi.c +0 -0
  379. data/ext/ffi_c/libffi/testsuite/libffi.closures/ffitest.h +138 -0
  380. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/huge_struct.c +20 -19
  381. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct.c +6 -6
  382. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct1.c +8 -8
  383. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct10.c +7 -6
  384. data/ext/ffi_c/libffi/testsuite/libffi.closures/nested_struct11.c +121 -0
  385. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct2.c +5 -5
  386. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct3.c +5 -5
  387. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct4.c +5 -5
  388. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct5.c +5 -5
  389. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct6.c +6 -6
  390. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct7.c +5 -5
  391. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct8.c +6 -6
  392. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct9.c +6 -6
  393. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/problem1.c +0 -0
  394. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large.c +7 -7
  395. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large2.c +7 -7
  396. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium.c +5 -5
  397. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium2.c +5 -5
  398. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/testclosure.c +2 -2
  399. data/ext/ffi_c/libffi/testsuite/{libffi.special → libffi.closures}/unwindtest.cc +3 -10
  400. data/ext/ffi_c/libffi/testsuite/{libffi.special → libffi.closures}/unwindtest_ffi_call.cc +3 -2
  401. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex.inc +91 -0
  402. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_double.c +10 -0
  403. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_float.c +10 -0
  404. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_longdouble.c +10 -0
  405. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex.inc +42 -0
  406. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_double.c +10 -0
  407. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_float.c +10 -0
  408. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_longdouble.c +10 -0
  409. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct.inc +71 -0
  410. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_double.c +10 -0
  411. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_float.c +10 -0
  412. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_longdouble.c +10 -0
  413. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va.inc +80 -0
  414. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_double.c +10 -0
  415. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_float.c +16 -0
  416. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_longdouble.c +10 -0
  417. data/ext/ffi_c/libffi/testsuite/{libffi.special/special.exp → libffi.complex/complex.exp} +9 -8
  418. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex.inc +51 -0
  419. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_double.inc +7 -0
  420. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_float.inc +7 -0
  421. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_longdouble.inc +7 -0
  422. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_double.c +10 -0
  423. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_float.c +10 -0
  424. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_int.c +86 -0
  425. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_longdouble.c +10 -0
  426. data/ext/ffi_c/libffi/testsuite/libffi.complex/ffitest.h +1 -0
  427. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex.inc +78 -0
  428. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_double.c +10 -0
  429. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_float.c +10 -0
  430. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_longdouble.c +10 -0
  431. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex.inc +37 -0
  432. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1.inc +41 -0
  433. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_double.c +10 -0
  434. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_float.c +10 -0
  435. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_longdouble.c +10 -0
  436. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2.inc +44 -0
  437. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_double.c +10 -0
  438. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_float.c +10 -0
  439. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_longdouble.c +10 -0
  440. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_double.c +10 -0
  441. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_float.c +10 -0
  442. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_longdouble.c +10 -0
  443. data/ext/ffi_c/libffi/testsuite/libffi.go/aa-direct.c +34 -0
  444. data/ext/ffi_c/libffi/testsuite/libffi.go/closure1.c +28 -0
  445. data/ext/ffi_c/libffi/testsuite/libffi.go/ffitest.h +1 -0
  446. data/ext/ffi_c/libffi/testsuite/libffi.go/go.exp +36 -0
  447. data/ext/ffi_c/libffi/testsuite/libffi.go/static-chain.h +19 -0
  448. data/ext/ffi_c/libffi.bsd.mk +12 -6
  449. data/ext/ffi_c/libffi.darwin.mk +21 -9
  450. data/ext/ffi_c/libffi.gnu.mk +3 -2
  451. data/ext/ffi_c/libffi.mk +11 -6
  452. data/ext/ffi_c/libffi.vc.mk +1 -1
  453. data/ext/ffi_c/libffi.vc64.mk +1 -1
  454. data/ext/ffi_c/rbffi.h +22 -14
  455. data/ext/ffi_c/rbffi_endian.h +11 -2
  456. data/ffi.gemspec +42 -0
  457. data/lib/ffi/abstract_memory.rb +44 -0
  458. data/lib/ffi/autopointer.rb +70 -50
  459. data/lib/ffi/data_converter.rb +67 -0
  460. data/lib/ffi/enum.rb +159 -24
  461. data/lib/ffi/errno.rb +21 -11
  462. data/lib/ffi/ffi.rb +25 -11
  463. data/lib/ffi/io.rb +24 -14
  464. data/lib/ffi/library.rb +174 -67
  465. data/lib/ffi/managedstruct.rb +63 -34
  466. data/lib/ffi/platform/aarch64-darwin/types.conf +130 -0
  467. data/lib/ffi/platform/aarch64-freebsd/types.conf +128 -0
  468. data/lib/ffi/platform/aarch64-freebsd12/types.conf +181 -0
  469. data/lib/ffi/platform/aarch64-linux/types.conf +104 -0
  470. data/lib/ffi/platform/aarch64-openbsd/types.conf +134 -0
  471. data/lib/ffi/platform/arm-freebsd/types.conf +152 -0
  472. data/lib/ffi/platform/arm-freebsd12/types.conf +152 -0
  473. data/lib/ffi/platform/arm-linux/types.conf +110 -82
  474. data/lib/ffi/platform/i386-cygwin/types.conf +3 -0
  475. data/lib/ffi/platform/i386-darwin/types.conf +63 -63
  476. data/lib/ffi/platform/i386-freebsd/types.conf +89 -89
  477. data/lib/ffi/platform/i386-freebsd12/types.conf +152 -0
  478. data/lib/ffi/platform/{i486-gnu → i386-gnu}/types.conf +84 -84
  479. data/lib/ffi/platform/i386-linux/types.conf +77 -77
  480. data/lib/ffi/platform/i386-netbsd/types.conf +87 -87
  481. data/lib/ffi/platform/i386-openbsd/types.conf +89 -87
  482. data/lib/ffi/platform/i386-solaris/types.conf +96 -96
  483. data/lib/ffi/platform/i386-windows/types.conf +43 -96
  484. data/lib/ffi/platform/ia64-linux/types.conf +79 -79
  485. data/lib/ffi/platform/mips-linux/types.conf +79 -79
  486. data/lib/ffi/platform/mips64-linux/types.conf +104 -0
  487. data/lib/ffi/platform/mips64el-linux/types.conf +104 -0
  488. data/lib/ffi/platform/mipsel-linux/types.conf +79 -79
  489. data/lib/ffi/platform/mipsisa32r6-linux/types.conf +102 -0
  490. data/lib/ffi/platform/mipsisa32r6el-linux/types.conf +102 -0
  491. data/lib/ffi/platform/mipsisa64r6-linux/types.conf +104 -0
  492. data/lib/ffi/platform/mipsisa64r6el-linux/types.conf +104 -0
  493. data/lib/ffi/platform/powerpc-aix/types.conf +155 -155
  494. data/lib/ffi/platform/powerpc-darwin/types.conf +63 -63
  495. data/lib/ffi/platform/powerpc-linux/types.conf +108 -78
  496. data/lib/ffi/platform/powerpc-openbsd/types.conf +156 -0
  497. data/lib/ffi/platform/powerpc64-linux/types.conf +104 -0
  498. data/lib/ffi/platform/powerpc64le-linux/types.conf +100 -0
  499. data/lib/ffi/platform/riscv64-linux/types.conf +104 -0
  500. data/lib/ffi/platform/s390-linux/types.conf +79 -79
  501. data/lib/ffi/platform/s390x-linux/types.conf +79 -79
  502. data/lib/ffi/platform/sparc-linux/types.conf +79 -79
  503. data/lib/ffi/platform/sparc-solaris/types.conf +103 -103
  504. data/lib/ffi/platform/sparc64-linux/types.conf +102 -0
  505. data/lib/ffi/platform/sparcv9-openbsd/types.conf +156 -0
  506. data/lib/ffi/platform/sparcv9-solaris/types.conf +103 -103
  507. data/lib/ffi/platform/x86_64-cygwin/types.conf +3 -0
  508. data/lib/ffi/platform/x86_64-darwin/types.conf +93 -63
  509. data/lib/ffi/platform/x86_64-dragonflybsd/types.conf +130 -0
  510. data/lib/ffi/platform/x86_64-freebsd/types.conf +90 -88
  511. data/lib/ffi/platform/x86_64-freebsd12/types.conf +158 -0
  512. data/lib/ffi/platform/x86_64-haiku/types.conf +117 -0
  513. data/lib/ffi/platform/x86_64-linux/types.conf +107 -77
  514. data/lib/ffi/platform/x86_64-msys/types.conf +119 -0
  515. data/lib/ffi/platform/x86_64-netbsd/types.conf +89 -87
  516. data/lib/ffi/platform/x86_64-openbsd/types.conf +100 -92
  517. data/lib/ffi/platform/x86_64-solaris/types.conf +96 -96
  518. data/lib/ffi/platform/x86_64-windows/types.conf +52 -0
  519. data/lib/ffi/platform.rb +81 -26
  520. data/lib/ffi/pointer.rb +72 -27
  521. data/lib/ffi/struct.rb +99 -66
  522. data/lib/ffi/struct_by_reference.rb +72 -0
  523. data/lib/ffi/struct_layout.rb +96 -0
  524. data/lib/ffi/struct_layout_builder.rb +82 -17
  525. data/lib/ffi/tools/const_generator.rb +11 -8
  526. data/lib/ffi/tools/generator.rb +48 -1
  527. data/lib/ffi/tools/generator_task.rb +13 -16
  528. data/lib/ffi/tools/struct_generator.rb +6 -5
  529. data/lib/ffi/tools/types_generator.rb +14 -10
  530. data/lib/ffi/types.rb +31 -14
  531. data/lib/ffi/union.rb +23 -12
  532. data/lib/ffi/variadic.rb +25 -21
  533. data/lib/ffi/version.rb +3 -0
  534. data/lib/ffi.rb +20 -8
  535. data/rakelib/ffi_gem_helper.rb +65 -0
  536. data/samples/getlogin.rb +8 -0
  537. data/samples/getpid.rb +8 -0
  538. data/samples/gettimeofday.rb +18 -0
  539. data/samples/hello.rb +8 -0
  540. data/samples/inotify.rb +60 -0
  541. data/samples/pty.rb +75 -0
  542. data/samples/qsort.rb +20 -0
  543. metadata +413 -263
  544. data/History.txt +0 -1
  545. data/README.rdoc +0 -102
  546. data/ext/ffi_c/DataConverter.c +0 -91
  547. data/ext/ffi_c/Ffi_c.iml +0 -12
  548. data/ext/ffi_c/StructByReference.c +0 -158
  549. data/ext/ffi_c/StructByReference.h +0 -50
  550. data/ext/ffi_c/libffi/ChangeLog.libffi +0 -584
  551. data/ext/ffi_c/libffi/ChangeLog.libgcj +0 -40
  552. data/ext/ffi_c/libffi/ChangeLog.v1 +0 -764
  553. data/ext/ffi_c/libffi/Makefile.vc +0 -141
  554. data/ext/ffi_c/libffi/Makefile.vc64 +0 -141
  555. data/ext/ffi_c/libffi/README +0 -342
  556. data/ext/ffi_c/libffi/aclocal.m4 +0 -1873
  557. data/ext/ffi_c/libffi/build-ios.sh +0 -67
  558. data/ext/ffi_c/libffi/compile +0 -143
  559. data/ext/ffi_c/libffi/depcomp +0 -630
  560. data/ext/ffi_c/libffi/doc/libffi.info +0 -593
  561. data/ext/ffi_c/libffi/doc/stamp-vti +0 -4
  562. data/ext/ffi_c/libffi/include/ffi.h.vc +0 -427
  563. data/ext/ffi_c/libffi/m4/ax_check_compiler_flags.m4 +0 -76
  564. data/ext/ffi_c/libffi/m4/libtool.m4 +0 -7831
  565. data/ext/ffi_c/libffi/m4/ltoptions.m4 +0 -369
  566. data/ext/ffi_c/libffi/m4/ltsugar.m4 +0 -123
  567. data/ext/ffi_c/libffi/m4/ltversion.m4 +0 -23
  568. data/ext/ffi_c/libffi/m4/lt~obsolete.m4 +0 -98
  569. data/ext/ffi_c/libffi/mdate-sh +0 -201
  570. data/ext/ffi_c/libffi/src/arm/gentramp.sh +0 -118
  571. data/ext/ffi_c/libffi/src/arm/trampoline.S +0 -4450
  572. data/ext/ffi_c/libffi/src/x86/darwin.S +0 -444
  573. data/ext/ffi_c/libffi/src/x86/darwin64.S +0 -416
  574. data/ext/ffi_c/libffi/src/x86/freebsd.S +0 -458
  575. data/ext/ffi_c/libffi/src/x86/win32.S +0 -1065
  576. data/ext/ffi_c/libffi/testsuite/lib/libffi-dg.exp +0 -300
  577. data/ext/ffi_c/libffi/testsuite/libffi.call/many_win32.c +0 -63
  578. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen_win32.c +0 -44
  579. data/ext/ffi_c/libffi/testsuite/libffi.special/ffitestcxx.h +0 -96
  580. data/ext/ffi_c/libffi/texinfo.tex +0 -7210
  581. data/ext/ffi_c/win32/stdint.h +0 -199
  582. data/gen/Rakefile +0 -30
  583. data/gen/log +0 -1
  584. data/lib/Lib.iml +0 -13
  585. data/spec/ffi/Ffi.iml +0 -12
  586. data/spec/ffi/async_callback_spec.rb +0 -46
  587. data/spec/ffi/bool_spec.rb +0 -40
  588. data/spec/ffi/buffer_spec.rb +0 -215
  589. data/spec/ffi/callback_spec.rb +0 -668
  590. data/spec/ffi/custom_param_type.rb +0 -47
  591. data/spec/ffi/custom_type_spec.rb +0 -85
  592. data/spec/ffi/dup_spec.rb +0 -65
  593. data/spec/ffi/enum_spec.rb +0 -227
  594. data/spec/ffi/errno_spec.rb +0 -29
  595. data/spec/ffi/ffi_spec.rb +0 -40
  596. data/spec/ffi/function_spec.rb +0 -87
  597. data/spec/ffi/library_spec.rb +0 -208
  598. data/spec/ffi/long_double.rb +0 -41
  599. data/spec/ffi/managed_struct_spec.rb +0 -72
  600. data/spec/ffi/number_spec.rb +0 -247
  601. data/spec/ffi/pointer_spec.rb +0 -214
  602. data/spec/ffi/rbx/attach_function_spec.rb +0 -28
  603. data/spec/ffi/rbx/memory_pointer_spec.rb +0 -115
  604. data/spec/ffi/rbx/spec_helper.rb +0 -1
  605. data/spec/ffi/rbx/struct_spec.rb +0 -13
  606. data/spec/ffi/spec_helper.rb +0 -35
  607. data/spec/ffi/string_spec.rb +0 -119
  608. data/spec/ffi/strptr_spec.rb +0 -61
  609. data/spec/ffi/struct_callback_spec.rb +0 -80
  610. data/spec/ffi/struct_initialize_spec.rb +0 -46
  611. data/spec/ffi/struct_packed_spec.rb +0 -62
  612. data/spec/ffi/struct_spec.rb +0 -719
  613. data/spec/ffi/typedef_spec.rb +0 -89
  614. data/spec/ffi/union_spec.rb +0 -76
  615. data/spec/ffi/variadic_spec.rb +0 -103
  616. data/spec/spec.opts +0 -4
  617. data/tasks/ann.rake +0 -80
  618. data/tasks/extension.rake +0 -32
  619. data/tasks/gem.rake +0 -199
  620. data/tasks/git.rake +0 -41
  621. data/tasks/notes.rake +0 -27
  622. data/tasks/post_load.rake +0 -34
  623. data/tasks/rdoc.rake +0 -50
  624. data/tasks/rubyforge.rake +0 -55
  625. data/tasks/setup.rb +0 -301
  626. data/tasks/spec.rake +0 -54
  627. data/tasks/svn.rake +0 -47
  628. data/tasks/test.rake +0 -40
  629. data/tasks/yard.rake +0 -11
@@ -1,5 +1,7 @@
1
1
  /* -----------------------------------------------------------------------
2
- ffi.c - Copyright (C) 2011 Anthony Green
2
+ ffi.c - Copyright (C) 2013 IBM
3
+ Copyright (C) 2011 Anthony Green
4
+ Copyright (C) 2011 Kyle Moffett
3
5
  Copyright (C) 2008 Red Hat, Inc
4
6
  Copyright (C) 2007, 2008 Free Software Foundation, Inc
5
7
  Copyright (c) 1998 Geoffrey Keating
@@ -26,919 +28,122 @@
26
28
  OTHER DEALINGS IN THE SOFTWARE.
27
29
  ----------------------------------------------------------------------- */
28
30
 
29
- #include <ffi.h>
30
- #include <ffi_common.h>
31
-
32
- #include <stdlib.h>
33
- #include <stdio.h>
34
-
35
-
36
- extern void ffi_closure_SYSV (void);
37
- extern void FFI_HIDDEN ffi_closure_LINUX64 (void);
38
-
39
- enum {
40
- /* The assembly depends on these exact flags. */
41
- FLAG_RETURNS_SMST = 1 << (31-31), /* Used for FFI_SYSV small structs. */
42
- FLAG_RETURNS_NOTHING = 1 << (31-30), /* These go in cr7 */
43
- FLAG_RETURNS_FP = 1 << (31-29),
44
- FLAG_RETURNS_64BITS = 1 << (31-28),
45
-
46
- FLAG_RETURNS_128BITS = 1 << (31-27), /* cr6 */
47
- FLAG_SYSV_SMST_R4 = 1 << (31-26), /* use r4 for FFI_SYSV 8 byte
48
- structs. */
49
- FLAG_SYSV_SMST_R3 = 1 << (31-25), /* use r3 for FFI_SYSV 4 byte
50
- structs. */
51
- /* Bits (31-24) through (31-19) store shift value for SMST */
52
-
53
- FLAG_ARG_NEEDS_COPY = 1 << (31- 7),
54
- FLAG_FP_ARGUMENTS = 1 << (31- 6), /* cr1.eq; specified by ABI */
55
- FLAG_4_GPR_ARGUMENTS = 1 << (31- 5),
56
- FLAG_RETVAL_REFERENCE = 1 << (31- 4)
57
- };
58
-
59
- /* About the SYSV ABI. */
60
- unsigned int NUM_GPR_ARG_REGISTERS = 8;
61
- #ifndef __NO_FPRS__
62
- unsigned int NUM_FPR_ARG_REGISTERS = 8;
63
- #else
64
- unsigned int NUM_FPR_ARG_REGISTERS = 0;
65
- #endif
66
-
67
- enum { ASM_NEEDS_REGISTERS = 4 };
68
-
69
- /* ffi_prep_args_SYSV is called by the assembly routine once stack space
70
- has been allocated for the function's arguments.
71
-
72
- The stack layout we want looks like this:
73
-
74
- | Return address from ffi_call_SYSV 4bytes | higher addresses
75
- |--------------------------------------------|
76
- | Previous backchain pointer 4 | stack pointer here
77
- |--------------------------------------------|<+ <<< on entry to
78
- | Saved r28-r31 4*4 | | ffi_call_SYSV
79
- |--------------------------------------------| |
80
- | GPR registers r3-r10 8*4 | | ffi_call_SYSV
81
- |--------------------------------------------| |
82
- | FPR registers f1-f8 (optional) 8*8 | |
83
- |--------------------------------------------| | stack |
84
- | Space for copied structures | | grows |
85
- |--------------------------------------------| | down V
86
- | Parameters that didn't fit in registers | |
87
- |--------------------------------------------| | lower addresses
88
- | Space for callee's LR 4 | |
89
- |--------------------------------------------| | stack pointer here
90
- | Current backchain pointer 4 |-/ during
91
- |--------------------------------------------| <<< ffi_call_SYSV
92
-
93
- */
94
-
95
- void
96
- ffi_prep_args_SYSV (extended_cif *ecif, unsigned *const stack)
97
- {
98
- const unsigned bytes = ecif->cif->bytes;
99
- const unsigned flags = ecif->cif->flags;
100
-
101
- typedef union {
102
- char *c;
103
- unsigned *u;
104
- long long *ll;
105
- float *f;
106
- double *d;
107
- } valp;
108
-
109
- /* 'stacktop' points at the previous backchain pointer. */
110
- valp stacktop;
111
-
112
- /* 'gpr_base' points at the space for gpr3, and grows upwards as
113
- we use GPR registers. */
114
- valp gpr_base;
115
- int intarg_count;
116
-
117
- /* 'fpr_base' points at the space for fpr1, and grows upwards as
118
- we use FPR registers. */
119
- valp fpr_base;
120
- int fparg_count;
121
-
122
- /* 'copy_space' grows down as we put structures in it. It should
123
- stay 16-byte aligned. */
124
- valp copy_space;
125
-
126
- /* 'next_arg' grows up as we put parameters in it. */
127
- valp next_arg;
128
-
129
- int i, ii MAYBE_UNUSED;
130
- ffi_type **ptr;
131
- double double_tmp;
132
- union {
133
- void **v;
134
- char **c;
135
- signed char **sc;
136
- unsigned char **uc;
137
- signed short **ss;
138
- unsigned short **us;
139
- unsigned int **ui;
140
- long long **ll;
141
- float **f;
142
- double **d;
143
- } p_argv;
144
- size_t struct_copy_size;
145
- unsigned gprvalue;
146
-
147
- if (ecif->cif->abi == FFI_LINUX_SOFT_FLOAT)
148
- NUM_FPR_ARG_REGISTERS = 0;
149
-
150
- stacktop.c = (char *) stack + bytes;
151
- gpr_base.u = stacktop.u - ASM_NEEDS_REGISTERS - NUM_GPR_ARG_REGISTERS;
152
- intarg_count = 0;
153
- fpr_base.d = gpr_base.d - NUM_FPR_ARG_REGISTERS;
154
- fparg_count = 0;
155
- copy_space.c = ((flags & FLAG_FP_ARGUMENTS) ? fpr_base.c : gpr_base.c);
156
- next_arg.u = stack + 2;
157
-
158
- /* Check that everything starts aligned properly. */
159
- FFI_ASSERT (((unsigned) (char *) stack & 0xF) == 0);
160
- FFI_ASSERT (((unsigned) copy_space.c & 0xF) == 0);
161
- FFI_ASSERT (((unsigned) stacktop.c & 0xF) == 0);
162
- FFI_ASSERT ((bytes & 0xF) == 0);
163
- FFI_ASSERT (copy_space.c >= next_arg.c);
164
-
165
- /* Deal with return values that are actually pass-by-reference. */
166
- if (flags & FLAG_RETVAL_REFERENCE)
167
- {
168
- *gpr_base.u++ = (unsigned long) (char *) ecif->rvalue;
169
- intarg_count++;
170
- }
171
-
172
- /* Now for the arguments. */
173
- p_argv.v = ecif->avalue;
174
- for (ptr = ecif->cif->arg_types, i = ecif->cif->nargs;
175
- i > 0;
176
- i--, ptr++, p_argv.v++)
177
- {
178
- switch ((*ptr)->type)
179
- {
180
- case FFI_TYPE_FLOAT:
181
- /* With FFI_LINUX_SOFT_FLOAT floats are handled like UINT32. */
182
- if (ecif->cif->abi == FFI_LINUX_SOFT_FLOAT)
183
- goto soft_float_prep;
184
- double_tmp = **p_argv.f;
185
- if (fparg_count >= NUM_FPR_ARG_REGISTERS)
186
- {
187
- *next_arg.f = (float) double_tmp;
188
- next_arg.u += 1;
189
- intarg_count++;
190
- }
191
- else
192
- *fpr_base.d++ = double_tmp;
193
- fparg_count++;
194
- FFI_ASSERT (flags & FLAG_FP_ARGUMENTS);
195
- break;
196
-
197
- case FFI_TYPE_DOUBLE:
198
- /* With FFI_LINUX_SOFT_FLOAT doubles are handled like UINT64. */
199
- if (ecif->cif->abi == FFI_LINUX_SOFT_FLOAT)
200
- goto soft_double_prep;
201
- double_tmp = **p_argv.d;
202
-
203
- if (fparg_count >= NUM_FPR_ARG_REGISTERS)
204
- {
205
- if (intarg_count >= NUM_GPR_ARG_REGISTERS
206
- && intarg_count % 2 != 0)
207
- {
208
- intarg_count++;
209
- next_arg.u++;
210
- }
211
- *next_arg.d = double_tmp;
212
- next_arg.u += 2;
213
- }
214
- else
215
- *fpr_base.d++ = double_tmp;
216
- fparg_count++;
217
- FFI_ASSERT (flags & FLAG_FP_ARGUMENTS);
218
- break;
219
-
220
- #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
221
- case FFI_TYPE_LONGDOUBLE:
222
- if ((ecif->cif->abi != FFI_LINUX)
223
- && (ecif->cif->abi != FFI_LINUX_SOFT_FLOAT))
224
- goto do_struct;
225
- /* The soft float ABI for long doubles works like this,
226
- a long double is passed in four consecutive gprs if available.
227
- A maximum of 2 long doubles can be passed in gprs.
228
- If we do not have 4 gprs left, the long double is passed on the
229
- stack, 4-byte aligned. */
230
- if (ecif->cif->abi == FFI_LINUX_SOFT_FLOAT)
231
- {
232
- unsigned int int_tmp = (*p_argv.ui)[0];
233
- if (intarg_count >= NUM_GPR_ARG_REGISTERS - 3)
234
- {
235
- if (intarg_count < NUM_GPR_ARG_REGISTERS)
236
- intarg_count += NUM_GPR_ARG_REGISTERS - intarg_count;
237
- *next_arg.u = int_tmp;
238
- next_arg.u++;
239
- for (ii = 1; ii < 4; ii++)
240
- {
241
- int_tmp = (*p_argv.ui)[ii];
242
- *next_arg.u = int_tmp;
243
- next_arg.u++;
244
- }
245
- }
246
- else
247
- {
248
- *gpr_base.u++ = int_tmp;
249
- for (ii = 1; ii < 4; ii++)
250
- {
251
- int_tmp = (*p_argv.ui)[ii];
252
- *gpr_base.u++ = int_tmp;
253
- }
254
- }
255
- intarg_count +=4;
256
- }
257
- else
258
- {
259
- double_tmp = (*p_argv.d)[0];
260
-
261
- if (fparg_count >= NUM_FPR_ARG_REGISTERS - 1)
262
- {
263
- if (intarg_count >= NUM_GPR_ARG_REGISTERS
264
- && intarg_count % 2 != 0)
265
- {
266
- intarg_count++;
267
- next_arg.u++;
268
- }
269
- *next_arg.d = double_tmp;
270
- next_arg.u += 2;
271
- double_tmp = (*p_argv.d)[1];
272
- *next_arg.d = double_tmp;
273
- next_arg.u += 2;
274
- }
275
- else
276
- {
277
- *fpr_base.d++ = double_tmp;
278
- double_tmp = (*p_argv.d)[1];
279
- *fpr_base.d++ = double_tmp;
280
- }
281
-
282
- fparg_count += 2;
283
- FFI_ASSERT (flags & FLAG_FP_ARGUMENTS);
284
- }
285
- break;
286
- #endif
287
-
288
- case FFI_TYPE_UINT64:
289
- case FFI_TYPE_SINT64:
290
- soft_double_prep:
291
- if (intarg_count == NUM_GPR_ARG_REGISTERS-1)
292
- intarg_count++;
293
- if (intarg_count >= NUM_GPR_ARG_REGISTERS)
294
- {
295
- if (intarg_count % 2 != 0)
296
- {
297
- intarg_count++;
298
- next_arg.u++;
299
- }
300
- *next_arg.ll = **p_argv.ll;
301
- next_arg.u += 2;
302
- }
303
- else
304
- {
305
- /* whoops: abi states only certain register pairs
306
- * can be used for passing long long int
307
- * specifically (r3,r4), (r5,r6), (r7,r8),
308
- * (r9,r10) and if next arg is long long but
309
- * not correct starting register of pair then skip
310
- * until the proper starting register
311
- */
312
- if (intarg_count % 2 != 0)
313
- {
314
- intarg_count ++;
315
- gpr_base.u++;
316
- }
317
- *gpr_base.ll++ = **p_argv.ll;
318
- }
319
- intarg_count += 2;
320
- break;
321
-
322
- case FFI_TYPE_STRUCT:
323
- #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
324
- do_struct:
325
- #endif
326
- struct_copy_size = ((*ptr)->size + 15) & ~0xF;
327
- copy_space.c -= struct_copy_size;
328
- memcpy (copy_space.c, *p_argv.c, (*ptr)->size);
329
-
330
- gprvalue = (unsigned long) copy_space.c;
331
-
332
- FFI_ASSERT (copy_space.c > next_arg.c);
333
- FFI_ASSERT (flags & FLAG_ARG_NEEDS_COPY);
334
- goto putgpr;
335
-
336
- case FFI_TYPE_UINT8:
337
- gprvalue = **p_argv.uc;
338
- goto putgpr;
339
- case FFI_TYPE_SINT8:
340
- gprvalue = **p_argv.sc;
341
- goto putgpr;
342
- case FFI_TYPE_UINT16:
343
- gprvalue = **p_argv.us;
344
- goto putgpr;
345
- case FFI_TYPE_SINT16:
346
- gprvalue = **p_argv.ss;
347
- goto putgpr;
348
-
349
- case FFI_TYPE_INT:
350
- case FFI_TYPE_UINT32:
351
- case FFI_TYPE_SINT32:
352
- case FFI_TYPE_POINTER:
353
- soft_float_prep:
354
-
355
- gprvalue = **p_argv.ui;
356
-
357
- putgpr:
358
- if (intarg_count >= NUM_GPR_ARG_REGISTERS)
359
- *next_arg.u++ = gprvalue;
360
- else
361
- *gpr_base.u++ = gprvalue;
362
- intarg_count++;
363
- break;
364
- }
365
- }
366
-
367
- /* Check that we didn't overrun the stack... */
368
- FFI_ASSERT (copy_space.c >= next_arg.c);
369
- FFI_ASSERT (gpr_base.u <= stacktop.u - ASM_NEEDS_REGISTERS);
370
- FFI_ASSERT (fpr_base.u
371
- <= stacktop.u - ASM_NEEDS_REGISTERS - NUM_GPR_ARG_REGISTERS);
372
- FFI_ASSERT (flags & FLAG_4_GPR_ARGUMENTS || intarg_count <= 4);
373
- }
374
-
375
- /* About the LINUX64 ABI. */
376
- enum {
377
- NUM_GPR_ARG_REGISTERS64 = 8,
378
- NUM_FPR_ARG_REGISTERS64 = 13
379
- };
380
- enum { ASM_NEEDS_REGISTERS64 = 4 };
381
-
382
- /* ffi_prep_args64 is called by the assembly routine once stack space
383
- has been allocated for the function's arguments.
384
-
385
- The stack layout we want looks like this:
386
-
387
- | Ret addr from ffi_call_LINUX64 8bytes | higher addresses
388
- |--------------------------------------------|
389
- | CR save area 8bytes |
390
- |--------------------------------------------|
391
- | Previous backchain pointer 8 | stack pointer here
392
- |--------------------------------------------|<+ <<< on entry to
393
- | Saved r28-r31 4*8 | | ffi_call_LINUX64
394
- |--------------------------------------------| |
395
- | GPR registers r3-r10 8*8 | |
396
- |--------------------------------------------| |
397
- | FPR registers f1-f13 (optional) 13*8 | |
398
- |--------------------------------------------| |
399
- | Parameter save area | |
400
- |--------------------------------------------| |
401
- | TOC save area 8 | |
402
- |--------------------------------------------| | stack |
403
- | Linker doubleword 8 | | grows |
404
- |--------------------------------------------| | down V
405
- | Compiler doubleword 8 | |
406
- |--------------------------------------------| | lower addresses
407
- | Space for callee's LR 8 | |
408
- |--------------------------------------------| |
409
- | CR save area 8 | |
410
- |--------------------------------------------| | stack pointer here
411
- | Current backchain pointer 8 |-/ during
412
- |--------------------------------------------| <<< ffi_call_LINUX64
413
-
414
- */
31
+ #include "ffi.h"
32
+ #include "ffi_common.h"
33
+ #include "ffi_powerpc.h"
415
34
 
35
+ #if HAVE_LONG_DOUBLE_VARIANT
36
+ /* Adjust ffi_type_longdouble. */
416
37
  void FFI_HIDDEN
417
- ffi_prep_args64 (extended_cif *ecif, unsigned long *const stack)
38
+ ffi_prep_types (ffi_abi abi)
418
39
  {
419
- const unsigned long bytes = ecif->cif->bytes;
420
- const unsigned long flags = ecif->cif->flags;
421
-
422
- typedef union {
423
- char *c;
424
- unsigned long *ul;
425
- float *f;
426
- double *d;
427
- } valp;
428
-
429
- /* 'stacktop' points at the previous backchain pointer. */
430
- valp stacktop;
431
-
432
- /* 'next_arg' points at the space for gpr3, and grows upwards as
433
- we use GPR registers, then continues at rest. */
434
- valp gpr_base;
435
- valp gpr_end;
436
- valp rest;
437
- valp next_arg;
438
-
439
- /* 'fpr_base' points at the space for fpr3, and grows upwards as
440
- we use FPR registers. */
441
- valp fpr_base;
442
- int fparg_count;
443
-
444
- int i, words;
445
- ffi_type **ptr;
446
- double double_tmp;
447
- union {
448
- void **v;
449
- char **c;
450
- signed char **sc;
451
- unsigned char **uc;
452
- signed short **ss;
453
- unsigned short **us;
454
- signed int **si;
455
- unsigned int **ui;
456
- unsigned long **ul;
457
- float **f;
458
- double **d;
459
- } p_argv;
460
- unsigned long gprvalue;
461
-
462
- stacktop.c = (char *) stack + bytes;
463
- gpr_base.ul = stacktop.ul - ASM_NEEDS_REGISTERS64 - NUM_GPR_ARG_REGISTERS64;
464
- gpr_end.ul = gpr_base.ul + NUM_GPR_ARG_REGISTERS64;
465
- rest.ul = stack + 6 + NUM_GPR_ARG_REGISTERS64;
466
- fpr_base.d = gpr_base.d - NUM_FPR_ARG_REGISTERS64;
467
- fparg_count = 0;
468
- next_arg.ul = gpr_base.ul;
469
-
470
- /* Check that everything starts aligned properly. */
471
- FFI_ASSERT (((unsigned long) (char *) stack & 0xF) == 0);
472
- FFI_ASSERT (((unsigned long) stacktop.c & 0xF) == 0);
473
- FFI_ASSERT ((bytes & 0xF) == 0);
474
-
475
- /* Deal with return values that are actually pass-by-reference. */
476
- if (flags & FLAG_RETVAL_REFERENCE)
477
- *next_arg.ul++ = (unsigned long) (char *) ecif->rvalue;
478
-
479
- /* Now for the arguments. */
480
- p_argv.v = ecif->avalue;
481
- for (ptr = ecif->cif->arg_types, i = ecif->cif->nargs;
482
- i > 0;
483
- i--, ptr++, p_argv.v++)
484
- {
485
- switch ((*ptr)->type)
486
- {
487
- case FFI_TYPE_FLOAT:
488
- double_tmp = **p_argv.f;
489
- *next_arg.f = (float) double_tmp;
490
- if (++next_arg.ul == gpr_end.ul)
491
- next_arg.ul = rest.ul;
492
- if (fparg_count < NUM_FPR_ARG_REGISTERS64)
493
- *fpr_base.d++ = double_tmp;
494
- fparg_count++;
495
- FFI_ASSERT (flags & FLAG_FP_ARGUMENTS);
496
- break;
497
-
498
- case FFI_TYPE_DOUBLE:
499
- double_tmp = **p_argv.d;
500
- *next_arg.d = double_tmp;
501
- if (++next_arg.ul == gpr_end.ul)
502
- next_arg.ul = rest.ul;
503
- if (fparg_count < NUM_FPR_ARG_REGISTERS64)
504
- *fpr_base.d++ = double_tmp;
505
- fparg_count++;
506
- FFI_ASSERT (flags & FLAG_FP_ARGUMENTS);
507
- break;
508
-
509
- #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
510
- case FFI_TYPE_LONGDOUBLE:
511
- double_tmp = (*p_argv.d)[0];
512
- *next_arg.d = double_tmp;
513
- if (++next_arg.ul == gpr_end.ul)
514
- next_arg.ul = rest.ul;
515
- if (fparg_count < NUM_FPR_ARG_REGISTERS64)
516
- *fpr_base.d++ = double_tmp;
517
- fparg_count++;
518
- double_tmp = (*p_argv.d)[1];
519
- *next_arg.d = double_tmp;
520
- if (++next_arg.ul == gpr_end.ul)
521
- next_arg.ul = rest.ul;
522
- if (fparg_count < NUM_FPR_ARG_REGISTERS64)
523
- *fpr_base.d++ = double_tmp;
524
- fparg_count++;
525
- FFI_ASSERT (__LDBL_MANT_DIG__ == 106);
526
- FFI_ASSERT (flags & FLAG_FP_ARGUMENTS);
527
- break;
528
- #endif
529
-
530
- case FFI_TYPE_STRUCT:
531
- words = ((*ptr)->size + 7) / 8;
532
- if (next_arg.ul >= gpr_base.ul && next_arg.ul + words > gpr_end.ul)
533
- {
534
- size_t first = gpr_end.c - next_arg.c;
535
- memcpy (next_arg.c, *p_argv.c, first);
536
- memcpy (rest.c, *p_argv.c + first, (*ptr)->size - first);
537
- next_arg.c = rest.c + words * 8 - first;
538
- }
539
- else
540
- {
541
- char *where = next_arg.c;
542
-
543
- /* Structures with size less than eight bytes are passed
544
- left-padded. */
545
- if ((*ptr)->size < 8)
546
- where += 8 - (*ptr)->size;
547
-
548
- memcpy (where, *p_argv.c, (*ptr)->size);
549
- next_arg.ul += words;
550
- if (next_arg.ul == gpr_end.ul)
551
- next_arg.ul = rest.ul;
552
- }
553
- break;
554
-
555
- case FFI_TYPE_UINT8:
556
- gprvalue = **p_argv.uc;
557
- goto putgpr;
558
- case FFI_TYPE_SINT8:
559
- gprvalue = **p_argv.sc;
560
- goto putgpr;
561
- case FFI_TYPE_UINT16:
562
- gprvalue = **p_argv.us;
563
- goto putgpr;
564
- case FFI_TYPE_SINT16:
565
- gprvalue = **p_argv.ss;
566
- goto putgpr;
567
- case FFI_TYPE_UINT32:
568
- gprvalue = **p_argv.ui;
569
- goto putgpr;
570
- case FFI_TYPE_INT:
571
- case FFI_TYPE_SINT32:
572
- gprvalue = **p_argv.si;
573
- goto putgpr;
574
-
575
- case FFI_TYPE_UINT64:
576
- case FFI_TYPE_SINT64:
577
- case FFI_TYPE_POINTER:
578
- gprvalue = **p_argv.ul;
579
- putgpr:
580
- *next_arg.ul++ = gprvalue;
581
- if (next_arg.ul == gpr_end.ul)
582
- next_arg.ul = rest.ul;
583
- break;
584
- }
585
- }
586
-
587
- FFI_ASSERT (flags & FLAG_4_GPR_ARGUMENTS
588
- || (next_arg.ul >= gpr_base.ul
589
- && next_arg.ul <= gpr_base.ul + 4));
40
+ # if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
41
+ # ifdef POWERPC64
42
+ ffi_prep_types_linux64 (abi);
43
+ # else
44
+ ffi_prep_types_sysv (abi);
45
+ # endif
46
+ # endif
590
47
  }
591
-
592
-
48
+ #endif
593
49
 
594
50
  /* Perform machine dependent cif processing */
595
- ffi_status
51
+ ffi_status FFI_HIDDEN
596
52
  ffi_prep_cif_machdep (ffi_cif *cif)
597
53
  {
598
- /* All this is for the SYSV and LINUX64 ABI. */
599
- int i;
600
- ffi_type **ptr;
601
- unsigned bytes;
602
- int fparg_count = 0, intarg_count = 0;
603
- unsigned flags = 0;
604
- unsigned struct_copy_size = 0;
605
- unsigned type = cif->rtype->type;
606
- unsigned size = cif->rtype->size;
607
-
608
- if (cif->abi == FFI_LINUX_SOFT_FLOAT)
609
- NUM_FPR_ARG_REGISTERS = 0;
610
-
611
- if (cif->abi != FFI_LINUX64)
612
- {
613
- /* All the machine-independent calculation of cif->bytes will be wrong.
614
- Redo the calculation for SYSV. */
615
-
616
- /* Space for the frame pointer, callee's LR, and the asm's temp regs. */
617
- bytes = (2 + ASM_NEEDS_REGISTERS) * sizeof (int);
618
-
619
- /* Space for the GPR registers. */
620
- bytes += NUM_GPR_ARG_REGISTERS * sizeof (int);
621
- }
622
- else
623
- {
624
- /* 64-bit ABI. */
625
-
626
- /* Space for backchain, CR, LR, cc/ld doubleword, TOC and the asm's temp
627
- regs. */
628
- bytes = (6 + ASM_NEEDS_REGISTERS64) * sizeof (long);
629
-
630
- /* Space for the mandatory parm save area and general registers. */
631
- bytes += 2 * NUM_GPR_ARG_REGISTERS64 * sizeof (long);
632
- }
633
-
634
- /* Return value handling. The rules for SYSV are as follows:
635
- - 32-bit (or less) integer values are returned in gpr3;
636
- - Structures of size <= 4 bytes also returned in gpr3;
637
- - 64-bit integer values and structures between 5 and 8 bytes are returned
638
- in gpr3 and gpr4;
639
- - Single/double FP values are returned in fpr1;
640
- - Larger structures are allocated space and a pointer is passed as
641
- the first argument.
642
- - long doubles (if not equivalent to double) are returned in
643
- fpr1,fpr2 for Linux and as for large structs for SysV.
644
- For LINUX64:
645
- - integer values in gpr3;
646
- - Structures/Unions by reference;
647
- - Single/double FP values in fpr1, long double in fpr1,fpr2.
648
- - soft-float float/doubles are treated as UINT32/UINT64 respectivley.
649
- - soft-float long doubles are returned in gpr3-gpr6. */
650
- switch (type)
651
- {
652
- #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
653
- case FFI_TYPE_LONGDOUBLE:
654
- if (cif->abi != FFI_LINUX && cif->abi != FFI_LINUX64
655
- && cif->abi != FFI_LINUX_SOFT_FLOAT)
656
- goto byref;
657
- flags |= FLAG_RETURNS_128BITS;
658
- /* Fall through. */
659
- #endif
660
- case FFI_TYPE_DOUBLE:
661
- flags |= FLAG_RETURNS_64BITS;
662
- /* Fall through. */
663
- case FFI_TYPE_FLOAT:
664
- /* With FFI_LINUX_SOFT_FLOAT no fp registers are used. */
665
- if (cif->abi != FFI_LINUX_SOFT_FLOAT)
666
- flags |= FLAG_RETURNS_FP;
667
- break;
668
-
669
- case FFI_TYPE_UINT64:
670
- case FFI_TYPE_SINT64:
671
- flags |= FLAG_RETURNS_64BITS;
672
- break;
673
-
674
- case FFI_TYPE_STRUCT:
675
- if (cif->abi == FFI_SYSV)
676
- {
677
- /* The final SYSV ABI says that structures smaller or equal 8 bytes
678
- are returned in r3/r4. The FFI_GCC_SYSV ABI instead returns them
679
- in memory. */
680
-
681
- /* Treat structs with size <= 8 bytes. */
682
- if (size <= 8)
683
- {
684
- flags |= FLAG_RETURNS_SMST;
685
- /* These structs are returned in r3. We pack the type and the
686
- precalculated shift value (needed in the sysv.S) into flags.
687
- The same applies for the structs returned in r3/r4. */
688
- if (size <= 4)
689
- {
690
- flags |= FLAG_SYSV_SMST_R3;
691
- flags |= 8 * (4 - size) << 8;
692
- break;
693
- }
694
- /* These structs are returned in r3 and r4. See above. */
695
- if (size <= 8)
696
- {
697
- flags |= FLAG_SYSV_SMST_R3 | FLAG_SYSV_SMST_R4;
698
- flags |= 8 * (8 - size) << 8;
699
- break;
700
- }
701
- }
702
- }
703
- #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
704
- byref:
705
- #endif
706
- intarg_count++;
707
- flags |= FLAG_RETVAL_REFERENCE;
708
- /* Fall through. */
709
- case FFI_TYPE_VOID:
710
- flags |= FLAG_RETURNS_NOTHING;
711
- break;
712
-
713
- default:
714
- /* Returns 32-bit integer, or similar. Nothing to do here. */
715
- break;
716
- }
717
-
718
- if (cif->abi != FFI_LINUX64)
719
- /* The first NUM_GPR_ARG_REGISTERS words of integer arguments, and the
720
- first NUM_FPR_ARG_REGISTERS fp arguments, go in registers; the rest
721
- goes on the stack. Structures and long doubles (if not equivalent
722
- to double) are passed as a pointer to a copy of the structure.
723
- Stuff on the stack needs to keep proper alignment. */
724
- for (ptr = cif->arg_types, i = cif->nargs; i > 0; i--, ptr++)
725
- {
726
- switch ((*ptr)->type)
727
- {
728
- case FFI_TYPE_FLOAT:
729
- /* With FFI_LINUX_SOFT_FLOAT floats are handled like UINT32. */
730
- if (cif->abi == FFI_LINUX_SOFT_FLOAT)
731
- goto soft_float_cif;
732
- fparg_count++;
733
- /* floating singles are not 8-aligned on stack */
734
- break;
735
-
736
- #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
737
- case FFI_TYPE_LONGDOUBLE:
738
- if (cif->abi != FFI_LINUX && cif->abi != FFI_LINUX_SOFT_FLOAT)
739
- goto do_struct;
740
- if (cif->abi == FFI_LINUX_SOFT_FLOAT)
741
- {
742
- if (intarg_count >= NUM_GPR_ARG_REGISTERS - 3
743
- || intarg_count < NUM_GPR_ARG_REGISTERS)
744
- /* A long double in FFI_LINUX_SOFT_FLOAT can use only
745
- a set of four consecutive gprs. If we have not enough,
746
- we have to adjust the intarg_count value. */
747
- intarg_count += NUM_GPR_ARG_REGISTERS - intarg_count;
748
- intarg_count += 4;
749
- break;
750
- }
751
- else
752
- fparg_count++;
753
- /* Fall thru */
754
- #endif
755
- case FFI_TYPE_DOUBLE:
756
- /* With FFI_LINUX_SOFT_FLOAT doubles are handled like UINT64. */
757
- if (cif->abi == FFI_LINUX_SOFT_FLOAT)
758
- goto soft_double_cif;
759
- fparg_count++;
760
- /* If this FP arg is going on the stack, it must be
761
- 8-byte-aligned. */
762
- if (fparg_count > NUM_FPR_ARG_REGISTERS
763
- && intarg_count >= NUM_GPR_ARG_REGISTERS
764
- && intarg_count % 2 != 0)
765
- intarg_count++;
766
- break;
767
-
768
- case FFI_TYPE_UINT64:
769
- case FFI_TYPE_SINT64:
770
- soft_double_cif:
771
- /* 'long long' arguments are passed as two words, but
772
- either both words must fit in registers or both go
773
- on the stack. If they go on the stack, they must
774
- be 8-byte-aligned.
775
-
776
- Also, only certain register pairs can be used for
777
- passing long long int -- specifically (r3,r4), (r5,r6),
778
- (r7,r8), (r9,r10).
779
- */
780
- if (intarg_count == NUM_GPR_ARG_REGISTERS-1
781
- || intarg_count % 2 != 0)
782
- intarg_count++;
783
- intarg_count += 2;
784
- break;
785
-
786
- case FFI_TYPE_STRUCT:
787
- #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
788
- do_struct:
54
+ #ifdef POWERPC64
55
+ return ffi_prep_cif_linux64 (cif);
56
+ #else
57
+ return ffi_prep_cif_sysv (cif);
789
58
  #endif
790
- /* We must allocate space for a copy of these to enforce
791
- pass-by-value. Pad the space up to a multiple of 16
792
- bytes (the maximum alignment required for anything under
793
- the SYSV ABI). */
794
- struct_copy_size += ((*ptr)->size + 15) & ~0xF;
795
- /* Fall through (allocate space for the pointer). */
59
+ }
796
60
 
797
- default:
798
- soft_float_cif:
799
- /* Everything else is passed as a 4-byte word in a GPR, either
800
- the object itself or a pointer to it. */
801
- intarg_count++;
802
- break;
803
- }
804
- }
805
- else
806
- for (ptr = cif->arg_types, i = cif->nargs; i > 0; i--, ptr++)
807
- {
808
- switch ((*ptr)->type)
809
- {
810
- #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
811
- case FFI_TYPE_LONGDOUBLE:
812
- if (cif->abi == FFI_LINUX_SOFT_FLOAT)
813
- intarg_count += 4;
814
- else
815
- {
816
- fparg_count += 2;
817
- intarg_count += 2;
818
- }
819
- break;
61
+ ffi_status FFI_HIDDEN
62
+ ffi_prep_cif_machdep_var (ffi_cif *cif,
63
+ unsigned int nfixedargs MAYBE_UNUSED,
64
+ unsigned int ntotalargs MAYBE_UNUSED)
65
+ {
66
+ #ifdef POWERPC64
67
+ return ffi_prep_cif_linux64_var (cif, nfixedargs, ntotalargs);
68
+ #else
69
+ return ffi_prep_cif_sysv (cif);
820
70
  #endif
821
- case FFI_TYPE_FLOAT:
822
- case FFI_TYPE_DOUBLE:
823
- fparg_count++;
824
- intarg_count++;
825
- break;
826
-
827
- case FFI_TYPE_STRUCT:
828
- intarg_count += ((*ptr)->size + 7) / 8;
829
- break;
830
-
831
- default:
832
- /* Everything else is passed as a 8-byte word in a GPR, either
833
- the object itself or a pointer to it. */
834
- intarg_count++;
835
- break;
836
- }
837
- }
838
-
839
- if (fparg_count != 0)
840
- flags |= FLAG_FP_ARGUMENTS;
841
- if (intarg_count > 4)
842
- flags |= FLAG_4_GPR_ARGUMENTS;
843
- if (struct_copy_size != 0)
844
- flags |= FLAG_ARG_NEEDS_COPY;
845
-
846
- if (cif->abi != FFI_LINUX64)
847
- {
848
- /* Space for the FPR registers, if needed. */
849
- if (fparg_count != 0)
850
- bytes += NUM_FPR_ARG_REGISTERS * sizeof (double);
851
-
852
- /* Stack space. */
853
- if (intarg_count > NUM_GPR_ARG_REGISTERS)
854
- bytes += (intarg_count - NUM_GPR_ARG_REGISTERS) * sizeof (int);
855
- if (fparg_count > NUM_FPR_ARG_REGISTERS)
856
- bytes += (fparg_count - NUM_FPR_ARG_REGISTERS) * sizeof (double);
857
- }
858
- else
859
- {
860
- /* Space for the FPR registers, if needed. */
861
- if (fparg_count != 0)
862
- bytes += NUM_FPR_ARG_REGISTERS64 * sizeof (double);
863
-
864
- /* Stack space. */
865
- if (intarg_count > NUM_GPR_ARG_REGISTERS64)
866
- bytes += (intarg_count - NUM_GPR_ARG_REGISTERS64) * sizeof (long);
867
- }
868
-
869
- /* The stack space allocated needs to be a multiple of 16 bytes. */
870
- bytes = (bytes + 15) & ~0xF;
871
-
872
- /* Add in the space for the copied structures. */
873
- bytes += struct_copy_size;
874
-
875
- cif->flags = flags;
876
- cif->bytes = bytes;
877
-
878
- return FFI_OK;
879
71
  }
880
72
 
881
- extern void ffi_call_SYSV(extended_cif *, unsigned, unsigned, unsigned *,
882
- void (*fn)(void));
883
- extern void FFI_HIDDEN ffi_call_LINUX64(extended_cif *, unsigned long,
884
- unsigned long, unsigned long *,
885
- void (*fn)(void));
886
-
887
- void
888
- ffi_call(ffi_cif *cif, void (*fn)(void), void *rvalue, void **avalue)
73
+ static void
74
+ ffi_call_int (ffi_cif *cif,
75
+ void (*fn) (void),
76
+ void *rvalue,
77
+ void **avalue,
78
+ void *closure)
889
79
  {
80
+ /* The final SYSV ABI says that structures smaller or equal 8 bytes
81
+ are returned in r3/r4. A draft ABI used by linux instead returns
82
+ them in memory.
83
+
84
+ We bounce-buffer SYSV small struct return values so that sysv.S
85
+ can write r3 and r4 to memory without worrying about struct size.
86
+
87
+ For ELFv2 ABI, use a bounce buffer for homogeneous structs too,
88
+ for similar reasons. This bounce buffer must be aligned to 16
89
+ bytes for use with homogeneous structs of vectors (float128). */
90
+ float128 smst_buffer[8];
890
91
  extended_cif ecif;
891
92
 
892
93
  ecif.cif = cif;
893
94
  ecif.avalue = avalue;
894
95
 
895
- /* If the return value is a struct and we don't have a return */
896
- /* value address then we need to make one */
96
+ ecif.rvalue = rvalue;
97
+ if ((cif->flags & FLAG_RETURNS_SMST) != 0)
98
+ ecif.rvalue = smst_buffer;
99
+ /* Ensure that we have a valid struct return value.
100
+ FIXME: Isn't this just papering over a user problem? */
101
+ else if (!rvalue && cif->rtype->type == FFI_TYPE_STRUCT)
102
+ ecif.rvalue = alloca (cif->rtype->size);
897
103
 
898
- if ((rvalue == NULL) && (cif->rtype->type == FFI_TYPE_STRUCT))
899
- {
900
- ecif.rvalue = alloca(cif->rtype->size);
901
- }
902
- else
903
- ecif.rvalue = rvalue;
904
-
905
-
906
- switch (cif->abi)
907
- {
908
- #ifndef POWERPC64
909
- case FFI_SYSV:
910
- case FFI_GCC_SYSV:
911
- case FFI_LINUX:
912
- case FFI_LINUX_SOFT_FLOAT:
913
- ffi_call_SYSV (&ecif, -cif->bytes, cif->flags, ecif.rvalue, fn);
914
- break;
104
+ #ifdef POWERPC64
105
+ ffi_call_LINUX64 (&ecif, fn, ecif.rvalue, cif->flags, closure,
106
+ -(long) cif->bytes);
915
107
  #else
916
- case FFI_LINUX64:
917
- ffi_call_LINUX64 (&ecif, -(long) cif->bytes, cif->flags, ecif.rvalue, fn);
918
- break;
919
- #endif
920
- default:
921
- FFI_ASSERT (0);
922
- break;
108
+ ffi_call_SYSV (&ecif, fn, ecif.rvalue, cif->flags, closure, -cif->bytes);
109
+ #endif
110
+
111
+ /* Check for a bounce-buffered return value */
112
+ if (rvalue && ecif.rvalue == smst_buffer)
113
+ {
114
+ unsigned int rsize = cif->rtype->size;
115
+ #ifndef __LITTLE_ENDIAN__
116
+ /* The SYSV ABI returns a structure of up to 4 bytes in size
117
+ left-padded in r3. */
118
+ # ifndef POWERPC64
119
+ if (rsize <= 4)
120
+ memcpy (rvalue, (char *) smst_buffer + 4 - rsize, rsize);
121
+ else
122
+ # endif
123
+ /* The SYSV ABI returns a structure of up to 8 bytes in size
124
+ left-padded in r3/r4, and the ELFv2 ABI similarly returns a
125
+ structure of up to 8 bytes in size left-padded in r3. But
126
+ note that a structure of a single float is not paddded. */
127
+ if (rsize <= 8 && (cif->flags & FLAG_RETURNS_FP) == 0)
128
+ memcpy (rvalue, (char *) smst_buffer + 8 - rsize, rsize);
129
+ else
130
+ #endif
131
+ memcpy (rvalue, smst_buffer, rsize);
923
132
  }
924
133
  }
925
134
 
135
+ void
136
+ ffi_call (ffi_cif *cif, void (*fn) (void), void *rvalue, void **avalue)
137
+ {
138
+ ffi_call_int (cif, fn, rvalue, avalue, NULL);
139
+ }
926
140
 
927
- #ifndef POWERPC64
928
- #define MIN_CACHE_LINE_SIZE 8
929
-
930
- static void
931
- flush_icache (char *wraddr, char *xaddr, int size)
141
+ void
142
+ ffi_call_go (ffi_cif *cif, void (*fn) (void), void *rvalue, void **avalue,
143
+ void *closure)
932
144
  {
933
- int i;
934
- for (i = 0; i < size; i += MIN_CACHE_LINE_SIZE)
935
- __asm__ volatile ("icbi 0,%0;" "dcbf 0,%1;"
936
- : : "r" (xaddr + i), "r" (wraddr + i) : "memory");
937
- __asm__ volatile ("icbi 0,%0;" "dcbf 0,%1;" "sync;" "isync;"
938
- : : "r"(xaddr + size - 1), "r"(wraddr + size - 1)
939
- : "memory");
145
+ ffi_call_int (cif, fn, rvalue, avalue, closure);
940
146
  }
941
- #endif
942
147
 
943
148
  ffi_status
944
149
  ffi_prep_closure_loc (ffi_closure *closure,
@@ -948,501 +153,23 @@ ffi_prep_closure_loc (ffi_closure *closure,
948
153
  void *codeloc)
949
154
  {
950
155
  #ifdef POWERPC64
951
- void **tramp = (void **) &closure->tramp[0];
952
-
953
- if (cif->abi != FFI_LINUX64)
954
- return FFI_BAD_ABI;
955
- /* Copy function address and TOC from ffi_closure_LINUX64. */
956
- memcpy (tramp, (char *) ffi_closure_LINUX64, 16);
957
- tramp[2] = codeloc;
156
+ return ffi_prep_closure_loc_linux64 (closure, cif, fun, user_data, codeloc);
958
157
  #else
959
- unsigned int *tramp;
960
-
961
- if (! (cif->abi == FFI_GCC_SYSV
962
- || cif->abi == FFI_SYSV
963
- || cif->abi == FFI_LINUX
964
- || cif->abi == FFI_LINUX_SOFT_FLOAT))
965
- return FFI_BAD_ABI;
966
-
967
- tramp = (unsigned int *) &closure->tramp[0];
968
- tramp[0] = 0x7c0802a6; /* mflr r0 */
969
- tramp[1] = 0x4800000d; /* bl 10 <trampoline_initial+0x10> */
970
- tramp[4] = 0x7d6802a6; /* mflr r11 */
971
- tramp[5] = 0x7c0803a6; /* mtlr r0 */
972
- tramp[6] = 0x800b0000; /* lwz r0,0(r11) */
973
- tramp[7] = 0x816b0004; /* lwz r11,4(r11) */
974
- tramp[8] = 0x7c0903a6; /* mtctr r0 */
975
- tramp[9] = 0x4e800420; /* bctr */
976
- *(void **) &tramp[2] = (void *) ffi_closure_SYSV; /* function */
977
- *(void **) &tramp[3] = codeloc; /* context */
978
-
979
- /* Flush the icache. */
980
- flush_icache ((char *)tramp, (char *)codeloc, FFI_TRAMPOLINE_SIZE);
981
- #endif
982
-
983
- closure->cif = cif;
984
- closure->fun = fun;
985
- closure->user_data = user_data;
986
-
987
- return FFI_OK;
988
- }
989
-
990
- typedef union
991
- {
992
- float f;
993
- double d;
994
- } ffi_dblfl;
995
-
996
- int ffi_closure_helper_SYSV (ffi_closure *, void *, unsigned long *,
997
- ffi_dblfl *, unsigned long *);
998
-
999
- /* Basically the trampoline invokes ffi_closure_SYSV, and on
1000
- * entry, r11 holds the address of the closure.
1001
- * After storing the registers that could possibly contain
1002
- * parameters to be passed into the stack frame and setting
1003
- * up space for a return value, ffi_closure_SYSV invokes the
1004
- * following helper function to do most of the work
1005
- */
1006
-
1007
- int
1008
- ffi_closure_helper_SYSV (ffi_closure *closure, void *rvalue,
1009
- unsigned long *pgr, ffi_dblfl *pfr,
1010
- unsigned long *pst)
1011
- {
1012
- /* rvalue is the pointer to space for return value in closure assembly */
1013
- /* pgr is the pointer to where r3-r10 are stored in ffi_closure_SYSV */
1014
- /* pfr is the pointer to where f1-f8 are stored in ffi_closure_SYSV */
1015
- /* pst is the pointer to outgoing parameter stack in original caller */
1016
-
1017
- void ** avalue;
1018
- ffi_type ** arg_types;
1019
- long i, avn;
1020
- long nf; /* number of floating registers already used */
1021
- long ng; /* number of general registers already used */
1022
- ffi_cif * cif;
1023
- double temp;
1024
- unsigned size;
1025
-
1026
- cif = closure->cif;
1027
- avalue = alloca (cif->nargs * sizeof (void *));
1028
- size = cif->rtype->size;
1029
-
1030
- nf = 0;
1031
- ng = 0;
1032
-
1033
- /* Copy the caller's structure return value address so that the closure
1034
- returns the data directly to the caller.
1035
- For FFI_SYSV the result is passed in r3/r4 if the struct size is less
1036
- or equal 8 bytes. */
1037
-
1038
- if ((cif->rtype->type == FFI_TYPE_STRUCT
1039
- && !((cif->abi == FFI_SYSV) && (size <= 8)))
1040
- #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
1041
- || (cif->rtype->type == FFI_TYPE_LONGDOUBLE
1042
- && cif->abi != FFI_LINUX && cif->abi != FFI_LINUX_SOFT_FLOAT)
1043
- #endif
1044
- )
1045
- {
1046
- rvalue = (void *) *pgr;
1047
- ng++;
1048
- pgr++;
1049
- }
1050
-
1051
- i = 0;
1052
- avn = cif->nargs;
1053
- arg_types = cif->arg_types;
1054
-
1055
- /* Grab the addresses of the arguments from the stack frame. */
1056
- while (i < avn)
1057
- {
1058
- switch (arg_types[i]->type)
1059
- {
1060
- case FFI_TYPE_SINT8:
1061
- case FFI_TYPE_UINT8:
1062
- /* there are 8 gpr registers used to pass values */
1063
- if (ng < 8)
1064
- {
1065
- avalue[i] = (char *) pgr + 3;
1066
- ng++;
1067
- pgr++;
1068
- }
1069
- else
1070
- {
1071
- avalue[i] = (char *) pst + 3;
1072
- pst++;
1073
- }
1074
- break;
1075
-
1076
- case FFI_TYPE_SINT16:
1077
- case FFI_TYPE_UINT16:
1078
- /* there are 8 gpr registers used to pass values */
1079
- if (ng < 8)
1080
- {
1081
- avalue[i] = (char *) pgr + 2;
1082
- ng++;
1083
- pgr++;
1084
- }
1085
- else
1086
- {
1087
- avalue[i] = (char *) pst + 2;
1088
- pst++;
1089
- }
1090
- break;
1091
-
1092
- case FFI_TYPE_SINT32:
1093
- case FFI_TYPE_UINT32:
1094
- case FFI_TYPE_POINTER:
1095
- soft_float_closure:
1096
- /* there are 8 gpr registers used to pass values */
1097
- if (ng < 8)
1098
- {
1099
- avalue[i] = pgr;
1100
- ng++;
1101
- pgr++;
1102
- }
1103
- else
1104
- {
1105
- avalue[i] = pst;
1106
- pst++;
1107
- }
1108
- break;
1109
-
1110
- case FFI_TYPE_STRUCT:
1111
- #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
1112
- do_struct:
1113
- #endif
1114
- /* Structs are passed by reference. The address will appear in a
1115
- gpr if it is one of the first 8 arguments. */
1116
- if (ng < 8)
1117
- {
1118
- avalue[i] = (void *) *pgr;
1119
- ng++;
1120
- pgr++;
1121
- }
1122
- else
1123
- {
1124
- avalue[i] = (void *) *pst;
1125
- pst++;
1126
- }
1127
- break;
1128
-
1129
- case FFI_TYPE_SINT64:
1130
- case FFI_TYPE_UINT64:
1131
- soft_double_closure:
1132
- /* passing long long ints are complex, they must
1133
- * be passed in suitable register pairs such as
1134
- * (r3,r4) or (r5,r6) or (r6,r7), or (r7,r8) or (r9,r10)
1135
- * and if the entire pair aren't available then the outgoing
1136
- * parameter stack is used for both but an alignment of 8
1137
- * must will be kept. So we must either look in pgr
1138
- * or pst to find the correct address for this type
1139
- * of parameter.
1140
- */
1141
- if (ng < 7)
1142
- {
1143
- if (ng & 0x01)
1144
- {
1145
- /* skip r4, r6, r8 as starting points */
1146
- ng++;
1147
- pgr++;
1148
- }
1149
- avalue[i] = pgr;
1150
- ng += 2;
1151
- pgr += 2;
1152
- }
1153
- else
1154
- {
1155
- if (((long) pst) & 4)
1156
- pst++;
1157
- avalue[i] = pst;
1158
- pst += 2;
1159
- ng = 8;
1160
- }
1161
- break;
1162
-
1163
- case FFI_TYPE_FLOAT:
1164
- /* With FFI_LINUX_SOFT_FLOAT floats are handled like UINT32. */
1165
- if (cif->abi == FFI_LINUX_SOFT_FLOAT)
1166
- goto soft_float_closure;
1167
- /* unfortunately float values are stored as doubles
1168
- * in the ffi_closure_SYSV code (since we don't check
1169
- * the type in that routine).
1170
- */
1171
-
1172
- /* there are 8 64bit floating point registers */
1173
-
1174
- if (nf < 8)
1175
- {
1176
- temp = pfr->d;
1177
- pfr->f = (float) temp;
1178
- avalue[i] = pfr;
1179
- nf++;
1180
- pfr++;
1181
- }
1182
- else
1183
- {
1184
- /* FIXME? here we are really changing the values
1185
- * stored in the original calling routines outgoing
1186
- * parameter stack. This is probably a really
1187
- * naughty thing to do but...
1188
- */
1189
- avalue[i] = pst;
1190
- pst += 1;
1191
- }
1192
- break;
1193
-
1194
- case FFI_TYPE_DOUBLE:
1195
- /* With FFI_LINUX_SOFT_FLOAT doubles are handled like UINT64. */
1196
- if (cif->abi == FFI_LINUX_SOFT_FLOAT)
1197
- goto soft_double_closure;
1198
- /* On the outgoing stack all values are aligned to 8 */
1199
- /* there are 8 64bit floating point registers */
1200
-
1201
- if (nf < 8)
1202
- {
1203
- avalue[i] = pfr;
1204
- nf++;
1205
- pfr++;
1206
- }
1207
- else
1208
- {
1209
- if (((long) pst) & 4)
1210
- pst++;
1211
- avalue[i] = pst;
1212
- pst += 2;
1213
- }
1214
- break;
1215
-
1216
- #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
1217
- case FFI_TYPE_LONGDOUBLE:
1218
- if (cif->abi != FFI_LINUX && cif->abi != FFI_LINUX_SOFT_FLOAT)
1219
- goto do_struct;
1220
- if (cif->abi == FFI_LINUX_SOFT_FLOAT)
1221
- { /* Test if for the whole long double, 4 gprs are available.
1222
- otherwise the stuff ends up on the stack. */
1223
- if (ng < 5)
1224
- {
1225
- avalue[i] = pgr;
1226
- pgr += 4;
1227
- ng += 4;
1228
- }
1229
- else
1230
- {
1231
- avalue[i] = pst;
1232
- pst += 4;
1233
- ng = 8;
1234
- }
1235
- break;
1236
- }
1237
- if (nf < 7)
1238
- {
1239
- avalue[i] = pfr;
1240
- pfr += 2;
1241
- nf += 2;
1242
- }
1243
- else
1244
- {
1245
- if (((long) pst) & 4)
1246
- pst++;
1247
- avalue[i] = pst;
1248
- pst += 4;
1249
- nf = 8;
1250
- }
1251
- break;
1252
- #endif
1253
-
1254
- default:
1255
- FFI_ASSERT (0);
1256
- }
1257
-
1258
- i++;
1259
- }
1260
-
1261
-
1262
- (closure->fun) (cif, rvalue, avalue, closure->user_data);
1263
-
1264
- /* Tell ffi_closure_SYSV how to perform return type promotions.
1265
- Because the FFI_SYSV ABI returns the structures <= 8 bytes in r3/r4
1266
- we have to tell ffi_closure_SYSV how to treat them. We combine the base
1267
- type FFI_SYSV_TYPE_SMALL_STRUCT - 1 with the size of the struct.
1268
- So a one byte struct gets the return type 16. Return type 1 to 15 are
1269
- already used and we never have a struct with size zero. That is the reason
1270
- for the subtraction of 1. See the comment in ffitarget.h about ordering.
1271
- */
1272
- if (cif->abi == FFI_SYSV && cif->rtype->type == FFI_TYPE_STRUCT
1273
- && size <= 8)
1274
- return (FFI_SYSV_TYPE_SMALL_STRUCT - 1) + size;
1275
- #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
1276
- else if (cif->rtype->type == FFI_TYPE_LONGDOUBLE
1277
- && cif->abi != FFI_LINUX && cif->abi != FFI_LINUX_SOFT_FLOAT)
1278
- return FFI_TYPE_STRUCT;
1279
- #endif
1280
- /* With FFI_LINUX_SOFT_FLOAT floats and doubles are handled like UINT32
1281
- respectivley UINT64. */
1282
- if (cif->abi == FFI_LINUX_SOFT_FLOAT)
1283
- {
1284
- switch (cif->rtype->type)
1285
- {
1286
- case FFI_TYPE_FLOAT:
1287
- return FFI_TYPE_UINT32;
1288
- break;
1289
- case FFI_TYPE_DOUBLE:
1290
- return FFI_TYPE_UINT64;
1291
- break;
1292
- #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
1293
- case FFI_TYPE_LONGDOUBLE:
1294
- return FFI_TYPE_UINT128;
1295
- break;
158
+ return ffi_prep_closure_loc_sysv (closure, cif, fun, user_data, codeloc);
1296
159
  #endif
1297
- default:
1298
- return cif->rtype->type;
1299
- }
1300
- }
1301
- else
1302
- {
1303
- return cif->rtype->type;
1304
- }
1305
160
  }
1306
161
 
1307
- int FFI_HIDDEN ffi_closure_helper_LINUX64 (ffi_closure *, void *,
1308
- unsigned long *, ffi_dblfl *);
1309
-
1310
- int FFI_HIDDEN
1311
- ffi_closure_helper_LINUX64 (ffi_closure *closure, void *rvalue,
1312
- unsigned long *pst, ffi_dblfl *pfr)
162
+ ffi_status
163
+ ffi_prep_go_closure (ffi_go_closure *closure,
164
+ ffi_cif *cif,
165
+ void (*fun) (ffi_cif *, void *, void **, void *))
1313
166
  {
1314
- /* rvalue is the pointer to space for return value in closure assembly */
1315
- /* pst is the pointer to parameter save area
1316
- (r3-r10 are stored into its first 8 slots by ffi_closure_LINUX64) */
1317
- /* pfr is the pointer to where f1-f13 are stored in ffi_closure_LINUX64 */
1318
-
1319
- void **avalue;
1320
- ffi_type **arg_types;
1321
- long i, avn;
1322
- ffi_cif *cif;
1323
- ffi_dblfl *end_pfr = pfr + NUM_FPR_ARG_REGISTERS64;
1324
-
1325
- cif = closure->cif;
1326
- avalue = alloca (cif->nargs * sizeof (void *));
1327
-
1328
- /* Copy the caller's structure return value address so that the closure
1329
- returns the data directly to the caller. */
1330
- if (cif->rtype->type == FFI_TYPE_STRUCT)
1331
- {
1332
- rvalue = (void *) *pst;
1333
- pst++;
1334
- }
1335
-
1336
- i = 0;
1337
- avn = cif->nargs;
1338
- arg_types = cif->arg_types;
1339
-
1340
- /* Grab the addresses of the arguments from the stack frame. */
1341
- while (i < avn)
1342
- {
1343
- switch (arg_types[i]->type)
1344
- {
1345
- case FFI_TYPE_SINT8:
1346
- case FFI_TYPE_UINT8:
1347
- avalue[i] = (char *) pst + 7;
1348
- pst++;
1349
- break;
1350
-
1351
- case FFI_TYPE_SINT16:
1352
- case FFI_TYPE_UINT16:
1353
- avalue[i] = (char *) pst + 6;
1354
- pst++;
1355
- break;
1356
-
1357
- case FFI_TYPE_SINT32:
1358
- case FFI_TYPE_UINT32:
1359
- avalue[i] = (char *) pst + 4;
1360
- pst++;
1361
- break;
1362
-
1363
- case FFI_TYPE_SINT64:
1364
- case FFI_TYPE_UINT64:
1365
- case FFI_TYPE_POINTER:
1366
- avalue[i] = pst;
1367
- pst++;
1368
- break;
1369
-
1370
- case FFI_TYPE_STRUCT:
1371
- /* Structures with size less than eight bytes are passed
1372
- left-padded. */
1373
- if (arg_types[i]->size < 8)
1374
- avalue[i] = (char *) pst + 8 - arg_types[i]->size;
1375
- else
1376
- avalue[i] = pst;
1377
- pst += (arg_types[i]->size + 7) / 8;
1378
- break;
1379
-
1380
- case FFI_TYPE_FLOAT:
1381
- /* unfortunately float values are stored as doubles
1382
- * in the ffi_closure_LINUX64 code (since we don't check
1383
- * the type in that routine).
1384
- */
1385
-
1386
- /* there are 13 64bit floating point registers */
1387
-
1388
- if (pfr < end_pfr)
1389
- {
1390
- double temp = pfr->d;
1391
- pfr->f = (float) temp;
1392
- avalue[i] = pfr;
1393
- pfr++;
1394
- }
1395
- else
1396
- avalue[i] = pst;
1397
- pst++;
1398
- break;
1399
-
1400
- case FFI_TYPE_DOUBLE:
1401
- /* On the outgoing stack all values are aligned to 8 */
1402
- /* there are 13 64bit floating point registers */
1403
-
1404
- if (pfr < end_pfr)
1405
- {
1406
- avalue[i] = pfr;
1407
- pfr++;
1408
- }
1409
- else
1410
- avalue[i] = pst;
1411
- pst++;
1412
- break;
1413
-
1414
- #if FFI_TYPE_LONGDOUBLE != FFI_TYPE_DOUBLE
1415
- case FFI_TYPE_LONGDOUBLE:
1416
- if (pfr + 1 < end_pfr)
1417
- {
1418
- avalue[i] = pfr;
1419
- pfr += 2;
1420
- }
1421
- else
1422
- {
1423
- if (pfr < end_pfr)
1424
- {
1425
- /* Passed partly in f13 and partly on the stack.
1426
- Move it all to the stack. */
1427
- *pst = *(unsigned long *) pfr;
1428
- pfr++;
1429
- }
1430
- avalue[i] = pst;
1431
- }
1432
- pst += 2;
1433
- break;
167
+ #ifdef POWERPC64
168
+ closure->tramp = ffi_go_closure_linux64;
169
+ #else
170
+ closure->tramp = ffi_go_closure_sysv;
1434
171
  #endif
1435
-
1436
- default:
1437
- FFI_ASSERT (0);
1438
- }
1439
-
1440
- i++;
1441
- }
1442
-
1443
-
1444
- (closure->fun) (cif, rvalue, avalue, closure->user_data);
1445
-
1446
- /* Tell ffi_closure_LINUX64 how to perform return type promotions. */
1447
- return cif->rtype->type;
172
+ closure->cif = cif;
173
+ closure->fun = fun;
174
+ return FFI_OK;
1448
175
  }