mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 a0a4419e30
			
		
	
	
		a0a4419e30
		
	
	
	
	
		
			
			perf is failing to resolve symbols in the VDSO. A while (1) gettimeofday() loop shows: 93.99% [vdso] [.] 0x00000000000005e0 3.12% test [.] 00000037.plt_call.gettimeofday@@GLIBC_2.18 2.81% test [.] main The reason for this is that we are linking our VDSO shared libraries at 1MB, which is a little weird. Even though this is uncommon, Alan points out that it is valid and we should probably fix perf userspace. Regardless, I can't see a reason why we are doing this. The code is all position independent and we never rely on the VDSO ending up at 1M (and we never place it there on 64bit tasks). Changing our link address to 0x0 fixes perf VDSO symbol resolution: 73.18% [vdso] [.] 0x000000000000060c 12.39% [vdso] [.] __kernel_gettimeofday 3.58% test [.] 00000037.plt_call.gettimeofday@@GLIBC_2.18 2.94% [vdso] [.] __kernel_datapage_offset 2.90% test [.] main We still have some local symbol resolution issues that will be fixed in a subsequent patch. Signed-off-by: Anton Blanchard <anton@samba.org> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
		
			
				
	
	
		
			80 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef __PPC64_VDSO_H__
 | |
| #define __PPC64_VDSO_H__
 | |
| 
 | |
| #ifdef __KERNEL__
 | |
| 
 | |
| /* Default link addresses for the vDSOs */
 | |
| #define VDSO32_LBASE	0x0
 | |
| #define VDSO64_LBASE	0x0
 | |
| 
 | |
| /* Default map addresses for 32bit vDSO */
 | |
| #define VDSO32_MBASE	0x100000
 | |
| 
 | |
| #define VDSO_VERSION_STRING	LINUX_2.6.15
 | |
| 
 | |
| /* Define if 64 bits VDSO has procedure descriptors */
 | |
| #undef VDS64_HAS_DESCRIPTORS
 | |
| 
 | |
| #ifndef __ASSEMBLY__
 | |
| 
 | |
| /* Offsets relative to thread->vdso_base */
 | |
| extern unsigned long vdso64_rt_sigtramp;
 | |
| extern unsigned long vdso32_sigtramp;
 | |
| extern unsigned long vdso32_rt_sigtramp;
 | |
| 
 | |
| int vdso_getcpu_init(void);
 | |
| 
 | |
| #else /* __ASSEMBLY__ */
 | |
| 
 | |
| #ifdef __VDSO64__
 | |
| #ifdef VDS64_HAS_DESCRIPTORS
 | |
| #define V_FUNCTION_BEGIN(name)		\
 | |
| 	.globl name;			\
 | |
|         .section ".opd","a";		\
 | |
|         .align 3;			\
 | |
| 	name:				\
 | |
| 	.quad .name,.TOC.@tocbase,0;	\
 | |
| 	.previous;			\
 | |
| 	.globl .name;			\
 | |
| 	.type .name,@function; 		\
 | |
| 	.name:				\
 | |
| 
 | |
| #define V_FUNCTION_END(name)		\
 | |
| 	.size .name,.-.name;
 | |
| 
 | |
| #define V_LOCAL_FUNC(name) (.name)
 | |
| 
 | |
| #else /* VDS64_HAS_DESCRIPTORS */
 | |
| 
 | |
| #define V_FUNCTION_BEGIN(name)		\
 | |
| 	.globl name;			\
 | |
| 	name:				\
 | |
| 
 | |
| #define V_FUNCTION_END(name)		\
 | |
| 	.size name,.-name;
 | |
| 
 | |
| #define V_LOCAL_FUNC(name) (name)
 | |
| 
 | |
| #endif /* VDS64_HAS_DESCRIPTORS */
 | |
| #endif /* __VDSO64__ */
 | |
| 
 | |
| #ifdef __VDSO32__
 | |
| 
 | |
| #define V_FUNCTION_BEGIN(name)		\
 | |
| 	.globl name;			\
 | |
| 	.type name,@function; 		\
 | |
| 	name:				\
 | |
| 
 | |
| #define V_FUNCTION_END(name)		\
 | |
| 	.size name,.-name;
 | |
| 
 | |
| #define V_LOCAL_FUNC(name) (name)
 | |
| 
 | |
| #endif /* __VDSO32__ */
 | |
| 
 | |
| #endif /* __ASSEMBLY__ */
 | |
| 
 | |
| #endif /* __KERNEL__ */
 | |
| 
 | |
| #endif /* __PPC64_VDSO_H__ */
 |