1
2
3
4
5
6
7
8
9
10 #ifndef _XTENSA_FTRACE_H
11 #define _XTENSA_FTRACE_H
12
13 #include <asm/processor.h>
14
15 #ifndef __ASSEMBLY__
16 #define ftrace_return_address0 ({ unsigned long a0, a1; \
17 __asm__ __volatile__ ( \
18 "mov %0, a0\n" \
19 "mov %1, a1\n" \
20 : "=r"(a0), "=r"(a1)); \
21 MAKE_PC_FROM_RA(a0, a1); })
22
23 #ifdef CONFIG_FRAME_POINTER
24 extern unsigned long return_address(unsigned level);
25 #define ftrace_return_address(n) return_address(n)
26 #endif
27 #endif
28
29 #ifdef CONFIG_FUNCTION_TRACER
30
31 #define MCOUNT_ADDR ((unsigned long)(_mcount))
32 #define MCOUNT_INSN_SIZE 3
33
34 #ifndef __ASSEMBLY__
35 extern void _mcount(void);
36 #define mcount _mcount
37 #endif
38 #endif
39
40 #endif