diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-12-20 21:05:28 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-12-20 21:05:28 -0500 |
commit | 54d46ea993744c5408e39ce0cb4851e13cbea716 (patch) | |
tree | 8e38fa92cc2ae72e0353c44e1e68be9bf5a7a058 /arch/alpha | |
parent | f59dc2bb5a50b26ea751f9eac1c81e4cc7de5257 (diff) | |
parent | 50ececcfa7d1acee085b2c518cad495062db6379 (diff) |
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/signal
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
Diffstat (limited to 'arch/alpha')
-rw-r--r-- | arch/alpha/Kconfig | 3 | ||||
-rw-r--r-- | arch/alpha/include/asm/ptrace.h | 1 | ||||
-rw-r--r-- | arch/alpha/include/asm/unistd.h | 1 | ||||
-rw-r--r-- | arch/alpha/include/uapi/asm/signal.h | 6 | ||||
-rw-r--r-- | arch/alpha/kernel/signal.c | 10 |
5 files changed, 3 insertions, 18 deletions
diff --git a/arch/alpha/Kconfig b/arch/alpha/Kconfig index 5dd7f5db24d4..9d5904cc7712 100644 --- a/arch/alpha/Kconfig +++ b/arch/alpha/Kconfig | |||
@@ -20,10 +20,9 @@ config ALPHA | |||
20 | select GENERIC_CMOS_UPDATE | 20 | select GENERIC_CMOS_UPDATE |
21 | select GENERIC_STRNCPY_FROM_USER | 21 | select GENERIC_STRNCPY_FROM_USER |
22 | select GENERIC_STRNLEN_USER | 22 | select GENERIC_STRNLEN_USER |
23 | select GENERIC_KERNEL_THREAD | ||
24 | select GENERIC_KERNEL_EXECVE | ||
25 | select HAVE_MOD_ARCH_SPECIFIC | 23 | select HAVE_MOD_ARCH_SPECIFIC |
26 | select MODULES_USE_ELF_RELA | 24 | select MODULES_USE_ELF_RELA |
25 | select GENERIC_SIGALTSTACK | ||
27 | help | 26 | help |
28 | The Alpha is a 64-bit general-purpose processor designed and | 27 | The Alpha is a 64-bit general-purpose processor designed and |
29 | marketed by the Digital Equipment Corporation of blessed memory, | 28 | marketed by the Digital Equipment Corporation of blessed memory, |
diff --git a/arch/alpha/include/asm/ptrace.h b/arch/alpha/include/asm/ptrace.h index df9a6cd748d5..21128505ddbe 100644 --- a/arch/alpha/include/asm/ptrace.h +++ b/arch/alpha/include/asm/ptrace.h | |||
@@ -8,6 +8,7 @@ | |||
8 | #define user_mode(regs) (((regs)->ps & 8) != 0) | 8 | #define user_mode(regs) (((regs)->ps & 8) != 0) |
9 | #define instruction_pointer(regs) ((regs)->pc) | 9 | #define instruction_pointer(regs) ((regs)->pc) |
10 | #define profile_pc(regs) instruction_pointer(regs) | 10 | #define profile_pc(regs) instruction_pointer(regs) |
11 | #define current_user_stack_pointer() rdusp() | ||
11 | 12 | ||
12 | #define task_pt_regs(task) \ | 13 | #define task_pt_regs(task) \ |
13 | ((struct pt_regs *) (task_stack_page(task) + 2*PAGE_SIZE) - 1) | 14 | ((struct pt_regs *) (task_stack_page(task) + 2*PAGE_SIZE) - 1) |
diff --git a/arch/alpha/include/asm/unistd.h b/arch/alpha/include/asm/unistd.h index d6069ff3b1c8..b3396ee039b7 100644 --- a/arch/alpha/include/asm/unistd.h +++ b/arch/alpha/include/asm/unistd.h | |||
@@ -15,7 +15,6 @@ | |||
15 | #define __ARCH_WANT_SYS_OLDUMOUNT | 15 | #define __ARCH_WANT_SYS_OLDUMOUNT |
16 | #define __ARCH_WANT_SYS_SIGPENDING | 16 | #define __ARCH_WANT_SYS_SIGPENDING |
17 | #define __ARCH_WANT_SYS_RT_SIGSUSPEND | 17 | #define __ARCH_WANT_SYS_RT_SIGSUSPEND |
18 | #define __ARCH_WANT_SYS_EXECVE | ||
19 | #define __ARCH_WANT_SYS_FORK | 18 | #define __ARCH_WANT_SYS_FORK |
20 | #define __ARCH_WANT_SYS_VFORK | 19 | #define __ARCH_WANT_SYS_VFORK |
21 | #define __ARCH_WANT_SYS_CLONE | 20 | #define __ARCH_WANT_SYS_CLONE |
diff --git a/arch/alpha/include/uapi/asm/signal.h b/arch/alpha/include/uapi/asm/signal.h index 965bbfa59c65..dd4ca4bcbb4a 100644 --- a/arch/alpha/include/uapi/asm/signal.h +++ b/arch/alpha/include/uapi/asm/signal.h | |||
@@ -84,12 +84,6 @@ typedef unsigned long sigset_t; | |||
84 | #define SA_ONESHOT SA_RESETHAND | 84 | #define SA_ONESHOT SA_RESETHAND |
85 | #define SA_NOMASK SA_NODEFER | 85 | #define SA_NOMASK SA_NODEFER |
86 | 86 | ||
87 | /* | ||
88 | * sigaltstack controls | ||
89 | */ | ||
90 | #define SS_ONSTACK 1 | ||
91 | #define SS_DISABLE 2 | ||
92 | |||
93 | #define MINSIGSTKSZ 4096 | 87 | #define MINSIGSTKSZ 4096 |
94 | #define SIGSTKSZ 16384 | 88 | #define SIGSTKSZ 16384 |
95 | 89 | ||
diff --git a/arch/alpha/kernel/signal.c b/arch/alpha/kernel/signal.c index 336393c9c11f..02d02c047f17 100644 --- a/arch/alpha/kernel/signal.c +++ b/arch/alpha/kernel/signal.c | |||
@@ -122,12 +122,6 @@ SYSCALL_DEFINE1(sigsuspend, old_sigset_t, mask) | |||
122 | return sigsuspend(&blocked); | 122 | return sigsuspend(&blocked); |
123 | } | 123 | } |
124 | 124 | ||
125 | asmlinkage int | ||
126 | sys_sigaltstack(const stack_t __user *uss, stack_t __user *uoss) | ||
127 | { | ||
128 | return do_sigaltstack(uss, uoss, rdusp()); | ||
129 | } | ||
130 | |||
131 | /* | 125 | /* |
132 | * Do a signal return; undo the signal stack. | 126 | * Do a signal return; undo the signal stack. |
133 | */ | 127 | */ |
@@ -418,9 +412,7 @@ setup_rt_frame(int sig, struct k_sigaction *ka, siginfo_t *info, | |||
418 | err |= __put_user(0, &frame->uc.uc_flags); | 412 | err |= __put_user(0, &frame->uc.uc_flags); |
419 | err |= __put_user(0, &frame->uc.uc_link); | 413 | err |= __put_user(0, &frame->uc.uc_link); |
420 | err |= __put_user(set->sig[0], &frame->uc.uc_osf_sigmask); | 414 | err |= __put_user(set->sig[0], &frame->uc.uc_osf_sigmask); |
421 | err |= __put_user(current->sas_ss_sp, &frame->uc.uc_stack.ss_sp); | 415 | err |= __save_altstack(&frame->uc.uc_stack, oldsp); |
422 | err |= __put_user(sas_ss_flags(oldsp), &frame->uc.uc_stack.ss_flags); | ||
423 | err |= __put_user(current->sas_ss_size, &frame->uc.uc_stack.ss_size); | ||
424 | err |= setup_sigcontext(&frame->uc.uc_mcontext, regs, | 416 | err |= setup_sigcontext(&frame->uc.uc_mcontext, regs, |
425 | set->sig[0], oldsp); | 417 | set->sig[0], oldsp); |
426 | err |= __copy_to_user(&frame->uc.uc_sigmask, set, sizeof(*set)); | 418 | err |= __copy_to_user(&frame->uc.uc_sigmask, set, sizeof(*set)); |