signal32.c 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673
  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. #include <asm/abi.h>
  25. #include <asm/asm.h>
  26. #include <asm/compat-signal.h>
  27. #include <linux/bitops.h>
  28. #include <asm/cacheflush.h>
  29. #include <asm/sim.h>
  30. #include <asm/ucontext.h>
  31. #include <asm/fpu.h>
  32. #include <asm/msa.h>
  33. #include <asm/war.h>
  34. #include <asm/vdso.h>
  35. #include <asm/dsp.h>
  36. #include "signal-common.h"
  37. static int (*save_fp_context32)(struct sigcontext32 __user *sc);
  38. static int (*restore_fp_context32)(struct sigcontext32 __user *sc);
  39. extern asmlinkage int _save_fp_context32(struct sigcontext32 __user *sc);
  40. extern asmlinkage int _restore_fp_context32(struct sigcontext32 __user *sc);
  41. extern asmlinkage int _save_msa_context32(struct sigcontext32 __user *sc);
  42. extern asmlinkage int _restore_msa_context32(struct sigcontext32 __user *sc);
  43. /*
  44. * Including <asm/unistd.h> would give use the 64-bit syscall numbers ...
  45. */
  46. #define __NR_O32_restart_syscall 4253
  47. /* 32-bit compatibility types */
  48. typedef unsigned int __sighandler32_t;
  49. typedef void (*vfptr_t)(void);
  50. struct ucontext32 {
  51. u32 uc_flags;
  52. s32 uc_link;
  53. compat_stack_t uc_stack;
  54. struct sigcontext32 uc_mcontext;
  55. compat_sigset_t uc_sigmask; /* mask last for extensibility */
  56. };
  57. struct sigframe32 {
  58. u32 sf_ass[4]; /* argument save space for o32 */
  59. u32 sf_pad[2]; /* Was: signal trampoline */
  60. struct sigcontext32 sf_sc;
  61. compat_sigset_t sf_mask;
  62. };
  63. struct rt_sigframe32 {
  64. u32 rs_ass[4]; /* argument save space for o32 */
  65. u32 rs_pad[2]; /* Was: signal trampoline */
  66. compat_siginfo_t rs_info;
  67. struct ucontext32 rs_uc;
  68. };
  69. /*
  70. * Thread saved context copy to/from a signal context presumed to be on the
  71. * user stack, and therefore accessed with appropriate macros from uaccess.h.
  72. */
  73. static int copy_fp_to_sigcontext32(struct sigcontext32 __user *sc)
  74. {
  75. int i;
  76. int err = 0;
  77. int inc = test_thread_flag(TIF_32BIT_FPREGS) ? 2 : 1;
  78. for (i = 0; i < NUM_FPU_REGS; i += inc) {
  79. err |=
  80. __put_user(get_fpr64(&current->thread.fpu.fpr[i], 0),
  81. &sc->sc_fpregs[i]);
  82. }
  83. err |= __put_user(current->thread.fpu.fcr31, &sc->sc_fpc_csr);
  84. return err;
  85. }
  86. static int copy_fp_from_sigcontext32(struct sigcontext32 __user *sc)
  87. {
  88. int i;
  89. int err = 0;
  90. int inc = test_thread_flag(TIF_32BIT_FPREGS) ? 2 : 1;
  91. u64 fpr_val;
  92. for (i = 0; i < NUM_FPU_REGS; i += inc) {
  93. err |= __get_user(fpr_val, &sc->sc_fpregs[i]);
  94. set_fpr64(&current->thread.fpu.fpr[i], 0, fpr_val);
  95. }
  96. err |= __get_user(current->thread.fpu.fcr31, &sc->sc_fpc_csr);
  97. return err;
  98. }
  99. /*
  100. * These functions will save only the upper 64 bits of the vector registers,
  101. * since the lower 64 bits have already been saved as the scalar FP context.
  102. */
  103. static int copy_msa_to_sigcontext32(struct sigcontext32 __user *sc)
  104. {
  105. int i;
  106. int err = 0;
  107. for (i = 0; i < NUM_FPU_REGS; i++) {
  108. err |=
  109. __put_user(get_fpr64(&current->thread.fpu.fpr[i], 1),
  110. &sc->sc_msaregs[i]);
  111. }
  112. err |= __put_user(current->thread.fpu.msacsr, &sc->sc_msa_csr);
  113. return err;
  114. }
  115. static int copy_msa_from_sigcontext32(struct sigcontext32 __user *sc)
  116. {
  117. int i;
  118. int err = 0;
  119. u64 val;
  120. for (i = 0; i < NUM_FPU_REGS; i++) {
  121. err |= __get_user(val, &sc->sc_msaregs[i]);
  122. set_fpr64(&current->thread.fpu.fpr[i], 1, val);
  123. }
  124. err |= __get_user(current->thread.fpu.msacsr, &sc->sc_msa_csr);
  125. return err;
  126. }
  127. /*
  128. * sigcontext handlers
  129. */
  130. static int protected_save_fp_context32(struct sigcontext32 __user *sc,
  131. unsigned used_math)
  132. {
  133. int err;
  134. bool save_msa = cpu_has_msa && (used_math & USEDMATH_MSA);
  135. while (1) {
  136. lock_fpu_owner();
  137. if (is_fpu_owner()) {
  138. err = save_fp_context32(sc);
  139. if (save_msa && !err)
  140. err = _save_msa_context32(sc);
  141. unlock_fpu_owner();
  142. } else {
  143. unlock_fpu_owner();
  144. err = copy_fp_to_sigcontext32(sc);
  145. if (save_msa && !err)
  146. err = copy_msa_to_sigcontext32(sc);
  147. }
  148. if (likely(!err))
  149. break;
  150. /* touch the sigcontext and try again */
  151. err = __put_user(0, &sc->sc_fpregs[0]) |
  152. __put_user(0, &sc->sc_fpregs[31]) |
  153. __put_user(0, &sc->sc_fpc_csr);
  154. if (err)
  155. break; /* really bad sigcontext */
  156. }
  157. return err;
  158. }
  159. static int protected_restore_fp_context32(struct sigcontext32 __user *sc,
  160. unsigned used_math)
  161. {
  162. int err, tmp __maybe_unused;
  163. bool restore_msa = cpu_has_msa && (used_math & USEDMATH_MSA);
  164. while (1) {
  165. lock_fpu_owner();
  166. if (is_fpu_owner()) {
  167. err = restore_fp_context32(sc);
  168. if (restore_msa && !err) {
  169. enable_msa();
  170. err = _restore_msa_context32(sc);
  171. } else {
  172. /* signal handler may have used MSA */
  173. disable_msa();
  174. }
  175. unlock_fpu_owner();
  176. } else {
  177. unlock_fpu_owner();
  178. err = copy_fp_from_sigcontext32(sc);
  179. if (restore_msa && !err)
  180. err = copy_msa_from_sigcontext32(sc);
  181. }
  182. if (likely(!err))
  183. break;
  184. /* touch the sigcontext and try again */
  185. err = __get_user(tmp, &sc->sc_fpregs[0]) |
  186. __get_user(tmp, &sc->sc_fpregs[31]) |
  187. __get_user(tmp, &sc->sc_fpc_csr);
  188. if (err)
  189. break; /* really bad sigcontext */
  190. }
  191. return err;
  192. }
  193. static int setup_sigcontext32(struct pt_regs *regs,
  194. struct sigcontext32 __user *sc)
  195. {
  196. int err = 0;
  197. int i;
  198. u32 used_math;
  199. err |= __put_user(regs->cp0_epc, &sc->sc_pc);
  200. err |= __put_user(0, &sc->sc_regs[0]);
  201. for (i = 1; i < 32; i++)
  202. err |= __put_user(regs->regs[i], &sc->sc_regs[i]);
  203. err |= __put_user(regs->hi, &sc->sc_mdhi);
  204. err |= __put_user(regs->lo, &sc->sc_mdlo);
  205. if (cpu_has_dsp) {
  206. err |= __put_user(rddsp(DSP_MASK), &sc->sc_dsp);
  207. err |= __put_user(mfhi1(), &sc->sc_hi1);
  208. err |= __put_user(mflo1(), &sc->sc_lo1);
  209. err |= __put_user(mfhi2(), &sc->sc_hi2);
  210. err |= __put_user(mflo2(), &sc->sc_lo2);
  211. err |= __put_user(mfhi3(), &sc->sc_hi3);
  212. err |= __put_user(mflo3(), &sc->sc_lo3);
  213. }
  214. used_math = used_math() ? USEDMATH_FP : 0;
  215. used_math |= thread_msa_context_live() ? USEDMATH_MSA : 0;
  216. err |= __put_user(used_math, &sc->sc_used_math);
  217. if (used_math) {
  218. /*
  219. * Save FPU state to signal context. Signal handler
  220. * will "inherit" current FPU state.
  221. */
  222. err |= protected_save_fp_context32(sc, used_math);
  223. }
  224. return err;
  225. }
  226. static int
  227. check_and_restore_fp_context32(struct sigcontext32 __user *sc,
  228. unsigned used_math)
  229. {
  230. int err, sig;
  231. err = sig = fpcsr_pending(&sc->sc_fpc_csr);
  232. if (err > 0)
  233. err = 0;
  234. err |= protected_restore_fp_context32(sc, used_math);
  235. return err ?: sig;
  236. }
  237. static int restore_sigcontext32(struct pt_regs *regs,
  238. struct sigcontext32 __user *sc)
  239. {
  240. u32 used_math;
  241. int err = 0;
  242. s32 treg;
  243. int i;
  244. /* Always make any pending restarted system calls return -EINTR */
  245. current_thread_info()->restart_block.fn = do_no_restart_syscall;
  246. err |= __get_user(regs->cp0_epc, &sc->sc_pc);
  247. err |= __get_user(regs->hi, &sc->sc_mdhi);
  248. err |= __get_user(regs->lo, &sc->sc_mdlo);
  249. if (cpu_has_dsp) {
  250. err |= __get_user(treg, &sc->sc_hi1); mthi1(treg);
  251. err |= __get_user(treg, &sc->sc_lo1); mtlo1(treg);
  252. err |= __get_user(treg, &sc->sc_hi2); mthi2(treg);
  253. err |= __get_user(treg, &sc->sc_lo2); mtlo2(treg);
  254. err |= __get_user(treg, &sc->sc_hi3); mthi3(treg);
  255. err |= __get_user(treg, &sc->sc_lo3); mtlo3(treg);
  256. err |= __get_user(treg, &sc->sc_dsp); wrdsp(treg, DSP_MASK);
  257. }
  258. for (i = 1; i < 32; i++)
  259. err |= __get_user(regs->regs[i], &sc->sc_regs[i]);
  260. err |= __get_user(used_math, &sc->sc_used_math);
  261. conditional_used_math(used_math);
  262. if (used_math) {
  263. /* restore fpu context if we have used it before */
  264. if (!err)
  265. err = check_and_restore_fp_context32(sc, used_math);
  266. } else {
  267. /* signal handler may have used FPU or MSA. Disable them. */
  268. disable_msa();
  269. lose_fpu(0);
  270. }
  271. return err;
  272. }
  273. /*
  274. *
  275. */
  276. extern void __put_sigset_unknown_nsig(void);
  277. extern void __get_sigset_unknown_nsig(void);
  278. static inline int put_sigset(const sigset_t *kbuf, compat_sigset_t __user *ubuf)
  279. {
  280. int err = 0;
  281. if (!access_ok(VERIFY_WRITE, ubuf, sizeof(*ubuf)))
  282. return -EFAULT;
  283. switch (_NSIG_WORDS) {
  284. default:
  285. __put_sigset_unknown_nsig();
  286. case 2:
  287. err |= __put_user(kbuf->sig[1] >> 32, &ubuf->sig[3]);
  288. err |= __put_user(kbuf->sig[1] & 0xffffffff, &ubuf->sig[2]);
  289. case 1:
  290. err |= __put_user(kbuf->sig[0] >> 32, &ubuf->sig[1]);
  291. err |= __put_user(kbuf->sig[0] & 0xffffffff, &ubuf->sig[0]);
  292. }
  293. return err;
  294. }
  295. static inline int get_sigset(sigset_t *kbuf, const compat_sigset_t __user *ubuf)
  296. {
  297. int err = 0;
  298. unsigned long sig[4];
  299. if (!access_ok(VERIFY_READ, ubuf, sizeof(*ubuf)))
  300. return -EFAULT;
  301. switch (_NSIG_WORDS) {
  302. default:
  303. __get_sigset_unknown_nsig();
  304. case 2:
  305. err |= __get_user(sig[3], &ubuf->sig[3]);
  306. err |= __get_user(sig[2], &ubuf->sig[2]);
  307. kbuf->sig[1] = sig[2] | (sig[3] << 32);
  308. case 1:
  309. err |= __get_user(sig[1], &ubuf->sig[1]);
  310. err |= __get_user(sig[0], &ubuf->sig[0]);
  311. kbuf->sig[0] = sig[0] | (sig[1] << 32);
  312. }
  313. return err;
  314. }
  315. /*
  316. * Atomically swap in the new signal mask, and wait for a signal.
  317. */
  318. asmlinkage int sys32_sigsuspend(compat_sigset_t __user *uset)
  319. {
  320. return compat_sys_rt_sigsuspend(uset, sizeof(compat_sigset_t));
  321. }
  322. SYSCALL_DEFINE3(32_sigaction, long, sig, const struct compat_sigaction __user *, act,
  323. struct compat_sigaction __user *, oact)
  324. {
  325. struct k_sigaction new_ka, old_ka;
  326. int ret;
  327. int err = 0;
  328. if (act) {
  329. old_sigset_t mask;
  330. s32 handler;
  331. if (!access_ok(VERIFY_READ, act, sizeof(*act)))
  332. return -EFAULT;
  333. err |= __get_user(handler, &act->sa_handler);
  334. new_ka.sa.sa_handler = (void __user *)(s64)handler;
  335. err |= __get_user(new_ka.sa.sa_flags, &act->sa_flags);
  336. err |= __get_user(mask, &act->sa_mask.sig[0]);
  337. if (err)
  338. return -EFAULT;
  339. siginitset(&new_ka.sa.sa_mask, mask);
  340. }
  341. ret = do_sigaction(sig, act ? &new_ka : NULL, oact ? &old_ka : NULL);
  342. if (!ret && oact) {
  343. if (!access_ok(VERIFY_WRITE, oact, sizeof(*oact)))
  344. return -EFAULT;
  345. err |= __put_user(old_ka.sa.sa_flags, &oact->sa_flags);
  346. err |= __put_user((u32)(u64)old_ka.sa.sa_handler,
  347. &oact->sa_handler);
  348. err |= __put_user(old_ka.sa.sa_mask.sig[0], oact->sa_mask.sig);
  349. err |= __put_user(0, &oact->sa_mask.sig[1]);
  350. err |= __put_user(0, &oact->sa_mask.sig[2]);
  351. err |= __put_user(0, &oact->sa_mask.sig[3]);
  352. if (err)
  353. return -EFAULT;
  354. }
  355. return ret;
  356. }
  357. int copy_siginfo_to_user32(compat_siginfo_t __user *to, const siginfo_t *from)
  358. {
  359. int err;
  360. if (!access_ok (VERIFY_WRITE, to, sizeof(compat_siginfo_t)))
  361. return -EFAULT;
  362. /* If you change siginfo_t structure, please be sure
  363. this code is fixed accordingly.
  364. It should never copy any pad contained in the structure
  365. to avoid security leaks, but must copy the generic
  366. 3 ints plus the relevant union member.
  367. This routine must convert siginfo from 64bit to 32bit as well
  368. at the same time. */
  369. err = __put_user(from->si_signo, &to->si_signo);
  370. err |= __put_user(from->si_errno, &to->si_errno);
  371. err |= __put_user((short)from->si_code, &to->si_code);
  372. if (from->si_code < 0)
  373. err |= __copy_to_user(&to->_sifields._pad, &from->_sifields._pad, SI_PAD_SIZE);
  374. else {
  375. switch (from->si_code >> 16) {
  376. case __SI_TIMER >> 16:
  377. err |= __put_user(from->si_tid, &to->si_tid);
  378. err |= __put_user(from->si_overrun, &to->si_overrun);
  379. err |= __put_user(from->si_int, &to->si_int);
  380. break;
  381. case __SI_CHLD >> 16:
  382. err |= __put_user(from->si_utime, &to->si_utime);
  383. err |= __put_user(from->si_stime, &to->si_stime);
  384. err |= __put_user(from->si_status, &to->si_status);
  385. default:
  386. err |= __put_user(from->si_pid, &to->si_pid);
  387. err |= __put_user(from->si_uid, &to->si_uid);
  388. break;
  389. case __SI_FAULT >> 16:
  390. err |= __put_user((unsigned long)from->si_addr, &to->si_addr);
  391. break;
  392. case __SI_POLL >> 16:
  393. err |= __put_user(from->si_band, &to->si_band);
  394. err |= __put_user(from->si_fd, &to->si_fd);
  395. break;
  396. case __SI_RT >> 16: /* This is not generated by the kernel as of now. */
  397. case __SI_MESGQ >> 16:
  398. err |= __put_user(from->si_pid, &to->si_pid);
  399. err |= __put_user(from->si_uid, &to->si_uid);
  400. err |= __put_user(from->si_int, &to->si_int);
  401. break;
  402. }
  403. }
  404. return err;
  405. }
  406. int copy_siginfo_from_user32(siginfo_t *to, compat_siginfo_t __user *from)
  407. {
  408. memset(to, 0, sizeof *to);
  409. if (copy_from_user(to, from, 3*sizeof(int)) ||
  410. copy_from_user(to->_sifields._pad,
  411. from->_sifields._pad, SI_PAD_SIZE32))
  412. return -EFAULT;
  413. return 0;
  414. }
  415. asmlinkage void sys32_sigreturn(nabi_no_regargs struct pt_regs regs)
  416. {
  417. struct sigframe32 __user *frame;
  418. sigset_t blocked;
  419. int sig;
  420. frame = (struct sigframe32 __user *) regs.regs[29];
  421. if (!access_ok(VERIFY_READ, frame, sizeof(*frame)))
  422. goto badframe;
  423. if (__copy_conv_sigset_from_user(&blocked, &frame->sf_mask))
  424. goto badframe;
  425. set_current_blocked(&blocked);
  426. sig = restore_sigcontext32(&regs, &frame->sf_sc);
  427. if (sig < 0)
  428. goto badframe;
  429. else if (sig)
  430. force_sig(sig, current);
  431. /*
  432. * Don't let your children do this ...
  433. */
  434. __asm__ __volatile__(
  435. "move\t$29, %0\n\t"
  436. "j\tsyscall_exit"
  437. :/* no outputs */
  438. :"r" (&regs));
  439. /* Unreached */
  440. badframe:
  441. force_sig(SIGSEGV, current);
  442. }
  443. asmlinkage void sys32_rt_sigreturn(nabi_no_regargs struct pt_regs regs)
  444. {
  445. struct rt_sigframe32 __user *frame;
  446. sigset_t set;
  447. int sig;
  448. frame = (struct rt_sigframe32 __user *) regs.regs[29];
  449. if (!access_ok(VERIFY_READ, frame, sizeof(*frame)))
  450. goto badframe;
  451. if (__copy_conv_sigset_from_user(&set, &frame->rs_uc.uc_sigmask))
  452. goto badframe;
  453. set_current_blocked(&set);
  454. sig = restore_sigcontext32(&regs, &frame->rs_uc.uc_mcontext);
  455. if (sig < 0)
  456. goto badframe;
  457. else if (sig)
  458. force_sig(sig, current);
  459. if (compat_restore_altstack(&frame->rs_uc.uc_stack))
  460. goto badframe;
  461. /*
  462. * Don't let your children do this ...
  463. */
  464. __asm__ __volatile__(
  465. "move\t$29, %0\n\t"
  466. "j\tsyscall_exit"
  467. :/* no outputs */
  468. :"r" (&regs));
  469. /* Unreached */
  470. badframe:
  471. force_sig(SIGSEGV, current);
  472. }
  473. static int setup_frame_32(void *sig_return, struct k_sigaction *ka,
  474. struct pt_regs *regs, int signr, sigset_t *set)
  475. {
  476. struct sigframe32 __user *frame;
  477. int err = 0;
  478. frame = get_sigframe(ka, regs, sizeof(*frame));
  479. if (!access_ok(VERIFY_WRITE, frame, sizeof (*frame)))
  480. goto give_sigsegv;
  481. err |= setup_sigcontext32(regs, &frame->sf_sc);
  482. err |= __copy_conv_sigset_to_user(&frame->sf_mask, set);
  483. if (err)
  484. goto give_sigsegv;
  485. /*
  486. * Arguments to signal handler:
  487. *
  488. * a0 = signal number
  489. * a1 = 0 (should be cause)
  490. * a2 = pointer to struct sigcontext
  491. *
  492. * $25 and c0_epc point to the signal handler, $29 points to the
  493. * struct sigframe.
  494. */
  495. regs->regs[ 4] = signr;
  496. regs->regs[ 5] = 0;
  497. regs->regs[ 6] = (unsigned long) &frame->sf_sc;
  498. regs->regs[29] = (unsigned long) frame;
  499. regs->regs[31] = (unsigned long) sig_return;
  500. regs->cp0_epc = regs->regs[25] = (unsigned long) ka->sa.sa_handler;
  501. DEBUGP("SIG deliver (%s:%d): sp=0x%p pc=0x%lx ra=0x%lx\n",
  502. current->comm, current->pid,
  503. frame, regs->cp0_epc, regs->regs[31]);
  504. return 0;
  505. give_sigsegv:
  506. force_sigsegv(signr, current);
  507. return -EFAULT;
  508. }
  509. static int setup_rt_frame_32(void *sig_return, struct k_sigaction *ka,
  510. struct pt_regs *regs, int signr, sigset_t *set,
  511. siginfo_t *info)
  512. {
  513. struct rt_sigframe32 __user *frame;
  514. int err = 0;
  515. frame = get_sigframe(ka, regs, sizeof(*frame));
  516. if (!access_ok(VERIFY_WRITE, frame, sizeof (*frame)))
  517. goto give_sigsegv;
  518. /* Convert (siginfo_t -> compat_siginfo_t) and copy to user. */
  519. err |= copy_siginfo_to_user32(&frame->rs_info, info);
  520. /* Create the ucontext. */
  521. err |= __put_user(0, &frame->rs_uc.uc_flags);
  522. err |= __put_user(0, &frame->rs_uc.uc_link);
  523. err |= __compat_save_altstack(&frame->rs_uc.uc_stack, regs->regs[29]);
  524. err |= setup_sigcontext32(regs, &frame->rs_uc.uc_mcontext);
  525. err |= __copy_conv_sigset_to_user(&frame->rs_uc.uc_sigmask, set);
  526. if (err)
  527. goto give_sigsegv;
  528. /*
  529. * Arguments to signal handler:
  530. *
  531. * a0 = signal number
  532. * a1 = 0 (should be cause)
  533. * a2 = pointer to ucontext
  534. *
  535. * $25 and c0_epc point to the signal handler, $29 points to
  536. * the struct rt_sigframe32.
  537. */
  538. regs->regs[ 4] = signr;
  539. regs->regs[ 5] = (unsigned long) &frame->rs_info;
  540. regs->regs[ 6] = (unsigned long) &frame->rs_uc;
  541. regs->regs[29] = (unsigned long) frame;
  542. regs->regs[31] = (unsigned long) sig_return;
  543. regs->cp0_epc = regs->regs[25] = (unsigned long) ka->sa.sa_handler;
  544. DEBUGP("SIG deliver (%s:%d): sp=0x%p pc=0x%lx ra=0x%lx\n",
  545. current->comm, current->pid,
  546. frame, regs->cp0_epc, regs->regs[31]);
  547. return 0;
  548. give_sigsegv:
  549. force_sigsegv(signr, current);
  550. return -EFAULT;
  551. }
  552. /*
  553. * o32 compatibility on 64-bit kernels, without DSP ASE
  554. */
  555. struct mips_abi mips_abi_32 = {
  556. .setup_frame = setup_frame_32,
  557. .signal_return_offset =
  558. offsetof(struct mips_vdso, o32_signal_trampoline),
  559. .setup_rt_frame = setup_rt_frame_32,
  560. .rt_signal_return_offset =
  561. offsetof(struct mips_vdso, o32_rt_signal_trampoline),
  562. .restart = __NR_O32_restart_syscall
  563. };
  564. static int signal32_init(void)
  565. {
  566. if (cpu_has_fpu) {
  567. save_fp_context32 = _save_fp_context32;
  568. restore_fp_context32 = _restore_fp_context32;
  569. } else {
  570. save_fp_context32 = copy_fp_to_sigcontext32;
  571. restore_fp_context32 = copy_fp_from_sigcontext32;
  572. }
  573. return 0;
  574. }
  575. arch_initcall(signal32_init);