mcount.S 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. /*
  2. * arch/xtensa/kernel/mcount.S
  3. *
  4. * Xtensa specific mcount support
  5. *
  6. * This file is subject to the terms and conditions of the GNU General Public
  7. * License. See the file "COPYING" in the main directory of this archive
  8. * for more details.
  9. *
  10. * Copyright (C) 2013 Tensilica Inc.
  11. */
  12. #include <linux/linkage.h>
  13. #include <asm/asmmacro.h>
  14. #include <asm/ftrace.h>
  15. /*
  16. * Entry condition:
  17. *
  18. * a2: a0 of the caller in windowed ABI
  19. * a10: a0 of the caller in call0 ABI
  20. *
  21. * In call0 ABI the function _mcount is called with the special ABI:
  22. * its argument is in a10 and all the usual argument registers (a2 - a7)
  23. * must be preserved in addition to callee-saved a12 - a15.
  24. */
  25. ENTRY(_mcount)
  26. #if defined(__XTENSA_WINDOWED_ABI__)
  27. abi_entry_default
  28. movi a4, ftrace_trace_function
  29. l32i a4, a4, 0
  30. movi a3, ftrace_stub
  31. bne a3, a4, 1f
  32. abi_ret_default
  33. 1: xor a7, a2, a1
  34. movi a3, 0x3fffffff
  35. and a7, a7, a3
  36. xor a7, a7, a1
  37. xor a6, a0, a1
  38. and a6, a6, a3
  39. xor a6, a6, a1
  40. addi a6, a6, -MCOUNT_INSN_SIZE
  41. callx4 a4
  42. abi_ret_default
  43. #elif defined(__XTENSA_CALL0_ABI__)
  44. abi_entry_default
  45. movi a9, ftrace_trace_function
  46. l32i a9, a9, 0
  47. movi a11, ftrace_stub
  48. bne a9, a11, 1f
  49. abi_ret_default
  50. 1: abi_entry(28)
  51. s32i a0, sp, 0
  52. s32i a2, sp, 4
  53. s32i a3, sp, 8
  54. s32i a4, sp, 12
  55. s32i a5, sp, 16
  56. s32i a6, sp, 20
  57. s32i a7, sp, 24
  58. addi a2, a10, -MCOUNT_INSN_SIZE
  59. callx0 a9
  60. l32i a0, sp, 0
  61. l32i a2, sp, 4
  62. l32i a3, sp, 8
  63. l32i a4, sp, 12
  64. l32i a5, sp, 16
  65. l32i a6, sp, 20
  66. l32i a7, sp, 24
  67. abi_ret(28)
  68. #else
  69. #error Unsupported Xtensa ABI
  70. #endif
  71. ENDPROC(_mcount)
  72. ENTRY(ftrace_stub)
  73. abi_entry_default
  74. abi_ret_default
  75. ENDPROC(ftrace_stub)