mcount64.S 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. /*
  2. * Copyright IBM Corp. 2008,2009
  3. *
  4. * Author(s): Heiko Carstens <heiko.carstens@de.ibm.com>,
  5. *
  6. */
  7. #include <linux/linkage.h>
  8. #include <asm/asm-offsets.h>
  9. .section .kprobes.text, "ax"
  10. ENTRY(ftrace_stub)
  11. br %r14
  12. ENTRY(_mcount)
  13. #ifdef CONFIG_DYNAMIC_FTRACE
  14. br %r14
  15. ENTRY(ftrace_caller)
  16. #endif
  17. larl %r1,function_trace_stop
  18. icm %r1,0xf,0(%r1)
  19. bnzr %r14
  20. stmg %r2,%r5,32(%r15)
  21. stg %r14,112(%r15)
  22. lgr %r1,%r15
  23. aghi %r15,-160
  24. stg %r1,__SF_BACKCHAIN(%r15)
  25. lgr %r2,%r14
  26. lg %r3,168(%r15)
  27. larl %r14,ftrace_trace_function
  28. lg %r14,0(%r14)
  29. basr %r14,%r14
  30. #ifdef CONFIG_FUNCTION_GRAPH_TRACER
  31. lg %r2,168(%r15)
  32. lg %r3,272(%r15)
  33. ENTRY(ftrace_graph_caller)
  34. # The bras instruction gets runtime patched to call prepare_ftrace_return.
  35. # See ftrace_enable_ftrace_graph_caller. The patched instruction is:
  36. # bras %r14,prepare_ftrace_return
  37. bras %r14,0f
  38. 0: stg %r2,168(%r15)
  39. #endif
  40. aghi %r15,160
  41. lmg %r2,%r5,32(%r15)
  42. lg %r14,112(%r15)
  43. br %r14
  44. #ifdef CONFIG_FUNCTION_GRAPH_TRACER
  45. ENTRY(return_to_handler)
  46. stmg %r2,%r5,32(%r15)
  47. lgr %r1,%r15
  48. aghi %r15,-160
  49. stg %r1,__SF_BACKCHAIN(%r15)
  50. brasl %r14,ftrace_return_to_handler
  51. aghi %r15,160
  52. lgr %r14,%r2
  53. lmg %r2,%r5,32(%r15)
  54. br %r14
  55. #endif