ia32_signal.c 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617
  1. /*
  2. * linux/arch/x86_64/ia32/ia32_signal.c
  3. *
  4. * Copyright (C) 1991, 1992 Linus Torvalds
  5. *
  6. * 1997-11-28 Modified for POSIX.1b signals by Richard Henderson
  7. * 2000-06-20 Pentium III FXSR, SSE support by Gareth Hughes
  8. * 2000-12-* x86-64 compatibility mode signal handling by Andi Kleen
  9. */
  10. #include <linux/sched.h>
  11. #include <linux/mm.h>
  12. #include <linux/smp.h>
  13. #include <linux/kernel.h>
  14. #include <linux/signal.h>
  15. #include <linux/errno.h>
  16. #include <linux/wait.h>
  17. #include <linux/ptrace.h>
  18. #include <linux/unistd.h>
  19. #include <linux/stddef.h>
  20. #include <linux/personality.h>
  21. #include <linux/compat.h>
  22. #include <linux/binfmts.h>
  23. #include <asm/ucontext.h>
  24. #include <asm/uaccess.h>
  25. #include <asm/i387.h>
  26. #include <asm/ia32.h>
  27. #include <asm/ptrace.h>
  28. #include <asm/ia32_unistd.h>
  29. #include <asm/user32.h>
  30. #include <asm/sigcontext32.h>
  31. #include <asm/fpu32.h>
  32. #include <asm/proto.h>
  33. #include <asm/vsyscall32.h>
  34. #define DEBUG_SIG 0
  35. #define _BLOCKABLE (~(sigmask(SIGKILL) | sigmask(SIGSTOP)))
  36. asmlinkage int do_signal(struct pt_regs *regs, sigset_t *oldset);
  37. void signal_fault(struct pt_regs *regs, void __user *frame, char *where);
  38. int copy_siginfo_to_user32(compat_siginfo_t __user *to, siginfo_t *from)
  39. {
  40. int err;
  41. if (!access_ok (VERIFY_WRITE, to, sizeof(compat_siginfo_t)))
  42. return -EFAULT;
  43. /* If you change siginfo_t structure, please make sure that
  44. this code is fixed accordingly.
  45. It should never copy any pad contained in the structure
  46. to avoid security leaks, but must copy the generic
  47. 3 ints plus the relevant union member. */
  48. err = __put_user(from->si_signo, &to->si_signo);
  49. err |= __put_user(from->si_errno, &to->si_errno);
  50. err |= __put_user((short)from->si_code, &to->si_code);
  51. if (from->si_code < 0) {
  52. err |= __put_user(from->si_pid, &to->si_pid);
  53. err |= __put_user(from->si_uid, &to->si_uid);
  54. err |= __put_user(ptr_to_compat(from->si_ptr), &to->si_ptr);
  55. } else {
  56. /* First 32bits of unions are always present:
  57. * si_pid === si_band === si_tid === si_addr(LS half) */
  58. err |= __put_user(from->_sifields._pad[0], &to->_sifields._pad[0]);
  59. switch (from->si_code >> 16) {
  60. case __SI_FAULT >> 16:
  61. break;
  62. case __SI_CHLD >> 16:
  63. err |= __put_user(from->si_utime, &to->si_utime);
  64. err |= __put_user(from->si_stime, &to->si_stime);
  65. err |= __put_user(from->si_status, &to->si_status);
  66. /* FALL THROUGH */
  67. default:
  68. case __SI_KILL >> 16:
  69. err |= __put_user(from->si_uid, &to->si_uid);
  70. break;
  71. case __SI_POLL >> 16:
  72. err |= __put_user(from->si_fd, &to->si_fd);
  73. break;
  74. case __SI_TIMER >> 16:
  75. err |= __put_user(from->si_overrun, &to->si_overrun);
  76. err |= __put_user(ptr_to_compat(from->si_ptr),
  77. &to->si_ptr);
  78. break;
  79. case __SI_RT >> 16: /* This is not generated by the kernel as of now. */
  80. case __SI_MESGQ >> 16:
  81. err |= __put_user(from->si_uid, &to->si_uid);
  82. err |= __put_user(from->si_int, &to->si_int);
  83. break;
  84. }
  85. }
  86. return err;
  87. }
  88. int copy_siginfo_from_user32(siginfo_t *to, compat_siginfo_t __user *from)
  89. {
  90. int err;
  91. u32 ptr32;
  92. if (!access_ok (VERIFY_READ, from, sizeof(compat_siginfo_t)))
  93. return -EFAULT;
  94. err = __get_user(to->si_signo, &from->si_signo);
  95. err |= __get_user(to->si_errno, &from->si_errno);
  96. err |= __get_user(to->si_code, &from->si_code);
  97. err |= __get_user(to->si_pid, &from->si_pid);
  98. err |= __get_user(to->si_uid, &from->si_uid);
  99. err |= __get_user(ptr32, &from->si_ptr);
  100. to->si_ptr = compat_ptr(ptr32);
  101. return err;
  102. }
  103. asmlinkage long
  104. sys32_sigsuspend(int history0, int history1, old_sigset_t mask)
  105. {
  106. mask &= _BLOCKABLE;
  107. spin_lock_irq(&current->sighand->siglock);
  108. current->saved_sigmask = current->blocked;
  109. siginitset(&current->blocked, mask);
  110. recalc_sigpending();
  111. spin_unlock_irq(&current->sighand->siglock);
  112. current->state = TASK_INTERRUPTIBLE;
  113. schedule();
  114. set_thread_flag(TIF_RESTORE_SIGMASK);
  115. return -ERESTARTNOHAND;
  116. }
  117. asmlinkage long
  118. sys32_sigaltstack(const stack_ia32_t __user *uss_ptr,
  119. stack_ia32_t __user *uoss_ptr,
  120. struct pt_regs *regs)
  121. {
  122. stack_t uss,uoss;
  123. int ret;
  124. mm_segment_t seg;
  125. if (uss_ptr) {
  126. u32 ptr;
  127. memset(&uss,0,sizeof(stack_t));
  128. if (!access_ok(VERIFY_READ,uss_ptr,sizeof(stack_ia32_t)) ||
  129. __get_user(ptr, &uss_ptr->ss_sp) ||
  130. __get_user(uss.ss_flags, &uss_ptr->ss_flags) ||
  131. __get_user(uss.ss_size, &uss_ptr->ss_size))
  132. return -EFAULT;
  133. uss.ss_sp = compat_ptr(ptr);
  134. }
  135. seg = get_fs();
  136. set_fs(KERNEL_DS);
  137. ret = do_sigaltstack(uss_ptr ? &uss : NULL, &uoss, regs->rsp);
  138. set_fs(seg);
  139. if (ret >= 0 && uoss_ptr) {
  140. if (!access_ok(VERIFY_WRITE,uoss_ptr,sizeof(stack_ia32_t)) ||
  141. __put_user(ptr_to_compat(uoss.ss_sp), &uoss_ptr->ss_sp) ||
  142. __put_user(uoss.ss_flags, &uoss_ptr->ss_flags) ||
  143. __put_user(uoss.ss_size, &uoss_ptr->ss_size))
  144. ret = -EFAULT;
  145. }
  146. return ret;
  147. }
  148. /*
  149. * Do a signal return; undo the signal stack.
  150. */
  151. struct sigframe
  152. {
  153. u32 pretcode;
  154. int sig;
  155. struct sigcontext_ia32 sc;
  156. struct _fpstate_ia32 fpstate;
  157. unsigned int extramask[_COMPAT_NSIG_WORDS-1];
  158. char retcode[8];
  159. };
  160. struct rt_sigframe
  161. {
  162. u32 pretcode;
  163. int sig;
  164. u32 pinfo;
  165. u32 puc;
  166. compat_siginfo_t info;
  167. struct ucontext_ia32 uc;
  168. struct _fpstate_ia32 fpstate;
  169. char retcode[8];
  170. };
  171. static int
  172. ia32_restore_sigcontext(struct pt_regs *regs, struct sigcontext_ia32 __user *sc, unsigned int *peax)
  173. {
  174. unsigned int err = 0;
  175. /* Always make any pending restarted system calls return -EINTR */
  176. current_thread_info()->restart_block.fn = do_no_restart_syscall;
  177. #if DEBUG_SIG
  178. printk("SIG restore_sigcontext: sc=%p err(%x) eip(%x) cs(%x) flg(%x)\n",
  179. sc, sc->err, sc->eip, sc->cs, sc->eflags);
  180. #endif
  181. #define COPY(x) { \
  182. unsigned int reg; \
  183. err |= __get_user(reg, &sc->e ##x); \
  184. regs->r ## x = reg; \
  185. }
  186. #define RELOAD_SEG(seg,mask) \
  187. { unsigned int cur; \
  188. unsigned short pre; \
  189. err |= __get_user(pre, &sc->seg); \
  190. asm volatile("movl %%" #seg ",%0" : "=r" (cur)); \
  191. pre |= mask; \
  192. if (pre != cur) loadsegment(seg,pre); }
  193. /* Reload fs and gs if they have changed in the signal handler.
  194. This does not handle long fs/gs base changes in the handler, but
  195. does not clobber them at least in the normal case. */
  196. {
  197. unsigned gs, oldgs;
  198. err |= __get_user(gs, &sc->gs);
  199. gs |= 3;
  200. asm("movl %%gs,%0" : "=r" (oldgs));
  201. if (gs != oldgs)
  202. load_gs_index(gs);
  203. }
  204. RELOAD_SEG(fs,3);
  205. RELOAD_SEG(ds,3);
  206. RELOAD_SEG(es,3);
  207. COPY(di); COPY(si); COPY(bp); COPY(sp); COPY(bx);
  208. COPY(dx); COPY(cx); COPY(ip);
  209. /* Don't touch extended registers */
  210. err |= __get_user(regs->cs, &sc->cs);
  211. regs->cs |= 3;
  212. err |= __get_user(regs->ss, &sc->ss);
  213. regs->ss |= 3;
  214. {
  215. unsigned int tmpflags;
  216. err |= __get_user(tmpflags, &sc->eflags);
  217. regs->eflags = (regs->eflags & ~0x40DD5) | (tmpflags & 0x40DD5);
  218. regs->orig_rax = -1; /* disable syscall checks */
  219. }
  220. {
  221. u32 tmp;
  222. struct _fpstate_ia32 __user * buf;
  223. err |= __get_user(tmp, &sc->fpstate);
  224. buf = compat_ptr(tmp);
  225. if (buf) {
  226. if (!access_ok(VERIFY_READ, buf, sizeof(*buf)))
  227. goto badframe;
  228. err |= restore_i387_ia32(current, buf, 0);
  229. } else {
  230. struct task_struct *me = current;
  231. if (used_math()) {
  232. clear_fpu(me);
  233. clear_used_math();
  234. }
  235. }
  236. }
  237. {
  238. u32 tmp;
  239. err |= __get_user(tmp, &sc->eax);
  240. *peax = tmp;
  241. }
  242. return err;
  243. badframe:
  244. return 1;
  245. }
  246. asmlinkage long sys32_sigreturn(struct pt_regs *regs)
  247. {
  248. struct sigframe __user *frame = (struct sigframe __user *)(regs->rsp-8);
  249. sigset_t set;
  250. unsigned int eax;
  251. if (!access_ok(VERIFY_READ, frame, sizeof(*frame)))
  252. goto badframe;
  253. if (__get_user(set.sig[0], &frame->sc.oldmask)
  254. || (_COMPAT_NSIG_WORDS > 1
  255. && __copy_from_user((((char *) &set.sig) + 4), &frame->extramask,
  256. sizeof(frame->extramask))))
  257. goto badframe;
  258. sigdelsetmask(&set, ~_BLOCKABLE);
  259. spin_lock_irq(&current->sighand->siglock);
  260. current->blocked = set;
  261. recalc_sigpending();
  262. spin_unlock_irq(&current->sighand->siglock);
  263. if (ia32_restore_sigcontext(regs, &frame->sc, &eax))
  264. goto badframe;
  265. return eax;
  266. badframe:
  267. signal_fault(regs, frame, "32bit sigreturn");
  268. return 0;
  269. }
  270. asmlinkage long sys32_rt_sigreturn(struct pt_regs *regs)
  271. {
  272. struct rt_sigframe __user *frame;
  273. sigset_t set;
  274. unsigned int eax;
  275. struct pt_regs tregs;
  276. frame = (struct rt_sigframe __user *)(regs->rsp - 4);
  277. if (!access_ok(VERIFY_READ, frame, sizeof(*frame)))
  278. goto badframe;
  279. if (__copy_from_user(&set, &frame->uc.uc_sigmask, sizeof(set)))
  280. goto badframe;
  281. sigdelsetmask(&set, ~_BLOCKABLE);
  282. spin_lock_irq(&current->sighand->siglock);
  283. current->blocked = set;
  284. recalc_sigpending();
  285. spin_unlock_irq(&current->sighand->siglock);
  286. if (ia32_restore_sigcontext(regs, &frame->uc.uc_mcontext, &eax))
  287. goto badframe;
  288. tregs = *regs;
  289. if (sys32_sigaltstack(&frame->uc.uc_stack, NULL, &tregs) == -EFAULT)
  290. goto badframe;
  291. return eax;
  292. badframe:
  293. signal_fault(regs,frame,"32bit rt sigreturn");
  294. return 0;
  295. }
  296. /*
  297. * Set up a signal frame.
  298. */
  299. static int
  300. ia32_setup_sigcontext(struct sigcontext_ia32 __user *sc, struct _fpstate_ia32 __user *fpstate,
  301. struct pt_regs *regs, unsigned int mask)
  302. {
  303. int tmp, err = 0;
  304. tmp = 0;
  305. __asm__("movl %%gs,%0" : "=r"(tmp): "0"(tmp));
  306. err |= __put_user(tmp, (unsigned int __user *)&sc->gs);
  307. __asm__("movl %%fs,%0" : "=r"(tmp): "0"(tmp));
  308. err |= __put_user(tmp, (unsigned int __user *)&sc->fs);
  309. __asm__("movl %%ds,%0" : "=r"(tmp): "0"(tmp));
  310. err |= __put_user(tmp, (unsigned int __user *)&sc->ds);
  311. __asm__("movl %%es,%0" : "=r"(tmp): "0"(tmp));
  312. err |= __put_user(tmp, (unsigned int __user *)&sc->es);
  313. err |= __put_user((u32)regs->rdi, &sc->edi);
  314. err |= __put_user((u32)regs->rsi, &sc->esi);
  315. err |= __put_user((u32)regs->rbp, &sc->ebp);
  316. err |= __put_user((u32)regs->rsp, &sc->esp);
  317. err |= __put_user((u32)regs->rbx, &sc->ebx);
  318. err |= __put_user((u32)regs->rdx, &sc->edx);
  319. err |= __put_user((u32)regs->rcx, &sc->ecx);
  320. err |= __put_user((u32)regs->rax, &sc->eax);
  321. err |= __put_user((u32)regs->cs, &sc->cs);
  322. err |= __put_user((u32)regs->ss, &sc->ss);
  323. err |= __put_user(current->thread.trap_no, &sc->trapno);
  324. err |= __put_user(current->thread.error_code, &sc->err);
  325. err |= __put_user((u32)regs->rip, &sc->eip);
  326. err |= __put_user((u32)regs->eflags, &sc->eflags);
  327. err |= __put_user((u32)regs->rsp, &sc->esp_at_signal);
  328. tmp = save_i387_ia32(current, fpstate, regs, 0);
  329. if (tmp < 0)
  330. err = -EFAULT;
  331. else {
  332. clear_used_math();
  333. stts();
  334. err |= __put_user(ptr_to_compat(tmp ? fpstate : NULL),
  335. &sc->fpstate);
  336. }
  337. /* non-iBCS2 extensions.. */
  338. err |= __put_user(mask, &sc->oldmask);
  339. err |= __put_user(current->thread.cr2, &sc->cr2);
  340. return err;
  341. }
  342. /*
  343. * Determine which stack to use..
  344. */
  345. static void __user *
  346. get_sigframe(struct k_sigaction *ka, struct pt_regs * regs, size_t frame_size)
  347. {
  348. unsigned long rsp;
  349. /* Default to using normal stack */
  350. rsp = regs->rsp;
  351. /* This is the X/Open sanctioned signal stack switching. */
  352. if (ka->sa.sa_flags & SA_ONSTACK) {
  353. if (sas_ss_flags(rsp) == 0)
  354. rsp = current->sas_ss_sp + current->sas_ss_size;
  355. }
  356. /* This is the legacy signal stack switching. */
  357. else if ((regs->ss & 0xffff) != __USER_DS &&
  358. !(ka->sa.sa_flags & SA_RESTORER) &&
  359. ka->sa.sa_restorer) {
  360. rsp = (unsigned long) ka->sa.sa_restorer;
  361. }
  362. rsp -= frame_size;
  363. /* Align the stack pointer according to the i386 ABI,
  364. * i.e. so that on function entry ((sp + 4) & 15) == 0. */
  365. rsp = ((rsp + 4) & -16ul) - 4;
  366. return (void __user *) rsp;
  367. }
  368. int ia32_setup_frame(int sig, struct k_sigaction *ka,
  369. compat_sigset_t *set, struct pt_regs * regs)
  370. {
  371. struct sigframe __user *frame;
  372. int err = 0;
  373. frame = get_sigframe(ka, regs, sizeof(*frame));
  374. if (!access_ok(VERIFY_WRITE, frame, sizeof(*frame)))
  375. goto give_sigsegv;
  376. err |= __put_user(sig, &frame->sig);
  377. if (err)
  378. goto give_sigsegv;
  379. err |= ia32_setup_sigcontext(&frame->sc, &frame->fpstate, regs,
  380. set->sig[0]);
  381. if (err)
  382. goto give_sigsegv;
  383. if (_COMPAT_NSIG_WORDS > 1) {
  384. err |= __copy_to_user(frame->extramask, &set->sig[1],
  385. sizeof(frame->extramask));
  386. }
  387. if (err)
  388. goto give_sigsegv;
  389. /* Return stub is in 32bit vsyscall page */
  390. {
  391. void __user *restorer;
  392. if (current->binfmt->hasvdso)
  393. restorer = VSYSCALL32_SIGRETURN;
  394. else
  395. restorer = (void *)&frame->retcode;
  396. if (ka->sa.sa_flags & SA_RESTORER)
  397. restorer = ka->sa.sa_restorer;
  398. err |= __put_user(ptr_to_compat(restorer), &frame->pretcode);
  399. }
  400. /* These are actually not used anymore, but left because some
  401. gdb versions depend on them as a marker. */
  402. {
  403. /* copy_to_user optimizes that into a single 8 byte store */
  404. static const struct {
  405. u16 poplmovl;
  406. u32 val;
  407. u16 int80;
  408. u16 pad;
  409. } __attribute__((packed)) code = {
  410. 0xb858, /* popl %eax ; movl $...,%eax */
  411. __NR_ia32_sigreturn,
  412. 0x80cd, /* int $0x80 */
  413. 0,
  414. };
  415. err |= __copy_to_user(frame->retcode, &code, 8);
  416. }
  417. if (err)
  418. goto give_sigsegv;
  419. /* Set up registers for signal handler */
  420. regs->rsp = (unsigned long) frame;
  421. regs->rip = (unsigned long) ka->sa.sa_handler;
  422. /* Make -mregparm=3 work */
  423. regs->rax = sig;
  424. regs->rdx = 0;
  425. regs->rcx = 0;
  426. asm volatile("movl %0,%%ds" :: "r" (__USER32_DS));
  427. asm volatile("movl %0,%%es" :: "r" (__USER32_DS));
  428. regs->cs = __USER32_CS;
  429. regs->ss = __USER32_DS;
  430. set_fs(USER_DS);
  431. regs->eflags &= ~TF_MASK;
  432. if (test_thread_flag(TIF_SINGLESTEP))
  433. ptrace_notify(SIGTRAP);
  434. #if DEBUG_SIG
  435. printk("SIG deliver (%s:%d): sp=%p pc=%lx ra=%u\n",
  436. current->comm, current->pid, frame, regs->rip, frame->pretcode);
  437. #endif
  438. return 0;
  439. give_sigsegv:
  440. force_sigsegv(sig, current);
  441. return -EFAULT;
  442. }
  443. int ia32_setup_rt_frame(int sig, struct k_sigaction *ka, siginfo_t *info,
  444. compat_sigset_t *set, struct pt_regs * regs)
  445. {
  446. struct rt_sigframe __user *frame;
  447. int err = 0;
  448. frame = get_sigframe(ka, regs, sizeof(*frame));
  449. if (!access_ok(VERIFY_WRITE, frame, sizeof(*frame)))
  450. goto give_sigsegv;
  451. {
  452. struct exec_domain *ed = current_thread_info()->exec_domain;
  453. err |= __put_user((ed
  454. && ed->signal_invmap
  455. && sig < 32
  456. ? ed->signal_invmap[sig]
  457. : sig),
  458. &frame->sig);
  459. }
  460. err |= __put_user(ptr_to_compat(&frame->info), &frame->pinfo);
  461. err |= __put_user(ptr_to_compat(&frame->uc), &frame->puc);
  462. err |= copy_siginfo_to_user32(&frame->info, info);
  463. if (err)
  464. goto give_sigsegv;
  465. /* Create the ucontext. */
  466. err |= __put_user(0, &frame->uc.uc_flags);
  467. err |= __put_user(0, &frame->uc.uc_link);
  468. err |= __put_user(current->sas_ss_sp, &frame->uc.uc_stack.ss_sp);
  469. err |= __put_user(sas_ss_flags(regs->rsp),
  470. &frame->uc.uc_stack.ss_flags);
  471. err |= __put_user(current->sas_ss_size, &frame->uc.uc_stack.ss_size);
  472. err |= ia32_setup_sigcontext(&frame->uc.uc_mcontext, &frame->fpstate,
  473. regs, set->sig[0]);
  474. err |= __copy_to_user(&frame->uc.uc_sigmask, set, sizeof(*set));
  475. if (err)
  476. goto give_sigsegv;
  477. {
  478. void __user *restorer = VSYSCALL32_RTSIGRETURN;
  479. if (ka->sa.sa_flags & SA_RESTORER)
  480. restorer = ka->sa.sa_restorer;
  481. err |= __put_user(ptr_to_compat(restorer), &frame->pretcode);
  482. }
  483. /* This is movl $,%eax ; int $0x80 */
  484. /* Not actually used anymore, but left because some gdb versions
  485. need it. */
  486. {
  487. /* __copy_to_user optimizes that into a single 8 byte store */
  488. static const struct {
  489. u8 movl;
  490. u32 val;
  491. u16 int80;
  492. u16 pad;
  493. u8 pad2;
  494. } __attribute__((packed)) code = {
  495. 0xb8,
  496. __NR_ia32_rt_sigreturn,
  497. 0x80cd,
  498. 0,
  499. };
  500. err |= __copy_to_user(frame->retcode, &code, 8);
  501. }
  502. if (err)
  503. goto give_sigsegv;
  504. /* Set up registers for signal handler */
  505. regs->rsp = (unsigned long) frame;
  506. regs->rip = (unsigned long) ka->sa.sa_handler;
  507. /* Make -mregparm=3 work */
  508. regs->rax = sig;
  509. regs->rdx = (unsigned long) &frame->info;
  510. regs->rcx = (unsigned long) &frame->uc;
  511. /* Make -mregparm=3 work */
  512. regs->rax = sig;
  513. regs->rdx = (unsigned long) &frame->info;
  514. regs->rcx = (unsigned long) &frame->uc;
  515. asm volatile("movl %0,%%ds" :: "r" (__USER32_DS));
  516. asm volatile("movl %0,%%es" :: "r" (__USER32_DS));
  517. regs->cs = __USER32_CS;
  518. regs->ss = __USER32_DS;
  519. set_fs(USER_DS);
  520. regs->eflags &= ~TF_MASK;
  521. if (test_thread_flag(TIF_SINGLESTEP))
  522. ptrace_notify(SIGTRAP);
  523. #if DEBUG_SIG
  524. printk("SIG deliver (%s:%d): sp=%p pc=%lx ra=%u\n",
  525. current->comm, current->pid, frame, regs->rip, frame->pretcode);
  526. #endif
  527. return 0;
  528. give_sigsegv:
  529. force_sigsegv(sig, current);
  530. return -EFAULT;
  531. }