sh: Add platform-specific constants for SH7709
[linux-2.6] / arch / mips / kernel / signal32.c
1 /*
2  * This file is subject to the terms and conditions of the GNU General Public
3  * License.  See the file "COPYING" in the main directory of this archive
4  * for more details.
5  *
6  * Copyright (C) 1991, 1992  Linus Torvalds
7  * Copyright (C) 1994 - 2000, 2006  Ralf Baechle
8  * Copyright (C) 1999, 2000 Silicon Graphics, Inc.
9  */
10 #include <linux/cache.h>
11 #include <linux/compat.h>
12 #include <linux/sched.h>
13 #include <linux/mm.h>
14 #include <linux/smp.h>
15 #include <linux/kernel.h>
16 #include <linux/signal.h>
17 #include <linux/syscalls.h>
18 #include <linux/errno.h>
19 #include <linux/wait.h>
20 #include <linux/ptrace.h>
21 #include <linux/suspend.h>
22 #include <linux/compiler.h>
23 #include <linux/uaccess.h>
24
25 #include <asm/abi.h>
26 #include <asm/asm.h>
27 #include <asm/compat-signal.h>
28 #include <linux/bitops.h>
29 #include <asm/cacheflush.h>
30 #include <asm/sim.h>
31 #include <asm/ucontext.h>
32 #include <asm/system.h>
33 #include <asm/fpu.h>
34 #include <asm/war.h>
35
36 #include "signal-common.h"
37
38 /*
39  * Including <asm/unistd.h> would give use the 64-bit syscall numbers ...
40  */
41 #define __NR_O32_sigreturn              4119
42 #define __NR_O32_rt_sigreturn           4193
43 #define __NR_O32_restart_syscall        4253
44
45 /* 32-bit compatibility types */
46
47 typedef unsigned int __sighandler32_t;
48 typedef void (*vfptr_t)(void);
49
50 struct sigaction32 {
51         unsigned int            sa_flags;
52         __sighandler32_t        sa_handler;
53         compat_sigset_t         sa_mask;
54 };
55
56 /* IRIX compatible stack_t  */
57 typedef struct sigaltstack32 {
58         s32 ss_sp;
59         compat_size_t ss_size;
60         int ss_flags;
61 } stack32_t;
62
63 struct ucontext32 {
64         u32                 uc_flags;
65         s32                 uc_link;
66         stack32_t           uc_stack;
67         struct sigcontext32 uc_mcontext;
68         compat_sigset_t     uc_sigmask;   /* mask last for extensibility */
69 };
70
71 /*
72  * Horribly complicated - with the bloody RM9000 workarounds enabled
73  * the signal trampolines is moving to the end of the structure so we can
74  * increase the alignment without breaking software compatibility.
75  */
76 #if ICACHE_REFILLS_WORKAROUND_WAR == 0
77
78 struct sigframe32 {
79         u32 sf_ass[4];          /* argument save space for o32 */
80         u32 sf_code[2];         /* signal trampoline */
81         struct sigcontext32 sf_sc;
82         compat_sigset_t sf_mask;
83 };
84
85 struct rt_sigframe32 {
86         u32 rs_ass[4];                  /* argument save space for o32 */
87         u32 rs_code[2];                 /* signal trampoline */
88         compat_siginfo_t rs_info;
89         struct ucontext32 rs_uc;
90 };
91
92 #else  /* ICACHE_REFILLS_WORKAROUND_WAR */
93
94 struct sigframe32 {
95         u32 sf_ass[4];                  /* argument save space for o32 */
96         u32 sf_pad[2];
97         struct sigcontext32 sf_sc;      /* hw context */
98         compat_sigset_t sf_mask;
99         u32 sf_code[8] ____cacheline_aligned;   /* signal trampoline */
100 };
101
102 struct rt_sigframe32 {
103         u32 rs_ass[4];                  /* argument save space for o32 */
104         u32 rs_pad[2];
105         compat_siginfo_t rs_info;
106         struct ucontext32 rs_uc;
107         u32 rs_code[8] __attribute__((aligned(32)));    /* signal trampoline */
108 };
109
110 #endif  /* !ICACHE_REFILLS_WORKAROUND_WAR */
111
112 /*
113  * sigcontext handlers
114  */
115 static int protected_save_fp_context32(struct sigcontext32 __user *sc)
116 {
117         int err;
118         while (1) {
119                 lock_fpu_owner();
120                 own_fpu_inatomic(1);
121                 err = save_fp_context32(sc); /* this might fail */
122                 unlock_fpu_owner();
123                 if (likely(!err))
124                         break;
125                 /* touch the sigcontext and try again */
126                 err = __put_user(0, &sc->sc_fpregs[0]) |
127                         __put_user(0, &sc->sc_fpregs[31]) |
128                         __put_user(0, &sc->sc_fpc_csr);
129                 if (err)
130                         break;  /* really bad sigcontext */
131         }
132         return err;
133 }
134
135 static int protected_restore_fp_context32(struct sigcontext32 __user *sc)
136 {
137         int err, tmp;
138         while (1) {
139                 lock_fpu_owner();
140                 own_fpu_inatomic(0);
141                 err = restore_fp_context32(sc); /* this might fail */
142                 unlock_fpu_owner();
143                 if (likely(!err))
144                         break;
145                 /* touch the sigcontext and try again */
146                 err = __get_user(tmp, &sc->sc_fpregs[0]) |
147                         __get_user(tmp, &sc->sc_fpregs[31]) |
148                         __get_user(tmp, &sc->sc_fpc_csr);
149                 if (err)
150                         break;  /* really bad sigcontext */
151         }
152         return err;
153 }
154
155 static int setup_sigcontext32(struct pt_regs *regs,
156                               struct sigcontext32 __user *sc)
157 {
158         int err = 0;
159         int i;
160         u32 used_math;
161
162         err |= __put_user(regs->cp0_epc, &sc->sc_pc);
163
164         err |= __put_user(0, &sc->sc_regs[0]);
165         for (i = 1; i < 32; i++)
166                 err |= __put_user(regs->regs[i], &sc->sc_regs[i]);
167
168         err |= __put_user(regs->hi, &sc->sc_mdhi);
169         err |= __put_user(regs->lo, &sc->sc_mdlo);
170         if (cpu_has_dsp) {
171                 err |= __put_user(rddsp(DSP_MASK), &sc->sc_dsp);
172                 err |= __put_user(mfhi1(), &sc->sc_hi1);
173                 err |= __put_user(mflo1(), &sc->sc_lo1);
174                 err |= __put_user(mfhi2(), &sc->sc_hi2);
175                 err |= __put_user(mflo2(), &sc->sc_lo2);
176                 err |= __put_user(mfhi3(), &sc->sc_hi3);
177                 err |= __put_user(mflo3(), &sc->sc_lo3);
178         }
179
180         used_math = !!used_math();
181         err |= __put_user(used_math, &sc->sc_used_math);
182
183         if (used_math) {
184                 /*
185                  * Save FPU state to signal context.  Signal handler
186                  * will "inherit" current FPU state.
187                  */
188                 err |= protected_save_fp_context32(sc);
189         }
190         return err;
191 }
192
193 static int
194 check_and_restore_fp_context32(struct sigcontext32 __user *sc)
195 {
196         int err, sig;
197
198         err = sig = fpcsr_pending(&sc->sc_fpc_csr);
199         if (err > 0)
200                 err = 0;
201         err |= protected_restore_fp_context32(sc);
202         return err ?: sig;
203 }
204
205 static int restore_sigcontext32(struct pt_regs *regs,
206                                 struct sigcontext32 __user *sc)
207 {
208         u32 used_math;
209         int err = 0;
210         s32 treg;
211         int i;
212
213         /* Always make any pending restarted system calls return -EINTR */
214         current_thread_info()->restart_block.fn = do_no_restart_syscall;
215
216         err |= __get_user(regs->cp0_epc, &sc->sc_pc);
217         err |= __get_user(regs->hi, &sc->sc_mdhi);
218         err |= __get_user(regs->lo, &sc->sc_mdlo);
219         if (cpu_has_dsp) {
220                 err |= __get_user(treg, &sc->sc_hi1); mthi1(treg);
221                 err |= __get_user(treg, &sc->sc_lo1); mtlo1(treg);
222                 err |= __get_user(treg, &sc->sc_hi2); mthi2(treg);
223                 err |= __get_user(treg, &sc->sc_lo2); mtlo2(treg);
224                 err |= __get_user(treg, &sc->sc_hi3); mthi3(treg);
225                 err |= __get_user(treg, &sc->sc_lo3); mtlo3(treg);
226                 err |= __get_user(treg, &sc->sc_dsp); wrdsp(treg, DSP_MASK);
227         }
228
229         for (i = 1; i < 32; i++)
230                 err |= __get_user(regs->regs[i], &sc->sc_regs[i]);
231
232         err |= __get_user(used_math, &sc->sc_used_math);
233         conditional_used_math(used_math);
234
235         if (used_math) {
236                 /* restore fpu context if we have used it before */
237                 if (!err)
238                         err = check_and_restore_fp_context32(sc);
239         } else {
240                 /* signal handler may have used FPU.  Give it up. */
241                 lose_fpu(0);
242         }
243
244         return err;
245 }
246
247 /*
248  *
249  */
250 extern void __put_sigset_unknown_nsig(void);
251 extern void __get_sigset_unknown_nsig(void);
252
253 static inline int put_sigset(const sigset_t *kbuf, compat_sigset_t __user *ubuf)
254 {
255         int err = 0;
256
257         if (!access_ok(VERIFY_WRITE, ubuf, sizeof(*ubuf)))
258                 return -EFAULT;
259
260         switch (_NSIG_WORDS) {
261         default:
262                 __put_sigset_unknown_nsig();
263         case 2:
264                 err |= __put_user(kbuf->sig[1] >> 32, &ubuf->sig[3]);
265                 err |= __put_user(kbuf->sig[1] & 0xffffffff, &ubuf->sig[2]);
266         case 1:
267                 err |= __put_user(kbuf->sig[0] >> 32, &ubuf->sig[1]);
268                 err |= __put_user(kbuf->sig[0] & 0xffffffff, &ubuf->sig[0]);
269         }
270
271         return err;
272 }
273
274 static inline int get_sigset(sigset_t *kbuf, const compat_sigset_t __user *ubuf)
275 {
276         int err = 0;
277         unsigned long sig[4];
278
279         if (!access_ok(VERIFY_READ, ubuf, sizeof(*ubuf)))
280                 return -EFAULT;
281
282         switch (_NSIG_WORDS) {
283         default:
284                 __get_sigset_unknown_nsig();
285         case 2:
286                 err |= __get_user(sig[3], &ubuf->sig[3]);
287                 err |= __get_user(sig[2], &ubuf->sig[2]);
288                 kbuf->sig[1] = sig[2] | (sig[3] << 32);
289         case 1:
290                 err |= __get_user(sig[1], &ubuf->sig[1]);
291                 err |= __get_user(sig[0], &ubuf->sig[0]);
292                 kbuf->sig[0] = sig[0] | (sig[1] << 32);
293         }
294
295         return err;
296 }
297
298 /*
299  * Atomically swap in the new signal mask, and wait for a signal.
300  */
301
302 asmlinkage int sys32_sigsuspend(nabi_no_regargs struct pt_regs regs)
303 {
304         compat_sigset_t __user *uset;
305         sigset_t newset;
306
307         uset = (compat_sigset_t __user *) regs.regs[4];
308         if (get_sigset(&newset, uset))
309                 return -EFAULT;
310         sigdelsetmask(&newset, ~_BLOCKABLE);
311
312         spin_lock_irq(&current->sighand->siglock);
313         current->saved_sigmask = current->blocked;
314         current->blocked = newset;
315         recalc_sigpending();
316         spin_unlock_irq(&current->sighand->siglock);
317
318         current->state = TASK_INTERRUPTIBLE;
319         schedule();
320         set_thread_flag(TIF_RESTORE_SIGMASK);
321         return -ERESTARTNOHAND;
322 }
323
324 asmlinkage int sys32_rt_sigsuspend(nabi_no_regargs struct pt_regs regs)
325 {
326         compat_sigset_t __user *uset;
327         sigset_t newset;
328         size_t sigsetsize;
329
330         /* XXX Don't preclude handling different sized sigset_t's.  */
331         sigsetsize = regs.regs[5];
332         if (sigsetsize != sizeof(compat_sigset_t))
333                 return -EINVAL;
334
335         uset = (compat_sigset_t __user *) regs.regs[4];
336         if (get_sigset(&newset, uset))
337                 return -EFAULT;
338         sigdelsetmask(&newset, ~_BLOCKABLE);
339
340         spin_lock_irq(&current->sighand->siglock);
341         current->saved_sigmask = current->blocked;
342         current->blocked = newset;
343         recalc_sigpending();
344         spin_unlock_irq(&current->sighand->siglock);
345
346         current->state = TASK_INTERRUPTIBLE;
347         schedule();
348         set_thread_flag(TIF_RESTORE_SIGMASK);
349         return -ERESTARTNOHAND;
350 }
351
352 asmlinkage int sys32_sigaction(int sig, const struct sigaction32 __user *act,
353                                struct sigaction32 __user *oact)
354 {
355         struct k_sigaction new_ka, old_ka;
356         int ret;
357         int err = 0;
358
359         if (act) {
360                 old_sigset_t mask;
361                 s32 handler;
362
363                 if (!access_ok(VERIFY_READ, act, sizeof(*act)))
364                         return -EFAULT;
365                 err |= __get_user(handler, &act->sa_handler);
366                 new_ka.sa.sa_handler = (void __user *)(s64)handler;
367                 err |= __get_user(new_ka.sa.sa_flags, &act->sa_flags);
368                 err |= __get_user(mask, &act->sa_mask.sig[0]);
369                 if (err)
370                         return -EFAULT;
371
372                 siginitset(&new_ka.sa.sa_mask, mask);
373         }
374
375         ret = do_sigaction(sig, act ? &new_ka : NULL, oact ? &old_ka : NULL);
376
377         if (!ret && oact) {
378                 if (!access_ok(VERIFY_WRITE, oact, sizeof(*oact)))
379                         return -EFAULT;
380                 err |= __put_user(old_ka.sa.sa_flags, &oact->sa_flags);
381                 err |= __put_user((u32)(u64)old_ka.sa.sa_handler,
382                                   &oact->sa_handler);
383                 err |= __put_user(old_ka.sa.sa_mask.sig[0], oact->sa_mask.sig);
384                 err |= __put_user(0, &oact->sa_mask.sig[1]);
385                 err |= __put_user(0, &oact->sa_mask.sig[2]);
386                 err |= __put_user(0, &oact->sa_mask.sig[3]);
387                 if (err)
388                         return -EFAULT;
389         }
390
391         return ret;
392 }
393
394 asmlinkage int sys32_sigaltstack(nabi_no_regargs struct pt_regs regs)
395 {
396         const stack32_t __user *uss = (const stack32_t __user *) regs.regs[4];
397         stack32_t __user *uoss = (stack32_t __user *) regs.regs[5];
398         unsigned long usp = regs.regs[29];
399         stack_t kss, koss;
400         int ret, err = 0;
401         mm_segment_t old_fs = get_fs();
402         s32 sp;
403
404         if (uss) {
405                 if (!access_ok(VERIFY_READ, uss, sizeof(*uss)))
406                         return -EFAULT;
407                 err |= __get_user(sp, &uss->ss_sp);
408                 kss.ss_sp = (void __user *) (long) sp;
409                 err |= __get_user(kss.ss_size, &uss->ss_size);
410                 err |= __get_user(kss.ss_flags, &uss->ss_flags);
411                 if (err)
412                         return -EFAULT;
413         }
414
415         set_fs(KERNEL_DS);
416         ret = do_sigaltstack(uss ? (stack_t __user *)&kss : NULL,
417                              uoss ? (stack_t __user *)&koss : NULL, usp);
418         set_fs(old_fs);
419
420         if (!ret && uoss) {
421                 if (!access_ok(VERIFY_WRITE, uoss, sizeof(*uoss)))
422                         return -EFAULT;
423                 sp = (int) (unsigned long) koss.ss_sp;
424                 err |= __put_user(sp, &uoss->ss_sp);
425                 err |= __put_user(koss.ss_size, &uoss->ss_size);
426                 err |= __put_user(koss.ss_flags, &uoss->ss_flags);
427                 if (err)
428                         return -EFAULT;
429         }
430         return ret;
431 }
432
433 int copy_siginfo_to_user32(compat_siginfo_t __user *to, siginfo_t *from)
434 {
435         int err;
436
437         if (!access_ok (VERIFY_WRITE, to, sizeof(compat_siginfo_t)))
438                 return -EFAULT;
439
440         /* If you change siginfo_t structure, please be sure
441            this code is fixed accordingly.
442            It should never copy any pad contained in the structure
443            to avoid security leaks, but must copy the generic
444            3 ints plus the relevant union member.
445            This routine must convert siginfo from 64bit to 32bit as well
446            at the same time.  */
447         err = __put_user(from->si_signo, &to->si_signo);
448         err |= __put_user(from->si_errno, &to->si_errno);
449         err |= __put_user((short)from->si_code, &to->si_code);
450         if (from->si_code < 0)
451                 err |= __copy_to_user(&to->_sifields._pad, &from->_sifields._pad, SI_PAD_SIZE);
452         else {
453                 switch (from->si_code >> 16) {
454                 case __SI_TIMER >> 16:
455                         err |= __put_user(from->si_tid, &to->si_tid);
456                         err |= __put_user(from->si_overrun, &to->si_overrun);
457                         err |= __put_user(from->si_int, &to->si_int);
458                         break;
459                 case __SI_CHLD >> 16:
460                         err |= __put_user(from->si_utime, &to->si_utime);
461                         err |= __put_user(from->si_stime, &to->si_stime);
462                         err |= __put_user(from->si_status, &to->si_status);
463                 default:
464                         err |= __put_user(from->si_pid, &to->si_pid);
465                         err |= __put_user(from->si_uid, &to->si_uid);
466                         break;
467                 case __SI_FAULT >> 16:
468                         err |= __put_user((unsigned long)from->si_addr, &to->si_addr);
469                         break;
470                 case __SI_POLL >> 16:
471                         err |= __put_user(from->si_band, &to->si_band);
472                         err |= __put_user(from->si_fd, &to->si_fd);
473                         break;
474                 case __SI_RT >> 16: /* This is not generated by the kernel as of now.  */
475                 case __SI_MESGQ >> 16:
476                         err |= __put_user(from->si_pid, &to->si_pid);
477                         err |= __put_user(from->si_uid, &to->si_uid);
478                         err |= __put_user(from->si_int, &to->si_int);
479                         break;
480                 }
481         }
482         return err;
483 }
484
485 int copy_siginfo_from_user32(siginfo_t *to, compat_siginfo_t __user *from)
486 {
487         memset(to, 0, sizeof *to);
488
489         if (copy_from_user(to, from, 3*sizeof(int)) ||
490             copy_from_user(to->_sifields._pad,
491                            from->_sifields._pad, SI_PAD_SIZE32))
492                 return -EFAULT;
493
494         return 0;
495 }
496
497 asmlinkage void sys32_sigreturn(nabi_no_regargs struct pt_regs regs)
498 {
499         struct sigframe32 __user *frame;
500         sigset_t blocked;
501         int sig;
502
503         frame = (struct sigframe32 __user *) regs.regs[29];
504         if (!access_ok(VERIFY_READ, frame, sizeof(*frame)))
505                 goto badframe;
506         if (__copy_conv_sigset_from_user(&blocked, &frame->sf_mask))
507                 goto badframe;
508
509         sigdelsetmask(&blocked, ~_BLOCKABLE);
510         spin_lock_irq(&current->sighand->siglock);
511         current->blocked = blocked;
512         recalc_sigpending();
513         spin_unlock_irq(&current->sighand->siglock);
514
515         sig = restore_sigcontext32(&regs, &frame->sf_sc);
516         if (sig < 0)
517                 goto badframe;
518         else if (sig)
519                 force_sig(sig, current);
520
521         /*
522          * Don't let your children do this ...
523          */
524         __asm__ __volatile__(
525                 "move\t$29, %0\n\t"
526                 "j\tsyscall_exit"
527                 :/* no outputs */
528                 :"r" (&regs));
529         /* Unreached */
530
531 badframe:
532         force_sig(SIGSEGV, current);
533 }
534
535 asmlinkage void sys32_rt_sigreturn(nabi_no_regargs struct pt_regs regs)
536 {
537         struct rt_sigframe32 __user *frame;
538         mm_segment_t old_fs;
539         sigset_t set;
540         stack_t st;
541         s32 sp;
542         int sig;
543
544         frame = (struct rt_sigframe32 __user *) regs.regs[29];
545         if (!access_ok(VERIFY_READ, frame, sizeof(*frame)))
546                 goto badframe;
547         if (__copy_conv_sigset_from_user(&set, &frame->rs_uc.uc_sigmask))
548                 goto badframe;
549
550         sigdelsetmask(&set, ~_BLOCKABLE);
551         spin_lock_irq(&current->sighand->siglock);
552         current->blocked = set;
553         recalc_sigpending();
554         spin_unlock_irq(&current->sighand->siglock);
555
556         sig = restore_sigcontext32(&regs, &frame->rs_uc.uc_mcontext);
557         if (sig < 0)
558                 goto badframe;
559         else if (sig)
560                 force_sig(sig, current);
561
562         /* The ucontext contains a stack32_t, so we must convert!  */
563         if (__get_user(sp, &frame->rs_uc.uc_stack.ss_sp))
564                 goto badframe;
565         st.ss_sp = (void __user *)(long) sp;
566         if (__get_user(st.ss_size, &frame->rs_uc.uc_stack.ss_size))
567                 goto badframe;
568         if (__get_user(st.ss_flags, &frame->rs_uc.uc_stack.ss_flags))
569                 goto badframe;
570
571         /* It is more difficult to avoid calling this function than to
572            call it and ignore errors.  */
573         old_fs = get_fs();
574         set_fs(KERNEL_DS);
575         do_sigaltstack((stack_t __user *)&st, NULL, regs.regs[29]);
576         set_fs(old_fs);
577
578         /*
579          * Don't let your children do this ...
580          */
581         __asm__ __volatile__(
582                 "move\t$29, %0\n\t"
583                 "j\tsyscall_exit"
584                 :/* no outputs */
585                 :"r" (&regs));
586         /* Unreached */
587
588 badframe:
589         force_sig(SIGSEGV, current);
590 }
591
592 static int setup_frame_32(struct k_sigaction * ka, struct pt_regs *regs,
593         int signr, sigset_t *set)
594 {
595         struct sigframe32 __user *frame;
596         int err = 0;
597
598         frame = get_sigframe(ka, regs, sizeof(*frame));
599         if (!access_ok(VERIFY_WRITE, frame, sizeof (*frame)))
600                 goto give_sigsegv;
601
602         err |= install_sigtramp(frame->sf_code, __NR_O32_sigreturn);
603
604         err |= setup_sigcontext32(regs, &frame->sf_sc);
605         err |= __copy_conv_sigset_to_user(&frame->sf_mask, set);
606
607         if (err)
608                 goto give_sigsegv;
609
610         /*
611          * Arguments to signal handler:
612          *
613          *   a0 = signal number
614          *   a1 = 0 (should be cause)
615          *   a2 = pointer to struct sigcontext
616          *
617          * $25 and c0_epc point to the signal handler, $29 points to the
618          * struct sigframe.
619          */
620         regs->regs[ 4] = signr;
621         regs->regs[ 5] = 0;
622         regs->regs[ 6] = (unsigned long) &frame->sf_sc;
623         regs->regs[29] = (unsigned long) frame;
624         regs->regs[31] = (unsigned long) frame->sf_code;
625         regs->cp0_epc = regs->regs[25] = (unsigned long) ka->sa.sa_handler;
626
627         DEBUGP("SIG deliver (%s:%d): sp=0x%p pc=0x%lx ra=0x%lx\n",
628                current->comm, current->pid,
629                frame, regs->cp0_epc, regs->regs[31]);
630
631         return 0;
632
633 give_sigsegv:
634         force_sigsegv(signr, current);
635         return -EFAULT;
636 }
637
638 static int setup_rt_frame_32(struct k_sigaction * ka, struct pt_regs *regs,
639         int signr, sigset_t *set, siginfo_t *info)
640 {
641         struct rt_sigframe32 __user *frame;
642         int err = 0;
643         s32 sp;
644
645         frame = get_sigframe(ka, regs, sizeof(*frame));
646         if (!access_ok(VERIFY_WRITE, frame, sizeof (*frame)))
647                 goto give_sigsegv;
648
649         err |= install_sigtramp(frame->rs_code, __NR_O32_rt_sigreturn);
650
651         /* Convert (siginfo_t -> compat_siginfo_t) and copy to user. */
652         err |= copy_siginfo_to_user32(&frame->rs_info, info);
653
654         /* Create the ucontext.  */
655         err |= __put_user(0, &frame->rs_uc.uc_flags);
656         err |= __put_user(0, &frame->rs_uc.uc_link);
657         sp = (int) (long) current->sas_ss_sp;
658         err |= __put_user(sp,
659                           &frame->rs_uc.uc_stack.ss_sp);
660         err |= __put_user(sas_ss_flags(regs->regs[29]),
661                           &frame->rs_uc.uc_stack.ss_flags);
662         err |= __put_user(current->sas_ss_size,
663                           &frame->rs_uc.uc_stack.ss_size);
664         err |= setup_sigcontext32(regs, &frame->rs_uc.uc_mcontext);
665         err |= __copy_conv_sigset_to_user(&frame->rs_uc.uc_sigmask, set);
666
667         if (err)
668                 goto give_sigsegv;
669
670         /*
671          * Arguments to signal handler:
672          *
673          *   a0 = signal number
674          *   a1 = 0 (should be cause)
675          *   a2 = pointer to ucontext
676          *
677          * $25 and c0_epc point to the signal handler, $29 points to
678          * the struct rt_sigframe32.
679          */
680         regs->regs[ 4] = signr;
681         regs->regs[ 5] = (unsigned long) &frame->rs_info;
682         regs->regs[ 6] = (unsigned long) &frame->rs_uc;
683         regs->regs[29] = (unsigned long) frame;
684         regs->regs[31] = (unsigned long) frame->rs_code;
685         regs->cp0_epc = regs->regs[25] = (unsigned long) ka->sa.sa_handler;
686
687         DEBUGP("SIG deliver (%s:%d): sp=0x%p pc=0x%lx ra=0x%lx\n",
688                current->comm, current->pid,
689                frame, regs->cp0_epc, regs->regs[31]);
690
691         return 0;
692
693 give_sigsegv:
694         force_sigsegv(signr, current);
695         return -EFAULT;
696 }
697
698 /*
699  * o32 compatibility on 64-bit kernels, without DSP ASE
700  */
701 struct mips_abi mips_abi_32 = {
702         .setup_frame    = setup_frame_32,
703         .setup_rt_frame = setup_rt_frame_32,
704         .restart        = __NR_O32_restart_syscall
705 };
706
707 asmlinkage int sys32_rt_sigaction(int sig, const struct sigaction32 __user *act,
708                                   struct sigaction32 __user *oact,
709                                   unsigned int sigsetsize)
710 {
711         struct k_sigaction new_sa, old_sa;
712         int ret = -EINVAL;
713
714         /* XXX: Don't preclude handling different sized sigset_t's.  */
715         if (sigsetsize != sizeof(sigset_t))
716                 goto out;
717
718         if (act) {
719                 s32 handler;
720                 int err = 0;
721
722                 if (!access_ok(VERIFY_READ, act, sizeof(*act)))
723                         return -EFAULT;
724                 err |= __get_user(handler, &act->sa_handler);
725                 new_sa.sa.sa_handler = (void __user *)(s64)handler;
726                 err |= __get_user(new_sa.sa.sa_flags, &act->sa_flags);
727                 err |= get_sigset(&new_sa.sa.sa_mask, &act->sa_mask);
728                 if (err)
729                         return -EFAULT;
730         }
731
732         ret = do_sigaction(sig, act ? &new_sa : NULL, oact ? &old_sa : NULL);
733
734         if (!ret && oact) {
735                 int err = 0;
736
737                 if (!access_ok(VERIFY_WRITE, oact, sizeof(*oact)))
738                         return -EFAULT;
739
740                 err |= __put_user((u32)(u64)old_sa.sa.sa_handler,
741                                    &oact->sa_handler);
742                 err |= __put_user(old_sa.sa.sa_flags, &oact->sa_flags);
743                 err |= put_sigset(&old_sa.sa.sa_mask, &oact->sa_mask);
744                 if (err)
745                         return -EFAULT;
746         }
747 out:
748         return ret;
749 }
750
751 asmlinkage int sys32_rt_sigprocmask(int how, compat_sigset_t __user *set,
752         compat_sigset_t __user *oset, unsigned int sigsetsize)
753 {
754         sigset_t old_set, new_set;
755         int ret;
756         mm_segment_t old_fs = get_fs();
757
758         if (set && get_sigset(&new_set, set))
759                 return -EFAULT;
760
761         set_fs(KERNEL_DS);
762         ret = sys_rt_sigprocmask(how, set ? (sigset_t __user *)&new_set : NULL,
763                                  oset ? (sigset_t __user *)&old_set : NULL,
764                                  sigsetsize);
765         set_fs(old_fs);
766
767         if (!ret && oset && put_sigset(&old_set, oset))
768                 return -EFAULT;
769
770         return ret;
771 }
772
773 asmlinkage int sys32_rt_sigpending(compat_sigset_t __user *uset,
774         unsigned int sigsetsize)
775 {
776         int ret;
777         sigset_t set;
778         mm_segment_t old_fs = get_fs();
779
780         set_fs(KERNEL_DS);
781         ret = sys_rt_sigpending((sigset_t __user *)&set, sigsetsize);
782         set_fs(old_fs);
783
784         if (!ret && put_sigset(&set, uset))
785                 return -EFAULT;
786
787         return ret;
788 }
789
790 asmlinkage int sys32_rt_sigqueueinfo(int pid, int sig, compat_siginfo_t __user *uinfo)
791 {
792         siginfo_t info;
793         int ret;
794         mm_segment_t old_fs = get_fs();
795
796         if (copy_from_user(&info, uinfo, 3*sizeof(int)) ||
797             copy_from_user(info._sifields._pad, uinfo->_sifields._pad, SI_PAD_SIZE))
798                 return -EFAULT;
799         set_fs(KERNEL_DS);
800         ret = sys_rt_sigqueueinfo(pid, sig, (siginfo_t __user *)&info);
801         set_fs(old_fs);
802         return ret;
803 }
804
805 asmlinkage long
806 sys32_waitid(int which, compat_pid_t pid,
807              compat_siginfo_t __user *uinfo, int options,
808              struct compat_rusage __user *uru)
809 {
810         siginfo_t info;
811         struct rusage ru;
812         long ret;
813         mm_segment_t old_fs = get_fs();
814
815         info.si_signo = 0;
816         set_fs(KERNEL_DS);
817         ret = sys_waitid(which, pid, (siginfo_t __user *) &info, options,
818                          uru ? (struct rusage __user *) &ru : NULL);
819         set_fs(old_fs);
820
821         if (ret < 0 || info.si_signo == 0)
822                 return ret;
823
824         if (uru && (ret = put_compat_rusage(&ru, uru)))
825                 return ret;
826
827         BUG_ON(info.si_code & __SI_MASK);
828         info.si_code |= __SI_CHLD;
829         return copy_siginfo_to_user32(uinfo, &info);
830 }