ffi 1.9.21-x86-mingw32 → 1.9.22-x86-mingw32

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of ffi might be problematic. Click here for more details.

Files changed (551) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +22 -0
  3. data/.gitmodules +3 -0
  4. data/.travis.yml +52 -0
  5. data/.yardopts +5 -0
  6. data/Gemfile +15 -0
  7. data/{spec/ffi/LICENSE.SPECS → LICENSE.SPECS} +1 -1
  8. data/README.md +1 -1
  9. data/Rakefile +28 -3
  10. data/appveyor.yml +22 -0
  11. data/ffi.gemspec +14 -1
  12. data/lib/2.0/ffi_c.so +0 -0
  13. data/lib/2.1/ffi_c.so +0 -0
  14. data/lib/2.2/ffi_c.so +0 -0
  15. data/lib/2.3/ffi_c.so +0 -0
  16. data/lib/2.4/ffi_c.so +0 -0
  17. data/lib/2.5/ffi_c.so +0 -0
  18. data/lib/ffi/library.rb +1 -1
  19. data/lib/ffi/version.rb +1 -1
  20. data/samples/getlogin.rb +8 -0
  21. data/samples/getpid.rb +8 -0
  22. data/samples/gettimeofday.rb +18 -0
  23. data/samples/hello.rb +7 -0
  24. data/samples/inotify.rb +60 -0
  25. data/samples/pty.rb +76 -0
  26. data/samples/qsort.rb +21 -0
  27. data/samples/sample_helper.rb +6 -0
  28. metadata +17 -526
  29. data/ext/ffi_c/AbstractMemory.c +0 -1109
  30. data/ext/ffi_c/AbstractMemory.h +0 -175
  31. data/ext/ffi_c/ArrayType.c +0 -162
  32. data/ext/ffi_c/ArrayType.h +0 -59
  33. data/ext/ffi_c/Buffer.c +0 -365
  34. data/ext/ffi_c/Call.c +0 -517
  35. data/ext/ffi_c/Call.h +0 -110
  36. data/ext/ffi_c/ClosurePool.c +0 -283
  37. data/ext/ffi_c/ClosurePool.h +0 -57
  38. data/ext/ffi_c/DataConverter.c +0 -91
  39. data/ext/ffi_c/DynamicLibrary.c +0 -339
  40. data/ext/ffi_c/DynamicLibrary.h +0 -98
  41. data/ext/ffi_c/Function.c +0 -998
  42. data/ext/ffi_c/Function.h +0 -87
  43. data/ext/ffi_c/FunctionInfo.c +0 -271
  44. data/ext/ffi_c/LastError.c +0 -184
  45. data/ext/ffi_c/LastError.h +0 -47
  46. data/ext/ffi_c/LongDouble.c +0 -63
  47. data/ext/ffi_c/LongDouble.h +0 -51
  48. data/ext/ffi_c/MappedType.c +0 -168
  49. data/ext/ffi_c/MappedType.h +0 -59
  50. data/ext/ffi_c/MemoryPointer.c +0 -197
  51. data/ext/ffi_c/MemoryPointer.h +0 -53
  52. data/ext/ffi_c/MethodHandle.c +0 -358
  53. data/ext/ffi_c/MethodHandle.h +0 -55
  54. data/ext/ffi_c/Platform.c +0 -129
  55. data/ext/ffi_c/Platform.h +0 -45
  56. data/ext/ffi_c/Pointer.c +0 -508
  57. data/ext/ffi_c/Pointer.h +0 -63
  58. data/ext/ffi_c/Struct.c +0 -829
  59. data/ext/ffi_c/Struct.h +0 -106
  60. data/ext/ffi_c/StructByReference.c +0 -190
  61. data/ext/ffi_c/StructByReference.h +0 -50
  62. data/ext/ffi_c/StructByValue.c +0 -150
  63. data/ext/ffi_c/StructByValue.h +0 -55
  64. data/ext/ffi_c/StructLayout.c +0 -698
  65. data/ext/ffi_c/Thread.c +0 -352
  66. data/ext/ffi_c/Thread.h +0 -95
  67. data/ext/ffi_c/Type.c +0 -397
  68. data/ext/ffi_c/Type.h +0 -62
  69. data/ext/ffi_c/Types.c +0 -139
  70. data/ext/ffi_c/Types.h +0 -89
  71. data/ext/ffi_c/Variadic.c +0 -304
  72. data/ext/ffi_c/compat.h +0 -78
  73. data/ext/ffi_c/extconf.rb +0 -71
  74. data/ext/ffi_c/ffi.c +0 -98
  75. data/ext/ffi_c/libffi.bsd.mk +0 -40
  76. data/ext/ffi_c/libffi.darwin.mk +0 -105
  77. data/ext/ffi_c/libffi.gnu.mk +0 -32
  78. data/ext/ffi_c/libffi.mk +0 -18
  79. data/ext/ffi_c/libffi.vc.mk +0 -26
  80. data/ext/ffi_c/libffi.vc64.mk +0 -26
  81. data/ext/ffi_c/libffi/ChangeLog.libffi +0 -584
  82. data/ext/ffi_c/libffi/ChangeLog.libffi-3.1 +0 -6000
  83. data/ext/ffi_c/libffi/ChangeLog.libgcj +0 -40
  84. data/ext/ffi_c/libffi/ChangeLog.v1 +0 -764
  85. data/ext/ffi_c/libffi/LICENSE +0 -21
  86. data/ext/ffi_c/libffi/Makefile.am +0 -205
  87. data/ext/ffi_c/libffi/Makefile.in +0 -1805
  88. data/ext/ffi_c/libffi/README +0 -454
  89. data/ext/ffi_c/libffi/acinclude.m4 +0 -473
  90. data/ext/ffi_c/libffi/aclocal.m4 +0 -2134
  91. data/ext/ffi_c/libffi/autogen.sh +0 -2
  92. data/ext/ffi_c/libffi/autom4te.cache/output.0 +0 -21972
  93. data/ext/ffi_c/libffi/autom4te.cache/output.1 +0 -21972
  94. data/ext/ffi_c/libffi/autom4te.cache/output.2 +0 -21972
  95. data/ext/ffi_c/libffi/autom4te.cache/output.3 +0 -21972
  96. data/ext/ffi_c/libffi/autom4te.cache/requests +0 -331
  97. data/ext/ffi_c/libffi/autom4te.cache/traces.0 +0 -4010
  98. data/ext/ffi_c/libffi/autom4te.cache/traces.1 +0 -1005
  99. data/ext/ffi_c/libffi/autom4te.cache/traces.2 +0 -4010
  100. data/ext/ffi_c/libffi/autom4te.cache/traces.3 +0 -4010
  101. data/ext/ffi_c/libffi/compile +0 -347
  102. data/ext/ffi_c/libffi/config.guess +0 -1462
  103. data/ext/ffi_c/libffi/config.sub +0 -1825
  104. data/ext/ffi_c/libffi/configure +0 -21972
  105. data/ext/ffi_c/libffi/configure.ac +0 -388
  106. data/ext/ffi_c/libffi/configure.host +0 -272
  107. data/ext/ffi_c/libffi/depcomp +0 -791
  108. data/ext/ffi_c/libffi/doc/Makefile.am +0 -3
  109. data/ext/ffi_c/libffi/doc/Makefile.in +0 -811
  110. data/ext/ffi_c/libffi/doc/libffi.texi +0 -985
  111. data/ext/ffi_c/libffi/doc/mdate-sh +0 -228
  112. data/ext/ffi_c/libffi/doc/texinfo.tex +0 -10079
  113. data/ext/ffi_c/libffi/doc/version.texi +0 -4
  114. data/ext/ffi_c/libffi/fficonfig.h.in +0 -210
  115. data/ext/ffi_c/libffi/fficonfig.h.in~ +0 -210
  116. data/ext/ffi_c/libffi/generate-darwin-source-and-headers.py +0 -207
  117. data/ext/ffi_c/libffi/include/Makefile.am +0 -9
  118. data/ext/ffi_c/libffi/include/Makefile.in +0 -604
  119. data/ext/ffi_c/libffi/include/ffi.h.in +0 -484
  120. data/ext/ffi_c/libffi/include/ffi_cfi.h +0 -55
  121. data/ext/ffi_c/libffi/include/ffi_common.h +0 -147
  122. data/ext/ffi_c/libffi/install-sh +0 -508
  123. data/ext/ffi_c/libffi/libffi.map.in +0 -80
  124. data/ext/ffi_c/libffi/libffi.pc.in +0 -11
  125. data/ext/ffi_c/libffi/libffi.xcodeproj/project.pbxproj +0 -637
  126. data/ext/ffi_c/libffi/libtool-ldflags +0 -106
  127. data/ext/ffi_c/libffi/libtool-version +0 -29
  128. data/ext/ffi_c/libffi/ltmain.sh +0 -11156
  129. data/ext/ffi_c/libffi/m4/asmcfi.m4 +0 -13
  130. data/ext/ffi_c/libffi/m4/ax_append_flag.m4 +0 -69
  131. data/ext/ffi_c/libffi/m4/ax_cc_maxopt.m4 +0 -181
  132. data/ext/ffi_c/libffi/m4/ax_cflags_warn_all.m4 +0 -122
  133. data/ext/ffi_c/libffi/m4/ax_check_compile_flag.m4 +0 -72
  134. data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +0 -84
  135. data/ext/ffi_c/libffi/m4/ax_configure_args.m4 +0 -70
  136. data/ext/ffi_c/libffi/m4/ax_enable_builddir.m4 +0 -301
  137. data/ext/ffi_c/libffi/m4/ax_gcc_archflag.m4 +0 -225
  138. data/ext/ffi_c/libffi/m4/ax_gcc_x86_cpuid.m4 +0 -79
  139. data/ext/ffi_c/libffi/m4/libtool.m4 +0 -8387
  140. data/ext/ffi_c/libffi/m4/ltoptions.m4 +0 -437
  141. data/ext/ffi_c/libffi/m4/ltsugar.m4 +0 -124
  142. data/ext/ffi_c/libffi/m4/ltversion.m4 +0 -23
  143. data/ext/ffi_c/libffi/m4/lt~obsolete.m4 +0 -99
  144. data/ext/ffi_c/libffi/man/Makefile.am +0 -8
  145. data/ext/ffi_c/libffi/man/Makefile.in +0 -558
  146. data/ext/ffi_c/libffi/man/ffi.3 +0 -41
  147. data/ext/ffi_c/libffi/man/ffi_call.3 +0 -103
  148. data/ext/ffi_c/libffi/man/ffi_prep_cif.3 +0 -68
  149. data/ext/ffi_c/libffi/man/ffi_prep_cif_var.3 +0 -73
  150. data/ext/ffi_c/libffi/missing +0 -215
  151. data/ext/ffi_c/libffi/msvcc.sh +0 -260
  152. data/ext/ffi_c/libffi/src/aarch64/ffi.c +0 -941
  153. data/ext/ffi_c/libffi/src/aarch64/ffitarget.h +0 -81
  154. data/ext/ffi_c/libffi/src/aarch64/internal.h +0 -67
  155. data/ext/ffi_c/libffi/src/aarch64/sysv.S +0 -438
  156. data/ext/ffi_c/libffi/src/alpha/ffi.c +0 -521
  157. data/ext/ffi_c/libffi/src/alpha/ffitarget.h +0 -57
  158. data/ext/ffi_c/libffi/src/alpha/internal.h +0 -23
  159. data/ext/ffi_c/libffi/src/alpha/osf.S +0 -282
  160. data/ext/ffi_c/libffi/src/arc/arcompact.S +0 -135
  161. data/ext/ffi_c/libffi/src/arc/ffi.c +0 -266
  162. data/ext/ffi_c/libffi/src/arc/ffitarget.h +0 -53
  163. data/ext/ffi_c/libffi/src/arm/ffi.c +0 -808
  164. data/ext/ffi_c/libffi/src/arm/ffitarget.h +0 -82
  165. data/ext/ffi_c/libffi/src/arm/internal.h +0 -7
  166. data/ext/ffi_c/libffi/src/arm/sysv.S +0 -383
  167. data/ext/ffi_c/libffi/src/avr32/ffi.c +0 -423
  168. data/ext/ffi_c/libffi/src/avr32/ffitarget.h +0 -55
  169. data/ext/ffi_c/libffi/src/avr32/sysv.S +0 -208
  170. data/ext/ffi_c/libffi/src/bfin/ffi.c +0 -196
  171. data/ext/ffi_c/libffi/src/bfin/ffitarget.h +0 -43
  172. data/ext/ffi_c/libffi/src/bfin/sysv.S +0 -179
  173. data/ext/ffi_c/libffi/src/closures.c +0 -890
  174. data/ext/ffi_c/libffi/src/cris/ffi.c +0 -386
  175. data/ext/ffi_c/libffi/src/cris/ffitarget.h +0 -56
  176. data/ext/ffi_c/libffi/src/cris/sysv.S +0 -215
  177. data/ext/ffi_c/libffi/src/debug.c +0 -64
  178. data/ext/ffi_c/libffi/src/dlmalloc.c +0 -5166
  179. data/ext/ffi_c/libffi/src/frv/eabi.S +0 -128
  180. data/ext/ffi_c/libffi/src/frv/ffi.c +0 -292
  181. data/ext/ffi_c/libffi/src/frv/ffitarget.h +0 -62
  182. data/ext/ffi_c/libffi/src/ia64/ffi.c +0 -586
  183. data/ext/ffi_c/libffi/src/ia64/ffitarget.h +0 -55
  184. data/ext/ffi_c/libffi/src/ia64/ia64_flags.h +0 -40
  185. data/ext/ffi_c/libffi/src/ia64/unix.S +0 -560
  186. data/ext/ffi_c/libffi/src/java_raw_api.c +0 -374
  187. data/ext/ffi_c/libffi/src/m32r/ffi.c +0 -232
  188. data/ext/ffi_c/libffi/src/m32r/ffitarget.h +0 -53
  189. data/ext/ffi_c/libffi/src/m32r/sysv.S +0 -121
  190. data/ext/ffi_c/libffi/src/m68k/ffi.c +0 -362
  191. data/ext/ffi_c/libffi/src/m68k/ffitarget.h +0 -54
  192. data/ext/ffi_c/libffi/src/m68k/sysv.S +0 -357
  193. data/ext/ffi_c/libffi/src/m88k/ffi.c +0 -400
  194. data/ext/ffi_c/libffi/src/m88k/ffitarget.h +0 -49
  195. data/ext/ffi_c/libffi/src/m88k/obsd.S +0 -209
  196. data/ext/ffi_c/libffi/src/metag/ffi.c +0 -330
  197. data/ext/ffi_c/libffi/src/metag/ffitarget.h +0 -53
  198. data/ext/ffi_c/libffi/src/metag/sysv.S +0 -311
  199. data/ext/ffi_c/libffi/src/microblaze/ffi.c +0 -321
  200. data/ext/ffi_c/libffi/src/microblaze/ffitarget.h +0 -53
  201. data/ext/ffi_c/libffi/src/microblaze/sysv.S +0 -302
  202. data/ext/ffi_c/libffi/src/mips/ffi.c +0 -1105
  203. data/ext/ffi_c/libffi/src/mips/ffitarget.h +0 -249
  204. data/ext/ffi_c/libffi/src/mips/n32.S +0 -661
  205. data/ext/ffi_c/libffi/src/mips/o32.S +0 -502
  206. data/ext/ffi_c/libffi/src/moxie/eabi.S +0 -101
  207. data/ext/ffi_c/libffi/src/moxie/ffi.c +0 -272
  208. data/ext/ffi_c/libffi/src/moxie/ffitarget.h +0 -52
  209. data/ext/ffi_c/libffi/src/nios2/ffi.c +0 -304
  210. data/ext/ffi_c/libffi/src/nios2/ffitarget.h +0 -52
  211. data/ext/ffi_c/libffi/src/nios2/sysv.S +0 -136
  212. data/ext/ffi_c/libffi/src/or1k/ffi.c +0 -328
  213. data/ext/ffi_c/libffi/src/or1k/ffitarget.h +0 -58
  214. data/ext/ffi_c/libffi/src/or1k/sysv.S +0 -107
  215. data/ext/ffi_c/libffi/src/pa/ffi.c +0 -719
  216. data/ext/ffi_c/libffi/src/pa/ffitarget.h +0 -85
  217. data/ext/ffi_c/libffi/src/pa/hpux32.S +0 -368
  218. data/ext/ffi_c/libffi/src/pa/linux.S +0 -357
  219. data/ext/ffi_c/libffi/src/powerpc/aix.S +0 -328
  220. data/ext/ffi_c/libffi/src/powerpc/aix_closure.S +0 -447
  221. data/ext/ffi_c/libffi/src/powerpc/asm.h +0 -125
  222. data/ext/ffi_c/libffi/src/powerpc/darwin.S +0 -378
  223. data/ext/ffi_c/libffi/src/powerpc/darwin_closure.S +0 -571
  224. data/ext/ffi_c/libffi/src/powerpc/ffi.c +0 -173
  225. data/ext/ffi_c/libffi/src/powerpc/ffi_darwin.c +0 -1359
  226. data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +0 -945
  227. data/ext/ffi_c/libffi/src/powerpc/ffi_powerpc.h +0 -94
  228. data/ext/ffi_c/libffi/src/powerpc/ffi_sysv.c +0 -923
  229. data/ext/ffi_c/libffi/src/powerpc/ffitarget.h +0 -195
  230. data/ext/ffi_c/libffi/src/powerpc/linux64.S +0 -228
  231. data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +0 -488
  232. data/ext/ffi_c/libffi/src/powerpc/ppc_closure.S +0 -397
  233. data/ext/ffi_c/libffi/src/powerpc/sysv.S +0 -175
  234. data/ext/ffi_c/libffi/src/prep_cif.c +0 -261
  235. data/ext/ffi_c/libffi/src/raw_api.c +0 -267
  236. data/ext/ffi_c/libffi/src/s390/ffi.c +0 -756
  237. data/ext/ffi_c/libffi/src/s390/ffitarget.h +0 -70
  238. data/ext/ffi_c/libffi/src/s390/internal.h +0 -11
  239. data/ext/ffi_c/libffi/src/s390/sysv.S +0 -325
  240. data/ext/ffi_c/libffi/src/sh/ffi.c +0 -717
  241. data/ext/ffi_c/libffi/src/sh/ffitarget.h +0 -54
  242. data/ext/ffi_c/libffi/src/sh/sysv.S +0 -850
  243. data/ext/ffi_c/libffi/src/sh64/ffi.c +0 -469
  244. data/ext/ffi_c/libffi/src/sh64/ffitarget.h +0 -58
  245. data/ext/ffi_c/libffi/src/sh64/sysv.S +0 -539
  246. data/ext/ffi_c/libffi/src/sparc/ffi.c +0 -468
  247. data/ext/ffi_c/libffi/src/sparc/ffi64.c +0 -608
  248. data/ext/ffi_c/libffi/src/sparc/ffitarget.h +0 -81
  249. data/ext/ffi_c/libffi/src/sparc/internal.h +0 -26
  250. data/ext/ffi_c/libffi/src/sparc/v8.S +0 -443
  251. data/ext/ffi_c/libffi/src/sparc/v9.S +0 -440
  252. data/ext/ffi_c/libffi/src/tile/ffi.c +0 -355
  253. data/ext/ffi_c/libffi/src/tile/ffitarget.h +0 -65
  254. data/ext/ffi_c/libffi/src/tile/tile.S +0 -360
  255. data/ext/ffi_c/libffi/src/types.c +0 -106
  256. data/ext/ffi_c/libffi/src/vax/elfbsd.S +0 -195
  257. data/ext/ffi_c/libffi/src/vax/ffi.c +0 -276
  258. data/ext/ffi_c/libffi/src/vax/ffitarget.h +0 -49
  259. data/ext/ffi_c/libffi/src/x86/asmnames.h +0 -30
  260. data/ext/ffi_c/libffi/src/x86/ffi.c +0 -733
  261. data/ext/ffi_c/libffi/src/x86/ffi64.c +0 -857
  262. data/ext/ffi_c/libffi/src/x86/ffitarget.h +0 -141
  263. data/ext/ffi_c/libffi/src/x86/ffiw64.c +0 -287
  264. data/ext/ffi_c/libffi/src/x86/internal.h +0 -29
  265. data/ext/ffi_c/libffi/src/x86/internal64.h +0 -22
  266. data/ext/ffi_c/libffi/src/x86/sysv.S +0 -1043
  267. data/ext/ffi_c/libffi/src/x86/unix64.S +0 -525
  268. data/ext/ffi_c/libffi/src/x86/win64.S +0 -232
  269. data/ext/ffi_c/libffi/src/x86/win64_intel.S +0 -237
  270. data/ext/ffi_c/libffi/src/xtensa/ffi.c +0 -298
  271. data/ext/ffi_c/libffi/src/xtensa/ffitarget.h +0 -53
  272. data/ext/ffi_c/libffi/src/xtensa/sysv.S +0 -253
  273. data/ext/ffi_c/libffi/stamp-h.in +0 -1
  274. data/ext/ffi_c/libffi/testsuite/Makefile.am +0 -85
  275. data/ext/ffi_c/libffi/testsuite/Makefile.in +0 -607
  276. data/ext/ffi_c/libffi/testsuite/config/default.exp +0 -1
  277. data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +0 -445
  278. data/ext/ffi_c/libffi/testsuite/lib/target-libpath.exp +0 -283
  279. data/ext/ffi_c/libffi/testsuite/lib/wrapper.exp +0 -45
  280. data/ext/ffi_c/libffi/testsuite/libffi.call/align_mixed.c +0 -46
  281. data/ext/ffi_c/libffi/testsuite/libffi.call/call.exp +0 -30
  282. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn0.c +0 -89
  283. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn1.c +0 -81
  284. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn2.c +0 -81
  285. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn3.c +0 -82
  286. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn4.c +0 -89
  287. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn5.c +0 -92
  288. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_fn6.c +0 -90
  289. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_loc_fn0.c +0 -95
  290. data/ext/ffi_c/libffi/testsuite/libffi.call/closure_simple.c +0 -55
  291. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_12byte.c +0 -94
  292. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_16byte.c +0 -95
  293. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_18byte.c +0 -96
  294. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_19byte.c +0 -102
  295. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_1_1byte.c +0 -89
  296. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_20byte.c +0 -91
  297. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_20byte1.c +0 -93
  298. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_24byte.c +0 -113
  299. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_2byte.c +0 -90
  300. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3_1byte.c +0 -95
  301. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3byte1.c +0 -90
  302. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_3byte2.c +0 -90
  303. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_4_1byte.c +0 -98
  304. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_4byte.c +0 -90
  305. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_5_1_byte.c +0 -109
  306. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_5byte.c +0 -98
  307. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_64byte.c +0 -124
  308. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_6_1_byte.c +0 -113
  309. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_6byte.c +0 -99
  310. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_7_1_byte.c +0 -117
  311. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_7byte.c +0 -97
  312. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_8byte.c +0 -88
  313. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_9byte1.c +0 -90
  314. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_9byte2.c +0 -91
  315. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_double.c +0 -93
  316. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_float.c +0 -91
  317. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_longdouble.c +0 -92
  318. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_longdouble_split.c +0 -132
  319. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_longdouble_split2.c +0 -115
  320. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_pointer.c +0 -95
  321. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint16.c +0 -91
  322. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint32.c +0 -91
  323. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_sint64.c +0 -92
  324. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint16.c +0 -91
  325. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint32.c +0 -91
  326. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_align_uint64.c +0 -93
  327. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_dbls_struct.c +0 -66
  328. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_double.c +0 -43
  329. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_double_va.c +0 -61
  330. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_float.c +0 -42
  331. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_longdouble.c +0 -105
  332. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_longdouble_va.c +0 -61
  333. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_many_mixed_args.c +0 -70
  334. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_many_mixed_float_double.c +0 -55
  335. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_schar.c +0 -74
  336. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_sshort.c +0 -74
  337. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_sshortchar.c +0 -86
  338. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_uchar.c +0 -91
  339. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_ushort.c +0 -74
  340. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_multi_ushortchar.c +0 -86
  341. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_pointer.c +0 -74
  342. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_pointer_stack.c +0 -142
  343. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_schar.c +0 -44
  344. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_sint.c +0 -42
  345. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_sshort.c +0 -42
  346. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_struct_va1.c +0 -114
  347. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uchar.c +0 -42
  348. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uchar_va.c +0 -44
  349. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uint.c +0 -43
  350. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_uint_va.c +0 -45
  351. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ulong_va.c +0 -45
  352. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ulonglong.c +0 -47
  353. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ushort.c +0 -43
  354. data/ext/ffi_c/libffi/testsuite/libffi.call/cls_ushort_va.c +0 -44
  355. data/ext/ffi_c/libffi/testsuite/libffi.call/err_bad_abi.c +0 -36
  356. data/ext/ffi_c/libffi/testsuite/libffi.call/err_bad_typedef.c +0 -26
  357. data/ext/ffi_c/libffi/testsuite/libffi.call/ffitest.h +0 -136
  358. data/ext/ffi_c/libffi/testsuite/libffi.call/float.c +0 -59
  359. data/ext/ffi_c/libffi/testsuite/libffi.call/float1.c +0 -60
  360. data/ext/ffi_c/libffi/testsuite/libffi.call/float2.c +0 -60
  361. data/ext/ffi_c/libffi/testsuite/libffi.call/float3.c +0 -74
  362. data/ext/ffi_c/libffi/testsuite/libffi.call/float4.c +0 -62
  363. data/ext/ffi_c/libffi/testsuite/libffi.call/float_va.c +0 -107
  364. data/ext/ffi_c/libffi/testsuite/libffi.call/huge_struct.c +0 -341
  365. data/ext/ffi_c/libffi/testsuite/libffi.call/many.c +0 -59
  366. data/ext/ffi_c/libffi/testsuite/libffi.call/many2.c +0 -57
  367. data/ext/ffi_c/libffi/testsuite/libffi.call/many_double.c +0 -70
  368. data/ext/ffi_c/libffi/testsuite/libffi.call/many_mixed.c +0 -78
  369. data/ext/ffi_c/libffi/testsuite/libffi.call/negint.c +0 -52
  370. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct.c +0 -152
  371. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct1.c +0 -161
  372. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct10.c +0 -133
  373. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct11.c +0 -121
  374. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct2.c +0 -110
  375. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct3.c +0 -111
  376. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct4.c +0 -111
  377. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct5.c +0 -112
  378. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct6.c +0 -131
  379. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct7.c +0 -111
  380. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct8.c +0 -131
  381. data/ext/ffi_c/libffi/testsuite/libffi.call/nested_struct9.c +0 -131
  382. data/ext/ffi_c/libffi/testsuite/libffi.call/offsets.c +0 -46
  383. data/ext/ffi_c/libffi/testsuite/libffi.call/pr1172638.c +0 -127
  384. data/ext/ffi_c/libffi/testsuite/libffi.call/problem1.c +0 -90
  385. data/ext/ffi_c/libffi/testsuite/libffi.call/promotion.c +0 -59
  386. data/ext/ffi_c/libffi/testsuite/libffi.call/pyobjc-tc.c +0 -114
  387. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl.c +0 -36
  388. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl1.c +0 -43
  389. data/ext/ffi_c/libffi/testsuite/libffi.call/return_dbl2.c +0 -42
  390. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl.c +0 -35
  391. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl1.c +0 -36
  392. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl2.c +0 -49
  393. data/ext/ffi_c/libffi/testsuite/libffi.call/return_fl3.c +0 -42
  394. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ldl.c +0 -34
  395. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll.c +0 -41
  396. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ll1.c +0 -43
  397. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sc.c +0 -36
  398. data/ext/ffi_c/libffi/testsuite/libffi.call/return_sl.c +0 -38
  399. data/ext/ffi_c/libffi/testsuite/libffi.call/return_uc.c +0 -38
  400. data/ext/ffi_c/libffi/testsuite/libffi.call/return_ul.c +0 -38
  401. data/ext/ffi_c/libffi/testsuite/libffi.call/stret_large.c +0 -145
  402. data/ext/ffi_c/libffi/testsuite/libffi.call/stret_large2.c +0 -148
  403. data/ext/ffi_c/libffi/testsuite/libffi.call/stret_medium.c +0 -124
  404. data/ext/ffi_c/libffi/testsuite/libffi.call/stret_medium2.c +0 -125
  405. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen.c +0 -44
  406. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen2.c +0 -49
  407. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen3.c +0 -49
  408. data/ext/ffi_c/libffi/testsuite/libffi.call/strlen4.c +0 -55
  409. data/ext/ffi_c/libffi/testsuite/libffi.call/struct1.c +0 -67
  410. data/ext/ffi_c/libffi/testsuite/libffi.call/struct2.c +0 -67
  411. data/ext/ffi_c/libffi/testsuite/libffi.call/struct3.c +0 -60
  412. data/ext/ffi_c/libffi/testsuite/libffi.call/struct4.c +0 -64
  413. data/ext/ffi_c/libffi/testsuite/libffi.call/struct5.c +0 -66
  414. data/ext/ffi_c/libffi/testsuite/libffi.call/struct6.c +0 -64
  415. data/ext/ffi_c/libffi/testsuite/libffi.call/struct7.c +0 -74
  416. data/ext/ffi_c/libffi/testsuite/libffi.call/struct8.c +0 -81
  417. data/ext/ffi_c/libffi/testsuite/libffi.call/struct9.c +0 -68
  418. data/ext/ffi_c/libffi/testsuite/libffi.call/testclosure.c +0 -70
  419. data/ext/ffi_c/libffi/testsuite/libffi.call/uninitialized.c +0 -61
  420. data/ext/ffi_c/libffi/testsuite/libffi.call/unwindtest.cc +0 -117
  421. data/ext/ffi_c/libffi/testsuite/libffi.call/unwindtest_ffi_call.cc +0 -54
  422. data/ext/ffi_c/libffi/testsuite/libffi.call/va_1.c +0 -196
  423. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct1.c +0 -121
  424. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct2.c +0 -123
  425. data/ext/ffi_c/libffi/testsuite/libffi.call/va_struct3.c +0 -125
  426. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex.inc +0 -91
  427. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_double.c +0 -10
  428. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_float.c +0 -10
  429. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_align_complex_longdouble.c +0 -10
  430. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex.inc +0 -42
  431. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_double.c +0 -10
  432. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_float.c +0 -10
  433. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_longdouble.c +0 -10
  434. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct.inc +0 -71
  435. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_double.c +0 -10
  436. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_float.c +0 -10
  437. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_struct_longdouble.c +0 -10
  438. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va.inc +0 -80
  439. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_double.c +0 -10
  440. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_float.c +0 -16
  441. data/ext/ffi_c/libffi/testsuite/libffi.complex/cls_complex_va_longdouble.c +0 -10
  442. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex.exp +0 -36
  443. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex.inc +0 -51
  444. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_double.inc +0 -7
  445. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_float.inc +0 -7
  446. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_defs_longdouble.inc +0 -7
  447. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_double.c +0 -10
  448. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_float.c +0 -10
  449. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_int.c +0 -86
  450. data/ext/ffi_c/libffi/testsuite/libffi.complex/complex_longdouble.c +0 -10
  451. data/ext/ffi_c/libffi/testsuite/libffi.complex/ffitest.h +0 -1
  452. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex.inc +0 -78
  453. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_double.c +0 -10
  454. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_float.c +0 -10
  455. data/ext/ffi_c/libffi/testsuite/libffi.complex/many_complex_longdouble.c +0 -10
  456. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex.inc +0 -37
  457. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1.inc +0 -41
  458. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_double.c +0 -10
  459. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_float.c +0 -10
  460. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex1_longdouble.c +0 -10
  461. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2.inc +0 -44
  462. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_double.c +0 -10
  463. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_float.c +0 -10
  464. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex2_longdouble.c +0 -10
  465. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_double.c +0 -10
  466. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_float.c +0 -10
  467. data/ext/ffi_c/libffi/testsuite/libffi.complex/return_complex_longdouble.c +0 -10
  468. data/ext/ffi_c/libffi/testsuite/libffi.go/aa-direct.c +0 -34
  469. data/ext/ffi_c/libffi/testsuite/libffi.go/closure1.c +0 -28
  470. data/ext/ffi_c/libffi/testsuite/libffi.go/ffitest.h +0 -1
  471. data/ext/ffi_c/libffi/testsuite/libffi.go/go.exp +0 -36
  472. data/ext/ffi_c/libffi/testsuite/libffi.go/static-chain.h +0 -19
  473. data/ext/ffi_c/rbffi.h +0 -57
  474. data/ext/ffi_c/rbffi_endian.h +0 -59
  475. data/ext/ffi_c/win32/stdbool.h +0 -8
  476. data/ext/ffi_c/win32/stdint.h +0 -201
  477. data/gen/Rakefile +0 -30
  478. data/libtest/Benchmark.c +0 -52
  479. data/libtest/BoolTest.c +0 -34
  480. data/libtest/BufferTest.c +0 -31
  481. data/libtest/ClosureTest.c +0 -205
  482. data/libtest/EnumTest.c +0 -51
  483. data/libtest/FunctionTest.c +0 -70
  484. data/libtest/GNUmakefile +0 -149
  485. data/libtest/GlobalVariable.c +0 -62
  486. data/libtest/LastErrorTest.c +0 -21
  487. data/libtest/NumberTest.c +0 -132
  488. data/libtest/PointerTest.c +0 -63
  489. data/libtest/ReferenceTest.c +0 -23
  490. data/libtest/StringTest.c +0 -34
  491. data/libtest/StructTest.c +0 -243
  492. data/libtest/UnionTest.c +0 -43
  493. data/libtest/VariadicTest.c +0 -99
  494. data/spec/ffi/async_callback_spec.rb +0 -35
  495. data/spec/ffi/bitmask_spec.rb +0 -575
  496. data/spec/ffi/bool_spec.rb +0 -32
  497. data/spec/ffi/buffer_spec.rb +0 -279
  498. data/spec/ffi/callback_spec.rb +0 -773
  499. data/spec/ffi/custom_param_type.rb +0 -37
  500. data/spec/ffi/custom_type_spec.rb +0 -74
  501. data/spec/ffi/dup_spec.rb +0 -52
  502. data/spec/ffi/embed-test/ext/Makefile +0 -242
  503. data/spec/ffi/enum_spec.rb +0 -423
  504. data/spec/ffi/errno_spec.rb +0 -20
  505. data/spec/ffi/ffi_spec.rb +0 -28
  506. data/spec/ffi/fixtures/Benchmark.c +0 -52
  507. data/spec/ffi/fixtures/BitmaskTest.c +0 -51
  508. data/spec/ffi/fixtures/BoolTest.c +0 -34
  509. data/spec/ffi/fixtures/BufferTest.c +0 -31
  510. data/spec/ffi/fixtures/ClosureTest.c +0 -205
  511. data/spec/ffi/fixtures/EnumTest.c +0 -51
  512. data/spec/ffi/fixtures/FunctionTest.c +0 -142
  513. data/spec/ffi/fixtures/GNUmakefile +0 -149
  514. data/spec/ffi/fixtures/GlobalVariable.c +0 -62
  515. data/spec/ffi/fixtures/LastErrorTest.c +0 -21
  516. data/spec/ffi/fixtures/NumberTest.c +0 -132
  517. data/spec/ffi/fixtures/PipeHelper.h +0 -21
  518. data/spec/ffi/fixtures/PipeHelperPosix.c +0 -41
  519. data/spec/ffi/fixtures/PipeHelperWindows.c +0 -72
  520. data/spec/ffi/fixtures/PointerTest.c +0 -63
  521. data/spec/ffi/fixtures/ReferenceTest.c +0 -23
  522. data/spec/ffi/fixtures/StringTest.c +0 -34
  523. data/spec/ffi/fixtures/StructTest.c +0 -243
  524. data/spec/ffi/fixtures/UnionTest.c +0 -43
  525. data/spec/ffi/fixtures/VariadicTest.c +0 -99
  526. data/spec/ffi/fixtures/classes.rb +0 -438
  527. data/spec/ffi/function_spec.rb +0 -97
  528. data/spec/ffi/io_spec.rb +0 -16
  529. data/spec/ffi/library_spec.rb +0 -286
  530. data/spec/ffi/long_double.rb +0 -30
  531. data/spec/ffi/managed_struct_spec.rb +0 -68
  532. data/spec/ffi/memorypointer_spec.rb +0 -78
  533. data/spec/ffi/number_spec.rb +0 -247
  534. data/spec/ffi/platform_spec.rb +0 -114
  535. data/spec/ffi/pointer_spec.rb +0 -285
  536. data/spec/ffi/rbx/attach_function_spec.rb +0 -34
  537. data/spec/ffi/rbx/memory_pointer_spec.rb +0 -198
  538. data/spec/ffi/rbx/spec_helper.rb +0 -6
  539. data/spec/ffi/rbx/struct_spec.rb +0 -18
  540. data/spec/ffi/spec_helper.rb +0 -93
  541. data/spec/ffi/string_spec.rb +0 -118
  542. data/spec/ffi/strptr_spec.rb +0 -50
  543. data/spec/ffi/struct_by_ref_spec.rb +0 -43
  544. data/spec/ffi/struct_callback_spec.rb +0 -69
  545. data/spec/ffi/struct_initialize_spec.rb +0 -35
  546. data/spec/ffi/struct_packed_spec.rb +0 -50
  547. data/spec/ffi/struct_spec.rb +0 -882
  548. data/spec/ffi/typedef_spec.rb +0 -91
  549. data/spec/ffi/union_spec.rb +0 -67
  550. data/spec/ffi/variadic_spec.rb +0 -132
  551. data/spec/spec.opts +0 -4
