blob: a2ded89db73e7a7a42481842062f6b0f7d62971c [file] [log] [blame]
Paul Mackerras14cf11a2005-09-26 16:04:21 +10001/*
2 * Single-step support.
3 *
4 * Copyright (C) 2004 Paul Mackerras <paulus@au.ibm.com>, IBM
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version
9 * 2 of the License, or (at your option) any later version.
10 */
11#include <linux/kernel.h>
Gui,Jian0d69a052006-11-01 10:50:15 +080012#include <linux/kprobes.h>
Paul Mackerras14cf11a2005-09-26 16:04:21 +100013#include <linux/ptrace.h>
Linus Torvalds268bb0c2011-05-20 12:50:29 -070014#include <linux/prefetch.h>
Paul Mackerras14cf11a2005-09-26 16:04:21 +100015#include <asm/sstep.h>
16#include <asm/processor.h>
Linus Torvalds7c0f6ba2016-12-24 11:46:01 -080017#include <linux/uaccess.h>
Michael Ellerman5e9d0e32016-11-18 11:51:14 +110018#include <asm/cpu_has_feature.h>
Paul Mackerras0016a4c2010-06-15 14:48:58 +100019#include <asm/cputable.h>
Paul Mackerras14cf11a2005-09-26 16:04:21 +100020
21extern char system_call_common[];
22
Paul Mackerrasc0325242005-10-28 22:48:08 +100023#ifdef CONFIG_PPC64
Paul Mackerras14cf11a2005-09-26 16:04:21 +100024/* Bits in SRR1 that are copied from MSR */
Stephen Rothwellaf308372006-03-23 17:38:10 +110025#define MSR_MASK 0xffffffff87c0ffffUL
Paul Mackerrasc0325242005-10-28 22:48:08 +100026#else
27#define MSR_MASK 0x87c0ffff
28#endif
Paul Mackerras14cf11a2005-09-26 16:04:21 +100029
Paul Mackerras0016a4c2010-06-15 14:48:58 +100030/* Bits in XER */
31#define XER_SO 0x80000000U
32#define XER_OV 0x40000000U
33#define XER_CA 0x20000000U
34
Sean MacLennancd64d162010-09-01 07:21:21 +000035#ifdef CONFIG_PPC_FPU
Paul Mackerras0016a4c2010-06-15 14:48:58 +100036/*
37 * Functions in ldstfp.S
38 */
39extern int do_lfs(int rn, unsigned long ea);
40extern int do_lfd(int rn, unsigned long ea);
41extern int do_stfs(int rn, unsigned long ea);
42extern int do_stfd(int rn, unsigned long ea);
43extern int do_lvx(int rn, unsigned long ea);
44extern int do_stvx(int rn, unsigned long ea);
45extern int do_lxvd2x(int rn, unsigned long ea);
46extern int do_stxvd2x(int rn, unsigned long ea);
Sean MacLennancd64d162010-09-01 07:21:21 +000047#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +100048
Paul Mackerras14cf11a2005-09-26 16:04:21 +100049/*
Michael Ellermanb91e1362011-04-07 21:56:04 +000050 * Emulate the truncation of 64 bit values in 32-bit mode.
51 */
Naveen N. Rao71f6e582017-04-12 16:48:51 +053052static nokprobe_inline unsigned long truncate_if_32bit(unsigned long msr,
53 unsigned long val)
Michael Ellermanb91e1362011-04-07 21:56:04 +000054{
55#ifdef __powerpc64__
56 if ((msr & MSR_64BIT) == 0)
57 val &= 0xffffffffUL;
58#endif
59 return val;
60}
61
62/*
Paul Mackerras14cf11a2005-09-26 16:04:21 +100063 * Determine whether a conditional branch instruction would branch.
64 */
Naveen N. Rao71f6e582017-04-12 16:48:51 +053065static nokprobe_inline int branch_taken(unsigned int instr, struct pt_regs *regs)
Paul Mackerras14cf11a2005-09-26 16:04:21 +100066{
67 unsigned int bo = (instr >> 21) & 0x1f;
68 unsigned int bi;
69
70 if ((bo & 4) == 0) {
71 /* decrement counter */
72 --regs->ctr;
73 if (((bo >> 1) & 1) ^ (regs->ctr == 0))
74 return 0;
75 }
76 if ((bo & 0x10) == 0) {
77 /* check bit from CR */
78 bi = (instr >> 16) & 0x1f;
79 if (((regs->ccr >> (31 - bi)) & 1) != ((bo >> 3) & 1))
80 return 0;
81 }
82 return 1;
83}
84
Naveen N. Rao71f6e582017-04-12 16:48:51 +053085static nokprobe_inline long address_ok(struct pt_regs *regs, unsigned long ea, int nb)
Paul Mackerras0016a4c2010-06-15 14:48:58 +100086{
87 if (!user_mode(regs))
88 return 1;
89 return __access_ok(ea, nb, USER_DS);
90}
91
Paul Mackerras14cf11a2005-09-26 16:04:21 +100092/*
Paul Mackerras0016a4c2010-06-15 14:48:58 +100093 * Calculate effective address for a D-form instruction
94 */
Naveen N. Rao71f6e582017-04-12 16:48:51 +053095static nokprobe_inline unsigned long dform_ea(unsigned int instr, struct pt_regs *regs)
Paul Mackerras0016a4c2010-06-15 14:48:58 +100096{
97 int ra;
98 unsigned long ea;
99
100 ra = (instr >> 16) & 0x1f;
101 ea = (signed short) instr; /* sign-extend */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000102 if (ra)
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000103 ea += regs->gpr[ra];
Michael Ellermanb91e1362011-04-07 21:56:04 +0000104
105 return truncate_if_32bit(regs->msr, ea);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000106}
107
108#ifdef __powerpc64__
109/*
110 * Calculate effective address for a DS-form instruction
111 */
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530112static nokprobe_inline unsigned long dsform_ea(unsigned int instr, struct pt_regs *regs)
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000113{
114 int ra;
115 unsigned long ea;
116
117 ra = (instr >> 16) & 0x1f;
118 ea = (signed short) (instr & ~3); /* sign-extend */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000119 if (ra)
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000120 ea += regs->gpr[ra];
Michael Ellermanb91e1362011-04-07 21:56:04 +0000121
122 return truncate_if_32bit(regs->msr, ea);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000123}
124#endif /* __powerpc64 */
125
126/*
127 * Calculate effective address for an X-form instruction
128 */
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530129static nokprobe_inline unsigned long xform_ea(unsigned int instr,
130 struct pt_regs *regs)
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000131{
132 int ra, rb;
133 unsigned long ea;
134
135 ra = (instr >> 16) & 0x1f;
136 rb = (instr >> 11) & 0x1f;
137 ea = regs->gpr[rb];
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000138 if (ra)
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000139 ea += regs->gpr[ra];
Michael Ellermanb91e1362011-04-07 21:56:04 +0000140
141 return truncate_if_32bit(regs->msr, ea);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000142}
143
144/*
145 * Return the largest power of 2, not greater than sizeof(unsigned long),
146 * such that x is a multiple of it.
147 */
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530148static nokprobe_inline unsigned long max_align(unsigned long x)
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000149{
150 x |= sizeof(unsigned long);
151 return x & -x; /* isolates rightmost bit */
152}
153
154
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530155static nokprobe_inline unsigned long byterev_2(unsigned long x)
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000156{
157 return ((x >> 8) & 0xff) | ((x & 0xff) << 8);
158}
159
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530160static nokprobe_inline unsigned long byterev_4(unsigned long x)
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000161{
162 return ((x >> 24) & 0xff) | ((x >> 8) & 0xff00) |
163 ((x & 0xff00) << 8) | ((x & 0xff) << 24);
164}
165
166#ifdef __powerpc64__
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530167static nokprobe_inline unsigned long byterev_8(unsigned long x)
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000168{
169 return (byterev_4(x) << 32) | byterev_4(x >> 32);
170}
171#endif
172
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530173static nokprobe_inline int read_mem_aligned(unsigned long *dest,
174 unsigned long ea, int nb)
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000175{
176 int err = 0;
177 unsigned long x = 0;
178
179 switch (nb) {
180 case 1:
181 err = __get_user(x, (unsigned char __user *) ea);
182 break;
183 case 2:
184 err = __get_user(x, (unsigned short __user *) ea);
185 break;
186 case 4:
187 err = __get_user(x, (unsigned int __user *) ea);
188 break;
189#ifdef __powerpc64__
190 case 8:
191 err = __get_user(x, (unsigned long __user *) ea);
192 break;
193#endif
194 }
195 if (!err)
196 *dest = x;
197 return err;
198}
199
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530200static nokprobe_inline int read_mem_unaligned(unsigned long *dest,
201 unsigned long ea, int nb, struct pt_regs *regs)
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000202{
203 int err;
204 unsigned long x, b, c;
Tom Musta6506b472013-10-18 14:42:08 -0500205#ifdef __LITTLE_ENDIAN__
206 int len = nb; /* save a copy of the length for byte reversal */
207#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000208
209 /* unaligned, do this in pieces */
210 x = 0;
211 for (; nb > 0; nb -= c) {
Tom Musta6506b472013-10-18 14:42:08 -0500212#ifdef __LITTLE_ENDIAN__
213 c = 1;
214#endif
215#ifdef __BIG_ENDIAN__
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000216 c = max_align(ea);
Tom Musta6506b472013-10-18 14:42:08 -0500217#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000218 if (c > nb)
219 c = max_align(nb);
220 err = read_mem_aligned(&b, ea, c);
221 if (err)
222 return err;
223 x = (x << (8 * c)) + b;
224 ea += c;
225 }
Tom Musta6506b472013-10-18 14:42:08 -0500226#ifdef __LITTLE_ENDIAN__
227 switch (len) {
228 case 2:
229 *dest = byterev_2(x);
230 break;
231 case 4:
232 *dest = byterev_4(x);
233 break;
234#ifdef __powerpc64__
235 case 8:
236 *dest = byterev_8(x);
237 break;
238#endif
239 }
240#endif
241#ifdef __BIG_ENDIAN__
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000242 *dest = x;
Tom Musta6506b472013-10-18 14:42:08 -0500243#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000244 return 0;
245}
246
247/*
248 * Read memory at address ea for nb bytes, return 0 for success
249 * or -EFAULT if an error occurred.
250 */
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530251static int read_mem(unsigned long *dest, unsigned long ea, int nb,
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000252 struct pt_regs *regs)
253{
254 if (!address_ok(regs, ea, nb))
255 return -EFAULT;
256 if ((ea & (nb - 1)) == 0)
257 return read_mem_aligned(dest, ea, nb);
258 return read_mem_unaligned(dest, ea, nb, regs);
259}
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530260NOKPROBE_SYMBOL(read_mem);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000261
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530262static nokprobe_inline int write_mem_aligned(unsigned long val,
263 unsigned long ea, int nb)
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000264{
265 int err = 0;
266
267 switch (nb) {
268 case 1:
269 err = __put_user(val, (unsigned char __user *) ea);
270 break;
271 case 2:
272 err = __put_user(val, (unsigned short __user *) ea);
273 break;
274 case 4:
275 err = __put_user(val, (unsigned int __user *) ea);
276 break;
277#ifdef __powerpc64__
278 case 8:
279 err = __put_user(val, (unsigned long __user *) ea);
280 break;
281#endif
282 }
283 return err;
284}
285
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530286static nokprobe_inline int write_mem_unaligned(unsigned long val,
287 unsigned long ea, int nb, struct pt_regs *regs)
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000288{
289 int err;
290 unsigned long c;
291
Tom Musta6506b472013-10-18 14:42:08 -0500292#ifdef __LITTLE_ENDIAN__
293 switch (nb) {
294 case 2:
295 val = byterev_2(val);
296 break;
297 case 4:
298 val = byterev_4(val);
299 break;
300#ifdef __powerpc64__
301 case 8:
302 val = byterev_8(val);
303 break;
304#endif
305 }
306#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000307 /* unaligned or little-endian, do this in pieces */
308 for (; nb > 0; nb -= c) {
Tom Musta6506b472013-10-18 14:42:08 -0500309#ifdef __LITTLE_ENDIAN__
310 c = 1;
311#endif
312#ifdef __BIG_ENDIAN__
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000313 c = max_align(ea);
Tom Musta6506b472013-10-18 14:42:08 -0500314#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000315 if (c > nb)
316 c = max_align(nb);
317 err = write_mem_aligned(val >> (nb - c) * 8, ea, c);
318 if (err)
319 return err;
Tom Musta17e8de72013-08-22 09:25:28 -0500320 ea += c;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000321 }
322 return 0;
323}
324
325/*
326 * Write memory at address ea for nb bytes, return 0 for success
327 * or -EFAULT if an error occurred.
328 */
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530329static int write_mem(unsigned long val, unsigned long ea, int nb,
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000330 struct pt_regs *regs)
331{
332 if (!address_ok(regs, ea, nb))
333 return -EFAULT;
334 if ((ea & (nb - 1)) == 0)
335 return write_mem_aligned(val, ea, nb);
336 return write_mem_unaligned(val, ea, nb, regs);
337}
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530338NOKPROBE_SYMBOL(write_mem);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000339
Sean MacLennancd64d162010-09-01 07:21:21 +0000340#ifdef CONFIG_PPC_FPU
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000341/*
342 * Check the address and alignment, and call func to do the actual
343 * load or store.
344 */
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530345static int do_fp_load(int rn, int (*func)(int, unsigned long),
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000346 unsigned long ea, int nb,
347 struct pt_regs *regs)
348{
349 int err;
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500350 union {
351 double dbl;
352 unsigned long ul[2];
353 struct {
354#ifdef __BIG_ENDIAN__
355 unsigned _pad_;
356 unsigned word;
357#endif
358#ifdef __LITTLE_ENDIAN__
359 unsigned word;
360 unsigned _pad_;
361#endif
362 } single;
363 } data;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000364 unsigned long ptr;
365
366 if (!address_ok(regs, ea, nb))
367 return -EFAULT;
368 if ((ea & 3) == 0)
369 return (*func)(rn, ea);
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500370 ptr = (unsigned long) &data.ul;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000371 if (sizeof(unsigned long) == 8 || nb == 4) {
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500372 err = read_mem_unaligned(&data.ul[0], ea, nb, regs);
373 if (nb == 4)
374 ptr = (unsigned long)&(data.single.word);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000375 } else {
376 /* reading a double on 32-bit */
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500377 err = read_mem_unaligned(&data.ul[0], ea, 4, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000378 if (!err)
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500379 err = read_mem_unaligned(&data.ul[1], ea + 4, 4, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000380 }
381 if (err)
382 return err;
383 return (*func)(rn, ptr);
384}
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530385NOKPROBE_SYMBOL(do_fp_load);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000386
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530387static int do_fp_store(int rn, int (*func)(int, unsigned long),
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000388 unsigned long ea, int nb,
389 struct pt_regs *regs)
390{
391 int err;
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500392 union {
393 double dbl;
394 unsigned long ul[2];
395 struct {
396#ifdef __BIG_ENDIAN__
397 unsigned _pad_;
398 unsigned word;
399#endif
400#ifdef __LITTLE_ENDIAN__
401 unsigned word;
402 unsigned _pad_;
403#endif
404 } single;
405 } data;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000406 unsigned long ptr;
407
408 if (!address_ok(regs, ea, nb))
409 return -EFAULT;
410 if ((ea & 3) == 0)
411 return (*func)(rn, ea);
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500412 ptr = (unsigned long) &data.ul[0];
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000413 if (sizeof(unsigned long) == 8 || nb == 4) {
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500414 if (nb == 4)
415 ptr = (unsigned long)&(data.single.word);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000416 err = (*func)(rn, ptr);
417 if (err)
418 return err;
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500419 err = write_mem_unaligned(data.ul[0], ea, nb, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000420 } else {
421 /* writing a double on 32-bit */
422 err = (*func)(rn, ptr);
423 if (err)
424 return err;
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500425 err = write_mem_unaligned(data.ul[0], ea, 4, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000426 if (!err)
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500427 err = write_mem_unaligned(data.ul[1], ea + 4, 4, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000428 }
429 return err;
430}
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530431NOKPROBE_SYMBOL(do_fp_store);
Sean MacLennancd64d162010-09-01 07:21:21 +0000432#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000433
434#ifdef CONFIG_ALTIVEC
435/* For Altivec/VMX, no need to worry about alignment */
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530436static nokprobe_inline int do_vec_load(int rn, int (*func)(int, unsigned long),
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000437 unsigned long ea, struct pt_regs *regs)
438{
439 if (!address_ok(regs, ea & ~0xfUL, 16))
440 return -EFAULT;
441 return (*func)(rn, ea);
442}
443
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530444static nokprobe_inline int do_vec_store(int rn, int (*func)(int, unsigned long),
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000445 unsigned long ea, struct pt_regs *regs)
446{
447 if (!address_ok(regs, ea & ~0xfUL, 16))
448 return -EFAULT;
449 return (*func)(rn, ea);
450}
451#endif /* CONFIG_ALTIVEC */
452
453#ifdef CONFIG_VSX
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530454static nokprobe_inline int do_vsx_load(int rn, int (*func)(int, unsigned long),
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000455 unsigned long ea, struct pt_regs *regs)
456{
457 int err;
458 unsigned long val[2];
459
460 if (!address_ok(regs, ea, 16))
461 return -EFAULT;
462 if ((ea & 3) == 0)
463 return (*func)(rn, ea);
464 err = read_mem_unaligned(&val[0], ea, 8, regs);
465 if (!err)
466 err = read_mem_unaligned(&val[1], ea + 8, 8, regs);
467 if (!err)
468 err = (*func)(rn, (unsigned long) &val[0]);
469 return err;
470}
471
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530472static nokprobe_inline int do_vsx_store(int rn, int (*func)(int, unsigned long),
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000473 unsigned long ea, struct pt_regs *regs)
474{
475 int err;
476 unsigned long val[2];
477
478 if (!address_ok(regs, ea, 16))
479 return -EFAULT;
480 if ((ea & 3) == 0)
481 return (*func)(rn, ea);
482 err = (*func)(rn, (unsigned long) &val[0]);
483 if (err)
484 return err;
485 err = write_mem_unaligned(val[0], ea, 8, regs);
486 if (!err)
487 err = write_mem_unaligned(val[1], ea + 8, 8, regs);
488 return err;
489}
490#endif /* CONFIG_VSX */
491
492#define __put_user_asmx(x, addr, err, op, cr) \
493 __asm__ __volatile__( \
494 "1: " op " %2,0,%3\n" \
495 " mfcr %1\n" \
496 "2:\n" \
497 ".section .fixup,\"ax\"\n" \
498 "3: li %0,%4\n" \
499 " b 2b\n" \
500 ".previous\n" \
Nicholas Piggin24bfa6a2016-10-13 16:42:53 +1100501 EX_TABLE(1b, 3b) \
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000502 : "=r" (err), "=r" (cr) \
503 : "r" (x), "r" (addr), "i" (-EFAULT), "0" (err))
504
505#define __get_user_asmx(x, addr, err, op) \
506 __asm__ __volatile__( \
507 "1: "op" %1,0,%2\n" \
508 "2:\n" \
509 ".section .fixup,\"ax\"\n" \
510 "3: li %0,%3\n" \
511 " b 2b\n" \
512 ".previous\n" \
Nicholas Piggin24bfa6a2016-10-13 16:42:53 +1100513 EX_TABLE(1b, 3b) \
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000514 : "=r" (err), "=r" (x) \
515 : "r" (addr), "i" (-EFAULT), "0" (err))
516
517#define __cacheop_user_asmx(addr, err, op) \
518 __asm__ __volatile__( \
519 "1: "op" 0,%1\n" \
520 "2:\n" \
521 ".section .fixup,\"ax\"\n" \
522 "3: li %0,%3\n" \
523 " b 2b\n" \
524 ".previous\n" \
Nicholas Piggin24bfa6a2016-10-13 16:42:53 +1100525 EX_TABLE(1b, 3b) \
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000526 : "=r" (err) \
527 : "r" (addr), "i" (-EFAULT), "0" (err))
528
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530529static nokprobe_inline void set_cr0(struct pt_regs *regs, int rd)
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000530{
531 long val = regs->gpr[rd];
532
533 regs->ccr = (regs->ccr & 0x0fffffff) | ((regs->xer >> 3) & 0x10000000);
534#ifdef __powerpc64__
Michael Ellermanb91e1362011-04-07 21:56:04 +0000535 if (!(regs->msr & MSR_64BIT))
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000536 val = (int) val;
537#endif
538 if (val < 0)
539 regs->ccr |= 0x80000000;
540 else if (val > 0)
541 regs->ccr |= 0x40000000;
542 else
543 regs->ccr |= 0x20000000;
544}
545
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530546static nokprobe_inline void add_with_carry(struct pt_regs *regs, int rd,
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000547 unsigned long val1, unsigned long val2,
548 unsigned long carry_in)
549{
550 unsigned long val = val1 + val2;
551
552 if (carry_in)
553 ++val;
554 regs->gpr[rd] = val;
555#ifdef __powerpc64__
Michael Ellermanb91e1362011-04-07 21:56:04 +0000556 if (!(regs->msr & MSR_64BIT)) {
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000557 val = (unsigned int) val;
558 val1 = (unsigned int) val1;
559 }
560#endif
561 if (val < val1 || (carry_in && val == val1))
562 regs->xer |= XER_CA;
563 else
564 regs->xer &= ~XER_CA;
565}
566
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530567static nokprobe_inline void do_cmp_signed(struct pt_regs *regs, long v1, long v2,
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000568 int crfld)
569{
570 unsigned int crval, shift;
571
572 crval = (regs->xer >> 31) & 1; /* get SO bit */
573 if (v1 < v2)
574 crval |= 8;
575 else if (v1 > v2)
576 crval |= 4;
577 else
578 crval |= 2;
579 shift = (7 - crfld) * 4;
580 regs->ccr = (regs->ccr & ~(0xf << shift)) | (crval << shift);
581}
582
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530583static nokprobe_inline void do_cmp_unsigned(struct pt_regs *regs, unsigned long v1,
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000584 unsigned long v2, int crfld)
585{
586 unsigned int crval, shift;
587
588 crval = (regs->xer >> 31) & 1; /* get SO bit */
589 if (v1 < v2)
590 crval |= 8;
591 else if (v1 > v2)
592 crval |= 4;
593 else
594 crval |= 2;
595 shift = (7 - crfld) * 4;
596 regs->ccr = (regs->ccr & ~(0xf << shift)) | (crval << shift);
597}
598
Matt Brown02c0f622017-07-31 10:58:22 +1000599static nokprobe_inline void do_cmpb(struct pt_regs *regs, unsigned long v1,
600 unsigned long v2, int rd)
601{
602 unsigned long long out_val, mask;
603 int i;
604
605 out_val = 0;
606 for (i = 0; i < 8; i++) {
607 mask = 0xffUL << (i * 8);
608 if ((v1 & mask) == (v2 & mask))
609 out_val |= mask;
610 }
611
612 regs->gpr[rd] = out_val;
613}
614
Matt Browndcbd19b2017-07-31 10:58:23 +1000615/*
616 * The size parameter is used to adjust the equivalent popcnt instruction.
617 * popcntb = 8, popcntw = 32, popcntd = 64
618 */
619static nokprobe_inline void do_popcnt(struct pt_regs *regs, unsigned long v1,
620 int size, int ra)
621{
622 unsigned long long out = v1;
623
624 out -= (out >> 1) & 0x5555555555555555;
625 out = (0x3333333333333333 & out) + (0x3333333333333333 & (out >> 2));
626 out = (out + (out >> 4)) & 0x0f0f0f0f0f0f0f0f;
627
628 if (size == 8) { /* popcntb */
629 regs->gpr[ra] = out;
630 return;
631 }
632 out += out >> 8;
633 out += out >> 16;
634 if (size == 32) { /* popcntw */
635 regs->gpr[ra] = out & 0x0000003f0000003f;
636 return;
637 }
638
639 out = (out + (out >> 32)) & 0x7f;
640 regs->gpr[ra] = out; /* popcntd */
641}
642
Matt Brownf3127932017-07-31 10:58:24 +1000643#ifdef CONFIG_PPC64
644static nokprobe_inline void do_bpermd(struct pt_regs *regs, unsigned long v1,
645 unsigned long v2, int ra)
646{
647 unsigned char perm, idx;
648 unsigned int i;
649
650 perm = 0;
651 for (i = 0; i < 8; i++) {
652 idx = (v1 >> (i * 8)) & 0xff;
653 if (idx < 64)
654 if (v2 & PPC_BIT(idx))
655 perm |= 1 << i;
656 }
657 regs->gpr[ra] = perm;
658}
659#endif /* CONFIG_PPC64 */
Matt Brown2c979c42017-07-31 10:58:25 +1000660/*
661 * The size parameter adjusts the equivalent prty instruction.
662 * prtyw = 32, prtyd = 64
663 */
664static nokprobe_inline void do_prty(struct pt_regs *regs, unsigned long v,
665 int size, int ra)
666{
667 unsigned long long res = v ^ (v >> 8);
668
669 res ^= res >> 16;
670 if (size == 32) { /* prtyw */
671 regs->gpr[ra] = res & 0x0000000100000001;
672 return;
673 }
674
675 res ^= res >> 32;
676 regs->gpr[ra] = res & 1; /*prtyd */
677}
Matt Brownf3127932017-07-31 10:58:24 +1000678
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530679static nokprobe_inline int trap_compare(long v1, long v2)
Paul Mackerrascf87c3f2014-09-02 14:35:08 +1000680{
681 int ret = 0;
682
683 if (v1 < v2)
684 ret |= 0x10;
685 else if (v1 > v2)
686 ret |= 0x08;
687 else
688 ret |= 0x04;
689 if ((unsigned long)v1 < (unsigned long)v2)
690 ret |= 0x02;
691 else if ((unsigned long)v1 > (unsigned long)v2)
692 ret |= 0x01;
693 return ret;
694}
695
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000696/*
697 * Elements of 32-bit rotate and mask instructions.
698 */
699#define MASK32(mb, me) ((0xffffffffUL >> (mb)) + \
700 ((signed long)-0x80000000L >> (me)) + ((me) >= (mb)))
701#ifdef __powerpc64__
702#define MASK64_L(mb) (~0UL >> (mb))
703#define MASK64_R(me) ((signed long)-0x8000000000000000L >> (me))
704#define MASK64(mb, me) (MASK64_L(mb) + MASK64_R(me) + ((me) >= (mb)))
705#define DATA32(x) (((x) & 0xffffffffUL) | (((x) & 0xffffffffUL) << 32))
706#else
707#define DATA32(x) (x)
708#endif
709#define ROTATE(x, n) ((n) ? (((x) << (n)) | ((x) >> (8 * sizeof(long) - (n)))) : (x))
710
711/*
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000712 * Decode an instruction, and execute it if that can be done just by
713 * modifying *regs (i.e. integer arithmetic and logical instructions,
714 * branches, and barrier instructions).
715 * Returns 1 if the instruction has been executed, or 0 if not.
716 * Sets *op to indicate what the instruction does.
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000717 */
Naveen N. Rao71f6e582017-04-12 16:48:51 +0530718int analyse_instr(struct instruction_op *op, struct pt_regs *regs,
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000719 unsigned int instr)
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000720{
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000721 unsigned int opcode, ra, rb, rd, spr, u;
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000722 unsigned long int imm;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000723 unsigned long int val, val2;
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000724 unsigned int mb, me, sh;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000725 long ival;
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000726
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000727 op->type = COMPUTE;
728
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000729 opcode = instr >> 26;
730 switch (opcode) {
731 case 16: /* bc */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000732 op->type = BRANCH;
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000733 imm = (signed short)(instr & 0xfffc);
734 if ((instr & 2) == 0)
735 imm += regs->nip;
736 regs->nip += 4;
Michael Ellermanb91e1362011-04-07 21:56:04 +0000737 regs->nip = truncate_if_32bit(regs->msr, regs->nip);
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000738 if (instr & 1)
739 regs->link = regs->nip;
740 if (branch_taken(instr, regs))
Michael Neuling70a54a42013-05-06 21:32:40 +1000741 regs->nip = truncate_if_32bit(regs->msr, imm);
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000742 return 1;
Paul Mackerrasc0325242005-10-28 22:48:08 +1000743#ifdef CONFIG_PPC64
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000744 case 17: /* sc */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000745 if ((instr & 0xfe2) == 2)
746 op->type = SYSCALL;
747 else
748 op->type = UNKNOWN;
749 return 0;
Paul Mackerrasc0325242005-10-28 22:48:08 +1000750#endif
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000751 case 18: /* b */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000752 op->type = BRANCH;
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000753 imm = instr & 0x03fffffc;
754 if (imm & 0x02000000)
755 imm -= 0x04000000;
756 if ((instr & 2) == 0)
757 imm += regs->nip;
Michael Ellermanb91e1362011-04-07 21:56:04 +0000758 if (instr & 1)
759 regs->link = truncate_if_32bit(regs->msr, regs->nip + 4);
760 imm = truncate_if_32bit(regs->msr, imm);
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000761 regs->nip = imm;
762 return 1;
763 case 19:
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000764 switch ((instr >> 1) & 0x3ff) {
Paul Mackerrascf87c3f2014-09-02 14:35:08 +1000765 case 0: /* mcrf */
Anton Blanchard87c4b83e2017-06-15 09:46:38 +1000766 rd = 7 - ((instr >> 23) & 0x7);
767 ra = 7 - ((instr >> 18) & 0x7);
768 rd *= 4;
769 ra *= 4;
Paul Mackerrascf87c3f2014-09-02 14:35:08 +1000770 val = (regs->ccr >> ra) & 0xf;
771 regs->ccr = (regs->ccr & ~(0xfUL << rd)) | (val << rd);
772 goto instr_done;
773
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000774 case 16: /* bclr */
775 case 528: /* bcctr */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000776 op->type = BRANCH;
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000777 imm = (instr & 0x400)? regs->ctr: regs->link;
Michael Ellermanb91e1362011-04-07 21:56:04 +0000778 regs->nip = truncate_if_32bit(regs->msr, regs->nip + 4);
779 imm = truncate_if_32bit(regs->msr, imm);
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000780 if (instr & 1)
781 regs->link = regs->nip;
782 if (branch_taken(instr, regs))
783 regs->nip = imm;
784 return 1;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000785
786 case 18: /* rfid, scary */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000787 if (regs->msr & MSR_PR)
788 goto priv;
789 op->type = RFI;
790 return 0;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000791
792 case 150: /* isync */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000793 op->type = BARRIER;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000794 isync();
795 goto instr_done;
796
797 case 33: /* crnor */
798 case 129: /* crandc */
799 case 193: /* crxor */
800 case 225: /* crnand */
801 case 257: /* crand */
802 case 289: /* creqv */
803 case 417: /* crorc */
804 case 449: /* cror */
805 ra = (instr >> 16) & 0x1f;
806 rb = (instr >> 11) & 0x1f;
807 rd = (instr >> 21) & 0x1f;
808 ra = (regs->ccr >> (31 - ra)) & 1;
809 rb = (regs->ccr >> (31 - rb)) & 1;
810 val = (instr >> (6 + ra * 2 + rb)) & 1;
811 regs->ccr = (regs->ccr & ~(1UL << (31 - rd))) |
812 (val << (31 - rd));
813 goto instr_done;
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000814 }
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000815 break;
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000816 case 31:
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000817 switch ((instr >> 1) & 0x3ff) {
818 case 598: /* sync */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000819 op->type = BARRIER;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000820#ifdef __powerpc64__
821 switch ((instr >> 21) & 3) {
822 case 1: /* lwsync */
823 asm volatile("lwsync" : : : "memory");
824 goto instr_done;
825 case 2: /* ptesync */
826 asm volatile("ptesync" : : : "memory");
827 goto instr_done;
828 }
829#endif
830 mb();
831 goto instr_done;
832
833 case 854: /* eieio */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000834 op->type = BARRIER;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000835 eieio();
836 goto instr_done;
837 }
838 break;
839 }
840
841 /* Following cases refer to regs->gpr[], so we need all regs */
842 if (!FULL_REGS(regs))
843 return 0;
844
845 rd = (instr >> 21) & 0x1f;
846 ra = (instr >> 16) & 0x1f;
847 rb = (instr >> 11) & 0x1f;
848
849 switch (opcode) {
Paul Mackerrascf87c3f2014-09-02 14:35:08 +1000850#ifdef __powerpc64__
851 case 2: /* tdi */
852 if (rd & trap_compare(regs->gpr[ra], (short) instr))
853 goto trap;
854 goto instr_done;
855#endif
856 case 3: /* twi */
857 if (rd & trap_compare((int)regs->gpr[ra], (short) instr))
858 goto trap;
859 goto instr_done;
860
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000861 case 7: /* mulli */
862 regs->gpr[rd] = regs->gpr[ra] * (short) instr;
863 goto instr_done;
864
865 case 8: /* subfic */
866 imm = (short) instr;
867 add_with_carry(regs, rd, ~regs->gpr[ra], imm, 1);
868 goto instr_done;
869
870 case 10: /* cmpli */
871 imm = (unsigned short) instr;
872 val = regs->gpr[ra];
873#ifdef __powerpc64__
874 if ((rd & 1) == 0)
875 val = (unsigned int) val;
876#endif
877 do_cmp_unsigned(regs, val, imm, rd >> 2);
878 goto instr_done;
879
880 case 11: /* cmpi */
881 imm = (short) instr;
882 val = regs->gpr[ra];
883#ifdef __powerpc64__
884 if ((rd & 1) == 0)
885 val = (int) val;
886#endif
887 do_cmp_signed(regs, val, imm, rd >> 2);
888 goto instr_done;
889
890 case 12: /* addic */
891 imm = (short) instr;
892 add_with_carry(regs, rd, regs->gpr[ra], imm, 0);
893 goto instr_done;
894
895 case 13: /* addic. */
896 imm = (short) instr;
897 add_with_carry(regs, rd, regs->gpr[ra], imm, 0);
898 set_cr0(regs, rd);
899 goto instr_done;
900
901 case 14: /* addi */
902 imm = (short) instr;
903 if (ra)
904 imm += regs->gpr[ra];
905 regs->gpr[rd] = imm;
906 goto instr_done;
907
908 case 15: /* addis */
909 imm = ((short) instr) << 16;
910 if (ra)
911 imm += regs->gpr[ra];
912 regs->gpr[rd] = imm;
913 goto instr_done;
914
915 case 20: /* rlwimi */
916 mb = (instr >> 6) & 0x1f;
917 me = (instr >> 1) & 0x1f;
918 val = DATA32(regs->gpr[rd]);
919 imm = MASK32(mb, me);
920 regs->gpr[ra] = (regs->gpr[ra] & ~imm) | (ROTATE(val, rb) & imm);
921 goto logical_done;
922
923 case 21: /* rlwinm */
924 mb = (instr >> 6) & 0x1f;
925 me = (instr >> 1) & 0x1f;
926 val = DATA32(regs->gpr[rd]);
927 regs->gpr[ra] = ROTATE(val, rb) & MASK32(mb, me);
928 goto logical_done;
929
930 case 23: /* rlwnm */
931 mb = (instr >> 6) & 0x1f;
932 me = (instr >> 1) & 0x1f;
933 rb = regs->gpr[rb] & 0x1f;
934 val = DATA32(regs->gpr[rd]);
935 regs->gpr[ra] = ROTATE(val, rb) & MASK32(mb, me);
936 goto logical_done;
937
938 case 24: /* ori */
939 imm = (unsigned short) instr;
940 regs->gpr[ra] = regs->gpr[rd] | imm;
941 goto instr_done;
942
943 case 25: /* oris */
944 imm = (unsigned short) instr;
945 regs->gpr[ra] = regs->gpr[rd] | (imm << 16);
946 goto instr_done;
947
948 case 26: /* xori */
949 imm = (unsigned short) instr;
950 regs->gpr[ra] = regs->gpr[rd] ^ imm;
951 goto instr_done;
952
953 case 27: /* xoris */
954 imm = (unsigned short) instr;
955 regs->gpr[ra] = regs->gpr[rd] ^ (imm << 16);
956 goto instr_done;
957
958 case 28: /* andi. */
959 imm = (unsigned short) instr;
960 regs->gpr[ra] = regs->gpr[rd] & imm;
961 set_cr0(regs, ra);
962 goto instr_done;
963
964 case 29: /* andis. */
965 imm = (unsigned short) instr;
966 regs->gpr[ra] = regs->gpr[rd] & (imm << 16);
967 set_cr0(regs, ra);
968 goto instr_done;
969
970#ifdef __powerpc64__
971 case 30: /* rld* */
972 mb = ((instr >> 6) & 0x1f) | (instr & 0x20);
973 val = regs->gpr[rd];
974 if ((instr & 0x10) == 0) {
975 sh = rb | ((instr & 2) << 4);
976 val = ROTATE(val, sh);
977 switch ((instr >> 2) & 3) {
978 case 0: /* rldicl */
979 regs->gpr[ra] = val & MASK64_L(mb);
980 goto logical_done;
981 case 1: /* rldicr */
982 regs->gpr[ra] = val & MASK64_R(mb);
983 goto logical_done;
984 case 2: /* rldic */
985 regs->gpr[ra] = val & MASK64(mb, 63 - sh);
986 goto logical_done;
987 case 3: /* rldimi */
988 imm = MASK64(mb, 63 - sh);
989 regs->gpr[ra] = (regs->gpr[ra] & ~imm) |
990 (val & imm);
991 goto logical_done;
992 }
993 } else {
994 sh = regs->gpr[rb] & 0x3f;
995 val = ROTATE(val, sh);
996 switch ((instr >> 1) & 7) {
997 case 0: /* rldcl */
998 regs->gpr[ra] = val & MASK64_L(mb);
999 goto logical_done;
1000 case 1: /* rldcr */
1001 regs->gpr[ra] = val & MASK64_R(mb);
1002 goto logical_done;
1003 }
1004 }
1005#endif
Oliver O'Halloran66707832016-02-16 17:31:53 +11001006 break; /* illegal instruction */
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001007
1008 case 31:
1009 switch ((instr >> 1) & 0x3ff) {
Paul Mackerrascf87c3f2014-09-02 14:35:08 +10001010 case 4: /* tw */
1011 if (rd == 0x1f ||
1012 (rd & trap_compare((int)regs->gpr[ra],
1013 (int)regs->gpr[rb])))
1014 goto trap;
1015 goto instr_done;
1016#ifdef __powerpc64__
1017 case 68: /* td */
1018 if (rd & trap_compare(regs->gpr[ra], regs->gpr[rb]))
1019 goto trap;
1020 goto instr_done;
1021#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001022 case 83: /* mfmsr */
1023 if (regs->msr & MSR_PR)
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001024 goto priv;
1025 op->type = MFMSR;
1026 op->reg = rd;
1027 return 0;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001028 case 146: /* mtmsr */
1029 if (regs->msr & MSR_PR)
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001030 goto priv;
1031 op->type = MTMSR;
1032 op->reg = rd;
1033 op->val = 0xffffffff & ~(MSR_ME | MSR_LE);
1034 return 0;
Paul Mackerrasc0325242005-10-28 22:48:08 +10001035#ifdef CONFIG_PPC64
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001036 case 178: /* mtmsrd */
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001037 if (regs->msr & MSR_PR)
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001038 goto priv;
1039 op->type = MTMSR;
1040 op->reg = rd;
1041 /* only MSR_EE and MSR_RI get changed if bit 15 set */
1042 /* mtmsrd doesn't change MSR_HV, MSR_ME or MSR_LE */
1043 imm = (instr & 0x10000)? 0x8002: 0xefffffffffffeffeUL;
1044 op->val = imm;
1045 return 0;
Paul Mackerrasc0325242005-10-28 22:48:08 +10001046#endif
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001047
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001048 case 19: /* mfcr */
Anton Blanchard64e756c2017-06-15 09:46:39 +10001049 if ((instr >> 20) & 1) {
1050 imm = 0xf0000000UL;
1051 for (sh = 0; sh < 8; ++sh) {
1052 if (instr & (0x80000 >> sh)) {
1053 regs->gpr[rd] = regs->ccr & imm;
1054 break;
1055 }
1056 imm >>= 4;
1057 }
1058
1059 goto instr_done;
1060 }
1061
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001062 regs->gpr[rd] = regs->ccr;
1063 regs->gpr[rd] &= 0xffffffffUL;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001064 goto instr_done;
1065
1066 case 144: /* mtcrf */
1067 imm = 0xf0000000UL;
1068 val = regs->gpr[rd];
1069 for (sh = 0; sh < 8; ++sh) {
1070 if (instr & (0x80000 >> sh))
1071 regs->ccr = (regs->ccr & ~imm) |
1072 (val & imm);
1073 imm >>= 4;
1074 }
1075 goto instr_done;
1076
1077 case 339: /* mfspr */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001078 spr = ((instr >> 16) & 0x1f) | ((instr >> 6) & 0x3e0);
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001079 switch (spr) {
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001080 case SPRN_XER: /* mfxer */
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001081 regs->gpr[rd] = regs->xer;
1082 regs->gpr[rd] &= 0xffffffffUL;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001083 goto instr_done;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001084 case SPRN_LR: /* mflr */
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001085 regs->gpr[rd] = regs->link;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001086 goto instr_done;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001087 case SPRN_CTR: /* mfctr */
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001088 regs->gpr[rd] = regs->ctr;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001089 goto instr_done;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001090 default:
1091 op->type = MFSPR;
1092 op->reg = rd;
1093 op->spr = spr;
1094 return 0;
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001095 }
1096 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001097
1098 case 467: /* mtspr */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001099 spr = ((instr >> 16) & 0x1f) | ((instr >> 6) & 0x3e0);
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001100 switch (spr) {
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001101 case SPRN_XER: /* mtxer */
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001102 regs->xer = (regs->gpr[rd] & 0xffffffffUL);
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001103 goto instr_done;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001104 case SPRN_LR: /* mtlr */
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001105 regs->link = regs->gpr[rd];
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001106 goto instr_done;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001107 case SPRN_CTR: /* mtctr */
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001108 regs->ctr = regs->gpr[rd];
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001109 goto instr_done;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001110 default:
1111 op->type = MTSPR;
1112 op->val = regs->gpr[rd];
1113 op->spr = spr;
1114 return 0;
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001115 }
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001116 break;
1117
1118/*
1119 * Compare instructions
1120 */
1121 case 0: /* cmp */
1122 val = regs->gpr[ra];
1123 val2 = regs->gpr[rb];
1124#ifdef __powerpc64__
1125 if ((rd & 1) == 0) {
1126 /* word (32-bit) compare */
1127 val = (int) val;
1128 val2 = (int) val2;
1129 }
1130#endif
1131 do_cmp_signed(regs, val, val2, rd >> 2);
1132 goto instr_done;
1133
1134 case 32: /* cmpl */
1135 val = regs->gpr[ra];
1136 val2 = regs->gpr[rb];
1137#ifdef __powerpc64__
1138 if ((rd & 1) == 0) {
1139 /* word (32-bit) compare */
1140 val = (unsigned int) val;
1141 val2 = (unsigned int) val2;
1142 }
1143#endif
1144 do_cmp_unsigned(regs, val, val2, rd >> 2);
1145 goto instr_done;
1146
Matt Brown02c0f622017-07-31 10:58:22 +10001147 case 508: /* cmpb */
1148 do_cmpb(regs, regs->gpr[rd], regs->gpr[rb], ra);
1149 goto instr_done;
1150
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001151/*
1152 * Arithmetic instructions
1153 */
1154 case 8: /* subfc */
1155 add_with_carry(regs, rd, ~regs->gpr[ra],
1156 regs->gpr[rb], 1);
1157 goto arith_done;
1158#ifdef __powerpc64__
1159 case 9: /* mulhdu */
1160 asm("mulhdu %0,%1,%2" : "=r" (regs->gpr[rd]) :
1161 "r" (regs->gpr[ra]), "r" (regs->gpr[rb]));
1162 goto arith_done;
1163#endif
1164 case 10: /* addc */
1165 add_with_carry(regs, rd, regs->gpr[ra],
1166 regs->gpr[rb], 0);
1167 goto arith_done;
1168
1169 case 11: /* mulhwu */
1170 asm("mulhwu %0,%1,%2" : "=r" (regs->gpr[rd]) :
1171 "r" (regs->gpr[ra]), "r" (regs->gpr[rb]));
1172 goto arith_done;
1173
1174 case 40: /* subf */
1175 regs->gpr[rd] = regs->gpr[rb] - regs->gpr[ra];
1176 goto arith_done;
1177#ifdef __powerpc64__
1178 case 73: /* mulhd */
1179 asm("mulhd %0,%1,%2" : "=r" (regs->gpr[rd]) :
1180 "r" (regs->gpr[ra]), "r" (regs->gpr[rb]));
1181 goto arith_done;
1182#endif
1183 case 75: /* mulhw */
1184 asm("mulhw %0,%1,%2" : "=r" (regs->gpr[rd]) :
1185 "r" (regs->gpr[ra]), "r" (regs->gpr[rb]));
1186 goto arith_done;
1187
1188 case 104: /* neg */
1189 regs->gpr[rd] = -regs->gpr[ra];
1190 goto arith_done;
1191
1192 case 136: /* subfe */
1193 add_with_carry(regs, rd, ~regs->gpr[ra], regs->gpr[rb],
1194 regs->xer & XER_CA);
1195 goto arith_done;
1196
1197 case 138: /* adde */
1198 add_with_carry(regs, rd, regs->gpr[ra], regs->gpr[rb],
1199 regs->xer & XER_CA);
1200 goto arith_done;
1201
1202 case 200: /* subfze */
1203 add_with_carry(regs, rd, ~regs->gpr[ra], 0L,
1204 regs->xer & XER_CA);
1205 goto arith_done;
1206
1207 case 202: /* addze */
1208 add_with_carry(regs, rd, regs->gpr[ra], 0L,
1209 regs->xer & XER_CA);
1210 goto arith_done;
1211
1212 case 232: /* subfme */
1213 add_with_carry(regs, rd, ~regs->gpr[ra], -1L,
1214 regs->xer & XER_CA);
1215 goto arith_done;
1216#ifdef __powerpc64__
1217 case 233: /* mulld */
1218 regs->gpr[rd] = regs->gpr[ra] * regs->gpr[rb];
1219 goto arith_done;
1220#endif
1221 case 234: /* addme */
1222 add_with_carry(regs, rd, regs->gpr[ra], -1L,
1223 regs->xer & XER_CA);
1224 goto arith_done;
1225
1226 case 235: /* mullw */
1227 regs->gpr[rd] = (unsigned int) regs->gpr[ra] *
1228 (unsigned int) regs->gpr[rb];
1229 goto arith_done;
1230
1231 case 266: /* add */
1232 regs->gpr[rd] = regs->gpr[ra] + regs->gpr[rb];
1233 goto arith_done;
1234#ifdef __powerpc64__
1235 case 457: /* divdu */
1236 regs->gpr[rd] = regs->gpr[ra] / regs->gpr[rb];
1237 goto arith_done;
1238#endif
1239 case 459: /* divwu */
1240 regs->gpr[rd] = (unsigned int) regs->gpr[ra] /
1241 (unsigned int) regs->gpr[rb];
1242 goto arith_done;
1243#ifdef __powerpc64__
1244 case 489: /* divd */
1245 regs->gpr[rd] = (long int) regs->gpr[ra] /
1246 (long int) regs->gpr[rb];
1247 goto arith_done;
1248#endif
1249 case 491: /* divw */
1250 regs->gpr[rd] = (int) regs->gpr[ra] /
1251 (int) regs->gpr[rb];
1252 goto arith_done;
1253
1254
1255/*
1256 * Logical instructions
1257 */
1258 case 26: /* cntlzw */
1259 asm("cntlzw %0,%1" : "=r" (regs->gpr[ra]) :
1260 "r" (regs->gpr[rd]));
1261 goto logical_done;
1262#ifdef __powerpc64__
1263 case 58: /* cntlzd */
1264 asm("cntlzd %0,%1" : "=r" (regs->gpr[ra]) :
1265 "r" (regs->gpr[rd]));
1266 goto logical_done;
1267#endif
1268 case 28: /* and */
1269 regs->gpr[ra] = regs->gpr[rd] & regs->gpr[rb];
1270 goto logical_done;
1271
1272 case 60: /* andc */
1273 regs->gpr[ra] = regs->gpr[rd] & ~regs->gpr[rb];
1274 goto logical_done;
1275
Matt Browndcbd19b2017-07-31 10:58:23 +10001276 case 122: /* popcntb */
1277 do_popcnt(regs, regs->gpr[rd], 8, ra);
1278 goto logical_done;
1279
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001280 case 124: /* nor */
1281 regs->gpr[ra] = ~(regs->gpr[rd] | regs->gpr[rb]);
1282 goto logical_done;
Matt Brown2c979c42017-07-31 10:58:25 +10001283
1284 case 154: /* prtyw */
1285 do_prty(regs, regs->gpr[rd], 32, ra);
1286 goto logical_done;
1287
1288 case 186: /* prtyd */
1289 do_prty(regs, regs->gpr[rd], 64, ra);
1290 goto logical_done;
Matt Brownf3127932017-07-31 10:58:24 +10001291#ifdef CONFIG_PPC64
1292 case 252: /* bpermd */
1293 do_bpermd(regs, regs->gpr[rd], regs->gpr[rb], ra);
1294 goto logical_done;
1295#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001296 case 284: /* xor */
1297 regs->gpr[ra] = ~(regs->gpr[rd] ^ regs->gpr[rb]);
1298 goto logical_done;
1299
1300 case 316: /* xor */
1301 regs->gpr[ra] = regs->gpr[rd] ^ regs->gpr[rb];
1302 goto logical_done;
1303
Matt Browndcbd19b2017-07-31 10:58:23 +10001304 case 378: /* popcntw */
1305 do_popcnt(regs, regs->gpr[rd], 32, ra);
1306 goto logical_done;
1307
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001308 case 412: /* orc */
1309 regs->gpr[ra] = regs->gpr[rd] | ~regs->gpr[rb];
1310 goto logical_done;
1311
1312 case 444: /* or */
1313 regs->gpr[ra] = regs->gpr[rd] | regs->gpr[rb];
1314 goto logical_done;
1315
1316 case 476: /* nand */
1317 regs->gpr[ra] = ~(regs->gpr[rd] & regs->gpr[rb]);
1318 goto logical_done;
Matt Browndcbd19b2017-07-31 10:58:23 +10001319#ifdef CONFIG_PPC64
1320 case 506: /* popcntd */
1321 do_popcnt(regs, regs->gpr[rd], 64, ra);
1322 goto logical_done;
1323#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001324 case 922: /* extsh */
1325 regs->gpr[ra] = (signed short) regs->gpr[rd];
1326 goto logical_done;
1327
1328 case 954: /* extsb */
1329 regs->gpr[ra] = (signed char) regs->gpr[rd];
1330 goto logical_done;
1331#ifdef __powerpc64__
1332 case 986: /* extsw */
1333 regs->gpr[ra] = (signed int) regs->gpr[rd];
1334 goto logical_done;
1335#endif
1336
1337/*
1338 * Shift instructions
1339 */
1340 case 24: /* slw */
1341 sh = regs->gpr[rb] & 0x3f;
1342 if (sh < 32)
1343 regs->gpr[ra] = (regs->gpr[rd] << sh) & 0xffffffffUL;
1344 else
1345 regs->gpr[ra] = 0;
1346 goto logical_done;
1347
1348 case 536: /* srw */
1349 sh = regs->gpr[rb] & 0x3f;
1350 if (sh < 32)
1351 regs->gpr[ra] = (regs->gpr[rd] & 0xffffffffUL) >> sh;
1352 else
1353 regs->gpr[ra] = 0;
1354 goto logical_done;
1355
1356 case 792: /* sraw */
1357 sh = regs->gpr[rb] & 0x3f;
1358 ival = (signed int) regs->gpr[rd];
1359 regs->gpr[ra] = ival >> (sh < 32 ? sh : 31);
Paul Mackerrase698b962014-07-19 17:47:57 +10001360 if (ival < 0 && (sh >= 32 || (ival & ((1ul << sh) - 1)) != 0))
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001361 regs->xer |= XER_CA;
1362 else
1363 regs->xer &= ~XER_CA;
1364 goto logical_done;
1365
1366 case 824: /* srawi */
1367 sh = rb;
1368 ival = (signed int) regs->gpr[rd];
1369 regs->gpr[ra] = ival >> sh;
Paul Mackerrase698b962014-07-19 17:47:57 +10001370 if (ival < 0 && (ival & ((1ul << sh) - 1)) != 0)
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001371 regs->xer |= XER_CA;
1372 else
1373 regs->xer &= ~XER_CA;
1374 goto logical_done;
1375
1376#ifdef __powerpc64__
1377 case 27: /* sld */
Paul Mackerrase698b962014-07-19 17:47:57 +10001378 sh = regs->gpr[rb] & 0x7f;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001379 if (sh < 64)
1380 regs->gpr[ra] = regs->gpr[rd] << sh;
1381 else
1382 regs->gpr[ra] = 0;
1383 goto logical_done;
1384
1385 case 539: /* srd */
1386 sh = regs->gpr[rb] & 0x7f;
1387 if (sh < 64)
1388 regs->gpr[ra] = regs->gpr[rd] >> sh;
1389 else
1390 regs->gpr[ra] = 0;
1391 goto logical_done;
1392
1393 case 794: /* srad */
1394 sh = regs->gpr[rb] & 0x7f;
1395 ival = (signed long int) regs->gpr[rd];
1396 regs->gpr[ra] = ival >> (sh < 64 ? sh : 63);
Paul Mackerrase698b962014-07-19 17:47:57 +10001397 if (ival < 0 && (sh >= 64 || (ival & ((1ul << sh) - 1)) != 0))
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001398 regs->xer |= XER_CA;
1399 else
1400 regs->xer &= ~XER_CA;
1401 goto logical_done;
1402
1403 case 826: /* sradi with sh_5 = 0 */
1404 case 827: /* sradi with sh_5 = 1 */
1405 sh = rb | ((instr & 2) << 4);
1406 ival = (signed long int) regs->gpr[rd];
1407 regs->gpr[ra] = ival >> sh;
Paul Mackerrase698b962014-07-19 17:47:57 +10001408 if (ival < 0 && (ival & ((1ul << sh) - 1)) != 0)
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001409 regs->xer |= XER_CA;
1410 else
1411 regs->xer &= ~XER_CA;
1412 goto logical_done;
1413#endif /* __powerpc64__ */
1414
1415/*
1416 * Cache instructions
1417 */
1418 case 54: /* dcbst */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001419 op->type = MKOP(CACHEOP, DCBST, 0);
1420 op->ea = xform_ea(instr, regs);
1421 return 0;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001422
1423 case 86: /* dcbf */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001424 op->type = MKOP(CACHEOP, DCBF, 0);
1425 op->ea = xform_ea(instr, regs);
1426 return 0;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001427
1428 case 246: /* dcbtst */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001429 op->type = MKOP(CACHEOP, DCBTST, 0);
1430 op->ea = xform_ea(instr, regs);
1431 op->reg = rd;
1432 return 0;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001433
1434 case 278: /* dcbt */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001435 op->type = MKOP(CACHEOP, DCBTST, 0);
1436 op->ea = xform_ea(instr, regs);
1437 op->reg = rd;
1438 return 0;
Paul Mackerrascf87c3f2014-09-02 14:35:08 +10001439
1440 case 982: /* icbi */
1441 op->type = MKOP(CACHEOP, ICBI, 0);
1442 op->ea = xform_ea(instr, regs);
1443 return 0;
Paul Mackerras14cf11a2005-09-26 16:04:21 +10001444 }
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001445 break;
Paul Mackerras14cf11a2005-09-26 16:04:21 +10001446 }
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001447
1448 /*
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001449 * Loads and stores.
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001450 */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001451 op->type = UNKNOWN;
1452 op->update_reg = ra;
1453 op->reg = rd;
1454 op->val = regs->gpr[rd];
1455 u = (instr >> 20) & UPDATE;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001456
1457 switch (opcode) {
1458 case 31:
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001459 u = instr & UPDATE;
1460 op->ea = xform_ea(instr, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001461 switch ((instr >> 1) & 0x3ff) {
1462 case 20: /* lwarx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001463 op->type = MKOP(LARX, 0, 4);
1464 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001465
1466 case 150: /* stwcx. */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001467 op->type = MKOP(STCX, 0, 4);
1468 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001469
1470#ifdef __powerpc64__
1471 case 84: /* ldarx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001472 op->type = MKOP(LARX, 0, 8);
1473 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001474
1475 case 214: /* stdcx. */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001476 op->type = MKOP(STCX, 0, 8);
1477 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001478
1479 case 21: /* ldx */
1480 case 53: /* ldux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001481 op->type = MKOP(LOAD, u, 8);
1482 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001483#endif
1484
1485 case 23: /* lwzx */
1486 case 55: /* lwzux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001487 op->type = MKOP(LOAD, u, 4);
1488 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001489
1490 case 87: /* lbzx */
1491 case 119: /* lbzux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001492 op->type = MKOP(LOAD, u, 1);
1493 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001494
1495#ifdef CONFIG_ALTIVEC
1496 case 103: /* lvx */
1497 case 359: /* lvxl */
1498 if (!(regs->msr & MSR_VEC))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001499 goto vecunavail;
1500 op->type = MKOP(LOAD_VMX, 0, 16);
1501 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001502
1503 case 231: /* stvx */
1504 case 487: /* stvxl */
1505 if (!(regs->msr & MSR_VEC))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001506 goto vecunavail;
1507 op->type = MKOP(STORE_VMX, 0, 16);
1508 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001509#endif /* CONFIG_ALTIVEC */
1510
1511#ifdef __powerpc64__
1512 case 149: /* stdx */
1513 case 181: /* stdux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001514 op->type = MKOP(STORE, u, 8);
1515 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001516#endif
1517
1518 case 151: /* stwx */
1519 case 183: /* stwux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001520 op->type = MKOP(STORE, u, 4);
1521 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001522
1523 case 215: /* stbx */
1524 case 247: /* stbux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001525 op->type = MKOP(STORE, u, 1);
1526 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001527
1528 case 279: /* lhzx */
1529 case 311: /* lhzux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001530 op->type = MKOP(LOAD, u, 2);
1531 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001532
1533#ifdef __powerpc64__
1534 case 341: /* lwax */
1535 case 373: /* lwaux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001536 op->type = MKOP(LOAD, SIGNEXT | u, 4);
1537 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001538#endif
1539
1540 case 343: /* lhax */
1541 case 375: /* lhaux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001542 op->type = MKOP(LOAD, SIGNEXT | u, 2);
1543 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001544
1545 case 407: /* sthx */
1546 case 439: /* sthux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001547 op->type = MKOP(STORE, u, 2);
1548 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001549
1550#ifdef __powerpc64__
1551 case 532: /* ldbrx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001552 op->type = MKOP(LOAD, BYTEREV, 8);
1553 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001554
1555#endif
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001556 case 533: /* lswx */
1557 op->type = MKOP(LOAD_MULTI, 0, regs->xer & 0x7f);
1558 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001559
1560 case 534: /* lwbrx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001561 op->type = MKOP(LOAD, BYTEREV, 4);
1562 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001563
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001564 case 597: /* lswi */
1565 if (rb == 0)
1566 rb = 32; /* # bytes to load */
1567 op->type = MKOP(LOAD_MULTI, 0, rb);
1568 op->ea = 0;
1569 if (ra)
1570 op->ea = truncate_if_32bit(regs->msr,
1571 regs->gpr[ra]);
1572 break;
1573
Paul Bolleb69a1da2014-05-20 21:59:42 +02001574#ifdef CONFIG_PPC_FPU
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001575 case 535: /* lfsx */
1576 case 567: /* lfsux */
1577 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001578 goto fpunavail;
1579 op->type = MKOP(LOAD_FP, u, 4);
1580 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001581
1582 case 599: /* lfdx */
1583 case 631: /* lfdux */
1584 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001585 goto fpunavail;
1586 op->type = MKOP(LOAD_FP, u, 8);
1587 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001588
1589 case 663: /* stfsx */
1590 case 695: /* stfsux */
1591 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001592 goto fpunavail;
1593 op->type = MKOP(STORE_FP, u, 4);
1594 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001595
1596 case 727: /* stfdx */
1597 case 759: /* stfdux */
1598 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001599 goto fpunavail;
1600 op->type = MKOP(STORE_FP, u, 8);
1601 break;
Sean MacLennancd64d162010-09-01 07:21:21 +00001602#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001603
1604#ifdef __powerpc64__
1605 case 660: /* stdbrx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001606 op->type = MKOP(STORE, BYTEREV, 8);
1607 op->val = byterev_8(regs->gpr[rd]);
1608 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001609
1610#endif
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001611 case 661: /* stswx */
1612 op->type = MKOP(STORE_MULTI, 0, regs->xer & 0x7f);
1613 break;
1614
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001615 case 662: /* stwbrx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001616 op->type = MKOP(STORE, BYTEREV, 4);
1617 op->val = byterev_4(regs->gpr[rd]);
1618 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001619
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001620 case 725:
1621 if (rb == 0)
1622 rb = 32; /* # bytes to store */
1623 op->type = MKOP(STORE_MULTI, 0, rb);
1624 op->ea = 0;
1625 if (ra)
1626 op->ea = truncate_if_32bit(regs->msr,
1627 regs->gpr[ra]);
1628 break;
1629
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001630 case 790: /* lhbrx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001631 op->type = MKOP(LOAD, BYTEREV, 2);
1632 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001633
1634 case 918: /* sthbrx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001635 op->type = MKOP(STORE, BYTEREV, 2);
1636 op->val = byterev_2(regs->gpr[rd]);
1637 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001638
1639#ifdef CONFIG_VSX
1640 case 844: /* lxvd2x */
1641 case 876: /* lxvd2ux */
1642 if (!(regs->msr & MSR_VSX))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001643 goto vsxunavail;
1644 op->reg = rd | ((instr & 1) << 5);
1645 op->type = MKOP(LOAD_VSX, u, 16);
1646 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001647
1648 case 972: /* stxvd2x */
1649 case 1004: /* stxvd2ux */
1650 if (!(regs->msr & MSR_VSX))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001651 goto vsxunavail;
1652 op->reg = rd | ((instr & 1) << 5);
1653 op->type = MKOP(STORE_VSX, u, 16);
1654 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001655
1656#endif /* CONFIG_VSX */
1657 }
1658 break;
1659
1660 case 32: /* lwz */
1661 case 33: /* lwzu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001662 op->type = MKOP(LOAD, u, 4);
1663 op->ea = dform_ea(instr, regs);
1664 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001665
1666 case 34: /* lbz */
1667 case 35: /* lbzu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001668 op->type = MKOP(LOAD, u, 1);
1669 op->ea = dform_ea(instr, regs);
1670 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001671
1672 case 36: /* stw */
Tiejun Chen8e9f6932012-09-16 23:54:31 +00001673 case 37: /* stwu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001674 op->type = MKOP(STORE, u, 4);
1675 op->ea = dform_ea(instr, regs);
1676 break;
Tiejun Chen8e9f6932012-09-16 23:54:31 +00001677
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001678 case 38: /* stb */
1679 case 39: /* stbu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001680 op->type = MKOP(STORE, u, 1);
1681 op->ea = dform_ea(instr, regs);
1682 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001683
1684 case 40: /* lhz */
1685 case 41: /* lhzu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001686 op->type = MKOP(LOAD, u, 2);
1687 op->ea = dform_ea(instr, regs);
1688 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001689
1690 case 42: /* lha */
1691 case 43: /* lhau */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001692 op->type = MKOP(LOAD, SIGNEXT | u, 2);
1693 op->ea = dform_ea(instr, regs);
1694 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001695
1696 case 44: /* sth */
1697 case 45: /* sthu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001698 op->type = MKOP(STORE, u, 2);
1699 op->ea = dform_ea(instr, regs);
1700 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001701
1702 case 46: /* lmw */
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001703 if (ra >= rd)
1704 break; /* invalid form, ra in range to load */
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001705 op->type = MKOP(LOAD_MULTI, 0, 4 * (32 - rd));
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001706 op->ea = dform_ea(instr, regs);
1707 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001708
1709 case 47: /* stmw */
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001710 op->type = MKOP(STORE_MULTI, 0, 4 * (32 - rd));
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001711 op->ea = dform_ea(instr, regs);
1712 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001713
Sean MacLennancd64d162010-09-01 07:21:21 +00001714#ifdef CONFIG_PPC_FPU
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001715 case 48: /* lfs */
1716 case 49: /* lfsu */
1717 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001718 goto fpunavail;
1719 op->type = MKOP(LOAD_FP, u, 4);
1720 op->ea = dform_ea(instr, regs);
1721 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001722
1723 case 50: /* lfd */
1724 case 51: /* lfdu */
1725 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001726 goto fpunavail;
1727 op->type = MKOP(LOAD_FP, u, 8);
1728 op->ea = dform_ea(instr, regs);
1729 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001730
1731 case 52: /* stfs */
1732 case 53: /* stfsu */
1733 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001734 goto fpunavail;
1735 op->type = MKOP(STORE_FP, u, 4);
1736 op->ea = dform_ea(instr, regs);
1737 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001738
1739 case 54: /* stfd */
1740 case 55: /* stfdu */
1741 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001742 goto fpunavail;
1743 op->type = MKOP(STORE_FP, u, 8);
1744 op->ea = dform_ea(instr, regs);
1745 break;
Sean MacLennancd64d162010-09-01 07:21:21 +00001746#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001747
1748#ifdef __powerpc64__
1749 case 58: /* ld[u], lwa */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001750 op->ea = dsform_ea(instr, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001751 switch (instr & 3) {
1752 case 0: /* ld */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001753 op->type = MKOP(LOAD, 0, 8);
1754 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001755 case 1: /* ldu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001756 op->type = MKOP(LOAD, UPDATE, 8);
1757 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001758 case 2: /* lwa */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001759 op->type = MKOP(LOAD, SIGNEXT, 4);
1760 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001761 }
1762 break;
1763
1764 case 62: /* std[u] */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001765 op->ea = dsform_ea(instr, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001766 switch (instr & 3) {
1767 case 0: /* std */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001768 op->type = MKOP(STORE, 0, 8);
1769 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001770 case 1: /* stdu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001771 op->type = MKOP(STORE, UPDATE, 8);
1772 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001773 }
1774 break;
1775#endif /* __powerpc64__ */
1776
1777 }
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001778 return 0;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001779
1780 logical_done:
1781 if (instr & 1)
1782 set_cr0(regs, ra);
1783 goto instr_done;
1784
1785 arith_done:
1786 if (instr & 1)
1787 set_cr0(regs, rd);
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001788
1789 instr_done:
1790 regs->nip = truncate_if_32bit(regs->msr, regs->nip + 4);
1791 return 1;
1792
1793 priv:
1794 op->type = INTERRUPT | 0x700;
1795 op->val = SRR1_PROGPRIV;
1796 return 0;
1797
Paul Mackerrascf87c3f2014-09-02 14:35:08 +10001798 trap:
1799 op->type = INTERRUPT | 0x700;
1800 op->val = SRR1_PROGTRAP;
1801 return 0;
1802
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001803#ifdef CONFIG_PPC_FPU
1804 fpunavail:
1805 op->type = INTERRUPT | 0x800;
1806 return 0;
1807#endif
1808
1809#ifdef CONFIG_ALTIVEC
1810 vecunavail:
1811 op->type = INTERRUPT | 0xf20;
1812 return 0;
1813#endif
1814
1815#ifdef CONFIG_VSX
1816 vsxunavail:
1817 op->type = INTERRUPT | 0xf40;
1818 return 0;
1819#endif
1820}
1821EXPORT_SYMBOL_GPL(analyse_instr);
Naveen N. Rao71f6e582017-04-12 16:48:51 +05301822NOKPROBE_SYMBOL(analyse_instr);
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001823
1824/*
1825 * For PPC32 we always use stwu with r1 to change the stack pointer.
1826 * So this emulated store may corrupt the exception frame, now we
1827 * have to provide the exception frame trampoline, which is pushed
1828 * below the kprobed function stack. So we only update gpr[1] but
1829 * don't emulate the real store operation. We will do real store
1830 * operation safely in exception return code by checking this flag.
1831 */
Naveen N. Rao71f6e582017-04-12 16:48:51 +05301832static nokprobe_inline int handle_stack_update(unsigned long ea, struct pt_regs *regs)
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001833{
1834#ifdef CONFIG_PPC32
1835 /*
1836 * Check if we will touch kernel stack overflow
1837 */
1838 if (ea - STACK_INT_FRAME_SIZE <= current->thread.ksp_limit) {
1839 printk(KERN_CRIT "Can't kprobe this since kernel stack would overflow.\n");
1840 return -EINVAL;
1841 }
1842#endif /* CONFIG_PPC32 */
1843 /*
1844 * Check if we already set since that means we'll
1845 * lose the previous value.
1846 */
1847 WARN_ON(test_thread_flag(TIF_EMULATE_STACK_STORE));
1848 set_thread_flag(TIF_EMULATE_STACK_STORE);
1849 return 0;
1850}
1851
Naveen N. Rao71f6e582017-04-12 16:48:51 +05301852static nokprobe_inline void do_signext(unsigned long *valp, int size)
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001853{
1854 switch (size) {
1855 case 2:
1856 *valp = (signed short) *valp;
1857 break;
1858 case 4:
1859 *valp = (signed int) *valp;
1860 break;
1861 }
1862}
1863
Naveen N. Rao71f6e582017-04-12 16:48:51 +05301864static nokprobe_inline void do_byterev(unsigned long *valp, int size)
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001865{
1866 switch (size) {
1867 case 2:
1868 *valp = byterev_2(*valp);
1869 break;
1870 case 4:
1871 *valp = byterev_4(*valp);
1872 break;
1873#ifdef __powerpc64__
1874 case 8:
1875 *valp = byterev_8(*valp);
1876 break;
1877#endif
1878 }
1879}
1880
1881/*
1882 * Emulate instructions that cause a transfer of control,
1883 * loads and stores, and a few other instructions.
1884 * Returns 1 if the step was emulated, 0 if not,
1885 * or -1 if the instruction is one that should not be stepped,
1886 * such as an rfid, or a mtmsrd that would clear MSR_RI.
1887 */
Naveen N. Rao71f6e582017-04-12 16:48:51 +05301888int emulate_step(struct pt_regs *regs, unsigned int instr)
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001889{
1890 struct instruction_op op;
1891 int r, err, size;
1892 unsigned long val;
1893 unsigned int cr;
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001894 int i, rd, nb;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001895
1896 r = analyse_instr(&op, regs, instr);
1897 if (r != 0)
1898 return r;
1899
1900 err = 0;
1901 size = GETSIZE(op.type);
1902 switch (op.type & INSTR_TYPE_MASK) {
1903 case CACHEOP:
1904 if (!address_ok(regs, op.ea, 8))
1905 return 0;
1906 switch (op.type & CACHEOP_MASK) {
1907 case DCBST:
1908 __cacheop_user_asmx(op.ea, err, "dcbst");
1909 break;
1910 case DCBF:
1911 __cacheop_user_asmx(op.ea, err, "dcbf");
1912 break;
1913 case DCBTST:
1914 if (op.reg == 0)
1915 prefetchw((void *) op.ea);
1916 break;
1917 case DCBT:
1918 if (op.reg == 0)
1919 prefetch((void *) op.ea);
1920 break;
Paul Mackerrascf87c3f2014-09-02 14:35:08 +10001921 case ICBI:
1922 __cacheop_user_asmx(op.ea, err, "icbi");
1923 break;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001924 }
1925 if (err)
1926 return 0;
1927 goto instr_done;
1928
1929 case LARX:
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001930 if (op.ea & (size - 1))
1931 break; /* can't handle misaligned */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001932 if (!address_ok(regs, op.ea, size))
Markus Elfring3c4b66a2017-01-21 15:30:15 +01001933 return 0;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001934 err = 0;
1935 switch (size) {
1936 case 4:
1937 __get_user_asmx(val, op.ea, err, "lwarx");
1938 break;
Lennart Sorensendd217312016-05-05 16:44:44 -04001939#ifdef __powerpc64__
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001940 case 8:
1941 __get_user_asmx(val, op.ea, err, "ldarx");
1942 break;
Lennart Sorensendd217312016-05-05 16:44:44 -04001943#endif
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001944 default:
1945 return 0;
1946 }
1947 if (!err)
1948 regs->gpr[op.reg] = val;
1949 goto ldst_done;
1950
1951 case STCX:
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001952 if (op.ea & (size - 1))
1953 break; /* can't handle misaligned */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001954 if (!address_ok(regs, op.ea, size))
Markus Elfring3c4b66a2017-01-21 15:30:15 +01001955 return 0;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001956 err = 0;
1957 switch (size) {
1958 case 4:
1959 __put_user_asmx(op.val, op.ea, err, "stwcx.", cr);
1960 break;
Lennart Sorensendd217312016-05-05 16:44:44 -04001961#ifdef __powerpc64__
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001962 case 8:
1963 __put_user_asmx(op.val, op.ea, err, "stdcx.", cr);
1964 break;
Lennart Sorensendd217312016-05-05 16:44:44 -04001965#endif
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001966 default:
1967 return 0;
1968 }
1969 if (!err)
1970 regs->ccr = (regs->ccr & 0x0fffffff) |
1971 (cr & 0xe0000000) |
1972 ((regs->xer >> 3) & 0x10000000);
1973 goto ldst_done;
1974
1975 case LOAD:
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001976 err = read_mem(&regs->gpr[op.reg], op.ea, size, regs);
1977 if (!err) {
1978 if (op.type & SIGNEXT)
1979 do_signext(&regs->gpr[op.reg], size);
1980 if (op.type & BYTEREV)
1981 do_byterev(&regs->gpr[op.reg], size);
1982 }
1983 goto ldst_done;
1984
Paul Mackerras7048c842014-11-03 15:46:43 +11001985#ifdef CONFIG_PPC_FPU
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001986 case LOAD_FP:
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001987 if (size == 4)
1988 err = do_fp_load(op.reg, do_lfs, op.ea, size, regs);
1989 else
1990 err = do_fp_load(op.reg, do_lfd, op.ea, size, regs);
1991 goto ldst_done;
Paul Mackerras7048c842014-11-03 15:46:43 +11001992#endif
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001993#ifdef CONFIG_ALTIVEC
1994 case LOAD_VMX:
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001995 err = do_vec_load(op.reg, do_lvx, op.ea & ~0xfUL, regs);
1996 goto ldst_done;
1997#endif
1998#ifdef CONFIG_VSX
1999 case LOAD_VSX:
Paul Mackerrasbe96f632014-09-02 14:35:07 +10002000 err = do_vsx_load(op.reg, do_lxvd2x, op.ea, regs);
2001 goto ldst_done;
2002#endif
2003 case LOAD_MULTI:
2004 if (regs->msr & MSR_LE)
2005 return 0;
2006 rd = op.reg;
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10002007 for (i = 0; i < size; i += 4) {
2008 nb = size - i;
2009 if (nb > 4)
2010 nb = 4;
2011 err = read_mem(&regs->gpr[rd], op.ea, nb, regs);
Paul Mackerrasbe96f632014-09-02 14:35:07 +10002012 if (err)
2013 return 0;
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10002014 if (nb < 4) /* left-justify last bytes */
2015 regs->gpr[rd] <<= 32 - 8 * nb;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10002016 op.ea += 4;
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10002017 ++rd;
2018 }
Paul Mackerrasbe96f632014-09-02 14:35:07 +10002019 goto instr_done;
2020
2021 case STORE:
Paul Mackerrasbe96f632014-09-02 14:35:07 +10002022 if ((op.type & UPDATE) && size == sizeof(long) &&
2023 op.reg == 1 && op.update_reg == 1 &&
2024 !(regs->msr & MSR_PR) &&
2025 op.ea >= regs->gpr[1] - STACK_INT_FRAME_SIZE) {
2026 err = handle_stack_update(op.ea, regs);
2027 goto ldst_done;
2028 }
2029 err = write_mem(op.val, op.ea, size, regs);
2030 goto ldst_done;
2031
Paul Mackerras7048c842014-11-03 15:46:43 +11002032#ifdef CONFIG_PPC_FPU
Paul Mackerrasbe96f632014-09-02 14:35:07 +10002033 case STORE_FP:
Paul Mackerrasbe96f632014-09-02 14:35:07 +10002034 if (size == 4)
2035 err = do_fp_store(op.reg, do_stfs, op.ea, size, regs);
2036 else
2037 err = do_fp_store(op.reg, do_stfd, op.ea, size, regs);
2038 goto ldst_done;
Paul Mackerras7048c842014-11-03 15:46:43 +11002039#endif
Paul Mackerrasbe96f632014-09-02 14:35:07 +10002040#ifdef CONFIG_ALTIVEC
2041 case STORE_VMX:
Paul Mackerrasbe96f632014-09-02 14:35:07 +10002042 err = do_vec_store(op.reg, do_stvx, op.ea & ~0xfUL, regs);
2043 goto ldst_done;
2044#endif
2045#ifdef CONFIG_VSX
2046 case STORE_VSX:
Paul Mackerrasbe96f632014-09-02 14:35:07 +10002047 err = do_vsx_store(op.reg, do_stxvd2x, op.ea, regs);
2048 goto ldst_done;
2049#endif
2050 case STORE_MULTI:
2051 if (regs->msr & MSR_LE)
2052 return 0;
2053 rd = op.reg;
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10002054 for (i = 0; i < size; i += 4) {
2055 val = regs->gpr[rd];
2056 nb = size - i;
2057 if (nb > 4)
2058 nb = 4;
2059 else
2060 val >>= 32 - 8 * nb;
2061 err = write_mem(val, op.ea, nb, regs);
Paul Mackerrasbe96f632014-09-02 14:35:07 +10002062 if (err)
2063 return 0;
2064 op.ea += 4;
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10002065 ++rd;
2066 }
Paul Mackerrasbe96f632014-09-02 14:35:07 +10002067 goto instr_done;
2068
2069 case MFMSR:
2070 regs->gpr[op.reg] = regs->msr & MSR_MASK;
2071 goto instr_done;
2072
2073 case MTMSR:
2074 val = regs->gpr[op.reg];
2075 if ((val & MSR_RI) == 0)
2076 /* can't step mtmsr[d] that would clear MSR_RI */
2077 return -1;
2078 /* here op.val is the mask of bits to change */
2079 regs->msr = (regs->msr & ~op.val) | (val & op.val);
2080 goto instr_done;
2081
2082#ifdef CONFIG_PPC64
2083 case SYSCALL: /* sc */
2084 /*
2085 * N.B. this uses knowledge about how the syscall
2086 * entry code works. If that is changed, this will
2087 * need to be changed also.
2088 */
2089 if (regs->gpr[0] == 0x1ebe &&
2090 cpu_has_feature(CPU_FTR_REAL_LE)) {
2091 regs->msr ^= MSR_LE;
2092 goto instr_done;
2093 }
2094 regs->gpr[9] = regs->gpr[13];
2095 regs->gpr[10] = MSR_KERNEL;
2096 regs->gpr[11] = regs->nip + 4;
2097 regs->gpr[12] = regs->msr & MSR_MASK;
2098 regs->gpr[13] = (unsigned long) get_paca();
2099 regs->nip = (unsigned long) &system_call_common;
2100 regs->msr = MSR_KERNEL;
2101 return 1;
2102
2103 case RFI:
2104 return -1;
2105#endif
2106 }
2107 return 0;
2108
2109 ldst_done:
2110 if (err)
2111 return 0;
2112 if (op.type & UPDATE)
2113 regs->gpr[op.update_reg] = op.ea;
2114
2115 instr_done:
2116 regs->nip = truncate_if_32bit(regs->msr, regs->nip + 4);
2117 return 1;
Paul Mackerras14cf11a2005-09-26 16:04:21 +10002118}
Naveen N. Rao71f6e582017-04-12 16:48:51 +05302119NOKPROBE_SYMBOL(emulate_step);