70 lines
		
	
	
	
		
			2.1 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			70 lines
		
	
	
	
		
			2.1 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
|   | #ifndef USER32_H
 | ||
|  | #define USER32_H 1
 | ||
|  | 
 | ||
|  | /* IA32 compatible user structures for ptrace. These should be used for 32bit coredumps too. */ | ||
|  | 
 | ||
|  | struct user_i387_ia32_struct { | ||
|  | 	u32	cwd; | ||
|  | 	u32	swd; | ||
|  | 	u32	twd; | ||
|  | 	u32	fip; | ||
|  | 	u32	fcs; | ||
|  | 	u32	foo; | ||
|  | 	u32	fos; | ||
|  | 	u32	st_space[20];   /* 8*10 bytes for each FP-reg = 80 bytes */ | ||
|  | }; | ||
|  | 
 | ||
|  | /* FSAVE frame with extensions */ | ||
|  | struct user32_fxsr_struct { | ||
|  | 	unsigned short	cwd; | ||
|  | 	unsigned short	swd; | ||
|  | 	unsigned short	twd;	/* not compatible to 64bit twd */ | ||
|  | 	unsigned short	fop; | ||
|  | 	int	fip; | ||
|  | 	int	fcs; | ||
|  | 	int	foo; | ||
|  | 	int	fos; | ||
|  | 	int	mxcsr; | ||
|  | 	int	reserved; | ||
|  | 	int	st_space[32];	/* 8*16 bytes for each FP-reg = 128 bytes */ | ||
|  | 	int	xmm_space[32];	/* 8*16 bytes for each XMM-reg = 128 bytes */ | ||
|  | 	int	padding[56]; | ||
|  | }; | ||
|  | 
 | ||
|  | struct user_regs_struct32 { | ||
|  | 	__u32 ebx, ecx, edx, esi, edi, ebp, eax; | ||
|  | 	unsigned short ds, __ds, es, __es; | ||
|  | 	unsigned short fs, __fs, gs, __gs; | ||
|  | 	__u32 orig_eax, eip; | ||
|  | 	unsigned short cs, __cs; | ||
|  | 	__u32 eflags, esp; | ||
|  | 	unsigned short ss, __ss; | ||
|  | }; | ||
|  | 
 | ||
|  | struct user32 { | ||
|  |   struct user_regs_struct32 regs;		/* Where the registers are actually stored */ | ||
|  |   int u_fpvalid;		/* True if math co-processor being used. */ | ||
|  |                                 /* for this mess. Not yet used. */ | ||
|  |   struct user_i387_ia32_struct i387;	/* Math Co-processor registers. */ | ||
|  | /* The rest of this junk is to help gdb figure out what goes where */ | ||
|  |   __u32 u_tsize;	/* Text segment size (pages). */ | ||
|  |   __u32 u_dsize;	/* Data segment size (pages). */ | ||
|  |   __u32 u_ssize;	/* Stack segment size (pages). */ | ||
|  |   __u32 start_code;     /* Starting virtual address of text. */ | ||
|  |   __u32 start_stack;	/* Starting virtual address of stack area.
 | ||
|  | 				   This is actually the bottom of the stack, | ||
|  | 				   the top of the stack is always found in the | ||
|  | 				   esp register.  */ | ||
|  |   __u32 signal;     		/* Signal that caused the core dump. */ | ||
|  |   int reserved;			/* No __u32er used */ | ||
|  |   __u32 u_ar0;	/* Used by gdb to help find the values for */ | ||
|  | 				/* the registers. */ | ||
|  |   __u32 u_fpstate;	/* Math Co-processor pointer. */ | ||
|  |   __u32 magic;		/* To uniquely identify a core file */ | ||
|  |   char u_comm[32];		/* User command that was responsible */ | ||
|  |   int u_debugreg[8]; | ||
|  | }; | ||
|  | 
 | ||
|  | 
 | ||
|  | #endif
 |