vki-linux.h revision 65bdbe43c02a3eb95a9bda4f82a5a5b61e64b296
173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
273b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--------------------------------------------------------------------*/
34de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn/*--- Linux-specific kernel interface.                 vki-linux.h ---*/
473b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--------------------------------------------------------------------*/
573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
673b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*
7b9c427c63a278cc612ae0ec573be7bb1abaa447fnjn   This file is part of Valgrind, a dynamic binary instrumentation
8b9c427c63a278cc612ae0ec573be7bb1abaa447fnjn   framework.
973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
10ec062e8d96a361af9905b5447027819dfbfee01asewardj   Copyright (C) 2000-2011 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
3173b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* This file defines types and constants for the kernel interface, and to
3273b526fb4af0f60634f0078583d92b931d5c0eebnethercote   make that clear everything is prefixed VKI_/vki_.
3373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
3473b526fb4af0f60634f0078583d92b931d5c0eebnethercote   All code is copied verbatim from kernel source files, except that:
3573b526fb4af0f60634f0078583d92b931d5c0eebnethercote   - VKI_/vki_ prefixes are added
3673b526fb4af0f60634f0078583d92b931d5c0eebnethercote   - some extra explanatory comments are included;  they are all within
3773b526fb4af0f60634f0078583d92b931d5c0eebnethercote     "[[ ]]"
3873b526fb4af0f60634f0078583d92b931d5c0eebnethercote   - for some types, we only care about the size;  for a few of them (big
3973b526fb4af0f60634f0078583d92b931d5c0eebnethercote     ones that are painful to fully drag in here), a VKI_SIZEOF_* constant
4073b526fb4af0f60634f0078583d92b931d5c0eebnethercote     is used.
4173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
4273b526fb4af0f60634f0078583d92b931d5c0eebnethercote   The files the code is taken from is indicated.
4373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
4473b526fb4af0f60634f0078583d92b931d5c0eebnethercote   Note especially that the types are not the glibc versions, many of which
4573b526fb4af0f60634f0078583d92b931d5c0eebnethercote   are different to those in here.
4673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
47ac7924c7eedce947578c571ae419c4c84eaa5aefnjn   Also note that this file contains all the generic header info, ie. that
48edef146c47eda894495d2b3b71b32b10349f8d91sewardj   from linux/include/linux/ *.h.  The arch-specific header info, eg. that
494de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn   from linux/include/asm-i386/ *.h, is in vki-$PLATFORM.h and
504de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn   vki_posixtypes-$PLATFORM.h.  (Two files are required to avoid
51ac7924c7eedce947578c571ae419c4c84eaa5aefnjn   circular dependencies between the generic VKI header and the
52ac7924c7eedce947578c571ae419c4c84eaa5aefnjn   arch-specific VKI header.  It's possible in the future, as more stuff
53ac7924c7eedce947578c571ae419c4c84eaa5aefnjn   gets pulled in, that we might have to split files up some more to avoid
54ac7924c7eedce947578c571ae419c4c84eaa5aefnjn   further circular dependencies.)
55ac7924c7eedce947578c571ae419c4c84eaa5aefnjn
5673b526fb4af0f60634f0078583d92b931d5c0eebnethercote   Finally, note that it is assumed that __KERNEL__ is set for all these
5773b526fb4af0f60634f0078583d92b931d5c0eebnethercote   definitions, which affects some of them.
5873b526fb4af0f60634f0078583d92b931d5c0eebnethercote*/
5973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
604cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj/* The structure is (aiui, jrs 20060504):
614cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj
624cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj     #include plat-specific posix types (vki-posixtypes-ARCH-linux.h)
634cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj
644cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj     Lots more types, structs, consts, in this file
654cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj
664cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj     #include other plat-specific stuff (vki-ARCH-linux.h)
674cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj
684cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj     Even more types, structs, consts, in this file
694cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj
704cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj   The system call numbers are dealt with by
714cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj   pub_{core,tool}_vkiscnums.h, not via pub_{core,tool}_vki.h, which
724cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj   is what this file is part of.
734cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj*/
744cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj
754de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#ifndef __VKI_LINUX_H
764de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#define __VKI_LINUX_H
7773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
7873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
7973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// Arch-specific POSIX types
8073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
8173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
824de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#if defined(VGA_x86)
834cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj#  include "vki-posixtypes-x86-linux.h"
844de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#elif defined(VGA_amd64)
854cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj#  include "vki-posixtypes-amd64-linux.h"
8685665ca6fa29dd64754dabe50eb98f25896e752acerion#elif defined(VGA_ppc32)
874cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj#  include "vki-posixtypes-ppc32-linux.h"
882c48c7b0a453d32375a4df17e153011b797ef28csewardj#elif defined(VGA_ppc64)
894cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj#  include "vki-posixtypes-ppc64-linux.h"
9059570ffbe31930ab4d678754daaeec0715117a3dsewardj#elif defined(VGA_arm)
9159570ffbe31930ab4d678754daaeec0715117a3dsewardj#  include "vki-posixtypes-arm-linux.h"
92b5b87408c0c99f9f6938d8cd921e2a5f420577c4sewardj#elif defined(VGA_s390x)
93b5b87408c0c99f9f6938d8cd921e2a5f420577c4sewardj#  include "vki-posixtypes-s390x-linux.h"
944de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#else
954de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#  error Unknown platform
964de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#endif
9773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
9873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
9907b168da387c8cf6e250fa042fc93dcc80e32752bart// VKI_STATIC_ASSERT(). Inspired by BUILD_BUG_ON() from
10007b168da387c8cf6e250fa042fc93dcc80e32752bart// linux-2.6.34/include/linux/kernel.h
10107b168da387c8cf6e250fa042fc93dcc80e32752bart//----------------------------------------------------------------------
10207b168da387c8cf6e250fa042fc93dcc80e32752bart
10307b168da387c8cf6e250fa042fc93dcc80e32752bart/*
10407b168da387c8cf6e250fa042fc93dcc80e32752bart * Evaluates to zero if 'expr' is true and forces a compilation error if
10507b168da387c8cf6e250fa042fc93dcc80e32752bart * 'expr' is false. Can be used in a context where no comma expressions
10607b168da387c8cf6e250fa042fc93dcc80e32752bart * are allowed.
10707b168da387c8cf6e250fa042fc93dcc80e32752bart */
10807b168da387c8cf6e250fa042fc93dcc80e32752bart#ifdef __cplusplus
10907b168da387c8cf6e250fa042fc93dcc80e32752barttemplate <bool b> struct vki_static_assert { int m_bitfield:(2*b-1); };
11007b168da387c8cf6e250fa042fc93dcc80e32752bart#define VKI_STATIC_ASSERT(expr)                         \
11107b168da387c8cf6e250fa042fc93dcc80e32752bart    (sizeof(vki_static_assert<(expr)>) - sizeof(int))
11207b168da387c8cf6e250fa042fc93dcc80e32752bart#else
11307b168da387c8cf6e250fa042fc93dcc80e32752bart#define VKI_STATIC_ASSERT(expr) (sizeof(struct { int:-!(expr); }))
11407b168da387c8cf6e250fa042fc93dcc80e32752bart#endif
11507b168da387c8cf6e250fa042fc93dcc80e32752bart
11607b168da387c8cf6e250fa042fc93dcc80e32752bart//----------------------------------------------------------------------
11707b168da387c8cf6e250fa042fc93dcc80e32752bart// Based on _IOC_TYPECHECK() from linux-2.6.34/asm-generic/ioctl.h
11807b168da387c8cf6e250fa042fc93dcc80e32752bart//----------------------------------------------------------------------
11907b168da387c8cf6e250fa042fc93dcc80e32752bart
12007b168da387c8cf6e250fa042fc93dcc80e32752bart/* provoke compile error for invalid uses of size argument */
12107b168da387c8cf6e250fa042fc93dcc80e32752bart#define _VKI_IOC_TYPECHECK(t)                                           \
12207b168da387c8cf6e250fa042fc93dcc80e32752bart    (VKI_STATIC_ASSERT((sizeof(t) == sizeof(t[1])                       \
12307b168da387c8cf6e250fa042fc93dcc80e32752bart                        && sizeof(t) < (1 << _VKI_IOC_SIZEBITS)))       \
12407b168da387c8cf6e250fa042fc93dcc80e32752bart     + sizeof(t))
12507b168da387c8cf6e250fa042fc93dcc80e32752bart
12607b168da387c8cf6e250fa042fc93dcc80e32752bart//----------------------------------------------------------------------
12773b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/compiler.h
12873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
12973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
13073b526fb4af0f60634f0078583d92b931d5c0eebnethercote# define __user
13173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
13273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
1338236fe6f256ea0e078a1a458a4690eec10b9a2c7tom// From linux/include/linux/compiler-gcc.h
1348236fe6f256ea0e078a1a458a4690eec10b9a2c7tom//----------------------------------------------------------------------
1358236fe6f256ea0e078a1a458a4690eec10b9a2c7tom
1368236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#ifdef __GNUC__
1378236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define __vki_packed			__attribute__((packed))
1388236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#endif
1398236fe6f256ea0e078a1a458a4690eec10b9a2c7tom
1408236fe6f256ea0e078a1a458a4690eec10b9a2c7tom//----------------------------------------------------------------------
14173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/posix_types.h
14273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
14373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
144f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#undef __VKI_NFDBITS
145f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#define __VKI_NFDBITS	(8 * sizeof(unsigned long))
146f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote
147f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#undef __VKI_FD_SETSIZE
148f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#define __VKI_FD_SETSIZE	1024
149f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote
150f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#undef __VKI_FDSET_LONGS
151f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#define __VKI_FDSET_LONGS	(__VKI_FD_SETSIZE/__VKI_NFDBITS)
152f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote
153f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#undef __VKI_FDELT
154f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#define	__VKI_FDELT(d)	((d) / __VKI_NFDBITS)
155f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote
156f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#undef __VKI_FDMASK
157f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#define	__VKI_FDMASK(d)	(1UL << ((d) % __VKI_NFDBITS))
158f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote
159f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercotetypedef struct {
160f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote	unsigned long fds_bits [__VKI_FDSET_LONGS];
161f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote} __vki_kernel_fd_set;
162f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote
16373b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef int __vki_kernel_key_t;
164330abb517e58fd0ee96fda7fb8563e32e029a63enethercotetypedef int __vki_kernel_mqd_t;
16573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
16673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
16773b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/types.h
16873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
16973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
170f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercotetypedef __vki_kernel_fd_set	vki_fd_set;
17173b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_mode_t	vki_mode_t;
17273b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_off_t	vki_off_t;
17373b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_pid_t	vki_pid_t;
17473b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_key_t	vki_key_t;
17573b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_suseconds_t	vki_suseconds_t;
17673b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_timer_t	vki_timer_t;
17792b2fd542e89939b46edfa5c424af81f4a3bfe0cnethercotetypedef __vki_kernel_clockid_t	vki_clockid_t;
178330abb517e58fd0ee96fda7fb8563e32e029a63enethercotetypedef __vki_kernel_mqd_t	vki_mqd_t;
17973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
18073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Nb: it's a bit unclear due to a #ifdef, but I think this is right. --njn]]
18173b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_uid32_t	vki_uid_t;
18273b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_gid32_t	vki_gid_t;
18373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
184c6851dde1b46166417a2bdb096c05818f5f07f09nethercotetypedef __vki_kernel_old_uid_t	vki_old_uid_t;
185c6851dde1b46166417a2bdb096c05818f5f07f09nethercotetypedef __vki_kernel_old_gid_t	vki_old_gid_t;
186c6851dde1b46166417a2bdb096c05818f5f07f09nethercote
18773b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_loff_t	vki_loff_t;
18873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
18973b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_size_t	vki_size_t;
19073b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_time_t	vki_time_t;
19173b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_clock_t	vki_clock_t;
19273b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_caddr_t	vki_caddr_t;
19373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
1945b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercotetypedef unsigned long           vki_u_long;
1955b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercote
1967f7e4d1ac0c4ea8bf771e5490b69d0e4d619dfe9nethercotetypedef unsigned int	        vki_uint;
1977f7e4d1ac0c4ea8bf771e5490b69d0e4d619dfe9nethercote
19873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
19973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// Now the rest of the arch-specific stuff
20073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
20173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
2024de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#if defined(VGA_x86)
2034de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#  include "vki-x86-linux.h"
2044de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#elif defined(VGA_amd64)
2054de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#  include "vki-amd64-linux.h"
20685665ca6fa29dd64754dabe50eb98f25896e752acerion#elif defined(VGA_ppc32)
20785665ca6fa29dd64754dabe50eb98f25896e752acerion#  include "vki-ppc32-linux.h"
2082c48c7b0a453d32375a4df17e153011b797ef28csewardj#elif defined(VGA_ppc64)
2092c48c7b0a453d32375a4df17e153011b797ef28csewardj#  include "vki-ppc64-linux.h"
21059570ffbe31930ab4d678754daaeec0715117a3dsewardj#elif defined(VGA_arm)
21159570ffbe31930ab4d678754daaeec0715117a3dsewardj#  include "vki-arm-linux.h"
212b5b87408c0c99f9f6938d8cd921e2a5f420577c4sewardj#elif defined(VGA_s390x)
213b5b87408c0c99f9f6938d8cd921e2a5f420577c4sewardj#  include "vki-s390x-linux.h"
2144de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#else
2154de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#  error Unknown platform
2164de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#endif
21773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
21873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
2197f4d7e42a880cd0872f93f5178a723beb56941a4tom// From linux-2.6.20.1/include/linux/types.h
2207f4d7e42a880cd0872f93f5178a723beb56941a4tom//----------------------------------------------------------------------
2217f4d7e42a880cd0872f93f5178a723beb56941a4tom
2227f4d7e42a880cd0872f93f5178a723beb56941a4tomtypedef		__vki_s32	vki_int32_t;
223a3e7a48d5767431328115ee6fa05ce7855830aa9sewardjtypedef		__vki_s64	vki_int64_t;
2247f4d7e42a880cd0872f93f5178a723beb56941a4tom
2259b27b82dac450baac59c4f8d1cd3589bedead53csewardjtypedef		__vki_u8	vki_uint8_t;
2269b27b82dac450baac59c4f8d1cd3589bedead53csewardjtypedef		__vki_u16	vki_uint16_t;
2277f4d7e42a880cd0872f93f5178a723beb56941a4tomtypedef		__vki_u32	vki_uint32_t;
2287f4d7e42a880cd0872f93f5178a723beb56941a4tom
2298236fe6f256ea0e078a1a458a4690eec10b9a2c7tomtypedef		__vki_u16	__vki_le16;
2308236fe6f256ea0e078a1a458a4690eec10b9a2c7tom
2317f4d7e42a880cd0872f93f5178a723beb56941a4tom//----------------------------------------------------------------------
23273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/limits.h
23373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
23473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
23573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PATH_MAX       4096	/* # chars in a path name including nul */
23673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
23773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
23873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/kernel.h
23973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
24073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
24173b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sysinfo {
24273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long uptime;			/* Seconds since boot */
24373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long loads[3];		/* 1, 5, and 15 minute load averages */
24473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long totalram;		/* Total usable main memory size */
24573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long freeram;		/* Available memory size */
24673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long sharedram;	/* Amount of shared memory */
24773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long bufferram;	/* Memory used by buffers */
24873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long totalswap;	/* Total swap space size */
24973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long freeswap;		/* swap space still available */
25073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short procs;		/* Number of current processes */
25173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short pad;		/* explicit padding for m68k */
25273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long totalhigh;	/* Total high memory size */
25373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long freehigh;		/* Available high memory size */
25473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int mem_unit;		/* Memory unit size in bytes */
25573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char _f[20-2*sizeof(long)-sizeof(int)];	/* Padding: libc5 uses this.. */
25673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
25773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
25873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
25973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/time.h
26073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
26173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
26285b1ac7d3ba74ad66e975a0bfd8b1cb9a9d06bb9bart#define VKI_CLOCK_REALTIME            0
26385b1ac7d3ba74ad66e975a0bfd8b1cb9a9d06bb9bart#define VKI_CLOCK_MONOTONIC           1
26485b1ac7d3ba74ad66e975a0bfd8b1cb9a9d06bb9bart#define VKI_CLOCK_PROCESS_CPUTIME_ID  2
26585b1ac7d3ba74ad66e975a0bfd8b1cb9a9d06bb9bart#define VKI_CLOCK_THREAD_CPUTIME_ID   3
26685b1ac7d3ba74ad66e975a0bfd8b1cb9a9d06bb9bart
26773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_timespec {
26873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_time_t	tv_sec;		/* seconds */
26973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long		tv_nsec;	/* nanoseconds */
27073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
27173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
27273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_timeval {
27373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_time_t	tv_sec;		/* seconds */
27473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_suseconds_t	tv_usec;	/* microseconds */
27573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
27673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
27773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_timezone {
27873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	tz_minuteswest;	/* minutes west of Greenwich */
27973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	tz_dsttime;	/* type of dst correction */
28073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
28173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
28273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct  vki_itimerspec {
28373b526fb4af0f60634f0078583d92b931d5c0eebnethercote        struct  vki_timespec it_interval;    /* timer period */
28473b526fb4af0f60634f0078583d92b931d5c0eebnethercote        struct  vki_timespec it_value;       /* timer expiration */
28573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
28673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
28773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct	vki_itimerval {
28873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct	vki_timeval it_interval;	/* timer interval */
28973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct	vki_timeval it_value;	/* current value */
29073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
29173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
29273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
29373b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/timex.h
29473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
29573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
29673b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_timex {
29773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int modes;	/* mode selector */
29873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long offset;		/* time offset (usec) */
29973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long freq;		/* frequency offset (scaled ppm) */
30073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long maxerror;		/* maximum error (usec) */
30173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long esterror;		/* estimated error (usec) */
30273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int status;		/* clock command/status */
30373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long constant;		/* pll time constant */
30473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long precision;		/* clock precision (usec) (read only) */
30573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long tolerance;		/* clock frequency tolerance (ppm)
30673b526fb4af0f60634f0078583d92b931d5c0eebnethercote				 * (read only)
30773b526fb4af0f60634f0078583d92b931d5c0eebnethercote				 */
30873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_timeval time;	/* (read only) */
30973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long tick;		/* (modified) usecs between clock ticks */
31073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
31173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long ppsfreq;           /* pps frequency (scaled ppm) (ro) */
31273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long jitter;            /* pps jitter (us) (ro) */
31373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int shift;              /* interval duration (s) (shift) (ro) */
31473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long stabil;            /* pps stability (scaled ppm) (ro) */
31573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long jitcnt;            /* jitter limit exceeded (ro) */
31673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long calcnt;            /* calibration intervals (ro) */
31773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long errcnt;            /* calibration errors (ro) */
31873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long stbcnt;            /* stability limit exceeded (ro) */
31973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
32073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int  :32; int  :32; int  :32; int  :32;
32173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int  :32; int  :32; int  :32; int  :32;
32273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int  :32; int  :32; int  :32; int  :32;
32373b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
32473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
3259ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom#define VKI_ADJ_OFFSET			0x0001	/* time offset */
3269ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom#define VKI_ADJ_FREQUENCY		0x0002	/* frequency offset */
3279ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom#define VKI_ADJ_MAXERROR		0x0004	/* maximum time error */
3289ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom#define VKI_ADJ_ESTERROR		0x0008	/* estimated time error */
3299ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom#define VKI_ADJ_STATUS			0x0010	/* clock status */
3309ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom#define VKI_ADJ_TIMECONST		0x0020	/* pll time constant */
331e1c1a24e738b2a1d13f397e9501043914c1643f1tom#define VKI_ADJ_TAI			0x0080	/* set TAI offset */
3329ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom#define VKI_ADJ_TICK			0x4000	/* tick value */
333e1c1a24e738b2a1d13f397e9501043914c1643f1tom#define VKI_ADJ_ADJTIME			0x8000	/* switch between adjtime/adjtimex modes */
3349ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom//#define VKI_ADJ_OFFSET_SINGLESHOT	0x8001	/* old-fashioned adjtime */
335e1c1a24e738b2a1d13f397e9501043914c1643f1tom#define VKI_ADJ_OFFSET_READONLY		0x2000	/* read-only adjtime */
33673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
33773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
33873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/times.h
33973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
34073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
34173b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_tms {
34273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_clock_t tms_utime;
34373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_clock_t tms_stime;
34473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_clock_t tms_cutime;
34573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_clock_t tms_cstime;
34673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
34773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
34873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
34973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/utime.h
35073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
35173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
35273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_utimbuf {
35373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_time_t actime;
35473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_time_t modtime;
35573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
35673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
35773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
35873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/sched.h
35973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
36073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
361b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_CSIGNAL		0x000000ff	/* signal mask to be sent at exit */
36273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_VM		0x00000100	/* set if VM shared between processes */
36373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_FS		0x00000200	/* set if fs info shared between processes */
36473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_FILES		0x00000400	/* set if open files shared between processes */
36573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_SIGHAND	0x00000800	/* set if signal handlers and blocked signals shared */
366b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_CLONE_VFORK		0x00004000	/* set if the parent wants the child to wake it up on mm_release */
367b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_CLONE_PARENT	0x00008000	/* set if we want to have the same parent as the cloner */
36873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_THREAD	0x00010000	/* Same thread group? */
369b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_CLONE_SYSVSEM	0x00040000	/* share system V SEM_UNDO semantics */
370b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_CLONE_SETTLS	0x00080000	/* create a new TLS for the child */
37173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_PARENT_SETTID	0x00100000	/* set the TID in the parent */
37273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_CHILD_CLEARTID	0x00200000	/* clear the TID in the child */
37373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_DETACHED	0x00400000	/* Unused, ignored */
37473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_CHILD_SETTID	0x01000000	/* set the TID in the child */
37573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
37673b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sched_param {
37773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int sched_priority;
37873b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
37973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
380a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_TASK_COMM_LEN 16
381a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
38273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
38373b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-generic/siginfo.h
38473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
38573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
38673b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef union vki_sigval {
38773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int sival_int;
38873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void __user *sival_ptr;
38973b526fb4af0f60634f0078583d92b931d5c0eebnethercote} vki_sigval_t;
39073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
39173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#ifndef __VKI_ARCH_SI_PREAMBLE_SIZE
39273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_ARCH_SI_PREAMBLE_SIZE	(3 * sizeof(int))
39373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
39473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
39573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SI_MAX_SIZE	128
39673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
39773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#ifndef VKI_SI_PAD_SIZE
39873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SI_PAD_SIZE	((VKI_SI_MAX_SIZE - __VKI_ARCH_SI_PREAMBLE_SIZE) / sizeof(int))
39973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
40073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
40173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#ifndef __VKI_ARCH_SI_UID_T
40273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_ARCH_SI_UID_T	vki_uid_t
40373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
40473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
40573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#ifndef __VKI_ARCH_SI_BAND_T
40673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_ARCH_SI_BAND_T long
40773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
40873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
40973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Nb: this type changed between 2.4 and 2.6, but not in a way that
41073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// affects Valgrind.]]
41173b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct vki_siginfo {
41273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int si_signo;
41373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int si_errno;
41473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int si_code;
41573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
41673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union {
41773b526fb4af0f60634f0078583d92b931d5c0eebnethercote		int _pad[VKI_SI_PAD_SIZE];
41873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
41973b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* kill() */
42073b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct {
42173b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_pid_t _pid;		/* sender's pid */
42273b526fb4af0f60634f0078583d92b931d5c0eebnethercote			__VKI_ARCH_SI_UID_T _uid;	/* sender's uid */
42373b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} _kill;
42473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
42573b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* POSIX.1b timers */
42673b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct {
42773b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_timer_t _tid;		/* timer id */
42873b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int _overrun;		/* overrun count */
42973b526fb4af0f60634f0078583d92b931d5c0eebnethercote			char _pad[sizeof( __VKI_ARCH_SI_UID_T) - sizeof(int)];
43073b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_sigval_t _sigval;	/* same as below */
43173b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int _sys_private;       /* not to be passed to user */
43273b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} _timer;
43373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
43473b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* POSIX.1b signals */
43573b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct {
43673b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_pid_t _pid;		/* sender's pid */
43773b526fb4af0f60634f0078583d92b931d5c0eebnethercote			__VKI_ARCH_SI_UID_T _uid;	/* sender's uid */
43873b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_sigval_t _sigval;
43973b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} _rt;
44073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
44173b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* SIGCHLD */
44273b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct {
44373b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_pid_t _pid;		/* which child */
44473b526fb4af0f60634f0078583d92b931d5c0eebnethercote			__VKI_ARCH_SI_UID_T _uid;	/* sender's uid */
44573b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int _status;		/* exit code */
44673b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_clock_t _utime;
44773b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_clock_t _stime;
44873b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} _sigchld;
44973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
45073b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* SIGILL, SIGFPE, SIGSEGV, SIGBUS */
45173b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct {
45273b526fb4af0f60634f0078583d92b931d5c0eebnethercote			void __user *_addr; /* faulting insn/memory ref. */
45373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#ifdef __ARCH_SI_TRAPNO
45473b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int _trapno;	/* TRAP # which caused the signal */
45573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
45673b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} _sigfault;
45773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
45873b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* SIGPOLL */
45973b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct {
46073b526fb4af0f60634f0078583d92b931d5c0eebnethercote			__VKI_ARCH_SI_BAND_T _band;	/* POLL_IN, POLL_OUT, POLL_MSG */
46173b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int _fd;
46273b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} _sigpoll;
46373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	} _sifields;
46473b526fb4af0f60634f0078583d92b931d5c0eebnethercote} vki_siginfo_t;
46573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
466148250b9e89daa1073929da9df5fe6c8896b159ctom#define __VKI_SI_FAULT	0
467148250b9e89daa1073929da9df5fe6c8896b159ctom
46873b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*
46973b526fb4af0f60634f0078583d92b931d5c0eebnethercote * si_code values
47073b526fb4af0f60634f0078583d92b931d5c0eebnethercote * Digital reserves positive values for kernel-generated signals.
47173b526fb4af0f60634f0078583d92b931d5c0eebnethercote */
47273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SI_USER	0		/* sent by kill, sigsend, raise */
47373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SI_TKILL	-6		/* sent by tkill system call */
47473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
475e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom/*
476148250b9e89daa1073929da9df5fe6c8896b159ctom * SIGILL si_codes
477148250b9e89daa1073929da9df5fe6c8896b159ctom */
478148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_ILLOPC	(__VKI_SI_FAULT|1)	/* illegal opcode */
479148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_ILLOPN	(__VKI_SI_FAULT|2)	/* illegal operand */
480148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_ILLADR	(__VKI_SI_FAULT|3)	/* illegal addressing mode */
481148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_ILLTRP	(__VKI_SI_FAULT|4)	/* illegal trap */
482148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_PRVOPC	(__VKI_SI_FAULT|5)	/* privileged opcode */
483148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_PRVREG	(__VKI_SI_FAULT|6)	/* privileged register */
484148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_COPROC	(__VKI_SI_FAULT|7)	/* coprocessor error */
485148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_BADSTK	(__VKI_SI_FAULT|8)	/* internal stack error */
486148250b9e89daa1073929da9df5fe6c8896b159ctom
487148250b9e89daa1073929da9df5fe6c8896b159ctom/*
488148250b9e89daa1073929da9df5fe6c8896b159ctom * SIGFPE si_codes
489148250b9e89daa1073929da9df5fe6c8896b159ctom */
490148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_INTDIV	(__VKI_SI_FAULT|1)	/* integer divide by zero */
491148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_INTOVF	(__VKI_SI_FAULT|2)	/* integer overflow */
492148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_FLTDIV	(__VKI_SI_FAULT|3)	/* floating point divide by zero */
493148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_FLTOVF	(__VKI_SI_FAULT|4)	/* floating point overflow */
494148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_FLTUND	(__VKI_SI_FAULT|5)	/* floating point underflow */
495148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_FLTRES	(__VKI_SI_FAULT|6)	/* floating point inexact result */
496148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_FLTINV	(__VKI_SI_FAULT|7)	/* floating point invalid operation */
497148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_FLTSUB	(__VKI_SI_FAULT|8)	/* subscript out of range */
498148250b9e89daa1073929da9df5fe6c8896b159ctom
499148250b9e89daa1073929da9df5fe6c8896b159ctom/*
500148250b9e89daa1073929da9df5fe6c8896b159ctom * SIGSEGV si_codes
501148250b9e89daa1073929da9df5fe6c8896b159ctom */
502148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_SEGV_MAPERR	(__VKI_SI_FAULT|1)	/* address not mapped to object */
503148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_SEGV_ACCERR	(__VKI_SI_FAULT|2)	/* invalid permissions for mapped object */
504148250b9e89daa1073929da9df5fe6c8896b159ctom
505148250b9e89daa1073929da9df5fe6c8896b159ctom/*
506148250b9e89daa1073929da9df5fe6c8896b159ctom * SIGBUS si_codes
507148250b9e89daa1073929da9df5fe6c8896b159ctom */
508148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_BUS_ADRALN	(__VKI_SI_FAULT|1)	/* invalid address alignment */
509148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_BUS_ADRERR	(__VKI_SI_FAULT|2)	/* non-existant physical address */
510148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_BUS_OBJERR	(__VKI_SI_FAULT|3)	/* object specific hardware error */
511148250b9e89daa1073929da9df5fe6c8896b159ctom
512148250b9e89daa1073929da9df5fe6c8896b159ctom/*
51386df1559d94314c7385f79ec7f80a7063cb3e1e6sewardj * SIGTRAP si_codes
51486df1559d94314c7385f79ec7f80a7063cb3e1e6sewardj */
51586df1559d94314c7385f79ec7f80a7063cb3e1e6sewardj#define VKI_TRAP_BRKPT      (__VKI_SI_FAULT|1)  /* process breakpoint */
51686df1559d94314c7385f79ec7f80a7063cb3e1e6sewardj#define VKI_TRAP_TRACE      (__VKI_SI_FAULT|2)  /* process trace trap */
51786df1559d94314c7385f79ec7f80a7063cb3e1e6sewardj
51886df1559d94314c7385f79ec7f80a7063cb3e1e6sewardj/*
519e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom * This works because the alignment is ok on all current architectures
520e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom * but we leave open this being overridden in the future
521e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom */
522e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom#ifndef VKI___ARCH_SIGEV_PREAMBLE_SIZE
523e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom#define VKI___ARCH_SIGEV_PREAMBLE_SIZE	(sizeof(int) * 2 + sizeof(vki_sigval_t))
52473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
52573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
526e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom#define VKI_SIGEV_MAX_SIZE	64
527e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom#define VKI_SIGEV_PAD_SIZE	((VKI_SIGEV_MAX_SIZE - VKI___ARCH_SIGEV_PREAMBLE_SIZE) \
528e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom		/ sizeof(int))
52973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
53073b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct vki_sigevent {
53173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_sigval_t sigev_value;
53273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int sigev_signo;
53373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int sigev_notify;
53473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union {
53573b526fb4af0f60634f0078583d92b931d5c0eebnethercote		int _pad[VKI_SIGEV_PAD_SIZE];
53673b526fb4af0f60634f0078583d92b931d5c0eebnethercote		 int _tid;
53773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
53873b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct {
53973b526fb4af0f60634f0078583d92b931d5c0eebnethercote			void (*_function)(vki_sigval_t);
54073b526fb4af0f60634f0078583d92b931d5c0eebnethercote			void *_attribute;	/* really pthread_attr_t */
54173b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} _sigev_thread;
54273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	} _sigev_un;
54373b526fb4af0f60634f0078583d92b931d5c0eebnethercote} vki_sigevent_t;
54473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
54573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
54673b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From elsewhere...
54773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
54873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
54973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[The kernel actually uses the numbers 0,1,2 directly here, believe it or
55073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// not.  So we introduce our own constants, based on the glibc ones.]]
55173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SEEK_SET              0
55273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SEEK_CUR              1
55373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SEEK_END              2
55473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
55573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
55673b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/net.h
55773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
55873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
55973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_SOCKET		1	/* sys_socket(2)		*/
56073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_BIND		2	/* sys_bind(2)			*/
56173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_CONNECT		3	/* sys_connect(2)		*/
56273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_LISTEN		4	/* sys_listen(2)		*/
56373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_ACCEPT		5	/* sys_accept(2)		*/
56473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_GETSOCKNAME	6	/* sys_getsockname(2)		*/
56573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_GETPEERNAME	7	/* sys_getpeername(2)		*/
56673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_SOCKETPAIR	8	/* sys_socketpair(2)		*/
56773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_SEND		9	/* sys_send(2)			*/
56873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_RECV		10	/* sys_recv(2)			*/
56973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_SENDTO		11	/* sys_sendto(2)		*/
57073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_RECVFROM	12	/* sys_recvfrom(2)		*/
57173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_SHUTDOWN	13	/* sys_shutdown(2)		*/
57273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_SETSOCKOPT	14	/* sys_setsockopt(2)		*/
57373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_GETSOCKOPT	15	/* sys_getsockopt(2)		*/
57473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_SENDMSG		16	/* sys_sendmsg(2)		*/
57573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_RECVMSG		17	/* sys_recvmsg(2)		*/
576710f7cb43578a9b23a11aa7f9cfaea0311bc5ad9tom#define VKI_SYS_ACCEPT4		18	/* sys_accept4(2)		*/
57773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
578ca0518df66f8c3375a860f1a55a51f18e2a16c44njnenum vki_sock_type {
579ca0518df66f8c3375a860f1a55a51f18e2a16c44njn	VKI_SOCK_STREAM	= 1,
580ca0518df66f8c3375a860f1a55a51f18e2a16c44njn	// [[others omitted]]
581ca0518df66f8c3375a860f1a55a51f18e2a16c44njn};
582ca0518df66f8c3375a860f1a55a51f18e2a16c44njn
58373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
58473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/uio.h
58573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
58673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
58773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_iovec
58873b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
58973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void __user *iov_base;	/* BSD uses caddr_t (1003.1g requires void *) */
59073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_size_t iov_len; /* Must be size_t (1003.1g) */
59173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
59273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
59373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
59473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/socket.h
59573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
59673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
59773b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Resolved arbitrarily;  doesn't really matter whether it's '__inline__'
59873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//   or 'inline']]
59973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __KINLINE static __inline__
60073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
60173b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef unsigned short	vki_sa_family_t;
60273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
60373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sockaddr {
60473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_sa_family_t	sa_family;	/* address family, AF_xxx	*/
60573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char		sa_data[14];	/* 14 bytes of protocol address	*/
60673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
60773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
60873b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_msghdr {
60973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void	*	msg_name;	/* Socket name			*/
61073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int		msg_namelen;	/* Length of name		*/
61173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_iovec *	msg_iov;	/* Data blocks			*/
61273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_size_t	msg_iovlen;	/* Number of blocks		*/
61373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void 	*	msg_control;	/* Per protocol magic (eg BSD file descriptor passing) */
61473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_size_t	msg_controllen;	/* Length of cmsg list */
61573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	msg_flags;
61673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
61773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
618a4991237861dd834a58620b6a9eeca0e6e843f24tomstruct vki_mmsghdr {
619a4991237861dd834a58620b6a9eeca0e6e843f24tom	struct vki_msghdr   msg_hdr;
620a4991237861dd834a58620b6a9eeca0e6e843f24tom	unsigned        msg_len;
621a4991237861dd834a58620b6a9eeca0e6e843f24tom};
622a4991237861dd834a58620b6a9eeca0e6e843f24tom
62373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cmsghdr {
62473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_size_t	cmsg_len;	/* data byte count, including hdr */
62573b526fb4af0f60634f0078583d92b931d5c0eebnethercote        int		cmsg_level;	/* originating protocol */
62673b526fb4af0f60634f0078583d92b931d5c0eebnethercote        int		cmsg_type;	/* protocol-specific type */
62773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
62873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
62973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_CMSG_NXTHDR(ctl, len, cmsg) __vki_cmsg_nxthdr((ctl),(len),(cmsg))
63073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CMSG_NXTHDR(mhdr, cmsg) vki_cmsg_nxthdr((mhdr), (cmsg))
63173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
63273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CMSG_ALIGN(len) ( ((len)+sizeof(long)-1) & ~(sizeof(long)-1) )
63373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
63473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CMSG_DATA(cmsg)	((void *)((char *)(cmsg) + VKI_CMSG_ALIGN(sizeof(struct vki_cmsghdr))))
63573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
63673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_CMSG_FIRSTHDR(ctl,len) ((len) >= sizeof(struct vki_cmsghdr) ? \
63773b526fb4af0f60634f0078583d92b931d5c0eebnethercote				  (struct vki_cmsghdr *)(ctl) : \
63873b526fb4af0f60634f0078583d92b931d5c0eebnethercote				  (struct vki_cmsghdr *)NULL)
63973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CMSG_FIRSTHDR(msg)	__VKI_CMSG_FIRSTHDR((msg)->msg_control, (msg)->msg_controllen)
64073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
64173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Urgh, this is revolting...]
64273b526fb4af0f60634f0078583d92b931d5c0eebnethercote__KINLINE struct vki_cmsghdr * __vki_cmsg_nxthdr(void *__ctl, __vki_kernel_size_t __size,
64373b526fb4af0f60634f0078583d92b931d5c0eebnethercote					       struct vki_cmsghdr *__cmsg)
64473b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
64573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_cmsghdr * __ptr;
64673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
64773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__ptr = (struct vki_cmsghdr*)(((unsigned char *) __cmsg) +  VKI_CMSG_ALIGN(__cmsg->cmsg_len));
64873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	if ((unsigned long)((char*)(__ptr+1) - (char *) __ctl) > __size)
64973b526fb4af0f60634f0078583d92b931d5c0eebnethercote		return (struct vki_cmsghdr *)0;
65073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
65173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	return __ptr;
65273b526fb4af0f60634f0078583d92b931d5c0eebnethercote}
65373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
65473b526fb4af0f60634f0078583d92b931d5c0eebnethercote__KINLINE struct vki_cmsghdr * vki_cmsg_nxthdr (struct vki_msghdr *__msg, struct vki_cmsghdr *__cmsg)
65573b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
65673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	return __vki_cmsg_nxthdr(__msg->msg_control, __msg->msg_controllen, __cmsg);
65773b526fb4af0f60634f0078583d92b931d5c0eebnethercote}
65873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
65973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_SCM_RIGHTS	0x01		/* rw: access rights (array of int) */
66073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
66173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_AF_UNIX	1	/* Unix domain sockets 		*/
66273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_AF_INET	2	/* Internet IP Protocol		*/
66373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_AF_INET6	10	/* IP version 6			*/
66473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
66573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MSG_NOSIGNAL	0x4000	/* Do not generate SIGPIPE */
66673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
6671aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SOL_SCTP	132
6681aa57373be5343c365ee6b480e205abc16008402tom
66973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
67073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/in.h
67173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
67273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
67373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_in_addr {
67473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32	s_addr;
67573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
67673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
67773b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Structure describing an Internet (IP) socket address. */
67873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_SOCK_SIZE__	16	/* sizeof(struct sockaddr)	*/
67973b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sockaddr_in {
68073b526fb4af0f60634f0078583d92b931d5c0eebnethercote  vki_sa_family_t	sin_family;	/* Address family		*/
68173b526fb4af0f60634f0078583d92b931d5c0eebnethercote  unsigned short int	sin_port;	/* Port number			*/
68273b526fb4af0f60634f0078583d92b931d5c0eebnethercote  struct vki_in_addr	sin_addr;	/* Internet address		*/
68373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
68473b526fb4af0f60634f0078583d92b931d5c0eebnethercote  /* Pad to size of `struct sockaddr'. */
68573b526fb4af0f60634f0078583d92b931d5c0eebnethercote  unsigned char		__pad[__VKI_SOCK_SIZE__ - sizeof(short int) -
68673b526fb4af0f60634f0078583d92b931d5c0eebnethercote			sizeof(unsigned short int) - sizeof(struct vki_in_addr)];
68773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
68873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
68973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
69073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/in6.h
69173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
69273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
69373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_in6_addr
69473b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
69573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union
69673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	{
69773b526fb4af0f60634f0078583d92b931d5c0eebnethercote		__vki_u8	u6_addr8[16];
69873b526fb4af0f60634f0078583d92b931d5c0eebnethercote		__vki_u16	u6_addr16[8];
69973b526fb4af0f60634f0078583d92b931d5c0eebnethercote		__vki_u32	u6_addr32[4];
70073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	} vki_in6_u;
70173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define vki_s6_addr		vki_in6_u.u6_addr8
70273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define vki_s6_addr16		vki_in6_u.u6_addr16
70373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define vki_s6_addr32		vki_in6_u.u6_addr32
70473b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
70573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
70673b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sockaddr_in6 {
70773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short int	sin6_family;    /* AF_INET6 */
70873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u16		sin6_port;      /* Transport layer port # */
70973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32		sin6_flowinfo;  /* IPv6 flow information */
71073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_in6_addr	sin6_addr;      /* IPv6 address */
71173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32		sin6_scope_id;  /* scope id (new in RFC2553) */
71273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
71373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
71473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
71573b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/un.h
71673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
71773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
71873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_UNIX_PATH_MAX	108
71973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
72073b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sockaddr_un {
72173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_sa_family_t sun_family;	/* AF_UNIX */
72273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char sun_path[VKI_UNIX_PATH_MAX];	/* pathname */
72373b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
72473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
72573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
72673b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/if.h
72773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
72873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
72973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_IFNAMSIZ	16
73073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
73173b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_ifmap
73273b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
73373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long mem_start;
73473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long mem_end;
73573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short base_addr;
73673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char irq;
73773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char dma;
73873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char port;
73973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	/* 3 bytes spare */
74073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
74173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
74273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_if_settings
74373b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
74473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int type;	/* Type of physical device or protocol */
74573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int size;	/* Size of the data allocated by the caller */
74673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union {
74773b526fb4af0f60634f0078583d92b931d5c0eebnethercote                // [[Nb: converted these all to void* to avoid pulling in
74873b526fb4af0f60634f0078583d92b931d5c0eebnethercote                //   unnecessary headers]]]
74973b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* {atm/eth/dsl}_settings anyone ? */
75073b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void /*raw_hdlc_proto		*/__user *raw_hdlc;
75173b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void /*cisco_proto		*/__user *cisco;
75273b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void /*fr_proto			*/__user *fr;
75373b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void /*fr_proto_pvc		*/__user *fr_pvc;
75473b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void /*fr_proto_pvc_info	*/__user *fr_pvc_info;
75573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
75673b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* interface settings */
75773b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void /*sync_serial_settings	*/__user *sync;
75873b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void /*te1_settings		*/__user *te1;
75973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	} ifs_ifsu;
76073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
76173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
76273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_ifreq
76373b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
76473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IFHWADDRLEN	6
76573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union
76673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	{
76773b526fb4af0f60634f0078583d92b931d5c0eebnethercote		char	ifrn_name[VKI_IFNAMSIZ];		/* if name, e.g. "en0" */
76873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	} ifr_ifrn;
76973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
77073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union {
77173b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct	vki_sockaddr ifru_addr;
77273b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct	vki_sockaddr ifru_dstaddr;
77373b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct	vki_sockaddr ifru_broadaddr;
77473b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct	vki_sockaddr ifru_netmask;
77573b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct  vki_sockaddr ifru_hwaddr;
77673b526fb4af0f60634f0078583d92b931d5c0eebnethercote		short	ifru_flags;
77773b526fb4af0f60634f0078583d92b931d5c0eebnethercote		int	ifru_ivalue;
77873b526fb4af0f60634f0078583d92b931d5c0eebnethercote		int	ifru_mtu;
77973b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct  vki_ifmap ifru_map;
78073b526fb4af0f60634f0078583d92b931d5c0eebnethercote		char	ifru_slave[VKI_IFNAMSIZ];	/* Just fits the size */
78173b526fb4af0f60634f0078583d92b931d5c0eebnethercote		char	ifru_newname[VKI_IFNAMSIZ];
78273b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void __user *	ifru_data;
78373b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct	vki_if_settings ifru_settings;
78473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	} ifr_ifru;
78573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
78673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
78773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define vki_ifr_name	ifr_ifrn.ifrn_name	/* interface name 	*/
78873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define ifr_hwaddr	ifr_ifru.ifru_hwaddr	/* MAC address 		*/
78973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	ifr_addr	ifr_ifru.ifru_addr	/* address		*/
79073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	ifr_dstaddr	ifr_ifru.ifru_dstaddr	/* other end of p-p lnk	*/
79173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	ifr_broadaddr	ifr_ifru.ifru_broadaddr	/* broadcast address	*/
79273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	ifr_netmask	ifr_ifru.ifru_netmask	/* interface net mask	*/
79373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	vki_ifr_flags	ifr_ifru.ifru_flags	/* flags		*/
79473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	vki_ifr_metric	ifr_ifru.ifru_ivalue	/* metric		*/
79573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	vki_ifr_mtu		ifr_ifru.ifru_mtu	/* mtu			*/
79673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define ifr_map		ifr_ifru.ifru_map	/* device map		*/
79773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define ifr_slave	ifr_ifru.ifru_slave	/* slave device		*/
79873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	vki_ifr_data	ifr_ifru.ifru_data	/* for use by interface	*/
79973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define vki_ifr_ifindex	ifr_ifru.ifru_ivalue	/* interface index	*/
80073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define ifr_bandwidth	ifr_ifru.ifru_ivalue    /* link bandwidth	*/
80173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define ifr_qlen	ifr_ifru.ifru_ivalue	/* Queue length 	*/
80273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define ifr_newname	ifr_ifru.ifru_newname	/* New name		*/
80373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define ifr_settings	ifr_ifru.ifru_settings	/* Device/proto settings*/
80473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
80573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_ifconf
80673b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
80773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	ifc_len;			/* size of buffer	*/
80873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union
80973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	{
81073b526fb4af0f60634f0078583d92b931d5c0eebnethercote		char __user *ifcu_buf;
81173b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct vki_ifreq __user *ifcu_req;
81273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	} ifc_ifcu;
81373b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
81473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	vki_ifc_buf	ifc_ifcu.ifcu_buf	/* buffer address	*/
81573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
81673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
81773b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/if_arp.h
81873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
81973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
82073b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_arpreq {
82173b526fb4af0f60634f0078583d92b931d5c0eebnethercote  struct vki_sockaddr	arp_pa;		/* protocol address		*/
82273b526fb4af0f60634f0078583d92b931d5c0eebnethercote  struct vki_sockaddr	arp_ha;		/* hardware address		*/
82373b526fb4af0f60634f0078583d92b931d5c0eebnethercote  int			arp_flags;	/* flags			*/
82473b526fb4af0f60634f0078583d92b931d5c0eebnethercote  struct vki_sockaddr   arp_netmask;    /* netmask (only for proxy arps) */
82573b526fb4af0f60634f0078583d92b931d5c0eebnethercote  char			arp_dev[16];
82673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
82773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
82873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
82973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/route.h
83073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
83173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
83273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_rtentry
83373b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
83473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	rt_pad1;
83573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_sockaddr	rt_dst;		/* target address		*/
83673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_sockaddr	rt_gateway;	/* gateway addr (RTF_GATEWAY)	*/
83773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_sockaddr	rt_genmask;	/* target network mask (IP)	*/
83873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	rt_flags;
83973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	short		rt_pad2;
84073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	rt_pad3;
84173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void		*rt_pad4;
84273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	short		rt_metric;	/* +1 for binary compatibility!	*/
84373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char __user	*rt_dev;	/* forcing the device at add	*/
84473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	rt_mtu;		/* per route MTU/Window 	*/
84573b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Not important for Valgrind]]
84673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#ifndef __KERNEL__
84773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#define rt_mss	rt_mtu		/* Compatibility :-(            */
84873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#endif
84973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	rt_window;	/* Window clamping 		*/
85073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	rt_irtt;	/* Initial RTT			*/
85173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
85273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
85373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
8541aa57373be5343c365ee6b480e205abc16008402tom// From linux-2.6.13-rc5/include/net/sctp/user.h
8551aa57373be5343c365ee6b480e205abc16008402tom//----------------------------------------------------------------------
8561aa57373be5343c365ee6b480e205abc16008402tom
8571aa57373be5343c365ee6b480e205abc16008402tomtypedef __vki_s32 vki_sctp_assoc_t;
8581aa57373be5343c365ee6b480e205abc16008402tom
8591aa57373be5343c365ee6b480e205abc16008402tomenum vki_sctp_optname {
8601aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_RTOINFO,
8611aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_RTOINFO VKI_SCTP_RTOINFO
8621aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_ASSOCINFO,
8631aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_ASSOCINFO VKI_SCTP_ASSOCINFO
8641aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_INITMSG,
8651aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_INITMSG VKI_SCTP_INITMSG
8661aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_NODELAY, 	/* Get/set nodelay option. */
8671aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_NODELAY	VKI_SCTP_NODELAY
8681aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_AUTOCLOSE,
8691aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_AUTOCLOSE VKI_SCTP_AUTOCLOSE
8701aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_SET_PEER_PRIMARY_ADDR,
8711aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_SET_PEER_PRIMARY_ADDR VKI_SCTP_SET_PEER_PRIMARY_ADDR
8721aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_PRIMARY_ADDR,
8731aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_PRIMARY_ADDR VKI_SCTP_PRIMARY_ADDR
8741aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_ADAPTION_LAYER,
8751aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_ADAPTION_LAYER VKI_SCTP_ADAPTION_LAYER
8761aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_DISABLE_FRAGMENTS,
8771aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_DISABLE_FRAGMENTS VKI_SCTP_DISABLE_FRAGMENTS
8781aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_PEER_ADDR_PARAMS,
8791aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_PEER_ADDR_PARAMS VKI_SCTP_PEER_ADDR_PARAMS
8801aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_DEFAULT_SEND_PARAM,
8811aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_DEFAULT_SEND_PARAM VKI_SCTP_DEFAULT_SEND_PARAM
8821aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_EVENTS,
8831aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_EVENTS VKI_SCTP_EVENTS
8841aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_I_WANT_MAPPED_V4_ADDR,  /* Turn on/off mapped v4 addresses  */
8851aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_I_WANT_MAPPED_V4_ADDR VKI_SCTP_I_WANT_MAPPED_V4_ADDR
8861aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_MAXSEG, 	/* Get/set maximum fragment. */
8871aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_MAXSEG 	VKI_SCTP_MAXSEG
8881aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_STATUS,
8891aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_STATUS VKI_SCTP_STATUS
8901aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_GET_PEER_ADDR_INFO,
8911aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_GET_PEER_ADDR_INFO VKI_SCTP_GET_PEER_ADDR_INFO
8921aa57373be5343c365ee6b480e205abc16008402tom
8931aa57373be5343c365ee6b480e205abc16008402tom	/* Internal Socket Options. Some of the sctp library functions are
8941aa57373be5343c365ee6b480e205abc16008402tom	 * implemented using these socket options.
8951aa57373be5343c365ee6b480e205abc16008402tom	 */
8961aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_SOCKOPT_BINDX_ADD = 100,/* BINDX requests for adding addresses. */
8971aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_SOCKOPT_BINDX_ADD	VKI_SCTP_SOCKOPT_BINDX_ADD
8981aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_SOCKOPT_BINDX_REM, /* BINDX requests for removing addresses. */
8991aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_SOCKOPT_BINDX_REM	VKI_SCTP_SOCKOPT_BINDX_REM
9001aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_SOCKOPT_PEELOFF, 	/* peel off association. */
9011aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_SOCKOPT_PEELOFF	VKI_SCTP_SOCKOPT_PEELOFF
9021aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_GET_PEER_ADDRS_NUM, 	/* Get number of peer addresss. */
9031aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_GET_PEER_ADDRS_NUM	VKI_SCTP_GET_PEER_ADDRS_NUM
9041aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_GET_PEER_ADDRS, 	/* Get all peer addresss. */
9051aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_GET_PEER_ADDRS	VKI_SCTP_GET_PEER_ADDRS
9061aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_GET_LOCAL_ADDRS_NUM, 	/* Get number of local addresss. */
9071aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_GET_LOCAL_ADDRS_NUM	VKI_SCTP_GET_LOCAL_ADDRS_NUM
9081aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_GET_LOCAL_ADDRS, 	/* Get all local addresss. */
9091aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_GET_LOCAL_ADDRS	VKI_SCTP_GET_LOCAL_ADDRS
9101aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_SOCKOPT_CONNECTX, /* CONNECTX requests. */
9111aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_SOCKOPT_CONNECTX	VKI_SCTP_SOCKOPT_CONNECTX
9121aa57373be5343c365ee6b480e205abc16008402tom};
9131aa57373be5343c365ee6b480e205abc16008402tom
9141aa57373be5343c365ee6b480e205abc16008402tomstruct vki_sctp_getaddrs {
9151aa57373be5343c365ee6b480e205abc16008402tom	vki_sctp_assoc_t        assoc_id;
9161aa57373be5343c365ee6b480e205abc16008402tom	int			addr_num;
9171aa57373be5343c365ee6b480e205abc16008402tom	struct vki_sockaddr	*addrs;
9181aa57373be5343c365ee6b480e205abc16008402tom};
9191aa57373be5343c365ee6b480e205abc16008402tom
9201aa57373be5343c365ee6b480e205abc16008402tom//----------------------------------------------------------------------
92173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/resource.h
92273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
92373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
92473b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct	vki_rusage {
92573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_timeval ru_utime;	/* user time used */
92673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_timeval ru_stime;	/* system time used */
92773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_maxrss;		/* maximum resident set size */
92873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_ixrss;		/* integral shared memory size */
92973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_idrss;		/* integral unshared data size */
93073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_isrss;		/* integral unshared stack size */
93173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_minflt;		/* page reclaims */
93273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_majflt;		/* page faults */
93373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_nswap;		/* swaps */
93473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_inblock;		/* block input operations */
93573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_oublock;		/* block output operations */
93673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_msgsnd;		/* messages sent */
93773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_msgrcv;		/* messages received */
93873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_nsignals;		/* signals received */
93973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_nvcsw;		/* voluntary context switches */
94073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_nivcsw;		/* involuntary " */
94173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
94273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
94373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_rlimit {
94473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	rlim_cur;
94573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	rlim_max;
94673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
94773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
94846d02abf94a41586ef84aebf974db51a470e10datomstruct vki_rlimit64 {
94946d02abf94a41586ef84aebf974db51a470e10datom	__vki_u64 rlim_cur;
95046d02abf94a41586ef84aebf974db51a470e10datom	__vki_u64 rlim_max;
95146d02abf94a41586ef84aebf974db51a470e10datom};
95246d02abf94a41586ef84aebf974db51a470e10datom
95373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
95473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/elfcore.h
95573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
95673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
95773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_elf_siginfo
95873b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
95973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	si_signo;			/* signal number */
96073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	si_code;			/* extra code */
96173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	si_errno;			/* errno */
96273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
96373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
96473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Removed some commented out lines here]]
96573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_elf_prstatus
96673b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
96773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_elf_siginfo pr_info;	/* Info associated with signal */
96873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	short	pr_cursig;		/* Current signal */
96973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long pr_sigpend;	/* Set of pending signals */
97073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long pr_sighold;	/* Set of held signals */
97173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_pid_t	pr_pid;
97273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_pid_t	pr_ppid;
97373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_pid_t	pr_pgrp;
97473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_pid_t	pr_sid;
97573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_timeval pr_utime;	/* User time */
97673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_timeval pr_stime;	/* System time */
97773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_timeval pr_cutime;	/* Cumulative user time */
97873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_timeval pr_cstime;	/* Cumulative system time */
97973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_elf_gregset_t pr_reg;	/* GP registers */
98073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int pr_fpvalid;		/* True if math co-processor being used.  */
98173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
98273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
98373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_ELF_PRARGSZ	(80)	/* Number of chars for args */
98473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
98573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_elf_prpsinfo
98673b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
98773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char	pr_state;	/* numeric process state */
98873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char	pr_sname;	/* char for pr_state */
98973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char	pr_zomb;	/* zombie */
99073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char	pr_nice;	/* nice val */
99173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long pr_flag;	/* flags */
99273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_uid_t	pr_uid;
99373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_gid_t	pr_gid;
99473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_pid_t	pr_pid, pr_ppid, pr_pgrp, pr_sid;
99573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	/* Lots missing */
99673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char	pr_fname[16];	/* filename of executable */
99773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char	pr_psargs[VKI_ELF_PRARGSZ];	/* initial part of arg list */
99873b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
99973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
100073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
100140e735834f172bd304ead1fa7e5e31f9e455dc24njn// From linux-2.6.12.1/include/linux/eventpoll.h
100273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
100373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
100440e735834f172bd304ead1fa7e5e31f9e455dc24njn/* Valid opcodes to issue to sys_epoll_ctl() */
100540e735834f172bd304ead1fa7e5e31f9e455dc24njn#define VKI_EPOLL_CTL_ADD 1
100640e735834f172bd304ead1fa7e5e31f9e455dc24njn#define VKI_EPOLL_CTL_DEL 2
100740e735834f172bd304ead1fa7e5e31f9e455dc24njn#define VKI_EPOLL_CTL_MOD 3
100840e735834f172bd304ead1fa7e5e31f9e455dc24njn
100973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#ifdef __x86_64__
101073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_EPOLL_PACKED __attribute__((packed))
101173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#else
101273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_EPOLL_PACKED
101373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
101473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
101540e735834f172bd304ead1fa7e5e31f9e455dc24njnstruct vki_epoll_event {
101673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 events;
101773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64 data;
101873b526fb4af0f60634f0078583d92b931d5c0eebnethercote} VKI_EPOLL_PACKED;
101973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
102073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
102173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
102273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/mqueue.h
102373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
102473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
102573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_mq_attr {
102673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	mq_flags;	/* message queue flags			*/
102773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	mq_maxmsg;	/* maximum number of messages		*/
102873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	mq_msgsize;	/* maximum message size			*/
102973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	mq_curmsgs;	/* number of messages currently queued	*/
103073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	__reserved[4];	/* ignored for input, zeroed for output */
103173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
103273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
103373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
103473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/utsname.h
103573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
103673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
103773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_new_utsname {
103873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char sysname[65];
103973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char nodename[65];
104073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char release[65];
104173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char version[65];
104273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char machine[65];
104373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char domainname[65];
104473b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
104573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
104673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
104773b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/mii.h
104873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
104973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
105073b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* This structure is used in all SIOCxMIIxxx ioctl calls */
105173b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_mii_ioctl_data {
105273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_u16		phy_id;
105373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_u16		reg_num;
105473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_u16		val_in;
105573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_u16		val_out;
105673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
105773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
105873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
105973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/capability.h
106073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
106173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
106273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[capget()/capset() man page says this, ominously:
106373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//
106473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//   The kernel API is likely to change and use of these functions  (in
106573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//   particular the format of the cap_user_*_t types) is subject to
106673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//   change with each kernel revision.
106773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//
106873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// However, the format hasn't changed since at least Linux 2.4.6.]]
106973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
107073b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct __vki_user_cap_header_struct {
107173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 version;
107273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int pid;
107373b526fb4af0f60634f0078583d92b931d5c0eebnethercote} __user *vki_cap_user_header_t;
107473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
107573b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct __vki_user_cap_data_struct {
107673b526fb4af0f60634f0078583d92b931d5c0eebnethercote        __vki_u32 effective;
107773b526fb4af0f60634f0078583d92b931d5c0eebnethercote        __vki_u32 permitted;
107873b526fb4af0f60634f0078583d92b931d5c0eebnethercote        __vki_u32 inheritable;
107973b526fb4af0f60634f0078583d92b931d5c0eebnethercote} __user *vki_cap_user_data_t;
108073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
108173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
108273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
108373b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/module.h
108473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
108573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
108673b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[We do a VKI_SIZEOF_* here because this type is so big, and its size
108773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//   depends on the word size, so see vki_arch.h]]
108873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
108973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
109073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/ipc.h
109173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
109273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
109373b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Obsolete, used only for backwards compatibility and libc5 compiles */
109473b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_ipc_perm
109573b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
109673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_key_t	key;
109773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_uid_t	uid;
109873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_gid_t	gid;
109973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_uid_t	cuid;
110073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_gid_t	cgid;
110173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_mode_t	mode;
110273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	seq;
110373b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
110473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
110573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IPC_CREAT  00001000   /* create if key is nonexistent */
110673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IPC_EXCL   00002000   /* fail if key exists */
110773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IPC_NOWAIT 00004000   /* return error on wait */
110873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
110973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#define VKI_IPC_RMID 0     /* remove resource */
111073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IPC_SET  1     /* set ipc_perm options */
111173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IPC_STAT 2     /* get ipc_perm options */
111273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IPC_INFO 3     /* see ipcs */
111373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
111473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IPC_64  0x0100  /* New version (support 32-bit UIDs, bigger
111573b526fb4af0f60634f0078583d92b931d5c0eebnethercote			       message sizes, etc. */
111673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
111773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
111873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/sem.h
111973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
112073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
112173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_GETALL  13       /* get all semval's */
112273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SETVAL  16       /* set semval */
112373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SETALL  17       /* set all semval's */
112473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
112573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SEM_STAT 18
112673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SEM_INFO 19
112773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
112873b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Obsolete, used only for backwards compatibility and libc5 compiles */
112973b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_semid_ds {
113073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_ipc_perm	sem_perm;		/* permissions .. see ipc.h */
113173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t	sem_otime;		/* last semop time */
113273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t	sem_ctime;		/* last change time */
113373b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // [[Use void* to avoid excess header copying]]
113473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void/*struct sem	*/*sem_base;		/* ptr to first semaphore in array */
113573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void/*struct sem_queue */*sem_pending;		/* pending operations to be processed */
113673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void/*struct sem_queue */**sem_pending_last;	/* last pending operation */
113773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void/*struct sem_undo	*/*undo;			/* undo requests on this array */
113873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	sem_nsems;		/* no. of semaphores in array */
113973b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
114073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
114173b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sembuf {
114273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short  sem_num;	/* semaphore index in array */
114373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	short		sem_op;		/* semaphore operation */
114473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	short		sem_flg;	/* operation flags */
114573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
114673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
114773b526fb4af0f60634f0078583d92b931d5c0eebnethercoteunion vki_semun {
114873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int val;			/* value for SETVAL */
114973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_semid_ds __user *buf;	/* buffer for IPC_STAT & IPC_SET */
115073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short __user *array;	/* array for GETALL & SETALL */
115173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_seminfo __user *__buf;	/* buffer for IPC_INFO */
115273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void __user *__pad;
115373b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
115473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
115573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct  vki_seminfo {
115673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semmap;
115773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semmni;
115873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semmns;
115973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semmnu;
116073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semmsl;
116173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semopm;
116273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semume;
116373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semusz;
116473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semvmx;
116573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semaem;
116673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
116773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
116873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
116973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-generic/errno-base.h
117073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
117173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
117273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EPERM		 1	/* Operation not permitted */
117345f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define	VKI_ENOENT		 2	/* No such file or directory */
117473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_ESRCH		 3	/* No such process */
117573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EINTR		 4	/* Interrupted system call */
117659451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EIO			 5	/* I/O error */
117759451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENXIO		 6	/* No such device or address */
117859451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_E2BIG		 7	/* Argument list too long */
117959451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENOEXEC		 8	/* Exec format error */
118073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EBADF		 9	/* Bad file number */
118159451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ECHILD		10	/* No child processes */
118259451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EAGAIN		11	/* Try again */
118373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_ENOMEM		12	/* Out of memory */
118473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EACCES		13	/* Permission denied */
118573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EFAULT		14	/* Bad address */
118659451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENOTBLK		15	/* Block device required */
118759451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EBUSY		16	/* Device or resource busy */
118873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EEXIST		17	/* File exists */
118959451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EXDEV		18	/* Cross-device link */
119059451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENODEV		19	/* No such device */
119159451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENOTDIR		20	/* Not a directory */
119259451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EISDIR		21	/* Is a directory */
119373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EINVAL		22	/* Invalid argument */
119459451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENFILE		23	/* File table overflow */
119573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EMFILE		24	/* Too many open files */
119659451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENOTTY		25	/* Not a typewriter */
119759451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ETXTBSY		26	/* Text file busy */
119859451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EFBIG		27	/* File too large */
119959451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENOSPC		28	/* No space left on device */
120059451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ESPIPE		29	/* Illegal seek */
120159451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EROFS		30	/* Read-only file system */
120259451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EMLINK		31	/* Too many links */
120359451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EPIPE		32	/* Broken pipe */
120459451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EDOM		33	/* Math argument out of domain of func */
120559451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ERANGE		34	/* Math result not representable */
120673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
120773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
120873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-generic/errno.h
120973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
121073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
121159451647ad0829e0ffae02db4d20baeeff2e3239florian#define VKI_EWOULDBLOCK		VKI_EAGAIN
121259451647ad0829e0ffae02db4d20baeeff2e3239florian
121373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_ENOSYS		38	/* Function not implemented */
1214af8a6a8cabe15435a526c6d9435fe83992b671abtom#define	VKI_EOVERFLOW		75	/* Value too large for defined data type */
121573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
121673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
121773b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/wait.h
121873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
121973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
122073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_WNOHANG	0x00000001
122173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
122273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_WALL	0x40000000	/* Wait on all children, regardless of type */
122373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_WCLONE	0x80000000	/* Wait only on non-SIGCHLD children */
122473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
122573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
122673b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/mman.h
122773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
122873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
122973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MREMAP_MAYMOVE	1
123073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MREMAP_FIXED	2
123173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
123273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
1233aedcc7aa6015debd6ca554971f2e65488397661atom// From linux-2.6.31-rc4/include/linux/futex.h
123473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
123573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
123673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FUTEX_WAIT (0)
1237b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_FUTEX_WAKE (1)
123873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FUTEX_FD (2)
123973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FUTEX_REQUEUE (3)
1240b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_FUTEX_CMP_REQUEUE (4)
1241aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_WAKE_OP (5)
1242aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_LOCK_PI (6)
1243aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_UNLOCK_PI (7)
1244aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_TRYLOCK_PI (8)
1245aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_WAIT_BITSET (9)
1246aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_WAKE_BITSET (10)
1247aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_WAIT_REQUEUE_PI (11)
1248aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_CMP_REQUEUE_PI (12)
1249497c69e7365352c91422a41583cf3bb5cacc1de1sewardj#define VKI_FUTEX_PRIVATE_FLAG (128)
1250aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_CLOCK_REALTIME (256)
125173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
125205b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tomstruct vki_robust_list {
125305b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	struct vki_robust_list __user *next;
125405b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom};
125505b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom
125605b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tomstruct vki_robust_list_head {
125705b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	/*
125805b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * The head of the list. Points back to itself if empty:
125905b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 */
126005b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	struct vki_robust_list list;
126105b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom
126205b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	/*
126305b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * This relative offset is set by user-space, it gives the kernel
126405b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * the relative position of the futex field to examine. This way
126505b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * we keep userspace flexible, to freely shape its data-structure,
126605b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * without hardcoding any particular offset into the kernel:
126705b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 */
126805b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	long futex_offset;
126905b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom
127005b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	/*
127105b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * The death of the thread may race with userspace setting
127205b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * up a lock's links. So to handle this race, userspace first
127305b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * sets this field to the address of the to-be-taken lock,
127405b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * then does the lock acquire, and then adds itself to the
127505b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * list, and then clears this field. Hence the kernel will
127605b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * always have full knowledge of all locks that the thread
127705b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * _might_ have taken. We check the owner TID in any case,
127805b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * so only truly owned locks will be handled.
127905b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 */
128005b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	struct vki_robust_list __user *list_op_pending;
128105b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom};
128205b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom
128373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
128473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/errno.h
128573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
128673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
128773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_ERESTARTSYS	512
128873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
128973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
129073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/stat.h
129173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
129273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
129309b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFMT  00170000
129409b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFSOCK 0140000
129509b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFLNK  0120000
129609b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFREG  0100000
129709b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFBLK  0060000
129809b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFDIR  0040000
129909b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFCHR  0020000
130009b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFIFO  0010000
130109b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISUID  0004000
130209b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISGID  0002000
130309b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISVTX  0001000
130409b8480025cb3149879465b769058cb197bb9003njn
130509b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISLNK(m)	(((m) & VKI_S_IFMT) == VKI_S_IFLNK)
130609b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISREG(m)	(((m) & VKI_S_IFMT) == VKI_S_IFREG)
130709b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISDIR(m)	(((m) & VKI_S_IFMT) == VKI_S_IFDIR)
130809b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISCHR(m)	(((m) & VKI_S_IFMT) == VKI_S_IFCHR)
130909b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISBLK(m)	(((m) & VKI_S_IFMT) == VKI_S_IFBLK)
131009b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISFIFO(m)	(((m) & VKI_S_IFMT) == VKI_S_IFIFO)
131109b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISSOCK(m)	(((m) & VKI_S_IFMT) == VKI_S_IFSOCK)
131209b8480025cb3149879465b769058cb197bb9003njn
131345f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IRWXU 00700
131473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_S_IRUSR 00400
131573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_S_IWUSR 00200
131645f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IXUSR 00100
131745f4e7c91119c7d01a59f5e827c67841632c9314sewardj
131845f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IRWXG 00070
131945f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IRGRP 00040
132045f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IWGRP 00020
132145f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IXGRP 00010
132245f4e7c91119c7d01a59f5e827c67841632c9314sewardj
132345f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IRWXO 00007
132445f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IROTH 00004
132545f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IWOTH 00002
132645f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IXOTH 00001
132773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
132873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
132973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/dirent.h
133073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
133173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
133273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_dirent {
133373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long		d_ino;
133473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_off_t	d_off;
133573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	d_reclen;
133673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char		d_name[256]; /* We must not include limits.h! */
133773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
133873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
133973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
1340cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn// From linux-2.6.8.1/include/linux/fcntl.h
1341cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn//----------------------------------------------------------------------
1342cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn
1343b23d50521d681aac7a104cc2abb37efcc4e96ccdtom#define VKI_F_SETLEASE      (VKI_F_LINUX_SPECIFIC_BASE + 0)
1344b23d50521d681aac7a104cc2abb37efcc4e96ccdtom#define VKI_F_GETLEASE      (VKI_F_LINUX_SPECIFIC_BASE + 1)
1345cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn
1346b23d50521d681aac7a104cc2abb37efcc4e96ccdtom#define VKI_F_CANCELLK      (VKI_F_LINUX_SPECIFIC_BASE + 5)
1347b23d50521d681aac7a104cc2abb37efcc4e96ccdtom
1348b23d50521d681aac7a104cc2abb37efcc4e96ccdtom#define VKI_F_DUPFD_CLOEXEC (VKI_F_LINUX_SPECIFIC_BASE + 6)
1349b23d50521d681aac7a104cc2abb37efcc4e96ccdtom
1350b23d50521d681aac7a104cc2abb37efcc4e96ccdtom#define VKI_F_NOTIFY        (VKI_F_LINUX_SPECIFIC_BASE + 2)
1351b23d50521d681aac7a104cc2abb37efcc4e96ccdtom
1352b23d50521d681aac7a104cc2abb37efcc4e96ccdtom#define VKI_F_SETPIPE_SZ    (VKI_F_LINUX_SPECIFIC_BASE + 7)
1353b23d50521d681aac7a104cc2abb37efcc4e96ccdtom#define VKI_F_GETPIPE_SZ    (VKI_F_LINUX_SPECIFIC_BASE + 8)
1354cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn
1355cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn//----------------------------------------------------------------------
135673b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/sysctl.h
135773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
135873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
135973b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct __vki_sysctl_args {
136073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int __user *name;
136173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int nlen;
136273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void __user *oldval;
136373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_size_t __user *oldlenp;
136473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void __user *newval;
136573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_size_t newlen;
136673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long __unused[4];
136773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
136873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
136973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
137073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/aio_abi.h
137173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
137273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
137373b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef unsigned long	vki_aio_context_t;
137473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
137573b526fb4af0f60634f0078583d92b931d5c0eebnethercoteenum {
137673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	VKI_IOCB_CMD_PREAD = 0,
137773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	VKI_IOCB_CMD_PWRITE = 1,
13789c85af75f40edc77bc6492e08f0fd2567147fd14tom	VKI_IOCB_CMD_FSYNC = 2,
13799c85af75f40edc77bc6492e08f0fd2567147fd14tom	VKI_IOCB_CMD_FDSYNC = 3,
13809c85af75f40edc77bc6492e08f0fd2567147fd14tom	VKI_IOCB_CMD_PREADV = 7,
13819c85af75f40edc77bc6492e08f0fd2567147fd14tom	VKI_IOCB_CMD_PWRITEV = 8,
138273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
138373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
138473b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* read() from /dev/aio returns these structures. */
138573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_io_event {
138673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64	data;		/* the data field from the iocb */
138773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64	obj;		/* what iocb this event came from */
138873b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // [[Nb: These fields renamed from 'res' and 'res2' because 'res' is
138973b526fb4af0f60634f0078583d92b931d5c0eebnethercote        //   a macro in vg_syscalls.c!]]
139073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_s64	result;		/* result code for this event */
139173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_s64	result2;	/* secondary result */
139273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
139373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
139473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#if defined(VKI_LITTLE_ENDIAN)
139585665ca6fa29dd64754dabe50eb98f25896e752acerion#  define VKI_PADDED(x,y)	x, y
139673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#elif defined(VKI_BIG_ENDIAN)
139785665ca6fa29dd64754dabe50eb98f25896e752acerion#  define VKI_PADDED(x,y)	y, x
139873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#else
139973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#error edit for your odd byteorder.
140073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
140173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
140273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_iocb {
140373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	/* these are internal to the kernel/libc. */
140473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64	aio_data;	/* data to be returned in event's data */
140573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32	VKI_PADDED(aio_key, aio_reserved1);
140673b526fb4af0f60634f0078583d92b931d5c0eebnethercote				/* the kernel sets aio_key to the req # */
140773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
140873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	/* common fields */
140973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u16	aio_lio_opcode;	/* see IOCB_CMD_ above */
141073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_s16	aio_reqprio;
141173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32	aio_fildes;
141273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
141373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64	aio_buf;
141473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64	aio_nbytes;
141573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_s64	aio_offset;
141673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
141773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	/* extra parameters */
141873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64	aio_reserved2;	/* TODO: use this for a (struct sigevent *) */
141973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64	aio_reserved3;
142073b526fb4af0f60634f0078583d92b931d5c0eebnethercote}; /* 64 bytes */
142173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
142273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
142373b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/aio.h
142473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
142573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
142673b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_aio_ring {
142773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	id;	/* kernel internal index number */
142873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	nr;	/* number of io_events */
142973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	head;
143073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	tail;
143173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
143273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	magic;
143373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	compat_features;
143473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	incompat_features;
143573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	header_length;	/* size of aio_ring */
143673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
143773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_io_event		io_events[0];
143873b526fb4af0f60634f0078583d92b931d5c0eebnethercote}; /* 128 bytes + ring size */
143973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
144073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
144173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/msg.h
144273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
144373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
144473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MSG_STAT 11
144573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MSG_INFO 12
144673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
144773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_msqid_ds {
144873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_ipc_perm msg_perm;
144973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_msg *msg_first;		/* first message on queue,unused  */
145073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_msg *msg_last;		/* last message in queue,unused */
145173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t msg_stime;	/* last msgsnd time */
145273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t msg_rtime;	/* last msgrcv time */
145373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t msg_ctime;	/* last change time */
145473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  msg_lcbytes;	/* Reuse junk fields for 32 bit */
145573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  msg_lqbytes;	/* ditto */
145673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short msg_cbytes;	/* current number of bytes on queue */
145773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short msg_qnum;	/* number of messages in queue */
145873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short msg_qbytes;	/* max number of bytes on queue */
145973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_ipc_pid_t msg_lspid;	/* pid of last msgsnd */
146073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_ipc_pid_t msg_lrpid;	/* last receive pid */
146173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
146273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
146373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_msgbuf {
146473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long mtype;         /* type of message */
146573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char mtext[1];      /* message text */
146673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
146773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
146873b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_msginfo {
146973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int msgpool;
147073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int msgmap;
147173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int msgmax;
147273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int msgmnb;
147373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int msgmni;
147473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int msgssz;
147573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int msgtql;
147673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short  msgseg;
147773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
147873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
147973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
148073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/shm.h
148173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
148273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
148373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_shmid_ds {
148473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_ipc_perm		shm_perm;	/* operation perms */
148573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int			shm_segsz;	/* size of segment (bytes) */
148673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t		shm_atime;	/* last attach time */
148773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t		shm_dtime;	/* last detach time */
148873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t		shm_ctime;	/* last change time */
148973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_ipc_pid_t	shm_cpid;	/* pid of creator */
149073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_ipc_pid_t	shm_lpid;	/* pid of last operator */
149173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short		shm_nattch;	/* no. of current attaches */
149273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short 		shm_unused;	/* compatibility */
149373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void 			*shm_unused2;	/* ditto - used by DIPC */
149473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void			*shm_unused3;	/* unused */
149573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
149673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
1497f61fea0d88fc6cc2a6c4ff78c49aa0343529ee20tom#define VKI_SHM_RDONLY  010000  /* read-only access */
149860457093d30b23ac2531682205ab0bd9a5aae2edsewardj#define VKI_SHM_RND     020000  /* round attach address to SHMLBA boundary */
1499f61fea0d88fc6cc2a6c4ff78c49aa0343529ee20tom
150073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SHM_STAT 	13
150173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SHM_INFO 	14
150273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
150373b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Obsolete, used only for backwards compatibility */
150473b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct	vki_shminfo {
150573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int shmmax;
150673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int shmmin;
150773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int shmmni;
150873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int shmseg;
150973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int shmall;
151073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
151173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
151273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_shm_info {
151373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int used_ids;
151473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long shm_tot;	/* total allocated shm */
151573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long shm_rss;	/* total resident shm */
151673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long shm_swp;	/* total swapped shm */
151773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long swap_attempts;
151873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long swap_successes;
151973b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
152073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
152173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
152273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/rtc.h
152373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
152473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
152573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_rtc_time {
152673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_sec;
152773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_min;
152873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_hour;
152973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_mday;
153073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_mon;
153173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_year;
153273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_wday;
153373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_yday;
153473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_isdst;
153573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
153673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
153773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_AIE_ON	_VKI_IO('p', 0x01)	/* Alarm int. enable on	*/
153873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_AIE_OFF	_VKI_IO('p', 0x02)	/* ... off		*/
153973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_UIE_ON	_VKI_IO('p', 0x03)	/* Update int. enable on*/
154073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_UIE_OFF	_VKI_IO('p', 0x04)	/* ... off		*/
154173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_PIE_ON	_VKI_IO('p', 0x05)	/* Periodic int. enable on*/
154273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_PIE_OFF	_VKI_IO('p', 0x06)	/* ... off		*/
154373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
154473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_ALM_SET		_VKI_IOW('p', 0x07, struct vki_rtc_time) /* Set alarm time  */
154573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_ALM_READ	_VKI_IOR('p', 0x08, struct vki_rtc_time) /* Read alarm time */
154673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_RD_TIME		_VKI_IOR('p', 0x09, struct vki_rtc_time) /* Read RTC time   */
154773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#define RTC_SET_TIME	_IOW('p', 0x0a, struct rtc_time) /* Set RTC time    */
154873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_IRQP_READ	_VKI_IOR('p', 0x0b, unsigned long)	 /* Read IRQ rate   */
154973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_IRQP_SET	_VKI_IOW('p', 0x0c, unsigned long)	 /* Set IRQ rate    */
155073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
155173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
155273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/isdn.h
155373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
155473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
155595a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote// [[Nb: Resolved this for the common case where CONFIG_COBALT_MICRO_SERVER
155695a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote//   is not defined]]
155795a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote#define VKI_ISDN_MAX_CHANNELS   64
155895a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote
155973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IIOCGETCPS  _VKI_IO('I',21)
156073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
156173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IIOCNETGPN  _VKI_IO('I',34)
156273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
156373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_ISDN_MSNLEN          32
156473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
156573b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct {
156673b526fb4af0f60634f0078583d92b931d5c0eebnethercote  char name[10];
156773b526fb4af0f60634f0078583d92b931d5c0eebnethercote  char phone[VKI_ISDN_MSNLEN];
156873b526fb4af0f60634f0078583d92b931d5c0eebnethercote  int  outgoing;
156973b526fb4af0f60634f0078583d92b931d5c0eebnethercote} vki_isdn_net_ioctl_phone;
157073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
157173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
157273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/sockios.h
157373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
157473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
157573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCOUTQ		VKI_TIOCOUTQ
157673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
157773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCADDRT		0x890B	/* add routing table entry	*/
157873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCDELRT		0x890C	/* delete routing table entry	*/
157973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
158073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFNAME		0x8910	/* get iface name		*/
158173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFCONF		0x8912	/* get iface list		*/
158273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFFLAGS	0x8913	/* get flags			*/
158373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFFLAGS	0x8914	/* set flags			*/
158473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFADDR		0x8915	/* get PA address		*/
158573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFADDR		0x8916	/* set PA address		*/
158673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFDSTADDR	0x8917	/* get remote PA address	*/
158773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFDSTADDR	0x8918	/* set remote PA address	*/
158873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFBRDADDR	0x8919	/* get broadcast PA address	*/
158973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFBRDADDR	0x891a	/* set broadcast PA address	*/
159073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFNETMASK	0x891b	/* get network PA mask		*/
159173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFNETMASK	0x891c	/* set network PA mask		*/
159273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFMETRIC	0x891d	/* get metric			*/
159373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFMETRIC	0x891e	/* set metric			*/
159473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFMTU		0x8921	/* get MTU size			*/
159573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFMTU		0x8922	/* set MTU size			*/
159673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_SIOCSIFHWADDR	0x8924	/* set hardware address 	*/
159773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFHWADDR	0x8927	/* Get hardware address		*/
159873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFINDEX	0x8933	/* name -> if_index mapping	*/
159973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
160073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFTXQLEN	0x8942	/* Get the tx queue length	*/
160173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFTXQLEN	0x8943	/* Set the tx queue length 	*/
160273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
160373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGMIIPHY		0x8947	/* Get address of MII PHY in use. */
160473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGMIIREG		0x8948	/* Read MII PHY register.	*/
160573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSMIIREG		0x8949	/* Write MII PHY register.	*/
160673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
160773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCDARP		0x8953	/* delete ARP table entry	*/
160873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGARP		0x8954	/* get ARP table entry		*/
160973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSARP		0x8955	/* set ARP table entry		*/
161073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
161173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCDRARP		0x8960	/* delete RARP table entry	*/
161273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGRARP		0x8961	/* get RARP table entry		*/
161373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSRARP		0x8962	/* set RARP table entry		*/
161473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
161573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFMAP		0x8970	/* Get device parameters	*/
161673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFMAP		0x8971	/* Set device parameters	*/
161773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
161873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
161973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/ppdev.h
162073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
162173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
162273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PP_MAJOR	99
162373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
162473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PP_IOCTL	'p'
162573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
162673b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Set mode for read/write (e.g. IEEE1284_MODE_EPP) */
162773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPSETMODE	_VKI_IOW(VKI_PP_IOCTL, 0x80, int)
162873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
162973b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Read status */
163073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPRSTATUS	_VKI_IOR(VKI_PP_IOCTL, 0x81, unsigned char)
163173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#define PPWSTATUS	OBSOLETE__IOW(PP_IOCTL, 0x82, unsigned char)
163273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
163373b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Read/write control */
163473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPRCONTROL	_VKI_IOR(VKI_PP_IOCTL, 0x83, unsigned char)
163573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPWCONTROL	_VKI_IOW(VKI_PP_IOCTL, 0x84, unsigned char)
163673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
163773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_ppdev_frob_struct {
163873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char mask;
163973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char val;
164073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
164173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPFCONTROL      _VKI_IOW(VKI_PP_IOCTL, 0x8e, struct vki_ppdev_frob_struct)
164273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
164373b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Read/write data */
164473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPRDATA		_VKI_IOR(VKI_PP_IOCTL, 0x85, unsigned char)
164573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPWDATA		_VKI_IOW(VKI_PP_IOCTL, 0x86, unsigned char)
164673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
164773b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Claim the port to start using it */
164873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPCLAIM		_VKI_IO(VKI_PP_IOCTL, 0x8b)
164973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
165073b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Release the port when you aren't using it */
165173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPRELEASE	_VKI_IO(VKI_PP_IOCTL, 0x8c)
165273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
165373b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Yield the port (release it if another driver is waiting,
165473b526fb4af0f60634f0078583d92b931d5c0eebnethercote * then reclaim) */
165573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPYIELD		_VKI_IO(VKI_PP_IOCTL, 0x8d)
165673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
165773b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Register device exclusively (must be before PPCLAIM). */
165873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPEXCL		_VKI_IO(VKI_PP_IOCTL, 0x8f)
165973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
166073b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Data line direction: non-zero for input mode. */
166173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPDATADIR	_VKI_IOW(VKI_PP_IOCTL, 0x90, int)
166273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
166373b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Negotiate a particular IEEE 1284 mode. */
166473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPNEGOT	_VKI_IOW(VKI_PP_IOCTL, 0x91, int)
166573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
166673b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Set control lines when an interrupt occurs. */
166773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPWCTLONIRQ	_VKI_IOW(VKI_PP_IOCTL, 0x92, unsigned char)
166873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
166973b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Clear (and return) interrupt count. */
167073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPCLRIRQ	_VKI_IOR(VKI_PP_IOCTL, 0x93, int)
167173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
167273b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Set the IEEE 1284 phase that we're in (e.g. IEEE1284_PH_FWD_IDLE) */
167373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPSETPHASE	_VKI_IOW(VKI_PP_IOCTL, 0x94, int)
167473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
167573b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Set and get port timeout (struct timeval's) */
167673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPGETTIME	_VKI_IOR(VKI_PP_IOCTL, 0x95, struct vki_timeval)
167773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPSETTIME	_VKI_IOW(VKI_PP_IOCTL, 0x96, struct vki_timeval)
167873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
167973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPGETMODES	_VKI_IOR(VKI_PP_IOCTL, 0x97, unsigned int)
168073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
168173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPGETMODE	_VKI_IOR(VKI_PP_IOCTL, 0x98, int)
168273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPGETPHASE	_VKI_IOR(VKI_PP_IOCTL, 0x99, int)
168373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
168473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPGETFLAGS	_VKI_IOR(VKI_PP_IOCTL, 0x9a, int)
168573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPSETFLAGS	_VKI_IOW(VKI_PP_IOCTL, 0x9b, int)
168673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
168773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
168873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/fs.h
168973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
169073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
1691edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKROSET   _VKI_IO(0x12,93)	/* set device read-only (0 = read-write) */
1692edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKROGET   _VKI_IO(0x12,94)	/* get read-only status (0 = read_write) */
169395a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote#define VKI_BLKGETSIZE _VKI_IO(0x12,96) /* return device size /512 (long *arg) */
1694edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKRASET   _VKI_IO(0x12,98)	/* set read ahead for block device */
1695edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKRAGET   _VKI_IO(0x12,99)	/* get current read ahead setting */
1696edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKFRASET  _VKI_IO(0x12,100)/* set filesystem (mm/filemap.c) read-ahead */
1697edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKFRAGET  _VKI_IO(0x12,101)/* get filesystem (mm/filemap.c) read-ahead */
1698edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKSECTGET _VKI_IO(0x12,103)/* get max sectors per request (ll_rw_blk.c) */
1699edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKSSZGET  _VKI_IO(0x12,104)/* get block device sector size */
1700edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKBSZGET  _VKI_IOR(0x12,112,vki_size_t)
1701edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKBSZSET  _VKI_IOW(0x12,113,vki_size_t)
1702edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKGETSIZE64 _VKI_IOR(0x12,114,vki_size_t) /* return device size in bytes (u64 *arg) */
170395a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote
170473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FIBMAP	_VKI_IO(0x00,1)	/* bmap access */
170573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FIGETBSZ    _VKI_IO(0x00,2)	/* get the block size used for bmap */
170673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
170773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
170873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/scsi/sg.h
170973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
171073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
171173b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct vki_sg_io_hdr
171273b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
171373b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int interface_id;           /* [i] 'S' for SCSI generic (required) */
171473b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int dxfer_direction;        /* [i] data transfer direction  */
171573b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned char cmd_len;      /* [i] SCSI command length ( <= 16 bytes) */
171673b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned char mx_sb_len;    /* [i] max length to write to sbp */
171773b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned short iovec_count; /* [i] 0 implies no scatter gather */
171873b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned int dxfer_len;     /* [i] byte count of data transfer */
171973b526fb4af0f60634f0078583d92b931d5c0eebnethercote    void __user *dxferp;	/* [i], [*io] points to data transfer memory
172073b526fb4af0f60634f0078583d92b931d5c0eebnethercote					      or scatter gather list */
172173b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned char __user *cmdp; /* [i], [*i] points to command to perform */
172273b526fb4af0f60634f0078583d92b931d5c0eebnethercote    void __user *sbp;		/* [i], [*o] points to sense_buffer memory */
172373b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned int timeout;       /* [i] MAX_UINT->no timeout (unit: millisec) */
172473b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned int flags;         /* [i] 0 -> default, see SG_FLAG... */
172573b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int pack_id;                /* [i->o] unused internally (normally) */
172673b526fb4af0f60634f0078583d92b931d5c0eebnethercote    void __user * usr_ptr;      /* [i->o] unused internally */
172773b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned char status;       /* [o] scsi status */
172873b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned char masked_status;/* [o] shifted, masked scsi status */
172973b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned char msg_status;   /* [o] messaging level data (optional) */
173073b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned char sb_len_wr;    /* [o] byte count actually written to sbp */
173173b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned short host_status; /* [o] errors from host adapter */
173273b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned short driver_status;/* [o] errors from software driver */
173373b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int resid;                  /* [o] dxfer_len - actual_transferred */
173473b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned int duration;      /* [o] time taken by cmd (unit: millisec) */
173573b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned int info;          /* [o] auxiliary information */
173673b526fb4af0f60634f0078583d92b931d5c0eebnethercote} vki_sg_io_hdr_t;  /* 64 bytes long (on i386) */
173773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
173873b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct vki_sg_scsi_id { /* used by SG_GET_SCSI_ID ioctl() */
173973b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int host_no;        /* as in "scsi<n>" where 'n' is one of 0, 1, 2 etc */
174073b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int channel;
174173b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int scsi_id;        /* scsi id of target device */
174273b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int lun;
174373b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int scsi_type;      /* TYPE_... defined in scsi/scsi.h */
174473b526fb4af0f60634f0078583d92b931d5c0eebnethercote    short h_cmd_per_lun;/* host (adapter) maximum commands per lun */
174573b526fb4af0f60634f0078583d92b931d5c0eebnethercote    short d_queue_depth;/* device (or adapter) maximum queue length */
174673b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int unused[2];      /* probably find a good use, set 0 for now */
174773b526fb4af0f60634f0078583d92b931d5c0eebnethercote} vki_sg_scsi_id_t; /* 32 bytes long on i386 */
174873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
174973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_EMULATED_HOST 0x2203 /* true for emulated host adapter (ATAPI) */
175073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
175173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_SET_RESERVED_SIZE 0x2275  /* request a new reserved buffer size */
175273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_GET_RESERVED_SIZE 0x2272  /* actual size of reserved buffer */
175373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
175473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_GET_SCSI_ID 0x2276   /* Yields fd's bus, chan, dev, lun + type */
175573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
175673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_GET_SG_TABLESIZE 0x227F  /* 0 implies can't do scatter gather */
175773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
175873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_GET_VERSION_NUM 0x2282 /* Example: version 2.1.34 yields 20134 */
175973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
176073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_IO 0x2285   /* similar effect as write() followed by read() */
176173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
176273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_SET_TIMEOUT 0x2201  /* unit: jiffies (10ms on i386) */
176373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_GET_TIMEOUT 0x2202  /* yield timeout as _return_ value */
176473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
176573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#define SG_GET_COMMAND_Q 0x2270   /* Yields 0 (queuing off) or 1 (on) */
176673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_SET_COMMAND_Q 0x2271   /* Change queuing state with 0 or 1 */
176773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
176873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
17698758e70558926c9fa640de885df57c5cbbbbefectom// From linux-2.6.34/include/scsi/scsi.h and scsi/scsi_ioctl.h
17708758e70558926c9fa640de885df57c5cbbbbefectom//----------------------------------------------------------------------
17718758e70558926c9fa640de885df57c5cbbbbefectom
17728758e70558926c9fa640de885df57c5cbbbbefectom#define VKI_SCSI_IOCTL_DOORLOCK		0x5380 /* Lock the eject mechanism.  */
17738758e70558926c9fa640de885df57c5cbbbbefectom#define VKI_SCSI_IOCTL_DOORUNLOCK	0x5381 /* Unlock the mechanism.  */
17748758e70558926c9fa640de885df57c5cbbbbefectom#define VKI_SCSI_IOCTL_GET_IDLUN	0x5382
17758758e70558926c9fa640de885df57c5cbbbbefectom#define VKI_SCSI_IOCTL_GET_BUS_NUMBER	0x5386
17768758e70558926c9fa640de885df57c5cbbbbefectom
17778758e70558926c9fa640de885df57c5cbbbbefectomstruct vki_scsi_idlun {
17788758e70558926c9fa640de885df57c5cbbbbefectom	__vki_u32 dev_id;
17798758e70558926c9fa640de885df57c5cbbbbefectom	__vki_u32 host_unique_id;
17808758e70558926c9fa640de885df57c5cbbbbefectom};
17818758e70558926c9fa640de885df57c5cbbbbefectom
17828758e70558926c9fa640de885df57c5cbbbbefectom//----------------------------------------------------------------------
178373b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/cdrom.h
178473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
178573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
178673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMPLAYMSF	0x5303 /* Play Audio MSF (struct cdrom_msf) */
178773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMREADTOCHDR	0x5305 /* Read TOC header
178873b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                           (struct cdrom_tochdr) */
178973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMREADTOCENTRY	0x5306 /* Read TOC entry
179073b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                           (struct cdrom_tocentry) */
179173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMSUBCHNL	0x530b /* Read subchannel data
179273b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                           (struct cdrom_subchnl) */
179373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMREADMODE2	0x530c /* Read CDROM mode 2 data (2336 Bytes)
179473b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                           (struct cdrom_read) */
179573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMREADAUDIO	0x530e /* (struct cdrom_read_audio) */
179673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMMULTISESSION	0x5310 /* Obtain the start-of-last-session
179773b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                           address of multi session disks
179873b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                           (struct cdrom_multisession) */
179973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROM_GET_MCN	0x5311 /* Obtain the "Universal Product Code"
180073b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                           if available (struct cdrom_mcn) */
180173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMVOLREAD	0x5313 /* Get the drive's volume setting
180273b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                          (struct cdrom_volctrl) */
1803f9d83852c10bc84e8932ab8a1d18766df2f522betom#define VKI_CDROMREADRAW	0x5314	/* read data in raw mode (2352 Bytes)
1804f9d83852c10bc84e8932ab8a1d18766df2f522betom                                           (struct cdrom_read) */
180573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROM_CLEAR_OPTIONS	0x5321  /* Clear behavior options */
180673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROM_DRIVE_STATUS	0x5326  /* Get tray position, etc. */
180773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
180873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROM_SEND_PACKET	0x5393	/* send a packet to the drive */
180973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
181073b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_msf0
181173b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
181273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	minute;
181373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	second;
181473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	frame;
181573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
181673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
181773b526fb4af0f60634f0078583d92b931d5c0eebnethercoteunion vki_cdrom_addr
181873b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
181973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_cdrom_msf0	msf;
182073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int			lba;
182173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
182273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
182373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_msf
182473b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
182573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdmsf_min0;	/* start minute */
182673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdmsf_sec0;	/* start second */
182773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdmsf_frame0;	/* start frame */
182873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdmsf_min1;	/* end minute */
182973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdmsf_sec1;	/* end second */
183073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdmsf_frame1;	/* end frame */
183173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
183273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
183373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_tochdr
183473b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
183573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdth_trk0;	/* start track */
183673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdth_trk1;	/* end track */
183773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
183873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
183973b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_volctrl
184073b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
184173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	channel0;
184273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	channel1;
184373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	channel2;
184473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	channel3;
184573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
184673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
184773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_subchnl
184873b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
184973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdsc_format;
185073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdsc_audiostatus;
185173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdsc_adr:	4;
185273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdsc_ctrl:	4;
185373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdsc_trk;
185473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdsc_ind;
185573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union vki_cdrom_addr cdsc_absaddr;
185673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union vki_cdrom_addr cdsc_reladdr;
185773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
185873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
185973b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_tocentry
186073b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
186173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdte_track;
186273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdte_adr	:4;
186373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdte_ctrl	:4;
186473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdte_format;
186573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union vki_cdrom_addr cdte_addr;
186673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdte_datamode;
186773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
186873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
186973b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_read
187073b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
187173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	cdread_lba;
187273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char 	*cdread_bufaddr;
187373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	cdread_buflen;
187473b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
187573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
187673b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_read_audio
187773b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
187873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union vki_cdrom_addr addr; /* frame address */
187973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8 addr_format;      /* CDROM_LBA or CDROM_MSF */
188073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int nframes;           /* number of 2352-byte-frames to read at once */
188173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8 __user *buf;      /* frame buffer (size: nframes*2352 bytes) */
188273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
188373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
188473b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_multisession
188573b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
188673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union vki_cdrom_addr addr; /* frame address: start-of-last-session
188773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	                           (not the new "frame 16"!).  Only valid
188873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	                           if the "xa_flag" is true. */
188973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8 xa_flag;        /* 1: "is XA disk" */
189073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8 addr_format;    /* CDROM_LBA or CDROM_MSF */
189173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
189273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
189373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_mcn
189473b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
189573b526fb4af0f60634f0078583d92b931d5c0eebnethercote  __vki_u8 medium_catalog_number[14]; /* 13 ASCII digits, null-terminated */
189673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
189773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
189873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROM_PACKET_SIZE	12
189973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
190073b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_generic_command
190173b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
190273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char 		cmd[VKI_CDROM_PACKET_SIZE];
190373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char		__user *buffer;
190473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int 		buflen;
190573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int			stat;
190673b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // [[replace with void* to reduce inclusion amounts]]
190773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void/*struct vki_request_sense	*/__user *sense;
190873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char		data_direction;
190973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int			quiet;
191073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int			timeout;
191173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void			__user *reserved[1];	/* unused, actually */
191273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
191373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
191473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CD_SYNC_SIZE         12 /* 12 sync bytes per raw data frame */
191573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CD_HEAD_SIZE          4 /* header (address) bytes per raw data frame */
191673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CD_FRAMESIZE_RAW   2352 /* bytes per frame, "raw" mode */
191773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CD_FRAMESIZE_RAW0 (VKI_CD_FRAMESIZE_RAW-VKI_CD_SYNC_SIZE-VKI_CD_HEAD_SIZE) /*2336*/
191873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
191973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
192073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/soundcard.h
192173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
192273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
192373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#ifndef _VKI_SIOWR
192473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#if defined(_VKI_IOWR) && (defined(_AIX) || (!defined(sun) && !defined(sparc) && !defined(__sparc__) && !defined(__INCioctlh) && !defined(__Lynx__)))
192573b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Use already defined ioctl defines if they exist (except with Sun or Sparc) */
192673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	_VKI_SIO		_VKI_IO
192773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	_VKI_SIOR		_VKI_IOR
192873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	_VKI_SIOW		_VKI_IOW
192973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	_VKI_SIOWR		_VKI_IOWR
193073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#else
193173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Valgrind: Install this case if/when necessary]
193273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#error Valgrind: Cannot handle sparc/sun case yet...
193373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#  endif /* _IOWR */
193473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif  /* !_VKI_SIOWR */
193573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
193673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_CTRLRATE		_VKI_SIOWR('Q', 3, int)	/* Set/get timer resolution (HZ) */
193773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_GETOUTCOUNT	_VKI_SIOR ('Q', 4, int)
193873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_GETINCOUNT	_VKI_SIOR ('Q', 5, int)
193973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_PERCMODE		_VKI_SIOW ('Q', 6, int)
194073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_TESTMIDI		_VKI_SIOW ('Q', 8, int)
194173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_RESETSAMPLES	_VKI_SIOW ('Q', 9, int)
194273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_NRSYNTHS		_VKI_SIOR ('Q',10, int)
194373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_NRMIDIS		_VKI_SIOR ('Q',11, int)
194473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_GETTIME		_VKI_SIOR ('Q',19, int)
194573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
194673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_TMR_TIMEBASE		_VKI_SIOWR('T', 1, int)
194773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_TMR_TEMPO		_VKI_SIOWR('T', 5, int)
194873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_TMR_SOURCE		_VKI_SIOWR('T', 6, int)
194973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
195073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_MIDI_PRETIME		_VKI_SIOWR('m', 0, int)
195173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_MIDI_MPUMODE		_VKI_SIOWR('m', 1, int)
195273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
195373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_RESET		_VKI_SIO  ('P', 0)
195473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SYNC		_VKI_SIO  ('P', 1)
195573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SPEED		_VKI_SIOWR('P', 2, int)
195673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_STEREO		_VKI_SIOWR('P', 3, int)
195773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETBLKSIZE	_VKI_SIOWR('P', 4, int)
195873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_CHANNELS		_VKI_SIOWR('P', 6, int)
195973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SOUND_PCM_WRITE_FILTER	_VKI_SIOWR('P', 7, int)
196073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_POST		_VKI_SIO  ('P', 8)
196173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SUBDIVIDE	_VKI_SIOWR('P', 9, int)
196273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SETFRAGMENT	_VKI_SIOWR('P',10, int)
196373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
196473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETFMTS		_VKI_SIOR ('P',11, int) /* Returns a mask */
196555703dfaee1f046e2f038b65592387afb0187967tom#define VKI_SNDCTL_DSP_SETFMT		_VKI_SIOWR('P', 5, int) /* Selects ONE fmt */
196673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
196773b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct vki_audio_buf_info {
196873b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int fragments;	/* # of available fragments (partially usend ones not counted) */
196973b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int fragstotal;	/* Total # of fragments allocated */
197073b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int fragsize;	/* Size of a fragment in bytes */
197173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
197273b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int bytes;	/* Available space in bytes (includes partially used fragments) */
197373b526fb4af0f60634f0078583d92b931d5c0eebnethercote			/* Note! 'bytes' could be more than fragments*fragsize */
197473b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} vki_audio_buf_info;
197573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
197673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETOSPACE	_VKI_SIOR ('P',12, vki_audio_buf_info)
197773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETISPACE	_VKI_SIOR ('P',13, vki_audio_buf_info)
19780660567477bcf5b7e323de8d2e68dc5a9cd7334fnjn#define VKI_SNDCTL_DSP_NONBLOCK		_VKI_SIO  ('P',14)
197973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETCAPS		_VKI_SIOR ('P',15, int)
198073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
198173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETTRIGGER	_VKI_SIOR ('P',16, int)
198273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SETTRIGGER	_VKI_SIOW ('P',16, int)
198373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
198473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SETSYNCRO	_VKI_SIO  ('P', 21)
198573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SETDUPLEX	_VKI_SIO  ('P', 22)
198673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETODELAY	_VKI_SIOR ('P', 23, int)
198773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
198895a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote#define VKI_SNDCTL_DSP_GETCHANNELMASK	_VKI_SIOWR('P', 64, int)
198995a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote#define VKI_SNDCTL_DSP_BIND_CHANNEL	_VKI_SIOWR('P', 65, int)
199095a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote
199173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SETSPDIF		_VKI_SIOW ('P', 66, int)
199273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETSPDIF		_VKI_SIOR ('P', 67, int)
199373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
199473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SOUND_PCM_READ_RATE		_VKI_SIOR ('P', 2, int)
199573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SOUND_PCM_READ_CHANNELS	_VKI_SIOR ('P', 6, int)
199673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SOUND_PCM_READ_BITS		_VKI_SIOR ('P', 5, int)
199773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SOUND_PCM_READ_FILTER	_VKI_SIOR ('P', 7, int)
199873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
199973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
200073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
200173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/hdreg.h
200273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
200373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
20042c2bc2529113fa4df16d9341c79a3b1f2d4fda56tomstruct vki_hd_geometry {
20052c2bc2529113fa4df16d9341c79a3b1f2d4fda56tom      unsigned char heads;
20062c2bc2529113fa4df16d9341c79a3b1f2d4fda56tom      unsigned char sectors;
20072c2bc2529113fa4df16d9341c79a3b1f2d4fda56tom      unsigned short cylinders;
20082c2bc2529113fa4df16d9341c79a3b1f2d4fda56tom      unsigned long start;
20092c2bc2529113fa4df16d9341c79a3b1f2d4fda56tom};
20102c2bc2529113fa4df16d9341c79a3b1f2d4fda56tom
20112c2bc2529113fa4df16d9341c79a3b1f2d4fda56tom#define VKI_HDIO_GETGEO		0x0301	/* get device geometry */
20125d2af674214d1f7b9abda9b178775c69dc4f7c7dtom#define VKI_HDIO_GET_DMA	0x030b	/* get use-dma flag */
201373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_HDIO_GET_IDENTITY	0x030d	/* get IDE identification info */
201473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
201573b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Nb: done like this because the original type is a huge struct that will
201673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//   always be the same size.]]
201773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIZEOF_STRUCT_HD_DRIVEID   512
201873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
201973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
202073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/fb.h
202173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
202273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
202373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FBIOGET_VSCREENINFO	0x4600
2024fca8f5fadcbecf5f69e268f9c7393d27944fcd7atom#define VKI_FBIOPUT_VSCREENINFO	0x4601
202573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FBIOGET_FSCREENINFO	0x4602
2026fca8f5fadcbecf5f69e268f9c7393d27944fcd7atom#define VKI_FBIOPAN_DISPLAY	0x4606
202773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
202873b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_fb_fix_screeninfo {
202973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char id[16];			/* identification string eg "TT Builtin" */
203073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long smem_start;	/* Start of frame buffer mem */
203173b526fb4af0f60634f0078583d92b931d5c0eebnethercote					/* (physical address) */
203273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 smem_len;			/* Length of frame buffer mem */
203373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 type;			/* see FB_TYPE_*		*/
203473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 type_aux;		/* Interleave for interleaved Planes */
203573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 visual;		/* see FB_VISUAL_*		*/
203673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u16 xpanstep;		/* zero if no hardware panning  */
203773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u16 ypanstep;		/* zero if no hardware panning  */
203873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u16 ywrapstep;		/* zero if no hardware ywrap    */
203973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 line_length;		/* length of a line in bytes    */
204073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long mmio_start;	/* Start of Memory Mapped I/O   */
204173b526fb4af0f60634f0078583d92b931d5c0eebnethercote					/* (physical address) */
204273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 mmio_len;		/* Length of Memory Mapped I/O  */
204373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 accel;		/* Indicate to driver which	*/
204473b526fb4af0f60634f0078583d92b931d5c0eebnethercote					/*  specific chip/card we have	*/
204573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u16 reserved[3];		/* Reserved for future compatibility */
204673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
204773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
204873b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_fb_bitfield {
204973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 offset;		/* beginning of bitfield	*/
205073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 length;		/* length of bitfield		*/
205173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 msb_right;		/* != 0 : Most significant bit is */
205273b526fb4af0f60634f0078583d92b931d5c0eebnethercote					/* right */
205373b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
205473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
205573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_fb_var_screeninfo {
205673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 xres;			/* visible resolution		*/
205773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 yres;
205873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 xres_virtual;		/* virtual resolution		*/
205973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 yres_virtual;
206073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 xoffset;		/* offset from virtual to visible */
206173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 yoffset;		/* resolution			*/
206273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
206373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 bits_per_pixel;	/* guess what			*/
206473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 grayscale;		/* != 0 Graylevels instead of colors */
206573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
206673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_fb_bitfield red;	/* bitfield in fb mem if true color, */
206773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_fb_bitfield green;	/* else only length is significant */
206873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_fb_bitfield blue;
206973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_fb_bitfield transp;	/* transparency			*/
207073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
207173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 nonstd;		/* != 0 Non standard pixel format */
207273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
207373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 activate;		/* see FB_ACTIVATE_*		*/
207473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
207573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 height;		/* height of picture in mm    */
207673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 width;		/* width of picture in mm     */
207773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
207873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 accel_flags;		/* (OBSOLETE) see fb_info.flags */
207973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
208073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	/* Timing: All values in pixclocks, except pixclock (of course) */
208173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 pixclock;		/* pixel clock in ps (pico seconds) */
208273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 left_margin;		/* time from sync to picture	*/
208373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 right_margin;		/* time from picture to sync	*/
208473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 upper_margin;		/* time from sync to picture	*/
208573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 lower_margin;
208673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 hsync_len;		/* length of horizontal sync	*/
208773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 vsync_len;		/* length of vertical sync	*/
208873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 sync;			/* see FB_SYNC_*		*/
208973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 vmode;		/* see FB_VMODE_*		*/
209073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 rotate;		/* angle we rotate counter clockwise */
209173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 reserved[5];		/* Reserved for future compatibility */
209273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
209373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
2094b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes//----------------------------------------------------------------------
2095053eb0470396ddd47a7cc1ea4882a3c241631e10tom// From linux-2.6.9/include/linux/kd.h
2096b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes//----------------------------------------------------------------------
2097b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2098b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_GIO_FONT       0x4B60  /* gets font in expanded form */
2099b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_FONT       0x4B61  /* use font in expanded form */
2100b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2101b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_GIO_FONTX      0x4B6B  /* get font using struct consolefontdesc */
2102b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_FONTX      0x4B6C  /* set font using struct consolefontdesc */
2103b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughesstruct vki_consolefontdesc {
2104b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned short charcount;	/* characters in font (256 or 512) */
2105b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned short charheight;	/* scan lines per character (1-32) */
2106b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	char __user *chardata;		/* font data in expanded form */
2107b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes};
2108b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2109b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_FONTRESET  0x4B6D  /* reset to default font */
2110b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2111b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_GIO_CMAP       0x4B70  /* gets colour palette on VGA+ */
2112b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_CMAP       0x4B71  /* sets colour palette on VGA+ */
2113b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2114b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KIOCSOUND      0x4B2F  /* start sound generation (0 for off) */
2115b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDMKTONE       0x4B30  /* generate tone */
2116b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2117b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGETLED       0x4B31  /* return current led state */
2118b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSETLED       0x4B32  /* set led state [lights, not flags] */
2119b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2120b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGKBTYPE      0x4B33  /* get keyboard type */
2121b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2122b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDADDIO        0x4B34  /* add i/o port as valid */
2123b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDDELIO        0x4B35  /* del i/o port as valid */
2124b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDENABIO       0x4B36  /* enable i/o to video board */
2125b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDDISABIO      0x4B37  /* disable i/o to video board */
2126b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2127b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSETMODE      0x4B3A  /* set text/graphics mode */
2128b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGETMODE      0x4B3B  /* get current mode */
2129b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2130b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDMAPDISP      0x4B3C  /* map display into address space */
2131b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDUNMAPDISP    0x4B3D  /* unmap display from address space */
2132b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2133b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define		VKI_E_TABSZ		256
2134b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_GIO_SCRNMAP    0x4B40  /* get screen mapping from kernel */
2135b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_SCRNMAP	   0x4B41  /* put screen mapping table in kernel */
2136b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_GIO_UNISCRNMAP 0x4B69  /* get full Unicode screen mapping */
2137b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_UNISCRNMAP 0x4B6A  /* set full Unicode screen mapping */
2138b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2139b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_GIO_UNIMAP     0x4B66  /* get unicode-to-font mapping from kernel */
2140053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_unipair {
2141053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short unicode;
2142053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short fontpos;
2143053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2144053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_unimapdesc {
2145053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short entry_ct;
2146053eb0470396ddd47a7cc1ea4882a3c241631e10tom	struct vki_unipair __user *entries;
2147053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2148b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_UNIMAP     0x4B67  /* put unicode-to-font mapping in kernel */
2149b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_UNIMAPCLR  0x4B68  /* clear table, possibly advise hash algorithm */
2150053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_unimapinit {
2151053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short advised_hashsize;  /* 0 if no opinion */
2152053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short advised_hashstep;  /* 0 if no opinion */
2153053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short advised_hashlevel; /* 0 if no opinion */
2154053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2155b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2156b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGKBMODE      0x4B44  /* gets current keyboard mode */
2157b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSKBMODE      0x4B45  /* sets current keyboard mode */
2158b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2159b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGKBMETA      0x4B62  /* gets meta key handling mode */
2160b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSKBMETA      0x4B63  /* sets meta key handling mode */
2161b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2162b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGKBLED       0x4B64  /* get led flags (not lights) */
2163b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSKBLED       0x4B65  /* set led flags (not lights) */
2164b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2165b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughesstruct vki_kbentry {
2166b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned char kb_table;
2167b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned char kb_index;
2168b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned short kb_value;
2169b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes};
2170b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGKBENT       0x4B46  /* gets one entry in translation table */
2171b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSKBENT       0x4B47  /* sets one entry in translation table */
2172b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2173b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughesstruct vki_kbsentry {
2174b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned char kb_func;
2175b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned char kb_string[512];
2176b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes};
2177b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGKBSENT      0x4B48  /* gets one function key string entry */
2178b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSKBSENT      0x4B49  /* sets one function key string entry */
2179b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2180b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughesstruct vki_kbdiacr {
2181b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes        unsigned char diacr, base, result;
2182b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes};
2183b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughesstruct vki_kbdiacrs {
2184b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes        unsigned int kb_cnt;    /* number of entries in following array */
2185b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	struct vki_kbdiacr kbdiacr[256];    /* MAX_DIACR from keyboard.h */
2186b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes};
2187b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGKBDIACR     0x4B4A  /* read kernel accent table */
2188b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSKBDIACR     0x4B4B  /* write kernel accent table */
2189b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2190b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughesstruct vki_kbkeycode {
2191b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned int scancode, keycode;
2192b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes};
2193b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGETKEYCODE   0x4B4C  /* read kernel keycode table entry */
2194b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSETKEYCODE   0x4B4D  /* write kernel keycode table entry */
2195b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2196b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSIGACCEPT    0x4B4E  /* accept kbd generated signals */
2197b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2198b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughesstruct vki_kbd_repeat {
2199b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	int delay;	/* in msec; <= 0: don't change */
2200b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	int period;	/* in msec; <= 0: don't change */
2201b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes			/* earlier this field was misnamed "rate" */
2202b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes};
2203b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDKBDREP       0x4B52  /* set keyboard delay/repeat rate;
2204b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes                                    * actually used values are returned */
2205b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2206b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDFONTOP       0x4B72  /* font operations */
2207b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2208053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_console_font_op {
2209053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned int op;	/* operation code KD_FONT_OP_* */
2210053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned int flags;	/* KD_FONT_FLAG_* */
2211053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned int width, height;	/* font size */
2212053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned int charcount;
2213053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned char __user *data;	/* font data with height fixed to 32 */
2214053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2215053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2216053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_KD_FONT_OP_SET		0	/* Set font */
2217053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_KD_FONT_OP_GET		1	/* Get font */
2218053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_KD_FONT_OP_SET_DEFAULT	2	/* Set font to default, data points to name / NULL */
2219053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_KD_FONT_OP_COPY		3	/* Copy from another console */
2220053eb0470396ddd47a7cc1ea4882a3c241631e10tom
22215b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercote//----------------------------------------------------------------------
22225b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercote// From linux-2.6.9/include/linux/kb.h
22235b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercote//----------------------------------------------------------------------
22245b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercote
22255b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercotetypedef __vki_kernel_uid32_t vki_qid_t; /* Type in which we store ids in memory */
22265b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercote
2227ca0518df66f8c3375a860f1a55a51f18e2a16c44njn//----------------------------------------------------------------------
2228b807a78ac64d06eb04977044035d665d8a3c4f68tom// From linux-2.6.20.1/include/linux/ptrace.h
2229ca0518df66f8c3375a860f1a55a51f18e2a16c44njn//----------------------------------------------------------------------
2230ca0518df66f8c3375a860f1a55a51f18e2a16c44njn
223145f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_PTRACE_TRACEME         0
2232ca0518df66f8c3375a860f1a55a51f18e2a16c44njn#define VKI_PTRACE_PEEKTEXT	   1
2233ca0518df66f8c3375a860f1a55a51f18e2a16c44njn#define VKI_PTRACE_PEEKDATA	   2
2234ca0518df66f8c3375a860f1a55a51f18e2a16c44njn#define VKI_PTRACE_PEEKUSR	   3
22350109322c627d5f54ef6df387f4def68f0c1089e5tom#define VKI_PTRACE_POKEUSR	   6
22365b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercote
2237b807a78ac64d06eb04977044035d665d8a3c4f68tom#define VKI_PTRACE_DETACH         17
2238b807a78ac64d06eb04977044035d665d8a3c4f68tom
2239b807a78ac64d06eb04977044035d665d8a3c4f68tom#define VKI_PTRACE_GETEVENTMSG	0x4201
2240b807a78ac64d06eb04977044035d665d8a3c4f68tom#define VKI_PTRACE_GETSIGINFO	0x4202
2241b807a78ac64d06eb04977044035d665d8a3c4f68tom#define VKI_PTRACE_SETSIGINFO	0x4203
224245f4e7c91119c7d01a59f5e827c67841632c9314sewardj
22432f9328846035a021857b3f398af729bd7b08fb63tom//----------------------------------------------------------------------
22442f9328846035a021857b3f398af729bd7b08fb63tom// From linux-2.6.14/include/sound/asound.h
22452f9328846035a021857b3f398af729bd7b08fb63tom//----------------------------------------------------------------------
22462f9328846035a021857b3f398af729bd7b08fb63tom
22472f9328846035a021857b3f398af729bd7b08fb63tomenum {
22482f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_HW_FREE = _VKI_IO('A', 0x12),
22492f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_HWSYNC = _VKI_IO('A', 0x22),
22502f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_PREPARE = _VKI_IO('A', 0x40),
22512f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_RESET = _VKI_IO('A', 0x41),
22522f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_START = _VKI_IO('A', 0x42),
22532f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_DROP = _VKI_IO('A', 0x43),
22542f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_DRAIN = _VKI_IO('A', 0x44),
2255cf3bd97b427b5de4cf7e02d3ae52e53537eb4a7fnjn	VKI_SNDRV_PCM_IOCTL_PAUSE = _VKI_IOW('A', 0x45, int),
22562f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_RESUME = _VKI_IO('A', 0x47),
22572f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_XRUN = _VKI_IO('A', 0x48),
2258cf3bd97b427b5de4cf7e02d3ae52e53537eb4a7fnjn	VKI_SNDRV_PCM_IOCTL_LINK = _VKI_IOW('A', 0x60, int),
22592f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_UNLINK = _VKI_IO('A', 0x61),
22602f9328846035a021857b3f398af729bd7b08fb63tom};
22612f9328846035a021857b3f398af729bd7b08fb63tom
22622f9328846035a021857b3f398af729bd7b08fb63tomenum {
22632f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_TIMER_IOCTL_START = _VKI_IO('T', 0xa0),
22642f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_TIMER_IOCTL_STOP = _VKI_IO('T', 0xa1),
22652f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_TIMER_IOCTL_CONTINUE = _VKI_IO('T', 0xa2),
22662f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_TIMER_IOCTL_PAUSE = _VKI_IO('T', 0xa3),
22672f9328846035a021857b3f398af729bd7b08fb63tom};
22682f9328846035a021857b3f398af729bd7b08fb63tom
22695d2af674214d1f7b9abda9b178775c69dc4f7c7dtom//----------------------------------------------------------------------
22705d2af674214d1f7b9abda9b178775c69dc4f7c7dtom// From linux-2.6.15.4/include/linux/serial.h
22715d2af674214d1f7b9abda9b178775c69dc4f7c7dtom//----------------------------------------------------------------------
22725d2af674214d1f7b9abda9b178775c69dc4f7c7dtom
22735d2af674214d1f7b9abda9b178775c69dc4f7c7dtomstruct vki_serial_icounter_struct {
22745d2af674214d1f7b9abda9b178775c69dc4f7c7dtom	int cts, dsr, rng, dcd;
22755d2af674214d1f7b9abda9b178775c69dc4f7c7dtom	int rx, tx;
22765d2af674214d1f7b9abda9b178775c69dc4f7c7dtom	int frame, overrun, parity, brk;
22775d2af674214d1f7b9abda9b178775c69dc4f7c7dtom	int buf_overrun;
22785d2af674214d1f7b9abda9b178775c69dc4f7c7dtom	int reserved[9];
22795d2af674214d1f7b9abda9b178775c69dc4f7c7dtom};
22805d2af674214d1f7b9abda9b178775c69dc4f7c7dtom
2281053eb0470396ddd47a7cc1ea4882a3c241631e10tom//----------------------------------------------------------------------
2282053eb0470396ddd47a7cc1ea4882a3c241631e10tom// From linux-2.6.16/include/linux/vt.h
2283053eb0470396ddd47a7cc1ea4882a3c241631e10tom//----------------------------------------------------------------------
2284053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2285053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_OPENQRY	0x5600	/* find available vt */
2286053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2287053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_vt_mode {
2288053eb0470396ddd47a7cc1ea4882a3c241631e10tom	char mode;		/* vt mode */
2289053eb0470396ddd47a7cc1ea4882a3c241631e10tom	char waitv;		/* if set, hang on writes if not active */
2290053eb0470396ddd47a7cc1ea4882a3c241631e10tom	short relsig;		/* signal to raise on release req */
2291053eb0470396ddd47a7cc1ea4882a3c241631e10tom	short acqsig;		/* signal to raise on acquisition */
2292053eb0470396ddd47a7cc1ea4882a3c241631e10tom	short frsig;		/* unused (set to 0) */
2293053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2294053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_GETMODE	0x5601	/* get mode of active vt */
2295053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_SETMODE	0x5602	/* set mode of active vt */
2296053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2297053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_vt_stat {
2298053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_active;	/* active vt */
2299053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_signal;	/* signal to send */
2300053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_state;		/* vt bitmask */
2301053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2302053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_GETSTATE	0x5603	/* get global vt state info */
2303053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_SENDSIG	0x5604	/* signal to send to bitmask of vts */
2304053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2305053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_RELDISP	0x5605	/* release display */
2306053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2307053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_ACTIVATE	0x5606	/* make vt active */
2308053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_WAITACTIVE	0x5607	/* wait for vt active */
2309053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_DISALLOCATE	0x5608  /* free memory associated to vt */
2310053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2311053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_vt_sizes {
2312053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_rows;		/* number of rows */
2313053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_cols;		/* number of columns */
2314053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_scrollsize;	/* number of lines of scrollback */
2315053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2316053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_RESIZE	0x5609	/* set kernel's idea of screensize */
2317053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2318053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_vt_consize {
2319053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_rows;	/* number of rows */
2320053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_cols;	/* number of columns */
2321053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_vlin;	/* number of pixel rows on screen */
2322053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_clin;	/* number of pixel rows per character */
2323053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_vcol;	/* number of pixel columns on screen */
2324053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_ccol;	/* number of pixel columns per character */
2325053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2326053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_RESIZEX      0x560A  /* set kernel's idea of screensize + more */
2327053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_LOCKSWITCH   0x560B  /* disallow vt switching */
2328053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_UNLOCKSWITCH 0x560C  /* allow vt switching */
2329053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2330a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom//----------------------------------------------------------------------
2331a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom// From linux-2.6.19/include/linux/prctl.h
2332a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom//----------------------------------------------------------------------
2333a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2334a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_PDEATHSIG  1  /* Second arg is a signal */
2335a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_PDEATHSIG  2  /* Second arg is a ptr to return the signal */
2336a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2337a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_DUMPABLE   3
2338a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_DUMPABLE   4
2339a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2340a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_UNALIGN	  5
2341a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_UNALIGN	  6
2342a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_UNALIGN_NOPRINT	1	/* silently fix up unaligned user accesses */
2343a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_UNALIGN_SIGBUS	2	/* generate SIGBUS on unaligned user access */
2344a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2345a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_KEEPCAPS   7
2346a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_KEEPCAPS   8
2347a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2348a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_FPEMU  9
2349a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_FPEMU 10
2350a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FPEMU_NOPRINT	1	/* silently emulate fp operations accesses */
2351a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FPEMU_SIGFPE	2	/* don't emulate fp operations, send SIGFPE instead */
2352a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2353a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_FPEXC	11
2354a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_FPEXC	12
2355a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_SW_ENABLE	0x80	/* Use FPEXC for FP exception enables */
2356a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_DIV		0x010000	/* floating point divide by zero */
2357a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_OVF		0x020000	/* floating point overflow */
2358a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_UND		0x040000	/* floating point underflow */
2359a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_RES		0x080000	/* floating point inexact result */
2360a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_INV		0x100000	/* floating point invalid operation */
2361a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_DISABLED	0	/* FP exceptions disabled */
2362a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_NONRECOV	1	/* async non-recoverable exc. mode */
2363a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_ASYNC	2	/* async recoverable exception mode */
2364a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_PRECISE	3	/* precise exception mode */
2365a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2366a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_TIMING   13
2367a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_TIMING   14
2368a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_TIMING_STATISTICAL  0       /* Normal, traditional,
2369a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom                                                   statistical process timing */
2370a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_TIMING_TIMESTAMP    1       /* Accurate timestamp based
2371a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom                                                   process timing */
2372a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2373a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_NAME    15		/* Set process name */
2374a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_NAME    16		/* Get process name */
2375a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2376a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_ENDIAN	19
2377a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_ENDIAN	20
2378a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_ENDIAN_BIG		0
2379a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_ENDIAN_LITTLE	1	/* True little endian mode */
2380a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_ENDIAN_PPC_LITTLE	2	/* "PowerPC" pseudo little endian */
2381a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2382d7cf487123e934a38c6f3e22a40aebf5f00d55fftom//----------------------------------------------------------------------
2383d7cf487123e934a38c6f3e22a40aebf5f00d55fftom// From linux-2.6.19/include/linux/usbdevice_fs.h
2384d7cf487123e934a38c6f3e22a40aebf5f00d55fftom//----------------------------------------------------------------------
2385d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2386d7cf487123e934a38c6f3e22a40aebf5f00d55fftomstruct vki_usbdevfs_ctrltransfer {
2387d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	__vki_u8 bRequestType;
2388d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	__vki_u8 bRequest;
2389d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	__vki_u16 wValue;
2390d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	__vki_u16 wIndex;
2391d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	__vki_u16 wLength;
2392d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	__vki_u32 timeout;  /* in milliseconds */
2393d7cf487123e934a38c6f3e22a40aebf5f00d55fftom 	void __user *data;
2394d7cf487123e934a38c6f3e22a40aebf5f00d55fftom};
2395d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2396d7cf487123e934a38c6f3e22a40aebf5f00d55fftomstruct vki_usbdevfs_bulktransfer {
2397d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int ep;
2398d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int len;
2399d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int timeout; /* in milliseconds */
2400d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	void __user *data;
2401d7cf487123e934a38c6f3e22a40aebf5f00d55fftom};
2402d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2403d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_MAXDRIVERNAME 255
2404d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2405d7cf487123e934a38c6f3e22a40aebf5f00d55fftomstruct vki_usbdevfs_getdriver {
2406d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int interface;
2407d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	char driver[VKI_USBDEVFS_MAXDRIVERNAME + 1];
2408d7cf487123e934a38c6f3e22a40aebf5f00d55fftom};
2409d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2410d7cf487123e934a38c6f3e22a40aebf5f00d55fftomstruct vki_usbdevfs_connectinfo {
2411d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int devnum;
2412d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned char slow;
2413d7cf487123e934a38c6f3e22a40aebf5f00d55fftom};
2414d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2415d7cf487123e934a38c6f3e22a40aebf5f00d55fftomstruct vki_usbdevfs_iso_packet_desc {
2416d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int length;
2417d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int actual_length;
2418d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int status;
2419d7cf487123e934a38c6f3e22a40aebf5f00d55fftom};
2420d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2421d7cf487123e934a38c6f3e22a40aebf5f00d55fftomstruct vki_usbdevfs_urb {
2422d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned char type;
2423d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned char endpoint;
2424d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int status;
2425d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int flags;
2426d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	void __user *buffer;
2427d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int buffer_length;
2428d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int actual_length;
2429d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int start_frame;
2430d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int number_of_packets;
2431d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int error_count;
2432d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int signr;  /* signal to be sent on error, -1 if none should be sent */
2433d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	void *usercontext;
2434d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	struct vki_usbdevfs_iso_packet_desc iso_frame_desc[0];
2435d7cf487123e934a38c6f3e22a40aebf5f00d55fftom};
2436d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2437d7cf487123e934a38c6f3e22a40aebf5f00d55fftomstruct vki_usbdevfs_ioctl {
2438d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int	ifno;		/* interface 0..N ; negative numbers reserved */
2439d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int	ioctl_code;	/* MUST encode size + direction of data so the
2440d7cf487123e934a38c6f3e22a40aebf5f00d55fftom				 * macros in <asm/ioctl.h> give correct values */
2441d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	void __user *data;	/* param buffer (in, or out) */
2442d7cf487123e934a38c6f3e22a40aebf5f00d55fftom};
2443d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2444d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_CONTROL           _VKI_IOWR('U', 0, struct vki_usbdevfs_ctrltransfer)
2445d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_BULK              _VKI_IOWR('U', 2, struct vki_usbdevfs_bulktransfer)
2446d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_GETDRIVER         _VKI_IOW('U', 8, struct vki_usbdevfs_getdriver)
2447d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_SUBMITURB         _VKI_IOR('U', 10, struct vki_usbdevfs_urb)
24486e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn#define VKI_USBDEVFS_DISCARDURB        _VKI_IO('U', 11)
2449d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_REAPURB           _VKI_IOW('U', 12, void *)
2450d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_REAPURBNDELAY     _VKI_IOW('U', 13, void *)
2451d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_CONNECTINFO       _VKI_IOW('U', 17, struct vki_usbdevfs_connectinfo)
2452d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_IOCTL             _VKI_IOWR('U', 18, struct vki_usbdevfs_ioctl)
2453551fe9342240a22f66f91cd10d9a73c6c590becebart#define VKI_USBDEVFS_RESET             _VKI_IO('U', 20)
2454d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
24556e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn#define VKI_USBDEVFS_URB_TYPE_ISO              0
24566e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn#define VKI_USBDEVFS_URB_TYPE_INTERRUPT        1
24576e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn#define VKI_USBDEVFS_URB_TYPE_CONTROL          2
24586e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn#define VKI_USBDEVFS_URB_TYPE_BULK             3
24596e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn
24606e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn// [[this is missing in usbdevice_fs.h]]
24616e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjnstruct vki_usbdevfs_setuppacket {
24626e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn       __vki_u8 bRequestType;
24636e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn       __vki_u8 bRequest;
24646e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn       __vki_u16 wValue;
24656e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn       __vki_u16 wIndex;
24666e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn       __vki_u16 wLength;
24676e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn};
24686e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn
2469d5df125b895c5d5f31857c52dafa3cdea79ea05dtom//----------------------------------------------------------------------
2470d5df125b895c5d5f31857c52dafa3cdea79ea05dtom// From linux-2.6.20.1/include/linux/i2c.h
2471d5df125b895c5d5f31857c52dafa3cdea79ea05dtom//----------------------------------------------------------------------
2472d5df125b895c5d5f31857c52dafa3cdea79ea05dtom
2473d5df125b895c5d5f31857c52dafa3cdea79ea05dtom#define VKI_I2C_SLAVE		0x0703	/* Change slave address			*/
2474d5df125b895c5d5f31857c52dafa3cdea79ea05dtom					/* Attn.: Slave address is 7 or 10 bits */
2475d5df125b895c5d5f31857c52dafa3cdea79ea05dtom#define VKI_I2C_SLAVE_FORCE	0x0706	/* Change slave address			*/
2476d5df125b895c5d5f31857c52dafa3cdea79ea05dtom					/* Attn.: Slave address is 7 or 10 bits */
2477d5df125b895c5d5f31857c52dafa3cdea79ea05dtom					/* This changes the address, even if it */
2478d5df125b895c5d5f31857c52dafa3cdea79ea05dtom					/* is already taken!			*/
2479d5df125b895c5d5f31857c52dafa3cdea79ea05dtom#define VKI_I2C_TENBIT		0x0704	/* 0 for 7 bit addrs, != 0 for 10 bit	*/
2480d5df125b895c5d5f31857c52dafa3cdea79ea05dtom#define VKI_I2C_FUNCS		0x0705	/* Get the adapter functionality */
2481d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_RDWR		0x0707	/* Combined R/W transfer (one STOP only) */
2482d5df125b895c5d5f31857c52dafa3cdea79ea05dtom#define VKI_I2C_PEC		0x0708	/* != 0 for SMBus PEC                   */
2483d5df125b895c5d5f31857c52dafa3cdea79ea05dtom
2484d543d742b81199f0a633f872a64d122cc2cd2427tomstruct vki_i2c_msg {
2485d543d742b81199f0a633f872a64d122cc2cd2427tom	__vki_u16 addr;		/* slave address			*/
2486d543d742b81199f0a633f872a64d122cc2cd2427tom	__vki_u16 flags;
2487d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_M_TEN		0x0010	/* this is a ten bit chip address */
2488d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_M_RD		0x0001	/* read data, from slave to master */
2489d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_M_NOSTART	0x4000	/* if I2C_FUNC_PROTOCOL_MANGLING */
2490d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_M_REV_DIR_ADDR	0x2000	/* if I2C_FUNC_PROTOCOL_MANGLING */
2491d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_M_IGNORE_NAK	0x1000	/* if I2C_FUNC_PROTOCOL_MANGLING */
2492d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_M_NO_RD_ACK	0x0800	/* if I2C_FUNC_PROTOCOL_MANGLING */
2493d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_M_RECV_LEN	0x0400	/* length will be first received byte */
2494d543d742b81199f0a633f872a64d122cc2cd2427tom	__vki_u16 len;		/* msg length				*/
2495d543d742b81199f0a633f872a64d122cc2cd2427tom	__vki_u8 *buf;		/* pointer to msg data			*/
2496d543d742b81199f0a633f872a64d122cc2cd2427tom};
2497d543d742b81199f0a633f872a64d122cc2cd2427tom
2498d543d742b81199f0a633f872a64d122cc2cd2427tomstruct vki_i2c_rdwr_ioctl_data {
2499d543d742b81199f0a633f872a64d122cc2cd2427tom	struct vki_i2c_msg *msgs;	/* pointers to i2c_msgs */
2500d543d742b81199f0a633f872a64d122cc2cd2427tom	__vki_u32 nmsgs;		/* number of i2c_msgs */
2501d543d742b81199f0a633f872a64d122cc2cd2427tom};
2502d543d742b81199f0a633f872a64d122cc2cd2427tom
25037f4d7e42a880cd0872f93f5178a723beb56941a4tom//----------------------------------------------------------------------
25047f4d7e42a880cd0872f93f5178a723beb56941a4tom// From linux-2.6.20.1/include/linux/keyctl.h
25057f4d7e42a880cd0872f93f5178a723beb56941a4tom//----------------------------------------------------------------------
25067f4d7e42a880cd0872f93f5178a723beb56941a4tom
25077f4d7e42a880cd0872f93f5178a723beb56941a4tom/* keyctl commands */
25087f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_GET_KEYRING_ID	0	/* ask for a keyring's ID */
25097f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_JOIN_SESSION_KEYRING	1	/* join or start named session keyring */
25107f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_UPDATE		2	/* update a key */
25117f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_REVOKE		3	/* revoke a key */
25127f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_CHOWN		4	/* set ownership of a key */
25137f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_SETPERM		5	/* set perms on a key */
25147f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_DESCRIBE		6	/* describe a key */
25157f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_CLEAR		7	/* clear contents of a keyring */
25167f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_LINK			8	/* link a key into a keyring */
25177f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_UNLINK		9	/* unlink a key from a keyring */
25187f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_SEARCH		10	/* search for a key in a keyring */
25197f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_READ			11	/* read a key or keyring's contents */
25207f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_INSTANTIATE		12	/* instantiate a partially constructed key */
25217f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_NEGATE		13	/* negate a partially constructed key */
25227f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_SET_REQKEY_KEYRING	14	/* set default request-key keyring */
25237f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_SET_TIMEOUT		15	/* set key timeout */
25247f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_ASSUME_AUTHORITY	16	/* assume request_key() authorisation */
25257f4d7e42a880cd0872f93f5178a723beb56941a4tom
25267f4d7e42a880cd0872f93f5178a723beb56941a4tom/*--------------------------------------------------------------------*/
25277f4d7e42a880cd0872f93f5178a723beb56941a4tom// From linux-2.6.20.1/include/linux/key.h
25287f4d7e42a880cd0872f93f5178a723beb56941a4tom/*--------------------------------------------------------------------*/
25297f4d7e42a880cd0872f93f5178a723beb56941a4tom
25307f4d7e42a880cd0872f93f5178a723beb56941a4tom/* key handle serial number */
25317f4d7e42a880cd0872f93f5178a723beb56941a4tomtypedef vki_int32_t vki_key_serial_t;
25327f4d7e42a880cd0872f93f5178a723beb56941a4tom
25337f4d7e42a880cd0872f93f5178a723beb56941a4tom/* key handle permissions mask */
25347f4d7e42a880cd0872f93f5178a723beb56941a4tomtypedef vki_uint32_t vki_key_perm_t;
25357f4d7e42a880cd0872f93f5178a723beb56941a4tom
25369b27b82dac450baac59c4f8d1cd3589bedead53csewardj//----------------------------------------------------------------------
25379b27b82dac450baac59c4f8d1cd3589bedead53csewardj// From linux-2.6.24.7/include/linux/wireless.h
25389b27b82dac450baac59c4f8d1cd3589bedead53csewardj// (wireless extensions version 22, 2007-03-16)
25399b27b82dac450baac59c4f8d1cd3589bedead53csewardj//----------------------------------------------------------------------
25409b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25419b27b82dac450baac59c4f8d1cd3589bedead53csewardj/*
25429b27b82dac450baac59c4f8d1cd3589bedead53csewardj * [[Wireless extensions ioctls.]]
25439b27b82dac450baac59c4f8d1cd3589bedead53csewardj */
25449b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25459b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Wireless Identification */
25469b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWCOMMIT	0x8B00	/* Commit pending changes to driver */
25479b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWNAME		0x8B01	/* get name == wireless protocol */
25489b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25499b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Basic operations */
25509b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWNWID		0x8B02	/* set network id (pre-802.11) */
25519b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWNWID		0x8B03	/* get network id (the cell) */
25529b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWFREQ		0x8B04	/* set channel/frequency (Hz) */
25539b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWFREQ		0x8B05	/* get channel/frequency (Hz) */
25549b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWMODE		0x8B06	/* set operation mode */
25559b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWMODE		0x8B07	/* get operation mode */
25569b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWSENS		0x8B08	/* set sensitivity (dBm) */
25579b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWSENS		0x8B09	/* get sensitivity (dBm) */
25589b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25599b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Informative stuff */
25609b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWRANGE	0x8B0A	/* Unused */
25619b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWRANGE	0x8B0B	/* Get range of parameters */
25629b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWPRIV		0x8B0C	/* Unused */
25639b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWPRIV		0x8B0D	/* get private ioctl interface info */
25649b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWSTATS	0x8B0E	/* Unused */
25659b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWSTATS	0x8B0F	/* Get /proc/net/wireless stats */
25669b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25679b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Spy support (statistics per MAC address - used for Mobile IP support) */
25689b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWSPY		0x8B10	/* set spy addresses */
25699b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWSPY		0x8B11	/* get spy info (quality of link) */
25709b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWTHRSPY	0x8B12	/* set spy threshold (spy event) */
25719b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWTHRSPY	0x8B13	/* get spy threshold */
25729b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25739b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Access Point manipulation */
25749b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWAP		0x8B14	/* set access point MAC addresses */
25759b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWAP		0x8B15	/* get access point MAC addresses */
25769b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWAPLIST	0x8B17	/* Deprecated in favor of scanning */
25779b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWSCAN         0x8B18	/* trigger scanning (list cells) */
25789b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWSCAN         0x8B19	/* get scanning results */
25799b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25809b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* 802.11 specific support */
25819b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWESSID	0x8B1A	/* set ESSID (network name) */
25829b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWESSID	0x8B1B	/* get ESSID */
25839b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWNICKN	0x8B1C	/* set node name/nickname */
25849b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWNICKN	0x8B1D	/* get node name/nickname */
25859b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25869b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Other parameters useful in 802.11 and some other devices */
25879b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWRATE		0x8B20	/* set default bit rate (bps) */
25889b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWRATE		0x8B21	/* get default bit rate (bps) */
25899b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWRTS		0x8B22	/* set RTS/CTS threshold (bytes) */
25909b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWRTS		0x8B23	/* get RTS/CTS threshold (bytes) */
25919b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWFRAG		0x8B24	/* set fragmentation thr (bytes) */
25929b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWFRAG		0x8B25	/* get fragmentation thr (bytes) */
25939b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWTXPOW	0x8B26	/* set transmit power (dBm) */
25949b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWTXPOW	0x8B27	/* get transmit power (dBm) */
25959b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWRETRY	0x8B28	/* set retry limits and lifetime */
25969b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWRETRY	0x8B29	/* get retry limits and lifetime */
25979b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25989b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Encoding stuff (scrambling, hardware security, WEP...) */
25999b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWENCODE	0x8B2A	/* set encoding token & mode */
26009b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWENCODE	0x8B2B	/* get encoding token & mode */
26019b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26029b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Power saving stuff (power management, unicast and multicast) */
26039b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWPOWER	0x8B2C	/* set Power Management settings */
26049b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWPOWER	0x8B2D	/* get Power Management settings */
26059b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26069b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* WPA : Generic IEEE 802.11 informatiom element (e.g., for WPA/RSN/WMM). */
26079b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWGENIE	0x8B30		/* set generic IE */
26089b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWGENIE	0x8B31		/* get generic IE */
26099b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26109b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* WPA : IEEE 802.11 MLME requests */
26119b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWMLME		0x8B16	/* request MLME operation; uses
26129b27b82dac450baac59c4f8d1cd3589bedead53csewardj					 * struct iw_mlme */
26139b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* WPA : Authentication mode parameters */
26149b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWAUTH		0x8B32	/* set authentication mode params */
26159b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWAUTH		0x8B33	/* get authentication mode params */
26169b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26179b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* WPA : Extended version of encoding configuration */
26189b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWENCODEEXT	0x8B34	/* set encoding token & mode */
26199b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWENCODEEXT	0x8B35	/* get encoding token & mode */
26209b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26219b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* WPA2 : PMKSA cache management */
26229b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWPMKSA	0x8B36	/* PMKSA cache operation */
26239b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26249b27b82dac450baac59c4f8d1cd3589bedead53csewardj/*
26259b27b82dac450baac59c4f8d1cd3589bedead53csewardj * [[Payload for the wireless extensions ioctls.]]
26269b27b82dac450baac59c4f8d1cd3589bedead53csewardj */
26279b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26289b27b82dac450baac59c4f8d1cd3589bedead53csewardjstruct	vki_iw_param
26299b27b82dac450baac59c4f8d1cd3589bedead53csewardj{
26309b27b82dac450baac59c4f8d1cd3589bedead53csewardj  __vki_s32	value;		/* The value of the parameter itself */
26319b27b82dac450baac59c4f8d1cd3589bedead53csewardj  __vki_u8	fixed;		/* Hardware should not use auto select */
26329b27b82dac450baac59c4f8d1cd3589bedead53csewardj  __vki_u8	disabled;	/* Disable the feature */
26339b27b82dac450baac59c4f8d1cd3589bedead53csewardj  __vki_u16	flags;		/* Various specifc flags (if any) */
26349b27b82dac450baac59c4f8d1cd3589bedead53csewardj};
26359b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26369b27b82dac450baac59c4f8d1cd3589bedead53csewardjstruct	vki_iw_point
26379b27b82dac450baac59c4f8d1cd3589bedead53csewardj{
26389b27b82dac450baac59c4f8d1cd3589bedead53csewardj  void __user	*pointer;	/* Pointer to the data  (in user space) */
26399b27b82dac450baac59c4f8d1cd3589bedead53csewardj  __vki_u16	length;		/* number of fields or size in bytes */
26409b27b82dac450baac59c4f8d1cd3589bedead53csewardj  __vki_u16	flags;		/* Optional params */
26419b27b82dac450baac59c4f8d1cd3589bedead53csewardj};
26429b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26439b27b82dac450baac59c4f8d1cd3589bedead53csewardjstruct	vki_iw_freq
26449b27b82dac450baac59c4f8d1cd3589bedead53csewardj{
26459b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_s32	m;		/* Mantissa */
26469b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_s16	e;		/* Exponent */
26479b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_u8	i;		/* List index (when in range struct) */
26489b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_u8	flags;		/* Flags (fixed/auto) */
26499b27b82dac450baac59c4f8d1cd3589bedead53csewardj};
26509b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26519b27b82dac450baac59c4f8d1cd3589bedead53csewardjstruct	vki_iw_quality
26529b27b82dac450baac59c4f8d1cd3589bedead53csewardj{
26539b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_u8	qual;		/* link quality (%retries, SNR,
26549b27b82dac450baac59c4f8d1cd3589bedead53csewardj					   %missed beacons or better...) */
26559b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_u8	level;		/* signal level (dBm) */
26569b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_u8	noise;		/* noise level (dBm) */
26579b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_u8	updated;	/* Flags to know if updated */
26589b27b82dac450baac59c4f8d1cd3589bedead53csewardj};
26599b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26609b27b82dac450baac59c4f8d1cd3589bedead53csewardjunion	vki_iwreq_data
26619b27b82dac450baac59c4f8d1cd3589bedead53csewardj{
26629b27b82dac450baac59c4f8d1cd3589bedead53csewardj	/* Config - generic */
26639b27b82dac450baac59c4f8d1cd3589bedead53csewardj	char		name[VKI_IFNAMSIZ];
26649b27b82dac450baac59c4f8d1cd3589bedead53csewardj	/* Name : used to verify the presence of  wireless extensions.
26659b27b82dac450baac59c4f8d1cd3589bedead53csewardj	 * Name of the protocol/provider... */
26669b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26679b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_point	essid;	/* Extended network name */
26689b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	nwid;	/* network id (or domain - the cell) */
26699b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_freq	freq;	/* frequency or channel :
26709b27b82dac450baac59c4f8d1cd3589bedead53csewardj					 * 0-1000 = channel
26719b27b82dac450baac59c4f8d1cd3589bedead53csewardj					 * > 1000 = frequency in Hz */
26729b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26739b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	sens;	/* signal level threshold */
26749b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	bitrate;/* default bit rate */
26759b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	txpower;/* default transmit power */
26769b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	rts;	/* RTS threshold threshold */
26779b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	frag;	/* Fragmentation threshold */
26789b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_u32		mode;	/* Operation mode */
26799b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	retry;	/* Retry limits & lifetime */
26809b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26819b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_point	encoding; /* Encoding stuff : tokens */
26829b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	power;	/* PM duration/timeout */
26839b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_quality	qual;	/* Quality part of statistics */
26849b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26859b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_sockaddr ap_addr;	/* Access point address */
26869b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_sockaddr addr;	/* Destination address (hw/mac) */
26879b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26889b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	param;	/* Other small parameters */
26899b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_point	data;	/* Other large parameters */
26909b27b82dac450baac59c4f8d1cd3589bedead53csewardj};
26919b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26929b27b82dac450baac59c4f8d1cd3589bedead53csewardjstruct	vki_iwreq
26939b27b82dac450baac59c4f8d1cd3589bedead53csewardj{
26949b27b82dac450baac59c4f8d1cd3589bedead53csewardj	union
26959b27b82dac450baac59c4f8d1cd3589bedead53csewardj	{
26969b27b82dac450baac59c4f8d1cd3589bedead53csewardj		char ifrn_name[VKI_IFNAMSIZ];	/* if name, e.g. "eth0" */
26979b27b82dac450baac59c4f8d1cd3589bedead53csewardj	} ifr_ifrn;
26989b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26999b27b82dac450baac59c4f8d1cd3589bedead53csewardj	/* Data part (defined just above) */
27009b27b82dac450baac59c4f8d1cd3589bedead53csewardj	union	vki_iwreq_data	u;
27019b27b82dac450baac59c4f8d1cd3589bedead53csewardj};
27029b27b82dac450baac59c4f8d1cd3589bedead53csewardj
27033fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom/*--------------------------------------------------------------------*/
2704c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom// From linux-2.6.31.5/include/linux/perf_event.h
27053fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom/*--------------------------------------------------------------------*/
27063fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
2707c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tomstruct vki_perf_event_attr {
27083fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
27093fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	/*
27103fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	 * Major type: hardware/software/tracepoint/etc.
27113fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	 */
27123fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	__vki_u32			type;
27133fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
27143fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	/*
27153fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	 * Size of the attr structure, for fwd/bwd compat.
27163fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	 */
27173fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	__vki_u32			size;
27183fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
27193fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	/*
27203fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	 * Type specific configuration information.
27213fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	 */
27223fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	__vki_u64			config;
27233fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
27243fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	union {
27253fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom		__vki_u64		sample_period;
27263fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom		__vki_u64		sample_freq;
27273fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	};
27283fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
27293fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	__vki_u64			sample_type;
27303fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	__vki_u64			read_format;
27313fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
27323fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	__vki_u64			disabled       :  1, /* off by default        */
27333fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					inherit	       :  1, /* children inherit it   */
27343fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					pinned	       :  1, /* must always be on PMU */
27353fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					exclusive      :  1, /* only group on PMU     */
27363fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					exclude_user   :  1, /* don't count user      */
27373fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					exclude_kernel :  1, /* ditto kernel          */
27383fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					exclude_hv     :  1, /* ditto hypervisor      */
27393fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					exclude_idle   :  1, /* don't count when idle */
27403fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					mmap           :  1, /* include mmap data     */
27413fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					comm	       :  1, /* include comm data     */
27423fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					freq           :  1, /* use freq, not period  */
27433fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					inherit_stat   :  1, /* per task counts       */
27443fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					enable_on_exec :  1, /* next exec enables     */
27453fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					task           :  1, /* trace fork/exit       */
2746c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					watermark      :  1, /* wakeup_watermark      */
2747c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					/*
2748c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 * precise_ip:
2749c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 *
2750c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 *  0 - SAMPLE_IP can have arbitrary skid
2751c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 *  1 - SAMPLE_IP must have constant skid
2752c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 *  2 - SAMPLE_IP requested to have 0 skid
2753c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 *  3 - SAMPLE_IP must have 0 skid
2754c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 *
2755c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 *  See also PERF_RECORD_MISC_EXACT_IP
2756c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 */
2757c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					precise_ip     :  2, /* skid constraint       */
2758c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					mmap_data      :  1, /* non-exec mmap data    */
2759c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					sample_id_all  :  1, /* sample_type all events */
2760c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom
2761c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					__reserved_1   : 45;
27623fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
2763c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom	union {
2764c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom		__vki_u32		wakeup_events;	  /* wakeup every n events */
2765c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom		__vki_u32		wakeup_watermark; /* bytes before wakeup   */
2766c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom	};
27673fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
2768c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom	__vki_u32			bp_type;
2769c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom	union {
2770c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom		__vki_u64		bp_addr;
2771c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom		__vki_u64		config1; /* extension of config */
2772c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom	};
2773c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom	union {
2774c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom		__vki_u64		bp_len;
2775c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom		__vki_u64		config2; /* extension of config1 */
2776c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom	};
27773fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom};
27789b27b82dac450baac59c4f8d1cd3589bedead53csewardj
2779472a34b16c3703e8d3adcb12abd194e20a021963tom/*--------------------------------------------------------------------*/
2780472a34b16c3703e8d3adcb12abd194e20a021963tom// From linux-2.6.32.4/include/linux/getcpu.h
2781472a34b16c3703e8d3adcb12abd194e20a021963tom/*--------------------------------------------------------------------*/
2782472a34b16c3703e8d3adcb12abd194e20a021963tom
2783472a34b16c3703e8d3adcb12abd194e20a021963tomstruct vki_getcpu_cache {
2784472a34b16c3703e8d3adcb12abd194e20a021963tom	unsigned long blob[128 / sizeof(long)];
2785472a34b16c3703e8d3adcb12abd194e20a021963tom};
2786472a34b16c3703e8d3adcb12abd194e20a021963tom
27870ee313efc43e3e6ed6bfedbf211769b07dffbc65tom//----------------------------------------------------------------------
27880ee313efc43e3e6ed6bfedbf211769b07dffbc65tom// From linux-2.6.33.3/include/linux/input.h
27890ee313efc43e3e6ed6bfedbf211769b07dffbc65tom//----------------------------------------------------------------------
27900ee313efc43e3e6ed6bfedbf211769b07dffbc65tom
27910ee313efc43e3e6ed6bfedbf211769b07dffbc65tom/*
27920ee313efc43e3e6ed6bfedbf211769b07dffbc65tom * IOCTLs (0x00 - 0x7f)
27930ee313efc43e3e6ed6bfedbf211769b07dffbc65tom */
27940ee313efc43e3e6ed6bfedbf211769b07dffbc65tom
27950ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGNAME(len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x06, len)		/* get device name */
27960ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGPHYS(len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x07, len)		/* get physical location */
27970ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGUNIQ(len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x08, len)		/* get unique identifier */
27980ee313efc43e3e6ed6bfedbf211769b07dffbc65tom
27990ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGKEY(len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x18, len)		/* get global keystate */
28000ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGLED(len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x19, len)		/* get all LEDs */
28010ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGSND(len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x1a, len)		/* get all sounds status */
28020ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGSW(len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x1b, len)		/* get all switch states */
28030ee313efc43e3e6ed6bfedbf211769b07dffbc65tom
28040ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGBIT(ev,len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x20 + ev, len)	/* get event bits */
28050ee313efc43e3e6ed6bfedbf211769b07dffbc65tom
28060ee313efc43e3e6ed6bfedbf211769b07dffbc65tom/*
28070ee313efc43e3e6ed6bfedbf211769b07dffbc65tom * Event types
28080ee313efc43e3e6ed6bfedbf211769b07dffbc65tom */
28090ee313efc43e3e6ed6bfedbf211769b07dffbc65tom
28100ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_SYN		0x00
28110ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_KEY		0x01
28120ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_REL		0x02
28130ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_ABS		0x03
28140ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_MSC		0x04
28150ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_SW		0x05
28160ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_LED		0x11
28170ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_SND		0x12
28180ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_REP		0x14
28190ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_FF		0x15
28200ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_PWR		0x16
28210ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_FF_STATUS	0x17
28220ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_MAX		0x1f
28230ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_CNT		(VKI_EV_MAX+1)
28240ee313efc43e3e6ed6bfedbf211769b07dffbc65tom
28256bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom//----------------------------------------------------------------------
28266bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom// From linux-2.6.39-rc2/include/asm_generic/ioctls.h
28276bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom//----------------------------------------------------------------------
28286bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom
28296bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom#ifndef VKI_FIOQSIZE
28306bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom#define VKI_FIOQSIZE 0x5460     /* Value differs on some platforms */
28316bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom#endif
28326bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom
2833a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj//----------------------------------------------------------------------
2834a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj// From kernel/common/include/linux/ashmem.h
2835a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj//----------------------------------------------------------------------
2836a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2837a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#if defined(VGPV_arm_linux_android)
2838a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2839a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_NAME_LEN 256
2840a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2841a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_NAME_DEF "dev/ashmem"
2842a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2843a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_NOT_PURGED 0
2844a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_WAS_PURGED 1
2845a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2846a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_IS_UNPINNED 0
2847a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_IS_PINNED 1
2848a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2849a3e7a48d5767431328115ee6fa05ce7855830aa9sewardjstruct vki_ashmem_pin {
2850a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj   vki_uint32_t offset;
2851a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj   vki_uint32_t len;
2852a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj};
2853a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2854a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define __VKI_ASHMEMIOC 0x77
2855a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2856a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_SET_NAME _VKI_IOW(__VKI_ASHMEMIOC, 1, char[VKI_ASHMEM_NAME_LEN])
2857a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_GET_NAME _VKI_IOR(__VKI_ASHMEMIOC, 2, char[VKI_ASHMEM_NAME_LEN])
2858a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_SET_SIZE _VKI_IOW(__VKI_ASHMEMIOC, 3, vki_size_t)
2859a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_GET_SIZE _VKI_IO(__VKI_ASHMEMIOC, 4)
2860a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_SET_PROT_MASK _VKI_IOW(__VKI_ASHMEMIOC, 5, unsigned long)
2861a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_GET_PROT_MASK _VKI_IO(__VKI_ASHMEMIOC, 6)
2862a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_PIN _VKI_IOW(__VKI_ASHMEMIOC, 7, struct vki_ashmem_pin)
2863a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_UNPIN _VKI_IOW(__VKI_ASHMEMIOC, 8, struct vki_ashmem_pin)
2864a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_GET_PIN_STATUS _VKI_IO(__VKI_ASHMEMIOC, 9)
2865a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_PURGE_ALL_CACHES _VKI_IO(__VKI_ASHMEMIOC, 10)
2866a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2867a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj//----------------------------------------------------------------------
2868a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj// From kernel/common/include/linux/binder.h
2869a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj//----------------------------------------------------------------------
2870a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2871a3e7a48d5767431328115ee6fa05ce7855830aa9sewardjstruct vki_binder_write_read {
2872a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj signed long write_size;
2873a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj signed long write_consumed;
2874a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj unsigned long write_buffer;
2875a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj signed long read_size;
2876a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj signed long read_consumed;
2877a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj unsigned long read_buffer;
2878a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj};
2879a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2880a3e7a48d5767431328115ee6fa05ce7855830aa9sewardjstruct vki_binder_version {
2881a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj signed long protocol_version;
2882a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj};
2883a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2884a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_BINDER_WRITE_READ _VKI_IOWR('b', 1, struct vki_binder_write_read)
2885a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_BINDER_SET_IDLE_TIMEOUT _VKI_IOW('b', 3, vki_int64_t)
2886a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_BINDER_SET_MAX_THREADS _VKI_IOW('b', 5, vki_size_t)
2887a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_BINDER_SET_IDLE_PRIORITY _VKI_IOW('b', 6, int)
2888a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_BINDER_SET_CONTEXT_MGR _VKI_IOW('b', 7, int)
2889a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_BINDER_THREAD_EXIT _VKI_IOW('b', 8, int)
2890a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_BINDER_VERSION _VKI_IOWR('b', 9, struct vki_binder_version)
2891a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2892a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#endif /* defined(VGPV_arm_linux_android) */
2893a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
28948236fe6f256ea0e078a1a458a4690eec10b9a2c7tom//----------------------------------------------------------------------
28958236fe6f256ea0e078a1a458a4690eec10b9a2c7tom// From linux-3.0.4/include/net/bluetooth/bluetooth.h
28968236fe6f256ea0e078a1a458a4690eec10b9a2c7tom//----------------------------------------------------------------------
28978236fe6f256ea0e078a1a458a4690eec10b9a2c7tom
28988236fe6f256ea0e078a1a458a4690eec10b9a2c7tomtypedef struct {
28998236fe6f256ea0e078a1a458a4690eec10b9a2c7tom   __vki_u8 b[6];
29008236fe6f256ea0e078a1a458a4690eec10b9a2c7tom} __vki_packed vki_bdaddr_t;
29018236fe6f256ea0e078a1a458a4690eec10b9a2c7tom
29028236fe6f256ea0e078a1a458a4690eec10b9a2c7tom//----------------------------------------------------------------------
29038236fe6f256ea0e078a1a458a4690eec10b9a2c7tom// From linux-3.0.4/include/net/bluetooth/hci.h
29048236fe6f256ea0e078a1a458a4690eec10b9a2c7tom//----------------------------------------------------------------------
29058236fe6f256ea0e078a1a458a4690eec10b9a2c7tom
29068236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCIDEVUP        _VKI_IOW('H', 201, int)
29078236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCIDEVDOWN      _VKI_IOW('H', 202, int)
29088236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCIDEVRESET     _VKI_IOW('H', 203, int)
29098236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCIDEVRESTAT    _VKI_IOW('H', 204, int)
29108236fe6f256ea0e078a1a458a4690eec10b9a2c7tom
29118236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCIGETDEVLIST   _VKI_IOR('H', 210, int)
29128236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCIGETDEVINFO   _VKI_IOR('H', 211, int)
29138236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCIGETCONNLIST  _VKI_IOR('H', 212, int)
29148236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCIGETCONNINFO  _VKI_IOR('H', 213, int)
29158236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCIGETAUTHINFO  _VKI_IOR('H', 215, int)
29168236fe6f256ea0e078a1a458a4690eec10b9a2c7tom
29178236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCISETRAW       _VKI_IOW('H', 220, int)
29188236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCISETSCAN      _VKI_IOW('H', 221, int)
29198236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCISETAUTH      _VKI_IOW('H', 222, int)
29208236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCISETENCRYPT   _VKI_IOW('H', 223, int)
29218236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCISETPTYPE     _VKI_IOW('H', 224, int)
29228236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCISETLINKPOL   _VKI_IOW('H', 225, int)
29238236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCISETLINKMODE  _VKI_IOW('H', 226, int)
29248236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCISETACLMTU    _VKI_IOW('H', 227, int)
29258236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCISETSCOMTU    _VKI_IOW('H', 228, int)
29268236fe6f256ea0e078a1a458a4690eec10b9a2c7tom
29278236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCIBLOCKADDR    _VKI_IOW('H', 230, int)
29288236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCIUNBLOCKADDR  _VKI_IOW('H', 231, int)
29298236fe6f256ea0e078a1a458a4690eec10b9a2c7tom
29308236fe6f256ea0e078a1a458a4690eec10b9a2c7tom#define VKI_HCIINQUIRY      _VKI_IOR('H', 240, int)
29318236fe6f256ea0e078a1a458a4690eec10b9a2c7tom
29328236fe6f256ea0e078a1a458a4690eec10b9a2c7tomstruct vki_inquiry_info {
29338236fe6f256ea0e078a1a458a4690eec10b9a2c7tom   vki_bdaddr_t bdaddr;
29348236fe6f256ea0e078a1a458a4690eec10b9a2c7tom   __vki_u8     pscan_rep_mode;
29358236fe6f256ea0e078a1a458a4690eec10b9a2c7tom   __vki_u8     pscan_period_mode;
29368236fe6f256ea0e078a1a458a4690eec10b9a2c7tom   __vki_u8     pscan_mode;
29378236fe6f256ea0e078a1a458a4690eec10b9a2c7tom   __vki_u8     dev_class[3];
29388236fe6f256ea0e078a1a458a4690eec10b9a2c7tom   __vki_le16   clock_offset;
29398236fe6f256ea0e078a1a458a4690eec10b9a2c7tom} __vki_packed;
29408236fe6f256ea0e078a1a458a4690eec10b9a2c7tom
29418236fe6f256ea0e078a1a458a4690eec10b9a2c7tomstruct vki_hci_inquiry_req {
29428236fe6f256ea0e078a1a458a4690eec10b9a2c7tom   __vki_u16 dev_id;
29438236fe6f256ea0e078a1a458a4690eec10b9a2c7tom   __vki_u16 flags;
29448236fe6f256ea0e078a1a458a4690eec10b9a2c7tom   __vki_u8  lap[3];
29458236fe6f256ea0e078a1a458a4690eec10b9a2c7tom   __vki_u8  length;
29468236fe6f256ea0e078a1a458a4690eec10b9a2c7tom   __vki_u8  num_rsp;
29478236fe6f256ea0e078a1a458a4690eec10b9a2c7tom};
29488236fe6f256ea0e078a1a458a4690eec10b9a2c7tom
294965bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra//----------------------------------------------------------------------
295065bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra// From linux-3.4/include/linux/kvm.h
295165bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra//----------------------------------------------------------------------
295265bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define KVMIO 0xAE
295365bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra
295465bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_GET_API_VERSION       _VKI_IO(KVMIO,   0x00)
295565bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_CREATE_VM             _VKI_IO(KVMIO,   0x01) /* returns a VM fd */
295665bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_CHECK_EXTENSION       _VKI_IO(KVMIO,   0x03)
295765bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_GET_VCPU_MMAP_SIZE    _VKI_IO(KVMIO,   0x04) /* in bytes */
295865bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_S390_ENABLE_SIE       _VKI_IO(KVMIO,   0x06)
295965bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_CREATE_VCPU           _VKI_IO(KVMIO,   0x41)
296065bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_SET_NR_MMU_PAGES      _VKI_IO(KVMIO,   0x44)
296165bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_GET_NR_MMU_PAGES      _VKI_IO(KVMIO,   0x45)
296265bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_SET_TSS_ADDR          _VKI_IO(KVMIO,   0x47)
296365bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_CREATE_IRQCHIP        _VKI_IO(KVMIO,   0x60)
296465bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_CREATE_PIT            _VKI_IO(KVMIO,   0x64)
296565bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_REINJECT_CONTROL      _VKI_IO(KVMIO,   0x71)
296665bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_SET_BOOT_CPU_ID       _VKI_IO(KVMIO,   0x78)
296765bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_SET_TSC_KHZ           _VKI_IO(KVMIO,  0xa2)
296865bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_GET_TSC_KHZ           _VKI_IO(KVMIO,  0xa3)
296965bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_RUN                   _VKI_IO(KVMIO,   0x80)
297065bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_S390_INITIAL_RESET    _VKI_IO(KVMIO,   0x97)
297165bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra#define VKI_KVM_NMI                   _VKI_IO(KVMIO,   0x9a)
297265bdbe43c02a3eb95a9bda4f82a5a5b61e64b296cborntra
29734cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj#endif // __VKI_LINUX_H
29744cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj
297573b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--------------------------------------------------------------------*/
297673b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--- end                                                          ---*/
297773b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--------------------------------------------------------------------*/
2978