@@ -1,266 +0,0 @@
1
- /* -----------------------------------------------------------------------
2
- ffi.c - Copyright (c) 2013 Synopsys, Inc. (www.synopsys.com)
3
-
4
- ARC 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, EXPRESS
18
- OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
19
- MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
20
- IN NO EVENT SHALL RENESAS TECHNOLOGY BE LIABLE FOR ANY CLAIM, DAMAGES OR
21
- OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
22
- ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
23
- OTHER DEALINGS IN THE SOFTWARE.
24
- ----------------------------------------------------------------------- */
25
-
26
- #include <ffi.h>
27
- #include <ffi_common.h>
28
-
29
- #include <stdlib.h>
30
- #include <stdint.h>
31
-
32
- #include <sys/cachectl.h>
33
-
34
- /* for little endian ARC, the code is in fact stored as mixed endian for
35
- performance reasons */
36
- #if __BIG_ENDIAN__
37
- #define CODE_ENDIAN(x) (x)
38
- #else
39
- #define CODE_ENDIAN(x) ( (((uint32_t) (x)) << 16) | (((uint32_t) (x)) >> 16))
40
- #endif
41
-
42
- /* ffi_prep_args is called by the assembly routine once stack
43
- space has been allocated for the function's arguments. */
44
-
45
- void
46
- ffi_prep_args (char *stack, extended_cif * ecif)
47
- {
48
- unsigned int i;
49
- void **p_argv;
50
- char *argp;
51
- ffi_type **p_arg;
52
-
53
- argp = stack;
54
-
55
- if (ecif->cif->rtype->type == FFI_TYPE_STRUCT)
56
- {
57
- *(void **) argp = ecif->rvalue;
58
- argp += 4;
59
- }
60
-
61
- p_argv = ecif->avalue;
62
-
63
- for (i = ecif->cif->nargs, p_arg = ecif->cif->arg_types;
64
- (i != 0); i--, p_arg++)
65
- {
66
- size_t z;
67
- int alignment;
68
-
69
- /* align alignment to 4 */
70
- alignment = (((*p_arg)->alignment - 1) | 3) + 1;
71
-
72
- /* Align if necessary. */
73
- if ((alignment - 1) & (unsigned) argp)
74
- argp = (char *) FFI_ALIGN (argp, alignment);
75
-
76
- z = (*p_arg)->size;
77
- if (z < sizeof (int))
78
- {
79
- z = sizeof (int);
80
-
81
- switch ((*p_arg)->type)
82
- {
83
- case FFI_TYPE_SINT8:
84
- *(signed int *) argp = (signed int) *(SINT8 *) (*p_argv);
85
- break;
86
-
87
- case FFI_TYPE_UINT8:
88
- *(unsigned int *) argp = (unsigned int) *(UINT8 *) (*p_argv);
89
- break;
90
-
91
- case FFI_TYPE_SINT16:
92
- *(signed int *) argp = (signed int) *(SINT16 *) (*p_argv);
93
- break;
94
-
95
- case FFI_TYPE_UINT16:
96
- *(unsigned int *) argp = (unsigned int) *(UINT16 *) (*p_argv);
97
- break;
98
-
99
- case FFI_TYPE_STRUCT:
100
- memcpy (argp, *p_argv, (*p_arg)->size);
101
- break;
102
-
103
- default:
104
- FFI_ASSERT (0);
105
- }
106
- }
107
- else if (z == sizeof (int))
108
- {
109
- *(unsigned int *) argp = (unsigned int) *(UINT32 *) (*p_argv);
110
- }
111
- else
112
- {
113
- if ((*p_arg)->type == FFI_TYPE_STRUCT)
114
- {
115
- memcpy (argp, *p_argv, z);
116
- }
117
- else
118
- {
119
- /* Double or long long 64bit. */
120
- memcpy (argp, *p_argv, z);
121
- }
122
- }
123
- p_argv++;
124
- argp += z;
125
- }
126
-
127
- return;
128
- }
129
-
130
- /* Perform machine dependent cif processing. */
131
- ffi_status
132
- ffi_prep_cif_machdep (ffi_cif * cif)
133
- {
134
- /* Set the return type flag. */
135
- switch (cif->rtype->type)
136
- {
137
- case FFI_TYPE_VOID:
138
- cif->flags = (unsigned) cif->rtype->type;
139
- break;
140
-
141
- case FFI_TYPE_STRUCT:
142
- cif->flags = (unsigned) cif->rtype->type;
143
- break;
144
-
145
- case FFI_TYPE_SINT64:
146
- case FFI_TYPE_UINT64:
147
- case FFI_TYPE_DOUBLE:
148
- cif->flags = FFI_TYPE_DOUBLE;
149
- break;
150
-
151
- case FFI_TYPE_FLOAT:
152
- default:
153
- cif->flags = FFI_TYPE_INT;
154
- break;
155
- }
156
-
157
- return FFI_OK;
158
- }
159
-
160
- extern void ffi_call_ARCompact (void (*)(char *, extended_cif *),
161
- extended_cif *, unsigned, unsigned,
162
- unsigned *, void (*fn) (void));
163
-
164
- void
165
- ffi_call (ffi_cif * cif, void (*fn) (void), void *rvalue, void **avalue)
166
- {
167
- extended_cif ecif;
168
-
169
- ecif.cif = cif;
170
- ecif.avalue = avalue;
171
-
172
- /* If the return value is a struct and we don't have
173
- a return value address then we need to make one. */
174
- if ((rvalue == NULL) && (cif->rtype->type == FFI_TYPE_STRUCT))
175
- {
176
- ecif.rvalue = alloca (cif->rtype->size);
177
- }
178
- else
179
- ecif.rvalue = rvalue;
180
-
181
- switch (cif->abi)
182
- {
183
- case FFI_ARCOMPACT:
184
- ffi_call_ARCompact (ffi_prep_args, &ecif, cif->bytes,
185
- cif->flags, ecif.rvalue, fn);
186
- break;
187
-
188
- default:
189
- FFI_ASSERT (0);
190
- break;
191
- }
192
- }
193
-
194
- int
195
- ffi_closure_inner_ARCompact (ffi_closure * closure, void *rvalue,
196
- ffi_arg * args)
197
- {
198
- void **arg_area, **p_argv;
199
- ffi_cif *cif = closure->cif;
200
- char *argp = (char *) args;
201
- ffi_type **p_argt;
202
- int i;
203
-
204
- arg_area = (void **) alloca (cif->nargs * sizeof (void *));
205
-
206
- /* handle hidden argument */
207
- if (cif->flags == FFI_TYPE_STRUCT)
208
- {
209
- rvalue = *(void **) argp;
210
- argp += 4;
211
- }
212
-
213
- p_argv = arg_area;
214
-
215
- for (i = 0, p_argt = cif->arg_types; i < cif->nargs;
216
- i++, p_argt++, p_argv++)
217
- {
218
- size_t z;
219
- int alignment;
220
-
221
- /* align alignment to 4 */
222
- alignment = (((*p_argt)->alignment - 1) | 3) + 1;
223
-
224
- /* Align if necessary. */
225
- if ((alignment - 1) & (unsigned) argp)
226
- argp = (char *) FFI_ALIGN (argp, alignment);
227
-
228
- z = (*p_argt)->size;
229
- *p_argv = (void *) argp;
230
- argp += z;
231
- }
232
-
233
- (closure->fun) (cif, rvalue, arg_area, closure->user_data);
234
-
235
- return cif->flags;
236
- }
237
-
238
- extern void ffi_closure_ARCompact (void);
239
-
240
- ffi_status
241
- ffi_prep_closure_loc (ffi_closure * closure, ffi_cif * cif,
242
- void (*fun) (ffi_cif *, void *, void **, void *),
243
- void *user_data, void *codeloc)
244
- {
245
- uint32_t *tramp = (uint32_t *) & (closure->tramp[0]);
246
-
247
- switch (cif->abi)
248
- {
249
- case FFI_ARCOMPACT:
250
- FFI_ASSERT (tramp == codeloc);
251
- tramp[0] = CODE_ENDIAN (0x200a1fc0); /* mov r8, pcl */
252
- tramp[1] = CODE_ENDIAN (0x20200f80); /* j [long imm] */
253
- tramp[2] = CODE_ENDIAN (ffi_closure_ARCompact);
254
- break;
255
-
256
- default:
257
- return FFI_BAD_ABI;
258
- }
259
-
260
- closure->cif = cif;
261
- closure->fun = fun;
262
- closure->user_data = user_data;
263
- cacheflush (codeloc, FFI_TRAMPOLINE_SIZE, BCACHE);
264
-
265
- return FFI_OK;
266
- }
@@ -1,53 +0,0 @@
1
- /* -----------------------------------------------------------------------
2
- ffitarget.h - Copyright (c) 2012 Anthony Green
3
- Copyright (c) 2013 Synopsys, Inc. (www.synopsys.com)
4
- Target configuration macros for ARC.
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, EXPRESS
18
- OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
19
- MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
20
- IN NO EVENT SHALL RENESAS TECHNOLOGY BE LIABLE FOR ANY CLAIM, DAMAGES OR
21
- OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
22
- ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
23
- OTHER DEALINGS IN THE SOFTWARE.
24
-
25
- ----------------------------------------------------------------------- */
26
-
27
- #ifndef LIBFFI_TARGET_H
28
- #define LIBFFI_TARGET_H
29
-
30
- #ifndef LIBFFI_H
31
- #error "Please do not include ffitarget.h directly into your source. Use ffi.h instead."
32
- #endif
33
-
34
- /* ---- Generic type definitions ----------------------------------------- */
35
-
36
- #ifndef LIBFFI_ASM
37
- typedef unsigned long ffi_arg;
38
- typedef signed long ffi_sarg;
39
-
40
- typedef enum ffi_abi
41
- {
42
- FFI_FIRST_ABI = 0,
43
- FFI_ARCOMPACT,
44
- FFI_LAST_ABI,
45
- FFI_DEFAULT_ABI = FFI_ARCOMPACT
46
- } ffi_abi;
47
- #endif
48
-
49
- #define FFI_CLOSURES 1
50
- #define FFI_TRAMPOLINE_SIZE 12
51
- #define FFI_NATIVE_RAW_API 0
52
-
53
- #endif
@@ -1,808 +0,0 @@
1
- /* -----------------------------------------------------------------------
2
- ffi.c - Copyright (c) 2011 Timothy Wall
3
- Copyright (c) 2011 Plausible Labs Cooperative, Inc.
4
- Copyright (c) 2011 Anthony Green
5
- Copyright (c) 2011 Free Software Foundation
6
- Copyright (c) 1998, 2008, 2011 Red Hat, Inc.
7
-
8
- ARM Foreign Function Interface
9
-
10
- Permission is hereby granted, free of charge, to any person obtaining
11
- a copy of this software and associated documentation files (the
12
- ``Software''), to deal in the Software without restriction, including
13
- without limitation the rights to use, copy, modify, merge, publish,
14
- distribute, sublicense, and/or sell copies of the Software, and to
15
- permit persons to whom the Software is furnished to do so, subject to
16
- the following conditions:
17
-
18
- The above copyright notice and this permission notice shall be included
19
- in all copies or substantial portions of the Software.
20
-
21
- THE SOFTWARE IS PROVIDED ``AS IS'', WITHOUT WARRANTY OF ANY KIND,
22
- EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
23
- MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
24
- NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
25
- HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
26
- WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
27
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
28
- DEALINGS IN THE SOFTWARE.
29
- ----------------------------------------------------------------------- */
30
-
31
- #include <fficonfig.h>
32
- #include <ffi.h>
33
- #include <ffi_common.h>
34
- #include <stdlib.h>
35
- #include "internal.h"
36
-
37
- #if FFI_EXEC_TRAMPOLINE_TABLE
38
-
39
- #ifdef __MACH__
40
- #include <mach/vm_param.h>
41
- #endif
42
-
43
- #else
44
- extern unsigned int ffi_arm_trampoline[2] FFI_HIDDEN;
45
- #endif
46
-
47
- /* Forward declares. */
48
- static int vfp_type_p (const ffi_type *);
49
- static void layout_vfp_args (ffi_cif *);
50
-
51
- static void *
52
- ffi_align (ffi_type *ty, void *p)
53
- {
54
- /* Align if necessary */
55
- size_t alignment;
56
- #ifdef _WIN32_WCE
57
- alignment = 4;
58
- #else
59
- alignment = ty->alignment;
60
- if (alignment < 4)
61
- alignment = 4;
62
- #endif
63
- return (void *) FFI_ALIGN (p, alignment);
64
- }
65
-
66
- static size_t
67
- ffi_put_arg (ffi_type *ty, void *src, void *dst)
68
- {
69
- size_t z = ty->size;
70
-
71
- switch (ty->type)
72
- {
73
- case FFI_TYPE_SINT8:
74
- *(UINT32 *)dst = *(SINT8 *)src;
75
- break;
76
- case FFI_TYPE_UINT8:
77
- *(UINT32 *)dst = *(UINT8 *)src;
78
- break;
79
- case FFI_TYPE_SINT16:
80
- *(UINT32 *)dst = *(SINT16 *)src;
81
- break;
82
- case FFI_TYPE_UINT16:
83
- *(UINT32 *)dst = *(UINT16 *)src;
84
- break;
85
-
86
- case FFI_TYPE_INT:
87
- case FFI_TYPE_SINT32:
88
- case FFI_TYPE_UINT32:
89
- case FFI_TYPE_POINTER:
90
- case FFI_TYPE_FLOAT:
91
- *(UINT32 *)dst = *(UINT32 *)src;
92
- break;
93
-
94
- case FFI_TYPE_SINT64:
95
- case FFI_TYPE_UINT64:
96
- case FFI_TYPE_DOUBLE:
97
- *(UINT64 *)dst = *(UINT64 *)src;
98
- break;
99
-
100
- case FFI_TYPE_STRUCT:
101
- case FFI_TYPE_COMPLEX:
102
- memcpy (dst, src, z);
103
- break;
104
-
105
- default:
106
- abort();
107
- }
108
-
109
- return FFI_ALIGN (z, 4);
110
- }
111
-
112
- /* ffi_prep_args is called once stack space has been allocated
113
- for the function's arguments.
114
-
115
- The vfp_space parameter is the load area for VFP regs, the return
116
- value is cif->vfp_used (word bitset of VFP regs used for passing
117
- arguments). These are only used for the VFP hard-float ABI.
118
- */
119
- static void
120
- ffi_prep_args_SYSV (ffi_cif *cif, int flags, void *rvalue,
121
- void **avalue, char *argp)
122
- {
123
- ffi_type **arg_types = cif->arg_types;
124
- int i, n;
125
-
126
- if (flags == ARM_TYPE_STRUCT)
127
- {
128
- *(void **) argp = rvalue;
129
- argp += 4;
130
- }
131
-
132
- for (i = 0, n = cif->nargs; i < n; i++)
133
- {
134
- ffi_type *ty = arg_types[i];
135
- argp = ffi_align (ty, argp);
136
- argp += ffi_put_arg (ty, avalue[i], argp);
137
- }
138
- }
139
-
140
- static void
141
- ffi_prep_args_VFP (ffi_cif *cif, int flags, void *rvalue,
142
- void **avalue, char *stack, char *vfp_space)
143
- {
144
- ffi_type **arg_types = cif->arg_types;
145
- int i, n, vi = 0;
146
- char *argp, *regp, *eo_regp;
147
- char stack_used = 0;
148
- char done_with_regs = 0;
149
-
150
- /* The first 4 words on the stack are used for values
151
- passed in core registers. */
152
- regp = stack;
153
- eo_regp = argp = regp + 16;
154
-
155
- /* If the function returns an FFI_TYPE_STRUCT in memory,
156
- that address is passed in r0 to the function. */
157
- if (flags == ARM_TYPE_STRUCT)
158
- {
159
- *(void **) regp = rvalue;
160
- regp += 4;
161
- }
162
-
163
- for (i = 0, n = cif->nargs; i < n; i++)
164
- {
165
- ffi_type *ty = arg_types[i];
166
- void *a = avalue[i];
167
- int is_vfp_type = vfp_type_p (ty);
168
-
169
- /* Allocated in VFP registers. */
170
- if (vi < cif->vfp_nargs && is_vfp_type)
171
- {
172
- char *vfp_slot = vfp_space + cif->vfp_args[vi++] * 4;
173
- ffi_put_arg (ty, a, vfp_slot);
174
- continue;
175
- }
176
- /* Try allocating in core registers. */
177
- else if (!done_with_regs && !is_vfp_type)
178
- {
179
- char *tregp = ffi_align (ty, regp);
180
- size_t size = ty->size;
181
- size = (size < 4) ? 4 : size; // pad
182
- /* Check if there is space left in the aligned register
183
- area to place the argument. */
184
- if (tregp + size <= eo_regp)
185
- {
186
- regp = tregp + ffi_put_arg (ty, a, tregp);
187
- done_with_regs = (regp == argp);
188
- // ensure we did not write into the stack area
189
- FFI_ASSERT (regp <= argp);
190
- continue;
191
- }
192
- /* In case there are no arguments in the stack area yet,
193
- the argument is passed in the remaining core registers
194
- and on the stack. */
195
- else if (!stack_used)
196
- {
197
- stack_used = 1;
198
- done_with_regs = 1;
199
- argp = tregp + ffi_put_arg (ty, a, tregp);
200
- FFI_ASSERT (eo_regp < argp);
201
- continue;
202
- }
203
- }
204
- /* Base case, arguments are passed on the stack */
205
- stack_used = 1;
206
- argp = ffi_align (ty, argp);
207
- argp += ffi_put_arg (ty, a, argp);
208
- }
209
- }
210
-
211
- /* Perform machine dependent cif processing */
212
- ffi_status
213
- ffi_prep_cif_machdep (ffi_cif *cif)
214
- {
215
- int flags = 0, cabi = cif->abi;
216
- size_t bytes = cif->bytes;
217
-
218
- /* Map out the register placements of VFP register args. The VFP
219
- hard-float calling conventions are slightly more sophisticated
220
- than the base calling conventions, so we do it here instead of
221
- in ffi_prep_args(). */
222
- if (cabi == FFI_VFP)
223
- layout_vfp_args (cif);
224
-
225
- /* Set the return type flag */
226
- switch (cif->rtype->type)
227
- {
228
- case FFI_TYPE_VOID:
229
- flags = ARM_TYPE_VOID;
230
- break;
231
-
232
- case FFI_TYPE_INT:
233
- case FFI_TYPE_UINT8:
234
- case FFI_TYPE_SINT8:
235
- case FFI_TYPE_UINT16:
236
- case FFI_TYPE_SINT16:
237
- case FFI_TYPE_UINT32:
238
- case FFI_TYPE_SINT32:
239
- case FFI_TYPE_POINTER:
240
- flags = ARM_TYPE_INT;
241
- break;
242
-
243
- case FFI_TYPE_SINT64:
244
- case FFI_TYPE_UINT64:
245
- flags = ARM_TYPE_INT64;
246
- break;
247
-
248
- case FFI_TYPE_FLOAT:
249
- flags = (cabi == FFI_VFP ? ARM_TYPE_VFP_S : ARM_TYPE_INT);
250
- break;
251
- case FFI_TYPE_DOUBLE:
252
- flags = (cabi == FFI_VFP ? ARM_TYPE_VFP_D : ARM_TYPE_INT64);
253
- break;
254
-
255
- case FFI_TYPE_STRUCT:
256
- case FFI_TYPE_COMPLEX:
257
- if (cabi == FFI_VFP)
258
- {
259
- int h = vfp_type_p (cif->rtype);
260
-
261
- flags = ARM_TYPE_VFP_N;
262
- if (h == 0x100 + FFI_TYPE_FLOAT)
263
- flags = ARM_TYPE_VFP_S;
264
- if (h == 0x100 + FFI_TYPE_DOUBLE)
265
- flags = ARM_TYPE_VFP_D;
266
- if (h != 0)
267
- break;
268
- }
269
-
270
- /* A Composite Type not larger than 4 bytes is returned in r0.
271
- A Composite Type larger than 4 bytes, or whose size cannot
272
- be determined statically ... is stored in memory at an
273
- address passed [in r0]. */
274
- if (cif->rtype->size <= 4)
275
- flags = ARM_TYPE_INT;
276
- else
277
- {
278
- flags = ARM_TYPE_STRUCT;
279
- bytes += 4;
280
- }
281
- break;
282
-
283
- default:
284
- abort();
285
- }
286
-
287
- /* Round the stack up to a multiple of 8 bytes. This isn't needed
288
- everywhere, but it is on some platforms, and it doesn't harm anything
289
- when it isn't needed. */
290
- bytes = FFI_ALIGN (bytes, 8);
291
-
292
- /* Minimum stack space is the 4 register arguments that we pop. */
293
- if (bytes < 4*4)
294
- bytes = 4*4;
295
-
296
- cif->bytes = bytes;
297
- cif->flags = flags;
298
-
299
- return FFI_OK;
300
- }
301
-
302
- /* Perform machine dependent cif processing for variadic calls */
303
- ffi_status
304
- ffi_prep_cif_machdep_var (ffi_cif * cif,
305
- unsigned int nfixedargs, unsigned int ntotalargs)
306
- {
307
- /* VFP variadic calls actually use the SYSV ABI */
308
- if (cif->abi == FFI_VFP)
309
- cif->abi = FFI_SYSV;
310
-
311
- return ffi_prep_cif_machdep (cif);
312
- }
313
-
314
- /* Prototypes for assembly functions, in sysv.S. */
315
-
316
- struct call_frame
317
- {
318
- void *fp;
319
- void *lr;
320
- void *rvalue;
321
- int flags;
322
- void *closure;
323
- };
324
-
325
- extern void ffi_call_SYSV (void *stack, struct call_frame *,
326
- void (*fn) (void)) FFI_HIDDEN;
327
- extern void ffi_call_VFP (void *vfp_space, struct call_frame *,
328
- void (*fn) (void), unsigned vfp_used) FFI_HIDDEN;
329
-
330
- static void
331
- ffi_call_int (ffi_cif * cif, void (*fn) (void), void *rvalue,
332
- void **avalue, void *closure)
333
- {
334
- int flags = cif->flags;
335
- ffi_type *rtype = cif->rtype;
336
- size_t bytes, rsize, vfp_size;
337
- char *stack, *vfp_space, *new_rvalue;
338
- struct call_frame *frame;
339
-
340
- rsize = 0;
341
- if (rvalue == NULL)
342
- {
343
- /* If the return value is a struct and we don't have a return
344
- value address then we need to make one. Otherwise the return
345
- value is in registers and we can ignore them. */
346
- if (flags == ARM_TYPE_STRUCT)
347
- rsize = rtype->size;
348
- else
349
- flags = ARM_TYPE_VOID;
350
- }
351
- else if (flags == ARM_TYPE_VFP_N)
352
- {
353
- /* Largest case is double x 4. */
354
- rsize = 32;
355
- }
356
- else if (flags == ARM_TYPE_INT && rtype->type == FFI_TYPE_STRUCT)
357
- rsize = 4;
358
-
359
- /* Largest case. */
360
- vfp_size = (cif->abi == FFI_VFP && cif->vfp_used ? 8*8: 0);
361
-
362
- bytes = cif->bytes;
363
- stack = alloca (vfp_size + bytes + sizeof(struct call_frame) + rsize);
364
-
365
- vfp_space = NULL;
366
- if (vfp_size)
367
- {
368
- vfp_space = stack;
369
- stack += vfp_size;
370
- }
371
-
372
- frame = (struct call_frame *)(stack + bytes);
373
-
374
- new_rvalue = rvalue;
375
- if (rsize)
376
- new_rvalue = (void *)(frame + 1);
377
-
378
- frame->rvalue = new_rvalue;
379
- frame->flags = flags;
380
- frame->closure = closure;
381
-
382
- if (vfp_space)
383
- {
384
- ffi_prep_args_VFP (cif, flags, new_rvalue, avalue, stack, vfp_space);
385
- ffi_call_VFP (vfp_space, frame, fn, cif->vfp_used);
386
- }
387
- else
388
- {
389
- ffi_prep_args_SYSV (cif, flags, new_rvalue, avalue, stack);
390
- ffi_call_SYSV (stack, frame, fn);
391
- }
392
-
393
- if (rvalue && rvalue != new_rvalue)
394
- memcpy (rvalue, new_rvalue, rtype->size);
395
- }
396
-
397
- void
398
- ffi_call (ffi_cif *cif, void (*fn) (void), void *rvalue, void **avalue)
399
- {
400
- ffi_call_int (cif, fn, rvalue, avalue, NULL);
401
- }
402
-
403
- void
404
- ffi_call_go (ffi_cif *cif, void (*fn) (void), void *rvalue,
405
- void **avalue, void *closure)
406
- {
407
- ffi_call_int (cif, fn, rvalue, avalue, closure);
408
- }
409
-
410
- static void *
411
- ffi_prep_incoming_args_SYSV (ffi_cif *cif, void *rvalue,
412
- char *argp, void **avalue)
413
- {
414
- ffi_type **arg_types = cif->arg_types;
415
- int i, n;
416
-
417
- if (cif->flags == ARM_TYPE_STRUCT)
418
- {
419
- rvalue = *(void **) argp;
420
- argp += 4;
421
- }
422
-
423
- for (i = 0, n = cif->nargs; i < n; i++)
424
- {
425
- ffi_type *ty = arg_types[i];
426
- size_t z = ty->size;
427
-
428
- argp = ffi_align (ty, argp);
429
- avalue[i] = (void *) argp;
430
- argp += z;
431
- }
432
-
433
- return rvalue;
434
- }
435
-
436
- static void *
437
- ffi_prep_incoming_args_VFP (ffi_cif *cif, void *rvalue, char *stack,
438
- char *vfp_space, void **avalue)
439
- {
440
- ffi_type **arg_types = cif->arg_types;
441
- int i, n, vi = 0;
442
- char *argp, *regp, *eo_regp;
443
- char done_with_regs = 0;
444
- char stack_used = 0;
445
-
446
- regp = stack;
447
- eo_regp = argp = regp + 16;
448
-
449
- if (cif->flags == ARM_TYPE_STRUCT)
450
- {
451
- rvalue = *(void **) regp;
452
- regp += 4;
453
- }
454
-
455
- for (i = 0, n = cif->nargs; i < n; i++)
456
- {
457
- ffi_type *ty = arg_types[i];
458
- int is_vfp_type = vfp_type_p (ty);
459
- size_t z = ty->size;
460
-
461
- if (vi < cif->vfp_nargs && is_vfp_type)
462
- {
463
- avalue[i] = vfp_space + cif->vfp_args[vi++] * 4;
464
- continue;
465
- }
466
- else if (!done_with_regs && !is_vfp_type)
467
- {
468
- char *tregp = ffi_align (ty, regp);
469
-
470
- z = (z < 4) ? 4 : z; // pad
471
-
472
- /* If the arguments either fits into the registers or uses registers
473
- and stack, while we haven't read other things from the stack */
474
- if (tregp + z <= eo_regp || !stack_used)
475
- {
476
- /* Because we're little endian, this is what it turns into. */
477
- avalue[i] = (void *) tregp;
478
- regp = tregp + z;
479
-
480
- /* If we read past the last core register, make sure we
481
- have not read from the stack before and continue
482
- reading after regp. */
483
- if (regp > eo_regp)
484
- {
485
- FFI_ASSERT (!stack_used);
486
- argp = regp;
487
- }
488
- if (regp >= eo_regp)
489
- {
490
- done_with_regs = 1;
491
- stack_used = 1;
492
- }
493
- continue;
494
- }
495
- }
496
-
497
- stack_used = 1;
498
- argp = ffi_align (ty, argp);
499
- avalue[i] = (void *) argp;
500
- argp += z;
501
- }
502
-
503
- return rvalue;
504
- }
505
-
506
- struct closure_frame
507
- {
508
- char vfp_space[8*8] __attribute__((aligned(8)));
509
- char result[8*4];
510
- char argp[];
511
- };
512
-
513
- int FFI_HIDDEN
514
- ffi_closure_inner_SYSV (ffi_cif *cif,
515
- void (*fun) (ffi_cif *, void *, void **, void *),
516
- void *user_data,
517
- struct closure_frame *frame)
518
- {
519
- void **avalue = (void **) alloca (cif->nargs * sizeof (void *));
520
- void *rvalue = ffi_prep_incoming_args_SYSV (cif, frame->result,
521
- frame->argp, avalue);
522
- fun (cif, rvalue, avalue, user_data);
523
- return cif->flags;
524
- }
525
-
526
- int FFI_HIDDEN
527
- ffi_closure_inner_VFP (ffi_cif *cif,
528
- void (*fun) (ffi_cif *, void *, void **, void *),
529
- void *user_data,
530
- struct closure_frame *frame)
531
- {
532
- void **avalue = (void **) alloca (cif->nargs * sizeof (void *));
533
- void *rvalue = ffi_prep_incoming_args_VFP (cif, frame->result, frame->argp,
534
- frame->vfp_space, avalue);
535
- fun (cif, rvalue, avalue, user_data);
536
- return cif->flags;
537
- }
538
-
539
- void ffi_closure_SYSV (void) FFI_HIDDEN;
540
- void ffi_closure_VFP (void) FFI_HIDDEN;
541
- void ffi_go_closure_SYSV (void) FFI_HIDDEN;
542
- void ffi_go_closure_VFP (void) FFI_HIDDEN;
543
-
544
- /* the cif must already be prep'ed */
545
-
546
- ffi_status
547
- ffi_prep_closure_loc (ffi_closure * closure,
548
- ffi_cif * cif,
549
- void (*fun) (ffi_cif *, void *, void **, void *),
550
- void *user_data, void *codeloc)
551
- {
552
- void (*closure_func) (void) = ffi_closure_SYSV;
553
-
554
- if (cif->abi == FFI_VFP)
555
- {
556
- /* We only need take the vfp path if there are vfp arguments. */
557
- if (cif->vfp_used)
558
- closure_func = ffi_closure_VFP;
559
- }
560
- else if (cif->abi != FFI_SYSV)
561
- return FFI_BAD_ABI;
562
-
563
- #if FFI_EXEC_TRAMPOLINE_TABLE
564
- void **config = (void **)((uint8_t *)codeloc - PAGE_MAX_SIZE);
565
- config[0] = closure;
566
- config[1] = closure_func;
567
- #else
568
- memcpy (closure->tramp, ffi_arm_trampoline, 8);
569
- __clear_cache(closure->tramp, closure->tramp + 8); /* clear data map */
570
- __clear_cache(codeloc, codeloc + 8); /* clear insn map */
571
- *(void (**)(void))(closure->tramp + 8) = closure_func;
572
- #endif
573
-
574
- closure->cif = cif;
575
- closure->fun = fun;
576
- closure->user_data = user_data;
577
-
578
- return FFI_OK;
579
- }
580
-
581
- ffi_status
582
- ffi_prep_go_closure (ffi_go_closure *closure, ffi_cif *cif,
583
- void (*fun) (ffi_cif *, void *, void **, void *))
584
- {
585
- void (*closure_func) (void) = ffi_go_closure_SYSV;
586
-
587
- if (cif->abi == FFI_VFP)
588
- {
589
- /* We only need take the vfp path if there are vfp arguments. */
590
- if (cif->vfp_used)
591
- closure_func = ffi_go_closure_VFP;
592
- }
593
- else if (cif->abi != FFI_SYSV)
594
- return FFI_BAD_ABI;
595
-
596
- closure->tramp = closure_func;
597
- closure->cif = cif;
598
- closure->fun = fun;
599
-
600
- return FFI_OK;
601
- }
602
-
603
- /* Below are routines for VFP hard-float support. */
604
-
605
- /* A subroutine of vfp_type_p. Given a structure type, return the type code
606
- of the first non-structure element. Recurse for structure elements.
607
- Return -1 if the structure is in fact empty, i.e. no nested elements. */
608
-
609
- static int
610
- is_hfa0 (const ffi_type *ty)
611
- {
612
- ffi_type **elements = ty->elements;
613
- int i, ret = -1;
614
-
615
- if (elements != NULL)
616
- for (i = 0; elements[i]; ++i)
617
- {
618
- ret = elements[i]->type;
619
- if (ret == FFI_TYPE_STRUCT || ret == FFI_TYPE_COMPLEX)
620
- {
621
- ret = is_hfa0 (elements[i]);
622
- if (ret < 0)
623
- continue;
624
- }
625
- break;
626
- }
627
-
628
- return ret;
629
- }
630
-
631
- /* A subroutine of vfp_type_p. Given a structure type, return true if all
632
- of the non-structure elements are the same as CANDIDATE. */
633
-
634
- static int
635
- is_hfa1 (const ffi_type *ty, int candidate)
636
- {
637
- ffi_type **elements = ty->elements;
638
- int i;
639
-
640
- if (elements != NULL)
641
- for (i = 0; elements[i]; ++i)
642
- {
643
- int t = elements[i]->type;
644
- if (t == FFI_TYPE_STRUCT || t == FFI_TYPE_COMPLEX)
645
- {
646
- if (!is_hfa1 (elements[i], candidate))
647
- return 0;
648
- }
649
- else if (t != candidate)
650
- return 0;
651
- }
652
-
653
- return 1;
654
- }
655
-
656
- /* Determine if TY is an homogenous floating point aggregate (HFA).
657
- That is, a structure consisting of 1 to 4 members of all the same type,
658
- where that type is a floating point scalar.
659
-
660
- Returns non-zero iff TY is an HFA. The result is an encoded value where
661
- bits 0-7 contain the type code, and bits 8-10 contain the element count. */
662
-
663
- static int
664
- vfp_type_p (const ffi_type *ty)
665
- {
666
- ffi_type **elements;
667
- int candidate, i;
668
- size_t size, ele_count;
669
-
670
- /* Quickest tests first. */
671
- candidate = ty->type;
672
- switch (ty->type)
673
- {
674
- default:
675
- return 0;
676
- case FFI_TYPE_FLOAT:
677
- case FFI_TYPE_DOUBLE:
678
- ele_count = 1;
679
- goto done;
680
- case FFI_TYPE_COMPLEX:
681
- candidate = ty->elements[0]->type;
682
- if (candidate != FFI_TYPE_FLOAT && candidate != FFI_TYPE_DOUBLE)
683
- return 0;
684
- ele_count = 2;
685
- goto done;
686
- case FFI_TYPE_STRUCT:
687
- break;
688
- }
689
-
690
- /* No HFA types are smaller than 4 bytes, or larger than 32 bytes. */
691
- size = ty->size;
692
- if (size < 4 || size > 32)
693
- return 0;
694
-
695
- /* Find the type of the first non-structure member. */
696
- elements = ty->elements;
697
- candidate = elements[0]->type;
698
- if (candidate == FFI_TYPE_STRUCT || candidate == FFI_TYPE_COMPLEX)
699
- {
700
- for (i = 0; ; ++i)
701
- {
702
- candidate = is_hfa0 (elements[i]);
703
- if (candidate >= 0)
704
- break;
705
- }
706
- }
707
-
708
- /* If the first member is not a floating point type, it's not an HFA.
709
- Also quickly re-check the size of the structure. */
710
- switch (candidate)
711
- {
712
- case FFI_TYPE_FLOAT:
713
- ele_count = size / sizeof(float);
714
- if (size != ele_count * sizeof(float))
715
- return 0;
716
- break;
717
- case FFI_TYPE_DOUBLE:
718
- ele_count = size / sizeof(double);
719
- if (size != ele_count * sizeof(double))
720
- return 0;
721
- break;
722
- default:
723
- return 0;
724
- }
725
- if (ele_count > 4)
726
- return 0;
727
-
728
- /* Finally, make sure that all scalar elements are the same type. */
729
- for (i = 0; elements[i]; ++i)
730
- {
731
- int t = elements[i]->type;
732
- if (t == FFI_TYPE_STRUCT || t == FFI_TYPE_COMPLEX)
733
- {
734
- if (!is_hfa1 (elements[i], candidate))
735
- return 0;
736
- }
737
- else if (t != candidate)
738
- return 0;
739
- }
740
-
741
- /* All tests succeeded. Encode the result. */
742
- done:
743
- return (ele_count << 8) | candidate;
744
- }
745
-
746
- static int
747
- place_vfp_arg (ffi_cif *cif, int h)
748
- {
749
- unsigned short reg = cif->vfp_reg_free;
750
- int align = 1, nregs = h >> 8;
751
-
752
- if ((h & 0xff) == FFI_TYPE_DOUBLE)
753
- align = 2, nregs *= 2;
754
-
755
- /* Align register number. */
756
- if ((reg & 1) && align == 2)
757
- reg++;
758
-
759
- while (reg + nregs <= 16)
760
- {
761
- int s, new_used = 0;
762
- for (s = reg; s < reg + nregs; s++)
763
- {
764
- new_used |= (1 << s);
765
- if (cif->vfp_used & (1 << s))
766
- {
767
- reg += align;
768
- goto next_reg;
769
- }
770
- }
771
- /* Found regs to allocate. */
772
- cif->vfp_used |= new_used;
773
- cif->vfp_args[cif->vfp_nargs++] = reg;
774
-
775
- /* Update vfp_reg_free. */
776
- if (cif->vfp_used & (1 << cif->vfp_reg_free))
777
- {
778
- reg += nregs;
779
- while (cif->vfp_used & (1 << reg))
780
- reg += 1;
781
- cif->vfp_reg_free = reg;
782
- }
783
- return 0;
784
- next_reg:;
785
- }
786
- // done, mark all regs as used
787
- cif->vfp_reg_free = 16;
788
- cif->vfp_used = 0xFFFF;
789
- return 1;
790
- }
791
-
792
- static void
793
- layout_vfp_args (ffi_cif * cif)
794
- {
795
- int i;
796
- /* Init VFP fields */
797
- cif->vfp_used = 0;
798
- cif->vfp_nargs = 0;
799
- cif->vfp_reg_free = 0;
800
- memset (cif->vfp_args, -1, 16); /* Init to -1. */
801
-
802
- for (i = 0; i < cif->nargs; i++)
803
- {
804
- int h = vfp_type_p (cif->arg_types[i]);
805
- if (h && place_vfp_arg (cif, h) == 1)
806
- break;
807
- }
808
- }