Paul Mundt | 4b4cf75 | 2008-09-21 17:17:53 +0900 | [diff] [blame] | 1 | #ifndef __ASM_SH_FTRACE_H |
| 2 | #define __ASM_SH_FTRACE_H |
| 3 | |
Matt Fleming | fad57fe | 2008-11-12 20:11:47 +0900 | [diff] [blame] | 4 | #ifdef CONFIG_FUNCTION_TRACER |
| 5 | |
| 6 | #define MCOUNT_INSN_SIZE 4 /* sizeof mcount call */ |
Paul Mundt | c68e320 | 2009-08-25 18:39:33 +0900 | [diff] [blame] | 7 | #define FTRACE_SYSCALL_MAX NR_syscalls |
Matt Fleming | fad57fe | 2008-11-12 20:11:47 +0900 | [diff] [blame] | 8 | |
Paul Mundt | 4b4cf75 | 2008-09-21 17:17:53 +0900 | [diff] [blame] | 9 | #ifndef __ASSEMBLY__ |
| 10 | extern void mcount(void); |
Matt Fleming | fad57fe | 2008-11-12 20:11:47 +0900 | [diff] [blame] | 11 | |
Minfei Huang | c93bf92 | 2015-07-12 17:52:24 +0800 | [diff] [blame] | 12 | #define MCOUNT_ADDR ((unsigned long)(mcount)) |
Matt Fleming | fad57fe | 2008-11-12 20:11:47 +0900 | [diff] [blame] | 13 | |
| 14 | #ifdef CONFIG_DYNAMIC_FTRACE |
Matt Fleming | ca0d172 | 2009-06-28 12:53:07 +0100 | [diff] [blame] | 15 | #define CALL_ADDR ((long)(ftrace_call)) |
Matt Fleming | fad57fe | 2008-11-12 20:11:47 +0900 | [diff] [blame] | 16 | #define STUB_ADDR ((long)(ftrace_stub)) |
Matt Fleming | 327933f | 2009-07-11 00:29:03 +0000 | [diff] [blame] | 17 | #define GRAPH_ADDR ((long)(ftrace_graph_call)) |
| 18 | #define CALLER_ADDR ((long)(ftrace_caller)) |
Matt Fleming | fad57fe | 2008-11-12 20:11:47 +0900 | [diff] [blame] | 19 | |
Matt Fleming | ca0d172 | 2009-06-28 12:53:07 +0100 | [diff] [blame] | 20 | #define MCOUNT_INSN_OFFSET ((STUB_ADDR - CALL_ADDR) - 4) |
Matt Fleming | 327933f | 2009-07-11 00:29:03 +0000 | [diff] [blame] | 21 | #define GRAPH_INSN_OFFSET ((CALLER_ADDR - GRAPH_ADDR) - 4) |
Paul Mundt | 22f131a | 2008-11-27 11:04:43 +0900 | [diff] [blame] | 22 | |
| 23 | struct dyn_arch_ftrace { |
| 24 | /* No extra data needed on sh */ |
| 25 | }; |
| 26 | |
| 27 | #endif /* CONFIG_DYNAMIC_FTRACE */ |
Paul Mundt | 4b4cf75 | 2008-09-21 17:17:53 +0900 | [diff] [blame] | 28 | |
Matt Fleming | fad57fe | 2008-11-12 20:11:47 +0900 | [diff] [blame] | 29 | static inline unsigned long ftrace_call_adjust(unsigned long addr) |
| 30 | { |
| 31 | /* 'addr' is the memory table address. */ |
| 32 | return addr; |
| 33 | } |
Matt Fleming | fad57fe | 2008-11-12 20:11:47 +0900 | [diff] [blame] | 34 | |
Paul Mundt | 36c8719 | 2009-10-14 11:49:49 +0900 | [diff] [blame] | 35 | #endif /* __ASSEMBLY__ */ |
| 36 | #endif /* CONFIG_FUNCTION_TRACER */ |
| 37 | |
| 38 | #ifndef __ASSEMBLY__ |
| 39 | |
Paul Mundt | ac4fac8 | 2009-10-13 13:10:14 +0900 | [diff] [blame] | 40 | /* arch/sh/kernel/return_address.c */ |
| 41 | extern void *return_address(unsigned int); |
Matt Fleming | d26cddb | 2009-10-11 17:56:17 +0100 | [diff] [blame] | 42 | |
AKASHI Takahiro | eed542d | 2014-05-20 20:31:04 +0900 | [diff] [blame] | 43 | #define ftrace_return_address(n) return_address(n) |
Matt Fleming | d26cddb | 2009-10-11 17:56:17 +0100 | [diff] [blame] | 44 | |
Paul Mundt | 22f131a | 2008-11-27 11:04:43 +0900 | [diff] [blame] | 45 | #endif /* __ASSEMBLY__ */ |
Matt Fleming | fad57fe | 2008-11-12 20:11:47 +0900 | [diff] [blame] | 46 | |
Paul Mundt | 4b4cf75 | 2008-09-21 17:17:53 +0900 | [diff] [blame] | 47 | #endif /* __ASM_SH_FTRACE_H */ |