1 
2 /*--------------------------------------------------------------------*/
3 /*--- x86/Linux-specific kernel interface.         vki-x86-linux.h ---*/
4 /*--------------------------------------------------------------------*/
5 
6 /*
7    This file is part of Valgrind, a dynamic binary instrumentation
8    framework.
9 
10    Copyright (C) 2000-2015 Julian Seward
11       jseward@acm.org
12 
13    This program is free software; you can redistribute it and/or
14    modify it under the terms of the GNU General Public License as
15    published by the Free Software Foundation; either version 2 of the
16    License, or (at your option) any later version.
17 
18    This program is distributed in the hope that it will be useful, but
19    WITHOUT ANY WARRANTY; without even the implied warranty of
20    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
21    General Public License for more details.
22 
23    You should have received a copy of the GNU General Public License
24    along with this program; if not, write to the Free Software
25    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
26    02111-1307, USA.
27 
28    The GNU General Public License is contained in the file COPYING.
29 */
30 
31 #ifndef __VKI_X86_LINUX_H
32 #define __VKI_X86_LINUX_H
33 
34 // x86 is little-endian.
35 #define VKI_LITTLE_ENDIAN  1
36 
37 //----------------------------------------------------------------------
38 // From linux-2.6.8.1/include/asm-i386/types.h
39 //----------------------------------------------------------------------
40 
41 typedef unsigned char __vki_u8;
42 
43 typedef __signed__ short __vki_s16;
44 typedef unsigned short __vki_u16;
45 
46 typedef __signed__ int __vki_s32;
47 typedef unsigned int __vki_u32;
48 
49 typedef __signed__ long long __vki_s64;
50 typedef unsigned long long __vki_u64;
51 
52 typedef unsigned short vki_u16;
53 
54 typedef unsigned int vki_u32;
55 
56 //----------------------------------------------------------------------
57 // From linux-2.6.8.1/include/asm-i386/page.h
58 //----------------------------------------------------------------------
59 
60 /* PAGE_SHIFT determines the page size */
61 #define VKI_PAGE_SHIFT	12
62 #define VKI_PAGE_SIZE	(1UL << VKI_PAGE_SHIFT)
63 #define VKI_MAX_PAGE_SHIFT	VKI_PAGE_SHIFT
64 #define VKI_MAX_PAGE_SIZE	VKI_PAGE_SIZE
65 
66 //----------------------------------------------------------------------
67 // From linux-2.6.35.4/arch/x86/include/asm/shmparam.h
68 //----------------------------------------------------------------------
69 
70 #define VKI_SHMLBA  VKI_PAGE_SIZE
71 
72 //----------------------------------------------------------------------
73 // From linux-2.6.8.1/include/asm-i386/signal.h
74 //----------------------------------------------------------------------
75 
76 #define VKI_MINSIGSTKSZ	2048
77 
78 #define VKI_SIG_BLOCK          0	/* for blocking signals */
79 #define VKI_SIG_UNBLOCK        1	/* for unblocking signals */
80 #define VKI_SIG_SETMASK        2	/* for setting the signal mask */
81 
82 /* Type of a signal handler.  */
83 typedef void __vki_signalfn_t(int);
84 typedef __vki_signalfn_t __user *__vki_sighandler_t;
85 
86 typedef void __vki_restorefn_t(void);
87 typedef __vki_restorefn_t __user *__vki_sigrestore_t;
88 
89 #define VKI_SIG_DFL	((__vki_sighandler_t)0)	/* default signal handling */
90 #define VKI_SIG_IGN	((__vki_sighandler_t)1)	/* ignore signal */
91 
92 #define _VKI_NSIG	64
93 #define _VKI_NSIG_BPW	32
94 #define _VKI_NSIG_WORDS	(_VKI_NSIG / _VKI_NSIG_BPW)
95 
96 typedef unsigned long vki_old_sigset_t;		/* at least 32 bits */
97 
98 typedef struct {
99 	unsigned long sig[_VKI_NSIG_WORDS];
100 } vki_sigset_t;
101 
102 #define VKI_SIGHUP		 1
103 #define VKI_SIGINT		 2
104 #define VKI_SIGQUIT		 3
105 #define VKI_SIGILL		 4
106 #define VKI_SIGTRAP		 5
107 #define VKI_SIGABRT		 6
108 //#define VKI_SIGIOT		 6
109 #define VKI_SIGBUS		 7
110 #define VKI_SIGFPE		 8
111 #define VKI_SIGKILL		 9
112 #define VKI_SIGUSR1		10
113 #define VKI_SIGSEGV		11
114 #define VKI_SIGUSR2		12
115 #define VKI_SIGPIPE		13
116 #define VKI_SIGALRM		14
117 #define VKI_SIGTERM		15
118 #define VKI_SIGSTKFLT		16
119 #define VKI_SIGCHLD		17
120 #define VKI_SIGCONT		18
121 #define VKI_SIGSTOP		19
122 #define VKI_SIGTSTP		20
123 #define VKI_SIGTTIN		21
124 #define VKI_SIGTTOU		22
125 #define VKI_SIGURG		23
126 #define VKI_SIGXCPU		24
127 #define VKI_SIGXFSZ		25
128 #define VKI_SIGVTALRM		26
129 #define VKI_SIGPROF		27
130 #define VKI_SIGWINCH		28
131 #define VKI_SIGIO		29
132 #define VKI_SIGPWR		30
133 #define VKI_SIGSYS		31
134 #define	VKI_SIGUNUSED		31
135 
136 /* These should not be considered constants from userland.  */
137 #define VKI_SIGRTMIN	32
138 // [[This was (_NSIG-1) in 2.4.X... not sure if it matters.]]
139 #define VKI_SIGRTMAX	_VKI_NSIG
140 
141 #define VKI_SA_NOCLDSTOP	0x00000001u
142 #define VKI_SA_NOCLDWAIT	0x00000002u
143 #define VKI_SA_SIGINFO		0x00000004u
144 #define VKI_SA_ONSTACK		0x08000000u
145 #define VKI_SA_RESTART		0x10000000u
146 #define VKI_SA_NODEFER		0x40000000u
147 #define VKI_SA_RESETHAND	0x80000000u
148 
149 #define VKI_SA_NOMASK		VKI_SA_NODEFER
150 #define VKI_SA_ONESHOT		VKI_SA_RESETHAND
151 //#define VKI_SA_INTERRUPT	0x20000000 /* dummy -- ignored */
152 
153 #define VKI_SA_RESTORER		0x04000000
154 
155 #define VKI_SS_ONSTACK	1
156 #define VKI_SS_DISABLE	2
157 
158 /* These are 'legacy' sigactions in which the size of sa_mask is fixed
159    (cannot be expanded at any future point) because it is sandwiched
160    between two other fields.
161    (there is identical kludgery in vki-ppc32-linux.h) */
162 struct vki_old_sigaction {
163         // [[Nb: a 'k' prefix is added to "sa_handler" because
164         // bits/sigaction.h (which gets dragged in somehow via signal.h)
165         // #defines it as something else.  Since that is done for glibc's
166         // purposes, which we don't care about here, we use our own name.]]
167         __vki_sighandler_t ksa_handler;
168         vki_old_sigset_t sa_mask;
169         unsigned long sa_flags;
170         __vki_sigrestore_t sa_restorer;
171 };
172 
173 struct vki_sigaction_base {
174         // [[See comment about extra 'k' above]]
175 	__vki_sighandler_t ksa_handler;
176 	unsigned long sa_flags;
177 	__vki_sigrestore_t sa_restorer;
178 	vki_sigset_t sa_mask;		/* mask last for extensibility */
179 };
180 
181 /* On Linux we use the same type for passing sigactions to
182    and from the kernel.  Hence: */
183 typedef  struct vki_sigaction_base  vki_sigaction_toK_t;
184 typedef  struct vki_sigaction_base  vki_sigaction_fromK_t;
185 
186 
187 typedef struct vki_sigaltstack {
188 	void __user *ss_sp;
189 	int ss_flags;
190 	vki_size_t ss_size;
191 } vki_stack_t;
192 
193 //----------------------------------------------------------------------
194 // From linux-2.6.8.1/include/asm-i386/sigcontext.h
195 //----------------------------------------------------------------------
196 
197 struct _vki_fpreg {
198 	unsigned short significand[4];
199 	unsigned short exponent;
200 };
201 
202 struct _vki_fpxreg {
203 	unsigned short significand[4];
204 	unsigned short exponent;
205 	unsigned short padding[3];
206 };
207 
208 struct _vki_xmmreg {
209 	unsigned long element[4];
210 };
211 
212 struct _vki_fpstate {
213 	/* Regular FPU environment */
214 	unsigned long 	cw;
215 	unsigned long	sw;
216 	unsigned long	tag;
217 	unsigned long	ipoff;
218 	unsigned long	cssel;
219 	unsigned long	dataoff;
220 	unsigned long	datasel;
221 	struct _vki_fpreg	_st[8];
222 	unsigned short	status;
223 	unsigned short	magic;		/* 0xffff = regular FPU data only */
224 
225 	/* FXSR FPU environment */
226 	unsigned long	_fxsr_env[6];	/* FXSR FPU env is ignored */
227 	unsigned long	mxcsr;
228 	unsigned long	reserved;
229 	struct _vki_fpxreg	_fxsr_st[8];	/* FXSR FPU reg data is ignored */
230 	struct _vki_xmmreg	_xmm[8];
231 	unsigned long	padding[56];
232 };
233 
234 struct vki_sigcontext {
235 	unsigned short gs, __gsh;
236 	unsigned short fs, __fsh;
237 	unsigned short es, __esh;
238 	unsigned short ds, __dsh;
239 	unsigned long edi;
240 	unsigned long esi;
241 	unsigned long ebp;
242 	unsigned long esp;
243 	unsigned long ebx;
244 	unsigned long edx;
245 	unsigned long ecx;
246 	unsigned long eax;
247 	unsigned long trapno;
248 	unsigned long err;
249 	unsigned long eip;
250 	unsigned short cs, __csh;
251 	unsigned long eflags;
252 	unsigned long esp_at_signal;
253 	unsigned short ss, __ssh;
254 	struct _vki_fpstate __user * fpstate;
255 	unsigned long oldmask;
256 	unsigned long cr2;
257 };
258 
259 //----------------------------------------------------------------------
260 // From linux-2.6.8.1/include/asm-i386/mman.h
261 //----------------------------------------------------------------------
262 
263 #define VKI_PROT_NONE	0x0		/* No page permissions */
264 #define VKI_PROT_READ	0x1		/* page can be read */
265 #define VKI_PROT_WRITE	0x2		/* page can be written */
266 #define VKI_PROT_EXEC	0x4		/* page can be executed */
267 #define VKI_PROT_GROWSDOWN	0x01000000	/* mprotect flag: extend change to start of growsdown vma */
268 #define VKI_PROT_GROWSUP	0x02000000	/* mprotect flag: extend change to end of growsup vma */
269 
270 #define VKI_MAP_SHARED	0x01		/* Share changes */
271 #define VKI_MAP_PRIVATE	0x02		/* Changes are private */
272 //#define VKI_MAP_TYPE	0x0f		/* Mask for type of mapping */
273 #define VKI_MAP_FIXED	0x10		/* Interpret addr exactly */
274 #define VKI_MAP_ANONYMOUS	0x20	/* don't use a file */
275 #define VKI_MAP_NORESERVE	0x4000		/* don't check for reservations */
276 
277 //----------------------------------------------------------------------
278 // From linux-2.6.8.1/include/asm-i386/fcntl.h
279 //----------------------------------------------------------------------
280 
281 #define VKI_O_ACCMODE	     03
282 #define VKI_O_RDONLY	     00
283 #define VKI_O_WRONLY	     01
284 #define VKI_O_RDWR	     02
285 #define VKI_O_CREAT	   0100	/* not fcntl */
286 #define VKI_O_EXCL	   0200	/* not fcntl */
287 #define VKI_O_TRUNC	  01000	/* not fcntl */
288 #define VKI_O_APPEND	  02000
289 #define VKI_O_NONBLOCK	  04000
290 #define VKI_O_LARGEFILE	0100000
291 
292 #define VKI_AT_FDCWD            -100
293 
294 #define VKI_F_DUPFD		0	/* dup */
295 #define VKI_F_GETFD		1	/* get close_on_exec */
296 #define VKI_F_SETFD		2	/* set/clear close_on_exec */
297 #define VKI_F_GETFL		3	/* get file->f_flags */
298 #define VKI_F_SETFL		4	/* set file->f_flags */
299 #define VKI_F_GETLK		5
300 #define VKI_F_SETLK		6
301 #define VKI_F_SETLKW		7
302 
303 #define VKI_F_SETOWN		8	/*  for sockets. */
304 #define VKI_F_GETOWN		9	/*  for sockets. */
305 #define VKI_F_SETSIG		10	/*  for sockets. */
306 #define VKI_F_GETSIG		11	/*  for sockets. */
307 
308 #define VKI_F_GETLK64		12	/*  using 'struct flock64' */
309 #define VKI_F_SETLK64		13
310 #define VKI_F_SETLKW64		14
311 
312 #define VKI_F_SETOWN_EX		15
313 #define VKI_F_GETOWN_EX		16
314 
315 #define VKI_F_OFD_GETLK		36
316 #define VKI_F_OFD_SETLK		37
317 #define VKI_F_OFD_SETLKW	38
318 
319 #define VKI_F_OWNER_TID		0
320 #define VKI_F_OWNER_PID		1
321 #define VKI_F_OWNER_PGRP	2
322 
323 struct vki_f_owner_ex {
324 	int	type;
325 	__vki_kernel_pid_t	pid;
326 };
327 
328 /* for F_[GET|SET]FL */
329 #define VKI_FD_CLOEXEC	1	/* actually anything with low bit set goes */
330 
331 #define VKI_F_LINUX_SPECIFIC_BASE	1024
332 
333 //----------------------------------------------------------------------
334 // From linux-2.6.8.1/include/asm-i386/resource.h
335 //----------------------------------------------------------------------
336 
337 #define VKI_RLIMIT_DATA		2	/* max data size */
338 #define VKI_RLIMIT_STACK	3	/* max stack size */
339 #define VKI_RLIMIT_CORE		4	/* max core file size */
340 #define VKI_RLIMIT_NOFILE	7	/* max number of open files */
341 
342 //----------------------------------------------------------------------
343 // From linux-2.6.8.1/include/asm-i386/socket.h
344 //----------------------------------------------------------------------
345 
346 #define VKI_SOL_SOCKET	1
347 
348 #define VKI_SO_TYPE	3
349 
350 #define VKI_SO_ATTACH_FILTER	26
351 
352 //----------------------------------------------------------------------
353 // From linux-2.6.8.1/include/asm-i386/sockios.h
354 //----------------------------------------------------------------------
355 
356 #define VKI_SIOCSPGRP		0x8902
357 #define VKI_SIOCGPGRP		0x8904
358 #define VKI_SIOCATMARK  	0x8905
359 #define VKI_SIOCGSTAMP		0x8906		/* Get stamp (timeval) */
360 #define VKI_SIOCGSTAMPNS	0x8907		/* Get stamp (timespec) */
361 
362 //----------------------------------------------------------------------
363 // From linux-2.6.8.1/include/asm-i386/stat.h
364 //----------------------------------------------------------------------
365 
366 struct vki_stat {
367 	unsigned long  st_dev;
368 	unsigned long  st_ino;
369 	unsigned short st_mode;
370 	unsigned short st_nlink;
371 	unsigned short st_uid;
372 	unsigned short st_gid;
373 	unsigned long  st_rdev;
374 	unsigned long  st_size;
375 	unsigned long  st_blksize;
376 	unsigned long  st_blocks;
377 	unsigned long  st_atime;
378 	unsigned long  st_atime_nsec;
379 	unsigned long  st_mtime;
380 	unsigned long  st_mtime_nsec;
381 	unsigned long  st_ctime;
382 	unsigned long  st_ctime_nsec;
383 	unsigned long  __unused4;
384 	unsigned long  __unused5;
385 };
386 
387 struct vki_stat64 {
388 	unsigned long long	st_dev;
389 	unsigned char	__pad0[4];
390 
391 #define STAT64_HAS_BROKEN_ST_INO	1
392 	unsigned long	__st_ino;
393 
394 	unsigned int	st_mode;
395 	unsigned int	st_nlink;
396 
397 	unsigned long	st_uid;
398 	unsigned long	st_gid;
399 
400 	unsigned long long	st_rdev;
401 	unsigned char	__pad3[4];
402 
403 	long long	st_size;
404 	unsigned long	st_blksize;
405 
406 	unsigned long	st_blocks;	/* Number 512-byte blocks allocated. */
407 	unsigned long	__pad4;		/* future possible st_blocks high bits */
408 
409 	unsigned long	st_atime;
410 	unsigned long	st_atime_nsec;
411 
412 	unsigned long	st_mtime;
413 	unsigned int	st_mtime_nsec;
414 
415 	unsigned long	st_ctime;
416 	unsigned long	st_ctime_nsec;
417 
418 	unsigned long long	st_ino;
419 };
420 
421 //----------------------------------------------------------------------
422 // From linux-2.6.8.1/include/asm-i386/statfs.h
423 //----------------------------------------------------------------------
424 
425 // [[Nb: asm-i386/statfs.h just #include asm-generic/statfs.h directly]]
426 struct vki_statfs {
427 	__vki_u32 f_type;
428 	__vki_u32 f_bsize;
429 	__vki_u32 f_blocks;
430 	__vki_u32 f_bfree;
431 	__vki_u32 f_bavail;
432 	__vki_u32 f_files;
433 	__vki_u32 f_ffree;
434 	__vki_kernel_fsid_t f_fsid;
435 	__vki_u32 f_namelen;
436 	__vki_u32 f_frsize;
437 	__vki_u32 f_spare[5];
438 };
439 
440 //----------------------------------------------------------------------
441 // From linux-2.6.8.1/include/asm-i386/termios.h
442 //----------------------------------------------------------------------
443 
444 struct vki_winsize {
445 	unsigned short ws_row;
446 	unsigned short ws_col;
447 	unsigned short ws_xpixel;
448 	unsigned short ws_ypixel;
449 };
450 
451 #define VKI_NCC 8
452 struct vki_termio {
453 	unsigned short c_iflag;		/* input mode flags */
454 	unsigned short c_oflag;		/* output mode flags */
455 	unsigned short c_cflag;		/* control mode flags */
456 	unsigned short c_lflag;		/* local mode flags */
457 	unsigned char c_line;		/* line discipline */
458 	unsigned char c_cc[VKI_NCC];	/* control characters */
459 };
460 
461 
462 //----------------------------------------------------------------------
463 // From linux-2.6.8.1/include/asm-i386/termbits.h
464 //----------------------------------------------------------------------
465 
466 typedef unsigned char   vki_cc_t;
467 typedef unsigned int    vki_tcflag_t;
468 
469 #define VKI_NCCS 19
470 struct vki_termios {
471 	vki_tcflag_t c_iflag;		/* input mode flags */
472 	vki_tcflag_t c_oflag;		/* output mode flags */
473 	vki_tcflag_t c_cflag;		/* control mode flags */
474 	vki_tcflag_t c_lflag;		/* local mode flags */
475 	vki_cc_t c_line;		/* line discipline */
476 	vki_cc_t c_cc[VKI_NCCS];	/* control characters */
477 };
478 
479 //----------------------------------------------------------------------
480 // From linux-2.6.8.1/include/asm-i386/ioctl.h
481 //----------------------------------------------------------------------
482 
483 #define _VKI_IOC_NRBITS		8
484 #define _VKI_IOC_TYPEBITS	8
485 #define _VKI_IOC_SIZEBITS	14
486 #define _VKI_IOC_DIRBITS	2
487 
488 #define _VKI_IOC_NRMASK		((1 << _VKI_IOC_NRBITS)-1)
489 #define _VKI_IOC_TYPEMASK	((1 << _VKI_IOC_TYPEBITS)-1)
490 #define _VKI_IOC_SIZEMASK	((1 << _VKI_IOC_SIZEBITS)-1)
491 #define _VKI_IOC_DIRMASK	((1 << _VKI_IOC_DIRBITS)-1)
492 
493 #define _VKI_IOC_NRSHIFT	0
494 #define _VKI_IOC_TYPESHIFT	(_VKI_IOC_NRSHIFT+_VKI_IOC_NRBITS)
495 #define _VKI_IOC_SIZESHIFT	(_VKI_IOC_TYPESHIFT+_VKI_IOC_TYPEBITS)
496 #define _VKI_IOC_DIRSHIFT	(_VKI_IOC_SIZESHIFT+_VKI_IOC_SIZEBITS)
497 
498 #define _VKI_IOC_NONE	0U
499 #define _VKI_IOC_WRITE	1U
500 #define _VKI_IOC_READ	2U
501 
502 #define _VKI_IOC(dir,type,nr,size) \
503 	(((dir)  << _VKI_IOC_DIRSHIFT) | \
504 	 ((type) << _VKI_IOC_TYPESHIFT) | \
505 	 ((nr)   << _VKI_IOC_NRSHIFT) | \
506 	 ((size) << _VKI_IOC_SIZESHIFT))
507 
508 /* used to create numbers */
509 #define _VKI_IO(type,nr)	_VKI_IOC(_VKI_IOC_NONE,(type),(nr),0)
510 #define _VKI_IOR(type,nr,size)	_VKI_IOC(_VKI_IOC_READ,(type),(nr),(_VKI_IOC_TYPECHECK(size)))
511 #define _VKI_IOW(type,nr,size)	_VKI_IOC(_VKI_IOC_WRITE,(type),(nr),(_VKI_IOC_TYPECHECK(size)))
512 #define _VKI_IOWR(type,nr,size)	_VKI_IOC(_VKI_IOC_READ|_VKI_IOC_WRITE,(type),(nr),(_VKI_IOC_TYPECHECK(size)))
513 
514 /* used to decode ioctl numbers.. */
515 #define _VKI_IOC_DIR(nr)	(((nr) >> _VKI_IOC_DIRSHIFT) & _VKI_IOC_DIRMASK)
516 #define _VKI_IOC_TYPE(nr)	(((nr) >> _VKI_IOC_TYPESHIFT) & _VKI_IOC_TYPEMASK)
517 #define _VKI_IOC_NR(nr)		(((nr) >> _VKI_IOC_NRSHIFT) & _VKI_IOC_NRMASK)
518 #define _VKI_IOC_SIZE(nr)	(((nr) >> _VKI_IOC_SIZESHIFT) & _VKI_IOC_SIZEMASK)
519 
520 //----------------------------------------------------------------------
521 // From linux-2.6.8.1/include/asm-i386/ioctls.h
522 //----------------------------------------------------------------------
523 
524 #define VKI_TCGETS	0x5401
525 #define VKI_TCSETS	0x5402 /* Clashes with SNDCTL_TMR_START sound ioctl */
526 #define VKI_TCSETSW	0x5403
527 #define VKI_TCSETSF	0x5404
528 #define VKI_TCGETA	0x5405
529 #define VKI_TCSETA	0x5406
530 #define VKI_TCSETAW	0x5407
531 #define VKI_TCSETAF	0x5408
532 #define VKI_TCSBRK	0x5409
533 #define VKI_TCXONC	0x540A
534 #define VKI_TCFLSH	0x540B
535 #define VKI_TIOCSCTTY	0x540E
536 #define VKI_TIOCGPGRP	0x540F
537 #define VKI_TIOCSPGRP	0x5410
538 #define VKI_TIOCOUTQ	0x5411
539 #define VKI_TIOCGWINSZ	0x5413
540 #define VKI_TIOCSWINSZ	0x5414
541 #define VKI_TIOCMGET	0x5415
542 #define VKI_TIOCMBIS	0x5416
543 #define VKI_TIOCMBIC	0x5417
544 #define VKI_TIOCMSET	0x5418
545 #define VKI_FIONREAD	0x541B
546 #define VKI_TIOCLINUX	0x541C
547 #define VKI_FIONBIO	0x5421
548 #define VKI_TIOCNOTTY	0x5422
549 #define VKI_TCSBRKP	0x5425	/* Needed for POSIX tcsendbreak() */
550 #define VKI_TIOCGPTN	_VKI_IOR('T',0x30, unsigned int) /* Get Pty Number (of pty-mux device) */
551 #define VKI_TIOCSPTLCK	_VKI_IOW('T',0x31, int)  /* Lock/unlock Pty */
552 
553 #define VKI_FIONCLEX    0x5450
554 #define VKI_FIOCLEX     0x5451
555 #define VKI_FIOASYNC	0x5452
556 #define VKI_TIOCSERGETLSR   0x5459 /* Get line status register */
557 
558 #define VKI_TIOCGICOUNT	0x545D	/* read serial port inline interrupt counts */
559 
560 //----------------------------------------------------------------------
561 // From linux-2.6.8.1/include/asm-i386/poll.h
562 //----------------------------------------------------------------------
563 
564 /* These are specified by iBCS2 */
565 #define VKI_POLLIN		0x0001
566 
567 struct vki_pollfd {
568 	int fd;
569 	short events;
570 	short revents;
571 };
572 
573 //----------------------------------------------------------------------
574 // From linux-2.6.8.1/include/asm-i386/user.h
575 //----------------------------------------------------------------------
576 
577 struct vki_user_i387_struct {
578 	long	cwd;
579 	long	swd;
580 	long	twd;
581 	long	fip;
582 	long	fcs;
583 	long	foo;
584 	long	fos;
585 	long	st_space[20];	/* 8*10 bytes for each FP-reg = 80 bytes */
586 };
587 
588 struct vki_user_fxsr_struct {
589 	unsigned short	cwd;
590 	unsigned short	swd;
591 	unsigned short	twd;
592 	unsigned short	fop;
593 	long	fip;
594 	long	fcs;
595 	long	foo;
596 	long	fos;
597 	long	mxcsr;
598 	long	reserved;
599 	long	st_space[32];	/* 8*16 bytes for each FP-reg = 128 bytes */
600 	long	xmm_space[32];	/* 8*16 bytes for each XMM-reg = 128 bytes */
601 	long	padding[56];
602 };
603 
604 /*
605  * This is the old layout of "struct pt_regs", and
606  * is still the layout used by user mode (the new
607  * pt_regs doesn't have all registers as the kernel
608  * doesn't use the extra segment registers)
609  */
610 struct vki_user_regs_struct {
611 	long ebx, ecx, edx, esi, edi, ebp, eax;
612 	unsigned short ds, __ds, es, __es;
613 	unsigned short fs, __fs, gs, __gs;
614 	long orig_eax, eip;
615 	unsigned short cs, __cs;
616 	long eflags, esp;
617 	unsigned short ss, __ss;
618 };
619 
620 //----------------------------------------------------------------------
621 // From linux-2.6.8.1/include/asm-i386/elf.h
622 //----------------------------------------------------------------------
623 
624 typedef unsigned long vki_elf_greg_t;
625 
626 #define VKI_ELF_NGREG (sizeof (struct vki_user_regs_struct) / sizeof(vki_elf_greg_t))
627 typedef vki_elf_greg_t vki_elf_gregset_t[VKI_ELF_NGREG];
628 
629 typedef struct vki_user_i387_struct vki_elf_fpregset_t;
630 typedef struct vki_user_fxsr_struct vki_elf_fpxregset_t;
631 
632 #define VKI_AT_SYSINFO		32
633 
634 //----------------------------------------------------------------------
635 // From linux-2.6.8.1/include/asm-i386/ucontext.h
636 //----------------------------------------------------------------------
637 
638 struct vki_ucontext {
639 	unsigned long		uc_flags;
640 	struct vki_ucontext    *uc_link;
641 	vki_stack_t		uc_stack;
642 	struct vki_sigcontext	uc_mcontext;
643 	vki_sigset_t		uc_sigmask;	/* mask last for extensibility */
644 };
645 
646 //----------------------------------------------------------------------
647 // From linux-2.6.8.1/include/asm-i386/segment.h
648 //----------------------------------------------------------------------
649 
650 #define VKI_GDT_ENTRY_TLS_ENTRIES	3
651 #define VKI_GDT_ENTRY_TLS_MIN	6
652 #define VKI_GDT_ENTRY_TLS_MAX 	(VKI_GDT_ENTRY_TLS_MIN + VKI_GDT_ENTRY_TLS_ENTRIES - 1)
653 
654 //----------------------------------------------------------------------
655 // From linux-2.6.8.1/include/asm-i386/ldt.h
656 //----------------------------------------------------------------------
657 
658 /* [[Nb: This is the structure passed to the modify_ldt syscall.  Just so as
659    to confuse and annoy everyone, this is _not_ the same as an
660    VgLdtEntry and has to be translated into such.  The logic for doing
661    so, in vg_ldt.c, is copied from the kernel sources.]] */
662 struct vki_user_desc {
663 	unsigned int  entry_number;
664 	unsigned long base_addr;
665 	unsigned int  limit;
666 	unsigned int  seg_32bit:1;
667 	unsigned int  contents:2;
668 	unsigned int  read_exec_only:1;
669 	unsigned int  limit_in_pages:1;
670 	unsigned int  seg_not_present:1;
671 	unsigned int  useable:1;
672         // [[Nb: this field is not in the kernel sources, but it has always
673         // been in the Valgrind sources so I will keep it there in case it's
674         // important... this is an x86-defined data structure so who
675         // knows;  maybe it's important to set this field to zero at some
676         // point.  --njn]]
677 	unsigned int  reserved:25;
678 };
679 
680 // [[Nb: for our convenience within Valgrind, use a more specific name]]
681 typedef struct vki_user_desc vki_modify_ldt_t;
682 
683 //----------------------------------------------------------------------
684 // From linux-2.6.8.1/include/asm-i386/ipcbuf.h
685 //----------------------------------------------------------------------
686 
687 struct vki_ipc64_perm
688 {
689 	__vki_kernel_key_t	key;
690 	__vki_kernel_uid32_t	uid;
691 	__vki_kernel_gid32_t	gid;
692 	__vki_kernel_uid32_t	cuid;
693 	__vki_kernel_gid32_t	cgid;
694 	__vki_kernel_mode_t	mode;
695 	unsigned short		__pad1;
696 	unsigned short		seq;
697 	unsigned short		__pad2;
698 	unsigned long		__unused1;
699 	unsigned long		__unused2;
700 };
701 
702 //----------------------------------------------------------------------
703 // From linux-2.6.8.1/include/asm-i386/sembuf.h
704 //----------------------------------------------------------------------
705 
706 struct vki_semid64_ds {
707 	struct vki_ipc64_perm sem_perm;		/* permissions .. see ipc.h */
708 	__vki_kernel_time_t	sem_otime;		/* last semop time */
709 	unsigned long	__unused1;
710 	__vki_kernel_time_t	sem_ctime;		/* last change time */
711 	unsigned long	__unused2;
712 	unsigned long	sem_nsems;		/* no. of semaphores in array */
713 	unsigned long	__unused3;
714 	unsigned long	__unused4;
715 };
716 
717 //----------------------------------------------------------------------
718 // From linux-2.6.8.1/include/asm-i386/msgbuf.h
719 //----------------------------------------------------------------------
720 
721 struct vki_msqid64_ds {
722 	struct vki_ipc64_perm msg_perm;
723 	__vki_kernel_time_t msg_stime;	/* last msgsnd time */
724 	unsigned long	__unused1;
725 	__vki_kernel_time_t msg_rtime;	/* last msgrcv time */
726 	unsigned long	__unused2;
727 	__vki_kernel_time_t msg_ctime;	/* last change time */
728 	unsigned long	__unused3;
729 	unsigned long  msg_cbytes;	/* current number of bytes on queue */
730 	unsigned long  msg_qnum;	/* number of messages in queue */
731 	unsigned long  msg_qbytes;	/* max number of bytes on queue */
732 	__vki_kernel_pid_t msg_lspid;	/* pid of last msgsnd */
733 	__vki_kernel_pid_t msg_lrpid;	/* last receive pid */
734 	unsigned long  __unused4;
735 	unsigned long  __unused5;
736 };
737 
738 //----------------------------------------------------------------------
739 // From linux-2.6.8.1/include/asm-i386/ipc.h
740 //----------------------------------------------------------------------
741 
742 struct vki_ipc_kludge {
743 	struct vki_msgbuf __user *msgp;
744 	long msgtyp;
745 };
746 
747 #define VKI_SEMOP		 1
748 #define VKI_SEMGET		 2
749 #define VKI_SEMCTL		 3
750 #define VKI_SEMTIMEDOP	 	 4
751 #define VKI_MSGSND		11
752 #define VKI_MSGRCV		12
753 #define VKI_MSGGET		13
754 #define VKI_MSGCTL		14
755 #define VKI_SHMAT		21
756 #define VKI_SHMDT		22
757 #define VKI_SHMGET		23
758 #define VKI_SHMCTL		24
759 
760 
761 //----------------------------------------------------------------------
762 // From linux-2.6.8.1/include/asm-i386/shmbuf.h
763 //----------------------------------------------------------------------
764 
765 struct vki_shmid64_ds {
766 	struct vki_ipc64_perm	shm_perm;	/* operation perms */
767 	vki_size_t		shm_segsz;	/* size of segment (bytes) */
768 	__vki_kernel_time_t	shm_atime;	/* last attach time */
769 	unsigned long		__unused1;
770 	__vki_kernel_time_t	shm_dtime;	/* last detach time */
771 	unsigned long		__unused2;
772 	__vki_kernel_time_t	shm_ctime;	/* last change time */
773 	unsigned long		__unused3;
774 	__vki_kernel_pid_t	shm_cpid;	/* pid of creator */
775 	__vki_kernel_pid_t	shm_lpid;	/* pid of last operator */
776 	unsigned long		shm_nattch;	/* no. of current attaches */
777 	unsigned long		__unused4;
778 	unsigned long		__unused5;
779 };
780 
781 struct vki_shminfo64 {
782 	unsigned long	shmmax;
783 	unsigned long	shmmin;
784 	unsigned long	shmmni;
785 	unsigned long	shmseg;
786 	unsigned long	shmall;
787 	unsigned long	__unused1;
788 	unsigned long	__unused2;
789 	unsigned long	__unused3;
790 	unsigned long	__unused4;
791 };
792 
793 //----------------------------------------------------------------------
794 // DRM ioctls
795 //----------------------------------------------------------------------
796 
797 // jrs 20050207: where did all this stuff come from?  Is it really
798 // i386 specific, or should it go into the linux-generic category?
799 //struct vki_drm_buf_pub {
800 //	Int		  idx;	       /**< Index into the master buffer list */
801 //	Int		  total;       /**< Buffer size */
802 //	Int		  used;	       /**< Amount of buffer in use (for DMA) */
803 //	void	  __user *address;     /**< Address of buffer */
804 //};
805 //
806 //struct vki_drm_buf_map {
807 //	Int	      count;		/**< Length of the buffer list */
808 //	void	      __user *virtual;	/**< Mmap'd area in user-virtual */
809 //	struct vki_drm_buf_pub __user *list;	/**< Buffer information */
810 //};
811 //
812 ///* We need to pay attention to this, because it mmaps memory */
813 //#define VKI_DRM_IOCTL_MAP_BUFS		_VKI_IOWR('d', 0x19, struct vki_drm_buf_map)
814 
815 //----------------------------------------------------------------------
816 // From linux-2.6.9/include/asm-i386/ptrace.h
817 //----------------------------------------------------------------------
818 
819 #define VKI_PTRACE_GETREGS            12
820 #define VKI_PTRACE_SETREGS            13
821 #define VKI_PTRACE_GETFPREGS          14
822 #define VKI_PTRACE_SETFPREGS          15
823 #define VKI_PTRACE_GETFPXREGS         18
824 #define VKI_PTRACE_SETFPXREGS         19
825 #define VKI_PTRACE_GET_THREAD_AREA    25
826 #define VKI_PTRACE_SET_THREAD_AREA    26
827 
828 //----------------------------------------------------------------------
829 // From linux-2.6.15.4/include/asm-i386/vm86.h
830 //----------------------------------------------------------------------
831 
832 #define VKI_VM86_PLUS_INSTALL_CHECK	0
833 #define VKI_VM86_ENTER			1
834 #define VKI_VM86_ENTER_NO_BYPASS	2
835 #define	VKI_VM86_REQUEST_IRQ		3
836 #define VKI_VM86_FREE_IRQ		4
837 #define VKI_VM86_GET_IRQ_BITS		5
838 #define VKI_VM86_GET_AND_RESET_IRQ	6
839 
840 struct vki_vm86_regs {
841 /*
842  * normal regs, with special meaning for the segment descriptors..
843  */
844 	long ebx;
845 	long ecx;
846 	long edx;
847 	long esi;
848 	long edi;
849 	long ebp;
850 	long eax;
851 	long __null_ds;
852 	long __null_es;
853 	long __null_fs;
854 	long __null_gs;
855 	long orig_eax;
856 	long eip;
857 	unsigned short cs, __csh;
858 	long eflags;
859 	long esp;
860 	unsigned short ss, __ssh;
861 /*
862  * these are specific to v86 mode:
863  */
864 	unsigned short es, __esh;
865 	unsigned short ds, __dsh;
866 	unsigned short fs, __fsh;
867 	unsigned short gs, __gsh;
868 };
869 
870 struct vki_revectored_struct {
871 	unsigned long __map[8];			/* 256 bits */
872 };
873 
874 struct vki_vm86_struct {
875 	struct vki_vm86_regs regs;
876 	unsigned long flags;
877 	unsigned long screen_bitmap;
878 	unsigned long cpu_type;
879 	struct vki_revectored_struct int_revectored;
880 	struct vki_revectored_struct int21_revectored;
881 };
882 
883 struct vki_vm86plus_info_struct {
884 	unsigned long force_return_for_pic:1;
885 	unsigned long vm86dbg_active:1;       /* for debugger */
886 	unsigned long vm86dbg_TFpendig:1;     /* for debugger */
887 	unsigned long unused:28;
888 	unsigned long is_vm86pus:1;	      /* for vm86 internal use */
889 	unsigned char vm86dbg_intxxtab[32];   /* for debugger */
890 };
891 
892 struct vki_vm86plus_struct {
893 	struct vki_vm86_regs regs;
894 	unsigned long flags;
895 	unsigned long screen_bitmap;
896 	unsigned long cpu_type;
897 	struct vki_revectored_struct int_revectored;
898 	struct vki_revectored_struct int21_revectored;
899 	struct vki_vm86plus_info_struct vm86plus;
900 };
901 
902 //----------------------------------------------------------------------
903 // From linux-2.6.8.1/include/asm-generic/errno.h
904 //----------------------------------------------------------------------
905 
906 #define	VKI_ENOSYS       38  /* Function not implemented */
907 #define	VKI_EOVERFLOW    75  /* Value too large for defined data type */
908 
909 //----------------------------------------------------------------------
910 // From linux-3.19.0/include/uapi/asm-generic/ioctls.h
911 //----------------------------------------------------------------------
912 
913 #define VKI_TIOCGSERIAL     0x541E
914 #define VKI_TIOCSSERIAL     0x541F
915 
916 //----------------------------------------------------------------------
917 // And that's it!
918 //----------------------------------------------------------------------
919 
920 #endif // __VKI_X86_LINUX_H
921 
922 /*--------------------------------------------------------------------*/
923 /*--- end                                                          ---*/
924 /*--------------------------------------------------------------------*/
925