parisc: switch to generic compat rt_sigaction()
authorAl Viro <viro@zeniv.linux.org.uk>
Tue, 25 Dec 2012 23:53:43 +0000 (18:53 -0500)
committerAl Viro <viro@zeniv.linux.org.uk>
Sun, 3 Feb 2013 23:16:07 +0000 (18:16 -0500)
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
arch/parisc/Kconfig
arch/parisc/kernel/signal32.c
arch/parisc/kernel/signal32.h
arch/parisc/kernel/sys32.h
arch/parisc/kernel/syscall_table.S

index 798038c8aaf92efe16a8ab850461dde18fb2d550..2bd407ffaebfa667c58b1269c1ab0ff21163da82 100644 (file)
@@ -24,6 +24,7 @@ config PARISC
        select MODULES_USE_ELF_RELA
        select CLONE_BACKWARDS
        select GENERIC_SIGALTSTACK
+       select GENERIC_COMPAT_RT_SIGACTION
        select GENERIC_COMPAT_RT_SIGQUEUEINFO
        select GENERIC_COMPAT_RT_SIGPROCMASK
        select GENERIC_COMPAT_RT_SIGPENDING
index 7769f9333e0c455248ac923408c76993925dbc93..33eca1b04926ad09184d703e9c2fcb55cd127069 100644 (file)
@@ -60,34 +60,6 @@ sigset_64to32(compat_sigset_t *s32, sigset_t *s64)
        s32->sig[1] = (s64->sig[0] >> 32) & 0xffffffffUL;
 }
 
-long
-sys32_rt_sigaction(int sig, const struct sigaction32 __user *act, struct sigaction32 __user *oact,
-                 size_t sigsetsize)
-{
-       struct k_sigaction32 new_sa32, old_sa32;
-       struct k_sigaction new_sa, old_sa;
-       int ret = -EINVAL;
-
-       if (act) {
-               if (copy_from_user(&new_sa32.sa, act, sizeof new_sa32.sa))
-                       return -EFAULT;
-               new_sa.sa.sa_handler = (__sighandler_t)(unsigned long)new_sa32.sa.sa_handler;
-               new_sa.sa.sa_flags = new_sa32.sa.sa_flags;
-               sigset_32to64(&new_sa.sa.sa_mask, &new_sa32.sa.sa_mask);
-       }
-
-       ret = do_sigaction(sig, act ? &new_sa : NULL, oact ? &old_sa : NULL);
-
-       if (!ret && oact) {
-               sigset_64to32(&old_sa32.sa.sa_mask, &old_sa.sa.sa_mask);
-               old_sa32.sa.sa_flags = old_sa.sa.sa_flags;
-               old_sa32.sa.sa_handler = (__sighandler_t32)(unsigned long)old_sa.sa.sa_handler;
-               if (copy_to_user(oact, &old_sa32.sa, sizeof old_sa32.sa))
-                       return -EFAULT;
-       }
-       return ret;
-}
-
 long
 restore_sigcontext32(struct compat_sigcontext __user *sc, struct compat_regfile __user * rf,
                struct pt_regs *regs)
index 640dc3ec8f5dd7377f0cee342db35b300624280d..72ab41a51f3297de6465b18bbaeac05a8d532303 100644 (file)
 
 #include <linux/compat.h>
 
-typedef compat_uptr_t compat_sighandler_t;
-
-/* Most things should be clean enough to redefine this at will, if care
-   is taken to make libc match.  */
-
-struct compat_sigaction {
-        compat_sighandler_t sa_handler;
-        compat_uint_t sa_flags;
-        compat_sigset_t sa_mask;               /* mask last for extensibility */
-};
-
 /* 32-bit ucontext as seen from an 64-bit kernel */
 struct compat_ucontext {
         compat_uint_t uc_flags;
@@ -45,10 +34,6 @@ struct compat_ucontext {
 
 /* ELF32 signal handling */
 
-struct k_sigaction32 {
-       struct compat_sigaction sa;
-};
-
 int copy_siginfo_to_user32 (compat_siginfo_t __user *to, siginfo_t *from);
 int copy_siginfo_from_user32 (siginfo_t *to, compat_siginfo_t __user *from);
 
index 06c2090cfaba340fa5f99e1d7e2fc10188a7ff3b..60dd470f39f88d505c694119c4a96a87812f8b17 100644 (file)
     set_fs (old_fs); \
 }
 
-#ifdef CONFIG_COMPAT
-
-typedef __u32 __sighandler_t32;
-
-struct sigaction32 {
-       __sighandler_t32 sa_handler;
-       unsigned int sa_flags;
-       compat_sigset_t sa_mask;                /* mask last for extensibility */
-};
-
-#endif
-
 #endif
index 883171edfc6e49020c0dabe45611a15818763adb..dd52c23c0dcd4bfc3661b3d4807cc121b02c602b 100644 (file)
        ENTRY_SAME(prctl)
        /* signals need a careful review */
        ENTRY_SAME(rt_sigreturn_wrapper)
-       ENTRY_DIFF(rt_sigaction)
+       ENTRY_COMP(rt_sigaction)
        ENTRY_COMP(rt_sigprocmask)      /* 175 */
        ENTRY_COMP(rt_sigpending)
        ENTRY_COMP(rt_sigtimedwait)