blob: 06c7e9b884083f3c6423de1d5de61e2d6d93260e [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 */
52static unsigned long truncate_if_32bit(unsigned long msr, unsigned long val)
53{
54#ifdef __powerpc64__
55 if ((msr & MSR_64BIT) == 0)
56 val &= 0xffffffffUL;
57#endif
58 return val;
59}
60
61/*
Paul Mackerras14cf11a2005-09-26 16:04:21 +100062 * Determine whether a conditional branch instruction would branch.
63 */
Gui,Jian0d69a052006-11-01 10:50:15 +080064static int __kprobes branch_taken(unsigned int instr, struct pt_regs *regs)
Paul Mackerras14cf11a2005-09-26 16:04:21 +100065{
66 unsigned int bo = (instr >> 21) & 0x1f;
67 unsigned int bi;
68
69 if ((bo & 4) == 0) {
70 /* decrement counter */
71 --regs->ctr;
72 if (((bo >> 1) & 1) ^ (regs->ctr == 0))
73 return 0;
74 }
75 if ((bo & 0x10) == 0) {
76 /* check bit from CR */
77 bi = (instr >> 16) & 0x1f;
78 if (((regs->ccr >> (31 - bi)) & 1) != ((bo >> 3) & 1))
79 return 0;
80 }
81 return 1;
82}
83
Paul Mackerras0016a4c2010-06-15 14:48:58 +100084
85static long __kprobes address_ok(struct pt_regs *regs, unsigned long ea, int nb)
86{
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 */
95static unsigned long __kprobes dform_ea(unsigned int instr, struct pt_regs *regs)
96{
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 */
112static unsigned long __kprobes dsform_ea(unsigned int instr, struct pt_regs *regs)
113{
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 */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000129static unsigned long __kprobes 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 */
148static inline unsigned long max_align(unsigned long x)
149{
150 x |= sizeof(unsigned long);
151 return x & -x; /* isolates rightmost bit */
152}
153
154
155static inline unsigned long byterev_2(unsigned long x)
156{
157 return ((x >> 8) & 0xff) | ((x & 0xff) << 8);
158}
159
160static inline unsigned long byterev_4(unsigned long x)
161{
162 return ((x >> 24) & 0xff) | ((x >> 8) & 0xff00) |
163 ((x & 0xff00) << 8) | ((x & 0xff) << 24);
164}
165
166#ifdef __powerpc64__
167static inline unsigned long byterev_8(unsigned long x)
168{
169 return (byterev_4(x) << 32) | byterev_4(x >> 32);
170}
171#endif
172
173static int __kprobes read_mem_aligned(unsigned long *dest, unsigned long ea,
174 int nb)
175{
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
200static int __kprobes read_mem_unaligned(unsigned long *dest, unsigned long ea,
201 int nb, struct pt_regs *regs)
202{
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 */
251static int __kprobes read_mem(unsigned long *dest, unsigned long ea, int nb,
252 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}
260
261static int __kprobes write_mem_aligned(unsigned long val, unsigned long ea,
262 int nb)
263{
264 int err = 0;
265
266 switch (nb) {
267 case 1:
268 err = __put_user(val, (unsigned char __user *) ea);
269 break;
270 case 2:
271 err = __put_user(val, (unsigned short __user *) ea);
272 break;
273 case 4:
274 err = __put_user(val, (unsigned int __user *) ea);
275 break;
276#ifdef __powerpc64__
277 case 8:
278 err = __put_user(val, (unsigned long __user *) ea);
279 break;
280#endif
281 }
282 return err;
283}
284
285static int __kprobes write_mem_unaligned(unsigned long val, unsigned long ea,
286 int nb, struct pt_regs *regs)
287{
288 int err;
289 unsigned long c;
290
Tom Musta6506b472013-10-18 14:42:08 -0500291#ifdef __LITTLE_ENDIAN__
292 switch (nb) {
293 case 2:
294 val = byterev_2(val);
295 break;
296 case 4:
297 val = byterev_4(val);
298 break;
299#ifdef __powerpc64__
300 case 8:
301 val = byterev_8(val);
302 break;
303#endif
304 }
305#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000306 /* unaligned or little-endian, do this in pieces */
307 for (; nb > 0; nb -= c) {
Tom Musta6506b472013-10-18 14:42:08 -0500308#ifdef __LITTLE_ENDIAN__
309 c = 1;
310#endif
311#ifdef __BIG_ENDIAN__
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000312 c = max_align(ea);
Tom Musta6506b472013-10-18 14:42:08 -0500313#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000314 if (c > nb)
315 c = max_align(nb);
316 err = write_mem_aligned(val >> (nb - c) * 8, ea, c);
317 if (err)
318 return err;
Tom Musta17e8de72013-08-22 09:25:28 -0500319 ea += c;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000320 }
321 return 0;
322}
323
324/*
325 * Write memory at address ea for nb bytes, return 0 for success
326 * or -EFAULT if an error occurred.
327 */
328static int __kprobes write_mem(unsigned long val, unsigned long ea, int nb,
329 struct pt_regs *regs)
330{
331 if (!address_ok(regs, ea, nb))
332 return -EFAULT;
333 if ((ea & (nb - 1)) == 0)
334 return write_mem_aligned(val, ea, nb);
335 return write_mem_unaligned(val, ea, nb, regs);
336}
337
Sean MacLennancd64d162010-09-01 07:21:21 +0000338#ifdef CONFIG_PPC_FPU
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000339/*
340 * Check the address and alignment, and call func to do the actual
341 * load or store.
342 */
343static int __kprobes do_fp_load(int rn, int (*func)(int, unsigned long),
344 unsigned long ea, int nb,
345 struct pt_regs *regs)
346{
347 int err;
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500348 union {
349 double dbl;
350 unsigned long ul[2];
351 struct {
352#ifdef __BIG_ENDIAN__
353 unsigned _pad_;
354 unsigned word;
355#endif
356#ifdef __LITTLE_ENDIAN__
357 unsigned word;
358 unsigned _pad_;
359#endif
360 } single;
361 } data;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000362 unsigned long ptr;
363
364 if (!address_ok(regs, ea, nb))
365 return -EFAULT;
366 if ((ea & 3) == 0)
367 return (*func)(rn, ea);
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500368 ptr = (unsigned long) &data.ul;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000369 if (sizeof(unsigned long) == 8 || nb == 4) {
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500370 err = read_mem_unaligned(&data.ul[0], ea, nb, regs);
371 if (nb == 4)
372 ptr = (unsigned long)&(data.single.word);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000373 } else {
374 /* reading a double on 32-bit */
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500375 err = read_mem_unaligned(&data.ul[0], ea, 4, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000376 if (!err)
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500377 err = read_mem_unaligned(&data.ul[1], ea + 4, 4, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000378 }
379 if (err)
380 return err;
381 return (*func)(rn, ptr);
382}
383
384static int __kprobes do_fp_store(int rn, int (*func)(int, unsigned long),
385 unsigned long ea, int nb,
386 struct pt_regs *regs)
387{
388 int err;
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500389 union {
390 double dbl;
391 unsigned long ul[2];
392 struct {
393#ifdef __BIG_ENDIAN__
394 unsigned _pad_;
395 unsigned word;
396#endif
397#ifdef __LITTLE_ENDIAN__
398 unsigned word;
399 unsigned _pad_;
400#endif
401 } single;
402 } data;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000403 unsigned long ptr;
404
405 if (!address_ok(regs, ea, nb))
406 return -EFAULT;
407 if ((ea & 3) == 0)
408 return (*func)(rn, ea);
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500409 ptr = (unsigned long) &data.ul[0];
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000410 if (sizeof(unsigned long) == 8 || nb == 4) {
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500411 if (nb == 4)
412 ptr = (unsigned long)&(data.single.word);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000413 err = (*func)(rn, ptr);
414 if (err)
415 return err;
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500416 err = write_mem_unaligned(data.ul[0], ea, nb, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000417 } else {
418 /* writing a double on 32-bit */
419 err = (*func)(rn, ptr);
420 if (err)
421 return err;
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500422 err = write_mem_unaligned(data.ul[0], ea, 4, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000423 if (!err)
Tom Mustadbc2fbd2013-10-18 14:44:17 -0500424 err = write_mem_unaligned(data.ul[1], ea + 4, 4, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000425 }
426 return err;
427}
Sean MacLennancd64d162010-09-01 07:21:21 +0000428#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000429
430#ifdef CONFIG_ALTIVEC
431/* For Altivec/VMX, no need to worry about alignment */
432static int __kprobes do_vec_load(int rn, int (*func)(int, unsigned long),
433 unsigned long ea, struct pt_regs *regs)
434{
435 if (!address_ok(regs, ea & ~0xfUL, 16))
436 return -EFAULT;
437 return (*func)(rn, ea);
438}
439
440static int __kprobes do_vec_store(int rn, int (*func)(int, unsigned long),
441 unsigned long ea, struct pt_regs *regs)
442{
443 if (!address_ok(regs, ea & ~0xfUL, 16))
444 return -EFAULT;
445 return (*func)(rn, ea);
446}
447#endif /* CONFIG_ALTIVEC */
448
449#ifdef CONFIG_VSX
450static int __kprobes do_vsx_load(int rn, int (*func)(int, unsigned long),
451 unsigned long ea, struct pt_regs *regs)
452{
453 int err;
454 unsigned long val[2];
455
456 if (!address_ok(regs, ea, 16))
457 return -EFAULT;
458 if ((ea & 3) == 0)
459 return (*func)(rn, ea);
460 err = read_mem_unaligned(&val[0], ea, 8, regs);
461 if (!err)
462 err = read_mem_unaligned(&val[1], ea + 8, 8, regs);
463 if (!err)
464 err = (*func)(rn, (unsigned long) &val[0]);
465 return err;
466}
467
468static int __kprobes do_vsx_store(int rn, int (*func)(int, unsigned long),
469 unsigned long ea, struct pt_regs *regs)
470{
471 int err;
472 unsigned long val[2];
473
474 if (!address_ok(regs, ea, 16))
475 return -EFAULT;
476 if ((ea & 3) == 0)
477 return (*func)(rn, ea);
478 err = (*func)(rn, (unsigned long) &val[0]);
479 if (err)
480 return err;
481 err = write_mem_unaligned(val[0], ea, 8, regs);
482 if (!err)
483 err = write_mem_unaligned(val[1], ea + 8, 8, regs);
484 return err;
485}
486#endif /* CONFIG_VSX */
487
488#define __put_user_asmx(x, addr, err, op, cr) \
489 __asm__ __volatile__( \
490 "1: " op " %2,0,%3\n" \
491 " mfcr %1\n" \
492 "2:\n" \
493 ".section .fixup,\"ax\"\n" \
494 "3: li %0,%4\n" \
495 " b 2b\n" \
496 ".previous\n" \
Nicholas Piggin24bfa6a2016-10-13 16:42:53 +1100497 EX_TABLE(1b, 3b) \
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000498 : "=r" (err), "=r" (cr) \
499 : "r" (x), "r" (addr), "i" (-EFAULT), "0" (err))
500
501#define __get_user_asmx(x, addr, err, op) \
502 __asm__ __volatile__( \
503 "1: "op" %1,0,%2\n" \
504 "2:\n" \
505 ".section .fixup,\"ax\"\n" \
506 "3: li %0,%3\n" \
507 " b 2b\n" \
508 ".previous\n" \
Nicholas Piggin24bfa6a2016-10-13 16:42:53 +1100509 EX_TABLE(1b, 3b) \
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000510 : "=r" (err), "=r" (x) \
511 : "r" (addr), "i" (-EFAULT), "0" (err))
512
513#define __cacheop_user_asmx(addr, err, op) \
514 __asm__ __volatile__( \
515 "1: "op" 0,%1\n" \
516 "2:\n" \
517 ".section .fixup,\"ax\"\n" \
518 "3: li %0,%3\n" \
519 " b 2b\n" \
520 ".previous\n" \
Nicholas Piggin24bfa6a2016-10-13 16:42:53 +1100521 EX_TABLE(1b, 3b) \
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000522 : "=r" (err) \
523 : "r" (addr), "i" (-EFAULT), "0" (err))
524
525static void __kprobes set_cr0(struct pt_regs *regs, int rd)
526{
527 long val = regs->gpr[rd];
528
529 regs->ccr = (regs->ccr & 0x0fffffff) | ((regs->xer >> 3) & 0x10000000);
530#ifdef __powerpc64__
Michael Ellermanb91e1362011-04-07 21:56:04 +0000531 if (!(regs->msr & MSR_64BIT))
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000532 val = (int) val;
533#endif
534 if (val < 0)
535 regs->ccr |= 0x80000000;
536 else if (val > 0)
537 regs->ccr |= 0x40000000;
538 else
539 regs->ccr |= 0x20000000;
540}
541
542static void __kprobes add_with_carry(struct pt_regs *regs, int rd,
543 unsigned long val1, unsigned long val2,
544 unsigned long carry_in)
545{
546 unsigned long val = val1 + val2;
547
548 if (carry_in)
549 ++val;
550 regs->gpr[rd] = val;
551#ifdef __powerpc64__
Michael Ellermanb91e1362011-04-07 21:56:04 +0000552 if (!(regs->msr & MSR_64BIT)) {
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000553 val = (unsigned int) val;
554 val1 = (unsigned int) val1;
555 }
556#endif
557 if (val < val1 || (carry_in && val == val1))
558 regs->xer |= XER_CA;
559 else
560 regs->xer &= ~XER_CA;
561}
562
563static void __kprobes do_cmp_signed(struct pt_regs *regs, long v1, long v2,
564 int crfld)
565{
566 unsigned int crval, shift;
567
568 crval = (regs->xer >> 31) & 1; /* get SO bit */
569 if (v1 < v2)
570 crval |= 8;
571 else if (v1 > v2)
572 crval |= 4;
573 else
574 crval |= 2;
575 shift = (7 - crfld) * 4;
576 regs->ccr = (regs->ccr & ~(0xf << shift)) | (crval << shift);
577}
578
579static void __kprobes do_cmp_unsigned(struct pt_regs *regs, unsigned long v1,
580 unsigned long v2, int crfld)
581{
582 unsigned int crval, shift;
583
584 crval = (regs->xer >> 31) & 1; /* get SO bit */
585 if (v1 < v2)
586 crval |= 8;
587 else if (v1 > v2)
588 crval |= 4;
589 else
590 crval |= 2;
591 shift = (7 - crfld) * 4;
592 regs->ccr = (regs->ccr & ~(0xf << shift)) | (crval << shift);
593}
594
Paul Mackerrascf87c3f2014-09-02 14:35:08 +1000595static int __kprobes trap_compare(long v1, long v2)
596{
597 int ret = 0;
598
599 if (v1 < v2)
600 ret |= 0x10;
601 else if (v1 > v2)
602 ret |= 0x08;
603 else
604 ret |= 0x04;
605 if ((unsigned long)v1 < (unsigned long)v2)
606 ret |= 0x02;
607 else if ((unsigned long)v1 > (unsigned long)v2)
608 ret |= 0x01;
609 return ret;
610}
611
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000612/*
613 * Elements of 32-bit rotate and mask instructions.
614 */
615#define MASK32(mb, me) ((0xffffffffUL >> (mb)) + \
616 ((signed long)-0x80000000L >> (me)) + ((me) >= (mb)))
617#ifdef __powerpc64__
618#define MASK64_L(mb) (~0UL >> (mb))
619#define MASK64_R(me) ((signed long)-0x8000000000000000L >> (me))
620#define MASK64(mb, me) (MASK64_L(mb) + MASK64_R(me) + ((me) >= (mb)))
621#define DATA32(x) (((x) & 0xffffffffUL) | (((x) & 0xffffffffUL) << 32))
622#else
623#define DATA32(x) (x)
624#endif
625#define ROTATE(x, n) ((n) ? (((x) << (n)) | ((x) >> (8 * sizeof(long) - (n)))) : (x))
626
627/*
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000628 * Decode an instruction, and execute it if that can be done just by
629 * modifying *regs (i.e. integer arithmetic and logical instructions,
630 * branches, and barrier instructions).
631 * Returns 1 if the instruction has been executed, or 0 if not.
632 * Sets *op to indicate what the instruction does.
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000633 */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000634int __kprobes analyse_instr(struct instruction_op *op, struct pt_regs *regs,
635 unsigned int instr)
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000636{
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000637 unsigned int opcode, ra, rb, rd, spr, u;
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000638 unsigned long int imm;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000639 unsigned long int val, val2;
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000640 unsigned int mb, me, sh;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000641 long ival;
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000642
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000643 op->type = COMPUTE;
644
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000645 opcode = instr >> 26;
646 switch (opcode) {
647 case 16: /* bc */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000648 op->type = BRANCH;
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000649 imm = (signed short)(instr & 0xfffc);
650 if ((instr & 2) == 0)
651 imm += regs->nip;
652 regs->nip += 4;
Michael Ellermanb91e1362011-04-07 21:56:04 +0000653 regs->nip = truncate_if_32bit(regs->msr, regs->nip);
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000654 if (instr & 1)
655 regs->link = regs->nip;
656 if (branch_taken(instr, regs))
Michael Neuling70a54a42013-05-06 21:32:40 +1000657 regs->nip = truncate_if_32bit(regs->msr, imm);
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000658 return 1;
Paul Mackerrasc0325242005-10-28 22:48:08 +1000659#ifdef CONFIG_PPC64
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000660 case 17: /* sc */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000661 if ((instr & 0xfe2) == 2)
662 op->type = SYSCALL;
663 else
664 op->type = UNKNOWN;
665 return 0;
Paul Mackerrasc0325242005-10-28 22:48:08 +1000666#endif
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000667 case 18: /* b */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000668 op->type = BRANCH;
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000669 imm = instr & 0x03fffffc;
670 if (imm & 0x02000000)
671 imm -= 0x04000000;
672 if ((instr & 2) == 0)
673 imm += regs->nip;
Michael Ellermanb91e1362011-04-07 21:56:04 +0000674 if (instr & 1)
675 regs->link = truncate_if_32bit(regs->msr, regs->nip + 4);
676 imm = truncate_if_32bit(regs->msr, imm);
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000677 regs->nip = imm;
678 return 1;
679 case 19:
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000680 switch ((instr >> 1) & 0x3ff) {
Paul Mackerrascf87c3f2014-09-02 14:35:08 +1000681 case 0: /* mcrf */
682 rd = (instr >> 21) & 0x1c;
683 ra = (instr >> 16) & 0x1c;
684 val = (regs->ccr >> ra) & 0xf;
685 regs->ccr = (regs->ccr & ~(0xfUL << rd)) | (val << rd);
686 goto instr_done;
687
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000688 case 16: /* bclr */
689 case 528: /* bcctr */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000690 op->type = BRANCH;
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000691 imm = (instr & 0x400)? regs->ctr: regs->link;
Michael Ellermanb91e1362011-04-07 21:56:04 +0000692 regs->nip = truncate_if_32bit(regs->msr, regs->nip + 4);
693 imm = truncate_if_32bit(regs->msr, imm);
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000694 if (instr & 1)
695 regs->link = regs->nip;
696 if (branch_taken(instr, regs))
697 regs->nip = imm;
698 return 1;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000699
700 case 18: /* rfid, scary */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000701 if (regs->msr & MSR_PR)
702 goto priv;
703 op->type = RFI;
704 return 0;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000705
706 case 150: /* isync */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000707 op->type = BARRIER;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000708 isync();
709 goto instr_done;
710
711 case 33: /* crnor */
712 case 129: /* crandc */
713 case 193: /* crxor */
714 case 225: /* crnand */
715 case 257: /* crand */
716 case 289: /* creqv */
717 case 417: /* crorc */
718 case 449: /* cror */
719 ra = (instr >> 16) & 0x1f;
720 rb = (instr >> 11) & 0x1f;
721 rd = (instr >> 21) & 0x1f;
722 ra = (regs->ccr >> (31 - ra)) & 1;
723 rb = (regs->ccr >> (31 - rb)) & 1;
724 val = (instr >> (6 + ra * 2 + rb)) & 1;
725 regs->ccr = (regs->ccr & ~(1UL << (31 - rd))) |
726 (val << (31 - rd));
727 goto instr_done;
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000728 }
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000729 break;
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000730 case 31:
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000731 switch ((instr >> 1) & 0x3ff) {
732 case 598: /* sync */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000733 op->type = BARRIER;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000734#ifdef __powerpc64__
735 switch ((instr >> 21) & 3) {
736 case 1: /* lwsync */
737 asm volatile("lwsync" : : : "memory");
738 goto instr_done;
739 case 2: /* ptesync */
740 asm volatile("ptesync" : : : "memory");
741 goto instr_done;
742 }
743#endif
744 mb();
745 goto instr_done;
746
747 case 854: /* eieio */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000748 op->type = BARRIER;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000749 eieio();
750 goto instr_done;
751 }
752 break;
753 }
754
755 /* Following cases refer to regs->gpr[], so we need all regs */
756 if (!FULL_REGS(regs))
757 return 0;
758
759 rd = (instr >> 21) & 0x1f;
760 ra = (instr >> 16) & 0x1f;
761 rb = (instr >> 11) & 0x1f;
762
763 switch (opcode) {
Paul Mackerrascf87c3f2014-09-02 14:35:08 +1000764#ifdef __powerpc64__
765 case 2: /* tdi */
766 if (rd & trap_compare(regs->gpr[ra], (short) instr))
767 goto trap;
768 goto instr_done;
769#endif
770 case 3: /* twi */
771 if (rd & trap_compare((int)regs->gpr[ra], (short) instr))
772 goto trap;
773 goto instr_done;
774
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000775 case 7: /* mulli */
776 regs->gpr[rd] = regs->gpr[ra] * (short) instr;
777 goto instr_done;
778
779 case 8: /* subfic */
780 imm = (short) instr;
781 add_with_carry(regs, rd, ~regs->gpr[ra], imm, 1);
782 goto instr_done;
783
784 case 10: /* cmpli */
785 imm = (unsigned short) instr;
786 val = regs->gpr[ra];
787#ifdef __powerpc64__
788 if ((rd & 1) == 0)
789 val = (unsigned int) val;
790#endif
791 do_cmp_unsigned(regs, val, imm, rd >> 2);
792 goto instr_done;
793
794 case 11: /* cmpi */
795 imm = (short) instr;
796 val = regs->gpr[ra];
797#ifdef __powerpc64__
798 if ((rd & 1) == 0)
799 val = (int) val;
800#endif
801 do_cmp_signed(regs, val, imm, rd >> 2);
802 goto instr_done;
803
804 case 12: /* addic */
805 imm = (short) instr;
806 add_with_carry(regs, rd, regs->gpr[ra], imm, 0);
807 goto instr_done;
808
809 case 13: /* addic. */
810 imm = (short) instr;
811 add_with_carry(regs, rd, regs->gpr[ra], imm, 0);
812 set_cr0(regs, rd);
813 goto instr_done;
814
815 case 14: /* addi */
816 imm = (short) instr;
817 if (ra)
818 imm += regs->gpr[ra];
819 regs->gpr[rd] = imm;
820 goto instr_done;
821
822 case 15: /* addis */
823 imm = ((short) instr) << 16;
824 if (ra)
825 imm += regs->gpr[ra];
826 regs->gpr[rd] = imm;
827 goto instr_done;
828
829 case 20: /* rlwimi */
830 mb = (instr >> 6) & 0x1f;
831 me = (instr >> 1) & 0x1f;
832 val = DATA32(regs->gpr[rd]);
833 imm = MASK32(mb, me);
834 regs->gpr[ra] = (regs->gpr[ra] & ~imm) | (ROTATE(val, rb) & imm);
835 goto logical_done;
836
837 case 21: /* rlwinm */
838 mb = (instr >> 6) & 0x1f;
839 me = (instr >> 1) & 0x1f;
840 val = DATA32(regs->gpr[rd]);
841 regs->gpr[ra] = ROTATE(val, rb) & MASK32(mb, me);
842 goto logical_done;
843
844 case 23: /* rlwnm */
845 mb = (instr >> 6) & 0x1f;
846 me = (instr >> 1) & 0x1f;
847 rb = regs->gpr[rb] & 0x1f;
848 val = DATA32(regs->gpr[rd]);
849 regs->gpr[ra] = ROTATE(val, rb) & MASK32(mb, me);
850 goto logical_done;
851
852 case 24: /* ori */
853 imm = (unsigned short) instr;
854 regs->gpr[ra] = regs->gpr[rd] | imm;
855 goto instr_done;
856
857 case 25: /* oris */
858 imm = (unsigned short) instr;
859 regs->gpr[ra] = regs->gpr[rd] | (imm << 16);
860 goto instr_done;
861
862 case 26: /* xori */
863 imm = (unsigned short) instr;
864 regs->gpr[ra] = regs->gpr[rd] ^ imm;
865 goto instr_done;
866
867 case 27: /* xoris */
868 imm = (unsigned short) instr;
869 regs->gpr[ra] = regs->gpr[rd] ^ (imm << 16);
870 goto instr_done;
871
872 case 28: /* andi. */
873 imm = (unsigned short) instr;
874 regs->gpr[ra] = regs->gpr[rd] & imm;
875 set_cr0(regs, ra);
876 goto instr_done;
877
878 case 29: /* andis. */
879 imm = (unsigned short) instr;
880 regs->gpr[ra] = regs->gpr[rd] & (imm << 16);
881 set_cr0(regs, ra);
882 goto instr_done;
883
884#ifdef __powerpc64__
885 case 30: /* rld* */
886 mb = ((instr >> 6) & 0x1f) | (instr & 0x20);
887 val = regs->gpr[rd];
888 if ((instr & 0x10) == 0) {
889 sh = rb | ((instr & 2) << 4);
890 val = ROTATE(val, sh);
891 switch ((instr >> 2) & 3) {
892 case 0: /* rldicl */
893 regs->gpr[ra] = val & MASK64_L(mb);
894 goto logical_done;
895 case 1: /* rldicr */
896 regs->gpr[ra] = val & MASK64_R(mb);
897 goto logical_done;
898 case 2: /* rldic */
899 regs->gpr[ra] = val & MASK64(mb, 63 - sh);
900 goto logical_done;
901 case 3: /* rldimi */
902 imm = MASK64(mb, 63 - sh);
903 regs->gpr[ra] = (regs->gpr[ra] & ~imm) |
904 (val & imm);
905 goto logical_done;
906 }
907 } else {
908 sh = regs->gpr[rb] & 0x3f;
909 val = ROTATE(val, sh);
910 switch ((instr >> 1) & 7) {
911 case 0: /* rldcl */
912 regs->gpr[ra] = val & MASK64_L(mb);
913 goto logical_done;
914 case 1: /* rldcr */
915 regs->gpr[ra] = val & MASK64_R(mb);
916 goto logical_done;
917 }
918 }
919#endif
Oliver O'Halloran66707832016-02-16 17:31:53 +1100920 break; /* illegal instruction */
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000921
922 case 31:
923 switch ((instr >> 1) & 0x3ff) {
Paul Mackerrascf87c3f2014-09-02 14:35:08 +1000924 case 4: /* tw */
925 if (rd == 0x1f ||
926 (rd & trap_compare((int)regs->gpr[ra],
927 (int)regs->gpr[rb])))
928 goto trap;
929 goto instr_done;
930#ifdef __powerpc64__
931 case 68: /* td */
932 if (rd & trap_compare(regs->gpr[ra], regs->gpr[rb]))
933 goto trap;
934 goto instr_done;
935#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000936 case 83: /* mfmsr */
937 if (regs->msr & MSR_PR)
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000938 goto priv;
939 op->type = MFMSR;
940 op->reg = rd;
941 return 0;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000942 case 146: /* mtmsr */
943 if (regs->msr & MSR_PR)
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000944 goto priv;
945 op->type = MTMSR;
946 op->reg = rd;
947 op->val = 0xffffffff & ~(MSR_ME | MSR_LE);
948 return 0;
Paul Mackerrasc0325242005-10-28 22:48:08 +1000949#ifdef CONFIG_PPC64
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000950 case 178: /* mtmsrd */
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000951 if (regs->msr & MSR_PR)
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000952 goto priv;
953 op->type = MTMSR;
954 op->reg = rd;
955 /* only MSR_EE and MSR_RI get changed if bit 15 set */
956 /* mtmsrd doesn't change MSR_HV, MSR_ME or MSR_LE */
957 imm = (instr & 0x10000)? 0x8002: 0xefffffffffffeffeUL;
958 op->val = imm;
959 return 0;
Paul Mackerrasc0325242005-10-28 22:48:08 +1000960#endif
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000961
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000962 case 19: /* mfcr */
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +1000963 regs->gpr[rd] = regs->ccr;
964 regs->gpr[rd] &= 0xffffffffUL;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000965 goto instr_done;
966
967 case 144: /* mtcrf */
968 imm = 0xf0000000UL;
969 val = regs->gpr[rd];
970 for (sh = 0; sh < 8; ++sh) {
971 if (instr & (0x80000 >> sh))
972 regs->ccr = (regs->ccr & ~imm) |
973 (val & imm);
974 imm >>= 4;
975 }
976 goto instr_done;
977
978 case 339: /* mfspr */
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000979 spr = ((instr >> 16) & 0x1f) | ((instr >> 6) & 0x3e0);
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +1000980 switch (spr) {
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000981 case SPRN_XER: /* mfxer */
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +1000982 regs->gpr[rd] = regs->xer;
983 regs->gpr[rd] &= 0xffffffffUL;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000984 goto instr_done;
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000985 case SPRN_LR: /* mflr */
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +1000986 regs->gpr[rd] = regs->link;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000987 goto instr_done;
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000988 case SPRN_CTR: /* mfctr */
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +1000989 regs->gpr[rd] = regs->ctr;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000990 goto instr_done;
Paul Mackerrasbe96f632014-09-02 14:35:07 +1000991 default:
992 op->type = MFSPR;
993 op->reg = rd;
994 op->spr = spr;
995 return 0;
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +1000996 }
997 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +1000998
999 case 467: /* mtspr */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001000 spr = ((instr >> 16) & 0x1f) | ((instr >> 6) & 0x3e0);
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001001 switch (spr) {
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001002 case SPRN_XER: /* mtxer */
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001003 regs->xer = (regs->gpr[rd] & 0xffffffffUL);
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001004 goto instr_done;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001005 case SPRN_LR: /* mtlr */
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001006 regs->link = regs->gpr[rd];
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001007 goto instr_done;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001008 case SPRN_CTR: /* mtctr */
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001009 regs->ctr = regs->gpr[rd];
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001010 goto instr_done;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001011 default:
1012 op->type = MTSPR;
1013 op->val = regs->gpr[rd];
1014 op->spr = spr;
1015 return 0;
Ananth N Mavinakayanahalli68881992007-04-18 15:56:38 +10001016 }
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001017 break;
1018
1019/*
1020 * Compare instructions
1021 */
1022 case 0: /* cmp */
1023 val = regs->gpr[ra];
1024 val2 = regs->gpr[rb];
1025#ifdef __powerpc64__
1026 if ((rd & 1) == 0) {
1027 /* word (32-bit) compare */
1028 val = (int) val;
1029 val2 = (int) val2;
1030 }
1031#endif
1032 do_cmp_signed(regs, val, val2, rd >> 2);
1033 goto instr_done;
1034
1035 case 32: /* cmpl */
1036 val = regs->gpr[ra];
1037 val2 = regs->gpr[rb];
1038#ifdef __powerpc64__
1039 if ((rd & 1) == 0) {
1040 /* word (32-bit) compare */
1041 val = (unsigned int) val;
1042 val2 = (unsigned int) val2;
1043 }
1044#endif
1045 do_cmp_unsigned(regs, val, val2, rd >> 2);
1046 goto instr_done;
1047
1048/*
1049 * Arithmetic instructions
1050 */
1051 case 8: /* subfc */
1052 add_with_carry(regs, rd, ~regs->gpr[ra],
1053 regs->gpr[rb], 1);
1054 goto arith_done;
1055#ifdef __powerpc64__
1056 case 9: /* mulhdu */
1057 asm("mulhdu %0,%1,%2" : "=r" (regs->gpr[rd]) :
1058 "r" (regs->gpr[ra]), "r" (regs->gpr[rb]));
1059 goto arith_done;
1060#endif
1061 case 10: /* addc */
1062 add_with_carry(regs, rd, regs->gpr[ra],
1063 regs->gpr[rb], 0);
1064 goto arith_done;
1065
1066 case 11: /* mulhwu */
1067 asm("mulhwu %0,%1,%2" : "=r" (regs->gpr[rd]) :
1068 "r" (regs->gpr[ra]), "r" (regs->gpr[rb]));
1069 goto arith_done;
1070
1071 case 40: /* subf */
1072 regs->gpr[rd] = regs->gpr[rb] - regs->gpr[ra];
1073 goto arith_done;
1074#ifdef __powerpc64__
1075 case 73: /* mulhd */
1076 asm("mulhd %0,%1,%2" : "=r" (regs->gpr[rd]) :
1077 "r" (regs->gpr[ra]), "r" (regs->gpr[rb]));
1078 goto arith_done;
1079#endif
1080 case 75: /* mulhw */
1081 asm("mulhw %0,%1,%2" : "=r" (regs->gpr[rd]) :
1082 "r" (regs->gpr[ra]), "r" (regs->gpr[rb]));
1083 goto arith_done;
1084
1085 case 104: /* neg */
1086 regs->gpr[rd] = -regs->gpr[ra];
1087 goto arith_done;
1088
1089 case 136: /* subfe */
1090 add_with_carry(regs, rd, ~regs->gpr[ra], regs->gpr[rb],
1091 regs->xer & XER_CA);
1092 goto arith_done;
1093
1094 case 138: /* adde */
1095 add_with_carry(regs, rd, regs->gpr[ra], regs->gpr[rb],
1096 regs->xer & XER_CA);
1097 goto arith_done;
1098
1099 case 200: /* subfze */
1100 add_with_carry(regs, rd, ~regs->gpr[ra], 0L,
1101 regs->xer & XER_CA);
1102 goto arith_done;
1103
1104 case 202: /* addze */
1105 add_with_carry(regs, rd, regs->gpr[ra], 0L,
1106 regs->xer & XER_CA);
1107 goto arith_done;
1108
1109 case 232: /* subfme */
1110 add_with_carry(regs, rd, ~regs->gpr[ra], -1L,
1111 regs->xer & XER_CA);
1112 goto arith_done;
1113#ifdef __powerpc64__
1114 case 233: /* mulld */
1115 regs->gpr[rd] = regs->gpr[ra] * regs->gpr[rb];
1116 goto arith_done;
1117#endif
1118 case 234: /* addme */
1119 add_with_carry(regs, rd, regs->gpr[ra], -1L,
1120 regs->xer & XER_CA);
1121 goto arith_done;
1122
1123 case 235: /* mullw */
1124 regs->gpr[rd] = (unsigned int) regs->gpr[ra] *
1125 (unsigned int) regs->gpr[rb];
1126 goto arith_done;
1127
1128 case 266: /* add */
1129 regs->gpr[rd] = regs->gpr[ra] + regs->gpr[rb];
1130 goto arith_done;
1131#ifdef __powerpc64__
1132 case 457: /* divdu */
1133 regs->gpr[rd] = regs->gpr[ra] / regs->gpr[rb];
1134 goto arith_done;
1135#endif
1136 case 459: /* divwu */
1137 regs->gpr[rd] = (unsigned int) regs->gpr[ra] /
1138 (unsigned int) regs->gpr[rb];
1139 goto arith_done;
1140#ifdef __powerpc64__
1141 case 489: /* divd */
1142 regs->gpr[rd] = (long int) regs->gpr[ra] /
1143 (long int) regs->gpr[rb];
1144 goto arith_done;
1145#endif
1146 case 491: /* divw */
1147 regs->gpr[rd] = (int) regs->gpr[ra] /
1148 (int) regs->gpr[rb];
1149 goto arith_done;
1150
1151
1152/*
1153 * Logical instructions
1154 */
1155 case 26: /* cntlzw */
1156 asm("cntlzw %0,%1" : "=r" (regs->gpr[ra]) :
1157 "r" (regs->gpr[rd]));
1158 goto logical_done;
1159#ifdef __powerpc64__
1160 case 58: /* cntlzd */
1161 asm("cntlzd %0,%1" : "=r" (regs->gpr[ra]) :
1162 "r" (regs->gpr[rd]));
1163 goto logical_done;
1164#endif
1165 case 28: /* and */
1166 regs->gpr[ra] = regs->gpr[rd] & regs->gpr[rb];
1167 goto logical_done;
1168
1169 case 60: /* andc */
1170 regs->gpr[ra] = regs->gpr[rd] & ~regs->gpr[rb];
1171 goto logical_done;
1172
1173 case 124: /* nor */
1174 regs->gpr[ra] = ~(regs->gpr[rd] | regs->gpr[rb]);
1175 goto logical_done;
1176
1177 case 284: /* xor */
1178 regs->gpr[ra] = ~(regs->gpr[rd] ^ regs->gpr[rb]);
1179 goto logical_done;
1180
1181 case 316: /* xor */
1182 regs->gpr[ra] = regs->gpr[rd] ^ regs->gpr[rb];
1183 goto logical_done;
1184
1185 case 412: /* orc */
1186 regs->gpr[ra] = regs->gpr[rd] | ~regs->gpr[rb];
1187 goto logical_done;
1188
1189 case 444: /* or */
1190 regs->gpr[ra] = regs->gpr[rd] | regs->gpr[rb];
1191 goto logical_done;
1192
1193 case 476: /* nand */
1194 regs->gpr[ra] = ~(regs->gpr[rd] & regs->gpr[rb]);
1195 goto logical_done;
1196
1197 case 922: /* extsh */
1198 regs->gpr[ra] = (signed short) regs->gpr[rd];
1199 goto logical_done;
1200
1201 case 954: /* extsb */
1202 regs->gpr[ra] = (signed char) regs->gpr[rd];
1203 goto logical_done;
1204#ifdef __powerpc64__
1205 case 986: /* extsw */
1206 regs->gpr[ra] = (signed int) regs->gpr[rd];
1207 goto logical_done;
1208#endif
1209
1210/*
1211 * Shift instructions
1212 */
1213 case 24: /* slw */
1214 sh = regs->gpr[rb] & 0x3f;
1215 if (sh < 32)
1216 regs->gpr[ra] = (regs->gpr[rd] << sh) & 0xffffffffUL;
1217 else
1218 regs->gpr[ra] = 0;
1219 goto logical_done;
1220
1221 case 536: /* srw */
1222 sh = regs->gpr[rb] & 0x3f;
1223 if (sh < 32)
1224 regs->gpr[ra] = (regs->gpr[rd] & 0xffffffffUL) >> sh;
1225 else
1226 regs->gpr[ra] = 0;
1227 goto logical_done;
1228
1229 case 792: /* sraw */
1230 sh = regs->gpr[rb] & 0x3f;
1231 ival = (signed int) regs->gpr[rd];
1232 regs->gpr[ra] = ival >> (sh < 32 ? sh : 31);
Paul Mackerrase698b962014-07-19 17:47:57 +10001233 if (ival < 0 && (sh >= 32 || (ival & ((1ul << sh) - 1)) != 0))
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001234 regs->xer |= XER_CA;
1235 else
1236 regs->xer &= ~XER_CA;
1237 goto logical_done;
1238
1239 case 824: /* srawi */
1240 sh = rb;
1241 ival = (signed int) regs->gpr[rd];
1242 regs->gpr[ra] = ival >> sh;
Paul Mackerrase698b962014-07-19 17:47:57 +10001243 if (ival < 0 && (ival & ((1ul << sh) - 1)) != 0)
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001244 regs->xer |= XER_CA;
1245 else
1246 regs->xer &= ~XER_CA;
1247 goto logical_done;
1248
1249#ifdef __powerpc64__
1250 case 27: /* sld */
Paul Mackerrase698b962014-07-19 17:47:57 +10001251 sh = regs->gpr[rb] & 0x7f;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001252 if (sh < 64)
1253 regs->gpr[ra] = regs->gpr[rd] << sh;
1254 else
1255 regs->gpr[ra] = 0;
1256 goto logical_done;
1257
1258 case 539: /* srd */
1259 sh = regs->gpr[rb] & 0x7f;
1260 if (sh < 64)
1261 regs->gpr[ra] = regs->gpr[rd] >> sh;
1262 else
1263 regs->gpr[ra] = 0;
1264 goto logical_done;
1265
1266 case 794: /* srad */
1267 sh = regs->gpr[rb] & 0x7f;
1268 ival = (signed long int) regs->gpr[rd];
1269 regs->gpr[ra] = ival >> (sh < 64 ? sh : 63);
Paul Mackerrase698b962014-07-19 17:47:57 +10001270 if (ival < 0 && (sh >= 64 || (ival & ((1ul << sh) - 1)) != 0))
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001271 regs->xer |= XER_CA;
1272 else
1273 regs->xer &= ~XER_CA;
1274 goto logical_done;
1275
1276 case 826: /* sradi with sh_5 = 0 */
1277 case 827: /* sradi with sh_5 = 1 */
1278 sh = rb | ((instr & 2) << 4);
1279 ival = (signed long int) regs->gpr[rd];
1280 regs->gpr[ra] = ival >> sh;
Paul Mackerrase698b962014-07-19 17:47:57 +10001281 if (ival < 0 && (ival & ((1ul << sh) - 1)) != 0)
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001282 regs->xer |= XER_CA;
1283 else
1284 regs->xer &= ~XER_CA;
1285 goto logical_done;
1286#endif /* __powerpc64__ */
1287
1288/*
1289 * Cache instructions
1290 */
1291 case 54: /* dcbst */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001292 op->type = MKOP(CACHEOP, DCBST, 0);
1293 op->ea = xform_ea(instr, regs);
1294 return 0;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001295
1296 case 86: /* dcbf */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001297 op->type = MKOP(CACHEOP, DCBF, 0);
1298 op->ea = xform_ea(instr, regs);
1299 return 0;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001300
1301 case 246: /* dcbtst */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001302 op->type = MKOP(CACHEOP, DCBTST, 0);
1303 op->ea = xform_ea(instr, regs);
1304 op->reg = rd;
1305 return 0;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001306
1307 case 278: /* dcbt */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001308 op->type = MKOP(CACHEOP, DCBTST, 0);
1309 op->ea = xform_ea(instr, regs);
1310 op->reg = rd;
1311 return 0;
Paul Mackerrascf87c3f2014-09-02 14:35:08 +10001312
1313 case 982: /* icbi */
1314 op->type = MKOP(CACHEOP, ICBI, 0);
1315 op->ea = xform_ea(instr, regs);
1316 return 0;
Paul Mackerras14cf11a2005-09-26 16:04:21 +10001317 }
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001318 break;
Paul Mackerras14cf11a2005-09-26 16:04:21 +10001319 }
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001320
1321 /*
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001322 * Loads and stores.
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001323 */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001324 op->type = UNKNOWN;
1325 op->update_reg = ra;
1326 op->reg = rd;
1327 op->val = regs->gpr[rd];
1328 u = (instr >> 20) & UPDATE;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001329
1330 switch (opcode) {
1331 case 31:
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001332 u = instr & UPDATE;
1333 op->ea = xform_ea(instr, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001334 switch ((instr >> 1) & 0x3ff) {
1335 case 20: /* lwarx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001336 op->type = MKOP(LARX, 0, 4);
1337 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001338
1339 case 150: /* stwcx. */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001340 op->type = MKOP(STCX, 0, 4);
1341 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001342
1343#ifdef __powerpc64__
1344 case 84: /* ldarx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001345 op->type = MKOP(LARX, 0, 8);
1346 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001347
1348 case 214: /* stdcx. */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001349 op->type = MKOP(STCX, 0, 8);
1350 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001351
1352 case 21: /* ldx */
1353 case 53: /* ldux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001354 op->type = MKOP(LOAD, u, 8);
1355 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001356#endif
1357
1358 case 23: /* lwzx */
1359 case 55: /* lwzux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001360 op->type = MKOP(LOAD, u, 4);
1361 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001362
1363 case 87: /* lbzx */
1364 case 119: /* lbzux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001365 op->type = MKOP(LOAD, u, 1);
1366 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001367
1368#ifdef CONFIG_ALTIVEC
1369 case 103: /* lvx */
1370 case 359: /* lvxl */
1371 if (!(regs->msr & MSR_VEC))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001372 goto vecunavail;
1373 op->type = MKOP(LOAD_VMX, 0, 16);
1374 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001375
1376 case 231: /* stvx */
1377 case 487: /* stvxl */
1378 if (!(regs->msr & MSR_VEC))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001379 goto vecunavail;
1380 op->type = MKOP(STORE_VMX, 0, 16);
1381 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001382#endif /* CONFIG_ALTIVEC */
1383
1384#ifdef __powerpc64__
1385 case 149: /* stdx */
1386 case 181: /* stdux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001387 op->type = MKOP(STORE, u, 8);
1388 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001389#endif
1390
1391 case 151: /* stwx */
1392 case 183: /* stwux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001393 op->type = MKOP(STORE, u, 4);
1394 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001395
1396 case 215: /* stbx */
1397 case 247: /* stbux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001398 op->type = MKOP(STORE, u, 1);
1399 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001400
1401 case 279: /* lhzx */
1402 case 311: /* lhzux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001403 op->type = MKOP(LOAD, u, 2);
1404 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001405
1406#ifdef __powerpc64__
1407 case 341: /* lwax */
1408 case 373: /* lwaux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001409 op->type = MKOP(LOAD, SIGNEXT | u, 4);
1410 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001411#endif
1412
1413 case 343: /* lhax */
1414 case 375: /* lhaux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001415 op->type = MKOP(LOAD, SIGNEXT | u, 2);
1416 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001417
1418 case 407: /* sthx */
1419 case 439: /* sthux */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001420 op->type = MKOP(STORE, u, 2);
1421 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001422
1423#ifdef __powerpc64__
1424 case 532: /* ldbrx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001425 op->type = MKOP(LOAD, BYTEREV, 8);
1426 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001427
1428#endif
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001429 case 533: /* lswx */
1430 op->type = MKOP(LOAD_MULTI, 0, regs->xer & 0x7f);
1431 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001432
1433 case 534: /* lwbrx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001434 op->type = MKOP(LOAD, BYTEREV, 4);
1435 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001436
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001437 case 597: /* lswi */
1438 if (rb == 0)
1439 rb = 32; /* # bytes to load */
1440 op->type = MKOP(LOAD_MULTI, 0, rb);
1441 op->ea = 0;
1442 if (ra)
1443 op->ea = truncate_if_32bit(regs->msr,
1444 regs->gpr[ra]);
1445 break;
1446
Paul Bolleb69a1da2014-05-20 21:59:42 +02001447#ifdef CONFIG_PPC_FPU
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001448 case 535: /* lfsx */
1449 case 567: /* lfsux */
1450 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001451 goto fpunavail;
1452 op->type = MKOP(LOAD_FP, u, 4);
1453 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001454
1455 case 599: /* lfdx */
1456 case 631: /* lfdux */
1457 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001458 goto fpunavail;
1459 op->type = MKOP(LOAD_FP, u, 8);
1460 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001461
1462 case 663: /* stfsx */
1463 case 695: /* stfsux */
1464 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001465 goto fpunavail;
1466 op->type = MKOP(STORE_FP, u, 4);
1467 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001468
1469 case 727: /* stfdx */
1470 case 759: /* stfdux */
1471 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001472 goto fpunavail;
1473 op->type = MKOP(STORE_FP, u, 8);
1474 break;
Sean MacLennancd64d162010-09-01 07:21:21 +00001475#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001476
1477#ifdef __powerpc64__
1478 case 660: /* stdbrx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001479 op->type = MKOP(STORE, BYTEREV, 8);
1480 op->val = byterev_8(regs->gpr[rd]);
1481 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001482
1483#endif
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001484 case 661: /* stswx */
1485 op->type = MKOP(STORE_MULTI, 0, regs->xer & 0x7f);
1486 break;
1487
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001488 case 662: /* stwbrx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001489 op->type = MKOP(STORE, BYTEREV, 4);
1490 op->val = byterev_4(regs->gpr[rd]);
1491 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001492
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001493 case 725:
1494 if (rb == 0)
1495 rb = 32; /* # bytes to store */
1496 op->type = MKOP(STORE_MULTI, 0, rb);
1497 op->ea = 0;
1498 if (ra)
1499 op->ea = truncate_if_32bit(regs->msr,
1500 regs->gpr[ra]);
1501 break;
1502
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001503 case 790: /* lhbrx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001504 op->type = MKOP(LOAD, BYTEREV, 2);
1505 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001506
1507 case 918: /* sthbrx */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001508 op->type = MKOP(STORE, BYTEREV, 2);
1509 op->val = byterev_2(regs->gpr[rd]);
1510 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001511
1512#ifdef CONFIG_VSX
1513 case 844: /* lxvd2x */
1514 case 876: /* lxvd2ux */
1515 if (!(regs->msr & MSR_VSX))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001516 goto vsxunavail;
1517 op->reg = rd | ((instr & 1) << 5);
1518 op->type = MKOP(LOAD_VSX, u, 16);
1519 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001520
1521 case 972: /* stxvd2x */
1522 case 1004: /* stxvd2ux */
1523 if (!(regs->msr & MSR_VSX))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001524 goto vsxunavail;
1525 op->reg = rd | ((instr & 1) << 5);
1526 op->type = MKOP(STORE_VSX, u, 16);
1527 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001528
1529#endif /* CONFIG_VSX */
1530 }
1531 break;
1532
1533 case 32: /* lwz */
1534 case 33: /* lwzu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001535 op->type = MKOP(LOAD, u, 4);
1536 op->ea = dform_ea(instr, regs);
1537 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001538
1539 case 34: /* lbz */
1540 case 35: /* lbzu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001541 op->type = MKOP(LOAD, u, 1);
1542 op->ea = dform_ea(instr, regs);
1543 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001544
1545 case 36: /* stw */
Tiejun Chen8e9f6932012-09-16 23:54:31 +00001546 case 37: /* stwu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001547 op->type = MKOP(STORE, u, 4);
1548 op->ea = dform_ea(instr, regs);
1549 break;
Tiejun Chen8e9f6932012-09-16 23:54:31 +00001550
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001551 case 38: /* stb */
1552 case 39: /* stbu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001553 op->type = MKOP(STORE, u, 1);
1554 op->ea = dform_ea(instr, regs);
1555 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001556
1557 case 40: /* lhz */
1558 case 41: /* lhzu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001559 op->type = MKOP(LOAD, u, 2);
1560 op->ea = dform_ea(instr, regs);
1561 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001562
1563 case 42: /* lha */
1564 case 43: /* lhau */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001565 op->type = MKOP(LOAD, SIGNEXT | u, 2);
1566 op->ea = dform_ea(instr, regs);
1567 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001568
1569 case 44: /* sth */
1570 case 45: /* sthu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001571 op->type = MKOP(STORE, u, 2);
1572 op->ea = dform_ea(instr, regs);
1573 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001574
1575 case 46: /* lmw */
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001576 if (ra >= rd)
1577 break; /* invalid form, ra in range to load */
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001578 op->type = MKOP(LOAD_MULTI, 0, 4 * (32 - rd));
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001579 op->ea = dform_ea(instr, regs);
1580 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001581
1582 case 47: /* stmw */
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001583 op->type = MKOP(STORE_MULTI, 0, 4 * (32 - rd));
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001584 op->ea = dform_ea(instr, regs);
1585 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001586
Sean MacLennancd64d162010-09-01 07:21:21 +00001587#ifdef CONFIG_PPC_FPU
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001588 case 48: /* lfs */
1589 case 49: /* lfsu */
1590 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001591 goto fpunavail;
1592 op->type = MKOP(LOAD_FP, u, 4);
1593 op->ea = dform_ea(instr, regs);
1594 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001595
1596 case 50: /* lfd */
1597 case 51: /* lfdu */
1598 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001599 goto fpunavail;
1600 op->type = MKOP(LOAD_FP, u, 8);
1601 op->ea = dform_ea(instr, regs);
1602 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001603
1604 case 52: /* stfs */
1605 case 53: /* stfsu */
1606 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001607 goto fpunavail;
1608 op->type = MKOP(STORE_FP, u, 4);
1609 op->ea = dform_ea(instr, regs);
1610 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001611
1612 case 54: /* stfd */
1613 case 55: /* stfdu */
1614 if (!(regs->msr & MSR_FP))
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001615 goto fpunavail;
1616 op->type = MKOP(STORE_FP, u, 8);
1617 op->ea = dform_ea(instr, regs);
1618 break;
Sean MacLennancd64d162010-09-01 07:21:21 +00001619#endif
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001620
1621#ifdef __powerpc64__
1622 case 58: /* ld[u], lwa */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001623 op->ea = dsform_ea(instr, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001624 switch (instr & 3) {
1625 case 0: /* ld */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001626 op->type = MKOP(LOAD, 0, 8);
1627 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001628 case 1: /* ldu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001629 op->type = MKOP(LOAD, UPDATE, 8);
1630 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001631 case 2: /* lwa */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001632 op->type = MKOP(LOAD, SIGNEXT, 4);
1633 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001634 }
1635 break;
1636
1637 case 62: /* std[u] */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001638 op->ea = dsform_ea(instr, regs);
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001639 switch (instr & 3) {
1640 case 0: /* std */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001641 op->type = MKOP(STORE, 0, 8);
1642 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001643 case 1: /* stdu */
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001644 op->type = MKOP(STORE, UPDATE, 8);
1645 break;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001646 }
1647 break;
1648#endif /* __powerpc64__ */
1649
1650 }
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001651 return 0;
Paul Mackerras0016a4c2010-06-15 14:48:58 +10001652
1653 logical_done:
1654 if (instr & 1)
1655 set_cr0(regs, ra);
1656 goto instr_done;
1657
1658 arith_done:
1659 if (instr & 1)
1660 set_cr0(regs, rd);
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001661
1662 instr_done:
1663 regs->nip = truncate_if_32bit(regs->msr, regs->nip + 4);
1664 return 1;
1665
1666 priv:
1667 op->type = INTERRUPT | 0x700;
1668 op->val = SRR1_PROGPRIV;
1669 return 0;
1670
Paul Mackerrascf87c3f2014-09-02 14:35:08 +10001671 trap:
1672 op->type = INTERRUPT | 0x700;
1673 op->val = SRR1_PROGTRAP;
1674 return 0;
1675
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001676#ifdef CONFIG_PPC_FPU
1677 fpunavail:
1678 op->type = INTERRUPT | 0x800;
1679 return 0;
1680#endif
1681
1682#ifdef CONFIG_ALTIVEC
1683 vecunavail:
1684 op->type = INTERRUPT | 0xf20;
1685 return 0;
1686#endif
1687
1688#ifdef CONFIG_VSX
1689 vsxunavail:
1690 op->type = INTERRUPT | 0xf40;
1691 return 0;
1692#endif
1693}
1694EXPORT_SYMBOL_GPL(analyse_instr);
1695
1696/*
1697 * For PPC32 we always use stwu with r1 to change the stack pointer.
1698 * So this emulated store may corrupt the exception frame, now we
1699 * have to provide the exception frame trampoline, which is pushed
1700 * below the kprobed function stack. So we only update gpr[1] but
1701 * don't emulate the real store operation. We will do real store
1702 * operation safely in exception return code by checking this flag.
1703 */
1704static __kprobes int handle_stack_update(unsigned long ea, struct pt_regs *regs)
1705{
1706#ifdef CONFIG_PPC32
1707 /*
1708 * Check if we will touch kernel stack overflow
1709 */
1710 if (ea - STACK_INT_FRAME_SIZE <= current->thread.ksp_limit) {
1711 printk(KERN_CRIT "Can't kprobe this since kernel stack would overflow.\n");
1712 return -EINVAL;
1713 }
1714#endif /* CONFIG_PPC32 */
1715 /*
1716 * Check if we already set since that means we'll
1717 * lose the previous value.
1718 */
1719 WARN_ON(test_thread_flag(TIF_EMULATE_STACK_STORE));
1720 set_thread_flag(TIF_EMULATE_STACK_STORE);
1721 return 0;
1722}
1723
1724static __kprobes void do_signext(unsigned long *valp, int size)
1725{
1726 switch (size) {
1727 case 2:
1728 *valp = (signed short) *valp;
1729 break;
1730 case 4:
1731 *valp = (signed int) *valp;
1732 break;
1733 }
1734}
1735
1736static __kprobes void do_byterev(unsigned long *valp, int size)
1737{
1738 switch (size) {
1739 case 2:
1740 *valp = byterev_2(*valp);
1741 break;
1742 case 4:
1743 *valp = byterev_4(*valp);
1744 break;
1745#ifdef __powerpc64__
1746 case 8:
1747 *valp = byterev_8(*valp);
1748 break;
1749#endif
1750 }
1751}
1752
1753/*
1754 * Emulate instructions that cause a transfer of control,
1755 * loads and stores, and a few other instructions.
1756 * Returns 1 if the step was emulated, 0 if not,
1757 * or -1 if the instruction is one that should not be stepped,
1758 * such as an rfid, or a mtmsrd that would clear MSR_RI.
1759 */
1760int __kprobes emulate_step(struct pt_regs *regs, unsigned int instr)
1761{
1762 struct instruction_op op;
1763 int r, err, size;
1764 unsigned long val;
1765 unsigned int cr;
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001766 int i, rd, nb;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001767
1768 r = analyse_instr(&op, regs, instr);
1769 if (r != 0)
1770 return r;
1771
1772 err = 0;
1773 size = GETSIZE(op.type);
1774 switch (op.type & INSTR_TYPE_MASK) {
1775 case CACHEOP:
1776 if (!address_ok(regs, op.ea, 8))
1777 return 0;
1778 switch (op.type & CACHEOP_MASK) {
1779 case DCBST:
1780 __cacheop_user_asmx(op.ea, err, "dcbst");
1781 break;
1782 case DCBF:
1783 __cacheop_user_asmx(op.ea, err, "dcbf");
1784 break;
1785 case DCBTST:
1786 if (op.reg == 0)
1787 prefetchw((void *) op.ea);
1788 break;
1789 case DCBT:
1790 if (op.reg == 0)
1791 prefetch((void *) op.ea);
1792 break;
Paul Mackerrascf87c3f2014-09-02 14:35:08 +10001793 case ICBI:
1794 __cacheop_user_asmx(op.ea, err, "icbi");
1795 break;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001796 }
1797 if (err)
1798 return 0;
1799 goto instr_done;
1800
1801 case LARX:
1802 if (regs->msr & MSR_LE)
1803 return 0;
1804 if (op.ea & (size - 1))
1805 break; /* can't handle misaligned */
1806 err = -EFAULT;
1807 if (!address_ok(regs, op.ea, size))
1808 goto ldst_done;
1809 err = 0;
1810 switch (size) {
1811 case 4:
1812 __get_user_asmx(val, op.ea, err, "lwarx");
1813 break;
Lennart Sorensendd217312016-05-05 16:44:44 -04001814#ifdef __powerpc64__
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001815 case 8:
1816 __get_user_asmx(val, op.ea, err, "ldarx");
1817 break;
Lennart Sorensendd217312016-05-05 16:44:44 -04001818#endif
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001819 default:
1820 return 0;
1821 }
1822 if (!err)
1823 regs->gpr[op.reg] = val;
1824 goto ldst_done;
1825
1826 case STCX:
1827 if (regs->msr & MSR_LE)
1828 return 0;
1829 if (op.ea & (size - 1))
1830 break; /* can't handle misaligned */
1831 err = -EFAULT;
1832 if (!address_ok(regs, op.ea, size))
1833 goto ldst_done;
1834 err = 0;
1835 switch (size) {
1836 case 4:
1837 __put_user_asmx(op.val, op.ea, err, "stwcx.", cr);
1838 break;
Lennart Sorensendd217312016-05-05 16:44:44 -04001839#ifdef __powerpc64__
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001840 case 8:
1841 __put_user_asmx(op.val, op.ea, err, "stdcx.", cr);
1842 break;
Lennart Sorensendd217312016-05-05 16:44:44 -04001843#endif
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001844 default:
1845 return 0;
1846 }
1847 if (!err)
1848 regs->ccr = (regs->ccr & 0x0fffffff) |
1849 (cr & 0xe0000000) |
1850 ((regs->xer >> 3) & 0x10000000);
1851 goto ldst_done;
1852
1853 case LOAD:
1854 if (regs->msr & MSR_LE)
1855 return 0;
1856 err = read_mem(&regs->gpr[op.reg], op.ea, size, regs);
1857 if (!err) {
1858 if (op.type & SIGNEXT)
1859 do_signext(&regs->gpr[op.reg], size);
1860 if (op.type & BYTEREV)
1861 do_byterev(&regs->gpr[op.reg], size);
1862 }
1863 goto ldst_done;
1864
Paul Mackerras7048c842014-11-03 15:46:43 +11001865#ifdef CONFIG_PPC_FPU
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001866 case LOAD_FP:
1867 if (regs->msr & MSR_LE)
1868 return 0;
1869 if (size == 4)
1870 err = do_fp_load(op.reg, do_lfs, op.ea, size, regs);
1871 else
1872 err = do_fp_load(op.reg, do_lfd, op.ea, size, regs);
1873 goto ldst_done;
Paul Mackerras7048c842014-11-03 15:46:43 +11001874#endif
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001875#ifdef CONFIG_ALTIVEC
1876 case LOAD_VMX:
1877 if (regs->msr & MSR_LE)
1878 return 0;
1879 err = do_vec_load(op.reg, do_lvx, op.ea & ~0xfUL, regs);
1880 goto ldst_done;
1881#endif
1882#ifdef CONFIG_VSX
1883 case LOAD_VSX:
1884 if (regs->msr & MSR_LE)
1885 return 0;
1886 err = do_vsx_load(op.reg, do_lxvd2x, op.ea, regs);
1887 goto ldst_done;
1888#endif
1889 case LOAD_MULTI:
1890 if (regs->msr & MSR_LE)
1891 return 0;
1892 rd = op.reg;
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001893 for (i = 0; i < size; i += 4) {
1894 nb = size - i;
1895 if (nb > 4)
1896 nb = 4;
1897 err = read_mem(&regs->gpr[rd], op.ea, nb, regs);
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001898 if (err)
1899 return 0;
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001900 if (nb < 4) /* left-justify last bytes */
1901 regs->gpr[rd] <<= 32 - 8 * nb;
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001902 op.ea += 4;
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001903 ++rd;
1904 }
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001905 goto instr_done;
1906
1907 case STORE:
1908 if (regs->msr & MSR_LE)
1909 return 0;
1910 if ((op.type & UPDATE) && size == sizeof(long) &&
1911 op.reg == 1 && op.update_reg == 1 &&
1912 !(regs->msr & MSR_PR) &&
1913 op.ea >= regs->gpr[1] - STACK_INT_FRAME_SIZE) {
1914 err = handle_stack_update(op.ea, regs);
1915 goto ldst_done;
1916 }
1917 err = write_mem(op.val, op.ea, size, regs);
1918 goto ldst_done;
1919
Paul Mackerras7048c842014-11-03 15:46:43 +11001920#ifdef CONFIG_PPC_FPU
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001921 case STORE_FP:
1922 if (regs->msr & MSR_LE)
1923 return 0;
1924 if (size == 4)
1925 err = do_fp_store(op.reg, do_stfs, op.ea, size, regs);
1926 else
1927 err = do_fp_store(op.reg, do_stfd, op.ea, size, regs);
1928 goto ldst_done;
Paul Mackerras7048c842014-11-03 15:46:43 +11001929#endif
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001930#ifdef CONFIG_ALTIVEC
1931 case STORE_VMX:
1932 if (regs->msr & MSR_LE)
1933 return 0;
1934 err = do_vec_store(op.reg, do_stvx, op.ea & ~0xfUL, regs);
1935 goto ldst_done;
1936#endif
1937#ifdef CONFIG_VSX
1938 case STORE_VSX:
1939 if (regs->msr & MSR_LE)
1940 return 0;
1941 err = do_vsx_store(op.reg, do_stxvd2x, op.ea, regs);
1942 goto ldst_done;
1943#endif
1944 case STORE_MULTI:
1945 if (regs->msr & MSR_LE)
1946 return 0;
1947 rd = op.reg;
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001948 for (i = 0; i < size; i += 4) {
1949 val = regs->gpr[rd];
1950 nb = size - i;
1951 if (nb > 4)
1952 nb = 4;
1953 else
1954 val >>= 32 - 8 * nb;
1955 err = write_mem(val, op.ea, nb, regs);
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001956 if (err)
1957 return 0;
1958 op.ea += 4;
Paul Mackerrasc9f6f4e2014-09-02 14:35:09 +10001959 ++rd;
1960 }
Paul Mackerrasbe96f632014-09-02 14:35:07 +10001961 goto instr_done;
1962
1963 case MFMSR:
1964 regs->gpr[op.reg] = regs->msr & MSR_MASK;
1965 goto instr_done;
1966
1967 case MTMSR:
1968 val = regs->gpr[op.reg];
1969 if ((val & MSR_RI) == 0)
1970 /* can't step mtmsr[d] that would clear MSR_RI */
1971 return -1;
1972 /* here op.val is the mask of bits to change */
1973 regs->msr = (regs->msr & ~op.val) | (val & op.val);
1974 goto instr_done;
1975
1976#ifdef CONFIG_PPC64
1977 case SYSCALL: /* sc */
1978 /*
1979 * N.B. this uses knowledge about how the syscall
1980 * entry code works. If that is changed, this will
1981 * need to be changed also.
1982 */
1983 if (regs->gpr[0] == 0x1ebe &&
1984 cpu_has_feature(CPU_FTR_REAL_LE)) {
1985 regs->msr ^= MSR_LE;
1986 goto instr_done;
1987 }
1988 regs->gpr[9] = regs->gpr[13];
1989 regs->gpr[10] = MSR_KERNEL;
1990 regs->gpr[11] = regs->nip + 4;
1991 regs->gpr[12] = regs->msr & MSR_MASK;
1992 regs->gpr[13] = (unsigned long) get_paca();
1993 regs->nip = (unsigned long) &system_call_common;
1994 regs->msr = MSR_KERNEL;
1995 return 1;
1996
1997 case RFI:
1998 return -1;
1999#endif
2000 }
2001 return 0;
2002
2003 ldst_done:
2004 if (err)
2005 return 0;
2006 if (op.type & UPDATE)
2007 regs->gpr[op.update_reg] = op.ea;
2008
2009 instr_done:
2010 regs->nip = truncate_if_32bit(regs->msr, regs->nip + 4);
2011 return 1;
Paul Mackerras14cf11a2005-09-26 16:04:21 +10002012}