eed542d696
Most archs with HAVE_ARCH_CALLER_ADDR have pretty much the same definitions of CALLER_ADDRx(n). Instead of duplicating the code for all the archs, define a ftrace_return_address0() and ftrace_return_address(n) that can be overwritten by the archs if they need to do something different. Instead of 7 macros in every arch, we now only have at most 2 (and actually only 1 as ftrace_return_address0() should be the same for all archs). The CALLER_ADDRx(n) will now be defined in linux/ftrace.h and use the ftrace_return_address*(n?) macros. This removes a lot of the duplicate code. Link: http://lkml.kernel.org/p/1400585464-30333-1-git-send-email-takahiro.akashi@linaro.org Signed-off-by: AKASHI Takahiro <takahiro.akashi@linaro.org> Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
41 lines
979 B
C
41 lines
979 B
C
/*
|
|
* arch/xtensa/include/asm/ftrace.h
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
* for more details.
|
|
*
|
|
* Copyright (C) 2013 Tensilica Inc.
|
|
*/
|
|
#ifndef _XTENSA_FTRACE_H
|
|
#define _XTENSA_FTRACE_H
|
|
|
|
#include <asm/processor.h>
|
|
|
|
#ifndef __ASSEMBLY__
|
|
#define ftrace_return_address0 ({ unsigned long a0, a1; \
|
|
__asm__ __volatile__ ( \
|
|
"mov %0, a0\n" \
|
|
"mov %1, a1\n" \
|
|
: "=r"(a0), "=r"(a1)); \
|
|
MAKE_PC_FROM_RA(a0, a1); })
|
|
|
|
#ifdef CONFIG_FRAME_POINTER
|
|
extern unsigned long return_address(unsigned level);
|
|
#define ftrace_return_address(n) return_address(n)
|
|
#endif
|
|
#endif /* __ASSEMBLY__ */
|
|
|
|
#ifdef CONFIG_FUNCTION_TRACER
|
|
|
|
#define MCOUNT_ADDR ((unsigned long)(_mcount))
|
|
#define MCOUNT_INSN_SIZE 3
|
|
|
|
#ifndef __ASSEMBLY__
|
|
extern void _mcount(void);
|
|
#define mcount _mcount
|
|
#endif /* __ASSEMBLY__ */
|
|
#endif /* CONFIG_FUNCTION_TRACER */
|
|
|
|
#endif /* _XTENSA_FTRACE_H */
|