rbdc 0.8.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (266) hide show
  1. data/bindings/ruby/rbdc/extconf.rb +57 -0
  2. data/bindings/ruby/rbdc/rbdc.c +304 -0
  3. data/dyncall/AUTHORS +4 -0
  4. data/dyncall/BUGS +3 -0
  5. data/dyncall/CMakeLists.txt +79 -0
  6. data/dyncall/ChangeLog +165 -0
  7. data/dyncall/LICENSE +15 -0
  8. data/dyncall/Makefile.M +15 -0
  9. data/dyncall/Makefile.embedded +71 -0
  10. data/dyncall/Makefile.generic +36 -0
  11. data/dyncall/Nmakefile +45 -0
  12. data/dyncall/README +92 -0
  13. data/dyncall/ToDo +114 -0
  14. data/dyncall/autovar/LICENSE.txt +15 -0
  15. data/dyncall/autovar/README.txt +69 -0
  16. data/dyncall/autovar/autovar_ABI.h +44 -0
  17. data/dyncall/autovar/autovar_ARCH.h +56 -0
  18. data/dyncall/autovar/autovar_CC.h +46 -0
  19. data/dyncall/autovar/autovar_OS.h +78 -0
  20. data/dyncall/autovar/autovar_OSFAMILY.h +39 -0
  21. data/dyncall/buildsys/cmake/Modules/FindDynCall.cmake +43 -0
  22. data/dyncall/buildsys/cmake/Modules/FindDynCallback.cmake +43 -0
  23. data/dyncall/buildsys/cmake/Modules/FindDynLoad.cmake +45 -0
  24. data/dyncall/buildsys/cmake/Modules/UseLATEX.cmake +811 -0
  25. data/dyncall/buildsys/dynmake/Makefile.base.M +82 -0
  26. data/dyncall/buildsys/dynmake/dynmake.bat +2 -0
  27. data/dyncall/buildsys/dynmake/dynmake.sh +4 -0
  28. data/dyncall/buildsys/lua/Makefile +10 -0
  29. data/dyncall/buildsys/lua/README.txt +4 -0
  30. data/dyncall/buildsys/lua/bootstrap.sh +34 -0
  31. data/dyncall/buildsys/lua/cleanup.sh +6 -0
  32. data/dyncall/buildsys/lua/mkfile +34 -0
  33. data/dyncall/buildsys/lua/setenv.sh +4 -0
  34. data/dyncall/buildsys/mk/app.mk +30 -0
  35. data/dyncall/buildsys/mk/dirs.mk +27 -0
  36. data/dyncall/buildsys/mk/epilog.mk +30 -0
  37. data/dyncall/buildsys/mk/lib.mk +23 -0
  38. data/dyncall/buildsys/mk/pcc.mk +60 -0
  39. data/dyncall/buildsys/mk/prolog.mk +35 -0
  40. data/dyncall/buildsys/nmake/common.nmake +61 -0
  41. data/dyncall/buildsys/nmake/epilog.nmake +28 -0
  42. data/dyncall/buildsys/nmake/prolog.nmake +76 -0
  43. data/dyncall/buildsys/nmake/tool_gcc.nmake +82 -0
  44. data/dyncall/buildsys/nmake/tool_msvc.nmake +67 -0
  45. data/dyncall/buildsys/scripts/batch-build-linux.sh +11 -0
  46. data/dyncall/buildsys/scripts/batch-build-minix.sh +11 -0
  47. data/dyncall/buildsys/scripts/batch-build-psp.sh +11 -0
  48. data/dyncall/buildsys/scripts/conf-nds.bat +41 -0
  49. data/dyncall/buildsys/scripts/setenv-cross-ios.sh +8 -0
  50. data/dyncall/buildsys/scripts/setenv-sdk-ios.sh +22 -0
  51. data/dyncall/buildsys/vs2005/dyncall/dyncall.vcproj +245 -0
  52. data/dyncall/buildsys/vs2005/test_plain/test_plain.vcproj +202 -0
  53. data/dyncall/buildsys/vs2005/vs2005.sln +29 -0
  54. data/dyncall/configure +152 -0
  55. data/dyncall/configure.bat +157 -0
  56. data/dyncall/configure.rc +234 -0
  57. data/dyncall/dynMakefile +4 -0
  58. data/dyncall/dyncall/CMakeLists.txt +53 -0
  59. data/dyncall/dyncall/DynCallConfig.cmake +3 -0
  60. data/dyncall/dyncall/Makefile.M +10 -0
  61. data/dyncall/dyncall/Makefile.embedded +20 -0
  62. data/dyncall/dyncall/Makefile.generic +16 -0
  63. data/dyncall/dyncall/Nmakefile +62 -0
  64. data/dyncall/dyncall/README-Developer.txt +45 -0
  65. data/dyncall/dyncall/README.txt +65 -0
  66. data/dyncall/dyncall/TODO +9 -0
  67. data/dyncall/dyncall/dynMakefile +4 -0
  68. data/dyncall/dyncall/dyncall.3 +189 -0
  69. data/dyncall/dyncall/dyncall.h +135 -0
  70. data/dyncall/dyncall/dyncall_alloc.h +40 -0
  71. data/dyncall/dyncall/dyncall_api.c +167 -0
  72. data/dyncall/dyncall/dyncall_call.S +72 -0
  73. data/dyncall/dyncall/dyncall_call_arm32_arm.S +80 -0
  74. data/dyncall/dyncall/dyncall_call_arm32_arm.h +61 -0
  75. data/dyncall/dyncall/dyncall_call_arm32_arm_armhf.S +96 -0
  76. data/dyncall/dyncall/dyncall_call_arm32_arm_armhf.h +44 -0
  77. data/dyncall/dyncall/dyncall_call_arm32_thumb.h +65 -0
  78. data/dyncall/dyncall/dyncall_call_arm32_thumb_apple.s +80 -0
  79. data/dyncall/dyncall/dyncall_call_arm32_thumb_armhf.S +121 -0
  80. data/dyncall/dyncall/dyncall_call_arm32_thumb_gas.s +101 -0
  81. data/dyncall/dyncall/dyncall_call_mips.h +50 -0
  82. data/dyncall/dyncall/dyncall_call_mips_eabi.h +61 -0
  83. data/dyncall/dyncall/dyncall_call_mips_eabi_gas.s +115 -0
  84. data/dyncall/dyncall/dyncall_call_mips_gas.S +36 -0
  85. data/dyncall/dyncall/dyncall_call_mips_n32.h +67 -0
  86. data/dyncall/dyncall/dyncall_call_mips_n32_gas.s +192 -0
  87. data/dyncall/dyncall/dyncall_call_mips_n64.h +67 -0
  88. data/dyncall/dyncall/dyncall_call_mips_n64_gas.s +192 -0
  89. data/dyncall/dyncall/dyncall_call_mips_o32.h +70 -0
  90. data/dyncall/dyncall/dyncall_call_mips_o32_gas.s +109 -0
  91. data/dyncall/dyncall/dyncall_call_ppc32.S +266 -0
  92. data/dyncall/dyncall/dyncall_call_ppc32.h +62 -0
  93. data/dyncall/dyncall/dyncall_call_sparc.S +192 -0
  94. data/dyncall/dyncall/dyncall_call_sparc.h +42 -0
  95. data/dyncall/dyncall/dyncall_call_sparc64.S +361 -0
  96. data/dyncall/dyncall/dyncall_call_sparc64.h +42 -0
  97. data/dyncall/dyncall/dyncall_call_sparc_v9.S +220 -0
  98. data/dyncall/dyncall/dyncall_call_sparc_v9.h +42 -0
  99. data/dyncall/dyncall/dyncall_call_x64-att.S +146 -0
  100. data/dyncall/dyncall/dyncall_call_x64.S +149 -0
  101. data/dyncall/dyncall/dyncall_call_x64.h +63 -0
  102. data/dyncall/dyncall/dyncall_call_x64_generic_masm.asm +70 -0
  103. data/dyncall/dyncall/dyncall_call_x86.S +238 -0
  104. data/dyncall/dyncall/dyncall_call_x86.h +70 -0
  105. data/dyncall/dyncall/dyncall_call_x86_8a.s +127 -0
  106. data/dyncall/dyncall/dyncall_call_x86_generic_masm.asm +136 -0
  107. data/dyncall/dyncall/dyncall_call_x86_nasm.asm +234 -0
  108. data/dyncall/dyncall/dyncall_callf.c +112 -0
  109. data/dyncall/dyncall/dyncall_callf.h +52 -0
  110. data/dyncall/dyncall/dyncall_callvm.c +68 -0
  111. data/dyncall/dyncall/dyncall_callvm.h +88 -0
  112. data/dyncall/dyncall/dyncall_callvm_arm32_arm.c +250 -0
  113. data/dyncall/dyncall/dyncall_callvm_arm32_arm.h +59 -0
  114. data/dyncall/dyncall/dyncall_callvm_arm32_arm_armhf.c +204 -0
  115. data/dyncall/dyncall/dyncall_callvm_arm32_arm_armhf.h +63 -0
  116. data/dyncall/dyncall/dyncall_callvm_arm32_thumb.c +271 -0
  117. data/dyncall/dyncall/dyncall_callvm_arm32_thumb.h +59 -0
  118. data/dyncall/dyncall/dyncall_callvm_base.c +33 -0
  119. data/dyncall/dyncall/dyncall_callvm_mips.c +40 -0
  120. data/dyncall/dyncall/dyncall_callvm_mips.h +37 -0
  121. data/dyncall/dyncall/dyncall_callvm_mips_eabi.c +181 -0
  122. data/dyncall/dyncall/dyncall_callvm_mips_eabi.h +61 -0
  123. data/dyncall/dyncall/dyncall_callvm_mips_n32.c +268 -0
  124. data/dyncall/dyncall/dyncall_callvm_mips_n64.c +268 -0
  125. data/dyncall/dyncall/dyncall_callvm_mips_n64.h +53 -0
  126. data/dyncall/dyncall/dyncall_callvm_mips_o32.c +235 -0
  127. data/dyncall/dyncall/dyncall_callvm_mips_o32.h +45 -0
  128. data/dyncall/dyncall/dyncall_callvm_ppc32.c +372 -0
  129. data/dyncall/dyncall/dyncall_callvm_ppc32.h +61 -0
  130. data/dyncall/dyncall/dyncall_callvm_sparc.c +155 -0
  131. data/dyncall/dyncall/dyncall_callvm_sparc.h +44 -0
  132. data/dyncall/dyncall/dyncall_callvm_sparc64.c +239 -0
  133. data/dyncall/dyncall/dyncall_callvm_sparc64.h +47 -0
  134. data/dyncall/dyncall/dyncall_callvm_sparc_v9.c +182 -0
  135. data/dyncall/dyncall/dyncall_callvm_sparc_v9.h +45 -0
  136. data/dyncall/dyncall/dyncall_callvm_x64.c +228 -0
  137. data/dyncall/dyncall/dyncall_callvm_x64.h +111 -0
  138. data/dyncall/dyncall/dyncall_callvm_x86.c +667 -0
  139. data/dyncall/dyncall/dyncall_callvm_x86.h +75 -0
  140. data/dyncall/dyncall/dyncall_config.h +46 -0
  141. data/dyncall/dyncall/dyncall_macros.h +248 -0
  142. data/dyncall/dyncall/dyncall_signature.h +71 -0
  143. data/dyncall/dyncall/dyncall_struct.c +255 -0
  144. data/dyncall/dyncall/dyncall_struct.h +69 -0
  145. data/dyncall/dyncall/dyncall_types.h +74 -0
  146. data/dyncall/dyncall/dyncall_utils.h +38 -0
  147. data/dyncall/dyncall/dyncall_value.h +73 -0
  148. data/dyncall/dyncall/dyncall_vector.c +52 -0
  149. data/dyncall/dyncall/dyncall_vector.h +56 -0
  150. data/dyncall/dyncall/gen-masm.sh +7 -0
  151. data/dyncall/dyncall/mkfile +29 -0
  152. data/dyncall/dyncallback/CMakeLists.txt +55 -0
  153. data/dyncall/dyncallback/DynCallbackConfig.cmake +2 -0
  154. data/dyncall/dyncallback/Makefile.M +10 -0
  155. data/dyncall/dyncallback/Makefile.embedded +15 -0
  156. data/dyncall/dyncallback/Makefile.generic +20 -0
  157. data/dyncall/dyncallback/Nmakefile +71 -0
  158. data/dyncall/dyncallback/README.txt +9 -0
  159. data/dyncall/dyncallback/TODO +4 -0
  160. data/dyncall/dyncallback/dynMakefile +4 -0
  161. data/dyncall/dyncallback/dyncall_alloc_wx.c +35 -0
  162. data/dyncall/dyncallback/dyncall_alloc_wx.h +46 -0
  163. data/dyncall/dyncallback/dyncall_alloc_wx_malloc.c +40 -0
  164. data/dyncall/dyncallback/dyncall_alloc_wx_mmap.c +42 -0
  165. data/dyncall/dyncallback/dyncall_alloc_wx_win32.c +42 -0
  166. data/dyncall/dyncallback/dyncall_args.c +45 -0
  167. data/dyncall/dyncallback/dyncall_args.h +65 -0
  168. data/dyncall/dyncallback/dyncall_args_arm32_arm.c +112 -0
  169. data/dyncall/dyncallback/dyncall_args_arm32_arm.h +40 -0
  170. data/dyncall/dyncallback/dyncall_args_arm32_thumb.c +29 -0
  171. data/dyncall/dyncallback/dyncall_args_arm32_thumb.h +32 -0
  172. data/dyncall/dyncallback/dyncall_args_mips.c +81 -0
  173. data/dyncall/dyncallback/dyncall_args_mips.h +41 -0
  174. data/dyncall/dyncallback/dyncall_args_ppc32.c +88 -0
  175. data/dyncall/dyncallback/dyncall_args_ppc32.h +41 -0
  176. data/dyncall/dyncallback/dyncall_args_sparc32.c +41 -0
  177. data/dyncall/dyncallback/dyncall_args_sparc32.h +37 -0
  178. data/dyncall/dyncallback/dyncall_args_sparc64.c +41 -0
  179. data/dyncall/dyncallback/dyncall_args_sparc64.h +37 -0
  180. data/dyncall/dyncallback/dyncall_args_x64.c +73 -0
  181. data/dyncall/dyncallback/dyncall_args_x64.h +44 -0
  182. data/dyncall/dyncallback/dyncall_args_x86.c +121 -0
  183. data/dyncall/dyncallback/dyncall_args_x86.h +58 -0
  184. data/dyncall/dyncallback/dyncall_callback.c +45 -0
  185. data/dyncall/dyncallback/dyncall_callback.h +51 -0
  186. data/dyncall/dyncallback/dyncall_callback_arch.S +71 -0
  187. data/dyncall/dyncallback/dyncall_callback_arm32_arm.c +63 -0
  188. data/dyncall/dyncallback/dyncall_callback_arm32_arm.h +45 -0
  189. data/dyncall/dyncallback/dyncall_callback_arm32_arm_apple.s +73 -0
  190. data/dyncall/dyncallback/dyncall_callback_arm32_arm_gas.s +73 -0
  191. data/dyncall/dyncallback/dyncall_callback_arm32_thumb.c +29 -0
  192. data/dyncall/dyncallback/dyncall_callback_arm32_thumb.h +33 -0
  193. data/dyncall/dyncallback/dyncall_callback_arm32_thumb_apple.s +32 -0
  194. data/dyncall/dyncallback/dyncall_callback_arm32_thumb_gas.s +32 -0
  195. data/dyncall/dyncallback/dyncall_callback_mips.c +61 -0
  196. data/dyncall/dyncallback/dyncall_callback_mips.h +42 -0
  197. data/dyncall/dyncallback/dyncall_callback_ppc32.S +33 -0
  198. data/dyncall/dyncallback/dyncall_callback_ppc32.c +60 -0
  199. data/dyncall/dyncallback/dyncall_callback_ppc32.h +43 -0
  200. data/dyncall/dyncallback/dyncall_callback_ppc32_apple.s +180 -0
  201. data/dyncall/dyncallback/dyncall_callback_sparc32.c +57 -0
  202. data/dyncall/dyncallback/dyncall_callback_sparc32.h +43 -0
  203. data/dyncall/dyncallback/dyncall_callback_sparc32.s +30 -0
  204. data/dyncall/dyncallback/dyncall_callback_sparc64.c +57 -0
  205. data/dyncall/dyncallback/dyncall_callback_sparc64.s +30 -0
  206. data/dyncall/dyncallback/dyncall_callback_x64.S +187 -0
  207. data/dyncall/dyncallback/dyncall_callback_x64.c +69 -0
  208. data/dyncall/dyncallback/dyncall_callback_x64.h +44 -0
  209. data/dyncall/dyncallback/dyncall_callback_x64_apple.s +122 -0
  210. data/dyncall/dyncallback/dyncall_callback_x64_gas.s +119 -0
  211. data/dyncall/dyncallback/dyncall_callback_x64_gas_w64.s +102 -0
  212. data/dyncall/dyncallback/dyncall_callback_x64_masm.asm +89 -0
  213. data/dyncall/dyncallback/dyncall_callback_x86.S +115 -0
  214. data/dyncall/dyncallback/dyncall_callback_x86.c +281 -0
  215. data/dyncall/dyncallback/dyncall_callback_x86.h +49 -0
  216. data/dyncall/dyncallback/dyncall_callback_x86_8a.s +100 -0
  217. data/dyncall/dyncallback/dyncall_callback_x86_masm.asm +74 -0
  218. data/dyncall/dyncallback/dyncall_thunk.c +47 -0
  219. data/dyncall/dyncallback/dyncall_thunk.h +84 -0
  220. data/dyncall/dyncallback/dyncall_thunk_arm32_arm.c +45 -0
  221. data/dyncall/dyncallback/dyncall_thunk_arm32_arm.h +40 -0
  222. data/dyncall/dyncallback/dyncall_thunk_arm32_thumb.c +29 -0
  223. data/dyncall/dyncallback/dyncall_thunk_arm32_thumb.h +35 -0
  224. data/dyncall/dyncallback/dyncall_thunk_mips.c +52 -0
  225. data/dyncall/dyncallback/dyncall_thunk_mips.h +37 -0
  226. data/dyncall/dyncallback/dyncall_thunk_ppc32.c +51 -0
  227. data/dyncall/dyncallback/dyncall_thunk_ppc32.h +40 -0
  228. data/dyncall/dyncallback/dyncall_thunk_sparc32.c +32 -0
  229. data/dyncall/dyncallback/dyncall_thunk_sparc32.h +36 -0
  230. data/dyncall/dyncallback/dyncall_thunk_sparc64.c +32 -0
  231. data/dyncall/dyncallback/dyncall_thunk_sparc64.h +36 -0
  232. data/dyncall/dyncallback/dyncall_thunk_x64.c +48 -0
  233. data/dyncall/dyncallback/dyncall_thunk_x64.h +39 -0
  234. data/dyncall/dyncallback/dyncall_thunk_x86.c +44 -0
  235. data/dyncall/dyncallback/dyncall_thunk_x86.h +39 -0
  236. data/dyncall/dyncallback/dyncallback.3 +134 -0
  237. data/dyncall/dyncallback/gen-masm.sh +8 -0
  238. data/dyncall/dyncallback/mkfile +29 -0
  239. data/dyncall/dynload/CMakeLists.txt +25 -0
  240. data/dyncall/dynload/DynLoadConfig.cmake +3 -0
  241. data/dyncall/dynload/Makefile.M +10 -0
  242. data/dyncall/dynload/Makefile.embedded +22 -0
  243. data/dyncall/dynload/Makefile.generic +18 -0
  244. data/dyncall/dynload/Nmakefile +57 -0
  245. data/dyncall/dynload/README.txt +113 -0
  246. data/dyncall/dynload/TODO +20 -0
  247. data/dyncall/dynload/dynMakefile +4 -0
  248. data/dyncall/dynload/dynload.3 +64 -0
  249. data/dyncall/dynload/dynload.c +38 -0
  250. data/dyncall/dynload/dynload.h +65 -0
  251. data/dyncall/dynload/dynload_alloc.h +40 -0
  252. data/dyncall/dynload/dynload_darwin.c +89 -0
  253. data/dyncall/dynload/dynload_syms.c +38 -0
  254. data/dyncall/dynload/dynload_syms_elf.c +214 -0
  255. data/dyncall/dynload/dynload_syms_mach-o.c +167 -0
  256. data/dyncall/dynload/dynload_syms_pe.c +109 -0
  257. data/dyncall/dynload/dynload_unix.c +57 -0
  258. data/dyncall/dynload/dynload_windows.c +59 -0
  259. data/dyncall/mkfile +36 -0
  260. data/dyncall/portasm/README.txt +42 -0
  261. data/dyncall/portasm/gen-masm.sh +3 -0
  262. data/dyncall/portasm/portasm-arm.S +36 -0
  263. data/dyncall/portasm/portasm-ppc.S +98 -0
  264. data/dyncall/portasm/portasm-x64-att.S +155 -0
  265. data/dyncall/portasm/portasm-x86.S +127 -0
  266. metadata +311 -0
