rbdc 0.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (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,149 @@
1
+ /*
2
+
3
+ Package: dyncall
4
+ Library: dyncall
5
+ File: dyncall/dyncall_call_x64.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.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
+
42
+ */
43
+
44
+ GLOBAL(dcCall_x64_sysv)
45
+ BEGIN_PROC(dcCall_x64_sysv)
46
+
47
+ push RBP /* Pseudo-prolog - preserve RBP. */
48
+ push RBX /* Preserve RBX and store pointer to function in it. */
49
+
50
+ mov RBP, RSP /* Store stack pointer in RBP. */
51
+
52
+ mov RBX, R8
53
+
54
+ movsd XMM0, qword ptr[RCX ] /* Copy first 8 floats to XMM0-XMM7 (this makes RCX free to use). */
55
+ movsd XMM1, qword ptr[RCX+ 8]
56
+ movsd XMM2, qword ptr[RCX+16]
57
+ movsd XMM3, qword ptr[RCX+24]
58
+ movsd XMM4, qword ptr[RCX+32]
59
+ movsd XMM5, qword ptr[RCX+40]
60
+ movsd XMM6, qword ptr[RCX+48]
61
+ movsd XMM7, qword ptr[RCX+56]
62
+
63
+ sub RSP, RDI /* Setup stack frame by subtracting the size of the arguments. */
64
+
65
+ and RSP, -32 /* Align stack to 32-byte border. */
66
+
67
+ mov RCX, RDI /* Store number of bytes to copy to stack in RCX (for rep movsb). */
68
+ mov RDI, RSP /* Store pointer to beginning of stack arguments in RDI (for rep movsb). */
69
+
70
+ rep movsb /* @@@ should be optimized (e.g. movq) */
71
+
72
+ mov RDI, qword ptr[RDX ] /* Copy first six int/pointer arguments to RDI, RSI, RDX, RCX, R8, R9. */
73
+ mov RSI, qword ptr[RDX+ 8]
74
+ mov RCX, qword ptr[RDX+24]
75
+ mov R8, qword ptr[RDX+32]
76
+ mov R9, qword ptr[RDX+40]
77
+ mov RDX, qword ptr[RDX+16] /* Set RDX last to not overwrite it to soon. */
78
+
79
+ mov AL, 8 /* Put upper bound of number of used xmm registers in AL. */
80
+ call RBX /* Invoke function. */
81
+
82
+ mov RSP, RBP /* Restore stack pointer (such that we can pop the preserved vALues). */
83
+
84
+ pop RBX /* Restore RBX. */
85
+ pop RBP /* Pseudo-epilog. */
86
+
87
+ ret
88
+ END_PROC(dcCall_x64_sysv)
89
+
90
+ /*---------------------------------------------------------------------------
91
+
92
+ Call Kernel for x64 Win64
93
+
94
+ Input:
95
+ RCX : size of arguments to be passed via stack
96
+ RDX : pointer to arguments to be passed via the stack
97
+ R8 : pointer to arguments of integral/pointer type to be passed via registers
98
+ R9 : target function pointer
99
+
100
+ */
101
+
102
+ GLOBAL(dcCall_x64_win64)
103
+ BEGIN_PROC(dcCall_x64_win64)
104
+
105
+ push RBP /* Pseudo-prolog - preserve RBP. */
106
+ push RSI /* Preserve RSI and RDI. */
107
+ push RDI
108
+
109
+ /* and RSP, -16 /* Align frame to 16 bytes. */
110
+ mov RBP, RSP /* Store stack pointer in RBP. */
111
+
112
+ add RCX, 15 /* Align stack size to 16 bytes. */
113
+ and RCX, -16
114
+ sub RSP, RCX /* Setup stack frame by subtracting the size of the arguments. */
115
+
116
+ mov RSI, RDX /* Let RSI point to the arguments. */
117
+ mov RDI, RSP /* Store pointer to beginning of stack arguments in RDI (for rep movsb). */
118
+ mov RAX, R9 /* Put function address in RAX. */
119
+
120
+ rep movsb /* @@@ should be optimized (e.g. movq) */
121
+
122
+ mov RCX, qword ptr[R8 ] /* Copy first four arguments to RCX, RDX, R8, R9 and XMM0-XMM3. */
123
+ mov RDX, qword ptr[R8+ 8]
124
+ mov R9, qword ptr[R8+24] /* Set R9 first to not overwrite R8 too soon. */
125
+ mov R8, qword ptr[R8+16]
126
+ movd XMM0, RCX
127
+ movd XMM1, RDX
128
+ movd XMM2, R8
129
+ movd XMM3, R9
130
+
131
+ push R9 /* Push first four arguments onto the stack preserve area. */
132
+ push R8
133
+ push RDX
134
+ push RCX
135
+
136
+ call RAX /* Invoke function. */
137
+
138
+ mov RSP, RBP /* Restore stack pointer (such that we can pop the preserved vALues). */
139
+
140
+ pop RDI /* Restore RSI and RDI. */
141
+ pop RSI
142
+ pop RBP /* Pseudo-epilog. */
143
+
144
+ ret
145
+
146
+ END_PROC(dcCall_x64_win64)
147
+
148
+ END_ASM
149
+
@@ -0,0 +1,63 @@
1
+ /*
2
+
3
+ Package: dyncall
4
+ Library: dyncall
5
+ File: dyncall/dyncall_call_x64.h
6
+ Description:
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
+ /*
28
+
29
+ dyncall x64
30
+
31
+ REVISION
32
+ 2007/12/11 initial
33
+
34
+ */
35
+
36
+
37
+ #ifndef DYNCALL_CALL_X64_H
38
+ #define DYNCALL_CALL_X64_H
39
+
40
+
41
+ #include "dyncall.h"
42
+
43
+ #ifdef __cplusplus
44
+ extern "C" {
45
+ #endif
46
+
47
+ /*
48
+ ** x64 SystemV calling convention
49
+ **
50
+ ** - hybrid return-type call (bool ... pointer)
51
+ **
52
+ */
53
+
54
+ void dcCall_x64_sysv(DCsize stacksize, DCpointer stackdata, DCpointer regdata_i, DCpointer regdata_f, DCpointer target);
55
+ void dcCall_x64_win64(DCsize stacksize, DCpointer stackdata, DCpointer regdata, DCpointer target);
56
+
57
+ #ifdef __cplusplus
58
+ }
59
+ #endif
60
+
61
+
62
+ #endif /* DYNCALL_CALL_X64_H */
63
+
@@ -0,0 +1,70 @@
1
+ ; auto-generated by gen-masm.sh
2
+ .CODE
3
+
4
+ dcCall_x64_sysv PROC
5
+ OPTION PROLOGUE:NONE, EPILOGUE:NONE
6
+ push RBP
7
+ push RBX
8
+ mov RBP,RSP
9
+ mov RBX,R8
10
+ movsd XMM0,qword ptr [RCX+0]
11
+ movsd XMM1,qword ptr [RCX+8]
12
+ movsd XMM2,qword ptr [RCX+16]
13
+ movsd XMM3,qword ptr [RCX+24]
14
+ movsd XMM4,qword ptr [RCX+32]
15
+ movsd XMM5,qword ptr [RCX+40]
16
+ movsd XMM6,qword ptr [RCX+48]
17
+ movsd XMM7,qword ptr [RCX+56]
18
+ add RDI,31
19
+ and RDI,-32
20
+ add RDI,8
21
+ sub RSP,RDI
22
+ mov RCX,RDI
23
+ mov RDI,RSP
24
+ rep movsb
25
+ mov RDI,qword ptr [RDX+0]
26
+ mov RSI,qword ptr [RDX+8]
27
+ mov RCX,qword ptr [RDX+24]
28
+ mov R8,qword ptr [RDX+32]
29
+ mov R9,qword ptr [RDX+40]
30
+ mov RDX,qword ptr [RDX+16]
31
+ mov AL,8
32
+ call RBX
33
+ mov RSP,RBP
34
+ pop RBX
35
+ pop RBP
36
+ ret
37
+ dcCALl_x64_sysv ENDP
38
+ dcCall_x64_win64 PROC
39
+ OPTION PROLOGUE:NONE, EPILOGUE:NONE
40
+ push RBP
41
+ push RSI
42
+ push RDI
43
+ mov RBP,RSP
44
+ add RCX,15
45
+ and RCX,-16
46
+ sub RSP,RCX
47
+ mov RSI,RDX
48
+ mov RDI,RSP
49
+ mov RAX,R9
50
+ rep movsb
51
+ mov RCX,qword ptr [R8+0]
52
+ mov RDX,qword ptr [R8+8]
53
+ mov R9,qword ptr [R8+24]
54
+ mov R8,qword ptr [R8+16]
55
+ movd XMM0,RCX
56
+ movd XMM1,RDX
57
+ movd XMM2,R8
58
+ movd XMM3,R9
59
+ push R9
60
+ push R8
61
+ push RDX
62
+ push RCX
63
+ call RAX
64
+ mov RSP,RBP
65
+ pop RDI
66
+ pop RSI
67
+ pop RBP
68
+ ret
69
+ dcCall_x64_win64 ENDP
70
+ END
@@ -0,0 +1,238 @@
1
+ /*
2
+
3
+ Package: dyncall
4
+ Library: dyncall
5
+ File: dyncall/dyncall_call_x86.S
6
+ Description: All - except Plan9 - x86 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-x86.S"
28
+ BEGIN_ASM
29
+ /* ============================================================================
30
+ DynCall Call Kernels for X86 Architecture
31
+ ----------------------------------------------------------------------------
32
+ C Interface:
33
+ dcCall_x86_XXX(void* target, void* args, size_t size);
34
+ ddCall_x86_sys_XXX(int_ptr target, void* args, size_t size);
35
+
36
+ Where XXX is one of calling-conventions,
37
+ cdecl, win32_msthis, win32_std, win32_fastcall.
38
+
39
+ Parameter Stack layout:
40
+ size := EBP + 16
41
+ args := EBP + 12
42
+ target := EBP + 8
43
+
44
+ NOTES:
45
+ - epilog restore ESP serves callee cleanup
46
+ - 16 byte alignment (to be compatible with darwin).
47
+ */
48
+
49
+
50
+ /*--- default / cdecl --------------------------------------------------------
51
+
52
+ Details:
53
+ - caller clean-up
54
+
55
+ */
56
+
57
+ GLOBAL(dcCall_x86_cdecl)
58
+ BEGIN_PROC(dcCall_x86_cdecl)
59
+ PUSH(EBP) /* prolog. */
60
+ MOVL(ESP,EBP)
61
+ PUSH(ESI) /* save preserved registers. */
62
+ PUSH(EDI)
63
+ MOVL(DWORD(EBP,12),ESI) /* ESI = arg buffer ptr */
64
+ MOVL(DWORD(EBP,16),ECX) /* ECX = arg buffer size */
65
+ ADDL(LIT(15),ECX) /* ECX = align(ECX,16) */
66
+ ANDL(LIT(-16),ECX)
67
+ MOVL(ECX,DWORD(EBP,16)) /* save ECX. */
68
+ SUBL(ECX,ESP) /* allocate stack size */
69
+ MOVL(ESP,EDI) /* EDI = stack ptr */
70
+
71
+ /*
72
+ work around for rep movsd (not supported by SunPro)
73
+
74
+ SHRL(LIT(2),ECX)
75
+ REP(MOVSD)
76
+
77
+ */
78
+
79
+ REP(MOVSB)
80
+ CALL_DWORD(EBP,8)
81
+ ADDL(DWORD(EBP,16),ESP)
82
+ POP(EDI)
83
+ POP(ESI)
84
+ MOVL(EBP,ESP)
85
+ POP(EBP)
86
+ RET()
87
+ END_PROC(dcCall_x86_cdecl)
88
+ /* ---- C++ this calls (microsoft) ------------------------------------------
89
+
90
+ Details:
91
+ - this pointer is in ECX
92
+
93
+ */
94
+
95
+ GLOBAL(dcCall_x86_win32_msthis)
96
+ BEGIN_PROC(dcCall_x86_win32_msthis)
97
+ PUSH(EBP) /* prolog. */
98
+ MOVL(ESP,EBP)
99
+ PUSH(ESI) /* save preserved. */
100
+ PUSH(EDI)
101
+ MOVL(DWORD(EBP,12),ESI) /* ESI = pointer on args. */
102
+ MOVL(DWORD(EBP,16),ECX) /* ECX = size. */
103
+ MOVL(DWORD(ESI,0),EAX) /* EAX = this pointer. */
104
+ ADDL(LIT(4),ESI) /* increment args pointer by thisptr. */
105
+ SUBL(LIT(4),ECX) /* decrement size by sizeof(thisptr). */
106
+ SUBL(ECX,ESP) /* allocate argument-block on stack. */
107
+ MOVL(ESP,EDI) /* EDI = stack args. */
108
+ REP(MOVSB) /* copy arguments. */
109
+ MOVL(EAX,ECX) /* ECX = this pointer. */
110
+ CALL_DWORD(EBP,8) /* call function. */
111
+ POP(EDI) /* restore preserved. */
112
+ POP(ESI)
113
+ MOVL(EBP,ESP) /* epilog. */
114
+ POP(EBP)
115
+ RET()
116
+ END_PROC(dcCall_x86_win32_msthis)
117
+
118
+ /*---- win32 stdcall ---------------------------------------------------------
119
+
120
+ Details:
121
+ - callee cleans up stack
122
+
123
+ */
124
+
125
+ GLOBAL(dcCall_x86_win32_std)
126
+ BEGIN_PROC(dcCall_x86_win32_std)
127
+ PUSH(EBP) /* prolog. */
128
+ MOVL(ESP,EBP)
129
+ PUSH(ESI) /* save ESI, EDI. */
130
+ PUSH(EDI)
131
+ MOVL(DWORD(EBP,12),ESI) /* ESI = args. */
132
+ MOVL(DWORD(EBP,16),ECX) /* ECX = size. */
133
+ SUBL(ECX,ESP) /* allocate size bytes on stack. */
134
+ MOVL(ESP,EDI) /* EDI = copy destination stack. */
135
+ REP(MOVSB) /* copy BYTEs. */
136
+ CALL_DWORD(EBP,8) /* call target. */
137
+ POP(EDI) /* restore EDI, ESI. */
138
+ POP(ESI)
139
+ MOVL(EBP,ESP) /* epilog. */
140
+ POP(EBP)
141
+ RET()
142
+ END_PROC(dcCall_x86_win32_std)
143
+
144
+ /*---- win32 fastcall (GNU/Microsoft) ----------------------------------------
145
+
146
+ Details:
147
+ - callee cleans up stack
148
+ - first two integer (up to 32bits) are passed in ECX and EDX
149
+
150
+ */
151
+
152
+ GLOBAL(dcCall_x86_win32_fast)
153
+ BEGIN_PROC(dcCall_x86_win32_fast)
154
+ PUSH(EBP) /* prolog. */
155
+ MOVL(ESP,EBP)
156
+ PUSH(ESI) /* save preserved. */
157
+ PUSH(EDI)
158
+ MOVL(DWORD(EBP,12),ESI) /* ESI = copy source args. */
159
+ MOVL(DWORD(EBP,16),ECX) /* ECX = size. */
160
+ MOVL(DWORD(ESI,0),EAX) /* EAX = first argument. */
161
+ MOVL(DWORD(ESI,4),EDX) /* EDX = second argument. */
162
+ ADDL(LIT(8),ESI) /* skip registers. */
163
+ SUBL(LIT(8),ECX)
164
+ MOVL(ECX,DWORD(EBP,16)) /* save stack alloc size. */
165
+ SUBL(ECX,ESP) /* allocate stack. */
166
+ MOVL(ESP,EDI) /* EDI = stack args. */
167
+ REP(MOVSB) /* copy BYTEs. */
168
+ MOVL(EAX,ECX) /* ECX = first argument. */
169
+ CALL_DWORD(EBP,8) /* call target. */
170
+ POP(EDI) /* restore preserved. */
171
+ POP(ESI)
172
+ MOVL(EBP,ESP) /* epilog. */
173
+ POP(EBP)
174
+ RET()
175
+ END_PROC(dcCall_x86_win32_fast)
176
+
177
+ /*--- syscall int80 linux ---------------------------------------------------
178
+
179
+ Details:
180
+ - all arguments are passed via registers
181
+
182
+ */
183
+
184
+ GLOBAL(dcCall_x86_sys_int80h_linux)
185
+ BEGIN_PROC(dcCall_x86_sys_int80h_linux)
186
+ PUSH(EBP) /* prolog. */
187
+ MOVL(ESP,EBP)
188
+ PUSH(EBX) /* save preserved. */
189
+ PUSH(ESI)
190
+ PUSH(EDI)
191
+ MOVL(DWORD(EBP,12),EAX) /* EAX = argument buffer. */
192
+ MOVL(DWORD(EAX,0),EBX) /* move first five arguments. */
193
+ MOVL(DWORD(EAX,4),ECX)
194
+ MOVL(DWORD(EAX,8),EDX)
195
+ MOVL(DWORD(EAX,12),ESI)
196
+ MOVL(DWORD(EAX,16),EDI)
197
+ MOVL(DWORD(EBP,8),EAX) /* EAX = syscall id. */
198
+ INT(LIT(HEX(80)))
199
+ POP(EDI) /* restore preserved. */
200
+ POP(ESI)
201
+ POP(EBX)
202
+ MOVL(EBP,ESP) /* epilog. */
203
+ POP(EBP)
204
+ RET()
205
+ END_PROC(dcCall_x86_sys_int80h_linux)
206
+
207
+ /*--- syscall int80 bsd -----------------------------------------------------
208
+
209
+ Details:
210
+ - all arguments are passed via stack
211
+
212
+ */
213
+
214
+ GLOBAL(dcCall_x86_sys_int80h_bsd)
215
+ BEGIN_PROC(dcCall_x86_sys_int80h_bsd)
216
+ PUSH(EBP) /* prolog. */
217
+ MOVL(ESP,EBP)
218
+ PUSH(ESI) /* save preserved. */
219
+ PUSH(EDI)
220
+ MOVL(DWORD(EBP,12),ESI) /* ESI = pointer on args. */
221
+ MOVL(DWORD(EBP,16),ECX) /* ECX = size. */
222
+ SUBL(ECX,ESP) /* allocate stack space. */
223
+ MOVL(ESP,EDI) /* EDI = stack args. */
224
+ REP(MOVSB)
225
+ MOVL(DWORD(EBP,8),EAX) /* load system call id. */
226
+ CALL(_do_int)
227
+ POP(EDI) /* restore preserved. */
228
+ POP(ESI)
229
+ MOVL(EBP,ESP) /* epilog. */
230
+ POP(EBP)
231
+ RET()
232
+ _do_int:
233
+ INT(LIT(HEX(80)))
234
+ RET()
235
+ END_PROC(dcCall_x86_sys_int80h_bsd)
236
+
237
+ END_ASM
238
+