vki-x86-linux.h revision a69c2def56fbfa9212f804b265ec2650b6e97c23
173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
273b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--------------------------------------------------------------------*/
34de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn/*--- x86/Linux-specific kernel interface.         vki-x86-linux.h ---*/
473b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--------------------------------------------------------------------*/
573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
673b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*
7b9c427c63a278cc612ae0ec573be7bb1abaa447fnjn   This file is part of Valgrind, a dynamic binary instrumentation
8b9c427c63a278cc612ae0ec573be7bb1abaa447fnjn   framework.
973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
109eecbbb9a9cbbd30b903c09a9e04d8efc20bda33sewardj   Copyright (C) 2000-2010 Julian Seward
1173b526fb4af0f60634f0078583d92b931d5c0eebnethercote      jseward@acm.org
1273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
1373b526fb4af0f60634f0078583d92b931d5c0eebnethercote   This program is free software; you can redistribute it and/or
1473b526fb4af0f60634f0078583d92b931d5c0eebnethercote   modify it under the terms of the GNU General Public License as
1573b526fb4af0f60634f0078583d92b931d5c0eebnethercote   published by the Free Software Foundation; either version 2 of the
1673b526fb4af0f60634f0078583d92b931d5c0eebnethercote   License, or (at your option) any later version.
1773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
1873b526fb4af0f60634f0078583d92b931d5c0eebnethercote   This program is distributed in the hope that it will be useful, but
1973b526fb4af0f60634f0078583d92b931d5c0eebnethercote   WITHOUT ANY WARRANTY; without even the implied warranty of
2073b526fb4af0f60634f0078583d92b931d5c0eebnethercote   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
2173b526fb4af0f60634f0078583d92b931d5c0eebnethercote   General Public License for more details.
2273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
2373b526fb4af0f60634f0078583d92b931d5c0eebnethercote   You should have received a copy of the GNU General Public License
2473b526fb4af0f60634f0078583d92b931d5c0eebnethercote   along with this program; if not, write to the Free Software
2573b526fb4af0f60634f0078583d92b931d5c0eebnethercote   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
2673b526fb4af0f60634f0078583d92b931d5c0eebnethercote   02111-1307, USA.
2773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
2873b526fb4af0f60634f0078583d92b931d5c0eebnethercote   The GNU General Public License is contained in the file COPYING.
2973b526fb4af0f60634f0078583d92b931d5c0eebnethercote*/
3073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
314de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#ifndef __VKI_X86_LINUX_H
324de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#define __VKI_X86_LINUX_H
3373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
3473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// x86 is little-endian.
3573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_LITTLE_ENDIAN  1
3673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
3773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
3873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/types.h
3973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
4073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
4173b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef unsigned char __vki_u8;
4273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
4373b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __signed__ short __vki_s16;
4473b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef unsigned short __vki_u16;
4573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
461aa57373be5343c365ee6b480e205abc16008402tomtypedef __signed__ int __vki_s32;
4773b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef unsigned int __vki_u32;
4873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
4973b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __signed__ long long __vki_s64;
5073b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef unsigned long long __vki_u64;
5173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
5273b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef unsigned short vki_u16;
5373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
54660e4eefc61fbfa322277ab4afaa6ae4e0104ab7nethercotetypedef unsigned int vki_u32;
55660e4eefc61fbfa322277ab4afaa6ae4e0104ab7nethercote
5673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
5773b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/page.h
5873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
5973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
6073b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* PAGE_SHIFT determines the page size */
6173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PAGE_SHIFT	12
6273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PAGE_SIZE	(1UL << VKI_PAGE_SHIFT)
63e66f2e09ec1aa9bab7a0fd6b02a6a6150ea85190sewardj#define VKI_MAX_PAGE_SHIFT	VKI_PAGE_SHIFT
64e66f2e09ec1aa9bab7a0fd6b02a6a6150ea85190sewardj#define VKI_MAX_PAGE_SIZE	VKI_PAGE_SIZE
6573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
6673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
67a69c2def56fbfa9212f804b265ec2650b6e97c23sewardj// From linux-2.6.35.4/arch/x86/include/asm/shmparam.h
68a69c2def56fbfa9212f804b265ec2650b6e97c23sewardj//----------------------------------------------------------------------
69a69c2def56fbfa9212f804b265ec2650b6e97c23sewardj
70a69c2def56fbfa9212f804b265ec2650b6e97c23sewardj#define VKI_SHMLBA  VKI_PAGE_SIZE
71a69c2def56fbfa9212f804b265ec2650b6e97c23sewardj
72a69c2def56fbfa9212f804b265ec2650b6e97c23sewardj//----------------------------------------------------------------------
7373b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/signal.h
7473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
7573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
7673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MINSIGSTKSZ	2048
7773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
7873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIG_BLOCK          0	/* for blocking signals */
7973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIG_UNBLOCK        1	/* for unblocking signals */
8073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIG_SETMASK        2	/* for setting the signal mask */
8173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
8273b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Type of a signal handler.  */
8373b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef void __vki_signalfn_t(int);
8473b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_signalfn_t __user *__vki_sighandler_t;
8573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
8673b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef void __vki_restorefn_t(void);
8773b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_restorefn_t __user *__vki_sigrestore_t;
8873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
8973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIG_DFL	((__vki_sighandler_t)0)	/* default signal handling */
9073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIG_IGN	((__vki_sighandler_t)1)	/* ignore signal */
9173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
9273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_NSIG	64
9373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_NSIG_BPW	32
9473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_NSIG_WORDS	(_VKI_NSIG / _VKI_NSIG_BPW)
9573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
9617258dc59ba69b305064bec5338eeb440911e5f6nethercotetypedef unsigned long vki_old_sigset_t;		/* at least 32 bits */
9717258dc59ba69b305064bec5338eeb440911e5f6nethercote
9873b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct {
9973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long sig[_VKI_NSIG_WORDS];
10073b526fb4af0f60634f0078583d92b931d5c0eebnethercote} vki_sigset_t;
10173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
10273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGHUP		 1
10373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGINT		 2
10473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGQUIT		 3
10573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGILL		 4
10673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGTRAP		 5
10773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGABRT		 6
10873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#define VKI_SIGIOT		 6
10973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGBUS		 7
11073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGFPE		 8
11173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGKILL		 9
11273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGUSR1		10
11373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGSEGV		11
11473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGUSR2		12
11573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGPIPE		13
11673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGALRM		14
11773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGTERM		15
11873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGSTKFLT		16
11973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGCHLD		17
12073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGCONT		18
12173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGSTOP		19
12273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGTSTP		20
12373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGTTIN		21
12473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGTTOU		22
12573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGURG		23
12673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGXCPU		24
12773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGXFSZ		25
12873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGVTALRM		26
12973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGPROF		27
13073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGWINCH		28
13173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGIO		29
13273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGPWR		30
13373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGSYS		31
13473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_SIGUNUSED		31
13573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
13673b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* These should not be considered constants from userland.  */
13773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGRTMIN	32
13873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[This was (_NSIG-1) in 2.4.X... not sure if it matters.]]
13973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIGRTMAX	_VKI_NSIG
14073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
14173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SA_NOCLDSTOP	0x00000001u
14273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SA_NOCLDWAIT	0x00000002u
14373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SA_SIGINFO		0x00000004u
14473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SA_ONSTACK		0x08000000u
14573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SA_RESTART		0x10000000u
14673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SA_NODEFER		0x40000000u
14773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SA_RESETHAND	0x80000000u
14873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
14973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SA_NOMASK		VKI_SA_NODEFER
15073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SA_ONESHOT		VKI_SA_RESETHAND
15173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#define VKI_SA_INTERRUPT	0x20000000 /* dummy -- ignored */
15273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
15373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SA_RESTORER		0x04000000
15473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
15573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SS_ONSTACK	1
15673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SS_DISABLE	2
15773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
158cda2f0fbda4c4b2644babc830244be8aed95de1dnjn/* These are 'legacy' sigactions in which the size of sa_mask is fixed
159cda2f0fbda4c4b2644babc830244be8aed95de1dnjn   (cannot be expanded at any future point) because it is sandwiched
160cda2f0fbda4c4b2644babc830244be8aed95de1dnjn   between two other fields.
161cda2f0fbda4c4b2644babc830244be8aed95de1dnjn   (there is identical kludgery in vki-ppc32-linux.h) */
162686b5db44f043ebb74f3db0fa3b803de3f313b60nethercotestruct vki_old_sigaction {
16373b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // [[Nb: a 'k' prefix is added to "sa_handler" because
16473b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // bits/sigaction.h (which gets dragged in somehow via signal.h)
16573b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // #defines it as something else.  Since that is done for glibc's
16673b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // purposes, which we don't care about here, we use our own name.]]
167686b5db44f043ebb74f3db0fa3b803de3f313b60nethercote        __vki_sighandler_t ksa_handler;
168686b5db44f043ebb74f3db0fa3b803de3f313b60nethercote        vki_old_sigset_t sa_mask;
169686b5db44f043ebb74f3db0fa3b803de3f313b60nethercote        unsigned long sa_flags;
170686b5db44f043ebb74f3db0fa3b803de3f313b60nethercote        __vki_sigrestore_t sa_restorer;
171686b5db44f043ebb74f3db0fa3b803de3f313b60nethercote};
172686b5db44f043ebb74f3db0fa3b803de3f313b60nethercote
173cda2f0fbda4c4b2644babc830244be8aed95de1dnjnstruct vki_sigaction_base {
174686b5db44f043ebb74f3db0fa3b803de3f313b60nethercote        // [[See comment about extra 'k' above]]
17573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_sighandler_t ksa_handler;
17673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long sa_flags;
17773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_sigrestore_t sa_restorer;
17873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_sigset_t sa_mask;		/* mask last for extensibility */
17973b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
18073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
181cda2f0fbda4c4b2644babc830244be8aed95de1dnjn/* On Linux we use the same type for passing sigactions to
182cda2f0fbda4c4b2644babc830244be8aed95de1dnjn   and from the kernel.  Hence: */
183cda2f0fbda4c4b2644babc830244be8aed95de1dnjntypedef  struct vki_sigaction_base  vki_sigaction_toK_t;
184cda2f0fbda4c4b2644babc830244be8aed95de1dnjntypedef  struct vki_sigaction_base  vki_sigaction_fromK_t;
185cda2f0fbda4c4b2644babc830244be8aed95de1dnjn
186cda2f0fbda4c4b2644babc830244be8aed95de1dnjn
18773b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct vki_sigaltstack {
18873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void __user *ss_sp;
18973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int ss_flags;
19073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_size_t ss_size;
19173b526fb4af0f60634f0078583d92b931d5c0eebnethercote} vki_stack_t;
19273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
19373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
19473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/sigcontext.h
19573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
19673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
19773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct _vki_fpreg {
19873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short significand[4];
19973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short exponent;
20073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
20173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
20273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct _vki_fpxreg {
20373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short significand[4];
20473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short exponent;
20573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short padding[3];
20673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
20773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
20873b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct _vki_xmmreg {
20973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long element[4];
21073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
21173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
21273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct _vki_fpstate {
21373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	/* Regular FPU environment */
21473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long 	cw;
21573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	sw;
21673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	tag;
21773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	ipoff;
21873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	cssel;
21973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	dataoff;
22073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	datasel;
22173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct _vki_fpreg	_st[8];
22273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	status;
22373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	magic;		/* 0xffff = regular FPU data only */
22473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
22573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	/* FXSR FPU environment */
22673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	_fxsr_env[6];	/* FXSR FPU env is ignored */
22773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	mxcsr;
22873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	reserved;
22973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct _vki_fpxreg	_fxsr_st[8];	/* FXSR FPU reg data is ignored */
23073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct _vki_xmmreg	_xmm[8];
23173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	padding[56];
23273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
23373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
23473b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sigcontext {
23573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short gs, __gsh;
23673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short fs, __fsh;
23773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short es, __esh;
23873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short ds, __dsh;
23973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long edi;
24073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long esi;
24173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long ebp;
24273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long esp;
24373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long ebx;
24473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long edx;
24573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long ecx;
24673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long eax;
24773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long trapno;
24873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long err;
24973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long eip;
25073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short cs, __csh;
25173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long eflags;
25273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long esp_at_signal;
25373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short ss, __ssh;
25473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct _vki_fpstate __user * fpstate;
25573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long oldmask;
25673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long cr2;
25773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
25873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
25973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
26073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/mman.h
26173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
26273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
263b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_PROT_NONE	0x0		/* No page permissions */
26473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PROT_READ	0x1		/* page can be read */
26573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PROT_WRITE	0x2		/* page can be written */
26673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PROT_EXEC	0x4		/* page can be executed */
26765505193b8d9c8f36f3df6c5d6a8e1d475bb37cbtom#define VKI_PROT_GROWSDOWN	0x01000000	/* mprotect flag: extend change to start of growsdown vma */
26865505193b8d9c8f36f3df6c5d6a8e1d475bb37cbtom#define VKI_PROT_GROWSUP	0x02000000	/* mprotect flag: extend change to end of growsup vma */
26973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
27073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MAP_SHARED	0x01		/* Share changes */
27173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MAP_PRIVATE	0x02		/* Changes are private */
27273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#define VKI_MAP_TYPE	0x0f		/* Mask for type of mapping */
27373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MAP_FIXED	0x10		/* Interpret addr exactly */
27473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MAP_ANONYMOUS	0x20	/* don't use a file */
275b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_MAP_NORESERVE	0x4000		/* don't check for reservations */
27673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
27773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
27873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/fcntl.h
27973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
28073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
28173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_O_RDONLY	     00
28273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_O_WRONLY	     01
283b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_O_RDWR	     02
28473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_O_CREAT	   0100	/* not fcntl */
28573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_O_EXCL	   0200	/* not fcntl */
28673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_O_TRUNC	  01000	/* not fcntl */
2878467291c755c4ee291f7ad676b19c3b0392c675fnethercote#define VKI_O_APPEND	  02000
28873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_O_NONBLOCK	  04000
28928d2e641964eb9342ff012e2314e22b2094606c0njn#define VKI_O_LARGEFILE	0100000
29073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
291c9d66c0debd4d9d7882fd7ba874a37429bbcc170dirk#define VKI_AT_FDCWD            -100
292c9d66c0debd4d9d7882fd7ba874a37429bbcc170dirk
29373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_F_DUPFD		0	/* dup */
294cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn#define VKI_F_GETFD		1	/* get close_on_exec */
29573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_F_SETFD		2	/* set/clear close_on_exec */
29673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_F_GETFL		3	/* get file->f_flags */
29773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_F_SETFL		4	/* set file->f_flags */
298cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn#define VKI_F_GETLK		5
299cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn#define VKI_F_SETLK		6
30073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_F_SETLKW		7
30173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
302cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn#define VKI_F_SETOWN		8	/*  for sockets. */
303cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn#define VKI_F_GETOWN		9	/*  for sockets. */
304cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn#define VKI_F_SETSIG		10	/*  for sockets. */
305cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn#define VKI_F_GETSIG		11	/*  for sockets. */
306cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn
307cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn#define VKI_F_GETLK64		12	/*  using 'struct flock64' */
308cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn#define VKI_F_SETLK64		13
30973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_F_SETLKW64		14
31073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
31173b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* for F_[GET|SET]FL */
31273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FD_CLOEXEC	1	/* actually anything with low bit set goes */
31373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
314cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn#define VKI_F_LINUX_SPECIFIC_BASE	1024
31573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
31673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
31773b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/resource.h
31873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
31973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
32073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RLIMIT_DATA		2	/* max data size */
32173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RLIMIT_STACK	3	/* max stack size */
32273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RLIMIT_CORE		4	/* max core file size */
32373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RLIMIT_NOFILE	7	/* max number of open files */
32473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
32573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
32673b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/socket.h
32773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
32873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
32973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SOL_SOCKET	1
33073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
33173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SO_TYPE	3
33273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
33373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
33473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/sockios.h
33573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
33673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
337a2ec4f53cfbf020c69aa8faae53a1435b29a55f2tom#define VKI_SIOCSPGRP		0x8902
338a2ec4f53cfbf020c69aa8faae53a1435b29a55f2tom#define VKI_SIOCGPGRP		0x8904
339a2ec4f53cfbf020c69aa8faae53a1435b29a55f2tom#define VKI_SIOCGSTAMP		0x8906		/* Get stamp (timeval) */
340a2ec4f53cfbf020c69aa8faae53a1435b29a55f2tom#define VKI_SIOCGSTAMPNS	0x8907		/* Get stamp (timespec) */
34173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
34273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
34373b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/stat.h
34473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
34573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
34673b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_stat {
34773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  st_dev;
34873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  st_ino;
34973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short st_mode;
35073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short st_nlink;
35173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short st_uid;
35273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short st_gid;
35373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  st_rdev;
35473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  st_size;
35573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  st_blksize;
35673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  st_blocks;
35773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  st_atime;
35873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  st_atime_nsec;
35973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  st_mtime;
36073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  st_mtime_nsec;
36173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  st_ctime;
36273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  st_ctime_nsec;
36373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  __unused4;
36473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  __unused5;
36573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
36673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
36773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_stat64 {
36873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long long	st_dev;
36973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char	__pad0[4];
37073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
37173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define STAT64_HAS_BROKEN_ST_INO	1
37273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	__st_ino;
37373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
37473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int	st_mode;
37573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int	st_nlink;
37673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
37773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	st_uid;
37873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	st_gid;
37973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
38073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long long	st_rdev;
38173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char	__pad3[4];
38273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
38373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long long	st_size;
38473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	st_blksize;
38573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
38673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	st_blocks;	/* Number 512-byte blocks allocated. */
38773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	__pad4;		/* future possible st_blocks high bits */
38873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
38973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	st_atime;
39073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	st_atime_nsec;
39173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
39273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	st_mtime;
39373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int	st_mtime_nsec;
39473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
39573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	st_ctime;
39673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	st_ctime_nsec;
39773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
39873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long long	st_ino;
39973b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
40073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
40173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
40273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/statfs.h
40373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
40473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
405ca0518df66f8c3375a860f1a55a51f18e2a16c44njn// [[Nb: asm-i386/statfs.h just #include asm-generic/statfs.h directly]]
40673b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_statfs {
40773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 f_type;
40873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 f_bsize;
40973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 f_blocks;
41073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 f_bfree;
41173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 f_bavail;
41273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 f_files;
41373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 f_ffree;
41473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_fsid_t f_fsid;
41573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 f_namelen;
41673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 f_frsize;
41773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 f_spare[5];
41873b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
41973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
42073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
42173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/termios.h
42273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
42373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
42473b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_winsize {
42573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short ws_row;
42673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short ws_col;
42773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short ws_xpixel;
42873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short ws_ypixel;
42973b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
43073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
43173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_NCC 8
43273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_termio {
43373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short c_iflag;		/* input mode flags */
43473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short c_oflag;		/* output mode flags */
43573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short c_cflag;		/* control mode flags */
43673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short c_lflag;		/* local mode flags */
43773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char c_line;		/* line discipline */
43873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char c_cc[VKI_NCC];	/* control characters */
43973b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
44073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
44173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
44273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
44373b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/termbits.h
44473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
44573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
446017e5833f60c5e41d1c0a61a8953fc7a23977efenethercotetypedef unsigned char   vki_cc_t;
447017e5833f60c5e41d1c0a61a8953fc7a23977efenethercotetypedef unsigned int    vki_tcflag_t;
448017e5833f60c5e41d1c0a61a8953fc7a23977efenethercote
449017e5833f60c5e41d1c0a61a8953fc7a23977efenethercote#define VKI_NCCS 19
450017e5833f60c5e41d1c0a61a8953fc7a23977efenethercotestruct vki_termios {
451017e5833f60c5e41d1c0a61a8953fc7a23977efenethercote	vki_tcflag_t c_iflag;		/* input mode flags */
452017e5833f60c5e41d1c0a61a8953fc7a23977efenethercote	vki_tcflag_t c_oflag;		/* output mode flags */
453017e5833f60c5e41d1c0a61a8953fc7a23977efenethercote	vki_tcflag_t c_cflag;		/* control mode flags */
454017e5833f60c5e41d1c0a61a8953fc7a23977efenethercote	vki_tcflag_t c_lflag;		/* local mode flags */
455017e5833f60c5e41d1c0a61a8953fc7a23977efenethercote	vki_cc_t c_line;		/* line discipline */
456017e5833f60c5e41d1c0a61a8953fc7a23977efenethercote	vki_cc_t c_cc[VKI_NCCS];	/* control characters */
457017e5833f60c5e41d1c0a61a8953fc7a23977efenethercote};
45873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
45973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
46073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/ioctl.h
46173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
46273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
463c616819253fcf211745060b2be26076174b1df19njn#define _VKI_IOC_NRBITS		8
46473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC_TYPEBITS	8
46573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC_SIZEBITS	14
46673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC_DIRBITS	2
46773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
468b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define _VKI_IOC_NRMASK		((1 << _VKI_IOC_NRBITS)-1)
469b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define _VKI_IOC_TYPEMASK	((1 << _VKI_IOC_TYPEBITS)-1)
47073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC_SIZEMASK	((1 << _VKI_IOC_SIZEBITS)-1)
47173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC_DIRMASK	((1 << _VKI_IOC_DIRBITS)-1)
47273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
47373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC_NRSHIFT	0
47473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC_TYPESHIFT	(_VKI_IOC_NRSHIFT+_VKI_IOC_NRBITS)
47573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC_SIZESHIFT	(_VKI_IOC_TYPESHIFT+_VKI_IOC_TYPEBITS)
47673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC_DIRSHIFT	(_VKI_IOC_SIZESHIFT+_VKI_IOC_SIZEBITS)
47773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
47873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC_NONE	0U
47973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC_WRITE	1U
48073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC_READ	2U
48173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
48273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC(dir,type,nr,size) \
48373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	(((dir)  << _VKI_IOC_DIRSHIFT) | \
48473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	 ((type) << _VKI_IOC_TYPESHIFT) | \
48573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	 ((nr)   << _VKI_IOC_NRSHIFT) | \
48673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	 ((size) << _VKI_IOC_SIZESHIFT))
48773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
48873b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* used to create numbers */
48973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IO(type,nr)	_VKI_IOC(_VKI_IOC_NONE,(type),(nr),0)
49073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOR(type,nr,size)	_VKI_IOC(_VKI_IOC_READ,(type),(nr),(_VKI_IOC_TYPECHECK(size)))
49173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOW(type,nr,size)	_VKI_IOC(_VKI_IOC_WRITE,(type),(nr),(_VKI_IOC_TYPECHECK(size)))
49273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOWR(type,nr,size)	_VKI_IOC(_VKI_IOC_READ|_VKI_IOC_WRITE,(type),(nr),(_VKI_IOC_TYPECHECK(size)))
49373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
49473b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* used to decode ioctl numbers.. */
49573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC_DIR(nr)	(((nr) >> _VKI_IOC_DIRSHIFT) & _VKI_IOC_DIRMASK)
496b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define _VKI_IOC_TYPE(nr)	(((nr) >> _VKI_IOC_TYPESHIFT) & _VKI_IOC_TYPEMASK)
497b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define _VKI_IOC_NR(nr)		(((nr) >> _VKI_IOC_NRSHIFT) & _VKI_IOC_NRMASK)
49873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define _VKI_IOC_SIZE(nr)	(((nr) >> _VKI_IOC_SIZESHIFT) & _VKI_IOC_SIZEMASK)
49973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
50073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
50173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/ioctls.h
50273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
50373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
50473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TCGETS	0x5401
50573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TCSETS	0x5402 /* Clashes with SNDCTL_TMR_START sound ioctl */
50673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TCSETSW	0x5403
50773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TCSETSF	0x5404
50873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TCGETA	0x5405
50973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TCSETA	0x5406
51073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TCSETAW	0x5407
51173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TCSETAF	0x5408
51273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TCSBRK	0x5409
51373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TCXONC	0x540A
51473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TCFLSH	0x540B
51573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TIOCSCTTY	0x540E
51673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TIOCGPGRP	0x540F
51773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TIOCSPGRP	0x5410
51873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TIOCOUTQ	0x5411
51973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TIOCGWINSZ	0x5413
52073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TIOCSWINSZ	0x5414
52162ba758224e7e1289b0f9be52bcbcf73e36630a4tom#define VKI_TIOCMGET	0x5415
52273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TIOCMBIS	0x5416
52373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TIOCMBIC	0x5417
52473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TIOCMSET	0x5418
52573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FIONREAD	0x541B
52673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TIOCLINUX	0x541C
52773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FIONBIO	0x5421
52873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TCSBRKP	0x5425	/* Needed for POSIX tcsendbreak() */
52973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TIOCGPTN	_VKI_IOR('T',0x30, unsigned int) /* Get Pty Number (of pty-mux device) */
53073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_TIOCSPTLCK	_VKI_IOW('T',0x31, int)  /* Lock/unlock Pty */
53173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
53273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FIOASYNC	0x5452
5335d2af674214d1f7b9abda9b178775c69dc4f7c7dtom#define VKI_TIOCSERGETLSR   0x5459 /* Get line status register */
5345d2af674214d1f7b9abda9b178775c69dc4f7c7dtom
5355d2af674214d1f7b9abda9b178775c69dc4f7c7dtom#define VKI_TIOCGICOUNT	0x545D	/* read serial port inline interrupt counts */
53673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
53773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
53873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/poll.h
53973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
54073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
54173b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* These are specified by iBCS2 */
54273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_POLLIN		0x0001
54373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
54473b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_pollfd {
54573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int fd;
54673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	short events;
54773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	short revents;
54873b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
54973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
55073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
55173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/user.h
55273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
55373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
55473b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_user_i387_struct {
55573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	cwd;
55673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	swd;
55773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	twd;
55873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	fip;
55973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	fcs;
56073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	foo;
56173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	fos;
56273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	st_space[20];	/* 8*10 bytes for each FP-reg = 80 bytes */
56373b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
56473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
56573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_user_fxsr_struct {
56673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	cwd;
56773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	swd;
56873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	twd;
56973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	fop;
57073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	fip;
57173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	fcs;
57273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	foo;
57373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	fos;
57473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	mxcsr;
57573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	reserved;
57673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	st_space[32];	/* 8*16 bytes for each FP-reg = 128 bytes */
57773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	xmm_space[32];	/* 8*16 bytes for each XMM-reg = 128 bytes */
57873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	padding[56];
57973b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
58073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
58173b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*
58273b526fb4af0f60634f0078583d92b931d5c0eebnethercote * This is the old layout of "struct pt_regs", and
58373b526fb4af0f60634f0078583d92b931d5c0eebnethercote * is still the layout used by user mode (the new
58473b526fb4af0f60634f0078583d92b931d5c0eebnethercote * pt_regs doesn't have all registers as the kernel
58573b526fb4af0f60634f0078583d92b931d5c0eebnethercote * doesn't use the extra segment registers)
58673b526fb4af0f60634f0078583d92b931d5c0eebnethercote */
58773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_user_regs_struct {
58873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long ebx, ecx, edx, esi, edi, ebp, eax;
58973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short ds, __ds, es, __es;
59073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short fs, __fs, gs, __gs;
59173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long orig_eax, eip;
59273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short cs, __cs;
59373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long eflags, esp;
59473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short ss, __ss;
59573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
59673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
59773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
59873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/elf.h
59973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
60073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
60173b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef unsigned long vki_elf_greg_t;
60273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
60373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_ELF_NGREG (sizeof (struct vki_user_regs_struct) / sizeof(vki_elf_greg_t))
60473b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef vki_elf_greg_t vki_elf_gregset_t[VKI_ELF_NGREG];
60573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
60673b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct vki_user_i387_struct vki_elf_fpregset_t;
60773b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct vki_user_fxsr_struct vki_elf_fpxregset_t;
60873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
60973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_AT_SYSINFO		32
61073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
61173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
61273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/ucontext.h
61373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
61473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
61573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_ucontext {
61673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long		uc_flags;
61773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_ucontext    *uc_link;
61873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_stack_t		uc_stack;
61973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_sigcontext	uc_mcontext;
62073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_sigset_t		uc_sigmask;	/* mask last for extensibility */
62173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
62273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
62373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
62473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/segment.h
62573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
62673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
62773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_GDT_ENTRY_TLS_ENTRIES	3
62873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_GDT_ENTRY_TLS_MIN	6
62973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_GDT_ENTRY_TLS_MAX 	(VKI_GDT_ENTRY_TLS_MIN + VKI_GDT_ENTRY_TLS_ENTRIES - 1)
63073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
63173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
63273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/ldt.h
63373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
63473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
63573b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* [[Nb: This is the structure passed to the modify_ldt syscall.  Just so as
63673b526fb4af0f60634f0078583d92b931d5c0eebnethercote   to confuse and annoy everyone, this is _not_ the same as an
63773b526fb4af0f60634f0078583d92b931d5c0eebnethercote   VgLdtEntry and has to be translated into such.  The logic for doing
63873b526fb4af0f60634f0078583d92b931d5c0eebnethercote   so, in vg_ldt.c, is copied from the kernel sources.]] */
63973b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_user_desc {
64073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int  entry_number;
64173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long base_addr;
64273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int  limit;
64373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int  seg_32bit:1;
64473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int  contents:2;
64573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int  read_exec_only:1;
64673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int  limit_in_pages:1;
64773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int  seg_not_present:1;
64873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int  useable:1;
64973b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // [[Nb: this field is not in the kernel sources, but it has always
65073b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // been in the Valgrind sources so I will keep it there in case it's
65173b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // important... this is an x86-defined data structure so who
65273b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // knows;  maybe it's important to set this field to zero at some
65373b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // point.  --njn]]
65473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int  reserved:25;
65573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
65673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
65773b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Nb: for our convenience within Valgrind, use a more specific name]]
65873b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct vki_user_desc vki_modify_ldt_t;
65973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
66073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
66173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/ipcbuf.h
66273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
66373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
66473b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_ipc64_perm
66573b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
66673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_key_t	key;
66773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_uid32_t	uid;
66873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_gid32_t	gid;
66973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_uid32_t	cuid;
67073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_gid32_t	cgid;
67173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_mode_t	mode;
67273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short		__pad1;
67373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short		seq;
67473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short		__pad2;
67573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long		__unused1;
67673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long		__unused2;
67773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
67873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
67973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
68073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/sembuf.h
68173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
68273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
68373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_semid64_ds {
68473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_ipc64_perm sem_perm;		/* permissions .. see ipc.h */
68573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t	sem_otime;		/* last semop time */
68673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	__unused1;
68773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t	sem_ctime;		/* last change time */
68873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	__unused2;
68973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	sem_nsems;		/* no. of semaphores in array */
69073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	__unused3;
69173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	__unused4;
69273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
69373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
69473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
69573b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/msgbuf.h
69673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
69773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
69873b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_msqid64_ds {
69973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_ipc64_perm msg_perm;
70073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t msg_stime;	/* last msgsnd time */
70173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	__unused1;
70273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t msg_rtime;	/* last msgrcv time */
70373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	__unused2;
70473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t msg_ctime;	/* last change time */
70573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	__unused3;
70673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  msg_cbytes;	/* current number of bytes on queue */
70773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  msg_qnum;	/* number of messages in queue */
70873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  msg_qbytes;	/* max number of bytes on queue */
70973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_pid_t msg_lspid;	/* pid of last msgsnd */
71073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_pid_t msg_lrpid;	/* last receive pid */
71173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  __unused4;
71273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  __unused5;
71373b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
71473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
71573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
71673b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/ipc.h
71773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
71873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
71973b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_ipc_kludge {
72073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_msgbuf __user *msgp;
72173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long msgtyp;
72273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
72373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
724c616819253fcf211745060b2be26076174b1df19njn#define VKI_SEMOP		 1
725c616819253fcf211745060b2be26076174b1df19njn#define VKI_SEMGET		 2
726c616819253fcf211745060b2be26076174b1df19njn#define VKI_SEMCTL		 3
727c616819253fcf211745060b2be26076174b1df19njn#define VKI_SEMTIMEDOP	 	 4
728c616819253fcf211745060b2be26076174b1df19njn#define VKI_MSGSND		11
729c616819253fcf211745060b2be26076174b1df19njn#define VKI_MSGRCV		12
730c616819253fcf211745060b2be26076174b1df19njn#define VKI_MSGGET		13
731c616819253fcf211745060b2be26076174b1df19njn#define VKI_MSGCTL		14
732c616819253fcf211745060b2be26076174b1df19njn#define VKI_SHMAT		21
733c616819253fcf211745060b2be26076174b1df19njn#define VKI_SHMDT		22
734c616819253fcf211745060b2be26076174b1df19njn#define VKI_SHMGET		23
735c616819253fcf211745060b2be26076174b1df19njn#define VKI_SHMCTL		24
736c616819253fcf211745060b2be26076174b1df19njn
737c616819253fcf211745060b2be26076174b1df19njn
73873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
73973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-i386/shmbuf.h
74073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
74173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
74273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_shmid64_ds {
74373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_ipc64_perm	shm_perm;	/* operation perms */
74473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_size_t		shm_segsz;	/* size of segment (bytes) */
74573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t	shm_atime;	/* last attach time */
74673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long		__unused1;
74773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t	shm_dtime;	/* last detach time */
74873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long		__unused2;
74973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t	shm_ctime;	/* last change time */
75073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long		__unused3;
75173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_pid_t	shm_cpid;	/* pid of creator */
75273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_pid_t	shm_lpid;	/* pid of last operator */
75373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long		shm_nattch;	/* no. of current attaches */
75473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long		__unused4;
75573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long		__unused5;
75673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
75773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
75873b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_shminfo64 {
75973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	shmmax;
76073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	shmmin;
76173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	shmmni;
76273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	shmseg;
76373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	shmall;
76473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	__unused1;
76573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	__unused2;
76673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	__unused3;
76773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	__unused4;
76873b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
76973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
77073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
771b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj// DRM ioctls
772b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//----------------------------------------------------------------------
773b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj
774b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj// jrs 20050207: where did all this stuff come from?  Is it really
775b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj// i386 specific, or should it go into the linux-generic category?
776b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//struct vki_drm_buf_pub {
777b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//	Int		  idx;	       /**< Index into the master buffer list */
778b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//	Int		  total;       /**< Buffer size */
779b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//	Int		  used;	       /**< Amount of buffer in use (for DMA) */
780b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//	void	  __user *address;     /**< Address of buffer */
781b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//};
782b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//
783b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//struct vki_drm_buf_map {
784b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//	Int	      count;		/**< Length of the buffer list */
785b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//	void	      __user *virtual;	/**< Mmap'd area in user-virtual */
786b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//	struct vki_drm_buf_pub __user *list;	/**< Buffer information */
787b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//};
788b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//
789b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj///* We need to pay attention to this, because it mmaps memory */
790b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//#define VKI_DRM_IOCTL_MAP_BUFS		_VKI_IOWR('d', 0x19, struct vki_drm_buf_map)
791b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj
792b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj//----------------------------------------------------------------------
793c616819253fcf211745060b2be26076174b1df19njn// From linux-2.6.9/include/asm-i386/ptrace.h
794ca0518df66f8c3375a860f1a55a51f18e2a16c44njn//----------------------------------------------------------------------
795ca0518df66f8c3375a860f1a55a51f18e2a16c44njn
796ca0518df66f8c3375a860f1a55a51f18e2a16c44njn#define VKI_PTRACE_GETREGS            12
797ca0518df66f8c3375a860f1a55a51f18e2a16c44njn#define VKI_PTRACE_SETREGS            13
798ca0518df66f8c3375a860f1a55a51f18e2a16c44njn#define VKI_PTRACE_GETFPREGS          14
799ca0518df66f8c3375a860f1a55a51f18e2a16c44njn#define VKI_PTRACE_SETFPREGS          15
800ca0518df66f8c3375a860f1a55a51f18e2a16c44njn#define VKI_PTRACE_GETFPXREGS         18
801ca0518df66f8c3375a860f1a55a51f18e2a16c44njn#define VKI_PTRACE_SETFPXREGS         19
802ca0518df66f8c3375a860f1a55a51f18e2a16c44njn
803ca0518df66f8c3375a860f1a55a51f18e2a16c44njn//----------------------------------------------------------------------
804c1369aa0930694618c641c5d73ef20ec18b64102tom// From linux-2.6.15.4/include/asm-i386/vm86.h
805c1369aa0930694618c641c5d73ef20ec18b64102tom//----------------------------------------------------------------------
806c1369aa0930694618c641c5d73ef20ec18b64102tom
807c1369aa0930694618c641c5d73ef20ec18b64102tom#define VKI_VM86_PLUS_INSTALL_CHECK	0
808c1369aa0930694618c641c5d73ef20ec18b64102tom#define VKI_VM86_ENTER			1
809c1369aa0930694618c641c5d73ef20ec18b64102tom#define VKI_VM86_ENTER_NO_BYPASS	2
810c1369aa0930694618c641c5d73ef20ec18b64102tom#define	VKI_VM86_REQUEST_IRQ		3
811c1369aa0930694618c641c5d73ef20ec18b64102tom#define VKI_VM86_FREE_IRQ		4
812c1369aa0930694618c641c5d73ef20ec18b64102tom#define VKI_VM86_GET_IRQ_BITS		5
813c1369aa0930694618c641c5d73ef20ec18b64102tom#define VKI_VM86_GET_AND_RESET_IRQ	6
814c1369aa0930694618c641c5d73ef20ec18b64102tom
815c1369aa0930694618c641c5d73ef20ec18b64102tomstruct vki_vm86_regs {
816c1369aa0930694618c641c5d73ef20ec18b64102tom/*
817c1369aa0930694618c641c5d73ef20ec18b64102tom * normal regs, with special meaning for the segment descriptors..
818c1369aa0930694618c641c5d73ef20ec18b64102tom */
819c1369aa0930694618c641c5d73ef20ec18b64102tom	long ebx;
820c1369aa0930694618c641c5d73ef20ec18b64102tom	long ecx;
821c1369aa0930694618c641c5d73ef20ec18b64102tom	long edx;
822c1369aa0930694618c641c5d73ef20ec18b64102tom	long esi;
823c1369aa0930694618c641c5d73ef20ec18b64102tom	long edi;
824c1369aa0930694618c641c5d73ef20ec18b64102tom	long ebp;
825c1369aa0930694618c641c5d73ef20ec18b64102tom	long eax;
826c1369aa0930694618c641c5d73ef20ec18b64102tom	long __null_ds;
827c1369aa0930694618c641c5d73ef20ec18b64102tom	long __null_es;
828c1369aa0930694618c641c5d73ef20ec18b64102tom	long __null_fs;
829c1369aa0930694618c641c5d73ef20ec18b64102tom	long __null_gs;
830c1369aa0930694618c641c5d73ef20ec18b64102tom	long orig_eax;
831c1369aa0930694618c641c5d73ef20ec18b64102tom	long eip;
832c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned short cs, __csh;
833c1369aa0930694618c641c5d73ef20ec18b64102tom	long eflags;
834c1369aa0930694618c641c5d73ef20ec18b64102tom	long esp;
835c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned short ss, __ssh;
836c1369aa0930694618c641c5d73ef20ec18b64102tom/*
837c1369aa0930694618c641c5d73ef20ec18b64102tom * these are specific to v86 mode:
838c1369aa0930694618c641c5d73ef20ec18b64102tom */
839c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned short es, __esh;
840c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned short ds, __dsh;
841c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned short fs, __fsh;
842c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned short gs, __gsh;
843c1369aa0930694618c641c5d73ef20ec18b64102tom};
844c1369aa0930694618c641c5d73ef20ec18b64102tom
845c1369aa0930694618c641c5d73ef20ec18b64102tomstruct vki_revectored_struct {
846c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned long __map[8];			/* 256 bits */
847c1369aa0930694618c641c5d73ef20ec18b64102tom};
848c1369aa0930694618c641c5d73ef20ec18b64102tom
849c1369aa0930694618c641c5d73ef20ec18b64102tomstruct vki_vm86_struct {
850c1369aa0930694618c641c5d73ef20ec18b64102tom	struct vki_vm86_regs regs;
851c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned long flags;
852c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned long screen_bitmap;
853c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned long cpu_type;
854c1369aa0930694618c641c5d73ef20ec18b64102tom	struct vki_revectored_struct int_revectored;
855c1369aa0930694618c641c5d73ef20ec18b64102tom	struct vki_revectored_struct int21_revectored;
856c1369aa0930694618c641c5d73ef20ec18b64102tom};
857c1369aa0930694618c641c5d73ef20ec18b64102tom
858c1369aa0930694618c641c5d73ef20ec18b64102tomstruct vki_vm86plus_info_struct {
859c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned long force_return_for_pic:1;
860c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned long vm86dbg_active:1;       /* for debugger */
861c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned long vm86dbg_TFpendig:1;     /* for debugger */
862c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned long unused:28;
863c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned long is_vm86pus:1;	      /* for vm86 internal use */
864c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned char vm86dbg_intxxtab[32];   /* for debugger */
865c1369aa0930694618c641c5d73ef20ec18b64102tom};
866c1369aa0930694618c641c5d73ef20ec18b64102tom
867c1369aa0930694618c641c5d73ef20ec18b64102tomstruct vki_vm86plus_struct {
868c1369aa0930694618c641c5d73ef20ec18b64102tom	struct vki_vm86_regs regs;
869c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned long flags;
870c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned long screen_bitmap;
871c1369aa0930694618c641c5d73ef20ec18b64102tom	unsigned long cpu_type;
872c1369aa0930694618c641c5d73ef20ec18b64102tom	struct vki_revectored_struct int_revectored;
873c1369aa0930694618c641c5d73ef20ec18b64102tom	struct vki_revectored_struct int21_revectored;
874c1369aa0930694618c641c5d73ef20ec18b64102tom	struct vki_vm86plus_info_struct vm86plus;
875c1369aa0930694618c641c5d73ef20ec18b64102tom};
876c1369aa0930694618c641c5d73ef20ec18b64102tom
877c1369aa0930694618c641c5d73ef20ec18b64102tom//----------------------------------------------------------------------
87873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// And that's it!
87973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
88073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
8814de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#endif // __VKI_X86_LINUX_H
88273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
88373b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--------------------------------------------------------------------*/
88473b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--- end                                                          ---*/
88573b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--------------------------------------------------------------------*/
886