@@ -0,0 +1,42 @@
1
+ /*
2
+
3
+ Package: dyncall
4
+ Library: dyncall
5
+ File: dyncall/dyncall_call_sparc64.h
6
+ Description:
7
+ License:
8
+
9
+ Copyright (c) 2011 Daniel Adler <dadler@uni-goettingen.de>
10
+
11
+ Permission to use, copy, modify, and distribute this software for any
12
+ purpose with or without fee is hereby granted, provided that the above
13
+ copyright notice and this permission notice appear in all copies.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
16
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
17
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
18
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
19
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
20
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
21
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
22
+
23
+ */
24
+
25
+
26
+ #ifndef DYNCALL_CALL_SPARC64_H
27
+ #define DYNCALL_CALL_SPARC64_H
28
+
29
+ #include "dyncall_types.h"
30
+
31
+ #ifdef __cplusplus
32
+ extern "C" {
33
+ #endif
34
+
35
+ void dcCall_sparc64 (DCpointer target, DCsize size, DCpointer data);
36
+
37
+ #ifdef __cplusplus
38
+ }
39
+ #endif
40
+
41
+ #endif /* DYNCALL_CALL_SPARC64_H */
42
+
@@ -0,0 +1,220 @@
1
+ #define BIAS 2047
2
+ .global dcCall_v9
3
+ /* dcCall_sparc64( DCCallVM* , void * target ) */
4
+ /* o0 o1 */
5
+ dcCall_v9:
6
+ or %o0, %g0, %o3 /* o3: callvm */
7
+ or %o1, %g0, %o0 /* o0: target */
8
+ ldx [%o3+24], %o1 /* o1: mVecSize */
9
+ add %o3, 32, %o2 /* o2: stack */
10
+ /* Compute a matching stack size (approximate): o3 = align(o1+136,16) */
11
+
12
+ add %o1, (16+1+6)*8+15, %o3
13
+ and %o3, -16, %o3
14
+ neg %o3 /* o3: -stacksize */
15
+ save %sp, %o3, %sp
16
+
17
+ ldd [%i2+8*0 ],%f0 /* Load double-precision float registers. */
18
+ ldd [%i2+8*1 ],%f2
19
+ ldd [%i2+8*2 ],%f4
20
+ ldd [%i2+8*3 ],%f6
21
+ ldd [%i2+8*4 ],%f8
22
+ ldd [%i2+8*5 ],%f10
23
+ ldd [%i2+8*6 ],%f12
24
+ ldd [%i2+8*7 ],%f14
25
+ ldd [%i2+8*8 ],%f16
26
+ ldd [%i2+8*9 ],%f18
27
+ ldd [%i2+8*10],%f20
28
+ ldd [%i2+8*11],%f22
29
+ ldd [%i2+8*12],%f24
30
+ ldd [%i2+8*13],%f26
31
+ ldd [%i2+8*14],%f28
32
+ ldd [%i2+8*15],%f30
33
+ ldx [%i2+8*0],%o0 /* Load output registers. */
34
+ ldx [%i2+8*1],%o1
35
+ ldx [%i2+8*2],%o2
36
+ ldx [%i2+8*3],%o3
37
+ ldx [%i2+8*4],%o4
38
+ ldx [%i2+8*5],%o5
39
+ sub %i1, 48, %i1
40
+ cmp %i1, 0
41
+ ble .do_call
42
+ nop
43
+ /* Copy loop: */
44
+ add %i2, 48, %i2 /* skip homing area */
45
+ or %g0, %g0, %l0 /* l0 = offset initialized to 0. */
46
+ add %sp, BIAS+((16+6)*8), %l2 /* l2 = argument area on stack space (7th word). (64+4+6*4 = byte offset 92). */
47
+ .next:
48
+ ldx [%i2+%l0],%l1 /* Read from arg buffer(%i2) to %l1. */
49
+ stx %l1, [%l2+%l0] /* Write %l1 to stack space(%l2). */
50
+ add %l0, 8, %l0 /* Increment offset. */
51
+ sub %i1, 8, %i1 /* Decrement copy size. */
52
+ cmp %i1, 0
53
+ bgt .next
54
+ nop
55
+ .do_call:
56
+ call %i0 /* Call target. */
57
+ nop
58
+ or %o0, %g0, %i0
59
+ jmpl %i7 + 8, %g0
60
+ restore
61
+
62
+ /*
63
+ or %o0, %g0, %i0
64
+ or %o1, %g0, %i1
65
+ or %o2, %g0, %i2
66
+ or %o3, %g0, %i3
67
+ return %i7 + 8
68
+ nop
69
+
70
+ Changes from v8:
71
+ - fundamental data types
72
+ - (un)signed int: 8,16,32,64
73
+ - float: 32,64,128
74
+ - float: IEEE 754 compilant
75
+ 32 32-bit float registers f0,f1,..,f31
76
+ 32 64-bit float registers f0,f2,..,f62
77
+ 16 128-bit float registers f0,f4,..,f60
78
+
79
+ Description:
80
+ We need to raise up a dynamic stack frame.
81
+ Therefore we need to compute the stack size. We do this first,
82
+ in the context of the caller as a leaf function (using o3 as scratch for addition).
83
+ Then we raise the frame, ending up in o0-o3 is then i0-i3.
84
+
85
+
86
+ Stack Layout:
87
+ BIAS = 2047
88
+
89
+ BIAS+XX: should be 16 byte aligned.
90
+ ...
91
+ 136: argument overflow area
92
+ 128: 1 extended word for struct/union poiner return value
93
+ BIAS+ 0: 16 extended words for registers (in/local) save area [register window]
94
+
95
+
96
+ Function Argument Passing:
97
+ - integer %o0..%o5 (caller view).
98
+ - floating-point %f0 .. %f15
99
+ - continuous memory starting at %sp+BIAS+136 (caller view).
100
+
101
+ Register Usage:
102
+ %fp0..%fp31 : floating-point arguments.
103
+ %sp or %o6 : stack pointer, always 8 (or 16?)-byte aligned.
104
+ %fp or %i6 : frame pointer.
105
+ %i0 and %o0 : integer and pointer return values.
106
+ %i7 and %o7 : return address. (caller puts return address to %o7, callee uses %i7)
107
+ %fp0 and %fp1: return value (float).
108
+ %i0..%i5 : input argument registers
109
+ %o0..%o5 : output argument registers
110
+ %g0 : always zero, writes to it have no effect.
111
+
112
+ Register Mappings:
113
+ r0-7 -> globals
114
+ r8-15 -> outs
115
+ r16-r23 -> locals
116
+ r24-r31 -> ins
117
+
118
+ Integer Register Overview Table:
119
+ ID Class Name Description
120
+ ------------------------------------------------------------------------------
121
+ 0 globals g0 always zero, writes to it have no effect
122
+ 1 g1
123
+ 2 g2
124
+ 3 g3
125
+ 4 g4
126
+ 5 g5
127
+ 6 g6
128
+ 7 g7
129
+ 8 out o0 [int/ptr] arg 0 and return
130
+ 9 o1 arg 1
131
+ 10 o2 arg 2
132
+ 11 o3 arg 3
133
+ 12 o4 arg 4
134
+ 13 o5 arg 5
135
+ 14 o6 stack pointer
136
+ 15 o7
137
+ 16 local l0 scratch
138
+ 17 l1
139
+ 18 l2
140
+ 19 l3
141
+ 20 l4
142
+ 21 l5
143
+ 22 l6
144
+ 23 l7
145
+ 24 in i0 [int/pt] arg 0 and return
146
+ 25 i1
147
+ 26 i2
148
+ 27 i3
149
+ 28 i4
150
+ 29 i5
151
+ 30 i6 frame pointer
152
+ 31 i7
153
+ */
154
+
155
+ /* ---------------------------------------------------------------------------
156
+
157
+ call kernel for sparc64 v9 abi
158
+ tested on sparc64/linux/debian [gcc54.fsffrance.org - thanx to the farm!]
159
+
160
+ new C Interface:
161
+ void dcCall_sparc (DCCallVM* callvm, DCpointer target);
162
+ %i0 %1
163
+
164
+ see dyncall_call_sparc.S for details.
165
+
166
+ old C Interface:
167
+ void dcCall_sparc (DCpointer target, DCsize size, DCpointer data);
168
+ %i0 , %i1 , %i2
169
+ Input:
170
+ i0 target
171
+ i1 size
172
+ i2 data
173
+
174
+ */
175
+ /*
176
+
177
+ Package: dyncall
178
+ Library: dyncall
179
+ File: dyncall/dyncall_call_sparc64.S
180
+ Description: Call kernel for sparc64 v9 ABI.
181
+ License:
182
+
183
+ Copyright (c) 2011-2013 Daniel Adler <dadler@uni-goettingen.de>
184
+
185
+ Permission to use, copy, modify, and distribute this software for any
186
+ purpose with or without fee is hereby granted, provided that the above
187
+ copyright notice and this permission notice appear in all copies.
188
+
189
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
190
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
191
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
192
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
193
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
194
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
195
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
196
+
197
+ */
198
+
199
+ #if 0
200
+
201
+
202
+ #define REGSIZE 8
203
+
204
+
205
+
206
+ #define SHEAD ((16+6)*8)
207
+ #define ALIGN 16
208
+ #define IREGS 6
209
+ #define FREGS 16
210
+ #define SREGS 16
211
+ #define IBASE 0
212
+ #define FBASE (IREGS*8)
213
+
214
+ // #define DHEAD ((IREGS+FREGS)*8)+SREGS*4
215
+
216
+ CALLVM_regdata = 72
217
+ CALLVM_size = 208
218
+ CALLVM_buffer = 216
219
+
220
+ #endif
@@ -0,0 +1,42 @@
1
+ /*
2
+
3
+ Package: dyncall
4
+ Library: dyncall
5
+ File: dyncall/dyncall_call_sparc_v9.h
6
+ Description:
7
+ License:
8
+
9
+ Copyright (c) 2011-2013 Daniel Adler <dadler@uni-goettingen.de>
10
+
11
+ Permission to use, copy, modify, and distribute this software for any
12
+ purpose with or without fee is hereby granted, provided that the above
13
+ copyright notice and this permission notice appear in all copies.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
16
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
17
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
18
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
19
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
20
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
21
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
22
+
23
+ */
24
+
25
+
26
+ #ifndef DYNCALL_CALL_SPARC_V9_H
27
+ #define DYNCALL_CALL_SPARC_V9_H
28
+
29
+ #include "dyncall_types.h"
30
+
31
+ #ifdef __cplusplus
32
+ extern "C" {
33
+ #endif
34
+
35
+ void dcCall_v9 (DCCallVM* vm, DCpointer target);
36
+
37
+ #ifdef __cplusplus
38
+ }
39
+ #endif
40
+
41
+ #endif /* DYNCALL_CALL_SPARC_v9_H */
42
+
@@ -0,0 +1,146 @@
1
+ /*
2
+
3
+ Package: dyncall
4
+ Library: dyncall
5
+ File: dyncall/dyncall_call_x64-att.S
6
+ Description: All x64 abi call kernel implementation
7
+ License:
8
+
9
+ Copyright (c) 2007-2011 Daniel Adler <dadler@uni-goettingen.de>,
10
+ Tassilo Philipp <tphilipp@potion-studios.com>
11
+
12
+ Permission to use, copy, modify, and distribute this software for any
13
+ purpose with or without fee is hereby granted, provided that the above
14
+ copyright notice and this permission notice appear in all copies.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
17
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
18
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
19
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
20
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
21
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
22
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
23
+
24
+ */
25
+
26
+
27
+ #include "../portasm/portasm-x64-att.S"
28
+
29
+ BEGIN_ASM
30
+
31
+ /*---------------------------------------------------------------------------
32
+
33
+ Call Kernel for x64 System V
34
+
35
+ Input:
36
+ RDI : size of arguments to be passed via stack
37
+ RSI : pointer to arguments to be passed via the stack
38
+ RDX : pointer to arguments of integral/pointer type to be passed via registers
39
+ RCX : pointer to arguments of floating point type to be passed via registers
40
+ R8 : target function pointer
41
+ Notes:
42
+ RSP+8: is always 16-byte aligned (32-byte align if __m256 is used)
43
+ */
44
+
45
+ GLOBAL(dcCall_x64_sysv)
46
+ BEGIN_PROC(dcCall_x64_sysv)
47
+ PUSH(RBP) /* Pseudo-prolog - preserve RBP. */
48
+ PUSH(RBX) /* Preserve RBX and store pointer to function in it. */
49
+ MOV(RSP,RBP) /* Store stack pointer in RBP. */
50
+ MOV(R8 ,RBX)
51
+ MOVSD(QWORD(RCX,0) ,XMM0) /* Copy first 8 floats to XMM0-XMM7. */
52
+ MOVSD(QWORD(RCX,8) ,XMM1)
53
+ MOVSD(QWORD(RCX,16),XMM2)
54
+ MOVSD(QWORD(RCX,24),XMM3)
55
+ MOVSD(QWORD(RCX,32),XMM4)
56
+ MOVSD(QWORD(RCX,40),XMM5)
57
+ MOVSD(QWORD(RCX,48),XMM6)
58
+ MOVSD(QWORD(RCX,56),XMM7)
59
+
60
+ ADD(LIT(31),RDI) /* Align stack to 32-byte. */
61
+ AND(LIT(-32),RDI)
62
+ ADD(LIT(8),RDI) /* Adjust by 8-byte for the return-address. */
63
+ SUB(RDI,RSP) /* Setup stack frame by subtracting the size of arguments. */
64
+
65
+ MOV(RDI,RCX) /* Store number of bytes to copy to stack in RCX (for rep movsb). */
66
+ MOV(RSP,RDI) /* Store pointer to beginning of stack arguments in RDI (for rep movsb). */
67
+
68
+ REP(MOVSB) /* copy bytes (@@@ should be optimized). */
69
+
70
+ MOV(QWORD(RDX,0),RDI) /* copy first six int/pointer arguments to RDI, RSI, RDX, RCX, R8, R9. */
71
+ MOV(QWORD(RDX,8),RSI)
72
+ MOV(QWORD(RDX,24),RCX)
73
+ MOV(QWORD(RDX,32),R8)
74
+ MOV(QWORD(RDX,40),R9)
75
+ MOV(QWORD(RDX,16),RDX) /* Set RDX last to not overwrite it to soon. */
76
+
77
+ MOVB(LIT(8),AL) /* Put upper bound of number of used xmm registers in AL. */
78
+ CALL_REG(RBX) /* Call function. */
79
+
80
+ MOV(RBP,RSP) /* Restore stack pointer. */
81
+ POP(RBX) /* Restore RBX. */
82
+ POP(RBP) /* Pseudo-epilog. */
83
+ RET()
84
+ END_PROC(dcCALl_x64_sysv)
85
+
86
+ /*---------------------------------------------------------------------------
87
+
88
+ Call Kernel for x64 Win64
89
+
90
+ Input:
91
+ RCX : size of arguments to be passed via stack
92
+ RDX : pointer to arguments to be passed via the stack
93
+ R8 : pointer to arguments of integral/pointer type to be passed via registers
94
+ R9 : target function pointer
95
+
96
+ */
97
+
98
+ GLOBAL(dcCall_x64_win64)
99
+ BEGIN_PROC(dcCall_x64_win64)
100
+
101
+ PUSH(RBP) /* Pseudo-prolog - preserve RBP. */
102
+ PUSH(RSI) /* Preserve RSI and RDI. */
103
+ PUSH(RDI)
104
+
105
+ MOV(RSP,RBP) /* Store stack pointer in RBP. */
106
+
107
+ ADD(LIT(15),RCX) /* Align stack size to 16 bytes. */
108
+ AND(LIT(-16),RCX)
109
+ SUB(RCX,RSP) /* Setup stack frame by subtracting the size of the arguments. */
110
+
111
+
112
+ MOV(RDX, RSI) /* Let RSI point to the arguments. */
113
+ MOV(RSP, RDI) /* Store pointer to beginning of stack arguments in RDI (for rep movsb). */
114
+ MOV(R9, RAX) /* Put function address in RAX. */
115
+
116
+ REP(MOVSB) /* @@@ should be optimized (e.g. movq) */
117
+
118
+ MOV(QWORD(R8,0),RCX) /* Copy first four arguments to RCX, RDX, R9, R8 ( and XMM0-XMM3. ) */
119
+ MOV(QWORD(R8,8),RDX)
120
+ MOV(QWORD(R8,24),R9)
121
+ MOV(QWORD(R8,16),R8)
122
+
123
+ MOVD(RCX, XMM0)
124
+ MOVD(RDX, XMM1)
125
+ MOVD(R8, XMM2)
126
+ MOVD(R9, XMM3)
127
+
128
+ PUSH(R9) /* Push first four arguments onto the stack preserve area. */
129
+ PUSH(R8)
130
+ PUSH(RDX)
131
+ PUSH(RCX)
132
+
133
+ CALL_REG(RAX) /* Invoke function. */
134
+
135
+ MOV(RBP, RSP) /* Restore stack pointer (such that we can pop the preserved vALues). */
136
+
137
+ POP(RDI) /* Restore RSI and RDI. */
138
+ POP(RSI)
139
+ POP(RBP) /* Pseudo-epilog. */
140
+
141
+ RET()
142
+
143
+ END_PROC(dcCall_x64_win64)
144
+
145
+ END_ASM
146
+