mach-support-amd64.c 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. /**
  2. * \file
  3. * mach support for x86
  4. *
  5. * Authors:
  6. * Geoff Norton (gnorton@novell.com)
  7. * Rodrigo Kumpera (kumpera@gmail.com)
  8. *
  9. * (C) 2010 Novell, Inc.
  10. * (C) 2013 Xamarin, Inc.
  11. */
  12. #include <config.h>
  13. #if defined(__MACH__)
  14. #include <stdint.h>
  15. #include <glib.h>
  16. #include <pthread.h>
  17. #include "utils/mono-sigcontext.h"
  18. #include "mach-support.h"
  19. //For reg numbers
  20. #include <mono/arch/amd64/amd64-codegen.h>
  21. int
  22. mono_mach_arch_get_mcontext_size ()
  23. {
  24. return sizeof (struct __darwin_mcontext64);
  25. }
  26. void
  27. mono_mach_arch_thread_states_to_mcontext (thread_state_t state, thread_state_t fpstate, void *context)
  28. {
  29. x86_thread_state64_t *arch_state = (x86_thread_state64_t *) state;
  30. x86_float_state64_t *arch_fpstate = (x86_float_state64_t *) fpstate;
  31. struct __darwin_mcontext64 *ctx = (struct __darwin_mcontext64 *) context;
  32. ctx->__ss = *arch_state;
  33. ctx->__fs = *arch_fpstate;
  34. }
  35. void
  36. mono_mach_arch_mcontext_to_thread_states (void *context, thread_state_t state, thread_state_t fpstate)
  37. {
  38. x86_thread_state64_t *arch_state = (x86_thread_state64_t *) state;
  39. x86_float_state64_t *arch_fpstate = (x86_float_state64_t *) fpstate;
  40. struct __darwin_mcontext64 *ctx = (struct __darwin_mcontext64 *) context;
  41. *arch_state = ctx->__ss;
  42. *arch_fpstate = ctx->__fs;
  43. }
  44. void
  45. mono_mach_arch_thread_states_to_mono_context (thread_state_t state, thread_state_t fpstate, MonoContext *context)
  46. {
  47. x86_thread_state64_t *arch_state = (x86_thread_state64_t *) state;
  48. x86_float_state64_t *arch_fpstate = (x86_float_state64_t *) fpstate;
  49. context->gregs [AMD64_RAX] = arch_state->__rax;
  50. context->gregs [AMD64_RBX] = arch_state->__rbx;
  51. context->gregs [AMD64_RCX] = arch_state->__rcx;
  52. context->gregs [AMD64_RDX] = arch_state->__rdx;
  53. context->gregs [AMD64_RDI] = arch_state->__rdi;
  54. context->gregs [AMD64_RSI] = arch_state->__rsi;
  55. context->gregs [AMD64_RBP] = arch_state->__rbp;
  56. context->gregs [AMD64_RSP] = arch_state->__rsp;
  57. context->gregs [AMD64_R8] = arch_state->__r8;
  58. context->gregs [AMD64_R9] = arch_state->__r9;
  59. context->gregs [AMD64_R10] = arch_state->__r10;
  60. context->gregs [AMD64_R11] = arch_state->__r11;
  61. context->gregs [AMD64_R12] = arch_state->__r12;
  62. context->gregs [AMD64_R13] = arch_state->__r13;
  63. context->gregs [AMD64_R14] = arch_state->__r14;
  64. context->gregs [AMD64_R15] = arch_state->__r15;
  65. context->gregs [AMD64_RIP] = arch_state->__rip;
  66. context->fregs [AMD64_XMM0] = arch_fpstate->__fpu_xmm0;
  67. context->fregs [AMD64_XMM1] = arch_fpstate->__fpu_xmm1;
  68. context->fregs [AMD64_XMM2] = arch_fpstate->__fpu_xmm2;
  69. context->fregs [AMD64_XMM3] = arch_fpstate->__fpu_xmm3;
  70. context->fregs [AMD64_XMM4] = arch_fpstate->__fpu_xmm4;
  71. context->fregs [AMD64_XMM5] = arch_fpstate->__fpu_xmm5;
  72. context->fregs [AMD64_XMM6] = arch_fpstate->__fpu_xmm6;
  73. context->fregs [AMD64_XMM7] = arch_fpstate->__fpu_xmm7;
  74. context->fregs [AMD64_XMM8] = arch_fpstate->__fpu_xmm8;
  75. context->fregs [AMD64_XMM9] = arch_fpstate->__fpu_xmm9;
  76. context->fregs [AMD64_XMM10] = arch_fpstate->__fpu_xmm10;
  77. context->fregs [AMD64_XMM11] = arch_fpstate->__fpu_xmm11;
  78. context->fregs [AMD64_XMM12] = arch_fpstate->__fpu_xmm12;
  79. context->fregs [AMD64_XMM13] = arch_fpstate->__fpu_xmm13;
  80. context->fregs [AMD64_XMM14] = arch_fpstate->__fpu_xmm14;
  81. context->fregs [AMD64_XMM15] = arch_fpstate->__fpu_xmm15;
  82. }
  83. int
  84. mono_mach_arch_get_thread_state_size ()
  85. {
  86. return sizeof (x86_thread_state64_t);
  87. }
  88. int
  89. mono_mach_arch_get_thread_fpstate_size ()
  90. {
  91. return sizeof (x86_float_state64_t);
  92. }
  93. kern_return_t
  94. mono_mach_arch_get_thread_states (thread_port_t thread, thread_state_t state, mach_msg_type_number_t *count, thread_state_t fpstate, mach_msg_type_number_t *fpcount)
  95. {
  96. #if defined(HOST_WATCHOS)
  97. g_error ("thread_get_state() is not supported by this platform");
  98. #else
  99. x86_thread_state64_t *arch_state = (x86_thread_state64_t *)state;
  100. x86_float_state64_t *arch_fpstate = (x86_float_state64_t *)fpstate;
  101. kern_return_t ret;
  102. *count = x86_THREAD_STATE64_COUNT;
  103. *fpcount = x86_FLOAT_STATE64_COUNT;
  104. ret = thread_get_state (thread, x86_THREAD_STATE64, (thread_state_t)arch_state, count);
  105. if (ret != KERN_SUCCESS)
  106. return ret;
  107. ret = thread_get_state (thread, x86_FLOAT_STATE64, (thread_state_t)arch_fpstate, fpcount);
  108. return ret;
  109. #endif
  110. }
  111. kern_return_t
  112. mono_mach_arch_set_thread_states (thread_port_t thread, thread_state_t state, mach_msg_type_number_t count, thread_state_t fpstate, mach_msg_type_number_t fpcount)
  113. {
  114. #if defined(HOST_WATCHOS)
  115. g_error ("thread_set_state() is not supported by this platform");
  116. #else
  117. kern_return_t ret;
  118. ret = thread_set_state (thread, x86_THREAD_STATE64, state, count);
  119. if (ret != KERN_SUCCESS)
  120. return ret;
  121. ret = thread_set_state (thread, x86_FLOAT_STATE64, fpstate, fpcount);
  122. return ret;
  123. #endif
  124. }
  125. #endif