blob: a7daf749b97f272ba4819646b9f2515fb845c29a [file] [log] [blame]
Stephen Rothwell81e70092005-10-18 11:17:58 +10001/*
2 * Signal handling for 32bit PPC and 32bit tasks on 64bit PPC
3 *
4 * PowerPC version
5 * Copyright (C) 1995-1996 Gary Thomas (gdt@linuxppc.org)
6 * Copyright (C) 2001 IBM
7 * Copyright (C) 1997,1998 Jakub Jelinek (jj@sunsite.mff.cuni.cz)
8 * Copyright (C) 1997 David S. Miller (davem@caip.rutgers.edu)
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
Stephen Rothwell81e70092005-10-18 11:17:58 +100020#include <linux/sched.h>
21#include <linux/mm.h>
22#include <linux/smp.h>
Stephen Rothwell81e70092005-10-18 11:17:58 +100023#include <linux/kernel.h>
24#include <linux/signal.h>
25#include <linux/errno.h>
26#include <linux/elf.h>
Lucas Woods05ead012007-12-13 15:56:06 -080027#include <linux/ptrace.h>
Christian Dietrich76462232011-06-04 05:36:54 +000028#include <linux/ratelimit.h>
Stephen Rothwell81e70092005-10-18 11:17:58 +100029#ifdef CONFIG_PPC64
30#include <linux/syscalls.h>
31#include <linux/compat.h>
Stephen Rothwell81e70092005-10-18 11:17:58 +100032#else
33#include <linux/wait.h>
Stephen Rothwell81e70092005-10-18 11:17:58 +100034#include <linux/unistd.h>
35#include <linux/stddef.h>
36#include <linux/tty.h>
37#include <linux/binfmts.h>
Stephen Rothwell81e70092005-10-18 11:17:58 +100038#endif
39
40#include <asm/uaccess.h>
41#include <asm/cacheflush.h>
Arnd Bergmanna7f31842006-03-23 00:00:08 +010042#include <asm/syscalls.h>
David Gibsonc5ff7002005-11-09 11:21:07 +110043#include <asm/sigcontext.h>
Benjamin Herrenschmidta7f290d2005-11-11 21:15:21 +110044#include <asm/vdso.h>
David Howellsae3a1972012-03-28 18:30:02 +010045#include <asm/switch_to.h>
Michael Neuling2b0a5762013-02-13 16:21:41 +000046#include <asm/tm.h>
Stephen Rothwell81e70092005-10-18 11:17:58 +100047#ifdef CONFIG_PPC64
Stephen Rothwell879168e2005-11-03 15:32:07 +110048#include "ppc32.h"
Stephen Rothwell81e70092005-10-18 11:17:58 +100049#include <asm/unistd.h>
Stephen Rothwell81e70092005-10-18 11:17:58 +100050#else
51#include <asm/ucontext.h>
52#include <asm/pgtable.h>
53#endif
54
Benjamin Herrenschmidt22e38f22007-06-04 15:15:49 +100055#include "signal.h"
56
Stephen Rothwell81e70092005-10-18 11:17:58 +100057
Stephen Rothwell81e70092005-10-18 11:17:58 +100058#ifdef CONFIG_PPC64
Stephen Rothwellb09a4912005-10-18 14:51:57 +100059#define sys_rt_sigreturn compat_sys_rt_sigreturn
Stephen Rothwellb09a4912005-10-18 14:51:57 +100060#define sys_swapcontext compat_sys_swapcontext
61#define sys_sigreturn compat_sys_sigreturn
Stephen Rothwell81e70092005-10-18 11:17:58 +100062
63#define old_sigaction old_sigaction32
64#define sigcontext sigcontext32
65#define mcontext mcontext32
66#define ucontext ucontext32
67
Al Viro7cce2462012-12-23 03:26:46 -050068#define __save_altstack __compat_save_altstack
69
Stephen Rothwell81e70092005-10-18 11:17:58 +100070/*
Michael Neulingc1cb2992008-07-08 18:43:41 +100071 * Userspace code may pass a ucontext which doesn't include VSX added
72 * at the end. We need to check for this case.
73 */
74#define UCONTEXTSIZEWITHOUTVSX \
75 (sizeof(struct ucontext) - sizeof(elf_vsrreghalf_t32))
76
77/*
Stephen Rothwell81e70092005-10-18 11:17:58 +100078 * Returning 0 means we return to userspace via
79 * ret_from_except and thus restore all user
80 * registers from *regs. This is what we need
81 * to do when a signal has been delivered.
82 */
Stephen Rothwell81e70092005-10-18 11:17:58 +100083
84#define GP_REGS_SIZE min(sizeof(elf_gregset_t32), sizeof(struct pt_regs32))
85#undef __SIGNAL_FRAMESIZE
86#define __SIGNAL_FRAMESIZE __SIGNAL_FRAMESIZE32
87#undef ELF_NVRREG
88#define ELF_NVRREG ELF_NVRREG32
89
90/*
91 * Functions for flipping sigsets (thanks to brain dead generic
92 * implementation that makes things simple for little endian only)
93 */
94static inline int put_sigset_t(compat_sigset_t __user *uset, sigset_t *set)
95{
96 compat_sigset_t cset;
97
98 switch (_NSIG_WORDS) {
Will Deacona313f4c2011-11-08 04:51:19 +000099 case 4: cset.sig[6] = set->sig[3] & 0xffffffffull;
Stephen Rothwell81e70092005-10-18 11:17:58 +1000100 cset.sig[7] = set->sig[3] >> 32;
101 case 3: cset.sig[4] = set->sig[2] & 0xffffffffull;
102 cset.sig[5] = set->sig[2] >> 32;
103 case 2: cset.sig[2] = set->sig[1] & 0xffffffffull;
104 cset.sig[3] = set->sig[1] >> 32;
105 case 1: cset.sig[0] = set->sig[0] & 0xffffffffull;
106 cset.sig[1] = set->sig[0] >> 32;
107 }
108 return copy_to_user(uset, &cset, sizeof(*uset));
109}
110
Paul Mackerras9b7cf8b2005-10-19 23:13:04 +1000111static inline int get_sigset_t(sigset_t *set,
112 const compat_sigset_t __user *uset)
Stephen Rothwell81e70092005-10-18 11:17:58 +1000113{
114 compat_sigset_t s32;
115
116 if (copy_from_user(&s32, uset, sizeof(*uset)))
117 return -EFAULT;
118
119 /*
120 * Swap the 2 words of the 64-bit sigset_t (they are stored
121 * in the "wrong" endian in 32-bit user storage).
122 */
123 switch (_NSIG_WORDS) {
124 case 4: set->sig[3] = s32.sig[6] | (((long)s32.sig[7]) << 32);
125 case 3: set->sig[2] = s32.sig[4] | (((long)s32.sig[5]) << 32);
126 case 2: set->sig[1] = s32.sig[2] | (((long)s32.sig[3]) << 32);
127 case 1: set->sig[0] = s32.sig[0] | (((long)s32.sig[1]) << 32);
128 }
129 return 0;
130}
131
Al Viro29e646d2006-02-01 05:28:09 -0500132#define to_user_ptr(p) ptr_to_compat(p)
Stephen Rothwell81e70092005-10-18 11:17:58 +1000133#define from_user_ptr(p) compat_ptr(p)
134
135static inline int save_general_regs(struct pt_regs *regs,
136 struct mcontext __user *frame)
137{
138 elf_greg_t64 *gregs = (elf_greg_t64 *)regs;
139 int i;
140
Paul Mackerras1bd79332006-03-08 13:24:22 +1100141 WARN_ON(!FULL_REGS(regs));
David Woodhouse401d1f02005-11-15 18:52:18 +0000142
143 for (i = 0; i <= PT_RESULT; i ++) {
144 if (i == 14 && !FULL_REGS(regs))
145 i = 32;
Stephen Rothwell81e70092005-10-18 11:17:58 +1000146 if (__put_user((unsigned int)gregs[i], &frame->mc_gregs[i]))
147 return -EFAULT;
David Woodhouse401d1f02005-11-15 18:52:18 +0000148 }
Stephen Rothwell81e70092005-10-18 11:17:58 +1000149 return 0;
150}
151
152static inline int restore_general_regs(struct pt_regs *regs,
153 struct mcontext __user *sr)
154{
155 elf_greg_t64 *gregs = (elf_greg_t64 *)regs;
156 int i;
157
158 for (i = 0; i <= PT_RESULT; i++) {
159 if ((i == PT_MSR) || (i == PT_SOFTE))
160 continue;
161 if (__get_user(gregs[i], &sr->mc_gregs[i]))
162 return -EFAULT;
163 }
164 return 0;
165}
166
167#else /* CONFIG_PPC64 */
168
Stephen Rothwell81e70092005-10-18 11:17:58 +1000169#define GP_REGS_SIZE min(sizeof(elf_gregset_t), sizeof(struct pt_regs))
170
171static inline int put_sigset_t(sigset_t __user *uset, sigset_t *set)
172{
173 return copy_to_user(uset, set, sizeof(*uset));
174}
175
Paul Mackerras9b7cf8b2005-10-19 23:13:04 +1000176static inline int get_sigset_t(sigset_t *set, const sigset_t __user *uset)
Stephen Rothwell81e70092005-10-18 11:17:58 +1000177{
178 return copy_from_user(set, uset, sizeof(*uset));
179}
180
Al Viro29e646d2006-02-01 05:28:09 -0500181#define to_user_ptr(p) ((unsigned long)(p))
182#define from_user_ptr(p) ((void __user *)(p))
Stephen Rothwell81e70092005-10-18 11:17:58 +1000183
184static inline int save_general_regs(struct pt_regs *regs,
185 struct mcontext __user *frame)
186{
Paul Mackerras1bd79332006-03-08 13:24:22 +1100187 WARN_ON(!FULL_REGS(regs));
Stephen Rothwell81e70092005-10-18 11:17:58 +1000188 return __copy_to_user(&frame->mc_gregs, regs, GP_REGS_SIZE);
189}
190
191static inline int restore_general_regs(struct pt_regs *regs,
192 struct mcontext __user *sr)
193{
194 /* copy up to but not including MSR */
195 if (__copy_from_user(regs, &sr->mc_gregs,
196 PT_MSR * sizeof(elf_greg_t)))
197 return -EFAULT;
198 /* copy from orig_r3 (the word after the MSR) up to the end */
199 if (__copy_from_user(&regs->orig_gpr3, &sr->mc_gregs[PT_ORIG_R3],
200 GP_REGS_SIZE - PT_ORIG_R3 * sizeof(elf_greg_t)))
201 return -EFAULT;
202 return 0;
203}
Stephen Rothwell81e70092005-10-18 11:17:58 +1000204#endif
205
Stephen Rothwell81e70092005-10-18 11:17:58 +1000206/*
207 * When we have signals to deliver, we set up on the
208 * user stack, going down from the original stack pointer:
Benjamin Herrenschmidta3f61dc2007-06-04 17:22:48 +1000209 * an ABI gap of 56 words
210 * an mcontext struct
Stephen Rothwell81e70092005-10-18 11:17:58 +1000211 * a sigcontext struct
212 * a gap of __SIGNAL_FRAMESIZE bytes
213 *
Benjamin Herrenschmidta3f61dc2007-06-04 17:22:48 +1000214 * Each of these things must be a multiple of 16 bytes in size. The following
215 * structure represent all of this except the __SIGNAL_FRAMESIZE gap
Stephen Rothwell81e70092005-10-18 11:17:58 +1000216 *
217 */
Benjamin Herrenschmidta3f61dc2007-06-04 17:22:48 +1000218struct sigframe {
219 struct sigcontext sctx; /* the sigcontext */
Stephen Rothwell81e70092005-10-18 11:17:58 +1000220 struct mcontext mctx; /* all the register values */
Michael Neuling2b0a5762013-02-13 16:21:41 +0000221#ifdef CONFIG_PPC_TRANSACTIONAL_MEM
222 struct sigcontext sctx_transact;
223 struct mcontext mctx_transact;
224#endif
Stephen Rothwell81e70092005-10-18 11:17:58 +1000225 /*
226 * Programs using the rs6000/xcoff abi can save up to 19 gp
227 * regs and 18 fp regs below sp before decrementing it.
228 */
229 int abigap[56];
230};
231
232/* We use the mc_pad field for the signal return trampoline. */
233#define tramp mc_pad
234
235/*
236 * When we have rt signals to deliver, we set up on the
237 * user stack, going down from the original stack pointer:
238 * one rt_sigframe struct (siginfo + ucontext + ABI gap)
239 * a gap of __SIGNAL_FRAMESIZE+16 bytes
240 * (the +16 is to get the siginfo and ucontext in the same
241 * positions as in older kernels).
242 *
243 * Each of these things must be a multiple of 16 bytes in size.
244 *
245 */
246struct rt_sigframe {
247#ifdef CONFIG_PPC64
248 compat_siginfo_t info;
249#else
250 struct siginfo info;
251#endif
252 struct ucontext uc;
Michael Neuling2b0a5762013-02-13 16:21:41 +0000253#ifdef CONFIG_PPC_TRANSACTIONAL_MEM
254 struct ucontext uc_transact;
255#endif
Stephen Rothwell81e70092005-10-18 11:17:58 +1000256 /*
257 * Programs using the rs6000/xcoff abi can save up to 19 gp
258 * regs and 18 fp regs below sp before decrementing it.
259 */
260 int abigap[56];
261};
262
Michael Neuling6a274c02008-07-02 14:06:37 +1000263#ifdef CONFIG_VSX
264unsigned long copy_fpr_to_user(void __user *to,
265 struct task_struct *task)
266{
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000267 u64 buf[ELF_NFPREG];
Michael Neuling6a274c02008-07-02 14:06:37 +1000268 int i;
269
270 /* save FPR copy to local buffer then write to the thread_struct */
271 for (i = 0; i < (ELF_NFPREG - 1) ; i++)
272 buf[i] = task->thread.TS_FPR(i);
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000273 buf[i] = task->thread.fp_state.fpscr;
Michael Neuling6a274c02008-07-02 14:06:37 +1000274 return __copy_to_user(to, buf, ELF_NFPREG * sizeof(double));
275}
276
277unsigned long copy_fpr_from_user(struct task_struct *task,
278 void __user *from)
279{
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000280 u64 buf[ELF_NFPREG];
Michael Neuling6a274c02008-07-02 14:06:37 +1000281 int i;
282
283 if (__copy_from_user(buf, from, ELF_NFPREG * sizeof(double)))
284 return 1;
285 for (i = 0; i < (ELF_NFPREG - 1) ; i++)
286 task->thread.TS_FPR(i) = buf[i];
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000287 task->thread.fp_state.fpscr = buf[i];
Michael Neuling6a274c02008-07-02 14:06:37 +1000288
289 return 0;
290}
291
292unsigned long copy_vsx_to_user(void __user *to,
293 struct task_struct *task)
294{
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000295 u64 buf[ELF_NVSRHALFREG];
Michael Neuling6a274c02008-07-02 14:06:37 +1000296 int i;
297
298 /* save FPR copy to local buffer then write to the thread_struct */
299 for (i = 0; i < ELF_NVSRHALFREG; i++)
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000300 buf[i] = task->thread.fp_state.fpr[i][TS_VSRLOWOFFSET];
Michael Neuling6a274c02008-07-02 14:06:37 +1000301 return __copy_to_user(to, buf, ELF_NVSRHALFREG * sizeof(double));
302}
303
304unsigned long copy_vsx_from_user(struct task_struct *task,
305 void __user *from)
306{
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000307 u64 buf[ELF_NVSRHALFREG];
Michael Neuling6a274c02008-07-02 14:06:37 +1000308 int i;
309
310 if (__copy_from_user(buf, from, ELF_NVSRHALFREG * sizeof(double)))
311 return 1;
312 for (i = 0; i < ELF_NVSRHALFREG ; i++)
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000313 task->thread.fp_state.fpr[i][TS_VSRLOWOFFSET] = buf[i];
Michael Neuling6a274c02008-07-02 14:06:37 +1000314 return 0;
315}
Michael Neuling2b0a5762013-02-13 16:21:41 +0000316
317#ifdef CONFIG_PPC_TRANSACTIONAL_MEM
318unsigned long copy_transact_fpr_to_user(void __user *to,
319 struct task_struct *task)
320{
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000321 u64 buf[ELF_NFPREG];
Michael Neuling2b0a5762013-02-13 16:21:41 +0000322 int i;
323
324 /* save FPR copy to local buffer then write to the thread_struct */
325 for (i = 0; i < (ELF_NFPREG - 1) ; i++)
326 buf[i] = task->thread.TS_TRANS_FPR(i);
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000327 buf[i] = task->thread.transact_fp.fpscr;
Michael Neuling2b0a5762013-02-13 16:21:41 +0000328 return __copy_to_user(to, buf, ELF_NFPREG * sizeof(double));
329}
330
331unsigned long copy_transact_fpr_from_user(struct task_struct *task,
332 void __user *from)
333{
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000334 u64 buf[ELF_NFPREG];
Michael Neuling2b0a5762013-02-13 16:21:41 +0000335 int i;
336
337 if (__copy_from_user(buf, from, ELF_NFPREG * sizeof(double)))
338 return 1;
339 for (i = 0; i < (ELF_NFPREG - 1) ; i++)
340 task->thread.TS_TRANS_FPR(i) = buf[i];
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000341 task->thread.transact_fp.fpscr = buf[i];
Michael Neuling2b0a5762013-02-13 16:21:41 +0000342
343 return 0;
344}
345
346unsigned long copy_transact_vsx_to_user(void __user *to,
347 struct task_struct *task)
348{
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000349 u64 buf[ELF_NVSRHALFREG];
Michael Neuling2b0a5762013-02-13 16:21:41 +0000350 int i;
351
352 /* save FPR copy to local buffer then write to the thread_struct */
353 for (i = 0; i < ELF_NVSRHALFREG; i++)
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000354 buf[i] = task->thread.transact_fp.fpr[i][TS_VSRLOWOFFSET];
Michael Neuling2b0a5762013-02-13 16:21:41 +0000355 return __copy_to_user(to, buf, ELF_NVSRHALFREG * sizeof(double));
356}
357
358unsigned long copy_transact_vsx_from_user(struct task_struct *task,
359 void __user *from)
360{
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000361 u64 buf[ELF_NVSRHALFREG];
Michael Neuling2b0a5762013-02-13 16:21:41 +0000362 int i;
363
364 if (__copy_from_user(buf, from, ELF_NVSRHALFREG * sizeof(double)))
365 return 1;
366 for (i = 0; i < ELF_NVSRHALFREG ; i++)
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000367 task->thread.transact_fp.fpr[i][TS_VSRLOWOFFSET] = buf[i];
Michael Neuling2b0a5762013-02-13 16:21:41 +0000368 return 0;
369}
370#endif /* CONFIG_PPC_TRANSACTIONAL_MEM */
Michael Neuling6a274c02008-07-02 14:06:37 +1000371#else
372inline unsigned long copy_fpr_to_user(void __user *to,
373 struct task_struct *task)
374{
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000375 return __copy_to_user(to, task->thread.fp_state.fpr,
Michael Neuling6a274c02008-07-02 14:06:37 +1000376 ELF_NFPREG * sizeof(double));
377}
378
379inline unsigned long copy_fpr_from_user(struct task_struct *task,
380 void __user *from)
381{
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000382 return __copy_from_user(task->thread.fp_state.fpr, from,
Michael Neuling6a274c02008-07-02 14:06:37 +1000383 ELF_NFPREG * sizeof(double));
384}
Michael Neuling2b0a5762013-02-13 16:21:41 +0000385
386#ifdef CONFIG_PPC_TRANSACTIONAL_MEM
387inline unsigned long copy_transact_fpr_to_user(void __user *to,
388 struct task_struct *task)
389{
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000390 return __copy_to_user(to, task->thread.transact_fp.fpr,
Michael Neuling2b0a5762013-02-13 16:21:41 +0000391 ELF_NFPREG * sizeof(double));
392}
393
394inline unsigned long copy_transact_fpr_from_user(struct task_struct *task,
395 void __user *from)
396{
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000397 return __copy_from_user(task->thread.transact_fp.fpr, from,
Michael Neuling2b0a5762013-02-13 16:21:41 +0000398 ELF_NFPREG * sizeof(double));
399}
400#endif /* CONFIG_PPC_TRANSACTIONAL_MEM */
Michael Neuling6a274c02008-07-02 14:06:37 +1000401#endif
402
Stephen Rothwell81e70092005-10-18 11:17:58 +1000403/*
404 * Save the current user registers on the user stack.
405 * We only save the altivec/spe registers if the process has used
406 * altivec/spe instructions at some point.
407 */
408static int save_user_regs(struct pt_regs *regs, struct mcontext __user *frame,
Michael Neuling1d25f112013-06-09 21:23:15 +1000409 struct mcontext __user *tm_frame, int sigret,
410 int ctx_has_vsx_region)
Stephen Rothwell81e70092005-10-18 11:17:58 +1000411{
Michael Neuling9e751182008-06-25 14:07:17 +1000412 unsigned long msr = regs->msr;
413
Stephen Rothwell81e70092005-10-18 11:17:58 +1000414 /* Make sure floating point registers are stored in regs */
415 flush_fp_to_thread(current);
416
Michael Neulingc6e67712008-06-25 14:07:18 +1000417 /* save general registers */
418 if (save_general_regs(regs, frame))
Stephen Rothwell81e70092005-10-18 11:17:58 +1000419 return 1;
420
Stephen Rothwell81e70092005-10-18 11:17:58 +1000421#ifdef CONFIG_ALTIVEC
422 /* save altivec registers */
423 if (current->thread.used_vr) {
424 flush_altivec_to_thread(current);
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000425 if (__copy_to_user(&frame->mc_vregs, &current->thread.vr_state,
Stephen Rothwell81e70092005-10-18 11:17:58 +1000426 ELF_NVRREG * sizeof(vector128)))
427 return 1;
428 /* set MSR_VEC in the saved MSR value to indicate that
429 frame->mc_vregs contains valid data */
Michael Neuling9e751182008-06-25 14:07:17 +1000430 msr |= MSR_VEC;
Stephen Rothwell81e70092005-10-18 11:17:58 +1000431 }
432 /* else assert((regs->msr & MSR_VEC) == 0) */
433
434 /* We always copy to/from vrsave, it's 0 if we don't have or don't
435 * use altivec. Since VSCR only contains 32 bits saved in the least
436 * significant bits of a vector, we "cheat" and stuff VRSAVE in the
437 * most significant bits of that same vector. --BenH
Paul Mackerras408a7e02013-08-05 14:13:16 +1000438 * Note that the current VRSAVE value is in the SPR at this point.
Stephen Rothwell81e70092005-10-18 11:17:58 +1000439 */
Paul Mackerras408a7e02013-08-05 14:13:16 +1000440 if (cpu_has_feature(CPU_FTR_ALTIVEC))
441 current->thread.vrsave = mfspr(SPRN_VRSAVE);
Stephen Rothwell81e70092005-10-18 11:17:58 +1000442 if (__put_user(current->thread.vrsave, (u32 __user *)&frame->mc_vregs[32]))
443 return 1;
444#endif /* CONFIG_ALTIVEC */
Michael Neuling6a274c02008-07-02 14:06:37 +1000445 if (copy_fpr_to_user(&frame->mc_fregs, current))
Michael Neulingc6e67712008-06-25 14:07:18 +1000446 return 1;
Michael Neulingec67ad82013-11-25 11:12:20 +1100447
448 /*
449 * Clear the MSR VSX bit to indicate there is no valid state attached
450 * to this context, except in the specific case below where we set it.
451 */
452 msr &= ~MSR_VSX;
Michael Neuling6a274c02008-07-02 14:06:37 +1000453#ifdef CONFIG_VSX
Michael Neulingce48b212008-06-25 14:07:18 +1000454 /*
455 * Copy VSR 0-31 upper half from thread_struct to local
456 * buffer, then write that to userspace. Also set MSR_VSX in
457 * the saved MSR value to indicate that frame->mc_vregs
458 * contains valid data
459 */
Michael Neuling16c29d12008-10-23 00:42:36 +0000460 if (current->thread.used_vsr && ctx_has_vsx_region) {
Anton Blancharda7d623d2015-10-29 11:44:02 +1100461 flush_vsx_to_thread(current);
Michael Neuling6a274c02008-07-02 14:06:37 +1000462 if (copy_vsx_to_user(&frame->mc_vsregs, current))
Michael Neulingce48b212008-06-25 14:07:18 +1000463 return 1;
464 msr |= MSR_VSX;
Michael Neulingec67ad82013-11-25 11:12:20 +1100465 }
Michael Neulingc6e67712008-06-25 14:07:18 +1000466#endif /* CONFIG_VSX */
Stephen Rothwell81e70092005-10-18 11:17:58 +1000467#ifdef CONFIG_SPE
468 /* save spe registers */
469 if (current->thread.used_spe) {
470 flush_spe_to_thread(current);
471 if (__copy_to_user(&frame->mc_vregs, current->thread.evr,
472 ELF_NEVRREG * sizeof(u32)))
473 return 1;
474 /* set MSR_SPE in the saved MSR value to indicate that
475 frame->mc_vregs contains valid data */
Michael Neuling9e751182008-06-25 14:07:17 +1000476 msr |= MSR_SPE;
Stephen Rothwell81e70092005-10-18 11:17:58 +1000477 }
478 /* else assert((regs->msr & MSR_SPE) == 0) */
479
480 /* We always copy to/from spefscr */
481 if (__put_user(current->thread.spefscr, (u32 __user *)&frame->mc_vregs + ELF_NEVRREG))
482 return 1;
483#endif /* CONFIG_SPE */
484
Michael Neuling9e751182008-06-25 14:07:17 +1000485 if (__put_user(msr, &frame->mc_gregs[PT_MSR]))
486 return 1;
Michael Neuling1d25f112013-06-09 21:23:15 +1000487 /* We need to write 0 the MSR top 32 bits in the tm frame so that we
488 * can check it on the restore to see if TM is active
489 */
490 if (tm_frame && __put_user(0, &tm_frame->mc_gregs[PT_MSR]))
491 return 1;
492
Stephen Rothwell81e70092005-10-18 11:17:58 +1000493 if (sigret) {
494 /* Set up the sigreturn trampoline: li r0,sigret; sc */
495 if (__put_user(0x38000000UL + sigret, &frame->tramp[0])
496 || __put_user(0x44000002UL, &frame->tramp[1]))
497 return 1;
498 flush_icache_range((unsigned long) &frame->tramp[0],
499 (unsigned long) &frame->tramp[2]);
500 }
501
502 return 0;
503}
504
Michael Neuling2b0a5762013-02-13 16:21:41 +0000505#ifdef CONFIG_PPC_TRANSACTIONAL_MEM
506/*
507 * Save the current user registers on the user stack.
508 * We only save the altivec/spe registers if the process has used
509 * altivec/spe instructions at some point.
510 * We also save the transactional registers to a second ucontext in the
511 * frame.
512 *
513 * See save_user_regs() and signal_64.c:setup_tm_sigcontexts().
514 */
515static int save_tm_user_regs(struct pt_regs *regs,
516 struct mcontext __user *frame,
517 struct mcontext __user *tm_frame, int sigret)
518{
519 unsigned long msr = regs->msr;
520
Paul Mackerrasd31626f2014-01-13 15:56:29 +1100521 /* Remove TM bits from thread's MSR. The MSR in the sigcontext
522 * just indicates to userland that we were doing a transaction, but we
523 * don't want to return in transactional state. This also ensures
524 * that flush_fp_to_thread won't set TIF_RESTORE_TM again.
525 */
526 regs->msr &= ~MSR_TS_MASK;
527
Michael Neuling2b0a5762013-02-13 16:21:41 +0000528 /* Make sure floating point registers are stored in regs */
529 flush_fp_to_thread(current);
530
531 /* Save both sets of general registers */
532 if (save_general_regs(&current->thread.ckpt_regs, frame)
533 || save_general_regs(regs, tm_frame))
534 return 1;
535
536 /* Stash the top half of the 64bit MSR into the 32bit MSR word
537 * of the transactional mcontext. This way we have a backward-compatible
538 * MSR in the 'normal' (checkpointed) mcontext and additionally one can
539 * also look at what type of transaction (T or S) was active at the
540 * time of the signal.
541 */
542 if (__put_user((msr >> 32), &tm_frame->mc_gregs[PT_MSR]))
543 return 1;
544
545#ifdef CONFIG_ALTIVEC
546 /* save altivec registers */
547 if (current->thread.used_vr) {
548 flush_altivec_to_thread(current);
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000549 if (__copy_to_user(&frame->mc_vregs, &current->thread.vr_state,
Michael Neuling2b0a5762013-02-13 16:21:41 +0000550 ELF_NVRREG * sizeof(vector128)))
551 return 1;
552 if (msr & MSR_VEC) {
553 if (__copy_to_user(&tm_frame->mc_vregs,
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000554 &current->thread.transact_vr,
Michael Neuling2b0a5762013-02-13 16:21:41 +0000555 ELF_NVRREG * sizeof(vector128)))
556 return 1;
557 } else {
558 if (__copy_to_user(&tm_frame->mc_vregs,
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000559 &current->thread.vr_state,
Michael Neuling2b0a5762013-02-13 16:21:41 +0000560 ELF_NVRREG * sizeof(vector128)))
561 return 1;
562 }
563
564 /* set MSR_VEC in the saved MSR value to indicate that
565 * frame->mc_vregs contains valid data
566 */
567 msr |= MSR_VEC;
568 }
569
570 /* We always copy to/from vrsave, it's 0 if we don't have or don't
571 * use altivec. Since VSCR only contains 32 bits saved in the least
572 * significant bits of a vector, we "cheat" and stuff VRSAVE in the
573 * most significant bits of that same vector. --BenH
574 */
Paul Mackerras408a7e02013-08-05 14:13:16 +1000575 if (cpu_has_feature(CPU_FTR_ALTIVEC))
576 current->thread.vrsave = mfspr(SPRN_VRSAVE);
Michael Neuling2b0a5762013-02-13 16:21:41 +0000577 if (__put_user(current->thread.vrsave,
578 (u32 __user *)&frame->mc_vregs[32]))
579 return 1;
580 if (msr & MSR_VEC) {
581 if (__put_user(current->thread.transact_vrsave,
582 (u32 __user *)&tm_frame->mc_vregs[32]))
583 return 1;
584 } else {
585 if (__put_user(current->thread.vrsave,
586 (u32 __user *)&tm_frame->mc_vregs[32]))
587 return 1;
588 }
589#endif /* CONFIG_ALTIVEC */
590
591 if (copy_fpr_to_user(&frame->mc_fregs, current))
592 return 1;
593 if (msr & MSR_FP) {
594 if (copy_transact_fpr_to_user(&tm_frame->mc_fregs, current))
595 return 1;
596 } else {
597 if (copy_fpr_to_user(&tm_frame->mc_fregs, current))
598 return 1;
599 }
600
601#ifdef CONFIG_VSX
602 /*
603 * Copy VSR 0-31 upper half from thread_struct to local
604 * buffer, then write that to userspace. Also set MSR_VSX in
605 * the saved MSR value to indicate that frame->mc_vregs
606 * contains valid data
607 */
608 if (current->thread.used_vsr) {
Anton Blancharda7d623d2015-10-29 11:44:02 +1100609 flush_vsx_to_thread(current);
Michael Neuling2b0a5762013-02-13 16:21:41 +0000610 if (copy_vsx_to_user(&frame->mc_vsregs, current))
611 return 1;
612 if (msr & MSR_VSX) {
613 if (copy_transact_vsx_to_user(&tm_frame->mc_vsregs,
614 current))
615 return 1;
616 } else {
617 if (copy_vsx_to_user(&tm_frame->mc_vsregs, current))
618 return 1;
619 }
620
621 msr |= MSR_VSX;
622 }
623#endif /* CONFIG_VSX */
624#ifdef CONFIG_SPE
625 /* SPE regs are not checkpointed with TM, so this section is
626 * simply the same as in save_user_regs().
627 */
628 if (current->thread.used_spe) {
629 flush_spe_to_thread(current);
630 if (__copy_to_user(&frame->mc_vregs, current->thread.evr,
631 ELF_NEVRREG * sizeof(u32)))
632 return 1;
633 /* set MSR_SPE in the saved MSR value to indicate that
634 * frame->mc_vregs contains valid data */
635 msr |= MSR_SPE;
636 }
637
638 /* We always copy to/from spefscr */
639 if (__put_user(current->thread.spefscr, (u32 __user *)&frame->mc_vregs + ELF_NEVRREG))
640 return 1;
641#endif /* CONFIG_SPE */
642
643 if (__put_user(msr, &frame->mc_gregs[PT_MSR]))
644 return 1;
645 if (sigret) {
646 /* Set up the sigreturn trampoline: li r0,sigret; sc */
647 if (__put_user(0x38000000UL + sigret, &frame->tramp[0])
648 || __put_user(0x44000002UL, &frame->tramp[1]))
649 return 1;
650 flush_icache_range((unsigned long) &frame->tramp[0],
651 (unsigned long) &frame->tramp[2]);
652 }
653
654 return 0;
655}
656#endif
657
Stephen Rothwell81e70092005-10-18 11:17:58 +1000658/*
659 * Restore the current user register values from the user stack,
660 * (except for MSR).
661 */
662static long restore_user_regs(struct pt_regs *regs,
663 struct mcontext __user *sr, int sig)
664{
665 long err;
666 unsigned int save_r2 = 0;
Stephen Rothwell81e70092005-10-18 11:17:58 +1000667 unsigned long msr;
Michael Neulingc6e67712008-06-25 14:07:18 +1000668#ifdef CONFIG_VSX
Michael Neulingc6e67712008-06-25 14:07:18 +1000669 int i;
670#endif
Stephen Rothwell81e70092005-10-18 11:17:58 +1000671
672 /*
673 * restore general registers but not including MSR or SOFTE. Also
674 * take care of keeping r2 (TLS) intact if not a signal
675 */
676 if (!sig)
677 save_r2 = (unsigned int)regs->gpr[2];
678 err = restore_general_regs(regs, sr);
Al Viro9a81c162010-09-20 21:48:57 +0100679 regs->trap = 0;
Paul Mackerrasfab5db92006-06-07 16:14:40 +1000680 err |= __get_user(msr, &sr->mc_gregs[PT_MSR]);
Stephen Rothwell81e70092005-10-18 11:17:58 +1000681 if (!sig)
682 regs->gpr[2] = (unsigned long) save_r2;
683 if (err)
684 return 1;
685
Paul Mackerrasfab5db92006-06-07 16:14:40 +1000686 /* if doing signal return, restore the previous little-endian mode */
687 if (sig)
688 regs->msr = (regs->msr & ~MSR_LE) | (msr & MSR_LE);
689
Stephen Rothwell81e70092005-10-18 11:17:58 +1000690#ifdef CONFIG_ALTIVEC
Michael Neulingc6e67712008-06-25 14:07:18 +1000691 /*
692 * Force the process to reload the altivec registers from
693 * current->thread when it next does altivec instructions
694 */
Stephen Rothwell81e70092005-10-18 11:17:58 +1000695 regs->msr &= ~MSR_VEC;
Paul Mackerrasfab5db92006-06-07 16:14:40 +1000696 if (msr & MSR_VEC) {
Stephen Rothwell81e70092005-10-18 11:17:58 +1000697 /* restore altivec registers from the stack */
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000698 if (__copy_from_user(&current->thread.vr_state, &sr->mc_vregs,
Stephen Rothwell81e70092005-10-18 11:17:58 +1000699 sizeof(sr->mc_vregs)))
700 return 1;
701 } else if (current->thread.used_vr)
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000702 memset(&current->thread.vr_state, 0,
703 ELF_NVRREG * sizeof(vector128));
Stephen Rothwell81e70092005-10-18 11:17:58 +1000704
705 /* Always get VRSAVE back */
706 if (__get_user(current->thread.vrsave, (u32 __user *)&sr->mc_vregs[32]))
707 return 1;
Paul Mackerras408a7e02013-08-05 14:13:16 +1000708 if (cpu_has_feature(CPU_FTR_ALTIVEC))
709 mtspr(SPRN_VRSAVE, current->thread.vrsave);
Stephen Rothwell81e70092005-10-18 11:17:58 +1000710#endif /* CONFIG_ALTIVEC */
Michael Neuling6a274c02008-07-02 14:06:37 +1000711 if (copy_fpr_from_user(current, &sr->mc_fregs))
712 return 1;
Stephen Rothwell81e70092005-10-18 11:17:58 +1000713
Michael Neulingc6e67712008-06-25 14:07:18 +1000714#ifdef CONFIG_VSX
Michael Neulingce48b212008-06-25 14:07:18 +1000715 /*
716 * Force the process to reload the VSX registers from
717 * current->thread when it next does VSX instruction.
718 */
719 regs->msr &= ~MSR_VSX;
720 if (msr & MSR_VSX) {
721 /*
722 * Restore altivec registers from the stack to a local
723 * buffer, then write this out to the thread_struct
724 */
Michael Neuling6a274c02008-07-02 14:06:37 +1000725 if (copy_vsx_from_user(current, &sr->mc_vsregs))
Michael Neulingce48b212008-06-25 14:07:18 +1000726 return 1;
Michael Neulingce48b212008-06-25 14:07:18 +1000727 } else if (current->thread.used_vsr)
728 for (i = 0; i < 32 ; i++)
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000729 current->thread.fp_state.fpr[i][TS_VSRLOWOFFSET] = 0;
Michael Neulingc6e67712008-06-25 14:07:18 +1000730#endif /* CONFIG_VSX */
731 /*
732 * force the process to reload the FP registers from
733 * current->thread when it next does FP instructions
734 */
735 regs->msr &= ~(MSR_FP | MSR_FE0 | MSR_FE1);
736
Stephen Rothwell81e70092005-10-18 11:17:58 +1000737#ifdef CONFIG_SPE
738 /* force the process to reload the spe registers from
739 current->thread when it next does spe instructions */
740 regs->msr &= ~MSR_SPE;
Paul Mackerrasfab5db92006-06-07 16:14:40 +1000741 if (msr & MSR_SPE) {
Stephen Rothwell81e70092005-10-18 11:17:58 +1000742 /* restore spe registers from the stack */
743 if (__copy_from_user(current->thread.evr, &sr->mc_vregs,
744 ELF_NEVRREG * sizeof(u32)))
745 return 1;
746 } else if (current->thread.used_spe)
747 memset(current->thread.evr, 0, ELF_NEVRREG * sizeof(u32));
748
749 /* Always get SPEFSCR back */
750 if (__get_user(current->thread.spefscr, (u32 __user *)&sr->mc_vregs + ELF_NEVRREG))
751 return 1;
752#endif /* CONFIG_SPE */
753
Stephen Rothwell81e70092005-10-18 11:17:58 +1000754 return 0;
755}
756
Michael Neuling2b0a5762013-02-13 16:21:41 +0000757#ifdef CONFIG_PPC_TRANSACTIONAL_MEM
758/*
759 * Restore the current user register values from the user stack, except for
760 * MSR, and recheckpoint the original checkpointed register state for processes
761 * in transactions.
762 */
763static long restore_tm_user_regs(struct pt_regs *regs,
764 struct mcontext __user *sr,
765 struct mcontext __user *tm_sr)
766{
767 long err;
Michael Neuling2c27a182013-06-09 21:23:17 +1000768 unsigned long msr, msr_hi;
Michael Neuling2b0a5762013-02-13 16:21:41 +0000769#ifdef CONFIG_VSX
770 int i;
771#endif
772
773 /*
774 * restore general registers but not including MSR or SOFTE. Also
775 * take care of keeping r2 (TLS) intact if not a signal.
776 * See comment in signal_64.c:restore_tm_sigcontexts();
777 * TFHAR is restored from the checkpointed NIP; TEXASR and TFIAR
778 * were set by the signal delivery.
779 */
780 err = restore_general_regs(regs, tm_sr);
781 err |= restore_general_regs(&current->thread.ckpt_regs, sr);
782
783 err |= __get_user(current->thread.tm_tfhar, &sr->mc_gregs[PT_NIP]);
784
785 err |= __get_user(msr, &sr->mc_gregs[PT_MSR]);
786 if (err)
787 return 1;
788
789 /* Restore the previous little-endian mode */
790 regs->msr = (regs->msr & ~MSR_LE) | (msr & MSR_LE);
791
Michael Neuling2b0a5762013-02-13 16:21:41 +0000792#ifdef CONFIG_ALTIVEC
793 regs->msr &= ~MSR_VEC;
794 if (msr & MSR_VEC) {
795 /* restore altivec registers from the stack */
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000796 if (__copy_from_user(&current->thread.vr_state, &sr->mc_vregs,
Michael Neuling2b0a5762013-02-13 16:21:41 +0000797 sizeof(sr->mc_vregs)) ||
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000798 __copy_from_user(&current->thread.transact_vr,
Michael Neuling2b0a5762013-02-13 16:21:41 +0000799 &tm_sr->mc_vregs,
800 sizeof(sr->mc_vregs)))
801 return 1;
802 } else if (current->thread.used_vr) {
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000803 memset(&current->thread.vr_state, 0,
804 ELF_NVRREG * sizeof(vector128));
805 memset(&current->thread.transact_vr, 0,
Michael Neuling2b0a5762013-02-13 16:21:41 +0000806 ELF_NVRREG * sizeof(vector128));
807 }
808
809 /* Always get VRSAVE back */
810 if (__get_user(current->thread.vrsave,
811 (u32 __user *)&sr->mc_vregs[32]) ||
812 __get_user(current->thread.transact_vrsave,
813 (u32 __user *)&tm_sr->mc_vregs[32]))
814 return 1;
Paul Mackerras408a7e02013-08-05 14:13:16 +1000815 if (cpu_has_feature(CPU_FTR_ALTIVEC))
816 mtspr(SPRN_VRSAVE, current->thread.vrsave);
Michael Neuling2b0a5762013-02-13 16:21:41 +0000817#endif /* CONFIG_ALTIVEC */
818
819 regs->msr &= ~(MSR_FP | MSR_FE0 | MSR_FE1);
820
821 if (copy_fpr_from_user(current, &sr->mc_fregs) ||
822 copy_transact_fpr_from_user(current, &tm_sr->mc_fregs))
823 return 1;
824
825#ifdef CONFIG_VSX
826 regs->msr &= ~MSR_VSX;
827 if (msr & MSR_VSX) {
828 /*
829 * Restore altivec registers from the stack to a local
830 * buffer, then write this out to the thread_struct
831 */
832 if (copy_vsx_from_user(current, &sr->mc_vsregs) ||
833 copy_transact_vsx_from_user(current, &tm_sr->mc_vsregs))
834 return 1;
835 } else if (current->thread.used_vsr)
836 for (i = 0; i < 32 ; i++) {
Paul Mackerrasde79f7b2013-09-10 20:20:42 +1000837 current->thread.fp_state.fpr[i][TS_VSRLOWOFFSET] = 0;
838 current->thread.transact_fp.fpr[i][TS_VSRLOWOFFSET] = 0;
Michael Neuling2b0a5762013-02-13 16:21:41 +0000839 }
840#endif /* CONFIG_VSX */
841
842#ifdef CONFIG_SPE
843 /* SPE regs are not checkpointed with TM, so this section is
844 * simply the same as in restore_user_regs().
845 */
846 regs->msr &= ~MSR_SPE;
847 if (msr & MSR_SPE) {
848 if (__copy_from_user(current->thread.evr, &sr->mc_vregs,
849 ELF_NEVRREG * sizeof(u32)))
850 return 1;
851 } else if (current->thread.used_spe)
852 memset(current->thread.evr, 0, ELF_NEVRREG * sizeof(u32));
853
854 /* Always get SPEFSCR back */
855 if (__get_user(current->thread.spefscr, (u32 __user *)&sr->mc_vregs
856 + ELF_NEVRREG))
857 return 1;
858#endif /* CONFIG_SPE */
859
Michael Neulingd2b9d2a2015-11-19 15:44:44 +1100860 /* Get the top half of the MSR from the user context */
861 if (__get_user(msr_hi, &tm_sr->mc_gregs[PT_MSR]))
862 return 1;
863 msr_hi <<= 32;
864 /* If TM bits are set to the reserved value, it's an invalid context */
865 if (MSR_TM_RESV(msr_hi))
866 return 1;
867 /* Pull in the MSR TM bits from the user context */
868 regs->msr = (regs->msr & ~MSR_TS_MASK) | (msr_hi & MSR_TS_MASK);
Michael Neuling2b0a5762013-02-13 16:21:41 +0000869 /* Now, recheckpoint. This loads up all of the checkpointed (older)
870 * registers, including FP and V[S]Rs. After recheckpointing, the
871 * transactional versions should be loaded.
872 */
873 tm_enable();
Michael Neulinge6b8fd02014-04-04 20:19:48 +1100874 /* Make sure the transaction is marked as failed */
875 current->thread.tm_texasr |= TEXASR_FS;
Michael Neuling2b0a5762013-02-13 16:21:41 +0000876 /* This loads the checkpointed FP/VEC state, if used */
877 tm_recheckpoint(&current->thread, msr);
Michael Neuling2b0a5762013-02-13 16:21:41 +0000878
879 /* This loads the speculative FP/VEC state, if used */
880 if (msr & MSR_FP) {
881 do_load_up_transact_fpu(&current->thread);
882 regs->msr |= (MSR_FP | current->thread.fpexc_mode);
883 }
Michael Neulingf110c0c2013-04-09 16:18:55 +1000884#ifdef CONFIG_ALTIVEC
Michael Neuling2b0a5762013-02-13 16:21:41 +0000885 if (msr & MSR_VEC) {
886 do_load_up_transact_altivec(&current->thread);
887 regs->msr |= MSR_VEC;
888 }
Michael Neulingf110c0c2013-04-09 16:18:55 +1000889#endif
Michael Neuling2b0a5762013-02-13 16:21:41 +0000890
891 return 0;
892}
893#endif
894
Stephen Rothwell81e70092005-10-18 11:17:58 +1000895#ifdef CONFIG_PPC64
Al Viroce395962013-10-13 17:23:53 -0400896int copy_siginfo_to_user32(struct compat_siginfo __user *d, const siginfo_t *s)
Stephen Rothwell81e70092005-10-18 11:17:58 +1000897{
898 int err;
899
900 if (!access_ok (VERIFY_WRITE, d, sizeof(*d)))
901 return -EFAULT;
902
903 /* If you change siginfo_t structure, please be sure
904 * this code is fixed accordingly.
905 * It should never copy any pad contained in the structure
906 * to avoid security leaks, but must copy the generic
907 * 3 ints plus the relevant union member.
908 * This routine must convert siginfo from 64bit to 32bit as well
909 * at the same time.
910 */
911 err = __put_user(s->si_signo, &d->si_signo);
912 err |= __put_user(s->si_errno, &d->si_errno);
913 err |= __put_user((short)s->si_code, &d->si_code);
914 if (s->si_code < 0)
915 err |= __copy_to_user(&d->_sifields._pad, &s->_sifields._pad,
916 SI_PAD_SIZE32);
917 else switch(s->si_code >> 16) {
918 case __SI_CHLD >> 16:
919 err |= __put_user(s->si_pid, &d->si_pid);
920 err |= __put_user(s->si_uid, &d->si_uid);
921 err |= __put_user(s->si_utime, &d->si_utime);
922 err |= __put_user(s->si_stime, &d->si_stime);
923 err |= __put_user(s->si_status, &d->si_status);
924 break;
925 case __SI_FAULT >> 16:
926 err |= __put_user((unsigned int)(unsigned long)s->si_addr,
927 &d->si_addr);
928 break;
929 case __SI_POLL >> 16:
930 err |= __put_user(s->si_band, &d->si_band);
931 err |= __put_user(s->si_fd, &d->si_fd);
932 break;
933 case __SI_TIMER >> 16:
934 err |= __put_user(s->si_tid, &d->si_tid);
935 err |= __put_user(s->si_overrun, &d->si_overrun);
936 err |= __put_user(s->si_int, &d->si_int);
937 break;
Michael Ellerman1b60bab2015-07-23 20:21:08 +1000938 case __SI_SYS >> 16:
939 err |= __put_user(ptr_to_compat(s->si_call_addr), &d->si_call_addr);
940 err |= __put_user(s->si_syscall, &d->si_syscall);
941 err |= __put_user(s->si_arch, &d->si_arch);
942 break;
Stephen Rothwell81e70092005-10-18 11:17:58 +1000943 case __SI_RT >> 16: /* This is not generated by the kernel as of now. */
944 case __SI_MESGQ >> 16:
945 err |= __put_user(s->si_int, &d->si_int);
946 /* fallthrough */
947 case __SI_KILL >> 16:
948 default:
949 err |= __put_user(s->si_pid, &d->si_pid);
950 err |= __put_user(s->si_uid, &d->si_uid);
951 break;
952 }
953 return err;
954}
955
956#define copy_siginfo_to_user copy_siginfo_to_user32
957
Roland McGrath9c0c44d2008-04-20 08:19:24 +1000958int copy_siginfo_from_user32(siginfo_t *to, struct compat_siginfo __user *from)
959{
Roland McGrath9c0c44d2008-04-20 08:19:24 +1000960 if (copy_from_user(to, from, 3*sizeof(int)) ||
961 copy_from_user(to->_sifields._pad,
962 from->_sifields._pad, SI_PAD_SIZE32))
963 return -EFAULT;
964
965 return 0;
966}
Stephen Rothwell81e70092005-10-18 11:17:58 +1000967#endif /* CONFIG_PPC64 */
968
Stephen Rothwell81e70092005-10-18 11:17:58 +1000969/*
970 * Set up a signal frame for a "real-time" signal handler
971 * (one which gets siginfo).
972 */
Richard Weinberger129b69d2014-03-02 14:46:11 +0100973int handle_rt_signal32(struct ksignal *ksig, sigset_t *oldset,
974 struct pt_regs *regs)
Stephen Rothwell81e70092005-10-18 11:17:58 +1000975{
976 struct rt_sigframe __user *rt_sf;
977 struct mcontext __user *frame;
Michael Neuling1d25f112013-06-09 21:23:15 +1000978 struct mcontext __user *tm_frame = NULL;
Olof Johanssond0c3d532007-10-12 10:20:07 +1000979 void __user *addr;
Benjamin Herrenschmidta3f61dc2007-06-04 17:22:48 +1000980 unsigned long newsp = 0;
Michael Neuling2b0a5762013-02-13 16:21:41 +0000981 int sigret;
982 unsigned long tramp;
Stephen Rothwell81e70092005-10-18 11:17:58 +1000983
984 /* Set up Signal Frame */
985 /* Put a Real Time Context onto stack */
Richard Weinberger059ade62014-03-05 16:25:55 +0100986 rt_sf = get_sigframe(ksig, get_tm_stackpointer(regs), sizeof(*rt_sf), 1);
Olof Johanssond0c3d532007-10-12 10:20:07 +1000987 addr = rt_sf;
Benjamin Herrenschmidta3f61dc2007-06-04 17:22:48 +1000988 if (unlikely(rt_sf == NULL))
Stephen Rothwell81e70092005-10-18 11:17:58 +1000989 goto badframe;
990
991 /* Put the siginfo & fill in most of the ucontext */
Richard Weinberger129b69d2014-03-02 14:46:11 +0100992 if (copy_siginfo_to_user(&rt_sf->info, &ksig->info)
Stephen Rothwell81e70092005-10-18 11:17:58 +1000993 || __put_user(0, &rt_sf->uc.uc_flags)
Al Viro7cce2462012-12-23 03:26:46 -0500994 || __save_altstack(&rt_sf->uc.uc_stack, regs->gpr[1])
Stephen Rothwell81e70092005-10-18 11:17:58 +1000995 || __put_user(to_user_ptr(&rt_sf->uc.uc_mcontext),
996 &rt_sf->uc.uc_regs)
997 || put_sigset_t(&rt_sf->uc.uc_sigmask, oldset))
998 goto badframe;
999
1000 /* Save user registers on the stack */
1001 frame = &rt_sf->uc.uc_mcontext;
Olof Johanssond0c3d532007-10-12 10:20:07 +10001002 addr = frame;
Benjamin Herrenschmidta5bba932006-05-30 13:51:37 +10001003 if (vdso32_rt_sigtramp && current->mm->context.vdso_base) {
Michael Neuling2b0a5762013-02-13 16:21:41 +00001004 sigret = 0;
1005 tramp = current->mm->context.vdso_base + vdso32_rt_sigtramp;
Benjamin Herrenschmidta7f290d2005-11-11 21:15:21 +11001006 } else {
Michael Neuling2b0a5762013-02-13 16:21:41 +00001007 sigret = __NR_rt_sigreturn;
1008 tramp = (unsigned long) frame->tramp;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001009 }
Paul Mackerrascc657f52005-11-14 21:55:15 +11001010
Michael Neuling2b0a5762013-02-13 16:21:41 +00001011#ifdef CONFIG_PPC_TRANSACTIONAL_MEM
Michael Neuling1d25f112013-06-09 21:23:15 +10001012 tm_frame = &rt_sf->uc_transact.uc_mcontext;
Michael Neuling2b0a5762013-02-13 16:21:41 +00001013 if (MSR_TM_ACTIVE(regs->msr)) {
Paul Mackerrasd765ff22014-01-29 16:33:56 +11001014 if (__put_user((unsigned long)&rt_sf->uc_transact,
1015 &rt_sf->uc.uc_link) ||
1016 __put_user((unsigned long)tm_frame,
1017 &rt_sf->uc_transact.uc_regs))
1018 goto badframe;
Michael Neuling1d25f112013-06-09 21:23:15 +10001019 if (save_tm_user_regs(regs, frame, tm_frame, sigret))
Michael Neuling2b0a5762013-02-13 16:21:41 +00001020 goto badframe;
1021 }
1022 else
1023#endif
Michael Neuling1d25f112013-06-09 21:23:15 +10001024 {
Paul Mackerrasd765ff22014-01-29 16:33:56 +11001025 if (__put_user(0, &rt_sf->uc.uc_link))
1026 goto badframe;
Michael Neuling1d25f112013-06-09 21:23:15 +10001027 if (save_user_regs(regs, frame, tm_frame, sigret, 1))
Michael Neuling2b0a5762013-02-13 16:21:41 +00001028 goto badframe;
Michael Neuling1d25f112013-06-09 21:23:15 +10001029 }
Michael Neuling2b0a5762013-02-13 16:21:41 +00001030 regs->link = tramp;
1031
Paul Mackerrasde79f7b2013-09-10 20:20:42 +10001032 current->thread.fp_state.fpscr = 0; /* turn off all fp exceptions */
Paul Mackerrascc657f52005-11-14 21:55:15 +11001033
Benjamin Herrenschmidta3f61dc2007-06-04 17:22:48 +10001034 /* create a stack frame for the caller of the handler */
1035 newsp = ((unsigned long)rt_sf) - (__SIGNAL_FRAMESIZE + 16);
Olof Johanssond0c3d532007-10-12 10:20:07 +10001036 addr = (void __user *)regs->gpr[1];
Paul Mackerrase2b55302005-10-22 14:46:33 +10001037 if (put_user(regs->gpr[1], (u32 __user *)newsp))
Stephen Rothwell81e70092005-10-18 11:17:58 +10001038 goto badframe;
Benjamin Herrenschmidta3f61dc2007-06-04 17:22:48 +10001039
1040 /* Fill registers for signal handler */
Stephen Rothwell81e70092005-10-18 11:17:58 +10001041 regs->gpr[1] = newsp;
Richard Weinberger129b69d2014-03-02 14:46:11 +01001042 regs->gpr[3] = ksig->sig;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001043 regs->gpr[4] = (unsigned long) &rt_sf->info;
1044 regs->gpr[5] = (unsigned long) &rt_sf->uc;
1045 regs->gpr[6] = (unsigned long) rt_sf;
Richard Weinberger129b69d2014-03-02 14:46:11 +01001046 regs->nip = (unsigned long) ksig->ka.sa.sa_handler;
Anton Blancharde871c6b2013-09-23 12:04:43 +10001047 /* enter the signal handler in native-endian mode */
Paul Mackerrasfab5db92006-06-07 16:14:40 +10001048 regs->msr &= ~MSR_LE;
Anton Blancharde871c6b2013-09-23 12:04:43 +10001049 regs->msr |= (MSR_KERNEL & MSR_LE);
Richard Weinberger129b69d2014-03-02 14:46:11 +01001050 return 0;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001051
1052badframe:
Christian Dietrich76462232011-06-04 05:36:54 +00001053 if (show_unhandled_signals)
1054 printk_ratelimited(KERN_INFO
1055 "%s[%d]: bad frame in handle_rt_signal32: "
1056 "%p nip %08lx lr %08lx\n",
1057 current->comm, current->pid,
1058 addr, regs->nip, regs->link);
Olof Johanssond0c3d532007-10-12 10:20:07 +10001059
Richard Weinberger129b69d2014-03-02 14:46:11 +01001060 return 1;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001061}
1062
1063static int do_setcontext(struct ucontext __user *ucp, struct pt_regs *regs, int sig)
1064{
1065 sigset_t set;
1066 struct mcontext __user *mcp;
1067
1068 if (get_sigset_t(&set, &ucp->uc_sigmask))
1069 return -EFAULT;
1070#ifdef CONFIG_PPC64
1071 {
1072 u32 cmcp;
1073
1074 if (__get_user(cmcp, &ucp->uc_regs))
1075 return -EFAULT;
1076 mcp = (struct mcontext __user *)(u64)cmcp;
Paul Mackerras7c85d1f2006-06-09 13:02:59 +10001077 /* no need to check access_ok(mcp), since mcp < 4GB */
Stephen Rothwell81e70092005-10-18 11:17:58 +10001078 }
1079#else
1080 if (__get_user(mcp, &ucp->uc_regs))
1081 return -EFAULT;
Paul Mackerras7c85d1f2006-06-09 13:02:59 +10001082 if (!access_ok(VERIFY_READ, mcp, sizeof(*mcp)))
1083 return -EFAULT;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001084#endif
Al Viro17440f12012-04-27 14:09:19 -04001085 set_current_blocked(&set);
Stephen Rothwell81e70092005-10-18 11:17:58 +10001086 if (restore_user_regs(regs, mcp, sig))
1087 return -EFAULT;
1088
1089 return 0;
1090}
1091
Michael Neuling2b0a5762013-02-13 16:21:41 +00001092#ifdef CONFIG_PPC_TRANSACTIONAL_MEM
1093static int do_setcontext_tm(struct ucontext __user *ucp,
1094 struct ucontext __user *tm_ucp,
1095 struct pt_regs *regs)
1096{
1097 sigset_t set;
1098 struct mcontext __user *mcp;
1099 struct mcontext __user *tm_mcp;
1100 u32 cmcp;
1101 u32 tm_cmcp;
1102
1103 if (get_sigset_t(&set, &ucp->uc_sigmask))
1104 return -EFAULT;
1105
1106 if (__get_user(cmcp, &ucp->uc_regs) ||
1107 __get_user(tm_cmcp, &tm_ucp->uc_regs))
1108 return -EFAULT;
1109 mcp = (struct mcontext __user *)(u64)cmcp;
1110 tm_mcp = (struct mcontext __user *)(u64)tm_cmcp;
1111 /* no need to check access_ok(mcp), since mcp < 4GB */
1112
1113 set_current_blocked(&set);
1114 if (restore_tm_user_regs(regs, mcp, tm_mcp))
1115 return -EFAULT;
1116
1117 return 0;
1118}
1119#endif
1120
Stephen Rothwell81e70092005-10-18 11:17:58 +10001121long sys_swapcontext(struct ucontext __user *old_ctx,
Paul Mackerras1bd79332006-03-08 13:24:22 +11001122 struct ucontext __user *new_ctx,
1123 int ctx_size, int r6, int r7, int r8, struct pt_regs *regs)
Stephen Rothwell81e70092005-10-18 11:17:58 +10001124{
1125 unsigned char tmp;
Michael Neuling16c29d12008-10-23 00:42:36 +00001126 int ctx_has_vsx_region = 0;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001127
Michael Neulingc1cb2992008-07-08 18:43:41 +10001128#ifdef CONFIG_PPC64
1129 unsigned long new_msr = 0;
1130
Andreas Schwab77eb50a2008-11-06 00:49:00 +00001131 if (new_ctx) {
1132 struct mcontext __user *mcp;
1133 u32 cmcp;
1134
1135 /*
1136 * Get pointer to the real mcontext. No need for
1137 * access_ok since we are dealing with compat
1138 * pointers.
1139 */
1140 if (__get_user(cmcp, &new_ctx->uc_regs))
1141 return -EFAULT;
1142 mcp = (struct mcontext __user *)(u64)cmcp;
1143 if (__get_user(new_msr, &mcp->mc_gregs[PT_MSR]))
1144 return -EFAULT;
1145 }
Michael Neulingc1cb2992008-07-08 18:43:41 +10001146 /*
1147 * Check that the context is not smaller than the original
1148 * size (with VMX but without VSX)
1149 */
1150 if (ctx_size < UCONTEXTSIZEWITHOUTVSX)
1151 return -EINVAL;
1152 /*
1153 * If the new context state sets the MSR VSX bits but
1154 * it doesn't provide VSX state.
1155 */
1156 if ((ctx_size < sizeof(struct ucontext)) &&
1157 (new_msr & MSR_VSX))
1158 return -EINVAL;
Michael Neuling16c29d12008-10-23 00:42:36 +00001159 /* Does the context have enough room to store VSX data? */
1160 if (ctx_size >= sizeof(struct ucontext))
1161 ctx_has_vsx_region = 1;
Michael Neulingc1cb2992008-07-08 18:43:41 +10001162#else
Stephen Rothwell81e70092005-10-18 11:17:58 +10001163 /* Context size is for future use. Right now, we only make sure
1164 * we are passed something we understand
1165 */
1166 if (ctx_size < sizeof(struct ucontext))
1167 return -EINVAL;
Michael Neulingc1cb2992008-07-08 18:43:41 +10001168#endif
Stephen Rothwell81e70092005-10-18 11:17:58 +10001169 if (old_ctx != NULL) {
Paul Mackerras1c9bb1a2006-12-20 13:57:06 +11001170 struct mcontext __user *mctx;
1171
1172 /*
1173 * old_ctx might not be 16-byte aligned, in which
1174 * case old_ctx->uc_mcontext won't be either.
1175 * Because we have the old_ctx->uc_pad2 field
1176 * before old_ctx->uc_mcontext, we need to round down
1177 * from &old_ctx->uc_mcontext to a 16-byte boundary.
1178 */
1179 mctx = (struct mcontext __user *)
1180 ((unsigned long) &old_ctx->uc_mcontext & ~0xfUL);
Michael Neuling16c29d12008-10-23 00:42:36 +00001181 if (!access_ok(VERIFY_WRITE, old_ctx, ctx_size)
Michael Neuling1d25f112013-06-09 21:23:15 +10001182 || save_user_regs(regs, mctx, NULL, 0, ctx_has_vsx_region)
Stephen Rothwell81e70092005-10-18 11:17:58 +10001183 || put_sigset_t(&old_ctx->uc_sigmask, &current->blocked)
Paul Mackerras1c9bb1a2006-12-20 13:57:06 +11001184 || __put_user(to_user_ptr(mctx), &old_ctx->uc_regs))
Stephen Rothwell81e70092005-10-18 11:17:58 +10001185 return -EFAULT;
1186 }
1187 if (new_ctx == NULL)
1188 return 0;
Michael Neuling16c29d12008-10-23 00:42:36 +00001189 if (!access_ok(VERIFY_READ, new_ctx, ctx_size)
Stephen Rothwell81e70092005-10-18 11:17:58 +10001190 || __get_user(tmp, (u8 __user *) new_ctx)
Michael Neuling16c29d12008-10-23 00:42:36 +00001191 || __get_user(tmp, (u8 __user *) new_ctx + ctx_size - 1))
Stephen Rothwell81e70092005-10-18 11:17:58 +10001192 return -EFAULT;
1193
1194 /*
1195 * If we get a fault copying the context into the kernel's
1196 * image of the user's registers, we can't just return -EFAULT
1197 * because the user's registers will be corrupted. For instance
1198 * the NIP value may have been updated but not some of the
1199 * other registers. Given that we have done the access_ok
1200 * and successfully read the first and last bytes of the region
1201 * above, this should only happen in an out-of-memory situation
1202 * or if another thread unmaps the region containing the context.
1203 * We kill the task with a SIGSEGV in this situation.
1204 */
1205 if (do_setcontext(new_ctx, regs, 0))
1206 do_exit(SIGSEGV);
David Woodhouse401d1f02005-11-15 18:52:18 +00001207
1208 set_thread_flag(TIF_RESTOREALL);
Stephen Rothwell81e70092005-10-18 11:17:58 +10001209 return 0;
1210}
1211
1212long sys_rt_sigreturn(int r3, int r4, int r5, int r6, int r7, int r8,
1213 struct pt_regs *regs)
1214{
1215 struct rt_sigframe __user *rt_sf;
Michael Neuling2b0a5762013-02-13 16:21:41 +00001216#ifdef CONFIG_PPC_TRANSACTIONAL_MEM
1217 struct ucontext __user *uc_transact;
1218 unsigned long msr_hi;
1219 unsigned long tmp;
1220 int tm_restore = 0;
1221#endif
Stephen Rothwell81e70092005-10-18 11:17:58 +10001222 /* Always make any pending restarted system calls return -EINTR */
Andy Lutomirskif56141e2015-02-12 15:01:14 -08001223 current->restart_block.fn = do_no_restart_syscall;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001224
1225 rt_sf = (struct rt_sigframe __user *)
1226 (regs->gpr[1] + __SIGNAL_FRAMESIZE + 16);
1227 if (!access_ok(VERIFY_READ, rt_sf, sizeof(*rt_sf)))
1228 goto bad;
Cyril Bur78a3e882016-08-23 10:46:17 +10001229
Michael Neuling2b0a5762013-02-13 16:21:41 +00001230#ifdef CONFIG_PPC_TRANSACTIONAL_MEM
Cyril Bur78a3e882016-08-23 10:46:17 +10001231 /*
1232 * If there is a transactional state then throw it away.
1233 * The purpose of a sigreturn is to destroy all traces of the
1234 * signal frame, this includes any transactional state created
1235 * within in. We only check for suspended as we can never be
1236 * active in the kernel, we are active, there is nothing better to
1237 * do than go ahead and Bad Thing later.
1238 * The cause is not important as there will never be a
1239 * recheckpoint so it's not user visible.
1240 */
1241 if (MSR_TM_SUSPENDED(mfmsr()))
1242 tm_reclaim_current(0);
1243
Michael Neuling2b0a5762013-02-13 16:21:41 +00001244 if (__get_user(tmp, &rt_sf->uc.uc_link))
1245 goto bad;
1246 uc_transact = (struct ucontext __user *)(uintptr_t)tmp;
1247 if (uc_transact) {
1248 u32 cmcp;
1249 struct mcontext __user *mcp;
1250
1251 if (__get_user(cmcp, &uc_transact->uc_regs))
1252 return -EFAULT;
1253 mcp = (struct mcontext __user *)(u64)cmcp;
1254 /* The top 32 bits of the MSR are stashed in the transactional
1255 * ucontext. */
1256 if (__get_user(msr_hi, &mcp->mc_gregs[PT_MSR]))
1257 goto bad;
1258
Michael Neuling55e43412013-06-09 21:23:18 +10001259 if (MSR_TM_ACTIVE(msr_hi<<32)) {
Michael Neuling2b0a5762013-02-13 16:21:41 +00001260 /* We only recheckpoint on return if we're
1261 * transaction.
1262 */
1263 tm_restore = 1;
1264 if (do_setcontext_tm(&rt_sf->uc, uc_transact, regs))
1265 goto bad;
1266 }
1267 }
1268 if (!tm_restore)
1269 /* Fall through, for non-TM restore */
1270#endif
Stephen Rothwell81e70092005-10-18 11:17:58 +10001271 if (do_setcontext(&rt_sf->uc, regs, 1))
1272 goto bad;
1273
1274 /*
1275 * It's not clear whether or why it is desirable to save the
1276 * sigaltstack setting on signal delivery and restore it on
1277 * signal return. But other architectures do this and we have
1278 * always done it up until now so it is probably better not to
1279 * change it. -- paulus
1280 */
1281#ifdef CONFIG_PPC64
Al Viro7cce2462012-12-23 03:26:46 -05001282 if (compat_restore_altstack(&rt_sf->uc.uc_stack))
1283 goto bad;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001284#else
Al Viro7cce2462012-12-23 03:26:46 -05001285 if (restore_altstack(&rt_sf->uc.uc_stack))
1286 goto bad;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001287#endif
David Woodhouse401d1f02005-11-15 18:52:18 +00001288 set_thread_flag(TIF_RESTOREALL);
1289 return 0;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001290
1291 bad:
Christian Dietrich76462232011-06-04 05:36:54 +00001292 if (show_unhandled_signals)
1293 printk_ratelimited(KERN_INFO
1294 "%s[%d]: bad frame in sys_rt_sigreturn: "
1295 "%p nip %08lx lr %08lx\n",
1296 current->comm, current->pid,
1297 rt_sf, regs->nip, regs->link);
Olof Johanssond0c3d532007-10-12 10:20:07 +10001298
Stephen Rothwell81e70092005-10-18 11:17:58 +10001299 force_sig(SIGSEGV, current);
1300 return 0;
1301}
1302
1303#ifdef CONFIG_PPC32
1304int sys_debug_setcontext(struct ucontext __user *ctx,
1305 int ndbg, struct sig_dbg_op __user *dbg,
1306 int r6, int r7, int r8,
1307 struct pt_regs *regs)
1308{
1309 struct sig_dbg_op op;
1310 int i;
Paul Mackerras7c85d1f2006-06-09 13:02:59 +10001311 unsigned char tmp;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001312 unsigned long new_msr = regs->msr;
Dave Kleikamp172ae2e2010-02-08 11:50:57 +00001313#ifdef CONFIG_PPC_ADV_DEBUG_REGS
Bharat Bhushan51ae8d42013-07-04 11:45:46 +05301314 unsigned long new_dbcr0 = current->thread.debug.dbcr0;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001315#endif
1316
1317 for (i=0; i<ndbg; i++) {
Paul Mackerras7c85d1f2006-06-09 13:02:59 +10001318 if (copy_from_user(&op, dbg + i, sizeof(op)))
Stephen Rothwell81e70092005-10-18 11:17:58 +10001319 return -EFAULT;
1320 switch (op.dbg_type) {
1321 case SIG_DBG_SINGLE_STEPPING:
Dave Kleikamp172ae2e2010-02-08 11:50:57 +00001322#ifdef CONFIG_PPC_ADV_DEBUG_REGS
Stephen Rothwell81e70092005-10-18 11:17:58 +10001323 if (op.dbg_value) {
1324 new_msr |= MSR_DE;
1325 new_dbcr0 |= (DBCR0_IDM | DBCR0_IC);
1326 } else {
Dave Kleikamp3bffb652010-02-08 11:51:18 +00001327 new_dbcr0 &= ~DBCR0_IC;
1328 if (!DBCR_ACTIVE_EVENTS(new_dbcr0,
Bharat Bhushan51ae8d42013-07-04 11:45:46 +05301329 current->thread.debug.dbcr1)) {
Dave Kleikamp3bffb652010-02-08 11:51:18 +00001330 new_msr &= ~MSR_DE;
1331 new_dbcr0 &= ~DBCR0_IDM;
1332 }
Stephen Rothwell81e70092005-10-18 11:17:58 +10001333 }
1334#else
1335 if (op.dbg_value)
1336 new_msr |= MSR_SE;
1337 else
1338 new_msr &= ~MSR_SE;
1339#endif
1340 break;
1341 case SIG_DBG_BRANCH_TRACING:
Dave Kleikamp172ae2e2010-02-08 11:50:57 +00001342#ifdef CONFIG_PPC_ADV_DEBUG_REGS
Stephen Rothwell81e70092005-10-18 11:17:58 +10001343 return -EINVAL;
1344#else
1345 if (op.dbg_value)
1346 new_msr |= MSR_BE;
1347 else
1348 new_msr &= ~MSR_BE;
1349#endif
1350 break;
1351
1352 default:
1353 return -EINVAL;
1354 }
1355 }
1356
1357 /* We wait until here to actually install the values in the
1358 registers so if we fail in the above loop, it will not
1359 affect the contents of these registers. After this point,
1360 failure is a problem, anyway, and it's very unlikely unless
1361 the user is really doing something wrong. */
1362 regs->msr = new_msr;
Dave Kleikamp172ae2e2010-02-08 11:50:57 +00001363#ifdef CONFIG_PPC_ADV_DEBUG_REGS
Bharat Bhushan51ae8d42013-07-04 11:45:46 +05301364 current->thread.debug.dbcr0 = new_dbcr0;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001365#endif
1366
Paul Mackerras7c85d1f2006-06-09 13:02:59 +10001367 if (!access_ok(VERIFY_READ, ctx, sizeof(*ctx))
1368 || __get_user(tmp, (u8 __user *) ctx)
1369 || __get_user(tmp, (u8 __user *) (ctx + 1) - 1))
1370 return -EFAULT;
1371
Stephen Rothwell81e70092005-10-18 11:17:58 +10001372 /*
1373 * If we get a fault copying the context into the kernel's
1374 * image of the user's registers, we can't just return -EFAULT
1375 * because the user's registers will be corrupted. For instance
1376 * the NIP value may have been updated but not some of the
1377 * other registers. Given that we have done the access_ok
1378 * and successfully read the first and last bytes of the region
1379 * above, this should only happen in an out-of-memory situation
1380 * or if another thread unmaps the region containing the context.
1381 * We kill the task with a SIGSEGV in this situation.
1382 */
1383 if (do_setcontext(ctx, regs, 1)) {
Christian Dietrich76462232011-06-04 05:36:54 +00001384 if (show_unhandled_signals)
1385 printk_ratelimited(KERN_INFO "%s[%d]: bad frame in "
1386 "sys_debug_setcontext: %p nip %08lx "
1387 "lr %08lx\n",
1388 current->comm, current->pid,
1389 ctx, regs->nip, regs->link);
Olof Johanssond0c3d532007-10-12 10:20:07 +10001390
Stephen Rothwell81e70092005-10-18 11:17:58 +10001391 force_sig(SIGSEGV, current);
1392 goto out;
1393 }
1394
1395 /*
1396 * It's not clear whether or why it is desirable to save the
1397 * sigaltstack setting on signal delivery and restore it on
1398 * signal return. But other architectures do this and we have
1399 * always done it up until now so it is probably better not to
1400 * change it. -- paulus
1401 */
Al Viro7cce2462012-12-23 03:26:46 -05001402 restore_altstack(&ctx->uc_stack);
Stephen Rothwell81e70092005-10-18 11:17:58 +10001403
David Woodhouse401d1f02005-11-15 18:52:18 +00001404 set_thread_flag(TIF_RESTOREALL);
Stephen Rothwell81e70092005-10-18 11:17:58 +10001405 out:
1406 return 0;
1407}
1408#endif
1409
1410/*
1411 * OK, we're invoking a handler
1412 */
Richard Weinberger129b69d2014-03-02 14:46:11 +01001413int handle_signal32(struct ksignal *ksig, sigset_t *oldset, struct pt_regs *regs)
Stephen Rothwell81e70092005-10-18 11:17:58 +10001414{
1415 struct sigcontext __user *sc;
Benjamin Herrenschmidta3f61dc2007-06-04 17:22:48 +10001416 struct sigframe __user *frame;
Michael Neuling1d25f112013-06-09 21:23:15 +10001417 struct mcontext __user *tm_mctx = NULL;
Benjamin Herrenschmidta3f61dc2007-06-04 17:22:48 +10001418 unsigned long newsp = 0;
Michael Neuling2b0a5762013-02-13 16:21:41 +00001419 int sigret;
1420 unsigned long tramp;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001421
1422 /* Set up Signal Frame */
Richard Weinberger059ade62014-03-05 16:25:55 +01001423 frame = get_sigframe(ksig, get_tm_stackpointer(regs), sizeof(*frame), 1);
Benjamin Herrenschmidta3f61dc2007-06-04 17:22:48 +10001424 if (unlikely(frame == NULL))
Stephen Rothwell81e70092005-10-18 11:17:58 +10001425 goto badframe;
Benjamin Herrenschmidta3f61dc2007-06-04 17:22:48 +10001426 sc = (struct sigcontext __user *) &frame->sctx;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001427
1428#if _NSIG != 64
1429#error "Please adjust handle_signal()"
1430#endif
Richard Weinberger129b69d2014-03-02 14:46:11 +01001431 if (__put_user(to_user_ptr(ksig->ka.sa.sa_handler), &sc->handler)
Stephen Rothwell81e70092005-10-18 11:17:58 +10001432 || __put_user(oldset->sig[0], &sc->oldmask)
1433#ifdef CONFIG_PPC64
1434 || __put_user((oldset->sig[0] >> 32), &sc->_unused[3])
1435#else
1436 || __put_user(oldset->sig[1], &sc->_unused[3])
1437#endif
Benjamin Herrenschmidta3f61dc2007-06-04 17:22:48 +10001438 || __put_user(to_user_ptr(&frame->mctx), &sc->regs)
Richard Weinberger129b69d2014-03-02 14:46:11 +01001439 || __put_user(ksig->sig, &sc->signal))
Stephen Rothwell81e70092005-10-18 11:17:58 +10001440 goto badframe;
1441
Benjamin Herrenschmidta5bba932006-05-30 13:51:37 +10001442 if (vdso32_sigtramp && current->mm->context.vdso_base) {
Michael Neuling2b0a5762013-02-13 16:21:41 +00001443 sigret = 0;
1444 tramp = current->mm->context.vdso_base + vdso32_sigtramp;
Benjamin Herrenschmidta7f290d2005-11-11 21:15:21 +11001445 } else {
Michael Neuling2b0a5762013-02-13 16:21:41 +00001446 sigret = __NR_sigreturn;
1447 tramp = (unsigned long) frame->mctx.tramp;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001448 }
1449
Michael Neuling2b0a5762013-02-13 16:21:41 +00001450#ifdef CONFIG_PPC_TRANSACTIONAL_MEM
Michael Neuling1d25f112013-06-09 21:23:15 +10001451 tm_mctx = &frame->mctx_transact;
Michael Neuling2b0a5762013-02-13 16:21:41 +00001452 if (MSR_TM_ACTIVE(regs->msr)) {
1453 if (save_tm_user_regs(regs, &frame->mctx, &frame->mctx_transact,
1454 sigret))
1455 goto badframe;
1456 }
1457 else
1458#endif
Michael Neuling1d25f112013-06-09 21:23:15 +10001459 {
1460 if (save_user_regs(regs, &frame->mctx, tm_mctx, sigret, 1))
Michael Neuling2b0a5762013-02-13 16:21:41 +00001461 goto badframe;
Michael Neuling1d25f112013-06-09 21:23:15 +10001462 }
Michael Neuling2b0a5762013-02-13 16:21:41 +00001463
1464 regs->link = tramp;
1465
Paul Mackerrasde79f7b2013-09-10 20:20:42 +10001466 current->thread.fp_state.fpscr = 0; /* turn off all fp exceptions */
Paul Mackerrascc657f52005-11-14 21:55:15 +11001467
Benjamin Herrenschmidta3f61dc2007-06-04 17:22:48 +10001468 /* create a stack frame for the caller of the handler */
1469 newsp = ((unsigned long)frame) - __SIGNAL_FRAMESIZE;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001470 if (put_user(regs->gpr[1], (u32 __user *)newsp))
1471 goto badframe;
Benjamin Herrenschmidta3f61dc2007-06-04 17:22:48 +10001472
Stephen Rothwell81e70092005-10-18 11:17:58 +10001473 regs->gpr[1] = newsp;
Richard Weinberger129b69d2014-03-02 14:46:11 +01001474 regs->gpr[3] = ksig->sig;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001475 regs->gpr[4] = (unsigned long) sc;
Richard Weinberger129b69d2014-03-02 14:46:11 +01001476 regs->nip = (unsigned long) (unsigned long)ksig->ka.sa.sa_handler;
Paul Mackerrasfab5db92006-06-07 16:14:40 +10001477 /* enter the signal handler in big-endian mode */
1478 regs->msr &= ~MSR_LE;
Richard Weinberger129b69d2014-03-02 14:46:11 +01001479 return 0;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001480
1481badframe:
Christian Dietrich76462232011-06-04 05:36:54 +00001482 if (show_unhandled_signals)
1483 printk_ratelimited(KERN_INFO
1484 "%s[%d]: bad frame in handle_signal32: "
1485 "%p nip %08lx lr %08lx\n",
1486 current->comm, current->pid,
1487 frame, regs->nip, regs->link);
Olof Johanssond0c3d532007-10-12 10:20:07 +10001488
Richard Weinberger129b69d2014-03-02 14:46:11 +01001489 return 1;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001490}
1491
1492/*
1493 * Do a signal return; undo the signal stack.
1494 */
1495long sys_sigreturn(int r3, int r4, int r5, int r6, int r7, int r8,
1496 struct pt_regs *regs)
1497{
Michael Neulingfee554502013-06-09 21:23:16 +10001498 struct sigframe __user *sf;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001499 struct sigcontext __user *sc;
1500 struct sigcontext sigctx;
1501 struct mcontext __user *sr;
Olof Johanssond0c3d532007-10-12 10:20:07 +10001502 void __user *addr;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001503 sigset_t set;
Michael Neulingfee554502013-06-09 21:23:16 +10001504#ifdef CONFIG_PPC_TRANSACTIONAL_MEM
1505 struct mcontext __user *mcp, *tm_mcp;
1506 unsigned long msr_hi;
1507#endif
Stephen Rothwell81e70092005-10-18 11:17:58 +10001508
1509 /* Always make any pending restarted system calls return -EINTR */
Andy Lutomirskif56141e2015-02-12 15:01:14 -08001510 current->restart_block.fn = do_no_restart_syscall;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001511
Michael Neulingfee554502013-06-09 21:23:16 +10001512 sf = (struct sigframe __user *)(regs->gpr[1] + __SIGNAL_FRAMESIZE);
1513 sc = &sf->sctx;
Olof Johanssond0c3d532007-10-12 10:20:07 +10001514 addr = sc;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001515 if (copy_from_user(&sigctx, sc, sizeof(sigctx)))
1516 goto badframe;
1517
1518#ifdef CONFIG_PPC64
1519 /*
1520 * Note that PPC32 puts the upper 32 bits of the sigmask in the
1521 * unused part of the signal stackframe
1522 */
1523 set.sig[0] = sigctx.oldmask + ((long)(sigctx._unused[3]) << 32);
1524#else
1525 set.sig[0] = sigctx.oldmask;
1526 set.sig[1] = sigctx._unused[3];
1527#endif
Al Viro17440f12012-04-27 14:09:19 -04001528 set_current_blocked(&set);
Stephen Rothwell81e70092005-10-18 11:17:58 +10001529
Michael Neulingfee554502013-06-09 21:23:16 +10001530#ifdef CONFIG_PPC_TRANSACTIONAL_MEM
1531 mcp = (struct mcontext __user *)&sf->mctx;
1532 tm_mcp = (struct mcontext __user *)&sf->mctx_transact;
1533 if (__get_user(msr_hi, &tm_mcp->mc_gregs[PT_MSR]))
Stephen Rothwell81e70092005-10-18 11:17:58 +10001534 goto badframe;
Michael Neulingfee554502013-06-09 21:23:16 +10001535 if (MSR_TM_ACTIVE(msr_hi<<32)) {
1536 if (!cpu_has_feature(CPU_FTR_TM))
1537 goto badframe;
1538 if (restore_tm_user_regs(regs, mcp, tm_mcp))
1539 goto badframe;
1540 } else
1541#endif
1542 {
1543 sr = (struct mcontext __user *)from_user_ptr(sigctx.regs);
1544 addr = sr;
1545 if (!access_ok(VERIFY_READ, sr, sizeof(*sr))
1546 || restore_user_regs(regs, sr, 1))
1547 goto badframe;
1548 }
Stephen Rothwell81e70092005-10-18 11:17:58 +10001549
David Woodhouse401d1f02005-11-15 18:52:18 +00001550 set_thread_flag(TIF_RESTOREALL);
Stephen Rothwell81e70092005-10-18 11:17:58 +10001551 return 0;
Stephen Rothwell81e70092005-10-18 11:17:58 +10001552
1553badframe:
Christian Dietrich76462232011-06-04 05:36:54 +00001554 if (show_unhandled_signals)
1555 printk_ratelimited(KERN_INFO
1556 "%s[%d]: bad frame in sys_sigreturn: "
1557 "%p nip %08lx lr %08lx\n",
1558 current->comm, current->pid,
1559 addr, regs->nip, regs->link);
Olof Johanssond0c3d532007-10-12 10:20:07 +10001560
Stephen Rothwell81e70092005-10-18 11:17:58 +10001561 force_sig(SIGSEGV, current);
1562 return 0;
1563}