diff options
author | Matt Fleming <mjf@gentoo.org> | 2008-11-12 06:11:47 -0500 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2008-12-22 04:42:52 -0500 |
commit | fad57feba77d2e5b183e068cb6b90693e4567b40 (patch) | |
tree | 478788d5a05a30f638540d345e9d09c5733687da /arch/sh/include | |
parent | ef6aff6884408db95ceb0f678f583536e0bd48f8 (diff) |
sh: dynamic ftrace support.
First cut at dynamic ftrace support.
Signed-off-by: Matt Fleming <mjf@gentoo.org>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh/include')
-rw-r--r-- | arch/sh/include/asm/ftrace.h | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/arch/sh/include/asm/ftrace.h b/arch/sh/include/asm/ftrace.h index 3aed362c9463..4cb5dbfc404a 100644 --- a/arch/sh/include/asm/ftrace.h +++ b/arch/sh/include/asm/ftrace.h | |||
@@ -1,8 +1,29 @@ | |||
1 | #ifndef __ASM_SH_FTRACE_H | 1 | #ifndef __ASM_SH_FTRACE_H |
2 | #define __ASM_SH_FTRACE_H | 2 | #define __ASM_SH_FTRACE_H |
3 | 3 | ||
4 | #ifdef CONFIG_FUNCTION_TRACER | ||
5 | |||
6 | #define MCOUNT_INSN_SIZE 4 /* sizeof mcount call */ | ||
7 | |||
4 | #ifndef __ASSEMBLY__ | 8 | #ifndef __ASSEMBLY__ |
5 | extern void mcount(void); | 9 | extern void mcount(void); |
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) | ||
18 | #endif | ||
19 | |||
20 | static inline unsigned long ftrace_call_adjust(unsigned long addr) | ||
21 | { | ||
22 | /* 'addr' is the memory table address. */ | ||
23 | return addr; | ||
24 | } | ||
6 | #endif | 25 | #endif |
7 | 26 | ||
27 | #endif /* CONFIG_FUNCTION_TRACER */ | ||
28 | |||
8 | #endif /* __ASM_SH_FTRACE_H */ | 29 | #endif /* __ASM_SH_FTRACE_H */ |