jump.S 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  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. * |hiddn| v1 | v2 | v3 | v4 | v5 | v6 | v7 | *
  15. * ------------------------------------------------- *
  16. * ------------------------------------------------- *
  17. * | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | *
  18. * ------------------------------------------------- *
  19. * | 0x20| 0x24| 0x28| 0x2c| 0x30| 0x34| 0x38| 0x3c| *
  20. * ------------------------------------------------- *
  21. * | v8 | lr | pc | FCTX| DATA| | *
  22. * ------------------------------------------------- *
  23. * *
  24. *******************************************************/
  25. .text
  26. .globl jump_fcontext
  27. .align 2
  28. .type jump_fcontext,%function
  29. jump_fcontext:
  30. @ save LR as PC
  31. push {lr}
  32. @ save hidden,V1-V8,LR
  33. push {a1,v1-v8,lr}
  34. @ store RSP (pointing to context-data) in A1
  35. mov a1, sp
  36. @ restore RSP (pointing to context-data) from A2
  37. mov sp, a2
  38. @ restore hidden,V1-V8,LR
  39. pop {a4,v1-v8,lr}
  40. @ return transfer_t from jump
  41. str a1, [a4, #0]
  42. str a3, [a4, #4]
  43. @ pass transfer_t as first arg in context function
  44. @ A1 == FCTX, A2 == DATA
  45. mov a2, a3
  46. @ restore PC
  47. pop {pc}
  48. .size jump_fcontext,.-jump_fcontext
  49. @ Mark that we don't need executable stack.
  50. .section .note.GNU-stack,"",%progbits