2008-10-22 23:26:29 -06:00
|
|
|
#ifndef _ASM_X86_FTRACE_H
|
|
|
|
#define _ASM_X86_FTRACE_H
|
2008-06-21 12:17:27 -06:00
|
|
|
|
2008-10-06 17:06:12 -06:00
|
|
|
#ifdef CONFIG_FUNCTION_TRACER
|
2008-06-21 12:17:27 -06:00
|
|
|
#define MCOUNT_ADDR ((long)(mcount))
|
|
|
|
#define MCOUNT_INSN_SIZE 5 /* sizeof mcount call */
|
|
|
|
|
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
extern void mcount(void);
|
2008-08-14 13:45:08 -06:00
|
|
|
|
|
|
|
static inline unsigned long ftrace_call_adjust(unsigned long addr)
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* call mcount is "e8 <4 byte offset>"
|
|
|
|
* The addr points to the 4 byte offset and the caller of this
|
|
|
|
* function wants the pointer to e8. Simply subtract one.
|
|
|
|
*/
|
|
|
|
return addr - 1;
|
|
|
|
}
|
2008-11-14 17:21:19 -07:00
|
|
|
|
|
|
|
#ifdef CONFIG_DYNAMIC_FTRACE
|
|
|
|
|
|
|
|
struct dyn_arch_ftrace {
|
|
|
|
/* No extra data needed for x86 */
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* CONFIG_DYNAMIC_FTRACE */
|
2008-10-30 22:03:22 -06:00
|
|
|
#endif /* __ASSEMBLY__ */
|
2008-10-06 17:06:12 -06:00
|
|
|
#endif /* CONFIG_FUNCTION_TRACER */
|
2008-06-21 12:17:27 -06:00
|
|
|
|
2008-11-10 23:03:45 -07:00
|
|
|
#ifdef CONFIG_FUNCTION_RET_TRACER
|
|
|
|
#define FTRACE_RET_STACK_SIZE 20
|
|
|
|
|
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Stack of return addresses for functions
|
|
|
|
* of a thread.
|
|
|
|
* Used in struct thread_info
|
|
|
|
*/
|
|
|
|
struct ftrace_ret_stack {
|
|
|
|
unsigned long ret;
|
|
|
|
unsigned long func;
|
|
|
|
unsigned long long calltime;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Primary handler of a function return.
|
|
|
|
* It relays on ftrace_return_to_handler.
|
|
|
|
* Defined in entry32.S
|
|
|
|
*/
|
|
|
|
extern void return_to_handler(void);
|
|
|
|
|
|
|
|
#endif /* __ASSEMBLY__ */
|
|
|
|
#endif /* CONFIG_FUNCTION_RET_TRACER */
|
|
|
|
|
2008-10-22 23:26:29 -06:00
|
|
|
#endif /* _ASM_X86_FTRACE_H */
|