[SPARC64]: Start using LMB information in bootmem_init().
[linux-2.6/openmoko-kernel/knife-kernel.git] / arch / um / sys-x86_64 / user-offsets.c
blob2f3443c6e859f4d890ef8b4e8c21c03c2e7bb152
1 #include <stdio.h>
2 #include <stddef.h>
3 #include <signal.h>
4 #include <sys/poll.h>
5 #include <sys/mman.h>
6 #include <sys/user.h>
7 #define __FRAME_OFFSETS
8 #include <asm/ptrace.h>
9 #include <asm/types.h>
11 #define DEFINE(sym, val) \
12 asm volatile("\n->" #sym " %0 " #val : : "i" (val))
14 #define DEFINE_LONGS(sym, val) \
15 asm volatile("\n->" #sym " %0 " #val : : "i" (val/sizeof(unsigned long)))
17 #define OFFSET(sym, str, mem) \
18 DEFINE(sym, offsetof(struct str, mem));
20 void foo(void)
22 OFFSET(HOST_SC_CR2, sigcontext, cr2);
23 OFFSET(HOST_SC_ERR, sigcontext, err);
24 OFFSET(HOST_SC_TRAPNO, sigcontext, trapno);
26 DEFINE(HOST_FP_SIZE, sizeof(struct _fpstate) / sizeof(unsigned long));
27 DEFINE(HOST_XFP_SIZE, 0);
28 DEFINE_LONGS(HOST_RBX, RBX);
29 DEFINE_LONGS(HOST_RCX, RCX);
30 DEFINE_LONGS(HOST_RDI, RDI);
31 DEFINE_LONGS(HOST_RSI, RSI);
32 DEFINE_LONGS(HOST_RDX, RDX);
33 DEFINE_LONGS(HOST_RBP, RBP);
34 DEFINE_LONGS(HOST_RAX, RAX);
35 DEFINE_LONGS(HOST_R8, R8);
36 DEFINE_LONGS(HOST_R9, R9);
37 DEFINE_LONGS(HOST_R10, R10);
38 DEFINE_LONGS(HOST_R11, R11);
39 DEFINE_LONGS(HOST_R12, R12);
40 DEFINE_LONGS(HOST_R13, R13);
41 DEFINE_LONGS(HOST_R14, R14);
42 DEFINE_LONGS(HOST_R15, R15);
43 DEFINE_LONGS(HOST_ORIG_RAX, ORIG_RAX);
44 DEFINE_LONGS(HOST_CS, CS);
45 DEFINE_LONGS(HOST_SS, SS);
46 DEFINE_LONGS(HOST_EFLAGS, EFLAGS);
47 #if 0
48 DEFINE_LONGS(HOST_FS, FS);
49 DEFINE_LONGS(HOST_GS, GS);
50 DEFINE_LONGS(HOST_DS, DS);
51 DEFINE_LONGS(HOST_ES, ES);
52 #endif
54 DEFINE_LONGS(HOST_IP, RIP);
55 DEFINE_LONGS(HOST_SP, RSP);
56 DEFINE(UM_FRAME_SIZE, sizeof(struct user_regs_struct));
58 /* XXX Duplicated between i386 and x86_64 */
59 DEFINE(UM_POLLIN, POLLIN);
60 DEFINE(UM_POLLPRI, POLLPRI);
61 DEFINE(UM_POLLOUT, POLLOUT);
63 DEFINE(UM_PROT_READ, PROT_READ);
64 DEFINE(UM_PROT_WRITE, PROT_WRITE);
65 DEFINE(UM_PROT_EXEC, PROT_EXEC);