ontop.S 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  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 ontop_fcontext
  27. .align 2
  28. .type ontop_fcontext,%function
  29. ontop_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. @ store parent context in A2
  39. mov a2, a1
  40. @ restore hidden,V1-V8,LR
  41. pop {a1,v1-v8,lr}
  42. @ return transfer_t from jump
  43. str a2, [a1, #0]
  44. str a3, [a1, #4]
  45. @ pass transfer_t as first arg in context function
  46. @ A1 == hidden, A2 == FCTX, A3 == DATA
  47. @ skip PC
  48. add sp, sp, #4
  49. @ jump to ontop-function
  50. bx a4
  51. .size ontop_fcontext,.-ontop_fcontext
  52. @ Mark that we don't need executable stack.
  53. .section .note.GNU-stack,"",%progbits