1*b2441318SGreg Kroah-Hartman // SPDX-License-Identifier: GPL-2.0 25c48b108SAl Viro #include <stdio.h> 35c48b108SAl Viro #include <stddef.h> 45c48b108SAl Viro #include <signal.h> 55c48b108SAl Viro #include <sys/poll.h> 65c48b108SAl Viro #include <sys/mman.h> 75c48b108SAl Viro #include <sys/user.h> 85c48b108SAl Viro #define __FRAME_OFFSETS 961e8d462SRichard Weinberger #include <linux/ptrace.h> 105c48b108SAl Viro #include <asm/types.h> 115c48b108SAl Viro 1245db1c61SH. Peter Anvin #ifdef __i386__ 13cfcbadb4SAndy Lutomirski #define __SYSCALL_I386(nr, sym, qual) [nr] = 1, 1445db1c61SH. Peter Anvin static char syscalls[] = { 1545db1c61SH. Peter Anvin #include <asm/syscalls_32.h> 1645db1c61SH. Peter Anvin }; 1745db1c61SH. Peter Anvin #else 18cfcbadb4SAndy Lutomirski #define __SYSCALL_64(nr, sym, qual) [nr] = 1, 1945db1c61SH. Peter Anvin static char syscalls[] = { 2045db1c61SH. Peter Anvin #include <asm/syscalls_64.h> 2145db1c61SH. Peter Anvin }; 2245db1c61SH. Peter Anvin #endif 2345db1c61SH. Peter Anvin 245c48b108SAl Viro #define DEFINE(sym, val) \ 255c48b108SAl Viro asm volatile("\n->" #sym " %0 " #val : : "i" (val)) 265c48b108SAl Viro 275c48b108SAl Viro #define DEFINE_LONGS(sym, val) \ 285c48b108SAl Viro asm volatile("\n->" #sym " %0 " #val : : "i" (val/sizeof(unsigned long))) 295c48b108SAl Viro 305c48b108SAl Viro void foo(void) 315c48b108SAl Viro { 325c48b108SAl Viro #ifdef __i386__ 335c48b108SAl Viro DEFINE_LONGS(HOST_FP_SIZE, sizeof(struct user_fpregs_struct)); 345c48b108SAl Viro DEFINE_LONGS(HOST_FPX_SIZE, sizeof(struct user_fpxregs_struct)); 355c48b108SAl Viro 365c48b108SAl Viro DEFINE(HOST_IP, EIP); 375c48b108SAl Viro DEFINE(HOST_SP, UESP); 385c48b108SAl Viro DEFINE(HOST_EFLAGS, EFL); 393579a389SAl Viro DEFINE(HOST_AX, EAX); 403579a389SAl Viro DEFINE(HOST_BX, EBX); 413579a389SAl Viro DEFINE(HOST_CX, ECX); 423579a389SAl Viro DEFINE(HOST_DX, EDX); 433579a389SAl Viro DEFINE(HOST_SI, ESI); 443579a389SAl Viro DEFINE(HOST_DI, EDI); 453579a389SAl Viro DEFINE(HOST_BP, EBP); 465c48b108SAl Viro DEFINE(HOST_CS, CS); 475c48b108SAl Viro DEFINE(HOST_SS, SS); 485c48b108SAl Viro DEFINE(HOST_DS, DS); 495c48b108SAl Viro DEFINE(HOST_FS, FS); 505c48b108SAl Viro DEFINE(HOST_ES, ES); 515c48b108SAl Viro DEFINE(HOST_GS, GS); 52966e803aSAl Viro DEFINE(HOST_ORIG_AX, ORIG_EAX); 535c48b108SAl Viro #else 542fb44600SFlorian Fainelli #ifdef FP_XSTATE_MAGIC1 556f602afdSThomas Meyer DEFINE_LONGS(HOST_FP_SIZE, 2696); 560a987645SFlorian Fainelli #else 570a987645SFlorian Fainelli DEFINE(HOST_FP_SIZE, sizeof(struct _fpstate) / sizeof(unsigned long)); 580a987645SFlorian Fainelli #endif 593579a389SAl Viro DEFINE_LONGS(HOST_BX, RBX); 603579a389SAl Viro DEFINE_LONGS(HOST_CX, RCX); 613579a389SAl Viro DEFINE_LONGS(HOST_DI, RDI); 623579a389SAl Viro DEFINE_LONGS(HOST_SI, RSI); 633579a389SAl Viro DEFINE_LONGS(HOST_DX, RDX); 643579a389SAl Viro DEFINE_LONGS(HOST_BP, RBP); 653579a389SAl Viro DEFINE_LONGS(HOST_AX, RAX); 665c48b108SAl Viro DEFINE_LONGS(HOST_R8, R8); 675c48b108SAl Viro DEFINE_LONGS(HOST_R9, R9); 685c48b108SAl Viro DEFINE_LONGS(HOST_R10, R10); 695c48b108SAl Viro DEFINE_LONGS(HOST_R11, R11); 705c48b108SAl Viro DEFINE_LONGS(HOST_R12, R12); 715c48b108SAl Viro DEFINE_LONGS(HOST_R13, R13); 725c48b108SAl Viro DEFINE_LONGS(HOST_R14, R14); 735c48b108SAl Viro DEFINE_LONGS(HOST_R15, R15); 74966e803aSAl Viro DEFINE_LONGS(HOST_ORIG_AX, ORIG_RAX); 755c48b108SAl Viro DEFINE_LONGS(HOST_CS, CS); 765c48b108SAl Viro DEFINE_LONGS(HOST_SS, SS); 775c48b108SAl Viro DEFINE_LONGS(HOST_EFLAGS, EFLAGS); 785c48b108SAl Viro #if 0 795c48b108SAl Viro DEFINE_LONGS(HOST_FS, FS); 805c48b108SAl Viro DEFINE_LONGS(HOST_GS, GS); 815c48b108SAl Viro DEFINE_LONGS(HOST_DS, DS); 825c48b108SAl Viro DEFINE_LONGS(HOST_ES, ES); 835c48b108SAl Viro #endif 845c48b108SAl Viro 855c48b108SAl Viro DEFINE_LONGS(HOST_IP, RIP); 865c48b108SAl Viro DEFINE_LONGS(HOST_SP, RSP); 875c48b108SAl Viro #endif 885c48b108SAl Viro 895c48b108SAl Viro DEFINE(UM_FRAME_SIZE, sizeof(struct user_regs_struct)); 905c48b108SAl Viro DEFINE(UM_POLLIN, POLLIN); 915c48b108SAl Viro DEFINE(UM_POLLPRI, POLLPRI); 925c48b108SAl Viro DEFINE(UM_POLLOUT, POLLOUT); 935c48b108SAl Viro 945c48b108SAl Viro DEFINE(UM_PROT_READ, PROT_READ); 955c48b108SAl Viro DEFINE(UM_PROT_WRITE, PROT_WRITE); 965c48b108SAl Viro DEFINE(UM_PROT_EXEC, PROT_EXEC); 9745db1c61SH. Peter Anvin 9845db1c61SH. Peter Anvin DEFINE(__NR_syscall_max, sizeof(syscalls) - 1); 9945db1c61SH. Peter Anvin DEFINE(NR_syscalls, sizeof(syscalls)); 1005c48b108SAl Viro } 101