remogatto-ffi 0.5.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (324) hide show
  1. data/LICENSE +51 -0
  2. data/README.rdoc +69 -0
  3. data/Rakefile +144 -0
  4. data/ext/ffi_c/AbstractMemory.c +489 -0
  5. data/ext/ffi_c/AbstractMemory.h +160 -0
  6. data/ext/ffi_c/ArrayType.c +129 -0
  7. data/ext/ffi_c/ArrayType.h +58 -0
  8. data/ext/ffi_c/AutoPointer.c +61 -0
  9. data/ext/ffi_c/AutoPointer.h +18 -0
  10. data/ext/ffi_c/Buffer.c +187 -0
  11. data/ext/ffi_c/Call.c +431 -0
  12. data/ext/ffi_c/Call.h +77 -0
  13. data/ext/ffi_c/DynamicLibrary.c +216 -0
  14. data/ext/ffi_c/DynamicLibrary.h +22 -0
  15. data/ext/ffi_c/Function.c +498 -0
  16. data/ext/ffi_c/Function.h +73 -0
  17. data/ext/ffi_c/FunctionInfo.c +213 -0
  18. data/ext/ffi_c/LastError.c +159 -0
  19. data/ext/ffi_c/LastError.h +18 -0
  20. data/ext/ffi_c/MemoryPointer.c +178 -0
  21. data/ext/ffi_c/MemoryPointer.h +20 -0
  22. data/ext/ffi_c/MethodHandle.c +356 -0
  23. data/ext/ffi_c/MethodHandle.h +53 -0
  24. data/ext/ffi_c/Platform.c +59 -0
  25. data/ext/ffi_c/Platform.h +16 -0
  26. data/ext/ffi_c/Pointer.c +217 -0
  27. data/ext/ffi_c/Pointer.h +49 -0
  28. data/ext/ffi_c/Struct.c +770 -0
  29. data/ext/ffi_c/Struct.h +80 -0
  30. data/ext/ffi_c/StructByValue.c +140 -0
  31. data/ext/ffi_c/StructByValue.h +53 -0
  32. data/ext/ffi_c/StructLayout.c +450 -0
  33. data/ext/ffi_c/Type.c +329 -0
  34. data/ext/ffi_c/Type.h +57 -0
  35. data/ext/ffi_c/Types.c +103 -0
  36. data/ext/ffi_c/Types.h +85 -0
  37. data/ext/ffi_c/Variadic.c +260 -0
  38. data/ext/ffi_c/compat.h +72 -0
  39. data/ext/ffi_c/endian.h +40 -0
  40. data/ext/ffi_c/extconf.rb +34 -0
  41. data/ext/ffi_c/ffi.c +80 -0
  42. data/ext/ffi_c/libffi.bsd.mk +34 -0
  43. data/ext/ffi_c/libffi.darwin.mk +75 -0
  44. data/ext/ffi_c/libffi.gnu.mk +29 -0
  45. data/ext/ffi_c/libffi.mk +13 -0
  46. data/ext/ffi_c/libffi/ChangeLog +3243 -0
  47. data/ext/ffi_c/libffi/ChangeLog.libffi +347 -0
  48. data/ext/ffi_c/libffi/ChangeLog.libgcj +40 -0
  49. data/ext/ffi_c/libffi/ChangeLog.v1 +764 -0
  50. data/ext/ffi_c/libffi/LICENSE +21 -0
  51. data/ext/ffi_c/libffi/Makefile.am +177 -0
  52. data/ext/ffi_c/libffi/Makefile.in +1640 -0
  53. data/ext/ffi_c/libffi/README +328 -0
  54. data/ext/ffi_c/libffi/TODO +1 -0
  55. data/ext/ffi_c/libffi/acinclude.m4 +92 -0
  56. data/ext/ffi_c/libffi/aclocal.m4 +7516 -0
  57. data/ext/ffi_c/libffi/compile +142 -0
  58. data/ext/ffi_c/libffi/config.guess +1516 -0
  59. data/ext/ffi_c/libffi/config.sub +1626 -0
  60. data/ext/ffi_c/libffi/configure +24414 -0
  61. data/ext/ffi_c/libffi/configure.ac +365 -0
  62. data/ext/ffi_c/libffi/configure.host +11 -0
  63. data/ext/ffi_c/libffi/depcomp +584 -0
  64. data/ext/ffi_c/libffi/doc/libffi.info +533 -0
  65. data/ext/ffi_c/libffi/doc/libffi.texi +541 -0
  66. data/ext/ffi_c/libffi/doc/stamp-vti +4 -0
  67. data/ext/ffi_c/libffi/doc/version.texi +4 -0
  68. data/ext/ffi_c/libffi/fficonfig.h.in +160 -0
  69. data/ext/ffi_c/libffi/include/Makefile.am +9 -0
  70. data/ext/ffi_c/libffi/include/Makefile.in +422 -0
  71. data/ext/ffi_c/libffi/include/ffi.h.in +393 -0
  72. data/ext/ffi_c/libffi/include/ffi_common.h +98 -0
  73. data/ext/ffi_c/libffi/install-sh +323 -0
  74. data/ext/ffi_c/libffi/libffi.pc.in +10 -0
  75. data/ext/ffi_c/libffi/libtool-version +29 -0
  76. data/ext/ffi_c/libffi/ltcf-c.sh +861 -0
  77. data/ext/ffi_c/libffi/ltcf-cxx.sh +1069 -0
  78. data/ext/ffi_c/libffi/ltcf-gcj.sh +700 -0
  79. data/ext/ffi_c/libffi/ltconfig +2862 -0
  80. data/ext/ffi_c/libffi/ltmain.sh +6930 -0
  81. data/ext/ffi_c/libffi/man/Makefile.am +8 -0
  82. data/ext/ffi_c/libffi/man/Makefile.in +395 -0
  83. data/ext/ffi_c/libffi/man/ffi.3 +31 -0
  84. data/ext/ffi_c/libffi/man/ffi_call.3 +103 -0
  85. data/ext/ffi_c/libffi/man/ffi_prep_cif.3 +66 -0
  86. data/ext/ffi_c/libffi/mdate-sh +201 -0
  87. data/ext/ffi_c/libffi/missing +353 -0
  88. data/ext/ffi_c/libffi/mkinstalldirs +158 -0
  89. data/ext/ffi_c/libffi/src/alpha/ffi.c +284 -0
  90. data/ext/ffi_c/libffi/src/alpha/ffitarget.h +48 -0
  91. data/ext/ffi_c/libffi/src/alpha/osf.S +366 -0
  92. data/ext/ffi_c/libffi/src/arm/ffi.c +309 -0
  93. data/ext/ffi_c/libffi/src/arm/ffitarget.h +49 -0
  94. data/ext/ffi_c/libffi/src/arm/sysv.S +299 -0
  95. data/ext/ffi_c/libffi/src/closures.c +596 -0
  96. data/ext/ffi_c/libffi/src/cris/ffi.c +383 -0
  97. data/ext/ffi_c/libffi/src/cris/ffitarget.h +51 -0
  98. data/ext/ffi_c/libffi/src/cris/sysv.S +215 -0
  99. data/ext/ffi_c/libffi/src/debug.c +59 -0
  100. data/ext/ffi_c/libffi/src/dlmalloc.c +5099 -0
  101. data/ext/ffi_c/libffi/src/frv/eabi.S +128 -0
  102. data/ext/ffi_c/libffi/src/frv/ffi.c +292 -0
  103. data/ext/ffi_c/libffi/src/frv/ffitarget.h +61 -0
  104. data/ext/ffi_c/libffi/src/ia64/ffi.c +580 -0
  105. data/ext/ffi_c/libffi/src/ia64/ffitarget.h +50 -0
  106. data/ext/ffi_c/libffi/src/ia64/ia64_flags.h +40 -0
  107. data/ext/ffi_c/libffi/src/ia64/unix.S +560 -0
  108. data/ext/ffi_c/libffi/src/java_raw_api.c +359 -0
  109. data/ext/ffi_c/libffi/src/m32r/ffi.c +232 -0
  110. data/ext/ffi_c/libffi/src/m32r/ffitarget.h +48 -0
  111. data/ext/ffi_c/libffi/src/m32r/sysv.S +121 -0
  112. data/ext/ffi_c/libffi/src/m68k/ffi.c +278 -0
  113. data/ext/ffi_c/libffi/src/m68k/ffitarget.h +49 -0
  114. data/ext/ffi_c/libffi/src/m68k/sysv.S +234 -0
  115. data/ext/ffi_c/libffi/src/mips/ffi.c +926 -0
  116. data/ext/ffi_c/libffi/src/mips/ffitarget.h +202 -0
  117. data/ext/ffi_c/libffi/src/mips/n32.S +534 -0
  118. data/ext/ffi_c/libffi/src/mips/o32.S +381 -0
  119. data/ext/ffi_c/libffi/src/pa/ffi.c +709 -0
  120. data/ext/ffi_c/libffi/src/pa/ffitarget.h +77 -0
  121. data/ext/ffi_c/libffi/src/pa/hpux32.S +368 -0
  122. data/ext/ffi_c/libffi/src/pa/linux.S +357 -0
  123. data/ext/ffi_c/libffi/src/powerpc/aix.S +225 -0
  124. data/ext/ffi_c/libffi/src/powerpc/aix_closure.S +247 -0
  125. data/ext/ffi_c/libffi/src/powerpc/asm.h +125 -0
  126. data/ext/ffi_c/libffi/src/powerpc/darwin.S +245 -0
  127. data/ext/ffi_c/libffi/src/powerpc/darwin_closure.S +317 -0
  128. data/ext/ffi_c/libffi/src/powerpc/ffi.c +1429 -0
  129. data/ext/ffi_c/libffi/src/powerpc/ffi_darwin.c +800 -0
  130. data/ext/ffi_c/libffi/src/powerpc/ffitarget.h +118 -0
  131. data/ext/ffi_c/libffi/src/powerpc/linux64.S +187 -0
  132. data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +236 -0
  133. data/ext/ffi_c/libffi/src/powerpc/ppc_closure.S +327 -0
  134. data/ext/ffi_c/libffi/src/powerpc/sysv.S +230 -0
  135. data/ext/ffi_c/libffi/src/prep_cif.c +174 -0
  136. data/ext/ffi_c/libffi/src/raw_api.c +254 -0
  137. data/ext/ffi_c/libffi/src/s390/ffi.c +780 -0
  138. data/ext/ffi_c/libffi/src/s390/ffitarget.h +60 -0
  139. data/ext/ffi_c/libffi/src/s390/sysv.S +434 -0
  140. data/ext/ffi_c/libffi/src/sh/ffi.c +716 -0
  141. data/ext/ffi_c/libffi/src/sh/ffitarget.h +49 -0
  142. data/ext/ffi_c/libffi/src/sh/sysv.S +850 -0
  143. data/ext/ffi_c/libffi/src/sh64/ffi.c +453 -0
  144. data/ext/ffi_c/libffi/src/sh64/ffitarget.h +53 -0
  145. data/ext/ffi_c/libffi/src/sh64/sysv.S +530 -0
  146. data/ext/ffi_c/libffi/src/sparc/ffi.c +610 -0
  147. data/ext/ffi_c/libffi/src/sparc/ffitarget.h +66 -0
  148. data/ext/ffi_c/libffi/src/sparc/v8.S +272 -0
  149. data/ext/ffi_c/libffi/src/sparc/v9.S +307 -0
  150. data/ext/ffi_c/libffi/src/types.c +77 -0
  151. data/ext/ffi_c/libffi/src/x86/darwin.S +443 -0
  152. data/ext/ffi_c/libffi/src/x86/darwin64.S +416 -0
  153. data/ext/ffi_c/libffi/src/x86/ffi.c +475 -0
  154. data/ext/ffi_c/libffi/src/x86/ffi64.c +572 -0
  155. data/ext/ffi_c/libffi/src/x86/ffitarget.h +90 -0
  156. data/ext/ffi_c/libffi/src/x86/freebsd.S +458 -0
  157. data/ext/ffi_c/libffi/src/x86/sysv.S +437 -0
  158. data/ext/ffi_c/libffi/src/x86/unix64.S +418 -0
  159. data/ext/ffi_c/libffi/src/x86/win32.S +391 -0
  160. data/ext/ffi_c/libffi/testsuite/Makefile.am +71 -0
  161. data/ext/ffi_c/libffi/testsuite/Makefile.in +447 -0
  162. data/ext/ffi_c/libffi/testsuite/config/default.exp +1 -0
  163. data/ext/ffi_c/libffi/testsuite/lib/libffi-dg.exp +289 -0
  164. data/ext/ffi_c/libffi/testsuite/lib/target-libpath.exp +263 -0
  165. data/ext/ffi_c/libffi/testsuite/lib/wrapper.exp +45 -0
  166. data/ext/ffi_c/libffi/testsuite/libffi.call/call.exp +36 -0
  167. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn0.c +97 -0
  168. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn1.c +89 -0
  169. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn2.c +89 -0
  170. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn3.c +90 -0
  171. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn4.c +97 -0
  172. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn5.c +99 -0
  173. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn6.c +98 -0
  174. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_stdcall.c +72 -0
  175. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_12byte.c +102 -0
  176. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_16byte.c +103 -0
  177. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_18byte.c +104 -0
  178. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_19byte.c +110 -0
  179. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_1_1byte.c +97 -0
  180. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_20byte.c +99 -0
  181. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_20byte1.c +101 -0
  182. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_24byte.c +121 -0
  183. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_2byte.c +98 -0
  184. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3_1byte.c +103 -0
  185. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3byte1.c +98 -0
  186. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3byte2.c +98 -0
  187. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_4_1byte.c +106 -0
  188. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_4byte.c +98 -0
  189. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_5_1_byte.c +117 -0
  190. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_5byte.c +106 -0
  191. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_64byte.c +132 -0
  192. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_6_1_byte.c +121 -0
  193. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_6byte.c +107 -0
  194. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_7_1_byte.c +125 -0
  195. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_7byte.c +105 -0
  196. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_8byte.c +96 -0
  197. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_9byte1.c +98 -0
  198. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_9byte2.c +99 -0
  199. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_double.c +101 -0
  200. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_float.c +99 -0
  201. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_longdouble.c +100 -0
  202. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_pointer.c +101 -0
  203. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint16.c +99 -0
  204. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint32.c +99 -0
  205. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint64.c +99 -0
  206. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint16.c +99 -0
  207. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint32.c +99 -0
  208. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint64.c +100 -0
  209. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_double.c +51 -0
  210. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_float.c +51 -0
  211. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_schar.c +82 -0
  212. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_sshort.c +82 -0
  213. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_sshortchar.c +94 -0
  214. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_uchar.c +99 -0
  215. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_ushort.c +82 -0
  216. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_ushortchar.c +94 -0
  217. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_schar.c +52 -0
  218. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_sint.c +50 -0
  219. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_sshort.c +50 -0
  220. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uchar.c +50 -0
  221. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uint.c +51 -0
  222. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ulonglong.c +54 -0
  223. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ushort.c +51 -0
  224. data/ext/ffi_c/libffi/testsuite/libffi.call/ffitest.h +86 -0
  225. data/ext/ffi_c/libffi/testsuite/libffi.call/float.c +59 -0
  226. data/ext/ffi_c/libffi/testsuite/libffi.call/float1.c +58 -0
  227. data/ext/ffi_c/libffi/testsuite/libffi.call/float2.c +57 -0
  228. data/ext/ffi_c/libffi/testsuite/libffi.call/float3.c +72 -0
  229. data/ext/ffi_c/libffi/testsuite/libffi.call/float4.c +62 -0
  230. data/ext/ffi_c/libffi/testsuite/libffi.call/many.c +69 -0
  231. data/ext/ffi_c/libffi/testsuite/libffi.call/many_win32.c +63 -0
  232. data/ext/ffi_c/libffi/testsuite/libffi.call/negint.c +53 -0
  233. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct.c +160 -0
  234. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct1.c +169 -0
  235. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct10.c +141 -0
  236. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct2.c +118 -0
  237. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct3.c +119 -0
  238. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct4.c +119 -0
  239. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct5.c +120 -0
  240. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct6.c +139 -0
  241. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct7.c +119 -0
  242. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct8.c +139 -0
  243. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct9.c +139 -0
  244. data/ext/ffi_c/libffi/testsuite/libffi.call/problem1.c +98 -0
  245. data/ext/ffi_c/libffi/testsuite/libffi.call/promotion.c +59 -0
  246. data/ext/ffi_c/libffi/testsuite/libffi.call/pyobjc-tc.c +114 -0
  247. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl.c +35 -0
  248. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl1.c +43 -0
  249. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl2.c +42 -0
  250. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl.c +35 -0
  251. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl1.c +36 -0
  252. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl2.c +49 -0
  253. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl3.c +42 -0
  254. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ldl.c +34 -0
  255. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll.c +41 -0
  256. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll1.c +42 -0
  257. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sc.c +36 -0
  258. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sl.c +38 -0
  259. data/ext/ffi_c/libffi/testsuite/libffi.call/return_uc.c +38 -0
  260. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ul.c +38 -0
  261. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen.c +44 -0
  262. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen_win32.c +44 -0
  263. data/ext/ffi_c/libffi/testsuite/libffi.call/struct1.c +65 -0
  264. data/ext/ffi_c/libffi/testsuite/libffi.call/struct2.c +67 -0
  265. data/ext/ffi_c/libffi/testsuite/libffi.call/struct3.c +59 -0
  266. data/ext/ffi_c/libffi/testsuite/libffi.call/struct4.c +63 -0
  267. data/ext/ffi_c/libffi/testsuite/libffi.call/struct5.c +65 -0
  268. data/ext/ffi_c/libffi/testsuite/libffi.call/struct6.c +64 -0
  269. data/ext/ffi_c/libffi/testsuite/libffi.call/struct7.c +74 -0
  270. data/ext/ffi_c/libffi/testsuite/libffi.call/struct8.c +80 -0
  271. data/ext/ffi_c/libffi/testsuite/libffi.call/struct9.c +67 -0
  272. data/ext/ffi_c/libffi/testsuite/libffi.special/ffitestcxx.h +86 -0
  273. data/ext/ffi_c/libffi/testsuite/libffi.special/special.exp +38 -0
  274. data/ext/ffi_c/libffi/testsuite/libffi.special/unwindtest.cc +123 -0
  275. data/ext/ffi_c/libffi/testsuite/libffi.special/unwindtest_ffi_call.cc +53 -0
  276. data/ext/ffi_c/libffi/texinfo.tex +7482 -0
  277. data/ext/ffi_c/rbffi.h +26 -0
  278. data/gen/Rakefile +12 -0
  279. data/lib/ffi.rb +11 -0
  280. data/lib/ffi/autopointer.rb +61 -0
  281. data/lib/ffi/buffer.rb +0 -0
  282. data/lib/ffi/callback.rb +10 -0
  283. data/lib/ffi/enum.rb +78 -0
  284. data/lib/ffi/errno.rb +8 -0
  285. data/lib/ffi/ffi.rb +99 -0
  286. data/lib/ffi/io.rb +21 -0
  287. data/lib/ffi/library.rb +218 -0
  288. data/lib/ffi/managedstruct.rb +55 -0
  289. data/lib/ffi/memorypointer.rb +73 -0
  290. data/lib/ffi/platform.rb +78 -0
  291. data/lib/ffi/pointer.rb +119 -0
  292. data/lib/ffi/struct.rb +164 -0
  293. data/lib/ffi/tools/const_generator.rb +177 -0
  294. data/lib/ffi/tools/generator.rb +58 -0
  295. data/lib/ffi/tools/generator_task.rb +35 -0
  296. data/lib/ffi/tools/struct_generator.rb +194 -0
  297. data/lib/ffi/tools/types_generator.rb +123 -0
  298. data/lib/ffi/types.rb +153 -0
  299. data/lib/ffi/union.rb +12 -0
  300. data/lib/ffi/variadic.rb +25 -0
  301. data/spec/ffi/bool_spec.rb +24 -0
  302. data/spec/ffi/buffer_spec.rb +202 -0
  303. data/spec/ffi/callback_spec.rb +591 -0
  304. data/spec/ffi/enum_spec.rb +164 -0
  305. data/spec/ffi/errno_spec.rb +13 -0
  306. data/spec/ffi/function_spec.rb +47 -0
  307. data/spec/ffi/library_spec.rb +144 -0
  308. data/spec/ffi/managed_struct_spec.rb +56 -0
  309. data/spec/ffi/number_spec.rb +231 -0
  310. data/spec/ffi/pointer_spec.rb +195 -0
  311. data/spec/ffi/rbx/attach_function_spec.rb +27 -0
  312. data/spec/ffi/rbx/memory_pointer_spec.rb +102 -0
  313. data/spec/ffi/rbx/spec_helper.rb +1 -0
  314. data/spec/ffi/rbx/struct_spec.rb +13 -0
  315. data/spec/ffi/spec_helper.rb +17 -0
  316. data/spec/ffi/string_spec.rb +103 -0
  317. data/spec/ffi/struct_callback_spec.rb +62 -0
  318. data/spec/ffi/struct_initialize_spec.rb +30 -0
  319. data/spec/ffi/struct_spec.rb +529 -0
  320. data/spec/ffi/typedef_spec.rb +48 -0
  321. data/spec/ffi/union_spec.rb +60 -0
  322. data/spec/ffi/variadic_spec.rb +84 -0
  323. data/spec/spec.opts +4 -0
  324. metadata +432 -0
