Pull signal handling cleanups from Al Viro: "sigaltstack infrastructure + conversion for x86, alpha and um, COMPAT_SYSCALL_DEFINE infrastructure. Note that there are several conflicts between "unify SS_ONSTACK/SS_DISABLE definitions" and UAPI patches in mainline; resolution is trivial - just remove definitions of SS_ONSTACK and SS_DISABLED from arch/*/uapi/asm/signal.h; they are all identical and include/uapi/linux/signal.h contains the unified variant." Fixed up conflicts as per Al. * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/signal: alpha: switch to generic sigaltstack new helpers: __save_altstack/__compat_save_altstack, switch x86 and um to those generic compat_sys_sigaltstack() introduce generic sys_sigaltstack(), switch x86 and um to it new helper: compat_user_stack_pointer() new helper: restore_altstack() unify SS_ONSTACK/SS_DISABLE definitions new helper: current_user_stack_pointer() missing user_stack_pointer() instances Bury the conditionals from kernel_thread/kernel_execve series COMPAT_SYSCALL_DEFINE: infrastructure
		
			
				
	
	
		
			44 lines
		
	
	
	
		
			1.3 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
	
		
			1.3 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * linux/include/asm-m32r/ptrace.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.
 | 
						|
 *
 | 
						|
 * M32R version:
 | 
						|
 *   Copyright (C) 2001-2002, 2004  Hirokazu Takata <takata at linux-m32r.org>
 | 
						|
 */
 | 
						|
#ifndef _ASM_M32R_PTRACE_H
 | 
						|
#define _ASM_M32R_PTRACE_H
 | 
						|
 | 
						|
 | 
						|
#include <asm/m32r.h>		/* M32R_PSW_BSM, M32R_PSW_BPM */
 | 
						|
#include <uapi/asm/ptrace.h>
 | 
						|
 | 
						|
#define arch_has_single_step() (1)
 | 
						|
 | 
						|
struct task_struct;
 | 
						|
extern void init_debug_traps(struct task_struct *);
 | 
						|
#define arch_ptrace_attach(child) \
 | 
						|
	init_debug_traps(child)
 | 
						|
 | 
						|
#if defined(CONFIG_ISA_M32R2) || defined(CONFIG_CHIP_VDEC2)
 | 
						|
#define user_mode(regs) ((M32R_PSW_BPM & (regs)->psw) != 0)
 | 
						|
#elif defined(CONFIG_ISA_M32R)
 | 
						|
#define user_mode(regs) ((M32R_PSW_BSM & (regs)->psw) != 0)
 | 
						|
#else
 | 
						|
#error unknown isa configuration
 | 
						|
#endif
 | 
						|
 | 
						|
#define instruction_pointer(regs) ((regs)->bpc)
 | 
						|
#define profile_pc(regs) instruction_pointer(regs)
 | 
						|
#define user_stack_pointer(regs) ((regs)->spu)
 | 
						|
 | 
						|
extern void withdraw_debug_trap(struct pt_regs *regs);
 | 
						|
 | 
						|
#define task_pt_regs(task) \
 | 
						|
        ((struct pt_regs *)(task_stack_page(task) + THREAD_SIZE) - 1)
 | 
						|
#define current_pt_regs() ((struct pt_regs *) \
 | 
						|
	((unsigned long)current_thread_info() + THREAD_SIZE) - 1)
 | 
						|
 | 
						|
#endif /* _ASM_M32R_PTRACE_H */
 |