mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 c93bf928fe
			
		
	
	
		c93bf928fe
		
	
	
	
	
		
			
			Always we use type unsigned long to format the ip address, since the value of ip address is never the negative. This patch uses type unsigned long, instead of long, to format the ip address. The code is more clearly to be viewed by using type unsigned long, although it is correct by using either unsigned long or long. Link: http://lkml.kernel.org/r/1436694744-16747-1-git-send-email-mhuang@redhat.com Cc: Minfei Huang <mnfhuang@gmail.com> Cc: "H. Peter Anvin" <hpa@zytor.com> Cc: James Hogan <james.hogan@imgtec.com> Cc: Michal Simek <monstr@monstr.eu> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org> Cc: "David S. Miller" <davem@davemloft.net> Signed-off-by: Minfei Huang <mnfhuang@gmail.com> Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
		
			
				
	
	
		
			80 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef _ASM_POWERPC_FTRACE
 | |
| #define _ASM_POWERPC_FTRACE
 | |
| 
 | |
| #ifdef CONFIG_FUNCTION_TRACER
 | |
| #define MCOUNT_ADDR		((unsigned long)(_mcount))
 | |
| #define MCOUNT_INSN_SIZE	4 /* sizeof mcount call */
 | |
| 
 | |
| #ifdef __ASSEMBLY__
 | |
| 
 | |
| /* Based off of objdump optput from glibc */
 | |
| 
 | |
| #define MCOUNT_SAVE_FRAME			\
 | |
| 	stwu	r1,-48(r1);			\
 | |
| 	stw	r3, 12(r1);			\
 | |
| 	stw	r4, 16(r1);			\
 | |
| 	stw	r5, 20(r1);			\
 | |
| 	stw	r6, 24(r1);			\
 | |
| 	mflr	r3;				\
 | |
| 	lwz	r4, 52(r1);			\
 | |
| 	mfcr	r5;				\
 | |
| 	stw	r7, 28(r1);			\
 | |
| 	stw	r8, 32(r1);			\
 | |
| 	stw	r9, 36(r1);			\
 | |
| 	stw	r10,40(r1);			\
 | |
| 	stw	r3, 44(r1);			\
 | |
| 	stw	r5, 8(r1)
 | |
| 
 | |
| #define MCOUNT_RESTORE_FRAME			\
 | |
| 	lwz	r6, 8(r1);			\
 | |
| 	lwz	r0, 44(r1);			\
 | |
| 	lwz	r3, 12(r1);			\
 | |
| 	mtctr	r0;				\
 | |
| 	lwz	r4, 16(r1);			\
 | |
| 	mtcr	r6;				\
 | |
| 	lwz	r5, 20(r1);			\
 | |
| 	lwz	r6, 24(r1);			\
 | |
| 	lwz	r0, 52(r1);			\
 | |
| 	lwz	r7, 28(r1);			\
 | |
| 	lwz	r8, 32(r1);			\
 | |
| 	mtlr	r0;				\
 | |
| 	lwz	r9, 36(r1);			\
 | |
| 	lwz	r10,40(r1);			\
 | |
| 	addi	r1, r1, 48
 | |
| 
 | |
| #else /* !__ASSEMBLY__ */
 | |
| extern void _mcount(void);
 | |
| 
 | |
| #ifdef CONFIG_DYNAMIC_FTRACE
 | |
| static inline unsigned long ftrace_call_adjust(unsigned long addr)
 | |
| {
 | |
|        /* reloction of mcount call site is the same as the address */
 | |
|        return addr;
 | |
| }
 | |
| 
 | |
| struct dyn_arch_ftrace {
 | |
| 	struct module *mod;
 | |
| };
 | |
| #endif /*  CONFIG_DYNAMIC_FTRACE */
 | |
| #endif /* __ASSEMBLY__ */
 | |
| 
 | |
| #endif
 | |
| 
 | |
| #if defined(CONFIG_FTRACE_SYSCALLS) && defined(CONFIG_PPC64) && !defined(__ASSEMBLY__)
 | |
| #if !defined(_CALL_ELF) || _CALL_ELF != 2
 | |
| #define ARCH_HAS_SYSCALL_MATCH_SYM_NAME
 | |
| static inline bool arch_syscall_match_sym_name(const char *sym, const char *name)
 | |
| {
 | |
| 	/*
 | |
| 	 * Compare the symbol name with the system call name. Skip the .sys or .SyS
 | |
| 	 * prefix from the symbol name and the sys prefix from the system call name and
 | |
| 	 * just match the rest. This is only needed on ppc64 since symbol names on
 | |
| 	 * 32bit do not start with a period so the generic function will work.
 | |
| 	 */
 | |
| 	return !strcmp(sym + 4, name + 3);
 | |
| }
 | |
| #endif
 | |
| #endif /* CONFIG_FTRACE_SYSCALLS && CONFIG_PPC64 && !__ASSEMBLY__ */
 | |
| 
 | |
| #endif /* _ASM_POWERPC_FTRACE */
 |