jump_i386_sysv_elf_gas.S 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. /*
  2. Copyright Oliver Kowalke 2009.
  3. Distributed under the Boost Software License, Version 1.0.
  4. (See accompanying file LICENSE_1_0.txt or copy at
  5. http://www.boost.org/LICENSE_1_0.txt)
  6. */
  7. /****************************************************************************************
  8. * *
  9. * ---------------------------------------------------------------------------------- *
  10. * | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | *
  11. * ---------------------------------------------------------------------------------- *
  12. * | 0x0 | 0x4 | 0x8 | 0xc | 0x10 | 0x14 | 0x18 | 0x1c | *
  13. * ---------------------------------------------------------------------------------- *
  14. * | fc_mxcsr|fc_x87_cw| EDI | ESI | EBX | EBP | EIP | hidden | *
  15. * ---------------------------------------------------------------------------------- *
  16. * ---------------------------------------------------------------------------------- *
  17. * | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | *
  18. * ---------------------------------------------------------------------------------- *
  19. * | 0x20 | 0x24 | | *
  20. * ---------------------------------------------------------------------------------- *
  21. * | to | data | | *
  22. * ---------------------------------------------------------------------------------- *
  23. * *
  24. ****************************************************************************************/
  25. .text
  26. .globl jump_fcontext
  27. .align 2
  28. .type jump_fcontext,@function
  29. jump_fcontext:
  30. leal -0x18(%esp), %esp /* prepare stack */
  31. #if !defined(BOOST_USE_TSX)
  32. stmxcsr (%esp) /* save MMX control- and status-word */
  33. fnstcw 0x4(%esp) /* save x87 control-word */
  34. #endif
  35. movl %edi, 0x8(%esp) /* save EDI */
  36. movl %esi, 0xc(%esp) /* save ESI */
  37. movl %ebx, 0x10(%esp) /* save EBX */
  38. movl %ebp, 0x14(%esp) /* save EBP */
  39. /* store ESP (pointing to context-data) in ECX */
  40. movl %esp, %ecx
  41. /* first arg of jump_fcontext() == fcontext to jump to */
  42. movl 0x20(%esp), %eax
  43. /* second arg of jump_fcontext() == data to be transferred */
  44. movl 0x24(%esp), %edx
  45. /* restore ESP (pointing to context-data) from EAX */
  46. movl %eax, %esp
  47. /* address of returned transport_t */
  48. movl 0x1c(%esp), %eax
  49. /* return parent fcontext_t */
  50. movl %ecx, (%eax)
  51. /* return data */
  52. movl %edx, 0x4(%eax)
  53. movl 0x18(%esp), %ecx /* restore EIP */
  54. #if !defined(BOOST_USE_TSX)
  55. ldmxcsr (%esp) /* restore MMX control- and status-word */
  56. fldcw 0x4(%esp) /* restore x87 control-word */
  57. #endif
  58. movl 0x8(%esp), %edi /* restore EDI */
  59. movl 0xc(%esp), %esi /* restore ESI */
  60. movl 0x10(%esp), %ebx /* restore EBX */
  61. movl 0x14(%esp), %ebp /* restore EBP */
  62. leal 0x20(%esp), %esp /* prepare stack */
  63. /* jump to context */
  64. jmp *%ecx
  65. .size jump_fcontext,.-jump_fcontext
  66. /* Mark that we don't need executable stack. */
  67. .section .note.GNU-stack,"",%progbits