 c52d0d30ae
			
		
	
	
	c52d0d30ae
	
	
	
		
			
			This is a preliminary patch to add a vdso to all user processes. Still missing are ELF headers and .eh_frame information. But it is enough to allow us to move signal trampolines off of the stack. Note that emulation of branch delay slots in the FPU emulator still requires the stack. We allocate a single page (the vdso) and write all possible signal trampolines into it. The stack is moved down by one page and the vdso is mapped into this space. Signed-off-by: David Daney <ddaney@caviumnetworks.com> To: linux-mips@linux-mips.org Patchwork: http://patchwork.linux-mips.org/patch/975/ Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
		
			
				
	
	
		
			29 lines
		
	
	
	
		
			622 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			29 lines
		
	
	
	
		
			622 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * 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) 2009 Cavium Networks
 | |
|  */
 | |
| 
 | |
| #ifndef __ASM_VDSO_H
 | |
| #define __ASM_VDSO_H
 | |
| 
 | |
| #include <linux/types.h>
 | |
| 
 | |
| 
 | |
| #ifdef CONFIG_32BIT
 | |
| struct mips_vdso {
 | |
| 	u32 signal_trampoline[2];
 | |
| 	u32 rt_signal_trampoline[2];
 | |
| };
 | |
| #else  /* !CONFIG_32BIT */
 | |
| struct mips_vdso {
 | |
| 	u32 o32_signal_trampoline[2];
 | |
| 	u32 o32_rt_signal_trampoline[2];
 | |
| 	u32 rt_signal_trampoline[2];
 | |
| 	u32 n32_rt_signal_trampoline[2];
 | |
| };
 | |
| #endif /* CONFIG_32BIT */
 | |
| 
 | |
| #endif /* __ASM_VDSO_H */
 |