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,178 @@
1
+ /*
2
+ * Copyright (c) 2008, 2009, Wayne Meissner
3
+ * Copyright (c) 2008, Luc Heinrich <luc@honk-honk.com>
4
+ *
5
+ * All rights reserved.
6
+ *
7
+ * Redistribution and use in source and binary forms, with or without
8
+ * modification, are permitted provided that the following conditions are met:
9
+ *
10
+ * * Redistributions of source code must retain the above copyright notice, this
11
+ * list of conditions and the following disclaimer.
12
+ * * Redistributions in binary form must reproduce the above copyright notice
13
+ * this list of conditions and the following disclaimer in the documentation
14
+ * and/or other materials provided with the distribution.
15
+ * * The name of the author or authors may not be used to endorse or promote
16
+ * products derived from this software without specific prior written permission.
17
+ *
18
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
21
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
22
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
24
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
25
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
26
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
+ */
29
+
30
+ #include <stdbool.h>
31
+ #include <stdint.h>
32
+ #include <limits.h>
33
+ #include <ruby.h>
34
+ #include "rbffi.h"
35
+ #include "AbstractMemory.h"
36
+ #include "Pointer.h"
37
+ #include "MemoryPointer.h"
38
+
39
+ typedef struct MemoryPointer {
40
+ AbstractMemory memory;
41
+ char* storage; /* start of malloc area */
42
+ bool autorelease;
43
+ bool allocated;
44
+ } MemoryPointer;
45
+
46
+ static VALUE memptr_allocate(VALUE klass);
47
+ static void memptr_release(MemoryPointer* ptr);
48
+ static VALUE memptr_malloc(VALUE self, long size, long count, bool clear);
49
+ static VALUE memptr_free(VALUE self);
50
+
51
+ VALUE rbffi_MemoryPointerClass;
52
+
53
+ #define MEMPTR(obj) ((MemoryPointer *) rbffi_AbstractMemory_Cast(obj, rbffi_MemoryPointerClass))
54
+
55
+ VALUE
56
+ rbffi_MemoryPointer_NewInstance(long size, long count, bool clear)
57
+ {
58
+ return memptr_malloc(memptr_allocate(rbffi_MemoryPointerClass), size, count, clear);
59
+ }
60
+
61
+ static VALUE
62
+ memptr_allocate(VALUE klass)
63
+ {
64
+ MemoryPointer* p;
65
+ VALUE obj = Data_Make_Struct(klass, MemoryPointer, NULL, memptr_release, p);
66
+ p->memory.ops = &rbffi_AbstractMemoryOps;
67
+ p->memory.access = MEM_RD | MEM_WR;
68
+
69
+ return obj;
70
+ }
71
+
72
+ static VALUE
73
+ memptr_initialize(int argc, VALUE* argv, VALUE self)
74
+ {
75
+ VALUE size = Qnil, count = Qnil, clear = Qnil;
76
+ int nargs = rb_scan_args(argc, argv, "12", &size, &count, &clear);
77
+
78
+ memptr_malloc(self, rbffi_type_size(size), nargs > 1 ? NUM2LONG(count) : 1,
79
+ RTEST(clear) || clear == Qnil);
80
+
81
+ if (rb_block_given_p()) {
82
+ return rb_ensure(rb_yield, self, memptr_free, self);
83
+ }
84
+
85
+ return self;
86
+ }
87
+
88
+ static VALUE
89
+ memptr_malloc(VALUE self, long size, long count, bool clear)
90
+ {
91
+ MemoryPointer* p;
92
+ unsigned long msize;
93
+
94
+ Data_Get_Struct(self, MemoryPointer, p);
95
+
96
+ msize = size * count;
97
+
98
+ p->storage = xmalloc(msize + 7);
99
+ if (p->storage == NULL) {
100
+ rb_raise(rb_eNoMemError, "Failed to allocate memory size=%ld bytes", msize);
101
+ }
102
+ p->autorelease = true;
103
+ p->memory.typeSize = size;
104
+ p->memory.size = msize;
105
+ /* ensure the memory is aligned on at least a 8 byte boundary */
106
+ p->memory.address = (char *) (((uintptr_t) p->storage + 0x7) & (uintptr_t) ~0x7UL);;
107
+ p->allocated = true;
108
+
109
+ if (clear && p->memory.size > 0) {
110
+ memset(p->memory.address, 0, p->memory.size);
111
+ }
112
+
113
+ return self;
114
+ }
115
+
116
+ static VALUE
117
+ memptr_inspect(VALUE self)
118
+ {
119
+ MemoryPointer* ptr;
120
+ char tmp[100];
121
+
122
+ Data_Get_Struct(self, MemoryPointer, ptr);
123
+
124
+ snprintf(tmp, sizeof(tmp), "#<FFI::MemoryPointer address=%p size=%lu>", ptr->memory.address, ptr->memory.size);
125
+ return rb_str_new2(tmp);
126
+ }
127
+
128
+ static VALUE
129
+ memptr_free(VALUE self)
130
+ {
131
+ MemoryPointer* ptr;
132
+
133
+ Data_Get_Struct(self, MemoryPointer, ptr);
134
+
135
+ if (ptr->allocated) {
136
+ if (ptr->storage != NULL) {
137
+ free(ptr->storage);
138
+ ptr->storage = NULL;
139
+ }
140
+ ptr->allocated = false;
141
+ }
142
+
143
+ return self;
144
+ }
145
+
146
+ static VALUE
147
+ memptr_autorelease(VALUE self, VALUE autorelease)
148
+ {
149
+ MemoryPointer* ptr;
150
+
151
+ Data_Get_Struct(self, MemoryPointer, ptr);
152
+ ptr->autorelease = autorelease == Qtrue;
153
+
154
+ return autorelease;
155
+ }
156
+
157
+ static void
158
+ memptr_release(MemoryPointer* ptr)
159
+ {
160
+ if (ptr->autorelease && ptr->allocated && ptr->storage != NULL) {
161
+ xfree(ptr->storage);
162
+ ptr->storage = NULL;
163
+ }
164
+ xfree(ptr);
165
+ }
166
+
167
+ void
168
+ rbffi_MemoryPointer_Init(VALUE moduleFFI)
169
+ {
170
+ rbffi_MemoryPointerClass = rb_define_class_under(moduleFFI, "MemoryPointer", rbffi_PointerClass);
171
+ rb_global_variable(&rbffi_MemoryPointerClass);
172
+
173
+ rb_define_alloc_func(rbffi_MemoryPointerClass, memptr_allocate);
174
+ rb_define_method(rbffi_MemoryPointerClass, "initialize", memptr_initialize, -1);
175
+ rb_define_method(rbffi_MemoryPointerClass, "inspect", memptr_inspect, 0);
176
+ rb_define_method(rbffi_MemoryPointerClass, "autorelease=", memptr_autorelease, 1);
177
+ rb_define_method(rbffi_MemoryPointerClass, "free", memptr_free, 0);
178
+ }
@@ -0,0 +1,20 @@
1
+
2
+ #ifndef _MEMORYPOINTER_H
3
+ #define _MEMORYPOINTER_H
4
+
5
+ #include <stdbool.h>
6
+ #include <ruby.h>
7
+
8
+ #ifdef __cplusplus
9
+ extern "C" {
10
+ #endif
11
+
12
+ extern void rbffi_MemoryPointer_Init(VALUE moduleFFI);
13
+ extern VALUE rbffi_MemoryPointerClass;
14
+ extern VALUE rbffi_MemoryPointer_NewInstance(long size, long count, bool clear);
15
+ #ifdef __cplusplus
16
+ }
17
+ #endif
18
+
19
+ #endif /* _MEMORYPOINTER_H */
20
+
@@ -0,0 +1,356 @@
1
+ /*
2
+ * Copyright (c) 2009, Wayne Meissner
3
+ * All rights reserved.
4
+ *
5
+ * Redistribution and use in source and binary forms, with or without
6
+ * modification, are permitted provided that the following conditions are met:
7
+ *
8
+ * * Redistributions of source code must retain the above copyright notice, this
9
+ * list of conditions and the following disclaimer.
10
+ * * Redistributions in binary form must reproduce the above copyright notice
11
+ * this list of conditions and the following disclaimer in the documentation
12
+ * and/or other materials provided with the distribution.
13
+ * * The name of the author or authors may not be used to endorse or promote
14
+ * products derived from this software without specific prior written permission.
15
+ *
16
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
20
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
22
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
23
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26
+ */
27
+
28
+ #include <sys/param.h>
29
+ #include <sys/types.h>
30
+ #ifndef _WIN32
31
+ # include <sys/mman.h>
32
+ #endif
33
+ #include <stdio.h>
34
+ #include <stdint.h>
35
+ #include <stdbool.h>
36
+ #ifndef _WIN32
37
+ # include <unistd.h>
38
+ #endif
39
+ #include <errno.h>
40
+ #include <ruby.h>
41
+ #if defined(HAVE_NATIVETHREAD) && !defined(_WIN32) && !defined(__WIN32__)
42
+ # include <pthread.h>
43
+ #endif
44
+
45
+ #include <ffi.h>
46
+ #include "rbffi.h"
47
+ #include "compat.h"
48
+
49
+ #include "Function.h"
50
+ #include "Types.h"
51
+ #include "Type.h"
52
+ #include "LastError.h"
53
+ #include "Call.h"
54
+ #include "MethodHandle.h"
55
+
56
+
57
+ #define MAX_METHOD_FIXED_ARITY (6)
58
+
59
+ #if defined(HAVE_NATIVETHREAD) && !defined(_WIN32) && !defined(__WIN32__)
60
+ # define USE_PTHREAD_LOCAL
61
+ #endif
62
+
63
+ #ifndef roundup
64
+ # define roundup(x, y) ((((x)+((y)-1))/(y))*(y))
65
+ #endif
66
+ #ifdef _WIN32
67
+ typedef char* caddr_t;
68
+ #endif
69
+
70
+ #if defined(HAVE_NATIVETHREAD) && !defined(_WIN32)
71
+ # define pool_lock(p) pthread_mutex_lock(&(p)->mutex)
72
+ # define pool_unlock(p) pthread_mutex_unlock(&(p)->mutex)
73
+ #else
74
+ # define pool_lock(p)
75
+ # define pool_unlock(p)
76
+ #endif
77
+
78
+
79
+ #ifdef USE_RAW
80
+ # define METHOD_CLOSURE ffi_raw_closure
81
+ # define METHOD_PARAMS ffi_raw*
82
+ #else
83
+ # define METHOD_CLOSURE ffi_closure
84
+ # define METHOD_PARAMS void**
85
+ #endif
86
+
87
+ static void* allocatePage(void);
88
+ static bool freePage(void *);
89
+ static bool protectPage(void *);
90
+
91
+ typedef void (*methodfn)(ffi_cif* cif, void* retval, METHOD_PARAMS parameters, void* user_data);
92
+ static void attached_method_fast_invoke(ffi_cif* cif, void* retval, METHOD_PARAMS parameters, void* user_data);
93
+ static void attached_method_invoke(ffi_cif* cif, void* retval, METHOD_PARAMS parameters, void* user_data);
94
+
95
+ struct MethodHandle {
96
+ FunctionType* info;
97
+ void* function;
98
+ METHOD_CLOSURE* closure;
99
+ void* code;
100
+ ffi_cif cif;
101
+ struct MethodHandlePool* pool;
102
+ MethodHandle* next;
103
+ };
104
+
105
+ struct MethodHandlePool {
106
+ #if defined (HAVE_NATIVETHREAD) && !defined(_WIN32)
107
+ pthread_mutex_t mutex;
108
+ #endif
109
+ void (*fn)(ffi_cif* cif, void* retval, METHOD_PARAMS parameters, void* user_data);
110
+ MethodHandle* list;
111
+ };
112
+
113
+ static ffi_type* methodHandleParamTypes[] = {
114
+ &ffi_type_sint,
115
+ &ffi_type_pointer,
116
+ &ffi_type_ulong,
117
+ };
118
+
119
+ static MethodHandlePool defaultMethodHandlePool, fastMethodHandlePool;
120
+
121
+ static int pageSize;
122
+
123
+
124
+ MethodHandle*
125
+ rbffi_MethodHandle_Alloc(FunctionType* fnInfo, void* function)
126
+ {
127
+ MethodHandle* method, *list = NULL;
128
+ MethodHandlePool* pool;
129
+ caddr_t page;
130
+ ffi_status ffiStatus;
131
+ int nclosures, closureSize;
132
+ int i, arity;
133
+
134
+ arity = fnInfo->parameterCount;
135
+ if (arity < 0) {
136
+ rb_raise(rb_eRuntimeError, "Cannot create method handle for variadic functions");
137
+ return NULL;
138
+ }
139
+
140
+ if (arity <= MAX_METHOD_FIXED_ARITY && !fnInfo->blocking && !fnInfo->hasStruct) {
141
+ pool = &fastMethodHandlePool;
142
+ } else {
143
+ pool = &defaultMethodHandlePool;
144
+ }
145
+
146
+ pool_lock(pool);
147
+ if (pool->list != NULL) {
148
+ method = pool->list;
149
+ pool->list = pool->list->next;
150
+ pool_unlock(pool);
151
+ method->info = fnInfo;
152
+ method->function = function;
153
+
154
+ return method;
155
+ }
156
+
157
+ closureSize = roundup(sizeof(METHOD_CLOSURE), 8);
158
+ nclosures = pageSize / closureSize;
159
+ page = allocatePage();
160
+ if (page == NULL) {
161
+ pool_unlock(pool);
162
+ rb_raise(rb_eRuntimeError, "failed to allocate a page. errno=%d (%s)", errno, strerror(errno));
163
+ }
164
+
165
+ for (i = 0; i < nclosures; ++i) {
166
+ char errmsg[256];
167
+ method = calloc(1, sizeof(MethodHandle));
168
+ if (method == NULL) {
169
+ snprintf(errmsg, sizeof(errmsg), "malloc failed: %s", strerror(errno));
170
+ goto error;
171
+ }
172
+ method->next = list;
173
+ list = method;
174
+ method->pool = pool;
175
+ method->code = method->closure = (METHOD_CLOSURE *) (page + (i * closureSize));
176
+
177
+ ffiStatus = ffi_prep_cif(&method->cif, FFI_DEFAULT_ABI, 3, &ffi_type_ulong,
178
+ methodHandleParamTypes);
179
+ if (ffiStatus != FFI_OK) {
180
+ snprintf(errmsg, sizeof(errmsg), "ffi_prep_cif failed. status=%#x", ffiStatus);
181
+ goto error;
182
+ }
183
+
184
+ #ifdef USE_RAW
185
+ ffiStatus = ffi_prep_raw_closure(method->closure, &method->cif, pool->fn, method);
186
+ #else
187
+ ffiStatus = ffi_prep_closure(method->closure, &method->cif, pool->fn, method);
188
+ #endif
189
+ if (ffiStatus != FFI_OK) {
190
+ snprintf(errmsg, sizeof(errmsg), "ffi_prep_closure failed. status=%#x", ffiStatus);
191
+ goto error;
192
+ }
193
+ continue;
194
+ error:
195
+ while (list != NULL) {
196
+ method = list;
197
+ list = list->next;
198
+ free(method);
199
+ }
200
+ freePage(page);
201
+ pool_unlock(pool);
202
+ rb_raise(rb_eRuntimeError, "%s", errmsg);
203
+ }
204
+ protectPage(page);
205
+
206
+ /* take the first member of the list for this handle */
207
+ method = list;
208
+ list = list->next;
209
+
210
+ /* now add the new block of MethodHandles to the pool */
211
+ if (list != NULL) {
212
+ list->next = pool->list;
213
+ pool->list = list;
214
+ }
215
+ pool_unlock(pool);
216
+ method->info = fnInfo;
217
+ method->function = function;
218
+
219
+ return method;
220
+ }
221
+
222
+ void
223
+ rbffi_MethodHandle_Free(MethodHandle* method)
224
+ {
225
+ if (method != NULL) {
226
+ MethodHandlePool* pool = method->pool;
227
+ pool_lock(pool);
228
+ method->next = pool->list;
229
+ pool->list = method;
230
+ pool_unlock(pool);
231
+ }
232
+ }
233
+
234
+ void*
235
+ rbffi_MethodHandle_CodeAddress(MethodHandle* handle)
236
+ {
237
+ return handle->code;
238
+ }
239
+
240
+ /*
241
+ * attached_method_invoke is used as the <= MAX_METHOD_FIXED_ARITY argument fixed-arity fast path
242
+ */
243
+ static void
244
+ attached_method_fast_invoke(ffi_cif* cif, void* mretval, METHOD_PARAMS parameters, void* user_data)
245
+ {
246
+ MethodHandle* handle = (MethodHandle *) user_data;
247
+ FunctionType* fnInfo = handle->info;
248
+ void* ffiValues[MAX_METHOD_FIXED_ARITY];
249
+ FFIStorage params[MAX_METHOD_FIXED_ARITY], retval;
250
+
251
+
252
+ if (fnInfo->parameterCount > 0) {
253
+ #ifdef USE_RAW
254
+ int argc = parameters[0].sint;
255
+ VALUE* argv = *(VALUE **) & parameters[1];
256
+ #else
257
+ int argc = *(ffi_sarg *) parameters[0];
258
+ VALUE* argv = *(VALUE **) parameters[1];
259
+ #endif
260
+
261
+ rbffi_SetupCallParams(argc, argv,
262
+ fnInfo->parameterCount, fnInfo->nativeParameterTypes, params, ffiValues,
263
+ fnInfo->callbackParameters, fnInfo->callbackCount, fnInfo->rbEnums);
264
+ }
265
+
266
+ #ifdef USE_RAW
267
+ ffi_raw_call(&fnInfo->ffi_cif, FFI_FN(handle->function), &retval, (ffi_raw *) ffiValues[0]);
268
+ #else
269
+ ffi_call(&fnInfo->ffi_cif, FFI_FN(handle->function), &retval, ffiValues);
270
+ #endif
271
+
272
+ if (!fnInfo->ignoreErrno) {
273
+ rbffi_save_errno();
274
+ }
275
+
276
+ *((VALUE *) mretval) = rbffi_NativeValue_ToRuby(fnInfo->returnType, fnInfo->rbReturnType,
277
+ &retval, fnInfo->rbEnums);
278
+ }
279
+
280
+ /*
281
+ * attached_method_vinvoke is used functions with more than 6 parameters, or
282
+ * with struct param or return values
283
+ */
284
+ static void
285
+ attached_method_invoke(ffi_cif* cif, void* mretval, METHOD_PARAMS parameters, void* user_data)
286
+ {
287
+ MethodHandle* handle = (MethodHandle *) user_data;
288
+
289
+ #ifdef USE_RAW
290
+ int argc = parameters[0].sint;
291
+ VALUE* argv = *(VALUE **) &parameters[1];
292
+ #else
293
+ int argc = *(ffi_sarg *) parameters[0];
294
+ VALUE* argv = *(VALUE **) parameters[1];
295
+ #endif
296
+
297
+ *(VALUE *) mretval = rbffi_CallFunction(argc, argv, handle->function, handle->info);
298
+ }
299
+
300
+ static int
301
+ getPageSize()
302
+ {
303
+ #ifdef _WIN32
304
+ SYSTEM_INFO si;
305
+ GetSystemInfo(&si);
306
+ return si.dwPageSize;
307
+ #else
308
+ return sysconf(_SC_PAGESIZE);
309
+ #endif
310
+ }
311
+
312
+ static void*
313
+ allocatePage(void)
314
+ {
315
+ #ifdef _WIN32
316
+ return VirtualAlloc(NULL, pageSize, MEM_COMMIT | MEM_RESERVE, PAGE_READWRITE);
317
+ #else
318
+ caddr_t page = mmap(NULL, pageSize, PROT_READ | PROT_WRITE, MAP_ANON | MAP_PRIVATE, -1, 0);
319
+ return (page != (caddr_t) -1) ? page : NULL;
320
+ #endif
321
+ }
322
+
323
+ static bool
324
+ freePage(void *addr)
325
+ {
326
+ #ifdef _WIN32
327
+ return VirtualFree(addr, 0, MEM_RELEASE);
328
+ #else
329
+ return munmap(addr, pageSize) == 0;
330
+ #endif
331
+ }
332
+
333
+ static bool
334
+ protectPage(void* page)
335
+ {
336
+ #ifdef _WIN32
337
+ DWORD oldProtect;
338
+ return VirtualProtect(page, pageSize, PAGE_EXECUTE_READ, &oldProtect);
339
+ #else
340
+ return mprotect(page, pageSize, PROT_READ | PROT_EXEC) == 0;
341
+ #endif
342
+ }
343
+
344
+ void
345
+ rbffi_MethodHandle_Init(VALUE module)
346
+ {
347
+ pageSize = getPageSize();
348
+
349
+ #if defined(HAVE_NATIVETHREAD) && !defined(_WIN32)
350
+ pthread_mutex_init(&defaultMethodHandlePool.mutex, NULL);
351
+ pthread_mutex_init(&fastMethodHandlePool.mutex, NULL);
352
+ #endif /* USE_PTHREAD_LOCAL */
353
+ defaultMethodHandlePool.fn = attached_method_invoke;
354
+ fastMethodHandlePool.fn = attached_method_fast_invoke;
355
+ }
356
+