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 */ |
| 7 | |
Paul Mundt | 4b4cf75 | 2008-09-21 17:17:53 +0900 | [diff] [blame] | 8 | #ifndef __ASSEMBLY__ |
| 9 | extern void mcount(void); |
Matt Fleming | fad57fe | 2008-11-12 20:11:47 +0900 | [diff] [blame] | 10 | |
| 11 | #define MCOUNT_ADDR ((long)(mcount)) |
| 12 | |
| 13 | #ifdef CONFIG_DYNAMIC_FTRACE |
| 14 | #define CALLER_ADDR ((long)(ftrace_caller)) |
| 15 | #define STUB_ADDR ((long)(ftrace_stub)) |
| 16 | |
| 17 | #define MCOUNT_INSN_OFFSET ((STUB_ADDR - CALLER_ADDR) >> 1) |
Paul Mundt | 22f131a | 2008-11-27 11:04:43 +0900 | [diff] [blame] | 18 | |
| 19 | struct dyn_arch_ftrace { |
| 20 | /* No extra data needed on sh */ |
| 21 | }; |
| 22 | |
| 23 | #endif /* CONFIG_DYNAMIC_FTRACE */ |
Paul Mundt | 4b4cf75 | 2008-09-21 17:17:53 +0900 | [diff] [blame] | 24 | |
Matt Fleming | fad57fe | 2008-11-12 20:11:47 +0900 | [diff] [blame] | 25 | static inline unsigned long ftrace_call_adjust(unsigned long addr) |
| 26 | { |
| 27 | /* 'addr' is the memory table address. */ |
| 28 | return addr; |
| 29 | } |
Matt Fleming | fad57fe | 2008-11-12 20:11:47 +0900 | [diff] [blame] | 30 | |
Paul Mundt | 22f131a | 2008-11-27 11:04:43 +0900 | [diff] [blame] | 31 | #endif /* __ASSEMBLY__ */ |
Matt Fleming | fad57fe | 2008-11-12 20:11:47 +0900 | [diff] [blame] | 32 | #endif /* CONFIG_FUNCTION_TRACER */ |
| 33 | |
Paul Mundt | 4b4cf75 | 2008-09-21 17:17:53 +0900 | [diff] [blame] | 34 | #endif /* __ASM_SH_FTRACE_H */ |