2008-09-21 16:17:53 +08:00
|
|
|
#ifndef __ASM_SH_FTRACE_H
|
|
|
|
#define __ASM_SH_FTRACE_H
|
|
|
|
|
2008-11-12 19:11:47 +08:00
|
|
|
#ifdef CONFIG_FUNCTION_TRACER
|
|
|
|
|
|
|
|
#define MCOUNT_INSN_SIZE 4 /* sizeof mcount call */
|
|
|
|
|
2008-09-21 16:17:53 +08:00
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
extern void mcount(void);
|
2008-11-12 19:11:47 +08:00
|
|
|
|
|
|
|
#define MCOUNT_ADDR ((long)(mcount))
|
|
|
|
|
|
|
|
#ifdef CONFIG_DYNAMIC_FTRACE
|
|
|
|
#define CALLER_ADDR ((long)(ftrace_caller))
|
|
|
|
#define STUB_ADDR ((long)(ftrace_stub))
|
|
|
|
|
|
|
|
#define MCOUNT_INSN_OFFSET ((STUB_ADDR - CALLER_ADDR) >> 1)
|
2008-11-27 10:04:43 +08:00
|
|
|
|
|
|
|
struct dyn_arch_ftrace {
|
|
|
|
/* No extra data needed on sh */
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* CONFIG_DYNAMIC_FTRACE */
|
2008-11-12 19:11:47 +08:00
|
|
|
|
|
|
|
static inline unsigned long ftrace_call_adjust(unsigned long addr)
|
|
|
|
{
|
|
|
|
/* 'addr' is the memory table address. */
|
|
|
|
return addr;
|
|
|
|
}
|
2008-09-21 16:17:53 +08:00
|
|
|
|
2008-11-27 10:04:43 +08:00
|
|
|
#endif /* __ASSEMBLY__ */
|
2008-11-12 19:11:47 +08:00
|
|
|
#endif /* CONFIG_FUNCTION_TRACER */
|
|
|
|
|
2008-09-21 16:17:53 +08:00
|
|
|
#endif /* __ASM_SH_FTRACE_H */
|