Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0 |
Al Viro | 8d0b9dc | 2005-05-05 16:15:23 -0700 | [diff] [blame] | 2 | #include <stdio.h> |
| 3 | #include <stddef.h> |
| 4 | #include <signal.h> |
Jeff Dike | 63ae2a9 | 2006-03-27 01:14:30 -0800 | [diff] [blame] | 5 | #include <sys/poll.h> |
Jeff Dike | 16dd07b | 2007-05-06 14:51:48 -0700 | [diff] [blame] | 6 | #include <sys/mman.h> |
Jeff Dike | 189872f | 2007-10-16 01:27:14 -0700 | [diff] [blame] | 7 | #include <sys/user.h> |
Al Viro | 8d0b9dc | 2005-05-05 16:15:23 -0700 | [diff] [blame] | 8 | #define __FRAME_OFFSETS |
Richard Weinberger | 61e8d46 | 2017-07-06 09:35:27 +0200 | [diff] [blame] | 9 | #include <linux/ptrace.h> |
Jeff Dike | ba9950c | 2005-05-20 13:59:07 -0700 | [diff] [blame] | 10 | #include <asm/types.h> |
Al Viro | 8d0b9dc | 2005-05-05 16:15:23 -0700 | [diff] [blame] | 11 | |
H. Peter Anvin | 45db1c6 | 2011-12-05 16:08:49 -0800 | [diff] [blame] | 12 | #ifdef __i386__ |
Andy Lutomirski | cfcbadb | 2016-01-28 15:11:24 -0800 | [diff] [blame] | 13 | #define __SYSCALL_I386(nr, sym, qual) [nr] = 1, |
H. Peter Anvin | 45db1c6 | 2011-12-05 16:08:49 -0800 | [diff] [blame] | 14 | static char syscalls[] = { |
| 15 | #include <asm/syscalls_32.h> |
| 16 | }; |
| 17 | #else |
Andy Lutomirski | cfcbadb | 2016-01-28 15:11:24 -0800 | [diff] [blame] | 18 | #define __SYSCALL_64(nr, sym, qual) [nr] = 1, |
H. Peter Anvin | 45db1c6 | 2011-12-05 16:08:49 -0800 | [diff] [blame] | 19 | static char syscalls[] = { |
| 20 | #include <asm/syscalls_64.h> |
| 21 | }; |
| 22 | #endif |
| 23 | |
Al Viro | 8d0b9dc | 2005-05-05 16:15:23 -0700 | [diff] [blame] | 24 | #define DEFINE(sym, val) \ |
Al Viro | 6582b7f | 2011-08-18 20:03:19 +0100 | [diff] [blame] | 25 | asm volatile("\n->" #sym " %0 " #val : : "i" (val)) |
Al Viro | 8d0b9dc | 2005-05-05 16:15:23 -0700 | [diff] [blame] | 26 | |
Al Viro | ecba97d | 2005-09-28 22:27:23 +0100 | [diff] [blame] | 27 | #define DEFINE_LONGS(sym, val) \ |
Al Viro | 6582b7f | 2011-08-18 20:03:19 +0100 | [diff] [blame] | 28 | asm volatile("\n->" #sym " %0 " #val : : "i" (val/sizeof(unsigned long))) |
Al Viro | ecba97d | 2005-09-28 22:27:23 +0100 | [diff] [blame] | 29 | |
Al Viro | 8d0b9dc | 2005-05-05 16:15:23 -0700 | [diff] [blame] | 30 | void foo(void) |
| 31 | { |
Al Viro | 6582b7f | 2011-08-18 20:03:19 +0100 | [diff] [blame] | 32 | #ifdef __i386__ |
| 33 | DEFINE_LONGS(HOST_FP_SIZE, sizeof(struct user_fpregs_struct)); |
| 34 | DEFINE_LONGS(HOST_FPX_SIZE, sizeof(struct user_fpxregs_struct)); |
| 35 | |
| 36 | DEFINE(HOST_IP, EIP); |
| 37 | DEFINE(HOST_SP, UESP); |
| 38 | DEFINE(HOST_EFLAGS, EFL); |
Al Viro | 3579a38 | 2011-08-18 20:10:09 +0100 | [diff] [blame] | 39 | DEFINE(HOST_AX, EAX); |
| 40 | DEFINE(HOST_BX, EBX); |
| 41 | DEFINE(HOST_CX, ECX); |
| 42 | DEFINE(HOST_DX, EDX); |
| 43 | DEFINE(HOST_SI, ESI); |
| 44 | DEFINE(HOST_DI, EDI); |
| 45 | DEFINE(HOST_BP, EBP); |
Al Viro | 6582b7f | 2011-08-18 20:03:19 +0100 | [diff] [blame] | 46 | DEFINE(HOST_CS, CS); |
| 47 | DEFINE(HOST_SS, SS); |
| 48 | DEFINE(HOST_DS, DS); |
| 49 | DEFINE(HOST_FS, FS); |
| 50 | DEFINE(HOST_ES, ES); |
| 51 | DEFINE(HOST_GS, GS); |
Al Viro | 966e803 | 2011-08-18 20:12:19 +0100 | [diff] [blame] | 52 | DEFINE(HOST_ORIG_AX, ORIG_EAX); |
Al Viro | 6582b7f | 2011-08-18 20:03:19 +0100 | [diff] [blame] | 53 | #else |
Florian Fainelli | 2fb4460 | 2017-07-18 16:43:47 -0700 | [diff] [blame] | 54 | #ifdef FP_XSTATE_MAGIC1 |
Thomas Meyer | 6f602afd | 2017-07-29 17:03:23 +0200 | [diff] [blame] | 55 | DEFINE_LONGS(HOST_FP_SIZE, 2696); |
Florian Fainelli | 0a98764 | 2017-05-25 11:36:26 -0700 | [diff] [blame] | 56 | #else |
| 57 | DEFINE(HOST_FP_SIZE, sizeof(struct _fpstate) / sizeof(unsigned long)); |
| 58 | #endif |
Al Viro | 3579a38 | 2011-08-18 20:10:09 +0100 | [diff] [blame] | 59 | DEFINE_LONGS(HOST_BX, RBX); |
| 60 | DEFINE_LONGS(HOST_CX, RCX); |
| 61 | DEFINE_LONGS(HOST_DI, RDI); |
| 62 | DEFINE_LONGS(HOST_SI, RSI); |
| 63 | DEFINE_LONGS(HOST_DX, RDX); |
| 64 | DEFINE_LONGS(HOST_BP, RBP); |
| 65 | DEFINE_LONGS(HOST_AX, RAX); |
Al Viro | ecba97d | 2005-09-28 22:27:23 +0100 | [diff] [blame] | 66 | DEFINE_LONGS(HOST_R8, R8); |
| 67 | DEFINE_LONGS(HOST_R9, R9); |
| 68 | DEFINE_LONGS(HOST_R10, R10); |
| 69 | DEFINE_LONGS(HOST_R11, R11); |
| 70 | DEFINE_LONGS(HOST_R12, R12); |
| 71 | DEFINE_LONGS(HOST_R13, R13); |
| 72 | DEFINE_LONGS(HOST_R14, R14); |
| 73 | DEFINE_LONGS(HOST_R15, R15); |
Al Viro | 966e803 | 2011-08-18 20:12:19 +0100 | [diff] [blame] | 74 | DEFINE_LONGS(HOST_ORIG_AX, ORIG_RAX); |
Al Viro | ecba97d | 2005-09-28 22:27:23 +0100 | [diff] [blame] | 75 | DEFINE_LONGS(HOST_CS, CS); |
| 76 | DEFINE_LONGS(HOST_SS, SS); |
| 77 | DEFINE_LONGS(HOST_EFLAGS, EFLAGS); |
Al Viro | 8d0b9dc | 2005-05-05 16:15:23 -0700 | [diff] [blame] | 78 | #if 0 |
Al Viro | ecba97d | 2005-09-28 22:27:23 +0100 | [diff] [blame] | 79 | DEFINE_LONGS(HOST_FS, FS); |
| 80 | DEFINE_LONGS(HOST_GS, GS); |
| 81 | DEFINE_LONGS(HOST_DS, DS); |
| 82 | DEFINE_LONGS(HOST_ES, ES); |
Al Viro | 8d0b9dc | 2005-05-05 16:15:23 -0700 | [diff] [blame] | 83 | #endif |
| 84 | |
Al Viro | ecba97d | 2005-09-28 22:27:23 +0100 | [diff] [blame] | 85 | DEFINE_LONGS(HOST_IP, RIP); |
| 86 | DEFINE_LONGS(HOST_SP, RSP); |
Al Viro | 6582b7f | 2011-08-18 20:03:19 +0100 | [diff] [blame] | 87 | #endif |
Jeff Dike | 63ae2a9 | 2006-03-27 01:14:30 -0800 | [diff] [blame] | 88 | |
Al Viro | 6582b7f | 2011-08-18 20:03:19 +0100 | [diff] [blame] | 89 | DEFINE(UM_FRAME_SIZE, sizeof(struct user_regs_struct)); |
Jeff Dike | 63ae2a9 | 2006-03-27 01:14:30 -0800 | [diff] [blame] | 90 | DEFINE(UM_POLLIN, POLLIN); |
| 91 | DEFINE(UM_POLLPRI, POLLPRI); |
| 92 | DEFINE(UM_POLLOUT, POLLOUT); |
Jeff Dike | 16dd07b | 2007-05-06 14:51:48 -0700 | [diff] [blame] | 93 | |
| 94 | DEFINE(UM_PROT_READ, PROT_READ); |
| 95 | DEFINE(UM_PROT_WRITE, PROT_WRITE); |
| 96 | DEFINE(UM_PROT_EXEC, PROT_EXEC); |
H. Peter Anvin | 45db1c6 | 2011-12-05 16:08:49 -0800 | [diff] [blame] | 97 | |
| 98 | DEFINE(__NR_syscall_max, sizeof(syscalls) - 1); |
| 99 | DEFINE(NR_syscalls, sizeof(syscalls)); |
Al Viro | 8d0b9dc | 2005-05-05 16:15:23 -0700 | [diff] [blame] | 100 | } |