signal.c
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:19k
源码类别:

Linux/Unix编程

开发平台:

Unix_Linux

  1. /*
  2.  * BK Id: %F% %I% %G% %U% %#%
  3.  */
  4. /*
  5.  *  linux/arch/ppc/kernel/signal.c
  6.  *
  7.  *  PowerPC version 
  8.  *    Copyright (C) 1995-1996 Gary Thomas (gdt@linuxppc.org)
  9.  *
  10.  *  Derived from "arch/i386/kernel/signal.c"
  11.  *    Copyright (C) 1991, 1992 Linus Torvalds
  12.  *    1997-11-28  Modified for POSIX.1b signals by Richard Henderson
  13.  *
  14.  *  This program is free software; you can redistribute it and/or
  15.  *  modify it under the terms of the GNU General Public License
  16.  *  as published by the Free Software Foundation; either version
  17.  *  2 of the License, or (at your option) any later version.
  18.  */
  19. #include <linux/sched.h>
  20. #include <linux/mm.h>
  21. #include <linux/smp.h>
  22. #include <linux/smp_lock.h>
  23. #include <linux/kernel.h>
  24. #include <linux/signal.h>
  25. #include <linux/errno.h>
  26. #include <linux/wait.h>
  27. #include <linux/ptrace.h>
  28. #include <linux/unistd.h>
  29. #include <linux/stddef.h>
  30. #include <linux/elf.h>
  31. #include <asm/ucontext.h>
  32. #include <asm/uaccess.h>
  33. #include <asm/pgtable.h>
  34. #define DEBUG_SIG 0
  35. #define _BLOCKABLE (~(sigmask(SIGKILL) | sigmask(SIGSTOP)))
  36. #ifndef MIN
  37. #define MIN(a,b) (((a) < (b)) ? (a) : (b))
  38. #endif
  39. #define GP_REGS_SIZE MIN(sizeof(elf_gregset_t), sizeof(struct pt_regs))
  40. /* 
  41.  * These are the flags in the MSR that the user is allowed to change
  42.  * by modifying the saved value of the MSR on the stack.  SE and BE
  43.  * should not be in this list since gdb may want to change these.  I.e,
  44.  * you should be able to step out of a signal handler to see what
  45.  * instruction executes next after the signal handler completes.
  46.  * Alternately, if you stepped into a signal handler, you should be
  47.  * able to continue 'til the next breakpoint from within the signal
  48.  * handler, even if the handler returns.
  49.  */
  50. #define MSR_USERCHANGE (MSR_FE0 | MSR_FE1)
  51. int do_signal(sigset_t *oldset, struct pt_regs *regs);
  52. int copy_siginfo_to_user(siginfo_t *to, siginfo_t *from)
  53. {
  54. if (!access_ok (VERIFY_WRITE, to, sizeof(siginfo_t)))
  55. return -EFAULT;
  56. if (from->si_code < 0)
  57. return __copy_to_user(to, from, sizeof(siginfo_t));
  58. else {
  59. int err;
  60. /* If you change siginfo_t structure, please be sure
  61.    this code is fixed accordingly.
  62.    It should never copy any pad contained in the structure
  63.    to avoid security leaks, but must copy the generic
  64.    3 ints plus the relevant union member.  */
  65. err = __put_user(from->si_signo, &to->si_signo);
  66. err |= __put_user(from->si_errno, &to->si_errno);
  67. err |= __put_user((short)from->si_code, &to->si_code);
  68. /* First 32bits of unions are always present.  */
  69. err |= __put_user(from->si_pid, &to->si_pid);
  70. switch (from->si_code >> 16) {
  71. case __SI_FAULT >> 16:
  72. break;
  73. case __SI_CHLD >> 16:
  74. err |= __put_user(from->si_utime, &to->si_utime);
  75. err |= __put_user(from->si_stime, &to->si_stime);
  76. err |= __put_user(from->si_status, &to->si_status);
  77. default:
  78. err |= __put_user(from->si_uid, &to->si_uid);
  79. break;
  80. /* case __SI_RT: This is not generated by the kernel as of now.  */
  81. }
  82. return err;
  83. }
  84. }
  85. /*
  86.  * Atomically swap in the new signal mask, and wait for a signal.
  87.  */
  88. int
  89. sys_sigsuspend(old_sigset_t mask, int p2, int p3, int p4, int p6, int p7,
  90.        struct pt_regs *regs)
  91. {
  92. sigset_t saveset;
  93. mask &= _BLOCKABLE;
  94. spin_lock_irq(&current->sigmask_lock);
  95. saveset = current->blocked;
  96. siginitset(&current->blocked, mask);
  97. recalc_sigpending(current);
  98. spin_unlock_irq(&current->sigmask_lock);
  99. regs->result = -EINTR;
  100. regs->gpr[3] = EINTR;
  101. regs->ccr |= 0x10000000;
  102. while (1) {
  103. current->state = TASK_INTERRUPTIBLE;
  104. schedule();
  105. if (do_signal(&saveset, regs))
  106. /*
  107.  * If a signal handler needs to be called,
  108.  * do_signal() has set R3 to the signal number (the
  109.  * first argument of the signal handler), so don't
  110.  * overwrite that with EINTR !
  111.  * In the other cases, do_signal() doesn't touch 
  112.  * R3, so it's still set to -EINTR (see above).
  113.  */
  114. return regs->gpr[3];
  115. }
  116. }
  117. int
  118. sys_rt_sigsuspend(sigset_t *unewset, size_t sigsetsize, int p3, int p4, int p6,
  119.   int p7, struct pt_regs *regs)
  120. {
  121. sigset_t saveset, newset;
  122. /* XXX: Don't preclude handling different sized sigset_t's.  */
  123. if (sigsetsize != sizeof(sigset_t))
  124. return -EINVAL;
  125. if (copy_from_user(&newset, unewset, sizeof(newset)))
  126. return -EFAULT;
  127. sigdelsetmask(&newset, ~_BLOCKABLE);
  128. spin_lock_irq(&current->sigmask_lock);
  129. saveset = current->blocked;
  130. current->blocked = newset;
  131. recalc_sigpending(current);
  132. spin_unlock_irq(&current->sigmask_lock);
  133. regs->result = -EINTR;
  134. regs->gpr[3] = EINTR;
  135. regs->ccr |= 0x10000000;
  136. while (1) {
  137. current->state = TASK_INTERRUPTIBLE;
  138. schedule();
  139. if (do_signal(&saveset, regs))
  140. return regs->gpr[3];
  141. }
  142. }
  143. int
  144. sys_sigaltstack(const stack_t *uss, stack_t *uoss)
  145. {
  146. struct pt_regs *regs = (struct pt_regs *) &uss;
  147. return do_sigaltstack(uss, uoss, regs->gpr[1]);
  148. }
  149. int 
  150. sys_sigaction(int sig, const struct old_sigaction *act,
  151.       struct old_sigaction *oact)
  152. {
  153. struct k_sigaction new_ka, old_ka;
  154. int ret;
  155. if (act) {
  156. old_sigset_t mask;
  157. if (verify_area(VERIFY_READ, act, sizeof(*act)) ||
  158.     __get_user(new_ka.sa.sa_handler, &act->sa_handler) ||
  159.     __get_user(new_ka.sa.sa_restorer, &act->sa_restorer))
  160. return -EFAULT;
  161. __get_user(new_ka.sa.sa_flags, &act->sa_flags);
  162. __get_user(mask, &act->sa_mask);
  163. siginitset(&new_ka.sa.sa_mask, mask);
  164. }
  165. ret = do_sigaction(sig, (act? &new_ka: NULL), (oact? &old_ka: NULL));
  166. if (!ret && oact) {
  167. if (verify_area(VERIFY_WRITE, oact, sizeof(*oact)) ||
  168.     __put_user(old_ka.sa.sa_handler, &oact->sa_handler) ||
  169.     __put_user(old_ka.sa.sa_restorer, &oact->sa_restorer))
  170. return -EFAULT;
  171. __put_user(old_ka.sa.sa_flags, &oact->sa_flags);
  172. __put_user(old_ka.sa.sa_mask.sig[0], &oact->sa_mask);
  173. }
  174. return ret;
  175. }
  176. /*
  177.  * When we have signals to deliver, we set up on the
  178.  * user stack, going down from the original stack pointer:
  179.  * a sigregs struct
  180.  * one or more sigcontext structs with
  181.  * a gap of __SIGNAL_FRAMESIZE bytes
  182.  *
  183.  * Each of these things must be a multiple of 16 bytes in size.
  184.  *
  185.  */
  186. struct sigregs {
  187. elf_gregset_t gp_regs;
  188. double fp_regs[ELF_NFPREG];
  189. unsigned long tramp[2];
  190. /* Programs using the rs6000/xcoff abi can save up to 19 gp regs
  191.    and 18 fp regs below sp before decrementing it. */
  192. int abigap[56];
  193. };
  194. struct rt_sigframe
  195. {
  196. unsigned long _unused[2];
  197. struct siginfo *pinfo;
  198. void *puc;
  199. struct siginfo info;
  200. struct ucontext uc;
  201. };
  202. /*
  203.  *  When we have rt signals to deliver, we set up on the
  204.  *  user stack, going down from the original stack pointer:
  205.  *    a sigregs struct
  206.  *    one rt_sigframe struct (siginfo + ucontext)
  207.  *    a gap of __SIGNAL_FRAMESIZE bytes
  208.  *
  209.  *  Each of these things must be a multiple of 16 bytes in size.
  210.  *
  211.  */
  212. int sys_rt_sigreturn(struct pt_regs *regs)
  213. {
  214. struct rt_sigframe *rt_sf;
  215. struct sigcontext_struct sigctx;
  216. struct sigregs *sr;
  217. int ret;
  218. elf_gregset_t saved_regs;  /* an array of ELF_NGREG unsigned longs */
  219. sigset_t set;
  220. stack_t st;
  221. unsigned long prevsp;
  222. rt_sf = (struct rt_sigframe *)(regs->gpr[1] + __SIGNAL_FRAMESIZE);
  223. if (copy_from_user(&sigctx, &rt_sf->uc.uc_mcontext, sizeof(sigctx))
  224.     || copy_from_user(&set, &rt_sf->uc.uc_sigmask, sizeof(set))
  225.     || copy_from_user(&st, &rt_sf->uc.uc_stack, sizeof(st)))
  226. goto badframe;
  227. sigdelsetmask(&set, ~_BLOCKABLE);
  228. spin_lock_irq(&current->sigmask_lock);
  229. current->blocked = set;
  230. recalc_sigpending(current);
  231. spin_unlock_irq(&current->sigmask_lock);
  232. if (regs->msr & MSR_FP)
  233. giveup_fpu(current);
  234. rt_sf++; /* Look at next rt_sigframe */
  235. if (rt_sf == (struct rt_sigframe *)(sigctx.regs)) {
  236. /* Last stacked signal - restore registers -
  237.  * sigctx is initialized to point to the 
  238.  * preamble frame (where registers are stored) 
  239.  * see handle_signal()
  240.  */
  241. sr = (struct sigregs *) sigctx.regs;
  242. if (copy_from_user(saved_regs, &sr->gp_regs,
  243.    sizeof(sr->gp_regs)))
  244. goto badframe;
  245. saved_regs[PT_MSR] = (regs->msr & ~MSR_USERCHANGE)
  246. | (saved_regs[PT_MSR] & MSR_USERCHANGE);
  247. memcpy(regs, saved_regs, GP_REGS_SIZE);
  248. if (copy_from_user(current->thread.fpr, &sr->fp_regs,
  249.    sizeof(sr->fp_regs)))
  250. goto badframe;
  251. /* This function sets back the stack flags into
  252.    the current task structure.  */
  253. sys_sigaltstack(&st, NULL);
  254. ret = regs->result;
  255. } else {
  256. /* More signals to go */
  257. /* Set up registers for next signal handler */
  258. regs->gpr[1] = (unsigned long)rt_sf - __SIGNAL_FRAMESIZE;
  259. if (copy_from_user(&sigctx, &rt_sf->uc.uc_mcontext, sizeof(sigctx)))
  260. goto badframe;
  261. sr = (struct sigregs *) sigctx.regs;
  262. regs->gpr[3] = ret = sigctx.signal;
  263. /* Get the siginfo   */
  264. get_user(regs->gpr[4], (unsigned long *)&rt_sf->pinfo);
  265. /* Get the ucontext */
  266. get_user(regs->gpr[5], (unsigned long *)&rt_sf->puc);
  267. regs->gpr[6] = (unsigned long) rt_sf;
  268. regs->link = (unsigned long) &sr->tramp;
  269. regs->nip = sigctx.handler;
  270. if (get_user(prevsp, &sr->gp_regs[PT_R1])
  271.     || put_user(prevsp, (unsigned long *) regs->gpr[1]))
  272. goto badframe;
  273. current->thread.fpscr = 0;
  274. }
  275. return ret;
  276. badframe:
  277. do_exit(SIGSEGV);
  278. }
  279. static void
  280. setup_rt_frame(struct pt_regs *regs, struct sigregs *frame,
  281.        signed long newsp)
  282. {
  283. struct rt_sigframe *rt_sf = (struct rt_sigframe *) newsp;
  284. /* Set up preamble frame */
  285. if (verify_area(VERIFY_WRITE, frame, sizeof(*frame)))
  286. goto badframe;
  287. if (regs->msr & MSR_FP)
  288. giveup_fpu(current);
  289. if (__copy_to_user(&frame->gp_regs, regs, GP_REGS_SIZE)
  290.     || __copy_to_user(&frame->fp_regs, current->thread.fpr,
  291.       ELF_NFPREG * sizeof(double))
  292. /* Set up to return from user space.
  293.    It calls the sc exception at offset 0x9999 
  294.    for sys_rt_sigreturn().
  295. */
  296.     || __put_user(0x38006666UL, &frame->tramp[0]) /* li r0,0x6666 */
  297.     || __put_user(0x44000002UL, &frame->tramp[1])) /* sc */
  298. goto badframe;
  299. flush_icache_range((unsigned long) &frame->tramp[0],
  300.    (unsigned long) &frame->tramp[2]);
  301. current->thread.fpscr = 0; /* turn off all fp exceptions */
  302. /* Retrieve rt_sigframe from stack and
  303.    set up registers for signal handler
  304. */
  305. newsp -= __SIGNAL_FRAMESIZE;
  306. if (put_user(regs->gpr[1], (unsigned long *)newsp)
  307.     || get_user(regs->nip, &rt_sf->uc.uc_mcontext.handler)
  308.     || get_user(regs->gpr[3], &rt_sf->uc.uc_mcontext.signal)
  309.     || get_user(regs->gpr[4], (unsigned long *)&rt_sf->pinfo)
  310.     || get_user(regs->gpr[5], (unsigned long *)&rt_sf->puc))
  311. goto badframe;
  312. regs->gpr[1] = newsp;
  313. regs->gpr[6] = (unsigned long) rt_sf;
  314. regs->link = (unsigned long) frame->tramp;
  315. return;
  316. badframe:
  317. #if DEBUG_SIG
  318. printk("badframe in setup_rt_frame, regs=%p frame=%p newsp=%lxn",
  319.        regs, frame, newsp);
  320. #endif
  321. do_exit(SIGSEGV);
  322. }
  323. /*
  324.  * Do a signal return; undo the signal stack.
  325.  */
  326. int sys_sigreturn(struct pt_regs *regs)
  327. {
  328. struct sigcontext_struct *sc, sigctx;
  329. struct sigregs *sr;
  330. int ret;
  331. elf_gregset_t saved_regs;  /* an array of ELF_NGREG unsigned longs */
  332. sigset_t set;
  333. unsigned long prevsp;
  334. sc = (struct sigcontext_struct *)(regs->gpr[1] + __SIGNAL_FRAMESIZE);
  335. if (copy_from_user(&sigctx, sc, sizeof(sigctx)))
  336. goto badframe;
  337. set.sig[0] = sigctx.oldmask;
  338. #if _NSIG_WORDS > 1
  339. set.sig[1] = sigctx._unused[3];
  340. #endif
  341. sigdelsetmask(&set, ~_BLOCKABLE);
  342. spin_lock_irq(&current->sigmask_lock);
  343. current->blocked = set;
  344. recalc_sigpending(current);
  345. spin_unlock_irq(&current->sigmask_lock);
  346. if (regs->msr & MSR_FP )
  347. giveup_fpu(current);
  348. sc++; /* Look at next sigcontext */
  349. if (sc == (struct sigcontext_struct *)(sigctx.regs)) {
  350. /* Last stacked signal - restore registers */
  351. sr = (struct sigregs *) sigctx.regs;
  352. if (copy_from_user(saved_regs, &sr->gp_regs,
  353.    sizeof(sr->gp_regs)))
  354. goto badframe;
  355. saved_regs[PT_MSR] = (regs->msr & ~MSR_USERCHANGE)
  356. | (saved_regs[PT_MSR] & MSR_USERCHANGE);
  357. memcpy(regs, saved_regs, GP_REGS_SIZE);
  358. if (copy_from_user(current->thread.fpr, &sr->fp_regs,
  359.    sizeof(sr->fp_regs)))
  360. goto badframe;
  361. ret = regs->result;
  362. } else {
  363. /* More signals to go */
  364. regs->gpr[1] = (unsigned long)sc - __SIGNAL_FRAMESIZE;
  365. if (copy_from_user(&sigctx, sc, sizeof(sigctx)))
  366. goto badframe;
  367. sr = (struct sigregs *) sigctx.regs;
  368. regs->gpr[3] = ret = sigctx.signal;
  369. regs->gpr[4] = (unsigned long) sc;
  370. regs->link = (unsigned long) &sr->tramp;
  371. regs->nip = sigctx.handler;
  372. if (get_user(prevsp, &sr->gp_regs[PT_R1])
  373.     || put_user(prevsp, (unsigned long *) regs->gpr[1]))
  374. goto badframe;
  375. current->thread.fpscr = 0;
  376. }
  377. return ret;
  378. badframe:
  379. do_exit(SIGSEGV);
  380. }
  381. /*
  382.  * Set up a signal frame.
  383.  */
  384. static void
  385. setup_frame(struct pt_regs *regs, struct sigregs *frame,
  386.     unsigned long newsp)
  387. {
  388. struct sigcontext_struct *sc = (struct sigcontext_struct *) newsp;
  389. if (verify_area(VERIFY_WRITE, frame, sizeof(*frame)))
  390. goto badframe;
  391. if (regs->msr & MSR_FP)
  392. giveup_fpu(current);
  393. if (__copy_to_user(&frame->gp_regs, regs, GP_REGS_SIZE)
  394.     || __copy_to_user(&frame->fp_regs, current->thread.fpr,
  395.       ELF_NFPREG * sizeof(double))
  396.     || __put_user(0x38007777UL, &frame->tramp[0])    /* li r0,0x7777 */
  397.     || __put_user(0x44000002UL, &frame->tramp[1]))   /* sc */
  398. goto badframe;
  399. flush_icache_range((unsigned long) &frame->tramp[0],
  400.    (unsigned long) &frame->tramp[2]);
  401. current->thread.fpscr = 0; /* turn off all fp exceptions */
  402. newsp -= __SIGNAL_FRAMESIZE;
  403. if (put_user(regs->gpr[1], (unsigned long *)newsp)
  404.     || get_user(regs->nip, &sc->handler)
  405.     || get_user(regs->gpr[3], &sc->signal))
  406. goto badframe;
  407. regs->gpr[1] = newsp;
  408. regs->gpr[4] = (unsigned long) sc;
  409. regs->link = (unsigned long) frame->tramp;
  410. return;
  411. badframe:
  412. #if DEBUG_SIG
  413. printk("badframe in setup_frame, regs=%p frame=%p newsp=%lxn",
  414.        regs, frame, newsp);
  415. #endif
  416. do_exit(SIGSEGV);
  417. }
  418. /*
  419.  * OK, we're invoking a handler
  420.  */
  421. static void
  422. handle_signal(unsigned long sig, struct k_sigaction *ka,
  423.       siginfo_t *info, sigset_t *oldset, struct pt_regs * regs,
  424.       unsigned long *newspp, unsigned long frame)
  425. {
  426. struct sigcontext_struct *sc;
  427. struct rt_sigframe *rt_sf;
  428. if (regs->trap == 0x0C00 /* System Call! */
  429.     && ((int)regs->result == -ERESTARTNOHAND ||
  430. ((int)regs->result == -ERESTARTSYS &&
  431.  !(ka->sa.sa_flags & SA_RESTART))))
  432. regs->result = -EINTR;
  433. /* Set up Signal Frame */
  434. if (ka->sa.sa_flags & SA_SIGINFO) {
  435. /* Put a Real Time Context onto stack */
  436. *newspp -= sizeof(*rt_sf);
  437. rt_sf = (struct rt_sigframe *) *newspp;
  438. if (verify_area(VERIFY_WRITE, rt_sf, sizeof(*rt_sf)))
  439. goto badframe;
  440. if (__put_user((unsigned long) ka->sa.sa_handler, &rt_sf->uc.uc_mcontext.handler)
  441.     || __put_user(&rt_sf->info, &rt_sf->pinfo)
  442.     || __put_user(&rt_sf->uc, &rt_sf->puc)
  443.     /* Put the siginfo */
  444.     || __copy_to_user(&rt_sf->info, info, sizeof(*info))
  445.     /* Create the ucontext */
  446.     || __put_user(0, &rt_sf->uc.uc_flags)
  447.     || __put_user(0, &rt_sf->uc.uc_link)
  448.     || __put_user(current->sas_ss_sp, &rt_sf->uc.uc_stack.ss_sp)
  449.     || __put_user(sas_ss_flags(regs->gpr[1]), 
  450.   &rt_sf->uc.uc_stack.ss_flags)
  451.     || __put_user(current->sas_ss_size, &rt_sf->uc.uc_stack.ss_size)
  452.     || __copy_to_user(&rt_sf->uc.uc_sigmask, oldset, sizeof(*oldset))
  453.     /* mcontext.regs points to preamble register frame */
  454.     || __put_user((struct pt_regs *)frame, &rt_sf->uc.uc_mcontext.regs)
  455.     || __put_user(sig, &rt_sf->uc.uc_mcontext.signal))
  456. goto badframe;
  457. } else {
  458. /* Put another sigcontext on the stack */
  459. *newspp -= sizeof(*sc);
  460. sc = (struct sigcontext_struct *) *newspp;
  461. if (verify_area(VERIFY_WRITE, sc, sizeof(*sc)))
  462. goto badframe;
  463. if (__put_user((unsigned long) ka->sa.sa_handler, &sc->handler)
  464.     || __put_user(oldset->sig[0], &sc->oldmask)
  465. #if _NSIG_WORDS > 1
  466.     || __put_user(oldset->sig[1], &sc->_unused[3])
  467. #endif
  468.     || __put_user((struct pt_regs *)frame, &sc->regs)
  469.     || __put_user(sig, &sc->signal))
  470. goto badframe;
  471. }
  472. if (ka->sa.sa_flags & SA_ONESHOT)
  473. ka->sa.sa_handler = SIG_DFL;
  474. if (!(ka->sa.sa_flags & SA_NODEFER)) {
  475. spin_lock_irq(&current->sigmask_lock);
  476. sigorsets(&current->blocked,&current->blocked,&ka->sa.sa_mask);
  477. sigaddset(&current->blocked,sig);
  478. recalc_sigpending(current);
  479. spin_unlock_irq(&current->sigmask_lock);
  480. }
  481. return;
  482. badframe:
  483. #if DEBUG_SIG
  484. printk("badframe in handle_signal, regs=%p frame=%lx newsp=%lxn",
  485.        regs, frame, *newspp);
  486. printk("sc=%p sig=%d ka=%p info=%p oldset=%pn", sc, sig, ka, info, oldset);
  487. #endif
  488. do_exit(SIGSEGV);
  489. }
  490. /*
  491.  * Note that 'init' is a special process: it doesn't get signals it doesn't
  492.  * want to handle. Thus you cannot kill init even with a SIGKILL even by
  493.  * mistake.
  494.  */
  495. int do_signal(sigset_t *oldset, struct pt_regs *regs)
  496. {
  497. siginfo_t info;
  498. struct k_sigaction *ka;
  499. unsigned long frame, newsp;
  500. if (!oldset)
  501. oldset = &current->blocked;
  502. newsp = frame = 0;
  503. for (;;) {
  504. unsigned long signr;
  505. spin_lock_irq(&current->sigmask_lock);
  506. signr = dequeue_signal(&current->blocked, &info);
  507. spin_unlock_irq(&current->sigmask_lock);
  508. if (!signr)
  509. break;
  510. if ((current->ptrace & PT_PTRACED) && signr != SIGKILL) {
  511. /* Let the debugger run.  */
  512. current->exit_code = signr;
  513. current->state = TASK_STOPPED;
  514. notify_parent(current, SIGCHLD);
  515. schedule();
  516. /* We're back.  Did the debugger cancel the sig?  */
  517. if (!(signr = current->exit_code))
  518. continue;
  519. current->exit_code = 0;
  520. /* The debugger continued.  Ignore SIGSTOP.  */
  521. if (signr == SIGSTOP)
  522. continue;
  523. /* Update the siginfo structure.  Is this good?  */
  524. if (signr != info.si_signo) {
  525. info.si_signo = signr;
  526. info.si_errno = 0;
  527. info.si_code = SI_USER;
  528. info.si_pid = current->p_pptr->pid;
  529. info.si_uid = current->p_pptr->uid;
  530. }
  531. /* If the (new) signal is now blocked, requeue it.  */
  532. if (sigismember(&current->blocked, signr)) {
  533. send_sig_info(signr, &info, current);
  534. continue;
  535. }
  536. }
  537. ka = &current->sig->action[signr-1];
  538. if (ka->sa.sa_handler == SIG_IGN) {
  539. if (signr != SIGCHLD)
  540. continue;
  541. /* Check for SIGCHLD: it's special.  */
  542. while (sys_wait4(-1, NULL, WNOHANG, NULL) > 0)
  543. /* nothing */;
  544. continue;
  545. }
  546. if (ka->sa.sa_handler == SIG_DFL) {
  547. int exit_code = signr;
  548. /* Init gets no signals it doesn't want.  */
  549. if (current->pid == 1)
  550. continue;
  551. switch (signr) {
  552. case SIGCONT: case SIGCHLD: case SIGWINCH: case SIGURG:
  553. continue;
  554. case SIGTSTP: case SIGTTIN: case SIGTTOU:
  555. if (is_orphaned_pgrp(current->pgrp))
  556. continue;
  557. /* FALLTHRU */
  558. case SIGSTOP:
  559. current->state = TASK_STOPPED;
  560. current->exit_code = signr;
  561. if (!(current->p_pptr->sig->action[SIGCHLD-1].sa.sa_flags & SA_NOCLDSTOP))
  562. notify_parent(current, SIGCHLD);
  563. schedule();
  564. continue;
  565. case SIGQUIT: case SIGILL: case SIGTRAP:
  566. case SIGABRT: case SIGFPE: case SIGSEGV:
  567. case SIGBUS: case SIGSYS: case SIGXCPU: case SIGXFSZ:
  568. if (do_coredump(signr, regs))
  569. exit_code |= 0x80;
  570. /* FALLTHRU */
  571. default:
  572. sig_exit(signr, exit_code, &info);
  573. /* NOTREACHED */
  574. }
  575. }
  576. if ( (ka->sa.sa_flags & SA_ONSTACK)
  577.      && (! on_sig_stack(regs->gpr[1])))
  578. newsp = (current->sas_ss_sp + current->sas_ss_size);
  579. else
  580. newsp = regs->gpr[1];
  581. newsp = frame = newsp - sizeof(struct sigregs);
  582. /* Whee!  Actually deliver the signal.  */
  583. handle_signal(signr, ka, &info, oldset, regs, &newsp, frame);
  584. break;
  585. }
  586. if (regs->trap == 0x0C00 /* System Call! */ &&
  587.     ((int)regs->result == -ERESTARTNOHAND ||
  588.      (int)regs->result == -ERESTARTSYS ||
  589.      (int)regs->result == -ERESTARTNOINTR)) {
  590. regs->gpr[3] = regs->orig_gpr3;
  591. regs->nip -= 4; /* Back up & retry system call */
  592. regs->result = 0;
  593. }
  594. if (newsp == frame)
  595. return 0; /* no signals delivered */
  596. if (ka->sa.sa_flags & SA_SIGINFO)
  597. setup_rt_frame(regs, (struct sigregs *) frame, newsp);
  598. else
  599. setup_frame(regs, (struct sigregs *) frame, newsp);
  600. return 1;
  601. }