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