ffi 1.11.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 (530) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +25 -0
  3. data/.gitmodules +4 -0
  4. data/.travis.yml +42 -0
  5. data/.yardopts +5 -0
  6. data/CHANGELOG.md +131 -0
  7. data/COPYING +49 -0
  8. data/Gemfile +15 -0
  9. data/LICENSE +24 -0
  10. data/LICENSE.SPECS +22 -0
  11. data/README.md +115 -0
  12. data/Rakefile +195 -0
  13. data/appveyor.yml +27 -0
  14. data/ext/ffi_c/AbstractMemory.c +1109 -0
  15. data/ext/ffi_c/AbstractMemory.h +175 -0
  16. data/ext/ffi_c/ArrayType.c +162 -0
  17. data/ext/ffi_c/ArrayType.h +59 -0
  18. data/ext/ffi_c/Buffer.c +365 -0
  19. data/ext/ffi_c/Call.c +503 -0
  20. data/ext/ffi_c/Call.h +107 -0
  21. data/ext/ffi_c/ClosurePool.c +283 -0
  22. data/ext/ffi_c/ClosurePool.h +57 -0
  23. data/ext/ffi_c/DynamicLibrary.c +339 -0
  24. data/ext/ffi_c/DynamicLibrary.h +98 -0
  25. data/ext/ffi_c/Function.c +917 -0
  26. data/ext/ffi_c/Function.h +87 -0
  27. data/ext/ffi_c/FunctionInfo.c +271 -0
  28. data/ext/ffi_c/LastError.c +229 -0
  29. data/ext/ffi_c/LastError.h +47 -0
  30. data/ext/ffi_c/LongDouble.c +63 -0
  31. data/ext/ffi_c/LongDouble.h +51 -0
  32. data/ext/ffi_c/MappedType.c +168 -0
  33. data/ext/ffi_c/MappedType.h +59 -0
  34. data/ext/ffi_c/MemoryPointer.c +197 -0
  35. data/ext/ffi_c/MemoryPointer.h +53 -0
  36. data/ext/ffi_c/MethodHandle.c +358 -0
  37. data/ext/ffi_c/MethodHandle.h +55 -0
  38. data/ext/ffi_c/Platform.c +82 -0
  39. data/ext/ffi_c/Platform.h +45 -0
  40. data/ext/ffi_c/Pointer.c +508 -0
  41. data/ext/ffi_c/Pointer.h +63 -0
  42. data/ext/ffi_c/Struct.c +829 -0
  43. data/ext/ffi_c/Struct.h +106 -0
  44. data/ext/ffi_c/StructByValue.c +150 -0
  45. data/ext/ffi_c/StructByValue.h +55 -0
  46. data/ext/ffi_c/StructLayout.c +698 -0
  47. data/ext/ffi_c/Thread.c +137 -0
  48. data/ext/ffi_c/Thread.h +84 -0
  49. data/ext/ffi_c/Type.c +379 -0
  50. data/ext/ffi_c/Type.h +61 -0
  51. data/ext/ffi_c/Types.c +139 -0
  52. data/ext/ffi_c/Types.h +89 -0
  53. data/ext/ffi_c/Variadic.c +298 -0
  54. data/ext/ffi_c/compat.h +78 -0
  55. data/ext/ffi_c/extconf.rb +86 -0
  56. data/ext/ffi_c/ffi.c +93 -0
  57. data/ext/ffi_c/libffi.bsd.mk +40 -0
  58. data/ext/ffi_c/libffi.darwin.mk +105 -0
  59. data/ext/ffi_c/libffi.gnu.mk +32 -0
  60. data/ext/ffi_c/libffi.mk +18 -0
  61. data/ext/ffi_c/libffi.vc.mk +26 -0
  62. data/ext/ffi_c/libffi.vc64.mk +26 -0
  63. data/ext/ffi_c/libffi/.appveyor.yml +50 -0
  64. data/ext/ffi_c/libffi/.github/issue_template.md +10 -0
  65. data/ext/ffi_c/libffi/.gitignore +38 -0
  66. data/ext/ffi_c/libffi/.travis.yml +34 -0
  67. data/ext/ffi_c/libffi/.travis/ar-lib +270 -0
  68. data/ext/ffi_c/libffi/.travis/build.sh +34 -0
  69. data/ext/ffi_c/libffi/.travis/compile +351 -0
  70. data/ext/ffi_c/libffi/.travis/install.sh +22 -0
  71. data/ext/ffi_c/libffi/.travis/moxie-sim.exp +60 -0
  72. data/ext/ffi_c/libffi/.travis/site.exp +18 -0
  73. data/ext/ffi_c/libffi/ChangeLog.libffi +584 -0
  74. data/ext/ffi_c/libffi/ChangeLog.libffi-3.1 +6000 -0
  75. data/ext/ffi_c/libffi/ChangeLog.libgcj +40 -0
  76. data/ext/ffi_c/libffi/ChangeLog.v1 +764 -0
  77. data/ext/ffi_c/libffi/LICENSE +21 -0
  78. data/ext/ffi_c/libffi/LICENSE-BUILDTOOLS +352 -0
  79. data/ext/ffi_c/libffi/Makefile.am +166 -0
  80. data/ext/ffi_c/libffi/README.md +461 -0
  81. data/ext/ffi_c/libffi/acinclude.m4 +479 -0
  82. data/ext/ffi_c/libffi/autogen.sh +2 -0
  83. data/ext/ffi_c/libffi/config.guess +1466 -0
  84. data/ext/ffi_c/libffi/config.sub +1836 -0
  85. data/ext/ffi_c/libffi/configure.ac +394 -0
  86. data/ext/ffi_c/libffi/configure.host +289 -0
  87. data/ext/ffi_c/libffi/generate-darwin-source-and-headers.py +203 -0
  88. data/ext/ffi_c/libffi/include/Makefile.am +9 -0
  89. data/ext/ffi_c/libffi/include/ffi.h.in +511 -0
  90. data/ext/ffi_c/libffi/include/ffi_cfi.h +55 -0
  91. data/ext/ffi_c/libffi/include/ffi_common.h +149 -0
  92. data/ext/ffi_c/libffi/libffi.map.in +80 -0
  93. data/ext/ffi_c/libffi/libffi.pc.in +11 -0
  94. data/ext/ffi_c/libffi/libffi.xcodeproj/project.pbxproj +1043 -0
  95. data/ext/ffi_c/libffi/libtool-version +29 -0
  96. data/ext/ffi_c/libffi/m4/asmcfi.m4 +13 -0
  97. data/ext/ffi_c/libffi/m4/ax_append_flag.m4 +71 -0
  98. data/ext/ffi_c/libffi/m4/ax_cc_maxopt.m4 +194 -0
  99. data/ext/ffi_c/libffi/m4/ax_cflags_warn_all.m4 +122 -0
  100. data/ext/ffi_c/libffi/m4/ax_check_compile_flag.m4 +74 -0
  101. data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +87 -0
  102. data/ext/ffi_c/libffi/m4/ax_configure_args.m4 +70 -0
  103. data/ext/ffi_c/libffi/m4/ax_enable_builddir.m4 +302 -0
  104. data/ext/ffi_c/libffi/m4/ax_gcc_archflag.m4 +263 -0
  105. data/ext/ffi_c/libffi/m4/ax_gcc_x86_cpuid.m4 +89 -0
  106. data/ext/ffi_c/libffi/m4/ax_require_defined.m4 +37 -0
  107. data/ext/ffi_c/libffi/man/Makefile.am +8 -0
  108. data/ext/ffi_c/libffi/man/ffi.3 +41 -0
  109. data/ext/ffi_c/libffi/man/ffi_call.3 +103 -0
  110. data/ext/ffi_c/libffi/man/ffi_prep_cif.3 +68 -0
  111. data/ext/ffi_c/libffi/man/ffi_prep_cif_var.3 +73 -0
  112. data/ext/ffi_c/libffi/msvcc.sh +328 -0
  113. data/ext/ffi_c/libffi/src/aarch64/ffi.c +941 -0
  114. data/ext/ffi_c/libffi/src/aarch64/ffitarget.h +81 -0
  115. data/ext/ffi_c/libffi/src/aarch64/internal.h +67 -0
  116. data/ext/ffi_c/libffi/src/aarch64/sysv.S +438 -0
  117. data/ext/ffi_c/libffi/src/alpha/ffi.c +521 -0
  118. data/ext/ffi_c/libffi/src/alpha/ffitarget.h +57 -0
  119. data/ext/ffi_c/libffi/src/alpha/internal.h +23 -0
  120. data/ext/ffi_c/libffi/src/alpha/osf.S +282 -0
  121. data/ext/ffi_c/libffi/src/arc/arcompact.S +135 -0
  122. data/ext/ffi_c/libffi/src/arc/ffi.c +266 -0
  123. data/ext/ffi_c/libffi/src/arc/ffitarget.h +53 -0
  124. data/ext/ffi_c/libffi/src/arm/ffi.c +819 -0
  125. data/ext/ffi_c/libffi/src/arm/ffitarget.h +82 -0
  126. data/ext/ffi_c/libffi/src/arm/internal.h +7 -0
  127. data/ext/ffi_c/libffi/src/arm/sysv.S +383 -0
  128. data/ext/ffi_c/libffi/src/avr32/ffi.c +423 -0
  129. data/ext/ffi_c/libffi/src/avr32/ffitarget.h +55 -0
  130. data/ext/ffi_c/libffi/src/avr32/sysv.S +208 -0
  131. data/ext/ffi_c/libffi/src/bfin/ffi.c +196 -0
  132. data/ext/ffi_c/libffi/src/bfin/ffitarget.h +43 -0
  133. data/ext/ffi_c/libffi/src/bfin/sysv.S +179 -0
  134. data/ext/ffi_c/libffi/src/closures.c +966 -0
  135. data/ext/ffi_c/libffi/src/cris/ffi.c +386 -0
  136. data/ext/ffi_c/libffi/src/cris/ffitarget.h +56 -0
  137. data/ext/ffi_c/libffi/src/cris/sysv.S +215 -0
  138. data/ext/ffi_c/libffi/src/debug.c +64 -0
  139. data/ext/ffi_c/libffi/src/dlmalloc.c +5166 -0
  140. data/ext/ffi_c/libffi/src/frv/eabi.S +128 -0
  141. data/ext/ffi_c/libffi/src/frv/ffi.c +292 -0
  142. data/ext/ffi_c/libffi/src/frv/ffitarget.h +62 -0
  143. data/ext/ffi_c/libffi/src/ia64/ffi.c +604 -0
  144. data/ext/ffi_c/libffi/src/ia64/ffitarget.h +56 -0
  145. data/ext/ffi_c/libffi/src/ia64/ia64_flags.h +40 -0
  146. data/ext/ffi_c/libffi/src/ia64/unix.S +567 -0
  147. data/ext/ffi_c/libffi/src/java_raw_api.c +374 -0
  148. data/ext/ffi_c/libffi/src/m32r/ffi.c +232 -0
  149. data/ext/ffi_c/libffi/src/m32r/ffitarget.h +53 -0
  150. data/ext/ffi_c/libffi/src/m32r/sysv.S +121 -0
  151. data/ext/ffi_c/libffi/src/m68k/ffi.c +362 -0
  152. data/ext/ffi_c/libffi/src/m68k/ffitarget.h +54 -0
  153. data/ext/ffi_c/libffi/src/m68k/sysv.S +357 -0
  154. data/ext/ffi_c/libffi/src/m88k/ffi.c +400 -0
  155. data/ext/ffi_c/libffi/src/m88k/ffitarget.h +49 -0
  156. data/ext/ffi_c/libffi/src/m88k/obsd.S +209 -0
  157. data/ext/ffi_c/libffi/src/metag/ffi.c +330 -0
  158. data/ext/ffi_c/libffi/src/metag/ffitarget.h +53 -0
  159. data/ext/ffi_c/libffi/src/metag/sysv.S +311 -0
  160. data/ext/ffi_c/libffi/src/microblaze/ffi.c +321 -0
  161. data/ext/ffi_c/libffi/src/microblaze/ffitarget.h +53 -0
  162. data/ext/ffi_c/libffi/src/microblaze/sysv.S +302 -0
  163. data/ext/ffi_c/libffi/src/mips/ffi.c +1130 -0
  164. data/ext/ffi_c/libffi/src/mips/ffitarget.h +244 -0
  165. data/ext/ffi_c/libffi/src/mips/n32.S +663 -0
  166. data/ext/ffi_c/libffi/src/mips/o32.S +502 -0
  167. data/ext/ffi_c/libffi/src/moxie/eabi.S +101 -0
  168. data/ext/ffi_c/libffi/src/moxie/ffi.c +285 -0
  169. data/ext/ffi_c/libffi/src/moxie/ffitarget.h +52 -0
  170. data/ext/ffi_c/libffi/src/nios2/ffi.c +304 -0
  171. data/ext/ffi_c/libffi/src/nios2/ffitarget.h +52 -0
  172. data/ext/ffi_c/libffi/src/nios2/sysv.S +136 -0
  173. data/ext/ffi_c/libffi/src/or1k/ffi.c +328 -0
  174. data/ext/ffi_c/libffi/src/or1k/ffitarget.h +58 -0
  175. data/ext/ffi_c/libffi/src/or1k/sysv.S +107 -0
  176. data/ext/ffi_c/libffi/src/pa/ffi.c +719 -0
  177. data/ext/ffi_c/libffi/src/pa/ffitarget.h +85 -0
  178. data/ext/ffi_c/libffi/src/pa/hpux32.S +368 -0
  179. data/ext/ffi_c/libffi/src/pa/linux.S +357 -0
  180. data/ext/ffi_c/libffi/src/powerpc/aix.S +566 -0
  181. data/ext/ffi_c/libffi/src/powerpc/aix_closure.S +694 -0
  182. data/ext/ffi_c/libffi/src/powerpc/asm.h +125 -0
  183. data/ext/ffi_c/libffi/src/powerpc/darwin.S +378 -0
  184. data/ext/ffi_c/libffi/src/powerpc/darwin_closure.S +571 -0
  185. data/ext/ffi_c/libffi/src/powerpc/ffi.c +173 -0
  186. data/ext/ffi_c/libffi/src/powerpc/ffi_darwin.c +1440 -0
  187. data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +974 -0
  188. data/ext/ffi_c/libffi/src/powerpc/ffi_powerpc.h +94 -0
  189. data/ext/ffi_c/libffi/src/powerpc/ffi_sysv.c +923 -0
  190. data/ext/ffi_c/libffi/src/powerpc/ffitarget.h +198 -0
  191. data/ext/ffi_c/libffi/src/powerpc/linux64.S +228 -0
  192. data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +488 -0
  193. data/ext/ffi_c/libffi/src/powerpc/ppc_closure.S +397 -0
  194. data/ext/ffi_c/libffi/src/powerpc/sysv.S +175 -0
  195. data/ext/ffi_c/libffi/src/prep_cif.c +261 -0
  196. data/ext/ffi_c/libffi/src/raw_api.c +267 -0
  197. data/ext/ffi_c/libffi/src/riscv/ffi.c +481 -0
  198. data/ext/ffi_c/libffi/src/riscv/ffitarget.h +69 -0
  199. data/ext/ffi_c/libffi/src/riscv/sysv.S +293 -0
  200. data/ext/ffi_c/libffi/src/s390/ffi.c +756 -0
  201. data/ext/ffi_c/libffi/src/s390/ffitarget.h +70 -0
  202. data/ext/ffi_c/libffi/src/s390/internal.h +11 -0
  203. data/ext/ffi_c/libffi/src/s390/sysv.S +325 -0
  204. data/ext/ffi_c/libffi/src/sh/ffi.c +717 -0
  205. data/ext/ffi_c/libffi/src/sh/ffitarget.h +54 -0
  206. data/ext/ffi_c/libffi/src/sh/sysv.S +850 -0
  207. data/ext/ffi_c/libffi/src/sh64/ffi.c +469 -0
  208. data/ext/ffi_c/libffi/src/sh64/ffitarget.h +58 -0
  209. data/ext/ffi_c/libffi/src/sh64/sysv.S +539 -0
  210. data/ext/ffi_c/libffi/src/sparc/ffi.c +468 -0
  211. data/ext/ffi_c/libffi/src/sparc/ffi64.c +608 -0
  212. data/ext/ffi_c/libffi/src/sparc/ffitarget.h +81 -0
  213. data/ext/ffi_c/libffi/src/sparc/internal.h +26 -0
  214. data/ext/ffi_c/libffi/src/sparc/v8.S +443 -0
  215. data/ext/ffi_c/libffi/src/sparc/v9.S +440 -0
  216. data/ext/ffi_c/libffi/src/tile/ffi.c +355 -0
  217. data/ext/ffi_c/libffi/src/tile/ffitarget.h +65 -0
  218. data/ext/ffi_c/libffi/src/tile/tile.S +360 -0
  219. data/ext/ffi_c/libffi/src/types.c +108 -0
  220. data/ext/ffi_c/libffi/src/vax/elfbsd.S +195 -0
  221. data/ext/ffi_c/libffi/src/vax/ffi.c +276 -0
  222. data/ext/ffi_c/libffi/src/vax/ffitarget.h +49 -0
  223. data/ext/ffi_c/libffi/src/x86/asmnames.h +30 -0
  224. data/ext/ffi_c/libffi/src/x86/ffi.c +754 -0
  225. data/ext/ffi_c/libffi/src/x86/ffi64.c +884 -0
  226. data/ext/ffi_c/libffi/src/x86/ffitarget.h +147 -0
  227. data/ext/ffi_c/libffi/src/x86/ffiw64.c +308 -0
  228. data/ext/ffi_c/libffi/src/x86/internal.h +29 -0
  229. data/ext/ffi_c/libffi/src/x86/internal64.h +22 -0
  230. data/ext/ffi_c/libffi/src/x86/sysv.S +1129 -0
  231. data/ext/ffi_c/libffi/src/x86/unix64.S +566 -0
  232. data/ext/ffi_c/libffi/src/x86/win64.S +232 -0
  233. data/ext/ffi_c/libffi/src/x86/win64_intel.S +237 -0
  234. data/ext/ffi_c/libffi/src/xtensa/ffi.c +298 -0
  235. data/ext/ffi_c/libffi/src/xtensa/ffitarget.h +53 -0
  236. data/ext/ffi_c/libffi/src/xtensa/sysv.S +258 -0
  237. data/ext/ffi_c/libffi/stamp-h.in +1 -0
  238. data/ext/ffi_c/libffi/testsuite/Makefile.am +117 -0
  239. data/ext/ffi_c/libffi/testsuite/config/default.exp +1 -0
  240. data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +636 -0
  241. data/ext/ffi_c/libffi/testsuite/lib/target-libpath.exp +283 -0
  242. data/ext/ffi_c/libffi/testsuite/lib/wrapper.exp +45 -0
  243. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/Makefile +28 -0
  244. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/README +78 -0
  245. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/alignof.h +50 -0
  246. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/bhaible.exp +58 -0
  247. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-call.c +1745 -0
  248. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-callback.c +2885 -0
  249. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/testcases.c +743 -0
  250. data/ext/ffi_c/libffi/testsuite/libffi.call/align_mixed.c +46 -0
  251. data/ext/ffi_c/libffi/testsuite/libffi.call/align_stdcall.c +46 -0
  252. data/ext/ffi_c/libffi/testsuite/libffi.call/call.exp +43 -0
  253. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn0.c +89 -0
  254. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn1.c +81 -0
  255. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn2.c +81 -0
  256. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn3.c +82 -0
  257. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn4.c +89 -0
  258. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn5.c +92 -0
  259. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn6.c +90 -0
  260. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_loc_fn0.c +95 -0
  261. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_simple.c +55 -0
  262. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_12byte.c +94 -0
  263. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_16byte.c +95 -0
  264. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_18byte.c +96 -0
  265. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_19byte.c +102 -0
  266. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_1_1byte.c +89 -0
  267. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_20byte.c +91 -0
  268. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_20byte1.c +93 -0
  269. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_24byte.c +113 -0
  270. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_2byte.c +90 -0
  271. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3_1byte.c +95 -0
  272. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3byte1.c +90 -0
  273. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3byte2.c +90 -0
  274. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3float.c +95 -0
  275. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_4_1byte.c +98 -0
  276. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_4byte.c +90 -0
  277. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_5_1_byte.c +109 -0
  278. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_5byte.c +98 -0
  279. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_64byte.c +124 -0
  280. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_6_1_byte.c +113 -0
  281. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_6byte.c +99 -0
  282. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_7_1_byte.c +117 -0
  283. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_7byte.c +97 -0
  284. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_8byte.c +88 -0
  285. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_9byte1.c +90 -0
  286. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_9byte2.c +91 -0
  287. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_double.c +93 -0
  288. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_float.c +91 -0
  289. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_longdouble.c +92 -0
  290. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_longdouble_split.c +132 -0
  291. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_longdouble_split2.c +115 -0
  292. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_pointer.c +95 -0
  293. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint16.c +91 -0
  294. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint32.c +91 -0
  295. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint64.c +92 -0
  296. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint16.c +91 -0
  297. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint32.c +91 -0
  298. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint64.c +93 -0
  299. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_dbls_struct.c +66 -0
  300. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_double.c +43 -0
  301. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_double_va.c +61 -0
  302. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_float.c +42 -0
  303. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_longdouble.c +105 -0
  304. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_longdouble_va.c +61 -0
  305. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_many_mixed_args.c +70 -0
  306. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_many_mixed_float_double.c +55 -0
  307. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_schar.c +74 -0
  308. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_sshort.c +74 -0
  309. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_sshortchar.c +86 -0
  310. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_uchar.c +91 -0
  311. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_ushort.c +74 -0
  312. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_ushortchar.c +86 -0
  313. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_pointer.c +74 -0
  314. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_pointer_stack.c +142 -0
  315. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_schar.c +44 -0
  316. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_sint.c +42 -0
  317. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_sshort.c +42 -0
  318. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_struct_va1.c +114 -0
  319. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uchar.c +42 -0
  320. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uchar_va.c +44 -0
  321. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uint.c +43 -0
  322. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uint_va.c +45 -0
  323. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ulong_va.c +45 -0
  324. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ulonglong.c +47 -0
  325. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ushort.c +43 -0
  326. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ushort_va.c +44 -0
  327. data/ext/ffi_c/libffi/testsuite/libffi.call/err_bad_abi.c +36 -0
  328. data/ext/ffi_c/libffi/testsuite/libffi.call/err_bad_typedef.c +26 -0
  329. data/ext/ffi_c/libffi/testsuite/libffi.call/ffitest.h +138 -0
  330. data/ext/ffi_c/libffi/testsuite/libffi.call/float.c +59 -0
  331. data/ext/ffi_c/libffi/testsuite/libffi.call/float1.c +60 -0
  332. data/ext/ffi_c/libffi/testsuite/libffi.call/float2.c +60 -0
  333. data/ext/ffi_c/libffi/testsuite/libffi.call/float3.c +74 -0
  334. data/ext/ffi_c/libffi/testsuite/libffi.call/float4.c +62 -0
  335. data/ext/ffi_c/libffi/testsuite/libffi.call/float_va.c +107 -0
  336. data/ext/ffi_c/libffi/testsuite/libffi.call/huge_struct.c +341 -0
  337. data/ext/ffi_c/libffi/testsuite/libffi.call/many.c +59 -0
  338. data/ext/ffi_c/libffi/testsuite/libffi.call/many2.c +57 -0
  339. data/ext/ffi_c/libffi/testsuite/libffi.call/many_double.c +70 -0
  340. data/ext/ffi_c/libffi/testsuite/libffi.call/many_mixed.c +78 -0
  341. data/ext/ffi_c/libffi/testsuite/libffi.call/negint.c +52 -0
  342. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct.c +152 -0
  343. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct1.c +161 -0
  344. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct10.c +134 -0
  345. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct11.c +121 -0
  346. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct2.c +110 -0
  347. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct3.c +111 -0
  348. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct4.c +111 -0
  349. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct5.c +112 -0
  350. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct6.c +131 -0
  351. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct7.c +111 -0
  352. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct8.c +131 -0
  353. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct9.c +131 -0
  354. data/ext/ffi_c/libffi/testsuite/libffi.call/offsets.c +46 -0
  355. data/ext/ffi_c/libffi/testsuite/libffi.call/pr1172638.c +127 -0
  356. data/ext/ffi_c/libffi/testsuite/libffi.call/problem1.c +90 -0
  357. data/ext/ffi_c/libffi/testsuite/libffi.call/promotion.c +59 -0
  358. data/ext/ffi_c/libffi/testsuite/libffi.call/pyobjc-tc.c +114 -0
  359. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl.c +36 -0
  360. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl1.c +43 -0
  361. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl2.c +42 -0
  362. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl.c +35 -0
  363. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl1.c +36 -0
  364. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl2.c +49 -0
  365. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl3.c +42 -0
  366. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ldl.c +34 -0
  367. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll.c +41 -0
  368. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll1.c +43 -0
  369. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sc.c +36 -0
  370. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sl.c +38 -0
  371. data/ext/ffi_c/libffi/testsuite/libffi.call/return_uc.c +38 -0
  372. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ul.c +38 -0
  373. data/ext/ffi_c/libffi/testsuite/libffi.call/stret_large.c +145 -0
  374. data/ext/ffi_c/libffi/testsuite/libffi.call/stret_large2.c +148 -0
  375. data/ext/ffi_c/libffi/testsuite/libffi.call/stret_medium.c +124 -0
  376. data/ext/ffi_c/libffi/testsuite/libffi.call/stret_medium2.c +125 -0
  377. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen.c +44 -0
  378. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen2.c +49 -0
  379. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen3.c +49 -0
  380. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen4.c +55 -0
  381. data/ext/ffi_c/libffi/testsuite/libffi.call/struct1.c +67 -0
  382. data/ext/ffi_c/libffi/testsuite/libffi.call/struct10.c +57 -0
  383. data/ext/ffi_c/libffi/testsuite/libffi.call/struct2.c +67 -0
  384. data/ext/ffi_c/libffi/testsuite/libffi.call/struct3.c +60 -0
  385. data/ext/ffi_c/libffi/testsuite/libffi.call/struct4.c +64 -0
  386. data/ext/ffi_c/libffi/testsuite/libffi.call/struct5.c +66 -0
  387. data/ext/ffi_c/libffi/testsuite/libffi.call/struct6.c +64 -0
  388. data/ext/ffi_c/libffi/testsuite/libffi.call/struct7.c +74 -0
  389. data/ext/ffi_c/libffi/testsuite/libffi.call/struct8.c +81 -0
  390. data/ext/ffi_c/libffi/testsuite/libffi.call/struct9.c +68 -0
  391. data/ext/ffi_c/libffi/testsuite/libffi.call/testclosure.c +70 -0
  392. data/ext/ffi_c/libffi/testsuite/libffi.call/uninitialized.c +61 -0
  393. data/ext/ffi_c/libffi/testsuite/libffi.call/unwindtest.cc +117 -0
  394. data/ext/ffi_c/libffi/testsuite/libffi.call/unwindtest_ffi_call.cc +54 -0
  395. data/ext/ffi_c/libffi/testsuite/libffi.call/va_1.c +196 -0
  396. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct1.c +121 -0
  397. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct2.c +123 -0
  398. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct3.c +125 -0
  399. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex.inc +91 -0
  400. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_double.c +10 -0
  401. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_float.c +10 -0
  402. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_longdouble.c +10 -0
  403. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex.inc +42 -0
  404. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_double.c +10 -0
  405. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_float.c +10 -0
  406. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_longdouble.c +10 -0
  407. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct.inc +71 -0
  408. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_double.c +10 -0
  409. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_float.c +10 -0
  410. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_longdouble.c +10 -0
  411. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va.inc +80 -0
  412. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_double.c +10 -0
  413. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_float.c +16 -0
  414. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_longdouble.c +10 -0
  415. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex.exp +36 -0
  416. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex.inc +51 -0
  417. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_double.inc +7 -0
  418. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_float.inc +7 -0
  419. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_longdouble.inc +7 -0
  420. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_double.c +10 -0
  421. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_float.c +10 -0
  422. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_int.c +86 -0
  423. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_longdouble.c +10 -0
  424. data/ext/ffi_c/libffi/testsuite/libffi.complex/ffitest.h +1 -0
  425. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex.inc +78 -0
  426. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_double.c +10 -0
  427. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_float.c +10 -0
  428. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_longdouble.c +10 -0
  429. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex.inc +37 -0
  430. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1.inc +41 -0
  431. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_double.c +10 -0
  432. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_float.c +10 -0
  433. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_longdouble.c +10 -0
  434. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2.inc +44 -0
  435. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_double.c +10 -0
  436. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_float.c +10 -0
  437. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_longdouble.c +10 -0
  438. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_double.c +10 -0
  439. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_float.c +10 -0
  440. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_longdouble.c +10 -0
  441. data/ext/ffi_c/libffi/testsuite/libffi.go/aa-direct.c +34 -0
  442. data/ext/ffi_c/libffi/testsuite/libffi.go/closure1.c +28 -0
  443. data/ext/ffi_c/libffi/testsuite/libffi.go/ffitest.h +1 -0
  444. data/ext/ffi_c/libffi/testsuite/libffi.go/go.exp +36 -0
  445. data/ext/ffi_c/libffi/testsuite/libffi.go/static-chain.h +19 -0
  446. data/ext/ffi_c/rbffi.h +55 -0
  447. data/ext/ffi_c/rbffi_endian.h +59 -0
  448. data/ext/ffi_c/win32/stdbool.h +8 -0
  449. data/ext/ffi_c/win32/stdint.h +201 -0
  450. data/ffi.gemspec +43 -0
  451. data/lib/ffi.rb +20 -0
  452. data/lib/ffi/autopointer.rb +203 -0
  453. data/lib/ffi/buffer.rb +4 -0
  454. data/lib/ffi/callback.rb +4 -0
  455. data/lib/ffi/data_converter.rb +67 -0
  456. data/lib/ffi/enum.rb +296 -0
  457. data/lib/ffi/errno.rb +43 -0
  458. data/lib/ffi/ffi.rb +45 -0
  459. data/lib/ffi/io.rb +62 -0
  460. data/lib/ffi/library.rb +588 -0
  461. data/lib/ffi/managedstruct.rb +84 -0
  462. data/lib/ffi/memorypointer.rb +1 -0
  463. data/lib/ffi/platform.rb +172 -0
  464. data/lib/ffi/platform/aarch64-freebsd/types.conf +128 -0
  465. data/lib/ffi/platform/aarch64-freebsd12/types.conf +128 -0
  466. data/lib/ffi/platform/aarch64-linux/types.conf +104 -0
  467. data/lib/ffi/platform/arm-freebsd/types.conf +152 -0
  468. data/lib/ffi/platform/arm-freebsd12/types.conf +152 -0
  469. data/lib/ffi/platform/arm-linux/types.conf +104 -0
  470. data/lib/ffi/platform/i386-cygwin/types.conf +3 -0
  471. data/lib/ffi/platform/i386-darwin/types.conf +100 -0
  472. data/lib/ffi/platform/i386-freebsd/types.conf +152 -0
  473. data/lib/ffi/platform/i386-freebsd12/types.conf +152 -0
  474. data/lib/ffi/platform/i386-gnu/types.conf +107 -0
  475. data/lib/ffi/platform/i386-linux/types.conf +103 -0
  476. data/lib/ffi/platform/i386-netbsd/types.conf +126 -0
  477. data/lib/ffi/platform/i386-openbsd/types.conf +128 -0
  478. data/lib/ffi/platform/i386-solaris/types.conf +122 -0
  479. data/lib/ffi/platform/i386-windows/types.conf +105 -0
  480. data/lib/ffi/platform/ia64-linux/types.conf +104 -0
  481. data/lib/ffi/platform/mips-linux/types.conf +102 -0
  482. data/lib/ffi/platform/mips64-linux/types.conf +104 -0
  483. data/lib/ffi/platform/mips64el-linux/types.conf +104 -0
  484. data/lib/ffi/platform/mipsel-linux/types.conf +102 -0
  485. data/lib/ffi/platform/mipsisa32r6-linux/types.conf +102 -0
  486. data/lib/ffi/platform/mipsisa32r6el-linux/types.conf +102 -0
  487. data/lib/ffi/platform/mipsisa64r6-linux/types.conf +104 -0
  488. data/lib/ffi/platform/mipsisa64r6el-linux/types.conf +104 -0
  489. data/lib/ffi/platform/powerpc-aix/types.conf +180 -0
  490. data/lib/ffi/platform/powerpc-darwin/types.conf +100 -0
  491. data/lib/ffi/platform/powerpc-linux/types.conf +100 -0
  492. data/lib/ffi/platform/powerpc64-linux/types.conf +104 -0
  493. data/lib/ffi/platform/s390-linux/types.conf +102 -0
  494. data/lib/ffi/platform/s390x-linux/types.conf +102 -0
  495. data/lib/ffi/platform/sparc-linux/types.conf +102 -0
  496. data/lib/ffi/platform/sparc-solaris/types.conf +128 -0
  497. data/lib/ffi/platform/sparc64-linux/types.conf +102 -0
  498. data/lib/ffi/platform/sparcv9-solaris/types.conf +128 -0
  499. data/lib/ffi/platform/x86_64-cygwin/types.conf +3 -0
  500. data/lib/ffi/platform/x86_64-darwin/types.conf +126 -0
  501. data/lib/ffi/platform/x86_64-freebsd/types.conf +128 -0
  502. data/lib/ffi/platform/x86_64-freebsd12/types.conf +128 -0
  503. data/lib/ffi/platform/x86_64-linux/types.conf +102 -0
  504. data/lib/ffi/platform/x86_64-netbsd/types.conf +128 -0
  505. data/lib/ffi/platform/x86_64-openbsd/types.conf +134 -0
  506. data/lib/ffi/platform/x86_64-solaris/types.conf +122 -0
  507. data/lib/ffi/platform/x86_64-windows/types.conf +120 -0
  508. data/lib/ffi/pointer.rb +160 -0
  509. data/lib/ffi/struct.rb +311 -0
  510. data/lib/ffi/struct_by_reference.rb +72 -0
  511. data/lib/ffi/struct_layout.rb +96 -0
  512. data/lib/ffi/struct_layout_builder.rb +227 -0
  513. data/lib/ffi/tools/const_generator.rb +230 -0
  514. data/lib/ffi/tools/generator.rb +105 -0
  515. data/lib/ffi/tools/generator_task.rb +32 -0
  516. data/lib/ffi/tools/struct_generator.rb +194 -0
  517. data/lib/ffi/tools/types_generator.rb +134 -0
  518. data/lib/ffi/types.rb +194 -0
  519. data/lib/ffi/union.rb +43 -0
  520. data/lib/ffi/variadic.rb +78 -0
  521. data/lib/ffi/version.rb +3 -0
  522. data/samples/getlogin.rb +8 -0
  523. data/samples/getpid.rb +8 -0
  524. data/samples/gettimeofday.rb +18 -0
  525. data/samples/hello.rb +7 -0
  526. data/samples/inotify.rb +60 -0
  527. data/samples/pty.rb +76 -0
  528. data/samples/qsort.rb +21 -0
  529. data/samples/sample_helper.rb +6 -0
  530. metadata +663 -0
