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