@@ -0,0 +1,580 @@
1
+ /* -----------------------------------------------------------------------
2
+ ffi.c - Copyright (c) 1998, 2007, 2008 Red Hat, Inc.
3
+ Copyright (c) 2000 Hewlett Packard Company
4
+
5
+ IA64 Foreign Function Interface
6
+
7
+ Permission is hereby granted, free of charge, to any person obtaining
8
+ a copy of this software and associated documentation files (the
9
+ ``Software''), to deal in the Software without restriction, including
10
+ without limitation the rights to use, copy, modify, merge, publish,
11
+ distribute, sublicense, and/or sell copies of the Software, and to
12
+ permit persons to whom the Software is furnished to do so, subject to
13
+ the following conditions:
14
+
15
+ The above copyright notice and this permission notice shall be included
16
+ in all copies or substantial portions of the Software.
17
+
18
+ THE SOFTWARE IS PROVIDED ``AS IS'', WITHOUT WARRANTY OF ANY KIND,
19
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
21
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
22
+ HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
23
+ WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
24
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
25
+ DEALINGS IN THE SOFTWARE.
26
+ ----------------------------------------------------------------------- */
27
+
28
+ #include <ffi.h>
29
+ #include <ffi_common.h>
30
+
31
+ #include <stdlib.h>
32
+ #include <stdbool.h>
33
+ #include <float.h>
34
+
35
+ #include "ia64_flags.h"
36
+
37
+ /* A 64-bit pointer value. In LP64 mode, this is effectively a plain
38
+ pointer. In ILP32 mode, it's a pointer that's been extended to
39
+ 64 bits by "addp4". */
40
+ typedef void *PTR64 __attribute__((mode(DI)));
41
+
42
+ /* Memory image of fp register contents. This is the implementation
43
+ specific format used by ldf.fill/stf.spill. All we care about is
44
+ that it wants a 16 byte aligned slot. */
45
+ typedef struct
46
+ {
47
+ UINT64 x[2] __attribute__((aligned(16)));
48
+ } fpreg;
49
+
50
+
51
+ /* The stack layout given to ffi_call_unix and ffi_closure_unix_inner. */
52
+
53
+ struct ia64_args
54
+ {
55
+ fpreg fp_regs[8]; /* Contents of 8 fp arg registers. */
56
+ UINT64 gp_regs[8]; /* Contents of 8 gp arg registers. */
57
+ UINT64 other_args[]; /* Arguments passed on stack, variable size. */
58
+ };
59
+
60
+
61
+ /* Adjust ADDR, a pointer to an 8 byte slot, to point to the low LEN bytes. */
62
+
63
+ static inline void *
64
+ endian_adjust (void *addr, size_t len)
65
+ {
66
+ #ifdef __BIG_ENDIAN__
67
+ return addr + (8 - len);
68
+ #else
69
+ return addr;
70
+ #endif
71
+ }
72
+
73
+ /* Store VALUE to ADDR in the current cpu implementation's fp spill format.
74
+ This is a macro instead of a function, so that it works for all 3 floating
75
+ point types without type conversions. Type conversion to long double breaks
76
+ the denorm support. */
77
+
78
+ #define stf_spill(addr, value) \
79
+ asm ("stf.spill %0 = %1%P0" : "=m" (*addr) : "f"(value));
80
+
81
+ /* Load a value from ADDR, which is in the current cpu implementation's
82
+ fp spill format. As above, this must also be a macro. */
83
+
84
+ #define ldf_fill(result, addr) \
85
+ asm ("ldf.fill %0 = %1%P1" : "=f"(result) : "m"(*addr));
86
+
87
+ /* Return the size of the C type associated with with TYPE. Which will
88
+ be one of the FFI_IA64_TYPE_HFA_* values. */
89
+
90
+ static size_t
91
+ hfa_type_size (int type)
92
+ {
93
+ switch (type)
94
+ {
95
+ case FFI_IA64_TYPE_HFA_FLOAT:
96
+ return sizeof(float);
97
+ case FFI_IA64_TYPE_HFA_DOUBLE:
98
+ return sizeof(double);
99
+ case FFI_IA64_TYPE_HFA_LDOUBLE:
100
+ return sizeof(__float80);
101
+ default:
102
+ abort ();
103
+ }
104
+ }
105
+
106
+ /* Load from ADDR a value indicated by TYPE. Which will be one of
107
+ the FFI_IA64_TYPE_HFA_* values. */
108
+
109
+ static void
110
+ hfa_type_load (fpreg *fpaddr, int type, void *addr)
111
+ {
112
+ switch (type)
113
+ {
114
+ case FFI_IA64_TYPE_HFA_FLOAT:
115
+ stf_spill (fpaddr, *(float *) addr);
116
+ return;
117
+ case FFI_IA64_TYPE_HFA_DOUBLE:
118
+ stf_spill (fpaddr, *(double *) addr);
119
+ return;
120
+ case FFI_IA64_TYPE_HFA_LDOUBLE:
121
+ stf_spill (fpaddr, *(__float80 *) addr);
122
+ return;
123
+ default:
124
+ abort ();
125
+ }
126
+ }
127
+
128
+ /* Load VALUE into ADDR as indicated by TYPE. Which will be one of
129
+ the FFI_IA64_TYPE_HFA_* values. */
130
+
131
+ static void
132
+ hfa_type_store (int type, void *addr, fpreg *fpaddr)
133
+ {
134
+ switch (type)
135
+ {
136
+ case FFI_IA64_TYPE_HFA_FLOAT:
137
+ {
138
+ float result;
139
+ ldf_fill (result, fpaddr);
140
+ *(float *) addr = result;
141
+ break;
142
+ }
143
+ case FFI_IA64_TYPE_HFA_DOUBLE:
144
+ {
145
+ double result;
146
+ ldf_fill (result, fpaddr);
147
+ *(double *) addr = result;
148
+ break;
149
+ }
150
+ case FFI_IA64_TYPE_HFA_LDOUBLE:
151
+ {
152
+ __float80 result;
153
+ ldf_fill (result, fpaddr);
154
+ *(__float80 *) addr = result;
155
+ break;
156
+ }
157
+ default:
158
+ abort ();
159
+ }
160
+ }
161
+
162
+ /* Is TYPE a struct containing floats, doubles, or extended doubles,
163
+ all of the same fp type? If so, return the element type. Return
164
+ FFI_TYPE_VOID if not. */
165
+
166
+ static int
167
+ hfa_element_type (ffi_type *type, int nested)
168
+ {
169
+ int element = FFI_TYPE_VOID;
170
+
171
+ switch (type->type)
172
+ {
173
+ case FFI_TYPE_FLOAT:
174
+ /* We want to return VOID for raw floating-point types, but the
175
+ synthetic HFA type if we're nested within an aggregate. */
176
+ if (nested)
177
+ element = FFI_IA64_TYPE_HFA_FLOAT;
178
+ break;
179
+
180
+ case FFI_TYPE_DOUBLE:
181
+ /* Similarly. */
182
+ if (nested)
183
+ element = FFI_IA64_TYPE_HFA_DOUBLE;
184
+ break;
185
+
186
+ case FFI_TYPE_LONGDOUBLE:
187
+ /* Similarly, except that that HFA is true for double extended,
188
+ but not quad precision. Both have sizeof == 16, so tell the
189
+ difference based on the precision. */
190
+ if (LDBL_MANT_DIG == 64 && nested)
191
+ element = FFI_IA64_TYPE_HFA_LDOUBLE;
192
+ break;
193
+
194
+ case FFI_TYPE_STRUCT:
195
+ {
196
+ ffi_type **ptr = &type->elements[0];
197
+
198
+ for (ptr = &type->elements[0]; *ptr ; ptr++)
199
+ {
200
+ int sub_element = hfa_element_type (*ptr, 1);
201
+ if (sub_element == FFI_TYPE_VOID)
202
+ return FFI_TYPE_VOID;
203
+
204
+ if (element == FFI_TYPE_VOID)
205
+ element = sub_element;
206
+ else if (element != sub_element)
207
+ return FFI_TYPE_VOID;
208
+ }
209
+ }
210
+ break;
211
+
212
+ default:
213
+ return FFI_TYPE_VOID;
214
+ }
215
+
216
+ return element;
217
+ }
218
+
219
+
220
+ /* Perform machine dependent cif processing. */
221
+
222
+ ffi_status
223
+ ffi_prep_cif_machdep(ffi_cif *cif)
224
+ {
225
+ int flags;
226
+
227
+ /* Adjust cif->bytes to include space for the bits of the ia64_args frame
228
+ that preceeds the integer register portion. The estimate that the
229
+ generic bits did for the argument space required is good enough for the
230
+ integer component. */
231
+ cif->bytes += offsetof(struct ia64_args, gp_regs[0]);
232
+ if (cif->bytes < sizeof(struct ia64_args))
233
+ cif->bytes = sizeof(struct ia64_args);
234
+
235
+ /* Set the return type flag. */
236
+ flags = cif->rtype->type;
237
+ switch (cif->rtype->type)
238
+ {
239
+ case FFI_TYPE_LONGDOUBLE:
240
+ /* Leave FFI_TYPE_LONGDOUBLE as meaning double extended precision,
241
+ and encode quad precision as a two-word integer structure. */
242
+ if (LDBL_MANT_DIG != 64)
243
+ flags = FFI_IA64_TYPE_SMALL_STRUCT | (16 << 8);
244
+ break;
245
+
246
+ case FFI_TYPE_STRUCT:
247
+ {
248
+ size_t size = cif->rtype->size;
249
+ int hfa_type = hfa_element_type (cif->rtype, 0);
250
+
251
+ if (hfa_type != FFI_TYPE_VOID)
252
+ {
253
+ size_t nelts = size / hfa_type_size (hfa_type);
254
+ if (nelts <= 8)
255
+ flags = hfa_type | (size << 8);
256
+ }
257
+ else
258
+ {
259
+ if (size <= 32)
260
+ flags = FFI_IA64_TYPE_SMALL_STRUCT | (size << 8);
261
+ }
262
+ }
263
+ break;
264
+
265
+ default:
266
+ break;
267
+ }
268
+ cif->flags = flags;
269
+
270
+ return FFI_OK;
271
+ }
272
+
273
+ extern int ffi_call_unix (struct ia64_args *, PTR64, void (*)(void), UINT64);
274
+
275
+ void
276
+ ffi_call(ffi_cif *cif, void (*fn)(void), void *rvalue, void **avalue)
277
+ {
278
+ struct ia64_args *stack;
279
+ long i, avn, gpcount, fpcount;
280
+ ffi_type **p_arg;
281
+
282
+ FFI_ASSERT (cif->abi == FFI_UNIX);
283
+
284
+ /* If we have no spot for a return value, make one. */
285
+ if (rvalue == NULL && cif->rtype->type != FFI_TYPE_VOID)
286
+ rvalue = alloca (cif->rtype->size);
287
+
288
+ /* Allocate the stack frame. */
289
+ stack = alloca (cif->bytes);
290
+
291
+ gpcount = fpcount = 0;
292
+ avn = cif->nargs;
293
+ for (i = 0, p_arg = cif->arg_types; i < avn; i++, p_arg++)
294
+ {
295
+ switch ((*p_arg)->type)
296
+ {
297
+ case FFI_TYPE_SINT8:
298
+ stack->gp_regs[gpcount++] = *(SINT8 *)avalue[i];
299
+ break;
300
+ case FFI_TYPE_UINT8:
301
+ stack->gp_regs[gpcount++] = *(UINT8 *)avalue[i];
302
+ break;
303
+ case FFI_TYPE_SINT16:
304
+ stack->gp_regs[gpcount++] = *(SINT16 *)avalue[i];
305
+ break;
306
+ case FFI_TYPE_UINT16:
307
+ stack->gp_regs[gpcount++] = *(UINT16 *)avalue[i];
308
+ break;
309
+ case FFI_TYPE_SINT32:
310
+ stack->gp_regs[gpcount++] = *(SINT32 *)avalue[i];
311
+ break;
312
+ case FFI_TYPE_UINT32:
313
+ stack->gp_regs[gpcount++] = *(UINT32 *)avalue[i];
314
+ break;
315
+ case FFI_TYPE_SINT64:
316
+ case FFI_TYPE_UINT64:
317
+ stack->gp_regs[gpcount++] = *(UINT64 *)avalue[i];
318
+ break;
319
+
320
+ case FFI_TYPE_POINTER:
321
+ stack->gp_regs[gpcount++] = (UINT64)(PTR64) *(void **)avalue[i];
322
+ break;
323
+
324
+ case FFI_TYPE_FLOAT:
325
+ if (gpcount < 8 && fpcount < 8)
326
+ stf_spill (&stack->fp_regs[fpcount++], *(float *)avalue[i]);
327
+ stack->gp_regs[gpcount++] = *(UINT32 *)avalue[i];
328
+ break;
329
+
330
+ case FFI_TYPE_DOUBLE:
331
+ if (gpcount < 8 && fpcount < 8)
332
+ stf_spill (&stack->fp_regs[fpcount++], *(double *)avalue[i]);
333
+ stack->gp_regs[gpcount++] = *(UINT64 *)avalue[i];
334
+ break;
335
+
336
+ case FFI_TYPE_LONGDOUBLE:
337
+ if (gpcount & 1)
338
+ gpcount++;
339
+ if (LDBL_MANT_DIG == 64 && gpcount < 8 && fpcount < 8)
340
+ stf_spill (&stack->fp_regs[fpcount++], *(__float80 *)avalue[i]);
341
+ memcpy (&stack->gp_regs[gpcount], avalue[i], 16);
342
+ gpcount += 2;
343
+ break;
344
+
345
+ case FFI_TYPE_STRUCT:
346
+ {
347
+ size_t size = (*p_arg)->size;
348
+ size_t align = (*p_arg)->alignment;
349
+ int hfa_type = hfa_element_type (*p_arg, 0);
350
+
351
+ FFI_ASSERT (align <= 16);
352
+ if (align == 16 && (gpcount & 1))
353
+ gpcount++;
354
+
355
+ if (hfa_type != FFI_TYPE_VOID)
356
+ {
357
+ size_t hfa_size = hfa_type_size (hfa_type);
358
+ size_t offset = 0;
359
+ size_t gp_offset = gpcount * 8;
360
+
361
+ while (fpcount < 8
362
+ && offset < size
363
+ && gp_offset < 8 * 8)
364
+ {
365
+ hfa_type_load (&stack->fp_regs[fpcount], hfa_type,
366
+ avalue[i] + offset);
367
+ offset += hfa_size;
368
+ gp_offset += hfa_size;
369
+ fpcount += 1;
370
+ }
371
+ }
372
+
373
+ memcpy (&stack->gp_regs[gpcount], avalue[i], size);
374
+ gpcount += (size + 7) / 8;
375
+ }
376
+ break;
377
+
378
+ default:
379
+ abort ();
380
+ }
381
+ }
382
+
383
+ ffi_call_unix (stack, rvalue, fn, cif->flags);
384
+ }
385
+
386
+ /* Closures represent a pair consisting of a function pointer, and
387
+ some user data. A closure is invoked by reinterpreting the closure
388
+ as a function pointer, and branching to it. Thus we can make an
389
+ interpreted function callable as a C function: We turn the
390
+ interpreter itself, together with a pointer specifying the
391
+ interpreted procedure, into a closure.
392
+
393
+ For IA64, function pointer are already pairs consisting of a code
394
+ pointer, and a gp pointer. The latter is needed to access global
395
+ variables. Here we set up such a pair as the first two words of
396
+ the closure (in the "trampoline" area), but we replace the gp
397
+ pointer with a pointer to the closure itself. We also add the real
398
+ gp pointer to the closure. This allows the function entry code to
399
+ both retrieve the user data, and to restire the correct gp pointer. */
400
+
401
+ extern void ffi_closure_unix ();
402
+
403
+ ffi_status
404
+ ffi_prep_closure_loc (ffi_closure* closure,
405
+ ffi_cif* cif,
406
+ void (*fun)(ffi_cif*,void*,void**,void*),
407
+ void *user_data,
408
+ void *codeloc)
409
+ {
410
+ /* The layout of a function descriptor. A C function pointer really
411
+ points to one of these. */
412
+ struct ia64_fd
413
+ {
414
+ UINT64 code_pointer;
415
+ UINT64 gp;
416
+ };
417
+
418
+ struct ffi_ia64_trampoline_struct
419
+ {
420
+ UINT64 code_pointer; /* Pointer to ffi_closure_unix. */
421
+ UINT64 fake_gp; /* Pointer to closure, installed as gp. */
422
+ UINT64 real_gp; /* Real gp value. */
423
+ };
424
+
425
+ struct ffi_ia64_trampoline_struct *tramp;
426
+ struct ia64_fd *fd;
427
+
428
+ FFI_ASSERT (cif->abi == FFI_UNIX);
429
+
430
+ tramp = (struct ffi_ia64_trampoline_struct *)closure->tramp;
431
+ fd = (struct ia64_fd *)(void *)ffi_closure_unix;
432
+
433
+ tramp->code_pointer = fd->code_pointer;
434
+ tramp->real_gp = fd->gp;
435
+ tramp->fake_gp = (UINT64)(PTR64)codeloc;
436
+ closure->cif = cif;
437
+ closure->user_data = user_data;
438
+ closure->fun = fun;
439
+
440
+ return FFI_OK;
441
+ }
442
+
443
+
444
+ UINT64
445
+ ffi_closure_unix_inner (ffi_closure *closure, struct ia64_args *stack,
446
+ void *rvalue, void *r8)
447
+ {
448
+ ffi_cif *cif;
449
+ void **avalue;
450
+ ffi_type **p_arg;
451
+ long i, avn, gpcount, fpcount;
452
+
453
+ cif = closure->cif;
454
+ avn = cif->nargs;
455
+ avalue = alloca (avn * sizeof (void *));
456
+
457
+ /* If the structure return value is passed in memory get that location
458
+ from r8 so as to pass the value directly back to the caller. */
459
+ if (cif->flags == FFI_TYPE_STRUCT)
460
+ rvalue = r8;
461
+
462
+ gpcount = fpcount = 0;
463
+ for (i = 0, p_arg = cif->arg_types; i < avn; i++, p_arg++)
464
+ {
465
+ switch ((*p_arg)->type)
466
+ {
467
+ case FFI_TYPE_SINT8:
468
+ case FFI_TYPE_UINT8:
469
+ avalue[i] = endian_adjust(&stack->gp_regs[gpcount++], 1);
470
+ break;
471
+ case FFI_TYPE_SINT16:
472
+ case FFI_TYPE_UINT16:
473
+ avalue[i] = endian_adjust(&stack->gp_regs[gpcount++], 2);
474
+ break;
475
+ case FFI_TYPE_SINT32:
476
+ case FFI_TYPE_UINT32:
477
+ avalue[i] = endian_adjust(&stack->gp_regs[gpcount++], 4);
478
+ break;
479
+ case FFI_TYPE_SINT64:
480
+ case FFI_TYPE_UINT64:
481
+ avalue[i] = &stack->gp_regs[gpcount++];
482
+ break;
483
+ case FFI_TYPE_POINTER:
484
+ avalue[i] = endian_adjust(&stack->gp_regs[gpcount++], sizeof(void*));
485
+ break;
486
+
487
+ case FFI_TYPE_FLOAT:
488
+ if (gpcount < 8 && fpcount < 8)
489
+ {
490
+ fpreg *addr = &stack->fp_regs[fpcount++];
491
+ float result;
492
+ avalue[i] = addr;
493
+ ldf_fill (result, addr);
494
+ *(float *)addr = result;
495
+ }
496
+ else
497
+ avalue[i] = endian_adjust(&stack->gp_regs[gpcount], 4);
498
+ gpcount++;
499
+ break;
500
+
501
+ case FFI_TYPE_DOUBLE:
502
+ if (gpcount < 8 && fpcount < 8)
503
+ {
504
+ fpreg *addr = &stack->fp_regs[fpcount++];
505
+ double result;
506
+ avalue[i] = addr;
507
+ ldf_fill (result, addr);
508
+ *(double *)addr = result;
509
+ }
510
+ else
511
+ avalue[i] = &stack->gp_regs[gpcount];
512
+ gpcount++;
513
+ break;
514
+
515
+ case FFI_TYPE_LONGDOUBLE:
516
+ if (gpcount & 1)
517
+ gpcount++;
518
+ if (LDBL_MANT_DIG == 64 && gpcount < 8 && fpcount < 8)
519
+ {
520
+ fpreg *addr = &stack->fp_regs[fpcount++];
521
+ __float80 result;
522
+ avalue[i] = addr;
523
+ ldf_fill (result, addr);
524
+ *(__float80 *)addr = result;
525
+ }
526
+ else
527
+ avalue[i] = &stack->gp_regs[gpcount];
528
+ gpcount += 2;
529
+ break;
530
+
531
+ case FFI_TYPE_STRUCT:
532
+ {
533
+ size_t size = (*p_arg)->size;
534
+ size_t align = (*p_arg)->alignment;
535
+ int hfa_type = hfa_element_type (*p_arg, 0);
536
+
537
+ FFI_ASSERT (align <= 16);
538
+ if (align == 16 && (gpcount & 1))
539
+ gpcount++;
540
+
541
+ if (hfa_type != FFI_TYPE_VOID)
542
+ {
543
+ size_t hfa_size = hfa_type_size (hfa_type);
544
+ size_t offset = 0;
545
+ size_t gp_offset = gpcount * 8;
546
+ void *addr = alloca (size);
547
+
548
+ avalue[i] = addr;
549
+
550
+ while (fpcount < 8
551
+ && offset < size
552
+ && gp_offset < 8 * 8)
553
+ {
554
+ hfa_type_store (hfa_type, addr + offset,
555
+ &stack->fp_regs[fpcount]);
556
+ offset += hfa_size;
557
+ gp_offset += hfa_size;
558
+ fpcount += 1;
559
+ }
560
+
561
+ if (offset < size)
562
+ memcpy (addr + offset, (char *)stack->gp_regs + gp_offset,
563
+ size - offset);
564
+ }
565
+ else
566
+ avalue[i] = &stack->gp_regs[gpcount];
567
+
568
+ gpcount += (size + 7) / 8;
569
+ }
570
+ break;
571
+
572
+ default:
573
+ abort ();
574
+ }
575
+ }
576
+
577
+ closure->fun (cif, rvalue, avalue, closure->user_data);
578
+
579
+ return cif->flags;
580
+ }