@@ -0,0 +1,440 @@
1
+ /* -----------------------------------------------------------------------
2
+ v9.S - Copyright (c) 2000, 2003, 2004, 2008 Red Hat, Inc.
3
+
4
+ SPARC 64-bit Foreign Function Interface
5
+
6
+ Permission is hereby granted, free of charge, to any person obtaining
7
+ a copy of this software and associated documentation files (the
8
+ ``Software''), to deal in the Software without restriction, including
9
+ without limitation the rights to use, copy, modify, merge, publish,
10
+ distribute, sublicense, and/or sell copies of the Software, and to
11
+ permit persons to whom the Software is furnished to do so, subject to
12
+ the following conditions:
13
+
14
+ The above copyright notice and this permission notice shall be included
15
+ in all copies or substantial portions of the Software.
16
+
17
+ THE SOFTWARE IS PROVIDED ``AS IS'', WITHOUT WARRANTY OF ANY KIND,
18
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
19
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
20
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
21
+ HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
22
+ WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
24
+ DEALINGS IN THE SOFTWARE.
25
+ ----------------------------------------------------------------------- */
26
+
27
+ #define LIBFFI_ASM
28
+ #include <fficonfig.h>
29
+ #include <ffi.h>
30
+ #include "internal.h"
31
+
32
+ #ifdef SPARC64
33
+
34
+ #define C2(X, Y) X ## Y
35
+ #define C1(X, Y) C2(X, Y)
36
+
37
+ #ifdef __USER_LABEL_PREFIX__
38
+ # define C(Y) C1(__USER_LABEL_PREFIX__, Y)
39
+ #else
40
+ # define C(Y) Y
41
+ #endif
42
+ #define L(Y) C1(.L, Y)
43
+
44
+ #if defined(__sun__) && defined(__svr4__)
45
+ # define E(INDEX) .align 16
46
+ #else
47
+ # define E(INDEX) .align 16; .org 2b + INDEX * 16
48
+ #endif
49
+
50
+ #define STACK_BIAS 2047
51
+
52
+ .text
53
+ .align 8
54
+ .globl C(ffi_call_v9)
55
+ .type C(ffi_call_v9),#function
56
+ FFI_HIDDEN(C(ffi_call_v9))
57
+
58
+ C(ffi_call_v9):
59
+ .LUW0:
60
+ save %sp, %o4, %sp
61
+ .LUW1:
62
+ mov %i0, %o0 ! copy cif
63
+ add %sp, STACK_BIAS+128+48, %o1 ! load args area
64
+ mov %i2, %o2 ! copy rvalue
65
+ call C(ffi_prep_args_v9)
66
+ mov %i3, %o3 ! copy avalue
67
+
68
+ andcc %o0, SPARC_FLAG_FP_ARGS, %g0 ! need fp regs?
69
+ add %sp, 48, %sp ! deallocate prep frame
70
+ be,pt %xcc, 1f
71
+ mov %o0, %l0 ! save flags
72
+
73
+ ldd [%sp+STACK_BIAS+128], %f0 ! load all fp arg regs
74
+ ldd [%sp+STACK_BIAS+128+8], %f2
75
+ ldd [%sp+STACK_BIAS+128+16], %f4
76
+ ldd [%sp+STACK_BIAS+128+24], %f6
77
+ ldd [%sp+STACK_BIAS+128+32], %f8
78
+ ldd [%sp+STACK_BIAS+128+40], %f10
79
+ ldd [%sp+STACK_BIAS+128+48], %f12
80
+ ldd [%sp+STACK_BIAS+128+56], %f14
81
+ ldd [%sp+STACK_BIAS+128+64], %f16
82
+ ldd [%sp+STACK_BIAS+128+72], %f18
83
+ ldd [%sp+STACK_BIAS+128+80], %f20
84
+ ldd [%sp+STACK_BIAS+128+88], %f22
85
+ ldd [%sp+STACK_BIAS+128+96], %f24
86
+ ldd [%sp+STACK_BIAS+128+104], %f26
87
+ ldd [%sp+STACK_BIAS+128+112], %f28
88
+ ldd [%sp+STACK_BIAS+128+120], %f30
89
+
90
+ 1: ldx [%sp+STACK_BIAS+128], %o0 ! load all int arg regs
91
+ ldx [%sp+STACK_BIAS+128+8], %o1
92
+ ldx [%sp+STACK_BIAS+128+16], %o2
93
+ ldx [%sp+STACK_BIAS+128+24], %o3
94
+ ldx [%sp+STACK_BIAS+128+32], %o4
95
+ ldx [%sp+STACK_BIAS+128+40], %o5
96
+ call %i1
97
+ mov %i5, %g5 ! load static chain
98
+
99
+ 0: call 1f ! load pc in %o7
100
+ and %l0, SPARC_FLAG_RET_MASK, %l1
101
+ 1: sll %l1, 4, %l1
102
+ add %o7, %l1, %o7 ! o7 = 0b + ret_type*16
103
+ jmp %o7+(2f-0b)
104
+ nop
105
+
106
+ .align 16
107
+ 2:
108
+ E(SPARC_RET_VOID)
109
+ return %i7+8
110
+ nop
111
+ E(SPARC_RET_STRUCT)
112
+ add %sp, STACK_BIAS-64+128+48, %l2
113
+ sub %sp, 64, %sp
114
+ b 8f
115
+ stx %o0, [%l2]
116
+ E(SPARC_RET_UINT8)
117
+ and %o0, 0xff, %i0
118
+ return %i7+8
119
+ stx %o0, [%o2]
120
+ E(SPARC_RET_SINT8)
121
+ sll %o0, 24, %o0
122
+ sra %o0, 24, %i0
123
+ return %i7+8
124
+ stx %o0, [%o2]
125
+ E(SPARC_RET_UINT16)
126
+ sll %o0, 16, %o0
127
+ srl %o0, 16, %i0
128
+ return %i7+8
129
+ stx %o0, [%o2]
130
+ E(SPARC_RET_SINT16)
131
+ sll %o0, 16, %o0
132
+ sra %o0, 16, %i0
133
+ return %i7+8
134
+ stx %o0, [%o2]
135
+ E(SPARC_RET_UINT32)
136
+ srl %o0, 0, %i0
137
+ return %i7+8
138
+ stx %o0, [%o2]
139
+ E(SP_V9_RET_SINT32)
140
+ sra %o0, 0, %i0
141
+ return %i7+8
142
+ stx %o0, [%o2]
143
+ E(SPARC_RET_INT64)
144
+ stx %o0, [%i2]
145
+ return %i7+8
146
+ nop
147
+ E(SPARC_RET_INT128)
148
+ stx %o0, [%i2]
149
+ stx %o1, [%i2+8]
150
+ return %i7+8
151
+ nop
152
+ E(SPARC_RET_F_8)
153
+ st %f7, [%i2+7*4]
154
+ nop
155
+ st %f6, [%i2+6*4]
156
+ nop
157
+ E(SPARC_RET_F_6)
158
+ st %f5, [%i2+5*4]
159
+ nop
160
+ st %f4, [%i2+4*4]
161
+ nop
162
+ E(SPARC_RET_F_4)
163
+ std %f2, [%i2+2*4]
164
+ return %i7+8
165
+ std %f0, [%o2]
166
+ E(SPARC_RET_F_2)
167
+ return %i7+8
168
+ std %f0, [%o2]
169
+ E(SP_V9_RET_F_3)
170
+ st %f2, [%i2+2*4]
171
+ nop
172
+ st %f1, [%i2+1*4]
173
+ nop
174
+ E(SPARC_RET_F_1)
175
+ return %i7+8
176
+ st %f0, [%o2]
177
+
178
+ ! Finish the SPARC_RET_STRUCT sequence.
179
+ .align 8
180
+ 8: stx %o1, [%l2+8]
181
+ stx %o2, [%l2+16]
182
+ stx %o3, [%l2+24]
183
+ std %f0, [%l2+32]
184
+ std %f2, [%l2+40]
185
+ std %f4, [%l2+48]
186
+ std %f6, [%l2+56]
187
+
188
+ ! Copy the structure into place.
189
+ srl %l0, SPARC_SIZEMASK_SHIFT, %o0 ! load size_mask
190
+ mov %i2, %o1 ! load dst
191
+ mov %l2, %o2 ! load src_gp
192
+ call C(ffi_struct_float_copy)
193
+ add %l2, 32, %o3 ! load src_fp
194
+
195
+ return %i7+8
196
+ nop
197
+
198
+ .LUW2:
199
+ .size C(ffi_call_v9), . - C(ffi_call_v9)
200
+
201
+
202
+ #undef STACKFRAME
203
+ #define STACKFRAME 336 /* 16*8 register window +
204
+ 6*8 args backing store +
205
+ 20*8 locals */
206
+ #define FP %fp+STACK_BIAS
207
+
208
+ /* ffi_closure_v9(...)
209
+
210
+ Receives the closure argument in %g1. */
211
+
212
+ .align 8
213
+ .globl C(ffi_go_closure_v9)
214
+ .type C(ffi_go_closure_v9),#function
215
+ FFI_HIDDEN(C(ffi_go_closure_v9))
216
+
217
+ C(ffi_go_closure_v9):
218
+ .LUW3:
219
+ save %sp, -STACKFRAME, %sp
220
+ .LUW4:
221
+ ldx [%g5+8], %o0
222
+ ldx [%g5+16], %o1
223
+ b 0f
224
+ mov %g5, %o2
225
+
226
+ .LUW5:
227
+ .size C(ffi_go_closure_v9), . - C(ffi_go_closure_v9)
228
+
229
+ .align 8
230
+ .globl C(ffi_closure_v9)
231
+ .type C(ffi_closure_v9),#function
232
+ FFI_HIDDEN(C(ffi_closure_v9))
233
+
234
+ C(ffi_closure_v9):
235
+ .LUW6:
236
+ save %sp, -STACKFRAME, %sp
237
+ .LUW7:
238
+ ldx [%g1+FFI_TRAMPOLINE_SIZE], %o0
239
+ ldx [%g1+FFI_TRAMPOLINE_SIZE+8], %o1
240
+ ldx [%g1+FFI_TRAMPOLINE_SIZE+16], %o2
241
+ 0:
242
+ ! Store all of the potential argument registers in va_list format.
243
+ stx %i0, [FP+128+0]
244
+ stx %i1, [FP+128+8]
245
+ stx %i2, [FP+128+16]
246
+ stx %i3, [FP+128+24]
247
+ stx %i4, [FP+128+32]
248
+ stx %i5, [FP+128+40]
249
+
250
+ ! Store possible floating point argument registers too.
251
+ std %f0, [FP-128]
252
+ std %f2, [FP-120]
253
+ std %f4, [FP-112]
254
+ std %f6, [FP-104]
255
+ std %f8, [FP-96]
256
+ std %f10, [FP-88]
257
+ std %f12, [FP-80]
258
+ std %f14, [FP-72]
259
+ std %f16, [FP-64]
260
+ std %f18, [FP-56]
261
+ std %f20, [FP-48]
262
+ std %f22, [FP-40]
263
+ std %f24, [FP-32]
264
+ std %f26, [FP-24]
265
+ std %f28, [FP-16]
266
+ std %f30, [FP-8]
267
+
268
+ ! Call ffi_closure_sparc_inner to do the bulk of the work.
269
+ add %fp, STACK_BIAS-160, %o3
270
+ add %fp, STACK_BIAS+128, %o4
271
+ call C(ffi_closure_sparc_inner_v9)
272
+ add %fp, STACK_BIAS-128, %o5
273
+
274
+ 0: call 1f ! load pc in %o7
275
+ and %o0, SPARC_FLAG_RET_MASK, %o0
276
+ 1: sll %o0, 4, %o0 ! o2 = i2 * 16
277
+ add %o7, %o0, %o7 ! o7 = 0b + i2*16
278
+ jmp %o7+(2f-0b)
279
+ nop
280
+
281
+ ! Note that we cannot load the data in the delay slot of
282
+ ! the return insn because the data is in the stack frame
283
+ ! that is deallocated by the return.
284
+ .align 16
285
+ 2:
286
+ E(SPARC_RET_VOID)
287
+ return %i7+8
288
+ nop
289
+ E(SPARC_RET_STRUCT)
290
+ ldx [FP-160], %i0
291
+ ldd [FP-160], %f0
292
+ b 8f
293
+ ldx [FP-152], %i1
294
+ E(SPARC_RET_UINT8)
295
+ ldub [FP-160+7], %i0
296
+ return %i7+8
297
+ nop
298
+ E(SPARC_RET_SINT8)
299
+ ldsb [FP-160+7], %i0
300
+ return %i7+8
301
+ nop
302
+ E(SPARC_RET_UINT16)
303
+ lduh [FP-160+6], %i0
304
+ return %i7+8
305
+ nop
306
+ E(SPARC_RET_SINT16)
307
+ ldsh [FP-160+6], %i0
308
+ return %i7+8
309
+ nop
310
+ E(SPARC_RET_UINT32)
311
+ lduw [FP-160+4], %i0
312
+ return %i7+8
313
+ nop
314
+ E(SP_V9_RET_SINT32)
315
+ ldsw [FP-160+4], %i0
316
+ return %i7+8
317
+ nop
318
+ E(SPARC_RET_INT64)
319
+ ldx [FP-160], %i0
320
+ return %i7+8
321
+ nop
322
+ E(SPARC_RET_INT128)
323
+ ldx [FP-160], %i0
324
+ ldx [FP-160+8], %i1
325
+ return %i7+8
326
+ nop
327
+ E(SPARC_RET_F_8)
328
+ ld [FP-160+7*4], %f7
329
+ nop
330
+ ld [FP-160+6*4], %f6
331
+ nop
332
+ E(SPARC_RET_F_6)
333
+ ld [FP-160+5*4], %f5
334
+ nop
335
+ ld [FP-160+4*4], %f4
336
+ nop
337
+ E(SPARC_RET_F_4)
338
+ ldd [FP-160], %f0
339
+ ldd [FP-160+8], %f2
340
+ return %i7+8
341
+ nop
342
+ E(SPARC_RET_F_2)
343
+ ldd [FP-160], %f0
344
+ return %i7+8
345
+ nop
346
+ E(SP_V9_RET_F_3)
347
+ ld [FP-160+2*4], %f2
348
+ nop
349
+ ld [FP-160+1*4], %f1
350
+ nop
351
+ E(SPARC_RET_F_1)
352
+ ld [FP-160], %f0
353
+ return %i7+8
354
+ nop
355
+
356
+ ! Finish the SPARC_RET_STRUCT sequence.
357
+ .align 8
358
+ 8: ldd [FP-152], %f2
359
+ ldx [FP-144], %i2
360
+ ldd [FP-144], %f4
361
+ ldx [FP-136], %i3
362
+ ldd [FP-136], %f6
363
+ return %i7+8
364
+ nop
365
+
366
+ .LUW8:
367
+ .size C(ffi_closure_v9), . - C(ffi_closure_v9)
368
+
369
+ #ifdef HAVE_RO_EH_FRAME
370
+ .section ".eh_frame",#alloc
371
+ #else
372
+ .section ".eh_frame",#alloc,#write
373
+ #endif
374
+
375
+ #ifdef HAVE_AS_SPARC_UA_PCREL
376
+ # define FDE_RANGE(B, E) .long %r_disp32(B), E - B
377
+ #else
378
+ # define FDE_RANGE(B, E) .align 8; .xword B, E - B
379
+ #endif
380
+
381
+ .align 8
382
+ .LCIE:
383
+ .long .LECIE - .LSCIE ! CIE Length
384
+ .LSCIE:
385
+ .long 0 ! CIE Identifier Tag
386
+ .byte 1 ! CIE Version
387
+ .ascii "zR\0" ! CIE Augmentation
388
+ .byte 4 ! CIE Code Alignment Factor
389
+ .byte 0x78 ! CIE Data Alignment Factor
390
+ .byte 15 ! CIE RA Column
391
+ .byte 1 ! Augmentation size
392
+ #ifdef HAVE_AS_SPARC_UA_PCREL
393
+ .byte 0x1b ! FDE Encoding (pcrel sdata4)
394
+ #else
395
+ .byte 0x50 ! FDE Encoding (aligned absolute)
396
+ #endif
397
+ .byte 0xc, 14, 0xff, 0xf ! DW_CFA_def_cfa, %o6, offset 0x7ff
398
+ .align 8
399
+ .LECIE:
400
+
401
+ .long .LEFDE1 - .LSFDE1 ! FDE Length
402
+ .LSFDE1:
403
+ .long .LSFDE1 - .LCIE ! FDE CIE offset
404
+ FDE_RANGE(.LUW0, .LUW2)
405
+ .byte 0 ! Augmentation size
406
+ .byte 0x40+1 ! DW_CFA_advance_loc 4
407
+ .byte 0xd, 30 ! DW_CFA_def_cfa_register, %i6
408
+ .byte 0x2d ! DW_CFA_GNU_window_save
409
+ .byte 0x9, 15, 31 ! DW_CFA_register, %o7, %i7
410
+ .align 8
411
+ .LEFDE1:
412
+
413
+ .long .LEFDE2 - .LSFDE2 ! FDE Length
414
+ .LSFDE2:
415
+ .long .LSFDE2 - .LCIE ! FDE CIE offset
416
+ FDE_RANGE(.LUW3, .LUW5)
417
+ .byte 0 ! Augmentation size
418
+ .byte 0x40+1 ! DW_CFA_advance_loc 4
419
+ .byte 0xd, 30 ! DW_CFA_def_cfa_register, %i6
420
+ .byte 0x2d ! DW_CFA_GNU_window_save
421
+ .byte 0x9, 15, 31 ! DW_CFA_register, %o7, %i7
422
+ .align 8
423
+ .LEFDE2:
424
+
425
+ .long .LEFDE3 - .LSFDE3 ! FDE Length
426
+ .LSFDE3:
427
+ .long .LSFDE3 - .LCIE ! FDE CIE offset
428
+ FDE_RANGE(.LUW6, .LUW8)
429
+ .byte 0 ! Augmentation size
430
+ .byte 0x40+1 ! DW_CFA_advance_loc 4
431
+ .byte 0xd, 30 ! DW_CFA_def_cfa_register, %i6
432
+ .byte 0x2d ! DW_CFA_GNU_window_save
433
+ .byte 0x9, 15, 31 ! DW_CFA_register, %o7, %i7
434
+ .align 8
435
+ .LEFDE3:
436
+
437
+ #endif /* SPARC64 */
438
+ #ifdef __linux__
439
+ .section .note.GNU-stack,"",@progbits
440
+ #endif
@@ -0,0 +1,355 @@
1
+ /* -----------------------------------------------------------------------
2
+ ffi.c - Copyright (c) 2012 Tilera Corp.
3
+
4
+ TILE Foreign Function Interface
5
+
6
+ Permission is hereby granted, free of charge, to any person obtaining
7
+ a copy of this software and associated documentation files (the
8
+ ``Software''), to deal in the Software without restriction, including
9
+ without limitation the rights to use, copy, modify, merge, publish,
10
+ distribute, sublicense, and/or sell copies of the Software, and to
11
+ permit persons to whom the Software is furnished to do so, subject to
12
+ the following conditions:
13
+
14
+ The above copyright notice and this permission notice shall be included
15
+ in all copies or substantial portions of the Software.
16
+
17
+ THE SOFTWARE IS PROVIDED ``AS IS'', WITHOUT WARRANTY OF ANY KIND,
18
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
19
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
20
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
21
+ HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
22
+ WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
24
+ DEALINGS IN THE SOFTWARE.
25
+ ----------------------------------------------------------------------- */
26
+
27
+ #include <ffi.h>
28
+ #include <ffi_common.h>
29
+ #include <stdlib.h>
30
+ #include <stdint.h>
31
+ #include <unistd.h>
32
+ #include <arch/abi.h>
33
+ #include <arch/icache.h>
34
+ #include <arch/opcode.h>
35
+
36
+
37
+ /* The first 10 registers are used to pass arguments and return values. */
38
+ #define NUM_ARG_REGS 10
39
+
40
+ /* Performs a raw function call with the given NUM_ARG_REGS register arguments
41
+ and the specified additional stack arguments (if any). */
42
+ extern void ffi_call_tile(ffi_sarg reg_args[NUM_ARG_REGS],
43
+ const ffi_sarg *stack_args,
44
+ size_t stack_args_bytes,
45
+ void (*fnaddr)(void))
46
+ FFI_HIDDEN;
47
+
48
+ /* This handles the raw call from the closure stub, cleaning up the
49
+ parameters and delegating to ffi_closure_tile_inner. */
50
+ extern void ffi_closure_tile(void) FFI_HIDDEN;
51
+
52
+
53
+ ffi_status
54
+ ffi_prep_cif_machdep(ffi_cif *cif)
55
+ {
56
+ /* We always allocate room for all registers. Even if we don't
57
+ use them as parameters, they get returned in the same array
58
+ as struct return values so we need to make room. */
59
+ if (cif->bytes < NUM_ARG_REGS * FFI_SIZEOF_ARG)
60
+ cif->bytes = NUM_ARG_REGS * FFI_SIZEOF_ARG;
61
+
62
+ if (cif->rtype->size > NUM_ARG_REGS * FFI_SIZEOF_ARG)
63
+ cif->flags = FFI_TYPE_STRUCT;
64
+ else
65
+ cif->flags = FFI_TYPE_INT;
66
+
67
+ /* Nothing to do. */
68
+ return FFI_OK;
69
+ }
70
+
71
+
72
+ static long
73
+ assign_to_ffi_arg(ffi_sarg *out, void *in, const ffi_type *type,
74
+ int write_to_reg)
75
+ {
76
+ switch (type->type)
77
+ {
78
+ case FFI_TYPE_SINT8:
79
+ *out = *(SINT8 *)in;
80
+ return 1;
81
+
82
+ case FFI_TYPE_UINT8:
83
+ *out = *(UINT8 *)in;
84
+ return 1;
85
+
86
+ case FFI_TYPE_SINT16:
87
+ *out = *(SINT16 *)in;
88
+ return 1;
89
+
90
+ case FFI_TYPE_UINT16:
91
+ *out = *(UINT16 *)in;
92
+ return 1;
93
+
94
+ case FFI_TYPE_SINT32:
95
+ case FFI_TYPE_UINT32:
96
+ #ifndef __LP64__
97
+ case FFI_TYPE_POINTER:
98
+ #endif
99
+ /* Note that even unsigned 32-bit quantities are sign extended
100
+ on tilegx when stored in a register. */
101
+ *out = *(SINT32 *)in;
102
+ return 1;
103
+
104
+ case FFI_TYPE_FLOAT:
105
+ #ifdef __tilegx__
106
+ if (write_to_reg)
107
+ {
108
+ /* Properly sign extend the value. */
109
+ union { float f; SINT32 s32; } val;
110
+ val.f = *(float *)in;
111
+ *out = val.s32;
112
+ }
113
+ else
114
+ #endif
115
+ {
116
+ *(float *)out = *(float *)in;
117
+ }
118
+ return 1;
119
+
120
+ case FFI_TYPE_SINT64:
121
+ case FFI_TYPE_UINT64:
122
+ case FFI_TYPE_DOUBLE:
123
+ #ifdef __LP64__
124
+ case FFI_TYPE_POINTER:
125
+ #endif
126
+ *(UINT64 *)out = *(UINT64 *)in;
127
+ return sizeof(UINT64) / FFI_SIZEOF_ARG;
128
+
129
+ case FFI_TYPE_STRUCT:
130
+ memcpy(out, in, type->size);
131
+ return (type->size + FFI_SIZEOF_ARG - 1) / FFI_SIZEOF_ARG;
132
+
133
+ case FFI_TYPE_VOID:
134
+ /* Must be a return type. Nothing to do. */
135
+ return 0;
136
+
137
+ default:
138
+ FFI_ASSERT(0);
139
+ return -1;
140
+ }
141
+ }
142
+
143
+
144
+ void
145
+ ffi_call(ffi_cif *cif, void (*fn)(void), void *rvalue, void **avalue)
146
+ {
147
+ ffi_sarg * const arg_mem = alloca(cif->bytes);
148
+ ffi_sarg * const reg_args = arg_mem;
149
+ ffi_sarg * const stack_args = &reg_args[NUM_ARG_REGS];
150
+ ffi_sarg *argp = arg_mem;
151
+ ffi_type ** const arg_types = cif->arg_types;
152
+ const long num_args = cif->nargs;
153
+ long i;
154
+
155
+ if (cif->flags == FFI_TYPE_STRUCT)
156
+ {
157
+ /* Pass a hidden pointer to the return value. We make sure there
158
+ is scratch space for the callee to store the return value even if
159
+ our caller doesn't care about it. */
160
+ *argp++ = (intptr_t)(rvalue ? rvalue : alloca(cif->rtype->size));
161
+
162
+ /* No more work needed to return anything. */
163
+ rvalue = NULL;
164
+ }
165
+
166
+ for (i = 0; i < num_args; i++)
167
+ {
168
+ ffi_type *type = arg_types[i];
169
+ void * const arg_in = avalue[i];
170
+ ptrdiff_t arg_word = argp - arg_mem;
171
+
172
+ #ifndef __tilegx__
173
+ /* Doubleword-aligned values are always in an even-number register
174
+ pair, or doubleword-aligned stack slot if out of registers. */
175
+ long align = arg_word & (type->alignment > FFI_SIZEOF_ARG);
176
+ argp += align;
177
+ arg_word += align;
178
+ #endif
179
+
180
+ if (type->type == FFI_TYPE_STRUCT)
181
+ {
182
+ const size_t arg_size_in_words =
183
+ (type->size + FFI_SIZEOF_ARG - 1) / FFI_SIZEOF_ARG;
184
+
185
+ if (arg_word < NUM_ARG_REGS &&
186
+ arg_word + arg_size_in_words > NUM_ARG_REGS)
187
+ {
188
+ /* Args are not allowed to span registers and the stack. */
189
+ argp = stack_args;
190
+ }
191
+
192
+ memcpy(argp, arg_in, type->size);
193
+ argp += arg_size_in_words;
194
+ }
195
+ else
196
+ {
197
+ argp += assign_to_ffi_arg(argp, arg_in, arg_types[i], 1);
198
+ }
199
+ }
200
+
201
+ /* Actually do the call. */
202
+ ffi_call_tile(reg_args, stack_args,
203
+ cif->bytes - (NUM_ARG_REGS * FFI_SIZEOF_ARG), fn);
204
+
205
+ if (rvalue != NULL)
206
+ assign_to_ffi_arg(rvalue, reg_args, cif->rtype, 0);
207
+ }
208
+
209
+
210
+ /* Template code for closure. */
211
+ extern const UINT64 ffi_template_tramp_tile[] FFI_HIDDEN;
212
+
213
+
214
+ ffi_status
215
+ ffi_prep_closure_loc (ffi_closure *closure,
216
+ ffi_cif *cif,
217
+ void (*fun)(ffi_cif*, void*, void**, void*),
218
+ void *user_data,
219
+ void *codeloc)
220
+ {
221
+ #ifdef __tilegx__
222
+ /* TILE-Gx */
223
+ SINT64 c;
224
+ SINT64 h;
225
+ int s;
226
+ UINT64 *out;
227
+
228
+ if (cif->abi != FFI_UNIX)
229
+ return FFI_BAD_ABI;
230
+
231
+ out = (UINT64 *)closure->tramp;
232
+
233
+ c = (intptr_t)closure;
234
+ h = (intptr_t)ffi_closure_tile;
235
+ s = 0;
236
+
237
+ /* Find the smallest shift count that doesn't lose information
238
+ (i.e. no need to explicitly insert high bits of the address that
239
+ are just the sign extension of the low bits). */
240
+ while ((c >> s) != (SINT16)(c >> s) || (h >> s) != (SINT16)(h >> s))
241
+ s += 16;
242
+
243
+ #define OPS(a, b, shift) \
244
+ (create_Imm16_X0((a) >> (shift)) | create_Imm16_X1((b) >> (shift)))
245
+
246
+ /* Emit the moveli. */
247
+ *out++ = ffi_template_tramp_tile[0] | OPS(c, h, s);
248
+ for (s -= 16; s >= 0; s -= 16)
249
+ *out++ = ffi_template_tramp_tile[1] | OPS(c, h, s);
250
+
251
+ #undef OPS
252
+
253
+ *out++ = ffi_template_tramp_tile[2];
254
+
255
+ #else
256
+ /* TILEPro */
257
+ UINT64 *out;
258
+ intptr_t delta;
259
+
260
+ if (cif->abi != FFI_UNIX)
261
+ return FFI_BAD_ABI;
262
+
263
+ out = (UINT64 *)closure->tramp;
264
+ delta = (intptr_t)ffi_closure_tile - (intptr_t)codeloc;
265
+
266
+ *out++ = ffi_template_tramp_tile[0] | create_JOffLong_X1(delta >> 3);
267
+ #endif
268
+
269
+ closure->cif = cif;
270
+ closure->fun = fun;
271
+ closure->user_data = user_data;
272
+
273
+ invalidate_icache(closure->tramp, (char *)out - closure->tramp,
274
+ getpagesize());
275
+
276
+ return FFI_OK;
277
+ }
278
+
279
+
280
+ /* This is called by the assembly wrapper for closures. This does
281
+ all of the work. On entry reg_args[0] holds the values the registers
282
+ had when the closure was invoked. On return reg_args[1] holds the register
283
+ values to be returned to the caller (many of which may be garbage). */
284
+ void FFI_HIDDEN
285
+ ffi_closure_tile_inner(ffi_closure *closure,
286
+ ffi_sarg reg_args[2][NUM_ARG_REGS],
287
+ ffi_sarg *stack_args)
288
+ {
289
+ ffi_cif * const cif = closure->cif;
290
+ void ** const avalue = alloca(cif->nargs * sizeof(void *));
291
+ void *rvalue;
292
+ ffi_type ** const arg_types = cif->arg_types;
293
+ ffi_sarg * const reg_args_in = reg_args[0];
294
+ ffi_sarg * const reg_args_out = reg_args[1];
295
+ ffi_sarg * argp;
296
+ long i, arg_word, nargs = cif->nargs;
297
+ /* Use a union to guarantee proper alignment for double. */
298
+ union { ffi_sarg arg[NUM_ARG_REGS]; double d; UINT64 u64; } closure_ret;
299
+
300
+ /* Start out reading register arguments. */
301
+ argp = reg_args_in;
302
+
303
+ /* Copy the caller's structure return address to that the closure
304
+ returns the data directly to the caller. */
305
+ if (cif->flags == FFI_TYPE_STRUCT)
306
+ {
307
+ /* Return by reference via hidden pointer. */
308
+ rvalue = (void *)(intptr_t)*argp++;
309
+ arg_word = 1;
310
+ }
311
+ else
312
+ {
313
+ /* Return the value in registers. */
314
+ rvalue = &closure_ret;
315
+ arg_word = 0;
316
+ }
317
+
318
+ /* Grab the addresses of the arguments. */
319
+ for (i = 0; i < nargs; i++)
320
+ {
321
+ ffi_type * const type = arg_types[i];
322
+ const size_t arg_size_in_words =
323
+ (type->size + FFI_SIZEOF_ARG - 1) / FFI_SIZEOF_ARG;
324
+
325
+ #ifndef __tilegx__
326
+ /* Doubleword-aligned values are always in an even-number register
327
+ pair, or doubleword-aligned stack slot if out of registers. */
328
+ long align = arg_word & (type->alignment > FFI_SIZEOF_ARG);
329
+ argp += align;
330
+ arg_word += align;
331
+ #endif
332
+
333
+ if (arg_word == NUM_ARG_REGS ||
334
+ (arg_word < NUM_ARG_REGS &&
335
+ arg_word + arg_size_in_words > NUM_ARG_REGS))
336
+ {
337
+ /* Switch to reading arguments from the stack. */
338
+ argp = stack_args;
339
+ arg_word = NUM_ARG_REGS;
340
+ }
341
+
342
+ avalue[i] = argp;
343
+ argp += arg_size_in_words;
344
+ arg_word += arg_size_in_words;
345
+ }
346
+
347
+ /* Invoke the closure. */
348
+ closure->fun(cif, rvalue, avalue, closure->user_data);
349
+
350
+ if (cif->flags != FFI_TYPE_STRUCT)
351
+ {
352
+ /* Canonicalize for register representation. */
353
+ assign_to_ffi_arg(reg_args_out, &closure_ret, cif->rtype, 1);
354
+ }
355
+ }