vki-linux.h revision d543d742b81199f0a633f872a64d122cc2cd2427
173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
273b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--------------------------------------------------------------------*/
34de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn/*--- Linux-specific kernel interface.                 vki-linux.h ---*/
473b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--------------------------------------------------------------------*/
573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
673b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*
7b9c427c63a278cc612ae0ec573be7bb1abaa447fnjn   This file is part of Valgrind, a dynamic binary instrumentation
8b9c427c63a278cc612ae0ec573be7bb1abaa447fnjn   framework.
973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
10ec062e8d96a361af9905b5447027819dfbfee01asewardj   Copyright (C) 2000-2011 Julian Seward
1173b526fb4af0f60634f0078583d92b931d5c0eebnethercote      jseward@acm.org
1273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
1373b526fb4af0f60634f0078583d92b931d5c0eebnethercote   This program is free software; you can redistribute it and/or
1473b526fb4af0f60634f0078583d92b931d5c0eebnethercote   modify it under the terms of the GNU General Public License as
1573b526fb4af0f60634f0078583d92b931d5c0eebnethercote   published by the Free Software Foundation; either version 2 of the
1673b526fb4af0f60634f0078583d92b931d5c0eebnethercote   License, or (at your option) any later version.
1773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
1873b526fb4af0f60634f0078583d92b931d5c0eebnethercote   This program is distributed in the hope that it will be useful, but
1973b526fb4af0f60634f0078583d92b931d5c0eebnethercote   WITHOUT ANY WARRANTY; without even the implied warranty of
2073b526fb4af0f60634f0078583d92b931d5c0eebnethercote   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
2173b526fb4af0f60634f0078583d92b931d5c0eebnethercote   General Public License for more details.
2273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
2373b526fb4af0f60634f0078583d92b931d5c0eebnethercote   You should have received a copy of the GNU General Public License
2473b526fb4af0f60634f0078583d92b931d5c0eebnethercote   along with this program; if not, write to the Free Software
2573b526fb4af0f60634f0078583d92b931d5c0eebnethercote   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
2673b526fb4af0f60634f0078583d92b931d5c0eebnethercote   02111-1307, USA.
2773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
2873b526fb4af0f60634f0078583d92b931d5c0eebnethercote   The GNU General Public License is contained in the file COPYING.
2973b526fb4af0f60634f0078583d92b931d5c0eebnethercote*/
3073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
3173b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* This file defines types and constants for the kernel interface, and to
3273b526fb4af0f60634f0078583d92b931d5c0eebnethercote   make that clear everything is prefixed VKI_/vki_.
3373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
3473b526fb4af0f60634f0078583d92b931d5c0eebnethercote   All code is copied verbatim from kernel source files, except that:
3573b526fb4af0f60634f0078583d92b931d5c0eebnethercote   - VKI_/vki_ prefixes are added
3673b526fb4af0f60634f0078583d92b931d5c0eebnethercote   - some extra explanatory comments are included;  they are all within
3773b526fb4af0f60634f0078583d92b931d5c0eebnethercote     "[[ ]]"
3873b526fb4af0f60634f0078583d92b931d5c0eebnethercote   - for some types, we only care about the size;  for a few of them (big
3973b526fb4af0f60634f0078583d92b931d5c0eebnethercote     ones that are painful to fully drag in here), a VKI_SIZEOF_* constant
4073b526fb4af0f60634f0078583d92b931d5c0eebnethercote     is used.
4173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
4273b526fb4af0f60634f0078583d92b931d5c0eebnethercote   The files the code is taken from is indicated.
4373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
4473b526fb4af0f60634f0078583d92b931d5c0eebnethercote   Note especially that the types are not the glibc versions, many of which
4573b526fb4af0f60634f0078583d92b931d5c0eebnethercote   are different to those in here.
4673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
47ac7924c7eedce947578c571ae419c4c84eaa5aefnjn   Also note that this file contains all the generic header info, ie. that
48edef146c47eda894495d2b3b71b32b10349f8d91sewardj   from linux/include/linux/ *.h.  The arch-specific header info, eg. that
494de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn   from linux/include/asm-i386/ *.h, is in vki-$PLATFORM.h and
504de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn   vki_posixtypes-$PLATFORM.h.  (Two files are required to avoid
51ac7924c7eedce947578c571ae419c4c84eaa5aefnjn   circular dependencies between the generic VKI header and the
52ac7924c7eedce947578c571ae419c4c84eaa5aefnjn   arch-specific VKI header.  It's possible in the future, as more stuff
53ac7924c7eedce947578c571ae419c4c84eaa5aefnjn   gets pulled in, that we might have to split files up some more to avoid
54ac7924c7eedce947578c571ae419c4c84eaa5aefnjn   further circular dependencies.)
55ac7924c7eedce947578c571ae419c4c84eaa5aefnjn
5673b526fb4af0f60634f0078583d92b931d5c0eebnethercote   Finally, note that it is assumed that __KERNEL__ is set for all these
5773b526fb4af0f60634f0078583d92b931d5c0eebnethercote   definitions, which affects some of them.
5873b526fb4af0f60634f0078583d92b931d5c0eebnethercote*/
5973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
604cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj/* The structure is (aiui, jrs 20060504):
614cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj
624cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj     #include plat-specific posix types (vki-posixtypes-ARCH-linux.h)
634cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj
644cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj     Lots more types, structs, consts, in this file
654cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj
664cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj     #include other plat-specific stuff (vki-ARCH-linux.h)
674cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj
684cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj     Even more types, structs, consts, in this file
694cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj
704cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj   The system call numbers are dealt with by
714cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj   pub_{core,tool}_vkiscnums.h, not via pub_{core,tool}_vki.h, which
724cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj   is what this file is part of.
734cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj*/
744cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj
754de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#ifndef __VKI_LINUX_H
764de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#define __VKI_LINUX_H
7773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
7873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
7973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// Arch-specific POSIX types
8073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
8173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
824de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#if defined(VGA_x86)
834cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj#  include "vki-posixtypes-x86-linux.h"
844de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#elif defined(VGA_amd64)
854cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj#  include "vki-posixtypes-amd64-linux.h"
8685665ca6fa29dd64754dabe50eb98f25896e752acerion#elif defined(VGA_ppc32)
874cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj#  include "vki-posixtypes-ppc32-linux.h"
882c48c7b0a453d32375a4df17e153011b797ef28csewardj#elif defined(VGA_ppc64)
894cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj#  include "vki-posixtypes-ppc64-linux.h"
9059570ffbe31930ab4d678754daaeec0715117a3dsewardj#elif defined(VGA_arm)
9159570ffbe31930ab4d678754daaeec0715117a3dsewardj#  include "vki-posixtypes-arm-linux.h"
92b5b87408c0c99f9f6938d8cd921e2a5f420577c4sewardj#elif defined(VGA_s390x)
93b5b87408c0c99f9f6938d8cd921e2a5f420577c4sewardj#  include "vki-posixtypes-s390x-linux.h"
944de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#else
954de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#  error Unknown platform
964de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#endif
9773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
9873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
9907b168da387c8cf6e250fa042fc93dcc80e32752bart// VKI_STATIC_ASSERT(). Inspired by BUILD_BUG_ON() from
10007b168da387c8cf6e250fa042fc93dcc80e32752bart// linux-2.6.34/include/linux/kernel.h
10107b168da387c8cf6e250fa042fc93dcc80e32752bart//----------------------------------------------------------------------
10207b168da387c8cf6e250fa042fc93dcc80e32752bart
10307b168da387c8cf6e250fa042fc93dcc80e32752bart/*
10407b168da387c8cf6e250fa042fc93dcc80e32752bart * Evaluates to zero if 'expr' is true and forces a compilation error if
10507b168da387c8cf6e250fa042fc93dcc80e32752bart * 'expr' is false. Can be used in a context where no comma expressions
10607b168da387c8cf6e250fa042fc93dcc80e32752bart * are allowed.
10707b168da387c8cf6e250fa042fc93dcc80e32752bart */
10807b168da387c8cf6e250fa042fc93dcc80e32752bart#ifdef __cplusplus
10907b168da387c8cf6e250fa042fc93dcc80e32752barttemplate <bool b> struct vki_static_assert { int m_bitfield:(2*b-1); };
11007b168da387c8cf6e250fa042fc93dcc80e32752bart#define VKI_STATIC_ASSERT(expr)                         \
11107b168da387c8cf6e250fa042fc93dcc80e32752bart    (sizeof(vki_static_assert<(expr)>) - sizeof(int))
11207b168da387c8cf6e250fa042fc93dcc80e32752bart#else
11307b168da387c8cf6e250fa042fc93dcc80e32752bart#define VKI_STATIC_ASSERT(expr) (sizeof(struct { int:-!(expr); }))
11407b168da387c8cf6e250fa042fc93dcc80e32752bart#endif
11507b168da387c8cf6e250fa042fc93dcc80e32752bart
11607b168da387c8cf6e250fa042fc93dcc80e32752bart//----------------------------------------------------------------------
11707b168da387c8cf6e250fa042fc93dcc80e32752bart// Based on _IOC_TYPECHECK() from linux-2.6.34/asm-generic/ioctl.h
11807b168da387c8cf6e250fa042fc93dcc80e32752bart//----------------------------------------------------------------------
11907b168da387c8cf6e250fa042fc93dcc80e32752bart
12007b168da387c8cf6e250fa042fc93dcc80e32752bart/* provoke compile error for invalid uses of size argument */
12107b168da387c8cf6e250fa042fc93dcc80e32752bart#define _VKI_IOC_TYPECHECK(t)                                           \
12207b168da387c8cf6e250fa042fc93dcc80e32752bart    (VKI_STATIC_ASSERT((sizeof(t) == sizeof(t[1])                       \
12307b168da387c8cf6e250fa042fc93dcc80e32752bart                        && sizeof(t) < (1 << _VKI_IOC_SIZEBITS)))       \
12407b168da387c8cf6e250fa042fc93dcc80e32752bart     + sizeof(t))
12507b168da387c8cf6e250fa042fc93dcc80e32752bart
12607b168da387c8cf6e250fa042fc93dcc80e32752bart//----------------------------------------------------------------------
12773b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/compiler.h
12873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
12973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
13073b526fb4af0f60634f0078583d92b931d5c0eebnethercote# define __user
13173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
13273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
13373b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/posix_types.h
13473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
13573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
136f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#undef __VKI_NFDBITS
137f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#define __VKI_NFDBITS	(8 * sizeof(unsigned long))
138f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote
139f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#undef __VKI_FD_SETSIZE
140f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#define __VKI_FD_SETSIZE	1024
141f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote
142f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#undef __VKI_FDSET_LONGS
143f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#define __VKI_FDSET_LONGS	(__VKI_FD_SETSIZE/__VKI_NFDBITS)
144f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote
145f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#undef __VKI_FDELT
146f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#define	__VKI_FDELT(d)	((d) / __VKI_NFDBITS)
147f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote
148f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#undef __VKI_FDMASK
149f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote#define	__VKI_FDMASK(d)	(1UL << ((d) % __VKI_NFDBITS))
150f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote
151f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercotetypedef struct {
152f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote	unsigned long fds_bits [__VKI_FDSET_LONGS];
153f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote} __vki_kernel_fd_set;
154f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercote
15573b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef int __vki_kernel_key_t;
156330abb517e58fd0ee96fda7fb8563e32e029a63enethercotetypedef int __vki_kernel_mqd_t;
15773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
15873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
15973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/types.h
16073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
16173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
162f1049bfd7145c4d8ee333bb2a714700e1ab3a049nethercotetypedef __vki_kernel_fd_set	vki_fd_set;
16373b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_mode_t	vki_mode_t;
16473b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_off_t	vki_off_t;
16573b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_pid_t	vki_pid_t;
16673b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_key_t	vki_key_t;
16773b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_suseconds_t	vki_suseconds_t;
16873b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_timer_t	vki_timer_t;
16992b2fd542e89939b46edfa5c424af81f4a3bfe0cnethercotetypedef __vki_kernel_clockid_t	vki_clockid_t;
170330abb517e58fd0ee96fda7fb8563e32e029a63enethercotetypedef __vki_kernel_mqd_t	vki_mqd_t;
17173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
17273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Nb: it's a bit unclear due to a #ifdef, but I think this is right. --njn]]
17373b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_uid32_t	vki_uid_t;
17473b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_gid32_t	vki_gid_t;
17573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
176c6851dde1b46166417a2bdb096c05818f5f07f09nethercotetypedef __vki_kernel_old_uid_t	vki_old_uid_t;
177c6851dde1b46166417a2bdb096c05818f5f07f09nethercotetypedef __vki_kernel_old_gid_t	vki_old_gid_t;
178c6851dde1b46166417a2bdb096c05818f5f07f09nethercote
17973b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_loff_t	vki_loff_t;
18073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
18173b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_size_t	vki_size_t;
18273b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_time_t	vki_time_t;
18373b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_clock_t	vki_clock_t;
18473b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef __vki_kernel_caddr_t	vki_caddr_t;
18573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
1865b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercotetypedef unsigned long           vki_u_long;
1875b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercote
1887f7e4d1ac0c4ea8bf771e5490b69d0e4d619dfe9nethercotetypedef unsigned int	        vki_uint;
1897f7e4d1ac0c4ea8bf771e5490b69d0e4d619dfe9nethercote
19073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
19173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// Now the rest of the arch-specific stuff
19273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
19373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
1944de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#if defined(VGA_x86)
1954de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#  include "vki-x86-linux.h"
1964de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#elif defined(VGA_amd64)
1974de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#  include "vki-amd64-linux.h"
19885665ca6fa29dd64754dabe50eb98f25896e752acerion#elif defined(VGA_ppc32)
19985665ca6fa29dd64754dabe50eb98f25896e752acerion#  include "vki-ppc32-linux.h"
2002c48c7b0a453d32375a4df17e153011b797ef28csewardj#elif defined(VGA_ppc64)
2012c48c7b0a453d32375a4df17e153011b797ef28csewardj#  include "vki-ppc64-linux.h"
20259570ffbe31930ab4d678754daaeec0715117a3dsewardj#elif defined(VGA_arm)
20359570ffbe31930ab4d678754daaeec0715117a3dsewardj#  include "vki-arm-linux.h"
204b5b87408c0c99f9f6938d8cd921e2a5f420577c4sewardj#elif defined(VGA_s390x)
205b5b87408c0c99f9f6938d8cd921e2a5f420577c4sewardj#  include "vki-s390x-linux.h"
2064de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#else
2074de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#  error Unknown platform
2084de47b1c9bfe84ddd76a9e71e486c5085c51e3a8njn#endif
20973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
21073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
2117f4d7e42a880cd0872f93f5178a723beb56941a4tom// From linux-2.6.20.1/include/linux/types.h
2127f4d7e42a880cd0872f93f5178a723beb56941a4tom//----------------------------------------------------------------------
2137f4d7e42a880cd0872f93f5178a723beb56941a4tom
2147f4d7e42a880cd0872f93f5178a723beb56941a4tomtypedef		__vki_s32	vki_int32_t;
215a3e7a48d5767431328115ee6fa05ce7855830aa9sewardjtypedef		__vki_s64	vki_int64_t;
2167f4d7e42a880cd0872f93f5178a723beb56941a4tom
2179b27b82dac450baac59c4f8d1cd3589bedead53csewardjtypedef		__vki_u8	vki_uint8_t;
2189b27b82dac450baac59c4f8d1cd3589bedead53csewardjtypedef		__vki_u16	vki_uint16_t;
2197f4d7e42a880cd0872f93f5178a723beb56941a4tomtypedef		__vki_u32	vki_uint32_t;
2207f4d7e42a880cd0872f93f5178a723beb56941a4tom
2217f4d7e42a880cd0872f93f5178a723beb56941a4tom//----------------------------------------------------------------------
22273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/limits.h
22373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
22473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
22573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PATH_MAX       4096	/* # chars in a path name including nul */
22673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
22773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
22873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/kernel.h
22973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
23073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
23173b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sysinfo {
23273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long uptime;			/* Seconds since boot */
23373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long loads[3];		/* 1, 5, and 15 minute load averages */
23473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long totalram;		/* Total usable main memory size */
23573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long freeram;		/* Available memory size */
23673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long sharedram;	/* Amount of shared memory */
23773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long bufferram;	/* Memory used by buffers */
23873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long totalswap;	/* Total swap space size */
23973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long freeswap;		/* swap space still available */
24073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short procs;		/* Number of current processes */
24173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short pad;		/* explicit padding for m68k */
24273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long totalhigh;	/* Total high memory size */
24373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long freehigh;		/* Available high memory size */
24473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int mem_unit;		/* Memory unit size in bytes */
24573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char _f[20-2*sizeof(long)-sizeof(int)];	/* Padding: libc5 uses this.. */
24673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
24773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
24873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
24973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/time.h
25073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
25173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
25285b1ac7d3ba74ad66e975a0bfd8b1cb9a9d06bb9bart#define VKI_CLOCK_REALTIME            0
25385b1ac7d3ba74ad66e975a0bfd8b1cb9a9d06bb9bart#define VKI_CLOCK_MONOTONIC           1
25485b1ac7d3ba74ad66e975a0bfd8b1cb9a9d06bb9bart#define VKI_CLOCK_PROCESS_CPUTIME_ID  2
25585b1ac7d3ba74ad66e975a0bfd8b1cb9a9d06bb9bart#define VKI_CLOCK_THREAD_CPUTIME_ID   3
25685b1ac7d3ba74ad66e975a0bfd8b1cb9a9d06bb9bart
25773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_timespec {
25873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_time_t	tv_sec;		/* seconds */
25973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long		tv_nsec;	/* nanoseconds */
26073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
26173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
26273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_timeval {
26373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_time_t	tv_sec;		/* seconds */
26473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_suseconds_t	tv_usec;	/* microseconds */
26573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
26673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
26773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_timezone {
26873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	tz_minuteswest;	/* minutes west of Greenwich */
26973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	tz_dsttime;	/* type of dst correction */
27073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
27173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
27273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct  vki_itimerspec {
27373b526fb4af0f60634f0078583d92b931d5c0eebnethercote        struct  vki_timespec it_interval;    /* timer period */
27473b526fb4af0f60634f0078583d92b931d5c0eebnethercote        struct  vki_timespec it_value;       /* timer expiration */
27573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
27673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
27773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct	vki_itimerval {
27873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct	vki_timeval it_interval;	/* timer interval */
27973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct	vki_timeval it_value;	/* current value */
28073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
28173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
28273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
28373b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/timex.h
28473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
28573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
28673b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_timex {
28773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int modes;	/* mode selector */
28873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long offset;		/* time offset (usec) */
28973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long freq;		/* frequency offset (scaled ppm) */
29073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long maxerror;		/* maximum error (usec) */
29173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long esterror;		/* estimated error (usec) */
29273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int status;		/* clock command/status */
29373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long constant;		/* pll time constant */
29473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long precision;		/* clock precision (usec) (read only) */
29573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long tolerance;		/* clock frequency tolerance (ppm)
29673b526fb4af0f60634f0078583d92b931d5c0eebnethercote				 * (read only)
29773b526fb4af0f60634f0078583d92b931d5c0eebnethercote				 */
29873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_timeval time;	/* (read only) */
29973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long tick;		/* (modified) usecs between clock ticks */
30073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
30173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long ppsfreq;           /* pps frequency (scaled ppm) (ro) */
30273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long jitter;            /* pps jitter (us) (ro) */
30373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int shift;              /* interval duration (s) (shift) (ro) */
30473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long stabil;            /* pps stability (scaled ppm) (ro) */
30573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long jitcnt;            /* jitter limit exceeded (ro) */
30673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long calcnt;            /* calibration intervals (ro) */
30773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long errcnt;            /* calibration errors (ro) */
30873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long stbcnt;            /* stability limit exceeded (ro) */
30973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
31073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int  :32; int  :32; int  :32; int  :32;
31173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int  :32; int  :32; int  :32; int  :32;
31273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int  :32; int  :32; int  :32; int  :32;
31373b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
31473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
3159ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom#define VKI_ADJ_OFFSET			0x0001	/* time offset */
3169ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom#define VKI_ADJ_FREQUENCY		0x0002	/* frequency offset */
3179ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom#define VKI_ADJ_MAXERROR		0x0004	/* maximum time error */
3189ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom#define VKI_ADJ_ESTERROR		0x0008	/* estimated time error */
3199ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom#define VKI_ADJ_STATUS			0x0010	/* clock status */
3209ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom#define VKI_ADJ_TIMECONST		0x0020	/* pll time constant */
321e1c1a24e738b2a1d13f397e9501043914c1643f1tom#define VKI_ADJ_TAI			0x0080	/* set TAI offset */
3229ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom#define VKI_ADJ_TICK			0x4000	/* tick value */
323e1c1a24e738b2a1d13f397e9501043914c1643f1tom#define VKI_ADJ_ADJTIME			0x8000	/* switch between adjtime/adjtimex modes */
3249ceaa9781f4886e8f6a4309e19d0cbaeb7616714tom//#define VKI_ADJ_OFFSET_SINGLESHOT	0x8001	/* old-fashioned adjtime */
325e1c1a24e738b2a1d13f397e9501043914c1643f1tom#define VKI_ADJ_OFFSET_READONLY		0x2000	/* read-only adjtime */
32673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
32773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
32873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/times.h
32973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
33073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
33173b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_tms {
33273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_clock_t tms_utime;
33373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_clock_t tms_stime;
33473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_clock_t tms_cutime;
33573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_clock_t tms_cstime;
33673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
33773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
33873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
33973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/utime.h
34073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
34173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
34273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_utimbuf {
34373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_time_t actime;
34473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_time_t modtime;
34573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
34673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
34773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
34873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/sched.h
34973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
35073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
351b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_CSIGNAL		0x000000ff	/* signal mask to be sent at exit */
35273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_VM		0x00000100	/* set if VM shared between processes */
35373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_FS		0x00000200	/* set if fs info shared between processes */
35473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_FILES		0x00000400	/* set if open files shared between processes */
35573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_SIGHAND	0x00000800	/* set if signal handlers and blocked signals shared */
356b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_CLONE_VFORK		0x00004000	/* set if the parent wants the child to wake it up on mm_release */
357b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_CLONE_PARENT	0x00008000	/* set if we want to have the same parent as the cloner */
35873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_THREAD	0x00010000	/* Same thread group? */
359b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_CLONE_SYSVSEM	0x00040000	/* share system V SEM_UNDO semantics */
360b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_CLONE_SETTLS	0x00080000	/* create a new TLS for the child */
36173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_PARENT_SETTID	0x00100000	/* set the TID in the parent */
36273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_CHILD_CLEARTID	0x00200000	/* clear the TID in the child */
36373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_DETACHED	0x00400000	/* Unused, ignored */
36473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CLONE_CHILD_SETTID	0x01000000	/* set the TID in the child */
36573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
36673b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sched_param {
36773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int sched_priority;
36873b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
36973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
370a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_TASK_COMM_LEN 16
371a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
37273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
37373b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-generic/siginfo.h
37473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
37573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
37673b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef union vki_sigval {
37773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int sival_int;
37873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void __user *sival_ptr;
37973b526fb4af0f60634f0078583d92b931d5c0eebnethercote} vki_sigval_t;
38073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
38173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#ifndef __VKI_ARCH_SI_PREAMBLE_SIZE
38273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_ARCH_SI_PREAMBLE_SIZE	(3 * sizeof(int))
38373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
38473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
38573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SI_MAX_SIZE	128
38673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
38773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#ifndef VKI_SI_PAD_SIZE
38873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SI_PAD_SIZE	((VKI_SI_MAX_SIZE - __VKI_ARCH_SI_PREAMBLE_SIZE) / sizeof(int))
38973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
39073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
39173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#ifndef __VKI_ARCH_SI_UID_T
39273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_ARCH_SI_UID_T	vki_uid_t
39373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
39473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
39573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#ifndef __VKI_ARCH_SI_BAND_T
39673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_ARCH_SI_BAND_T long
39773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
39873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
39973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Nb: this type changed between 2.4 and 2.6, but not in a way that
40073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// affects Valgrind.]]
40173b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct vki_siginfo {
40273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int si_signo;
40373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int si_errno;
40473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int si_code;
40573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
40673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union {
40773b526fb4af0f60634f0078583d92b931d5c0eebnethercote		int _pad[VKI_SI_PAD_SIZE];
40873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
40973b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* kill() */
41073b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct {
41173b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_pid_t _pid;		/* sender's pid */
41273b526fb4af0f60634f0078583d92b931d5c0eebnethercote			__VKI_ARCH_SI_UID_T _uid;	/* sender's uid */
41373b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} _kill;
41473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
41573b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* POSIX.1b timers */
41673b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct {
41773b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_timer_t _tid;		/* timer id */
41873b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int _overrun;		/* overrun count */
41973b526fb4af0f60634f0078583d92b931d5c0eebnethercote			char _pad[sizeof( __VKI_ARCH_SI_UID_T) - sizeof(int)];
42073b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_sigval_t _sigval;	/* same as below */
42173b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int _sys_private;       /* not to be passed to user */
42273b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} _timer;
42373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
42473b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* POSIX.1b signals */
42573b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct {
42673b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_pid_t _pid;		/* sender's pid */
42773b526fb4af0f60634f0078583d92b931d5c0eebnethercote			__VKI_ARCH_SI_UID_T _uid;	/* sender's uid */
42873b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_sigval_t _sigval;
42973b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} _rt;
43073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
43173b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* SIGCHLD */
43273b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct {
43373b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_pid_t _pid;		/* which child */
43473b526fb4af0f60634f0078583d92b931d5c0eebnethercote			__VKI_ARCH_SI_UID_T _uid;	/* sender's uid */
43573b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int _status;		/* exit code */
43673b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_clock_t _utime;
43773b526fb4af0f60634f0078583d92b931d5c0eebnethercote			vki_clock_t _stime;
43873b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} _sigchld;
43973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
44073b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* SIGILL, SIGFPE, SIGSEGV, SIGBUS */
44173b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct {
44273b526fb4af0f60634f0078583d92b931d5c0eebnethercote			void __user *_addr; /* faulting insn/memory ref. */
44373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#ifdef __ARCH_SI_TRAPNO
44473b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int _trapno;	/* TRAP # which caused the signal */
44573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
44673b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} _sigfault;
44773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
44873b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* SIGPOLL */
44973b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct {
45073b526fb4af0f60634f0078583d92b931d5c0eebnethercote			__VKI_ARCH_SI_BAND_T _band;	/* POLL_IN, POLL_OUT, POLL_MSG */
45173b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int _fd;
45273b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} _sigpoll;
45373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	} _sifields;
45473b526fb4af0f60634f0078583d92b931d5c0eebnethercote} vki_siginfo_t;
45573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
456148250b9e89daa1073929da9df5fe6c8896b159ctom#define __VKI_SI_FAULT	0
457148250b9e89daa1073929da9df5fe6c8896b159ctom
45873b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*
45973b526fb4af0f60634f0078583d92b931d5c0eebnethercote * si_code values
46073b526fb4af0f60634f0078583d92b931d5c0eebnethercote * Digital reserves positive values for kernel-generated signals.
46173b526fb4af0f60634f0078583d92b931d5c0eebnethercote */
46273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SI_USER	0		/* sent by kill, sigsend, raise */
46373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SI_TKILL	-6		/* sent by tkill system call */
46473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
465e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom/*
466148250b9e89daa1073929da9df5fe6c8896b159ctom * SIGILL si_codes
467148250b9e89daa1073929da9df5fe6c8896b159ctom */
468148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_ILLOPC	(__VKI_SI_FAULT|1)	/* illegal opcode */
469148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_ILLOPN	(__VKI_SI_FAULT|2)	/* illegal operand */
470148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_ILLADR	(__VKI_SI_FAULT|3)	/* illegal addressing mode */
471148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_ILLTRP	(__VKI_SI_FAULT|4)	/* illegal trap */
472148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_PRVOPC	(__VKI_SI_FAULT|5)	/* privileged opcode */
473148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_PRVREG	(__VKI_SI_FAULT|6)	/* privileged register */
474148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_COPROC	(__VKI_SI_FAULT|7)	/* coprocessor error */
475148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_ILL_BADSTK	(__VKI_SI_FAULT|8)	/* internal stack error */
476148250b9e89daa1073929da9df5fe6c8896b159ctom
477148250b9e89daa1073929da9df5fe6c8896b159ctom/*
478148250b9e89daa1073929da9df5fe6c8896b159ctom * SIGFPE si_codes
479148250b9e89daa1073929da9df5fe6c8896b159ctom */
480148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_INTDIV	(__VKI_SI_FAULT|1)	/* integer divide by zero */
481148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_INTOVF	(__VKI_SI_FAULT|2)	/* integer overflow */
482148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_FLTDIV	(__VKI_SI_FAULT|3)	/* floating point divide by zero */
483148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_FLTOVF	(__VKI_SI_FAULT|4)	/* floating point overflow */
484148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_FLTUND	(__VKI_SI_FAULT|5)	/* floating point underflow */
485148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_FLTRES	(__VKI_SI_FAULT|6)	/* floating point inexact result */
486148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_FLTINV	(__VKI_SI_FAULT|7)	/* floating point invalid operation */
487148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_FPE_FLTSUB	(__VKI_SI_FAULT|8)	/* subscript out of range */
488148250b9e89daa1073929da9df5fe6c8896b159ctom
489148250b9e89daa1073929da9df5fe6c8896b159ctom/*
490148250b9e89daa1073929da9df5fe6c8896b159ctom * SIGSEGV si_codes
491148250b9e89daa1073929da9df5fe6c8896b159ctom */
492148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_SEGV_MAPERR	(__VKI_SI_FAULT|1)	/* address not mapped to object */
493148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_SEGV_ACCERR	(__VKI_SI_FAULT|2)	/* invalid permissions for mapped object */
494148250b9e89daa1073929da9df5fe6c8896b159ctom
495148250b9e89daa1073929da9df5fe6c8896b159ctom/*
496148250b9e89daa1073929da9df5fe6c8896b159ctom * SIGBUS si_codes
497148250b9e89daa1073929da9df5fe6c8896b159ctom */
498148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_BUS_ADRALN	(__VKI_SI_FAULT|1)	/* invalid address alignment */
499148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_BUS_ADRERR	(__VKI_SI_FAULT|2)	/* non-existant physical address */
500148250b9e89daa1073929da9df5fe6c8896b159ctom#define VKI_BUS_OBJERR	(__VKI_SI_FAULT|3)	/* object specific hardware error */
501148250b9e89daa1073929da9df5fe6c8896b159ctom
502148250b9e89daa1073929da9df5fe6c8896b159ctom/*
50386df1559d94314c7385f79ec7f80a7063cb3e1e6sewardj * SIGTRAP si_codes
50486df1559d94314c7385f79ec7f80a7063cb3e1e6sewardj */
50586df1559d94314c7385f79ec7f80a7063cb3e1e6sewardj#define VKI_TRAP_BRKPT      (__VKI_SI_FAULT|1)  /* process breakpoint */
50686df1559d94314c7385f79ec7f80a7063cb3e1e6sewardj#define VKI_TRAP_TRACE      (__VKI_SI_FAULT|2)  /* process trace trap */
50786df1559d94314c7385f79ec7f80a7063cb3e1e6sewardj
50886df1559d94314c7385f79ec7f80a7063cb3e1e6sewardj/*
509e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom * This works because the alignment is ok on all current architectures
510e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom * but we leave open this being overridden in the future
511e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom */
512e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom#ifndef VKI___ARCH_SIGEV_PREAMBLE_SIZE
513e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom#define VKI___ARCH_SIGEV_PREAMBLE_SIZE	(sizeof(int) * 2 + sizeof(vki_sigval_t))
51473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
51573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
516e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom#define VKI_SIGEV_MAX_SIZE	64
517e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom#define VKI_SIGEV_PAD_SIZE	((VKI_SIGEV_MAX_SIZE - VKI___ARCH_SIGEV_PREAMBLE_SIZE) \
518e7203a89c1e39fb1abcebebf515f62bc4c68b2c4tom		/ sizeof(int))
51973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
52073b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct vki_sigevent {
52173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_sigval_t sigev_value;
52273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int sigev_signo;
52373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int sigev_notify;
52473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union {
52573b526fb4af0f60634f0078583d92b931d5c0eebnethercote		int _pad[VKI_SIGEV_PAD_SIZE];
52673b526fb4af0f60634f0078583d92b931d5c0eebnethercote		 int _tid;
52773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
52873b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct {
52973b526fb4af0f60634f0078583d92b931d5c0eebnethercote			void (*_function)(vki_sigval_t);
53073b526fb4af0f60634f0078583d92b931d5c0eebnethercote			void *_attribute;	/* really pthread_attr_t */
53173b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} _sigev_thread;
53273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	} _sigev_un;
53373b526fb4af0f60634f0078583d92b931d5c0eebnethercote} vki_sigevent_t;
53473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
53573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
53673b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From elsewhere...
53773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
53873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
53973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[The kernel actually uses the numbers 0,1,2 directly here, believe it or
54073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// not.  So we introduce our own constants, based on the glibc ones.]]
54173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SEEK_SET              0
54273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SEEK_CUR              1
54373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SEEK_END              2
54473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
54573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
54673b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/net.h
54773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
54873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
54973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_SOCKET		1	/* sys_socket(2)		*/
55073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_BIND		2	/* sys_bind(2)			*/
55173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_CONNECT		3	/* sys_connect(2)		*/
55273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_LISTEN		4	/* sys_listen(2)		*/
55373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_ACCEPT		5	/* sys_accept(2)		*/
55473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_GETSOCKNAME	6	/* sys_getsockname(2)		*/
55573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_GETPEERNAME	7	/* sys_getpeername(2)		*/
55673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_SOCKETPAIR	8	/* sys_socketpair(2)		*/
55773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_SEND		9	/* sys_send(2)			*/
55873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_RECV		10	/* sys_recv(2)			*/
55973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_SENDTO		11	/* sys_sendto(2)		*/
56073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_RECVFROM	12	/* sys_recvfrom(2)		*/
56173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_SHUTDOWN	13	/* sys_shutdown(2)		*/
56273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_SETSOCKOPT	14	/* sys_setsockopt(2)		*/
56373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_GETSOCKOPT	15	/* sys_getsockopt(2)		*/
56473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_SENDMSG		16	/* sys_sendmsg(2)		*/
56573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SYS_RECVMSG		17	/* sys_recvmsg(2)		*/
566710f7cb43578a9b23a11aa7f9cfaea0311bc5ad9tom#define VKI_SYS_ACCEPT4		18	/* sys_accept4(2)		*/
56773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
568ca0518df66f8c3375a860f1a55a51f18e2a16c44njnenum vki_sock_type {
569ca0518df66f8c3375a860f1a55a51f18e2a16c44njn	VKI_SOCK_STREAM	= 1,
570ca0518df66f8c3375a860f1a55a51f18e2a16c44njn	// [[others omitted]]
571ca0518df66f8c3375a860f1a55a51f18e2a16c44njn};
572ca0518df66f8c3375a860f1a55a51f18e2a16c44njn
57373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
57473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/uio.h
57573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
57673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
57773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_iovec
57873b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
57973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void __user *iov_base;	/* BSD uses caddr_t (1003.1g requires void *) */
58073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_size_t iov_len; /* Must be size_t (1003.1g) */
58173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
58273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
58373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
58473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/socket.h
58573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
58673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
58773b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Resolved arbitrarily;  doesn't really matter whether it's '__inline__'
58873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//   or 'inline']]
58973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __KINLINE static __inline__
59073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
59173b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef unsigned short	vki_sa_family_t;
59273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
59373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sockaddr {
59473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_sa_family_t	sa_family;	/* address family, AF_xxx	*/
59573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char		sa_data[14];	/* 14 bytes of protocol address	*/
59673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
59773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
59873b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_msghdr {
59973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void	*	msg_name;	/* Socket name			*/
60073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int		msg_namelen;	/* Length of name		*/
60173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_iovec *	msg_iov;	/* Data blocks			*/
60273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_size_t	msg_iovlen;	/* Number of blocks		*/
60373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void 	*	msg_control;	/* Per protocol magic (eg BSD file descriptor passing) */
60473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_size_t	msg_controllen;	/* Length of cmsg list */
60573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	msg_flags;
60673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
60773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
608a4991237861dd834a58620b6a9eeca0e6e843f24tomstruct vki_mmsghdr {
609a4991237861dd834a58620b6a9eeca0e6e843f24tom	struct vki_msghdr   msg_hdr;
610a4991237861dd834a58620b6a9eeca0e6e843f24tom	unsigned        msg_len;
611a4991237861dd834a58620b6a9eeca0e6e843f24tom};
612a4991237861dd834a58620b6a9eeca0e6e843f24tom
61373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cmsghdr {
61473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_size_t	cmsg_len;	/* data byte count, including hdr */
61573b526fb4af0f60634f0078583d92b931d5c0eebnethercote        int		cmsg_level;	/* originating protocol */
61673b526fb4af0f60634f0078583d92b931d5c0eebnethercote        int		cmsg_type;	/* protocol-specific type */
61773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
61873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
61973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_CMSG_NXTHDR(ctl, len, cmsg) __vki_cmsg_nxthdr((ctl),(len),(cmsg))
62073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CMSG_NXTHDR(mhdr, cmsg) vki_cmsg_nxthdr((mhdr), (cmsg))
62173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
62273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CMSG_ALIGN(len) ( ((len)+sizeof(long)-1) & ~(sizeof(long)-1) )
62373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
62473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CMSG_DATA(cmsg)	((void *)((char *)(cmsg) + VKI_CMSG_ALIGN(sizeof(struct vki_cmsghdr))))
62573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
62673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_CMSG_FIRSTHDR(ctl,len) ((len) >= sizeof(struct vki_cmsghdr) ? \
62773b526fb4af0f60634f0078583d92b931d5c0eebnethercote				  (struct vki_cmsghdr *)(ctl) : \
62873b526fb4af0f60634f0078583d92b931d5c0eebnethercote				  (struct vki_cmsghdr *)NULL)
62973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CMSG_FIRSTHDR(msg)	__VKI_CMSG_FIRSTHDR((msg)->msg_control, (msg)->msg_controllen)
63073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
63173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Urgh, this is revolting...]
63273b526fb4af0f60634f0078583d92b931d5c0eebnethercote__KINLINE struct vki_cmsghdr * __vki_cmsg_nxthdr(void *__ctl, __vki_kernel_size_t __size,
63373b526fb4af0f60634f0078583d92b931d5c0eebnethercote					       struct vki_cmsghdr *__cmsg)
63473b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
63573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_cmsghdr * __ptr;
63673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
63773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__ptr = (struct vki_cmsghdr*)(((unsigned char *) __cmsg) +  VKI_CMSG_ALIGN(__cmsg->cmsg_len));
63873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	if ((unsigned long)((char*)(__ptr+1) - (char *) __ctl) > __size)
63973b526fb4af0f60634f0078583d92b931d5c0eebnethercote		return (struct vki_cmsghdr *)0;
64073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
64173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	return __ptr;
64273b526fb4af0f60634f0078583d92b931d5c0eebnethercote}
64373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
64473b526fb4af0f60634f0078583d92b931d5c0eebnethercote__KINLINE struct vki_cmsghdr * vki_cmsg_nxthdr (struct vki_msghdr *__msg, struct vki_cmsghdr *__cmsg)
64573b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
64673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	return __vki_cmsg_nxthdr(__msg->msg_control, __msg->msg_controllen, __cmsg);
64773b526fb4af0f60634f0078583d92b931d5c0eebnethercote}
64873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
64973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_SCM_RIGHTS	0x01		/* rw: access rights (array of int) */
65073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
65173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_AF_UNIX	1	/* Unix domain sockets 		*/
65273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_AF_INET	2	/* Internet IP Protocol		*/
65373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_AF_INET6	10	/* IP version 6			*/
65473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
65573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MSG_NOSIGNAL	0x4000	/* Do not generate SIGPIPE */
65673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
6571aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SOL_SCTP	132
6581aa57373be5343c365ee6b480e205abc16008402tom
65973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
66073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/in.h
66173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
66273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
66373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_in_addr {
66473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32	s_addr;
66573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
66673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
66773b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Structure describing an Internet (IP) socket address. */
66873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_SOCK_SIZE__	16	/* sizeof(struct sockaddr)	*/
66973b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sockaddr_in {
67073b526fb4af0f60634f0078583d92b931d5c0eebnethercote  vki_sa_family_t	sin_family;	/* Address family		*/
67173b526fb4af0f60634f0078583d92b931d5c0eebnethercote  unsigned short int	sin_port;	/* Port number			*/
67273b526fb4af0f60634f0078583d92b931d5c0eebnethercote  struct vki_in_addr	sin_addr;	/* Internet address		*/
67373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
67473b526fb4af0f60634f0078583d92b931d5c0eebnethercote  /* Pad to size of `struct sockaddr'. */
67573b526fb4af0f60634f0078583d92b931d5c0eebnethercote  unsigned char		__pad[__VKI_SOCK_SIZE__ - sizeof(short int) -
67673b526fb4af0f60634f0078583d92b931d5c0eebnethercote			sizeof(unsigned short int) - sizeof(struct vki_in_addr)];
67773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
67873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
67973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
68073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/in6.h
68173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
68273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
68373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_in6_addr
68473b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
68573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union
68673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	{
68773b526fb4af0f60634f0078583d92b931d5c0eebnethercote		__vki_u8	u6_addr8[16];
68873b526fb4af0f60634f0078583d92b931d5c0eebnethercote		__vki_u16	u6_addr16[8];
68973b526fb4af0f60634f0078583d92b931d5c0eebnethercote		__vki_u32	u6_addr32[4];
69073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	} vki_in6_u;
69173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define vki_s6_addr		vki_in6_u.u6_addr8
69273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define vki_s6_addr16		vki_in6_u.u6_addr16
69373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define vki_s6_addr32		vki_in6_u.u6_addr32
69473b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
69573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
69673b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sockaddr_in6 {
69773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short int	sin6_family;    /* AF_INET6 */
69873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u16		sin6_port;      /* Transport layer port # */
69973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32		sin6_flowinfo;  /* IPv6 flow information */
70073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_in6_addr	sin6_addr;      /* IPv6 address */
70173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32		sin6_scope_id;  /* scope id (new in RFC2553) */
70273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
70373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
70473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
70573b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/un.h
70673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
70773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
70873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_UNIX_PATH_MAX	108
70973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
71073b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sockaddr_un {
71173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_sa_family_t sun_family;	/* AF_UNIX */
71273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char sun_path[VKI_UNIX_PATH_MAX];	/* pathname */
71373b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
71473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
71573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
71673b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/if.h
71773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
71873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
71973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_IFNAMSIZ	16
72073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
72173b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_ifmap
72273b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
72373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long mem_start;
72473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long mem_end;
72573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short base_addr;
72673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char irq;
72773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char dma;
72873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char port;
72973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	/* 3 bytes spare */
73073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
73173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
73273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_if_settings
73373b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
73473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int type;	/* Type of physical device or protocol */
73573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int size;	/* Size of the data allocated by the caller */
73673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union {
73773b526fb4af0f60634f0078583d92b931d5c0eebnethercote                // [[Nb: converted these all to void* to avoid pulling in
73873b526fb4af0f60634f0078583d92b931d5c0eebnethercote                //   unnecessary headers]]]
73973b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* {atm/eth/dsl}_settings anyone ? */
74073b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void /*raw_hdlc_proto		*/__user *raw_hdlc;
74173b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void /*cisco_proto		*/__user *cisco;
74273b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void /*fr_proto			*/__user *fr;
74373b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void /*fr_proto_pvc		*/__user *fr_pvc;
74473b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void /*fr_proto_pvc_info	*/__user *fr_pvc_info;
74573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
74673b526fb4af0f60634f0078583d92b931d5c0eebnethercote		/* interface settings */
74773b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void /*sync_serial_settings	*/__user *sync;
74873b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void /*te1_settings		*/__user *te1;
74973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	} ifs_ifsu;
75073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
75173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
75273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_ifreq
75373b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
75473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IFHWADDRLEN	6
75573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union
75673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	{
75773b526fb4af0f60634f0078583d92b931d5c0eebnethercote		char	ifrn_name[VKI_IFNAMSIZ];		/* if name, e.g. "en0" */
75873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	} ifr_ifrn;
75973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
76073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union {
76173b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct	vki_sockaddr ifru_addr;
76273b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct	vki_sockaddr ifru_dstaddr;
76373b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct	vki_sockaddr ifru_broadaddr;
76473b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct	vki_sockaddr ifru_netmask;
76573b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct  vki_sockaddr ifru_hwaddr;
76673b526fb4af0f60634f0078583d92b931d5c0eebnethercote		short	ifru_flags;
76773b526fb4af0f60634f0078583d92b931d5c0eebnethercote		int	ifru_ivalue;
76873b526fb4af0f60634f0078583d92b931d5c0eebnethercote		int	ifru_mtu;
76973b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct  vki_ifmap ifru_map;
77073b526fb4af0f60634f0078583d92b931d5c0eebnethercote		char	ifru_slave[VKI_IFNAMSIZ];	/* Just fits the size */
77173b526fb4af0f60634f0078583d92b931d5c0eebnethercote		char	ifru_newname[VKI_IFNAMSIZ];
77273b526fb4af0f60634f0078583d92b931d5c0eebnethercote		void __user *	ifru_data;
77373b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct	vki_if_settings ifru_settings;
77473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	} ifr_ifru;
77573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
77673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
77773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define vki_ifr_name	ifr_ifrn.ifrn_name	/* interface name 	*/
77873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define ifr_hwaddr	ifr_ifru.ifru_hwaddr	/* MAC address 		*/
77973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	ifr_addr	ifr_ifru.ifru_addr	/* address		*/
78073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	ifr_dstaddr	ifr_ifru.ifru_dstaddr	/* other end of p-p lnk	*/
78173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	ifr_broadaddr	ifr_ifru.ifru_broadaddr	/* broadcast address	*/
78273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	ifr_netmask	ifr_ifru.ifru_netmask	/* interface net mask	*/
78373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	vki_ifr_flags	ifr_ifru.ifru_flags	/* flags		*/
78473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	vki_ifr_metric	ifr_ifru.ifru_ivalue	/* metric		*/
78573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	vki_ifr_mtu		ifr_ifru.ifru_mtu	/* mtu			*/
78673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define ifr_map		ifr_ifru.ifru_map	/* device map		*/
78773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define ifr_slave	ifr_ifru.ifru_slave	/* slave device		*/
78873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	vki_ifr_data	ifr_ifru.ifru_data	/* for use by interface	*/
78973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define vki_ifr_ifindex	ifr_ifru.ifru_ivalue	/* interface index	*/
79073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define ifr_bandwidth	ifr_ifru.ifru_ivalue    /* link bandwidth	*/
79173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define ifr_qlen	ifr_ifru.ifru_ivalue	/* Queue length 	*/
79273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define ifr_newname	ifr_ifru.ifru_newname	/* New name		*/
79373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define ifr_settings	ifr_ifru.ifru_settings	/* Device/proto settings*/
79473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
79573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_ifconf
79673b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
79773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	ifc_len;			/* size of buffer	*/
79873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union
79973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	{
80073b526fb4af0f60634f0078583d92b931d5c0eebnethercote		char __user *ifcu_buf;
80173b526fb4af0f60634f0078583d92b931d5c0eebnethercote		struct vki_ifreq __user *ifcu_req;
80273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	} ifc_ifcu;
80373b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
80473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	vki_ifc_buf	ifc_ifcu.ifcu_buf	/* buffer address	*/
80573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
80673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
80773b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/if_arp.h
80873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
80973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
81073b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_arpreq {
81173b526fb4af0f60634f0078583d92b931d5c0eebnethercote  struct vki_sockaddr	arp_pa;		/* protocol address		*/
81273b526fb4af0f60634f0078583d92b931d5c0eebnethercote  struct vki_sockaddr	arp_ha;		/* hardware address		*/
81373b526fb4af0f60634f0078583d92b931d5c0eebnethercote  int			arp_flags;	/* flags			*/
81473b526fb4af0f60634f0078583d92b931d5c0eebnethercote  struct vki_sockaddr   arp_netmask;    /* netmask (only for proxy arps) */
81573b526fb4af0f60634f0078583d92b931d5c0eebnethercote  char			arp_dev[16];
81673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
81773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
81873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
81973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/route.h
82073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
82173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
82273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_rtentry
82373b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
82473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	rt_pad1;
82573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_sockaddr	rt_dst;		/* target address		*/
82673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_sockaddr	rt_gateway;	/* gateway addr (RTF_GATEWAY)	*/
82773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_sockaddr	rt_genmask;	/* target network mask (IP)	*/
82873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	rt_flags;
82973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	short		rt_pad2;
83073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	rt_pad3;
83173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void		*rt_pad4;
83273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	short		rt_metric;	/* +1 for binary compatibility!	*/
83373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char __user	*rt_dev;	/* forcing the device at add	*/
83473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	rt_mtu;		/* per route MTU/Window 	*/
83573b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Not important for Valgrind]]
83673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#ifndef __KERNEL__
83773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#define rt_mss	rt_mtu		/* Compatibility :-(            */
83873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#endif
83973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	rt_window;	/* Window clamping 		*/
84073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	rt_irtt;	/* Initial RTT			*/
84173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
84273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
84373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
8441aa57373be5343c365ee6b480e205abc16008402tom// From linux-2.6.13-rc5/include/net/sctp/user.h
8451aa57373be5343c365ee6b480e205abc16008402tom//----------------------------------------------------------------------
8461aa57373be5343c365ee6b480e205abc16008402tom
8471aa57373be5343c365ee6b480e205abc16008402tomtypedef __vki_s32 vki_sctp_assoc_t;
8481aa57373be5343c365ee6b480e205abc16008402tom
8491aa57373be5343c365ee6b480e205abc16008402tomenum vki_sctp_optname {
8501aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_RTOINFO,
8511aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_RTOINFO VKI_SCTP_RTOINFO
8521aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_ASSOCINFO,
8531aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_ASSOCINFO VKI_SCTP_ASSOCINFO
8541aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_INITMSG,
8551aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_INITMSG VKI_SCTP_INITMSG
8561aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_NODELAY, 	/* Get/set nodelay option. */
8571aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_NODELAY	VKI_SCTP_NODELAY
8581aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_AUTOCLOSE,
8591aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_AUTOCLOSE VKI_SCTP_AUTOCLOSE
8601aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_SET_PEER_PRIMARY_ADDR,
8611aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_SET_PEER_PRIMARY_ADDR VKI_SCTP_SET_PEER_PRIMARY_ADDR
8621aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_PRIMARY_ADDR,
8631aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_PRIMARY_ADDR VKI_SCTP_PRIMARY_ADDR
8641aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_ADAPTION_LAYER,
8651aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_ADAPTION_LAYER VKI_SCTP_ADAPTION_LAYER
8661aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_DISABLE_FRAGMENTS,
8671aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_DISABLE_FRAGMENTS VKI_SCTP_DISABLE_FRAGMENTS
8681aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_PEER_ADDR_PARAMS,
8691aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_PEER_ADDR_PARAMS VKI_SCTP_PEER_ADDR_PARAMS
8701aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_DEFAULT_SEND_PARAM,
8711aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_DEFAULT_SEND_PARAM VKI_SCTP_DEFAULT_SEND_PARAM
8721aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_EVENTS,
8731aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_EVENTS VKI_SCTP_EVENTS
8741aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_I_WANT_MAPPED_V4_ADDR,  /* Turn on/off mapped v4 addresses  */
8751aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_I_WANT_MAPPED_V4_ADDR VKI_SCTP_I_WANT_MAPPED_V4_ADDR
8761aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_MAXSEG, 	/* Get/set maximum fragment. */
8771aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_MAXSEG 	VKI_SCTP_MAXSEG
8781aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_STATUS,
8791aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_STATUS VKI_SCTP_STATUS
8801aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_GET_PEER_ADDR_INFO,
8811aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_GET_PEER_ADDR_INFO VKI_SCTP_GET_PEER_ADDR_INFO
8821aa57373be5343c365ee6b480e205abc16008402tom
8831aa57373be5343c365ee6b480e205abc16008402tom	/* Internal Socket Options. Some of the sctp library functions are
8841aa57373be5343c365ee6b480e205abc16008402tom	 * implemented using these socket options.
8851aa57373be5343c365ee6b480e205abc16008402tom	 */
8861aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_SOCKOPT_BINDX_ADD = 100,/* BINDX requests for adding addresses. */
8871aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_SOCKOPT_BINDX_ADD	VKI_SCTP_SOCKOPT_BINDX_ADD
8881aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_SOCKOPT_BINDX_REM, /* BINDX requests for removing addresses. */
8891aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_SOCKOPT_BINDX_REM	VKI_SCTP_SOCKOPT_BINDX_REM
8901aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_SOCKOPT_PEELOFF, 	/* peel off association. */
8911aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_SOCKOPT_PEELOFF	VKI_SCTP_SOCKOPT_PEELOFF
8921aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_GET_PEER_ADDRS_NUM, 	/* Get number of peer addresss. */
8931aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_GET_PEER_ADDRS_NUM	VKI_SCTP_GET_PEER_ADDRS_NUM
8941aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_GET_PEER_ADDRS, 	/* Get all peer addresss. */
8951aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_GET_PEER_ADDRS	VKI_SCTP_GET_PEER_ADDRS
8961aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_GET_LOCAL_ADDRS_NUM, 	/* Get number of local addresss. */
8971aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_GET_LOCAL_ADDRS_NUM	VKI_SCTP_GET_LOCAL_ADDRS_NUM
8981aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_GET_LOCAL_ADDRS, 	/* Get all local addresss. */
8991aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_GET_LOCAL_ADDRS	VKI_SCTP_GET_LOCAL_ADDRS
9001aa57373be5343c365ee6b480e205abc16008402tom	VKI_SCTP_SOCKOPT_CONNECTX, /* CONNECTX requests. */
9011aa57373be5343c365ee6b480e205abc16008402tom#define VKI_SCTP_SOCKOPT_CONNECTX	VKI_SCTP_SOCKOPT_CONNECTX
9021aa57373be5343c365ee6b480e205abc16008402tom};
9031aa57373be5343c365ee6b480e205abc16008402tom
9041aa57373be5343c365ee6b480e205abc16008402tomstruct vki_sctp_getaddrs {
9051aa57373be5343c365ee6b480e205abc16008402tom	vki_sctp_assoc_t        assoc_id;
9061aa57373be5343c365ee6b480e205abc16008402tom	int			addr_num;
9071aa57373be5343c365ee6b480e205abc16008402tom	struct vki_sockaddr	*addrs;
9081aa57373be5343c365ee6b480e205abc16008402tom};
9091aa57373be5343c365ee6b480e205abc16008402tom
9101aa57373be5343c365ee6b480e205abc16008402tom//----------------------------------------------------------------------
91173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/resource.h
91273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
91373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
91473b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct	vki_rusage {
91573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_timeval ru_utime;	/* user time used */
91673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_timeval ru_stime;	/* system time used */
91773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_maxrss;		/* maximum resident set size */
91873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_ixrss;		/* integral shared memory size */
91973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_idrss;		/* integral unshared data size */
92073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_isrss;		/* integral unshared stack size */
92173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_minflt;		/* page reclaims */
92273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_majflt;		/* page faults */
92373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_nswap;		/* swaps */
92473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_inblock;		/* block input operations */
92573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_oublock;		/* block output operations */
92673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_msgsnd;		/* messages sent */
92773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_msgrcv;		/* messages received */
92873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_nsignals;		/* signals received */
92973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_nvcsw;		/* voluntary context switches */
93073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	ru_nivcsw;		/* involuntary " */
93173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
93273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
93373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_rlimit {
93473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	rlim_cur;
93573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long	rlim_max;
93673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
93773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
93846d02abf94a41586ef84aebf974db51a470e10datomstruct vki_rlimit64 {
93946d02abf94a41586ef84aebf974db51a470e10datom	__vki_u64 rlim_cur;
94046d02abf94a41586ef84aebf974db51a470e10datom	__vki_u64 rlim_max;
94146d02abf94a41586ef84aebf974db51a470e10datom};
94246d02abf94a41586ef84aebf974db51a470e10datom
94373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
94473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/elfcore.h
94573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
94673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
94773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_elf_siginfo
94873b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
94973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	si_signo;			/* signal number */
95073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	si_code;			/* extra code */
95173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	si_errno;			/* errno */
95273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
95373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
95473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Removed some commented out lines here]]
95573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_elf_prstatus
95673b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
95773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_elf_siginfo pr_info;	/* Info associated with signal */
95873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	short	pr_cursig;		/* Current signal */
95973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long pr_sigpend;	/* Set of pending signals */
96073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long pr_sighold;	/* Set of held signals */
96173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_pid_t	pr_pid;
96273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_pid_t	pr_ppid;
96373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_pid_t	pr_pgrp;
96473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_pid_t	pr_sid;
96573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_timeval pr_utime;	/* User time */
96673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_timeval pr_stime;	/* System time */
96773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_timeval pr_cutime;	/* Cumulative user time */
96873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_timeval pr_cstime;	/* Cumulative system time */
96973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_elf_gregset_t pr_reg;	/* GP registers */
97073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int pr_fpvalid;		/* True if math co-processor being used.  */
97173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
97273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
97373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_ELF_PRARGSZ	(80)	/* Number of chars for args */
97473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
97573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_elf_prpsinfo
97673b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
97773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char	pr_state;	/* numeric process state */
97873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char	pr_sname;	/* char for pr_state */
97973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char	pr_zomb;	/* zombie */
98073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char	pr_nice;	/* nice val */
98173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long pr_flag;	/* flags */
98273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_uid_t	pr_uid;
98373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_gid_t	pr_gid;
98473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_pid_t	pr_pid, pr_ppid, pr_pgrp, pr_sid;
98573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	/* Lots missing */
98673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char	pr_fname[16];	/* filename of executable */
98773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char	pr_psargs[VKI_ELF_PRARGSZ];	/* initial part of arg list */
98873b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
98973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
99073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
99140e735834f172bd304ead1fa7e5e31f9e455dc24njn// From linux-2.6.12.1/include/linux/eventpoll.h
99273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
99373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
99440e735834f172bd304ead1fa7e5e31f9e455dc24njn/* Valid opcodes to issue to sys_epoll_ctl() */
99540e735834f172bd304ead1fa7e5e31f9e455dc24njn#define VKI_EPOLL_CTL_ADD 1
99640e735834f172bd304ead1fa7e5e31f9e455dc24njn#define VKI_EPOLL_CTL_DEL 2
99740e735834f172bd304ead1fa7e5e31f9e455dc24njn#define VKI_EPOLL_CTL_MOD 3
99840e735834f172bd304ead1fa7e5e31f9e455dc24njn
99973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#ifdef __x86_64__
100073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_EPOLL_PACKED __attribute__((packed))
100173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#else
100273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_EPOLL_PACKED
100373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
100473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
100540e735834f172bd304ead1fa7e5e31f9e455dc24njnstruct vki_epoll_event {
100673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 events;
100773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64 data;
100873b526fb4af0f60634f0078583d92b931d5c0eebnethercote} VKI_EPOLL_PACKED;
100973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
101073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
101173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
101273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/mqueue.h
101373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
101473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
101573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_mq_attr {
101673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	mq_flags;	/* message queue flags			*/
101773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	mq_maxmsg;	/* maximum number of messages		*/
101873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	mq_msgsize;	/* maximum message size			*/
101973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	mq_curmsgs;	/* number of messages currently queued	*/
102073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long	__reserved[4];	/* ignored for input, zeroed for output */
102173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
102273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
102373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
102473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/utsname.h
102573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
102673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
102773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_new_utsname {
102873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char sysname[65];
102973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char nodename[65];
103073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char release[65];
103173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char version[65];
103273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char machine[65];
103373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char domainname[65];
103473b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
103573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
103673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
103773b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/mii.h
103873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
103973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
104073b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* This structure is used in all SIOCxMIIxxx ioctl calls */
104173b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_mii_ioctl_data {
104273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_u16		phy_id;
104373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_u16		reg_num;
104473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_u16		val_in;
104573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_u16		val_out;
104673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
104773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
104873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
104973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/capability.h
105073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
105173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
105273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[capget()/capset() man page says this, ominously:
105373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//
105473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//   The kernel API is likely to change and use of these functions  (in
105573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//   particular the format of the cap_user_*_t types) is subject to
105673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//   change with each kernel revision.
105773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//
105873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// However, the format hasn't changed since at least Linux 2.4.6.]]
105973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
106073b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct __vki_user_cap_header_struct {
106173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 version;
106273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int pid;
106373b526fb4af0f60634f0078583d92b931d5c0eebnethercote} __user *vki_cap_user_header_t;
106473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
106573b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct __vki_user_cap_data_struct {
106673b526fb4af0f60634f0078583d92b931d5c0eebnethercote        __vki_u32 effective;
106773b526fb4af0f60634f0078583d92b931d5c0eebnethercote        __vki_u32 permitted;
106873b526fb4af0f60634f0078583d92b931d5c0eebnethercote        __vki_u32 inheritable;
106973b526fb4af0f60634f0078583d92b931d5c0eebnethercote} __user *vki_cap_user_data_t;
107073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
107173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
107273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
107373b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/module.h
107473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
107573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
107673b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[We do a VKI_SIZEOF_* here because this type is so big, and its size
107773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//   depends on the word size, so see vki_arch.h]]
107873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
107973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
108073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/ipc.h
108173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
108273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
108373b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Obsolete, used only for backwards compatibility and libc5 compiles */
108473b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_ipc_perm
108573b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
108673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_key_t	key;
108773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_uid_t	uid;
108873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_gid_t	gid;
108973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_uid_t	cuid;
109073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_gid_t	cgid;
109173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_mode_t	mode;
109273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	seq;
109373b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
109473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
109573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IPC_CREAT  00001000   /* create if key is nonexistent */
109673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IPC_EXCL   00002000   /* fail if key exists */
109773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IPC_NOWAIT 00004000   /* return error on wait */
109873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
109973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#define VKI_IPC_RMID 0     /* remove resource */
110073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IPC_SET  1     /* set ipc_perm options */
110173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IPC_STAT 2     /* get ipc_perm options */
110273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IPC_INFO 3     /* see ipcs */
110373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
110473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IPC_64  0x0100  /* New version (support 32-bit UIDs, bigger
110573b526fb4af0f60634f0078583d92b931d5c0eebnethercote			       message sizes, etc. */
110673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
110773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
110873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/sem.h
110973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
111073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
111173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_GETALL  13       /* get all semval's */
111273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SETVAL  16       /* set semval */
111373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SETALL  17       /* set all semval's */
111473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
111573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SEM_STAT 18
111673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SEM_INFO 19
111773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
111873b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Obsolete, used only for backwards compatibility and libc5 compiles */
111973b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_semid_ds {
112073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_ipc_perm	sem_perm;		/* permissions .. see ipc.h */
112173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t	sem_otime;		/* last semop time */
112273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t	sem_ctime;		/* last change time */
112373b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // [[Use void* to avoid excess header copying]]
112473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void/*struct sem	*/*sem_base;		/* ptr to first semaphore in array */
112573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void/*struct sem_queue */*sem_pending;		/* pending operations to be processed */
112673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void/*struct sem_queue */**sem_pending_last;	/* last pending operation */
112773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void/*struct sem_undo	*/*undo;			/* undo requests on this array */
112873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	sem_nsems;		/* no. of semaphores in array */
112973b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
113073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
113173b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_sembuf {
113273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short  sem_num;	/* semaphore index in array */
113373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	short		sem_op;		/* semaphore operation */
113473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	short		sem_flg;	/* operation flags */
113573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
113673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
113773b526fb4af0f60634f0078583d92b931d5c0eebnethercoteunion vki_semun {
113873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int val;			/* value for SETVAL */
113973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_semid_ds __user *buf;	/* buffer for IPC_STAT & IPC_SET */
114073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short __user *array;	/* array for GETALL & SETALL */
114173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_seminfo __user *__buf;	/* buffer for IPC_INFO */
114273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void __user *__pad;
114373b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
114473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
114573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct  vki_seminfo {
114673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semmap;
114773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semmni;
114873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semmns;
114973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semmnu;
115073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semmsl;
115173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semopm;
115273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semume;
115373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semusz;
115473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semvmx;
115573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int semaem;
115673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
115773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
115873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
115973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-generic/errno-base.h
116073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
116173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
116273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EPERM		 1	/* Operation not permitted */
116345f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define	VKI_ENOENT		 2	/* No such file or directory */
116473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_ESRCH		 3	/* No such process */
116573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EINTR		 4	/* Interrupted system call */
116659451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EIO			 5	/* I/O error */
116759451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENXIO		 6	/* No such device or address */
116859451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_E2BIG		 7	/* Argument list too long */
116959451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENOEXEC		 8	/* Exec format error */
117073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EBADF		 9	/* Bad file number */
117159451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ECHILD		10	/* No child processes */
117259451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EAGAIN		11	/* Try again */
117373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_ENOMEM		12	/* Out of memory */
117473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EACCES		13	/* Permission denied */
117573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EFAULT		14	/* Bad address */
117659451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENOTBLK		15	/* Block device required */
117759451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EBUSY		16	/* Device or resource busy */
117873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EEXIST		17	/* File exists */
117959451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EXDEV		18	/* Cross-device link */
118059451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENODEV		19	/* No such device */
118159451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENOTDIR		20	/* Not a directory */
118259451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EISDIR		21	/* Is a directory */
118373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EINVAL		22	/* Invalid argument */
118459451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENFILE		23	/* File table overflow */
118573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_EMFILE		24	/* Too many open files */
118659451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENOTTY		25	/* Not a typewriter */
118759451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ETXTBSY		26	/* Text file busy */
118859451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EFBIG		27	/* File too large */
118959451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ENOSPC		28	/* No space left on device */
119059451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ESPIPE		29	/* Illegal seek */
119159451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EROFS		30	/* Read-only file system */
119259451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EMLINK		31	/* Too many links */
119359451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EPIPE		32	/* Broken pipe */
119459451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_EDOM		33	/* Math argument out of domain of func */
119559451647ad0829e0ffae02db4d20baeeff2e3239florian#define	VKI_ERANGE		34	/* Math result not representable */
119673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
119773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
119873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/asm-generic/errno.h
119973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
120073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
120159451647ad0829e0ffae02db4d20baeeff2e3239florian#define VKI_EWOULDBLOCK		VKI_EAGAIN
120259451647ad0829e0ffae02db4d20baeeff2e3239florian
120373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_ENOSYS		38	/* Function not implemented */
1204af8a6a8cabe15435a526c6d9435fe83992b671abtom#define	VKI_EOVERFLOW		75	/* Value too large for defined data type */
120573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
120673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
120773b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/wait.h
120873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
120973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
121073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_WNOHANG	0x00000001
121173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
121273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_WALL	0x40000000	/* Wait on all children, regardless of type */
121373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define __VKI_WCLONE	0x80000000	/* Wait only on non-SIGCHLD children */
121473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
121573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
121673b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/mman.h
121773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
121873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
121973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MREMAP_MAYMOVE	1
122073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MREMAP_FIXED	2
122173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
122273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
1223aedcc7aa6015debd6ca554971f2e65488397661atom// From linux-2.6.31-rc4/include/linux/futex.h
122473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
122573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
122673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FUTEX_WAIT (0)
1227b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_FUTEX_WAKE (1)
122873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FUTEX_FD (2)
122973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FUTEX_REQUEUE (3)
1230b5f6f51ebcac183818061bf53427a3e7808ef10dsewardj#define VKI_FUTEX_CMP_REQUEUE (4)
1231aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_WAKE_OP (5)
1232aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_LOCK_PI (6)
1233aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_UNLOCK_PI (7)
1234aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_TRYLOCK_PI (8)
1235aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_WAIT_BITSET (9)
1236aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_WAKE_BITSET (10)
1237aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_WAIT_REQUEUE_PI (11)
1238aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_CMP_REQUEUE_PI (12)
1239497c69e7365352c91422a41583cf3bb5cacc1de1sewardj#define VKI_FUTEX_PRIVATE_FLAG (128)
1240aedcc7aa6015debd6ca554971f2e65488397661atom#define VKI_FUTEX_CLOCK_REALTIME (256)
124173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
124205b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tomstruct vki_robust_list {
124305b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	struct vki_robust_list __user *next;
124405b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom};
124505b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom
124605b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tomstruct vki_robust_list_head {
124705b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	/*
124805b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * The head of the list. Points back to itself if empty:
124905b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 */
125005b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	struct vki_robust_list list;
125105b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom
125205b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	/*
125305b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * This relative offset is set by user-space, it gives the kernel
125405b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * the relative position of the futex field to examine. This way
125505b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * we keep userspace flexible, to freely shape its data-structure,
125605b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * without hardcoding any particular offset into the kernel:
125705b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 */
125805b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	long futex_offset;
125905b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom
126005b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	/*
126105b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * The death of the thread may race with userspace setting
126205b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * up a lock's links. So to handle this race, userspace first
126305b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * sets this field to the address of the to-be-taken lock,
126405b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * then does the lock acquire, and then adds itself to the
126505b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * list, and then clears this field. Hence the kernel will
126605b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * always have full knowledge of all locks that the thread
126705b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * _might_ have taken. We check the owner TID in any case,
126805b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 * so only truly owned locks will be handled.
126905b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	 */
127005b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom	struct vki_robust_list __user *list_op_pending;
127105b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom};
127205b1f9a0d68e6d2c497ed4b671b8ff65e4ddbab9tom
127373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
127473b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/errno.h
127573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
127673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
127773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_ERESTARTSYS	512
127873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
127973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
128073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/stat.h
128173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
128273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
128309b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFMT  00170000
128409b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFSOCK 0140000
128509b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFLNK  0120000
128609b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFREG  0100000
128709b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFBLK  0060000
128809b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFDIR  0040000
128909b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFCHR  0020000
129009b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_IFIFO  0010000
129109b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISUID  0004000
129209b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISGID  0002000
129309b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISVTX  0001000
129409b8480025cb3149879465b769058cb197bb9003njn
129509b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISLNK(m)	(((m) & VKI_S_IFMT) == VKI_S_IFLNK)
129609b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISREG(m)	(((m) & VKI_S_IFMT) == VKI_S_IFREG)
129709b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISDIR(m)	(((m) & VKI_S_IFMT) == VKI_S_IFDIR)
129809b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISCHR(m)	(((m) & VKI_S_IFMT) == VKI_S_IFCHR)
129909b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISBLK(m)	(((m) & VKI_S_IFMT) == VKI_S_IFBLK)
130009b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISFIFO(m)	(((m) & VKI_S_IFMT) == VKI_S_IFIFO)
130109b8480025cb3149879465b769058cb197bb9003njn#define VKI_S_ISSOCK(m)	(((m) & VKI_S_IFMT) == VKI_S_IFSOCK)
130209b8480025cb3149879465b769058cb197bb9003njn
130345f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IRWXU 00700
130473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_S_IRUSR 00400
130573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_S_IWUSR 00200
130645f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IXUSR 00100
130745f4e7c91119c7d01a59f5e827c67841632c9314sewardj
130845f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IRWXG 00070
130945f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IRGRP 00040
131045f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IWGRP 00020
131145f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IXGRP 00010
131245f4e7c91119c7d01a59f5e827c67841632c9314sewardj
131345f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IRWXO 00007
131445f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IROTH 00004
131545f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IWOTH 00002
131645f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_S_IXOTH 00001
131773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
131873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
131973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/dirent.h
132073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
132173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
132273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_dirent {
132373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long		d_ino;
132473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_off_t	d_off;
132573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short	d_reclen;
132673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char		d_name[256]; /* We must not include limits.h! */
132773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
132873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
132973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
1330cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn// From linux-2.6.8.1/include/linux/fcntl.h
1331cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn//----------------------------------------------------------------------
1332cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn
1333b23d50521d681aac7a104cc2abb37efcc4e96ccdtom#define VKI_F_SETLEASE      (VKI_F_LINUX_SPECIFIC_BASE + 0)
1334b23d50521d681aac7a104cc2abb37efcc4e96ccdtom#define VKI_F_GETLEASE      (VKI_F_LINUX_SPECIFIC_BASE + 1)
1335cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn
1336b23d50521d681aac7a104cc2abb37efcc4e96ccdtom#define VKI_F_CANCELLK      (VKI_F_LINUX_SPECIFIC_BASE + 5)
1337b23d50521d681aac7a104cc2abb37efcc4e96ccdtom
1338b23d50521d681aac7a104cc2abb37efcc4e96ccdtom#define VKI_F_DUPFD_CLOEXEC (VKI_F_LINUX_SPECIFIC_BASE + 6)
1339b23d50521d681aac7a104cc2abb37efcc4e96ccdtom
1340b23d50521d681aac7a104cc2abb37efcc4e96ccdtom#define VKI_F_NOTIFY        (VKI_F_LINUX_SPECIFIC_BASE + 2)
1341b23d50521d681aac7a104cc2abb37efcc4e96ccdtom
1342b23d50521d681aac7a104cc2abb37efcc4e96ccdtom#define VKI_F_SETPIPE_SZ    (VKI_F_LINUX_SPECIFIC_BASE + 7)
1343b23d50521d681aac7a104cc2abb37efcc4e96ccdtom#define VKI_F_GETPIPE_SZ    (VKI_F_LINUX_SPECIFIC_BASE + 8)
1344cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn
1345cfb8ad53df2d8d59757bc9477da105fc7fbb1843njn//----------------------------------------------------------------------
134673b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/sysctl.h
134773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
134873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
134973b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct __vki_sysctl_args {
135073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int __user *name;
135173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int nlen;
135273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void __user *oldval;
135373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_size_t __user *oldlenp;
135473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void __user *newval;
135573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	vki_size_t newlen;
135673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long __unused[4];
135773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
135873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
135973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
136073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/aio_abi.h
136173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
136273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
136373b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef unsigned long	vki_aio_context_t;
136473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
136573b526fb4af0f60634f0078583d92b931d5c0eebnethercoteenum {
136673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	VKI_IOCB_CMD_PREAD = 0,
136773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	VKI_IOCB_CMD_PWRITE = 1,
13689c85af75f40edc77bc6492e08f0fd2567147fd14tom	VKI_IOCB_CMD_FSYNC = 2,
13699c85af75f40edc77bc6492e08f0fd2567147fd14tom	VKI_IOCB_CMD_FDSYNC = 3,
13709c85af75f40edc77bc6492e08f0fd2567147fd14tom	VKI_IOCB_CMD_PREADV = 7,
13719c85af75f40edc77bc6492e08f0fd2567147fd14tom	VKI_IOCB_CMD_PWRITEV = 8,
137273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
137373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
137473b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* read() from /dev/aio returns these structures. */
137573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_io_event {
137673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64	data;		/* the data field from the iocb */
137773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64	obj;		/* what iocb this event came from */
137873b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // [[Nb: These fields renamed from 'res' and 'res2' because 'res' is
137973b526fb4af0f60634f0078583d92b931d5c0eebnethercote        //   a macro in vg_syscalls.c!]]
138073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_s64	result;		/* result code for this event */
138173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_s64	result2;	/* secondary result */
138273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
138373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
138473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#if defined(VKI_LITTLE_ENDIAN)
138585665ca6fa29dd64754dabe50eb98f25896e752acerion#  define VKI_PADDED(x,y)	x, y
138673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#elif defined(VKI_BIG_ENDIAN)
138785665ca6fa29dd64754dabe50eb98f25896e752acerion#  define VKI_PADDED(x,y)	y, x
138873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#else
138973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#error edit for your odd byteorder.
139073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif
139173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
139273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_iocb {
139373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	/* these are internal to the kernel/libc. */
139473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64	aio_data;	/* data to be returned in event's data */
139573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32	VKI_PADDED(aio_key, aio_reserved1);
139673b526fb4af0f60634f0078583d92b931d5c0eebnethercote				/* the kernel sets aio_key to the req # */
139773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
139873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	/* common fields */
139973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u16	aio_lio_opcode;	/* see IOCB_CMD_ above */
140073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_s16	aio_reqprio;
140173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32	aio_fildes;
140273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
140373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64	aio_buf;
140473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64	aio_nbytes;
140573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_s64	aio_offset;
140673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
140773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	/* extra parameters */
140873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64	aio_reserved2;	/* TODO: use this for a (struct sigevent *) */
140973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u64	aio_reserved3;
141073b526fb4af0f60634f0078583d92b931d5c0eebnethercote}; /* 64 bytes */
141173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
141273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
141373b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/aio.h
141473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
141573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
141673b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_aio_ring {
141773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	id;	/* kernel internal index number */
141873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	nr;	/* number of io_events */
141973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	head;
142073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	tail;
142173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
142273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	magic;
142373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	compat_features;
142473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	incompat_features;
142573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned	header_length;	/* size of aio_ring */
142673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
142773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_io_event		io_events[0];
142873b526fb4af0f60634f0078583d92b931d5c0eebnethercote}; /* 128 bytes + ring size */
142973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
143073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
143173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/msg.h
143273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
143373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
143473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MSG_STAT 11
143573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_MSG_INFO 12
143673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
143773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_msqid_ds {
143873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_ipc_perm msg_perm;
143973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_msg *msg_first;		/* first message on queue,unused  */
144073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_msg *msg_last;		/* last message in queue,unused */
144173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t msg_stime;	/* last msgsnd time */
144273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t msg_rtime;	/* last msgrcv time */
144373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t msg_ctime;	/* last change time */
144473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  msg_lcbytes;	/* Reuse junk fields for 32 bit */
144573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long  msg_lqbytes;	/* ditto */
144673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short msg_cbytes;	/* current number of bytes on queue */
144773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short msg_qnum;	/* number of messages in queue */
144873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short msg_qbytes;	/* max number of bytes on queue */
144973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_ipc_pid_t msg_lspid;	/* pid of last msgsnd */
145073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_ipc_pid_t msg_lrpid;	/* last receive pid */
145173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
145273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
145373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_msgbuf {
145473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	long mtype;         /* type of message */
145573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char mtext[1];      /* message text */
145673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
145773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
145873b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_msginfo {
145973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int msgpool;
146073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int msgmap;
146173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int msgmax;
146273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int msgmnb;
146373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int msgmni;
146473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int msgssz;
146573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int msgtql;
146673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short  msgseg;
146773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
146873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
146973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
147073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/shm.h
147173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
147273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
147373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_shmid_ds {
147473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_ipc_perm		shm_perm;	/* operation perms */
147573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int			shm_segsz;	/* size of segment (bytes) */
147673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t		shm_atime;	/* last attach time */
147773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t		shm_dtime;	/* last detach time */
147873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_time_t		shm_ctime;	/* last change time */
147973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_ipc_pid_t	shm_cpid;	/* pid of creator */
148073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_kernel_ipc_pid_t	shm_lpid;	/* pid of last operator */
148173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short		shm_nattch;	/* no. of current attaches */
148273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned short 		shm_unused;	/* compatibility */
148373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void 			*shm_unused2;	/* ditto - used by DIPC */
148473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void			*shm_unused3;	/* unused */
148573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
148673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
1487f61fea0d88fc6cc2a6c4ff78c49aa0343529ee20tom#define VKI_SHM_RDONLY  010000  /* read-only access */
148860457093d30b23ac2531682205ab0bd9a5aae2edsewardj#define VKI_SHM_RND     020000  /* round attach address to SHMLBA boundary */
1489f61fea0d88fc6cc2a6c4ff78c49aa0343529ee20tom
149073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SHM_STAT 	13
149173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SHM_INFO 	14
149273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
149373b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Obsolete, used only for backwards compatibility */
149473b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct	vki_shminfo {
149573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int shmmax;
149673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int shmmin;
149773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int shmmni;
149873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int shmseg;
149973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int shmall;
150073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
150173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
150273b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_shm_info {
150373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int used_ids;
150473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long shm_tot;	/* total allocated shm */
150573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long shm_rss;	/* total resident shm */
150673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long shm_swp;	/* total swapped shm */
150773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long swap_attempts;
150873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long swap_successes;
150973b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
151073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
151173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
151273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/rtc.h
151373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
151473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
151573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_rtc_time {
151673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_sec;
151773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_min;
151873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_hour;
151973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_mday;
152073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_mon;
152173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_year;
152273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_wday;
152373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_yday;
152473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int tm_isdst;
152573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
152673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
152773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_AIE_ON	_VKI_IO('p', 0x01)	/* Alarm int. enable on	*/
152873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_AIE_OFF	_VKI_IO('p', 0x02)	/* ... off		*/
152973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_UIE_ON	_VKI_IO('p', 0x03)	/* Update int. enable on*/
153073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_UIE_OFF	_VKI_IO('p', 0x04)	/* ... off		*/
153173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_PIE_ON	_VKI_IO('p', 0x05)	/* Periodic int. enable on*/
153273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_PIE_OFF	_VKI_IO('p', 0x06)	/* ... off		*/
153373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
153473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_ALM_SET		_VKI_IOW('p', 0x07, struct vki_rtc_time) /* Set alarm time  */
153573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_ALM_READ	_VKI_IOR('p', 0x08, struct vki_rtc_time) /* Read alarm time */
153673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_RD_TIME		_VKI_IOR('p', 0x09, struct vki_rtc_time) /* Read RTC time   */
153773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#define RTC_SET_TIME	_IOW('p', 0x0a, struct rtc_time) /* Set RTC time    */
153873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_IRQP_READ	_VKI_IOR('p', 0x0b, unsigned long)	 /* Read IRQ rate   */
153973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_RTC_IRQP_SET	_VKI_IOW('p', 0x0c, unsigned long)	 /* Set IRQ rate    */
154073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
154173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
154273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/isdn.h
154373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
154473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
154595a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote// [[Nb: Resolved this for the common case where CONFIG_COBALT_MICRO_SERVER
154695a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote//   is not defined]]
154795a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote#define VKI_ISDN_MAX_CHANNELS   64
154895a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote
154973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IIOCGETCPS  _VKI_IO('I',21)
155073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
155173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_IIOCNETGPN  _VKI_IO('I',34)
155273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
155373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_ISDN_MSNLEN          32
155473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
155573b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct {
155673b526fb4af0f60634f0078583d92b931d5c0eebnethercote  char name[10];
155773b526fb4af0f60634f0078583d92b931d5c0eebnethercote  char phone[VKI_ISDN_MSNLEN];
155873b526fb4af0f60634f0078583d92b931d5c0eebnethercote  int  outgoing;
155973b526fb4af0f60634f0078583d92b931d5c0eebnethercote} vki_isdn_net_ioctl_phone;
156073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
156173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
156273b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/sockios.h
156373b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
156473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
156573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCOUTQ		VKI_TIOCOUTQ
156673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
156773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCADDRT		0x890B	/* add routing table entry	*/
156873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCDELRT		0x890C	/* delete routing table entry	*/
156973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
157073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFNAME		0x8910	/* get iface name		*/
157173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFCONF		0x8912	/* get iface list		*/
157273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFFLAGS	0x8913	/* get flags			*/
157373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFFLAGS	0x8914	/* set flags			*/
157473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFADDR		0x8915	/* get PA address		*/
157573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFADDR		0x8916	/* set PA address		*/
157673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFDSTADDR	0x8917	/* get remote PA address	*/
157773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFDSTADDR	0x8918	/* set remote PA address	*/
157873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFBRDADDR	0x8919	/* get broadcast PA address	*/
157973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFBRDADDR	0x891a	/* set broadcast PA address	*/
158073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFNETMASK	0x891b	/* get network PA mask		*/
158173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFNETMASK	0x891c	/* set network PA mask		*/
158273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFMETRIC	0x891d	/* get metric			*/
158373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFMETRIC	0x891e	/* set metric			*/
158473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFMTU		0x8921	/* get MTU size			*/
158573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFMTU		0x8922	/* set MTU size			*/
158673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	VKI_SIOCSIFHWADDR	0x8924	/* set hardware address 	*/
158773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFHWADDR	0x8927	/* Get hardware address		*/
158873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFINDEX	0x8933	/* name -> if_index mapping	*/
158973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
159073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFTXQLEN	0x8942	/* Get the tx queue length	*/
159173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFTXQLEN	0x8943	/* Set the tx queue length 	*/
159273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
159373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGMIIPHY		0x8947	/* Get address of MII PHY in use. */
159473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGMIIREG		0x8948	/* Read MII PHY register.	*/
159573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSMIIREG		0x8949	/* Write MII PHY register.	*/
159673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
159773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCDARP		0x8953	/* delete ARP table entry	*/
159873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGARP		0x8954	/* get ARP table entry		*/
159973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSARP		0x8955	/* set ARP table entry		*/
160073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
160173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCDRARP		0x8960	/* delete RARP table entry	*/
160273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGRARP		0x8961	/* get RARP table entry		*/
160373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSRARP		0x8962	/* set RARP table entry		*/
160473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
160573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCGIFMAP		0x8970	/* Get device parameters	*/
160673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIOCSIFMAP		0x8971	/* Set device parameters	*/
160773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
160873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
160973b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/ppdev.h
161073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
161173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
161273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PP_MAJOR	99
161373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
161473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PP_IOCTL	'p'
161573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
161673b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Set mode for read/write (e.g. IEEE1284_MODE_EPP) */
161773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPSETMODE	_VKI_IOW(VKI_PP_IOCTL, 0x80, int)
161873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
161973b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Read status */
162073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPRSTATUS	_VKI_IOR(VKI_PP_IOCTL, 0x81, unsigned char)
162173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#define PPWSTATUS	OBSOLETE__IOW(PP_IOCTL, 0x82, unsigned char)
162273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
162373b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Read/write control */
162473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPRCONTROL	_VKI_IOR(VKI_PP_IOCTL, 0x83, unsigned char)
162573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPWCONTROL	_VKI_IOW(VKI_PP_IOCTL, 0x84, unsigned char)
162673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
162773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_ppdev_frob_struct {
162873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char mask;
162973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char val;
163073b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
163173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPFCONTROL      _VKI_IOW(VKI_PP_IOCTL, 0x8e, struct vki_ppdev_frob_struct)
163273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
163373b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Read/write data */
163473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPRDATA		_VKI_IOR(VKI_PP_IOCTL, 0x85, unsigned char)
163573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPWDATA		_VKI_IOW(VKI_PP_IOCTL, 0x86, unsigned char)
163673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
163773b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Claim the port to start using it */
163873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPCLAIM		_VKI_IO(VKI_PP_IOCTL, 0x8b)
163973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
164073b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Release the port when you aren't using it */
164173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPRELEASE	_VKI_IO(VKI_PP_IOCTL, 0x8c)
164273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
164373b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Yield the port (release it if another driver is waiting,
164473b526fb4af0f60634f0078583d92b931d5c0eebnethercote * then reclaim) */
164573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPYIELD		_VKI_IO(VKI_PP_IOCTL, 0x8d)
164673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
164773b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Register device exclusively (must be before PPCLAIM). */
164873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPEXCL		_VKI_IO(VKI_PP_IOCTL, 0x8f)
164973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
165073b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Data line direction: non-zero for input mode. */
165173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPDATADIR	_VKI_IOW(VKI_PP_IOCTL, 0x90, int)
165273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
165373b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Negotiate a particular IEEE 1284 mode. */
165473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPNEGOT	_VKI_IOW(VKI_PP_IOCTL, 0x91, int)
165573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
165673b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Set control lines when an interrupt occurs. */
165773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPWCTLONIRQ	_VKI_IOW(VKI_PP_IOCTL, 0x92, unsigned char)
165873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
165973b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Clear (and return) interrupt count. */
166073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPCLRIRQ	_VKI_IOR(VKI_PP_IOCTL, 0x93, int)
166173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
166273b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Set the IEEE 1284 phase that we're in (e.g. IEEE1284_PH_FWD_IDLE) */
166373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPSETPHASE	_VKI_IOW(VKI_PP_IOCTL, 0x94, int)
166473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
166573b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Set and get port timeout (struct timeval's) */
166673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPGETTIME	_VKI_IOR(VKI_PP_IOCTL, 0x95, struct vki_timeval)
166773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPSETTIME	_VKI_IOW(VKI_PP_IOCTL, 0x96, struct vki_timeval)
166873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
166973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPGETMODES	_VKI_IOR(VKI_PP_IOCTL, 0x97, unsigned int)
167073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
167173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPGETMODE	_VKI_IOR(VKI_PP_IOCTL, 0x98, int)
167273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPGETPHASE	_VKI_IOR(VKI_PP_IOCTL, 0x99, int)
167373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
167473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPGETFLAGS	_VKI_IOR(VKI_PP_IOCTL, 0x9a, int)
167573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_PPSETFLAGS	_VKI_IOW(VKI_PP_IOCTL, 0x9b, int)
167673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
167773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
167873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/fs.h
167973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
168073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
1681edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKROSET   _VKI_IO(0x12,93)	/* set device read-only (0 = read-write) */
1682edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKROGET   _VKI_IO(0x12,94)	/* get read-only status (0 = read_write) */
168395a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote#define VKI_BLKGETSIZE _VKI_IO(0x12,96) /* return device size /512 (long *arg) */
1684edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKRASET   _VKI_IO(0x12,98)	/* set read ahead for block device */
1685edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKRAGET   _VKI_IO(0x12,99)	/* get current read ahead setting */
1686edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKFRASET  _VKI_IO(0x12,100)/* set filesystem (mm/filemap.c) read-ahead */
1687edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKFRAGET  _VKI_IO(0x12,101)/* get filesystem (mm/filemap.c) read-ahead */
1688edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKSECTGET _VKI_IO(0x12,103)/* get max sectors per request (ll_rw_blk.c) */
1689edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKSSZGET  _VKI_IO(0x12,104)/* get block device sector size */
1690edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKBSZGET  _VKI_IOR(0x12,112,vki_size_t)
1691edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKBSZSET  _VKI_IOW(0x12,113,vki_size_t)
1692edd26f1ef9d2a47c3708aaf6196f8a7239a26699tom#define VKI_BLKGETSIZE64 _VKI_IOR(0x12,114,vki_size_t) /* return device size in bytes (u64 *arg) */
169395a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote
169473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FIBMAP	_VKI_IO(0x00,1)	/* bmap access */
169573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FIGETBSZ    _VKI_IO(0x00,2)	/* get the block size used for bmap */
169673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
169773b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
169873b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/scsi/sg.h
169973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
170073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
170173b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct vki_sg_io_hdr
170273b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
170373b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int interface_id;           /* [i] 'S' for SCSI generic (required) */
170473b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int dxfer_direction;        /* [i] data transfer direction  */
170573b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned char cmd_len;      /* [i] SCSI command length ( <= 16 bytes) */
170673b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned char mx_sb_len;    /* [i] max length to write to sbp */
170773b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned short iovec_count; /* [i] 0 implies no scatter gather */
170873b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned int dxfer_len;     /* [i] byte count of data transfer */
170973b526fb4af0f60634f0078583d92b931d5c0eebnethercote    void __user *dxferp;	/* [i], [*io] points to data transfer memory
171073b526fb4af0f60634f0078583d92b931d5c0eebnethercote					      or scatter gather list */
171173b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned char __user *cmdp; /* [i], [*i] points to command to perform */
171273b526fb4af0f60634f0078583d92b931d5c0eebnethercote    void __user *sbp;		/* [i], [*o] points to sense_buffer memory */
171373b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned int timeout;       /* [i] MAX_UINT->no timeout (unit: millisec) */
171473b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned int flags;         /* [i] 0 -> default, see SG_FLAG... */
171573b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int pack_id;                /* [i->o] unused internally (normally) */
171673b526fb4af0f60634f0078583d92b931d5c0eebnethercote    void __user * usr_ptr;      /* [i->o] unused internally */
171773b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned char status;       /* [o] scsi status */
171873b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned char masked_status;/* [o] shifted, masked scsi status */
171973b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned char msg_status;   /* [o] messaging level data (optional) */
172073b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned char sb_len_wr;    /* [o] byte count actually written to sbp */
172173b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned short host_status; /* [o] errors from host adapter */
172273b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned short driver_status;/* [o] errors from software driver */
172373b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int resid;                  /* [o] dxfer_len - actual_transferred */
172473b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned int duration;      /* [o] time taken by cmd (unit: millisec) */
172573b526fb4af0f60634f0078583d92b931d5c0eebnethercote    unsigned int info;          /* [o] auxiliary information */
172673b526fb4af0f60634f0078583d92b931d5c0eebnethercote} vki_sg_io_hdr_t;  /* 64 bytes long (on i386) */
172773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
172873b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct vki_sg_scsi_id { /* used by SG_GET_SCSI_ID ioctl() */
172973b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int host_no;        /* as in "scsi<n>" where 'n' is one of 0, 1, 2 etc */
173073b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int channel;
173173b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int scsi_id;        /* scsi id of target device */
173273b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int lun;
173373b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int scsi_type;      /* TYPE_... defined in scsi/scsi.h */
173473b526fb4af0f60634f0078583d92b931d5c0eebnethercote    short h_cmd_per_lun;/* host (adapter) maximum commands per lun */
173573b526fb4af0f60634f0078583d92b931d5c0eebnethercote    short d_queue_depth;/* device (or adapter) maximum queue length */
173673b526fb4af0f60634f0078583d92b931d5c0eebnethercote    int unused[2];      /* probably find a good use, set 0 for now */
173773b526fb4af0f60634f0078583d92b931d5c0eebnethercote} vki_sg_scsi_id_t; /* 32 bytes long on i386 */
173873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
173973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_EMULATED_HOST 0x2203 /* true for emulated host adapter (ATAPI) */
174073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
174173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_SET_RESERVED_SIZE 0x2275  /* request a new reserved buffer size */
174273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_GET_RESERVED_SIZE 0x2272  /* actual size of reserved buffer */
174373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
174473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_GET_SCSI_ID 0x2276   /* Yields fd's bus, chan, dev, lun + type */
174573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
174673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_GET_SG_TABLESIZE 0x227F  /* 0 implies can't do scatter gather */
174773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
174873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_GET_VERSION_NUM 0x2282 /* Example: version 2.1.34 yields 20134 */
174973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
175073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_IO 0x2285   /* similar effect as write() followed by read() */
175173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
175273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_SET_TIMEOUT 0x2201  /* unit: jiffies (10ms on i386) */
175373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_GET_TIMEOUT 0x2202  /* yield timeout as _return_ value */
175473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
175573b526fb4af0f60634f0078583d92b931d5c0eebnethercote//#define SG_GET_COMMAND_Q 0x2270   /* Yields 0 (queuing off) or 1 (on) */
175673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SG_SET_COMMAND_Q 0x2271   /* Change queuing state with 0 or 1 */
175773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
175873b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
17598758e70558926c9fa640de885df57c5cbbbbefectom// From linux-2.6.34/include/scsi/scsi.h and scsi/scsi_ioctl.h
17608758e70558926c9fa640de885df57c5cbbbbefectom//----------------------------------------------------------------------
17618758e70558926c9fa640de885df57c5cbbbbefectom
17628758e70558926c9fa640de885df57c5cbbbbefectom#define VKI_SCSI_IOCTL_DOORLOCK		0x5380 /* Lock the eject mechanism.  */
17638758e70558926c9fa640de885df57c5cbbbbefectom#define VKI_SCSI_IOCTL_DOORUNLOCK	0x5381 /* Unlock the mechanism.  */
17648758e70558926c9fa640de885df57c5cbbbbefectom#define VKI_SCSI_IOCTL_GET_IDLUN	0x5382
17658758e70558926c9fa640de885df57c5cbbbbefectom#define VKI_SCSI_IOCTL_GET_BUS_NUMBER	0x5386
17668758e70558926c9fa640de885df57c5cbbbbefectom
17678758e70558926c9fa640de885df57c5cbbbbefectomstruct vki_scsi_idlun {
17688758e70558926c9fa640de885df57c5cbbbbefectom	__vki_u32 dev_id;
17698758e70558926c9fa640de885df57c5cbbbbefectom	__vki_u32 host_unique_id;
17708758e70558926c9fa640de885df57c5cbbbbefectom};
17718758e70558926c9fa640de885df57c5cbbbbefectom
17728758e70558926c9fa640de885df57c5cbbbbefectom//----------------------------------------------------------------------
177373b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/cdrom.h
177473b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
177573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
177673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMPLAYMSF	0x5303 /* Play Audio MSF (struct cdrom_msf) */
177773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMREADTOCHDR	0x5305 /* Read TOC header
177873b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                           (struct cdrom_tochdr) */
177973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMREADTOCENTRY	0x5306 /* Read TOC entry
178073b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                           (struct cdrom_tocentry) */
178173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMSUBCHNL	0x530b /* Read subchannel data
178273b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                           (struct cdrom_subchnl) */
178373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMREADMODE2	0x530c /* Read CDROM mode 2 data (2336 Bytes)
178473b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                           (struct cdrom_read) */
178573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMREADAUDIO	0x530e /* (struct cdrom_read_audio) */
178673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMMULTISESSION	0x5310 /* Obtain the start-of-last-session
178773b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                           address of multi session disks
178873b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                           (struct cdrom_multisession) */
178973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROM_GET_MCN	0x5311 /* Obtain the "Universal Product Code"
179073b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                           if available (struct cdrom_mcn) */
179173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROMVOLREAD	0x5313 /* Get the drive's volume setting
179273b526fb4af0f60634f0078583d92b931d5c0eebnethercote                                          (struct cdrom_volctrl) */
1793f9d83852c10bc84e8932ab8a1d18766df2f522betom#define VKI_CDROMREADRAW	0x5314	/* read data in raw mode (2352 Bytes)
1794f9d83852c10bc84e8932ab8a1d18766df2f522betom                                           (struct cdrom_read) */
179573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROM_CLEAR_OPTIONS	0x5321  /* Clear behavior options */
179673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROM_DRIVE_STATUS	0x5326  /* Get tray position, etc. */
179773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
179873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROM_SEND_PACKET	0x5393	/* send a packet to the drive */
179973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
180073b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_msf0
180173b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
180273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	minute;
180373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	second;
180473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	frame;
180573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
180673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
180773b526fb4af0f60634f0078583d92b931d5c0eebnethercoteunion vki_cdrom_addr
180873b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
180973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_cdrom_msf0	msf;
181073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int			lba;
181173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
181273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
181373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_msf
181473b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
181573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdmsf_min0;	/* start minute */
181673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdmsf_sec0;	/* start second */
181773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdmsf_frame0;	/* start frame */
181873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdmsf_min1;	/* end minute */
181973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdmsf_sec1;	/* end second */
182073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdmsf_frame1;	/* end frame */
182173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
182273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
182373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_tochdr
182473b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
182573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdth_trk0;	/* start track */
182673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdth_trk1;	/* end track */
182773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
182873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
182973b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_volctrl
183073b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
183173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	channel0;
183273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	channel1;
183373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	channel2;
183473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	channel3;
183573b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
183673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
183773b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_subchnl
183873b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
183973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdsc_format;
184073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdsc_audiostatus;
184173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdsc_adr:	4;
184273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdsc_ctrl:	4;
184373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdsc_trk;
184473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdsc_ind;
184573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union vki_cdrom_addr cdsc_absaddr;
184673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union vki_cdrom_addr cdsc_reladdr;
184773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
184873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
184973b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_tocentry
185073b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
185173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdte_track;
185273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdte_adr	:4;
185373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdte_ctrl	:4;
185473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdte_format;
185573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union vki_cdrom_addr cdte_addr;
185673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8	cdte_datamode;
185773b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
185873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
185973b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_read
186073b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
186173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	cdread_lba;
186273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char 	*cdread_bufaddr;
186373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int	cdread_buflen;
186473b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
186573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
186673b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_read_audio
186773b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
186873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union vki_cdrom_addr addr; /* frame address */
186973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8 addr_format;      /* CDROM_LBA or CDROM_MSF */
187073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int nframes;           /* number of 2352-byte-frames to read at once */
187173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8 __user *buf;      /* frame buffer (size: nframes*2352 bytes) */
187273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
187373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
187473b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_multisession
187573b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
187673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	union vki_cdrom_addr addr; /* frame address: start-of-last-session
187773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	                           (not the new "frame 16"!).  Only valid
187873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	                           if the "xa_flag" is true. */
187973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8 xa_flag;        /* 1: "is XA disk" */
188073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u8 addr_format;    /* CDROM_LBA or CDROM_MSF */
188173b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
188273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
188373b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_mcn
188473b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
188573b526fb4af0f60634f0078583d92b931d5c0eebnethercote  __vki_u8 medium_catalog_number[14]; /* 13 ASCII digits, null-terminated */
188673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
188773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
188873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CDROM_PACKET_SIZE	12
188973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
189073b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_cdrom_generic_command
189173b526fb4af0f60634f0078583d92b931d5c0eebnethercote{
189273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char 		cmd[VKI_CDROM_PACKET_SIZE];
189373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char		__user *buffer;
189473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned int 		buflen;
189573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int			stat;
189673b526fb4af0f60634f0078583d92b931d5c0eebnethercote        // [[replace with void* to reduce inclusion amounts]]
189773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void/*struct vki_request_sense	*/__user *sense;
189873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned char		data_direction;
189973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int			quiet;
190073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	int			timeout;
190173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	void			__user *reserved[1];	/* unused, actually */
190273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
190373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
190473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CD_SYNC_SIZE         12 /* 12 sync bytes per raw data frame */
190573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CD_HEAD_SIZE          4 /* header (address) bytes per raw data frame */
190673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CD_FRAMESIZE_RAW   2352 /* bytes per frame, "raw" mode */
190773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_CD_FRAMESIZE_RAW0 (VKI_CD_FRAMESIZE_RAW-VKI_CD_SYNC_SIZE-VKI_CD_HEAD_SIZE) /*2336*/
190873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
190973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
191073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/soundcard.h
191173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
191273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
191373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#ifndef _VKI_SIOWR
191473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#if defined(_VKI_IOWR) && (defined(_AIX) || (!defined(sun) && !defined(sparc) && !defined(__sparc__) && !defined(__INCioctlh) && !defined(__Lynx__)))
191573b526fb4af0f60634f0078583d92b931d5c0eebnethercote/* Use already defined ioctl defines if they exist (except with Sun or Sparc) */
191673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	_VKI_SIO		_VKI_IO
191773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	_VKI_SIOR		_VKI_IOR
191873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	_VKI_SIOW		_VKI_IOW
191973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define	_VKI_SIOWR		_VKI_IOWR
192073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#else
192173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Valgrind: Install this case if/when necessary]
192273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#error Valgrind: Cannot handle sparc/sun case yet...
192373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#  endif /* _IOWR */
192473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#endif  /* !_VKI_SIOWR */
192573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
192673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_CTRLRATE		_VKI_SIOWR('Q', 3, int)	/* Set/get timer resolution (HZ) */
192773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_GETOUTCOUNT	_VKI_SIOR ('Q', 4, int)
192873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_GETINCOUNT	_VKI_SIOR ('Q', 5, int)
192973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_PERCMODE		_VKI_SIOW ('Q', 6, int)
193073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_TESTMIDI		_VKI_SIOW ('Q', 8, int)
193173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_RESETSAMPLES	_VKI_SIOW ('Q', 9, int)
193273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_NRSYNTHS		_VKI_SIOR ('Q',10, int)
193373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_NRMIDIS		_VKI_SIOR ('Q',11, int)
193473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_SEQ_GETTIME		_VKI_SIOR ('Q',19, int)
193573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
193673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_TMR_TIMEBASE		_VKI_SIOWR('T', 1, int)
193773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_TMR_TEMPO		_VKI_SIOWR('T', 5, int)
193873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_TMR_SOURCE		_VKI_SIOWR('T', 6, int)
193973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
194073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_MIDI_PRETIME		_VKI_SIOWR('m', 0, int)
194173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_MIDI_MPUMODE		_VKI_SIOWR('m', 1, int)
194273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
194373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_RESET		_VKI_SIO  ('P', 0)
194473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SYNC		_VKI_SIO  ('P', 1)
194573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SPEED		_VKI_SIOWR('P', 2, int)
194673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_STEREO		_VKI_SIOWR('P', 3, int)
194773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETBLKSIZE	_VKI_SIOWR('P', 4, int)
194873b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_CHANNELS		_VKI_SIOWR('P', 6, int)
194973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SOUND_PCM_WRITE_FILTER	_VKI_SIOWR('P', 7, int)
195073b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_POST		_VKI_SIO  ('P', 8)
195173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SUBDIVIDE	_VKI_SIOWR('P', 9, int)
195273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SETFRAGMENT	_VKI_SIOWR('P',10, int)
195373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
195473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETFMTS		_VKI_SIOR ('P',11, int) /* Returns a mask */
195555703dfaee1f046e2f038b65592387afb0187967tom#define VKI_SNDCTL_DSP_SETFMT		_VKI_SIOWR('P', 5, int) /* Selects ONE fmt */
195673b526fb4af0f60634f0078583d92b931d5c0eebnethercote
195773b526fb4af0f60634f0078583d92b931d5c0eebnethercotetypedef struct vki_audio_buf_info {
195873b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int fragments;	/* # of available fragments (partially usend ones not counted) */
195973b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int fragstotal;	/* Total # of fragments allocated */
196073b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int fragsize;	/* Size of a fragment in bytes */
196173b526fb4af0f60634f0078583d92b931d5c0eebnethercote
196273b526fb4af0f60634f0078583d92b931d5c0eebnethercote			int bytes;	/* Available space in bytes (includes partially used fragments) */
196373b526fb4af0f60634f0078583d92b931d5c0eebnethercote			/* Note! 'bytes' could be more than fragments*fragsize */
196473b526fb4af0f60634f0078583d92b931d5c0eebnethercote		} vki_audio_buf_info;
196573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
196673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETOSPACE	_VKI_SIOR ('P',12, vki_audio_buf_info)
196773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETISPACE	_VKI_SIOR ('P',13, vki_audio_buf_info)
19680660567477bcf5b7e323de8d2e68dc5a9cd7334fnjn#define VKI_SNDCTL_DSP_NONBLOCK		_VKI_SIO  ('P',14)
196973b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETCAPS		_VKI_SIOR ('P',15, int)
197073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
197173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETTRIGGER	_VKI_SIOR ('P',16, int)
197273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SETTRIGGER	_VKI_SIOW ('P',16, int)
197373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
197473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SETSYNCRO	_VKI_SIO  ('P', 21)
197573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SETDUPLEX	_VKI_SIO  ('P', 22)
197673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETODELAY	_VKI_SIOR ('P', 23, int)
197773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
197895a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote#define VKI_SNDCTL_DSP_GETCHANNELMASK	_VKI_SIOWR('P', 64, int)
197995a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote#define VKI_SNDCTL_DSP_BIND_CHANNEL	_VKI_SIOWR('P', 65, int)
198095a9786cd29c06af2c1cda9ac20e5b0ea488faa4nethercote
198173b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_SETSPDIF		_VKI_SIOW ('P', 66, int)
198273b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SNDCTL_DSP_GETSPDIF		_VKI_SIOR ('P', 67, int)
198373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
198473b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SOUND_PCM_READ_RATE		_VKI_SIOR ('P', 2, int)
198573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SOUND_PCM_READ_CHANNELS	_VKI_SIOR ('P', 6, int)
198673b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SOUND_PCM_READ_BITS		_VKI_SIOR ('P', 5, int)
198773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SOUND_PCM_READ_FILTER	_VKI_SIOR ('P', 7, int)
198873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
198973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
199073b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
199173b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/hdreg.h
199273b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
199373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
19942c2bc2529113fa4df16d9341c79a3b1f2d4fda56tomstruct vki_hd_geometry {
19952c2bc2529113fa4df16d9341c79a3b1f2d4fda56tom      unsigned char heads;
19962c2bc2529113fa4df16d9341c79a3b1f2d4fda56tom      unsigned char sectors;
19972c2bc2529113fa4df16d9341c79a3b1f2d4fda56tom      unsigned short cylinders;
19982c2bc2529113fa4df16d9341c79a3b1f2d4fda56tom      unsigned long start;
19992c2bc2529113fa4df16d9341c79a3b1f2d4fda56tom};
20002c2bc2529113fa4df16d9341c79a3b1f2d4fda56tom
20012c2bc2529113fa4df16d9341c79a3b1f2d4fda56tom#define VKI_HDIO_GETGEO		0x0301	/* get device geometry */
20025d2af674214d1f7b9abda9b178775c69dc4f7c7dtom#define VKI_HDIO_GET_DMA	0x030b	/* get use-dma flag */
200373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_HDIO_GET_IDENTITY	0x030d	/* get IDE identification info */
200473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
200573b526fb4af0f60634f0078583d92b931d5c0eebnethercote// [[Nb: done like this because the original type is a huge struct that will
200673b526fb4af0f60634f0078583d92b931d5c0eebnethercote//   always be the same size.]]
200773b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_SIZEOF_STRUCT_HD_DRIVEID   512
200873b526fb4af0f60634f0078583d92b931d5c0eebnethercote
200973b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
201073b526fb4af0f60634f0078583d92b931d5c0eebnethercote// From linux-2.6.8.1/include/linux/fb.h
201173b526fb4af0f60634f0078583d92b931d5c0eebnethercote//----------------------------------------------------------------------
201273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
201373b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FBIOGET_VSCREENINFO	0x4600
2014fca8f5fadcbecf5f69e268f9c7393d27944fcd7atom#define VKI_FBIOPUT_VSCREENINFO	0x4601
201573b526fb4af0f60634f0078583d92b931d5c0eebnethercote#define VKI_FBIOGET_FSCREENINFO	0x4602
2016fca8f5fadcbecf5f69e268f9c7393d27944fcd7atom#define VKI_FBIOPAN_DISPLAY	0x4606
201773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
201873b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_fb_fix_screeninfo {
201973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	char id[16];			/* identification string eg "TT Builtin" */
202073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long smem_start;	/* Start of frame buffer mem */
202173b526fb4af0f60634f0078583d92b931d5c0eebnethercote					/* (physical address) */
202273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 smem_len;			/* Length of frame buffer mem */
202373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 type;			/* see FB_TYPE_*		*/
202473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 type_aux;		/* Interleave for interleaved Planes */
202573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 visual;		/* see FB_VISUAL_*		*/
202673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u16 xpanstep;		/* zero if no hardware panning  */
202773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u16 ypanstep;		/* zero if no hardware panning  */
202873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u16 ywrapstep;		/* zero if no hardware ywrap    */
202973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 line_length;		/* length of a line in bytes    */
203073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	unsigned long mmio_start;	/* Start of Memory Mapped I/O   */
203173b526fb4af0f60634f0078583d92b931d5c0eebnethercote					/* (physical address) */
203273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 mmio_len;		/* Length of Memory Mapped I/O  */
203373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 accel;		/* Indicate to driver which	*/
203473b526fb4af0f60634f0078583d92b931d5c0eebnethercote					/*  specific chip/card we have	*/
203573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u16 reserved[3];		/* Reserved for future compatibility */
203673b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
203773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
203873b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_fb_bitfield {
203973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 offset;		/* beginning of bitfield	*/
204073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 length;		/* length of bitfield		*/
204173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 msb_right;		/* != 0 : Most significant bit is */
204273b526fb4af0f60634f0078583d92b931d5c0eebnethercote					/* right */
204373b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
204473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
204573b526fb4af0f60634f0078583d92b931d5c0eebnethercotestruct vki_fb_var_screeninfo {
204673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 xres;			/* visible resolution		*/
204773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 yres;
204873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 xres_virtual;		/* virtual resolution		*/
204973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 yres_virtual;
205073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 xoffset;		/* offset from virtual to visible */
205173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 yoffset;		/* resolution			*/
205273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
205373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 bits_per_pixel;	/* guess what			*/
205473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 grayscale;		/* != 0 Graylevels instead of colors */
205573b526fb4af0f60634f0078583d92b931d5c0eebnethercote
205673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_fb_bitfield red;	/* bitfield in fb mem if true color, */
205773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_fb_bitfield green;	/* else only length is significant */
205873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_fb_bitfield blue;
205973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	struct vki_fb_bitfield transp;	/* transparency			*/
206073b526fb4af0f60634f0078583d92b931d5c0eebnethercote
206173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 nonstd;		/* != 0 Non standard pixel format */
206273b526fb4af0f60634f0078583d92b931d5c0eebnethercote
206373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 activate;		/* see FB_ACTIVATE_*		*/
206473b526fb4af0f60634f0078583d92b931d5c0eebnethercote
206573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 height;		/* height of picture in mm    */
206673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 width;		/* width of picture in mm     */
206773b526fb4af0f60634f0078583d92b931d5c0eebnethercote
206873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 accel_flags;		/* (OBSOLETE) see fb_info.flags */
206973b526fb4af0f60634f0078583d92b931d5c0eebnethercote
207073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	/* Timing: All values in pixclocks, except pixclock (of course) */
207173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 pixclock;		/* pixel clock in ps (pico seconds) */
207273b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 left_margin;		/* time from sync to picture	*/
207373b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 right_margin;		/* time from picture to sync	*/
207473b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 upper_margin;		/* time from sync to picture	*/
207573b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 lower_margin;
207673b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 hsync_len;		/* length of horizontal sync	*/
207773b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 vsync_len;		/* length of vertical sync	*/
207873b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 sync;			/* see FB_SYNC_*		*/
207973b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 vmode;		/* see FB_VMODE_*		*/
208073b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 rotate;		/* angle we rotate counter clockwise */
208173b526fb4af0f60634f0078583d92b931d5c0eebnethercote	__vki_u32 reserved[5];		/* Reserved for future compatibility */
208273b526fb4af0f60634f0078583d92b931d5c0eebnethercote};
208373b526fb4af0f60634f0078583d92b931d5c0eebnethercote
2084b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes//----------------------------------------------------------------------
2085053eb0470396ddd47a7cc1ea4882a3c241631e10tom// From linux-2.6.9/include/linux/kd.h
2086b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes//----------------------------------------------------------------------
2087b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2088b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_GIO_FONT       0x4B60  /* gets font in expanded form */
2089b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_FONT       0x4B61  /* use font in expanded form */
2090b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2091b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_GIO_FONTX      0x4B6B  /* get font using struct consolefontdesc */
2092b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_FONTX      0x4B6C  /* set font using struct consolefontdesc */
2093b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughesstruct vki_consolefontdesc {
2094b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned short charcount;	/* characters in font (256 or 512) */
2095b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned short charheight;	/* scan lines per character (1-32) */
2096b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	char __user *chardata;		/* font data in expanded form */
2097b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes};
2098b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2099b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_FONTRESET  0x4B6D  /* reset to default font */
2100b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2101b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_GIO_CMAP       0x4B70  /* gets colour palette on VGA+ */
2102b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_CMAP       0x4B71  /* sets colour palette on VGA+ */
2103b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2104b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KIOCSOUND      0x4B2F  /* start sound generation (0 for off) */
2105b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDMKTONE       0x4B30  /* generate tone */
2106b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2107b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGETLED       0x4B31  /* return current led state */
2108b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSETLED       0x4B32  /* set led state [lights, not flags] */
2109b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2110b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGKBTYPE      0x4B33  /* get keyboard type */
2111b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2112b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDADDIO        0x4B34  /* add i/o port as valid */
2113b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDDELIO        0x4B35  /* del i/o port as valid */
2114b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDENABIO       0x4B36  /* enable i/o to video board */
2115b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDDISABIO      0x4B37  /* disable i/o to video board */
2116b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2117b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSETMODE      0x4B3A  /* set text/graphics mode */
2118b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGETMODE      0x4B3B  /* get current mode */
2119b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2120b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDMAPDISP      0x4B3C  /* map display into address space */
2121b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDUNMAPDISP    0x4B3D  /* unmap display from address space */
2122b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2123b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define		VKI_E_TABSZ		256
2124b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_GIO_SCRNMAP    0x4B40  /* get screen mapping from kernel */
2125b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_SCRNMAP	   0x4B41  /* put screen mapping table in kernel */
2126b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_GIO_UNISCRNMAP 0x4B69  /* get full Unicode screen mapping */
2127b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_UNISCRNMAP 0x4B6A  /* set full Unicode screen mapping */
2128b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2129b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_GIO_UNIMAP     0x4B66  /* get unicode-to-font mapping from kernel */
2130053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_unipair {
2131053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short unicode;
2132053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short fontpos;
2133053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2134053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_unimapdesc {
2135053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short entry_ct;
2136053eb0470396ddd47a7cc1ea4882a3c241631e10tom	struct vki_unipair __user *entries;
2137053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2138b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_UNIMAP     0x4B67  /* put unicode-to-font mapping in kernel */
2139b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_PIO_UNIMAPCLR  0x4B68  /* clear table, possibly advise hash algorithm */
2140053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_unimapinit {
2141053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short advised_hashsize;  /* 0 if no opinion */
2142053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short advised_hashstep;  /* 0 if no opinion */
2143053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short advised_hashlevel; /* 0 if no opinion */
2144053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2145b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2146b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGKBMODE      0x4B44  /* gets current keyboard mode */
2147b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSKBMODE      0x4B45  /* sets current keyboard mode */
2148b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2149b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGKBMETA      0x4B62  /* gets meta key handling mode */
2150b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSKBMETA      0x4B63  /* sets meta key handling mode */
2151b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2152b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGKBLED       0x4B64  /* get led flags (not lights) */
2153b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSKBLED       0x4B65  /* set led flags (not lights) */
2154b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2155b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughesstruct vki_kbentry {
2156b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned char kb_table;
2157b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned char kb_index;
2158b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned short kb_value;
2159b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes};
2160b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGKBENT       0x4B46  /* gets one entry in translation table */
2161b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSKBENT       0x4B47  /* sets one entry in translation table */
2162b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2163b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughesstruct vki_kbsentry {
2164b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned char kb_func;
2165b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned char kb_string[512];
2166b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes};
2167b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGKBSENT      0x4B48  /* gets one function key string entry */
2168b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSKBSENT      0x4B49  /* sets one function key string entry */
2169b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2170b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughesstruct vki_kbdiacr {
2171b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes        unsigned char diacr, base, result;
2172b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes};
2173b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughesstruct vki_kbdiacrs {
2174b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes        unsigned int kb_cnt;    /* number of entries in following array */
2175b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	struct vki_kbdiacr kbdiacr[256];    /* MAX_DIACR from keyboard.h */
2176b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes};
2177b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGKBDIACR     0x4B4A  /* read kernel accent table */
2178b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSKBDIACR     0x4B4B  /* write kernel accent table */
2179b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2180b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughesstruct vki_kbkeycode {
2181b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	unsigned int scancode, keycode;
2182b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes};
2183b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDGETKEYCODE   0x4B4C  /* read kernel keycode table entry */
2184b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSETKEYCODE   0x4B4D  /* write kernel keycode table entry */
2185b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2186b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDSIGACCEPT    0x4B4E  /* accept kbd generated signals */
2187b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2188b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughesstruct vki_kbd_repeat {
2189b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	int delay;	/* in msec; <= 0: don't change */
2190b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes	int period;	/* in msec; <= 0: don't change */
2191b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes			/* earlier this field was misnamed "rate" */
2192b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes};
2193b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDKBDREP       0x4B52  /* set keyboard delay/repeat rate;
2194b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes                                    * actually used values are returned */
2195b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2196b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes#define VKI_KDFONTOP       0x4B72  /* font operations */
2197b3d3bcf257e94efdd67133f8529c7018c9fd6cacthughes
2198053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_console_font_op {
2199053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned int op;	/* operation code KD_FONT_OP_* */
2200053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned int flags;	/* KD_FONT_FLAG_* */
2201053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned int width, height;	/* font size */
2202053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned int charcount;
2203053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned char __user *data;	/* font data with height fixed to 32 */
2204053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2205053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2206053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_KD_FONT_OP_SET		0	/* Set font */
2207053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_KD_FONT_OP_GET		1	/* Get font */
2208053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_KD_FONT_OP_SET_DEFAULT	2	/* Set font to default, data points to name / NULL */
2209053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_KD_FONT_OP_COPY		3	/* Copy from another console */
2210053eb0470396ddd47a7cc1ea4882a3c241631e10tom
22115b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercote//----------------------------------------------------------------------
22125b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercote// From linux-2.6.9/include/linux/kb.h
22135b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercote//----------------------------------------------------------------------
22145b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercote
22155b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercotetypedef __vki_kernel_uid32_t vki_qid_t; /* Type in which we store ids in memory */
22165b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercote
2217ca0518df66f8c3375a860f1a55a51f18e2a16c44njn//----------------------------------------------------------------------
2218b807a78ac64d06eb04977044035d665d8a3c4f68tom// From linux-2.6.20.1/include/linux/ptrace.h
2219ca0518df66f8c3375a860f1a55a51f18e2a16c44njn//----------------------------------------------------------------------
2220ca0518df66f8c3375a860f1a55a51f18e2a16c44njn
222145f4e7c91119c7d01a59f5e827c67841632c9314sewardj#define VKI_PTRACE_TRACEME         0
2222ca0518df66f8c3375a860f1a55a51f18e2a16c44njn#define VKI_PTRACE_PEEKTEXT	   1
2223ca0518df66f8c3375a860f1a55a51f18e2a16c44njn#define VKI_PTRACE_PEEKDATA	   2
2224ca0518df66f8c3375a860f1a55a51f18e2a16c44njn#define VKI_PTRACE_PEEKUSR	   3
22250109322c627d5f54ef6df387f4def68f0c1089e5tom#define VKI_PTRACE_POKEUSR	   6
22265b653bc2c60f6913e5bb6c2ebabfcf705a90c012nethercote
2227b807a78ac64d06eb04977044035d665d8a3c4f68tom#define VKI_PTRACE_DETACH         17
2228b807a78ac64d06eb04977044035d665d8a3c4f68tom
2229b807a78ac64d06eb04977044035d665d8a3c4f68tom#define VKI_PTRACE_GETEVENTMSG	0x4201
2230b807a78ac64d06eb04977044035d665d8a3c4f68tom#define VKI_PTRACE_GETSIGINFO	0x4202
2231b807a78ac64d06eb04977044035d665d8a3c4f68tom#define VKI_PTRACE_SETSIGINFO	0x4203
223245f4e7c91119c7d01a59f5e827c67841632c9314sewardj
22332f9328846035a021857b3f398af729bd7b08fb63tom//----------------------------------------------------------------------
22342f9328846035a021857b3f398af729bd7b08fb63tom// From linux-2.6.14/include/sound/asound.h
22352f9328846035a021857b3f398af729bd7b08fb63tom//----------------------------------------------------------------------
22362f9328846035a021857b3f398af729bd7b08fb63tom
22372f9328846035a021857b3f398af729bd7b08fb63tomenum {
22382f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_HW_FREE = _VKI_IO('A', 0x12),
22392f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_HWSYNC = _VKI_IO('A', 0x22),
22402f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_PREPARE = _VKI_IO('A', 0x40),
22412f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_RESET = _VKI_IO('A', 0x41),
22422f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_START = _VKI_IO('A', 0x42),
22432f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_DROP = _VKI_IO('A', 0x43),
22442f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_DRAIN = _VKI_IO('A', 0x44),
2245cf3bd97b427b5de4cf7e02d3ae52e53537eb4a7fnjn	VKI_SNDRV_PCM_IOCTL_PAUSE = _VKI_IOW('A', 0x45, int),
22462f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_RESUME = _VKI_IO('A', 0x47),
22472f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_XRUN = _VKI_IO('A', 0x48),
2248cf3bd97b427b5de4cf7e02d3ae52e53537eb4a7fnjn	VKI_SNDRV_PCM_IOCTL_LINK = _VKI_IOW('A', 0x60, int),
22492f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_PCM_IOCTL_UNLINK = _VKI_IO('A', 0x61),
22502f9328846035a021857b3f398af729bd7b08fb63tom};
22512f9328846035a021857b3f398af729bd7b08fb63tom
22522f9328846035a021857b3f398af729bd7b08fb63tomenum {
22532f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_TIMER_IOCTL_START = _VKI_IO('T', 0xa0),
22542f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_TIMER_IOCTL_STOP = _VKI_IO('T', 0xa1),
22552f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_TIMER_IOCTL_CONTINUE = _VKI_IO('T', 0xa2),
22562f9328846035a021857b3f398af729bd7b08fb63tom	VKI_SNDRV_TIMER_IOCTL_PAUSE = _VKI_IO('T', 0xa3),
22572f9328846035a021857b3f398af729bd7b08fb63tom};
22582f9328846035a021857b3f398af729bd7b08fb63tom
22595d2af674214d1f7b9abda9b178775c69dc4f7c7dtom//----------------------------------------------------------------------
22605d2af674214d1f7b9abda9b178775c69dc4f7c7dtom// From linux-2.6.15.4/include/linux/serial.h
22615d2af674214d1f7b9abda9b178775c69dc4f7c7dtom//----------------------------------------------------------------------
22625d2af674214d1f7b9abda9b178775c69dc4f7c7dtom
22635d2af674214d1f7b9abda9b178775c69dc4f7c7dtomstruct vki_serial_icounter_struct {
22645d2af674214d1f7b9abda9b178775c69dc4f7c7dtom	int cts, dsr, rng, dcd;
22655d2af674214d1f7b9abda9b178775c69dc4f7c7dtom	int rx, tx;
22665d2af674214d1f7b9abda9b178775c69dc4f7c7dtom	int frame, overrun, parity, brk;
22675d2af674214d1f7b9abda9b178775c69dc4f7c7dtom	int buf_overrun;
22685d2af674214d1f7b9abda9b178775c69dc4f7c7dtom	int reserved[9];
22695d2af674214d1f7b9abda9b178775c69dc4f7c7dtom};
22705d2af674214d1f7b9abda9b178775c69dc4f7c7dtom
2271053eb0470396ddd47a7cc1ea4882a3c241631e10tom//----------------------------------------------------------------------
2272053eb0470396ddd47a7cc1ea4882a3c241631e10tom// From linux-2.6.16/include/linux/vt.h
2273053eb0470396ddd47a7cc1ea4882a3c241631e10tom//----------------------------------------------------------------------
2274053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2275053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_OPENQRY	0x5600	/* find available vt */
2276053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2277053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_vt_mode {
2278053eb0470396ddd47a7cc1ea4882a3c241631e10tom	char mode;		/* vt mode */
2279053eb0470396ddd47a7cc1ea4882a3c241631e10tom	char waitv;		/* if set, hang on writes if not active */
2280053eb0470396ddd47a7cc1ea4882a3c241631e10tom	short relsig;		/* signal to raise on release req */
2281053eb0470396ddd47a7cc1ea4882a3c241631e10tom	short acqsig;		/* signal to raise on acquisition */
2282053eb0470396ddd47a7cc1ea4882a3c241631e10tom	short frsig;		/* unused (set to 0) */
2283053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2284053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_GETMODE	0x5601	/* get mode of active vt */
2285053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_SETMODE	0x5602	/* set mode of active vt */
2286053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2287053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_vt_stat {
2288053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_active;	/* active vt */
2289053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_signal;	/* signal to send */
2290053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_state;		/* vt bitmask */
2291053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2292053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_GETSTATE	0x5603	/* get global vt state info */
2293053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_SENDSIG	0x5604	/* signal to send to bitmask of vts */
2294053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2295053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_RELDISP	0x5605	/* release display */
2296053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2297053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_ACTIVATE	0x5606	/* make vt active */
2298053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_WAITACTIVE	0x5607	/* wait for vt active */
2299053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_DISALLOCATE	0x5608  /* free memory associated to vt */
2300053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2301053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_vt_sizes {
2302053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_rows;		/* number of rows */
2303053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_cols;		/* number of columns */
2304053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_scrollsize;	/* number of lines of scrollback */
2305053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2306053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_RESIZE	0x5609	/* set kernel's idea of screensize */
2307053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2308053eb0470396ddd47a7cc1ea4882a3c241631e10tomstruct vki_vt_consize {
2309053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_rows;	/* number of rows */
2310053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_cols;	/* number of columns */
2311053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_vlin;	/* number of pixel rows on screen */
2312053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_clin;	/* number of pixel rows per character */
2313053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_vcol;	/* number of pixel columns on screen */
2314053eb0470396ddd47a7cc1ea4882a3c241631e10tom	unsigned short v_ccol;	/* number of pixel columns per character */
2315053eb0470396ddd47a7cc1ea4882a3c241631e10tom};
2316053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_RESIZEX      0x560A  /* set kernel's idea of screensize + more */
2317053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_LOCKSWITCH   0x560B  /* disallow vt switching */
2318053eb0470396ddd47a7cc1ea4882a3c241631e10tom#define VKI_VT_UNLOCKSWITCH 0x560C  /* allow vt switching */
2319053eb0470396ddd47a7cc1ea4882a3c241631e10tom
2320a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom//----------------------------------------------------------------------
2321a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom// From linux-2.6.19/include/linux/prctl.h
2322a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom//----------------------------------------------------------------------
2323a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2324a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_PDEATHSIG  1  /* Second arg is a signal */
2325a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_PDEATHSIG  2  /* Second arg is a ptr to return the signal */
2326a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2327a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_DUMPABLE   3
2328a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_DUMPABLE   4
2329a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2330a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_UNALIGN	  5
2331a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_UNALIGN	  6
2332a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_UNALIGN_NOPRINT	1	/* silently fix up unaligned user accesses */
2333a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_UNALIGN_SIGBUS	2	/* generate SIGBUS on unaligned user access */
2334a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2335a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_KEEPCAPS   7
2336a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_KEEPCAPS   8
2337a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2338a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_FPEMU  9
2339a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_FPEMU 10
2340a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FPEMU_NOPRINT	1	/* silently emulate fp operations accesses */
2341a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FPEMU_SIGFPE	2	/* don't emulate fp operations, send SIGFPE instead */
2342a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2343a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_FPEXC	11
2344a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_FPEXC	12
2345a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_SW_ENABLE	0x80	/* Use FPEXC for FP exception enables */
2346a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_DIV		0x010000	/* floating point divide by zero */
2347a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_OVF		0x020000	/* floating point overflow */
2348a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_UND		0x040000	/* floating point underflow */
2349a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_RES		0x080000	/* floating point inexact result */
2350a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_INV		0x100000	/* floating point invalid operation */
2351a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_DISABLED	0	/* FP exceptions disabled */
2352a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_NONRECOV	1	/* async non-recoverable exc. mode */
2353a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_ASYNC	2	/* async recoverable exception mode */
2354a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_FP_EXC_PRECISE	3	/* precise exception mode */
2355a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2356a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_TIMING   13
2357a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_TIMING   14
2358a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_TIMING_STATISTICAL  0       /* Normal, traditional,
2359a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom                                                   statistical process timing */
2360a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_TIMING_TIMESTAMP    1       /* Accurate timestamp based
2361a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom                                                   process timing */
2362a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2363a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_NAME    15		/* Set process name */
2364a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_NAME    16		/* Get process name */
2365a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2366a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_GET_ENDIAN	19
2367a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom#define VKI_PR_SET_ENDIAN	20
2368a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_ENDIAN_BIG		0
2369a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_ENDIAN_LITTLE	1	/* True little endian mode */
2370a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom# define VKI_PR_ENDIAN_PPC_LITTLE	2	/* "PowerPC" pseudo little endian */
2371a39ebc8e9f7e1b2cdee6c263a3898677a3296e56tom
2372d7cf487123e934a38c6f3e22a40aebf5f00d55fftom//----------------------------------------------------------------------
2373d7cf487123e934a38c6f3e22a40aebf5f00d55fftom// From linux-2.6.19/include/linux/usbdevice_fs.h
2374d7cf487123e934a38c6f3e22a40aebf5f00d55fftom//----------------------------------------------------------------------
2375d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2376d7cf487123e934a38c6f3e22a40aebf5f00d55fftomstruct vki_usbdevfs_ctrltransfer {
2377d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	__vki_u8 bRequestType;
2378d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	__vki_u8 bRequest;
2379d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	__vki_u16 wValue;
2380d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	__vki_u16 wIndex;
2381d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	__vki_u16 wLength;
2382d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	__vki_u32 timeout;  /* in milliseconds */
2383d7cf487123e934a38c6f3e22a40aebf5f00d55fftom 	void __user *data;
2384d7cf487123e934a38c6f3e22a40aebf5f00d55fftom};
2385d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2386d7cf487123e934a38c6f3e22a40aebf5f00d55fftomstruct vki_usbdevfs_bulktransfer {
2387d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int ep;
2388d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int len;
2389d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int timeout; /* in milliseconds */
2390d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	void __user *data;
2391d7cf487123e934a38c6f3e22a40aebf5f00d55fftom};
2392d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2393d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_MAXDRIVERNAME 255
2394d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2395d7cf487123e934a38c6f3e22a40aebf5f00d55fftomstruct vki_usbdevfs_getdriver {
2396d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int interface;
2397d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	char driver[VKI_USBDEVFS_MAXDRIVERNAME + 1];
2398d7cf487123e934a38c6f3e22a40aebf5f00d55fftom};
2399d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2400d7cf487123e934a38c6f3e22a40aebf5f00d55fftomstruct vki_usbdevfs_connectinfo {
2401d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int devnum;
2402d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned char slow;
2403d7cf487123e934a38c6f3e22a40aebf5f00d55fftom};
2404d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2405d7cf487123e934a38c6f3e22a40aebf5f00d55fftomstruct vki_usbdevfs_iso_packet_desc {
2406d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int length;
2407d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int actual_length;
2408d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int status;
2409d7cf487123e934a38c6f3e22a40aebf5f00d55fftom};
2410d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2411d7cf487123e934a38c6f3e22a40aebf5f00d55fftomstruct vki_usbdevfs_urb {
2412d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned char type;
2413d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned char endpoint;
2414d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int status;
2415d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int flags;
2416d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	void __user *buffer;
2417d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int buffer_length;
2418d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int actual_length;
2419d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int start_frame;
2420d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int number_of_packets;
2421d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int error_count;
2422d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	unsigned int signr;  /* signal to be sent on error, -1 if none should be sent */
2423d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	void *usercontext;
2424d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	struct vki_usbdevfs_iso_packet_desc iso_frame_desc[0];
2425d7cf487123e934a38c6f3e22a40aebf5f00d55fftom};
2426d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2427d7cf487123e934a38c6f3e22a40aebf5f00d55fftomstruct vki_usbdevfs_ioctl {
2428d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int	ifno;		/* interface 0..N ; negative numbers reserved */
2429d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	int	ioctl_code;	/* MUST encode size + direction of data so the
2430d7cf487123e934a38c6f3e22a40aebf5f00d55fftom				 * macros in <asm/ioctl.h> give correct values */
2431d7cf487123e934a38c6f3e22a40aebf5f00d55fftom	void __user *data;	/* param buffer (in, or out) */
2432d7cf487123e934a38c6f3e22a40aebf5f00d55fftom};
2433d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
2434d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_CONTROL           _VKI_IOWR('U', 0, struct vki_usbdevfs_ctrltransfer)
2435d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_BULK              _VKI_IOWR('U', 2, struct vki_usbdevfs_bulktransfer)
2436d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_GETDRIVER         _VKI_IOW('U', 8, struct vki_usbdevfs_getdriver)
2437d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_SUBMITURB         _VKI_IOR('U', 10, struct vki_usbdevfs_urb)
24386e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn#define VKI_USBDEVFS_DISCARDURB        _VKI_IO('U', 11)
2439d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_REAPURB           _VKI_IOW('U', 12, void *)
2440d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_REAPURBNDELAY     _VKI_IOW('U', 13, void *)
2441d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_CONNECTINFO       _VKI_IOW('U', 17, struct vki_usbdevfs_connectinfo)
2442d7cf487123e934a38c6f3e22a40aebf5f00d55fftom#define VKI_USBDEVFS_IOCTL             _VKI_IOWR('U', 18, struct vki_usbdevfs_ioctl)
2443551fe9342240a22f66f91cd10d9a73c6c590becebart#define VKI_USBDEVFS_RESET             _VKI_IO('U', 20)
2444d7cf487123e934a38c6f3e22a40aebf5f00d55fftom
24456e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn#define VKI_USBDEVFS_URB_TYPE_ISO              0
24466e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn#define VKI_USBDEVFS_URB_TYPE_INTERRUPT        1
24476e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn#define VKI_USBDEVFS_URB_TYPE_CONTROL          2
24486e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn#define VKI_USBDEVFS_URB_TYPE_BULK             3
24496e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn
24506e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn// [[this is missing in usbdevice_fs.h]]
24516e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjnstruct vki_usbdevfs_setuppacket {
24526e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn       __vki_u8 bRequestType;
24536e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn       __vki_u8 bRequest;
24546e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn       __vki_u16 wValue;
24556e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn       __vki_u16 wIndex;
24566e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn       __vki_u16 wLength;
24576e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn};
24586e10c6c7c1e2153aa41e9ae8f14f2ef68b969f7bnjn
2459d5df125b895c5d5f31857c52dafa3cdea79ea05dtom//----------------------------------------------------------------------
2460d5df125b895c5d5f31857c52dafa3cdea79ea05dtom// From linux-2.6.20.1/include/linux/i2c.h
2461d5df125b895c5d5f31857c52dafa3cdea79ea05dtom//----------------------------------------------------------------------
2462d5df125b895c5d5f31857c52dafa3cdea79ea05dtom
2463d5df125b895c5d5f31857c52dafa3cdea79ea05dtom#define VKI_I2C_SLAVE		0x0703	/* Change slave address			*/
2464d5df125b895c5d5f31857c52dafa3cdea79ea05dtom					/* Attn.: Slave address is 7 or 10 bits */
2465d5df125b895c5d5f31857c52dafa3cdea79ea05dtom#define VKI_I2C_SLAVE_FORCE	0x0706	/* Change slave address			*/
2466d5df125b895c5d5f31857c52dafa3cdea79ea05dtom					/* Attn.: Slave address is 7 or 10 bits */
2467d5df125b895c5d5f31857c52dafa3cdea79ea05dtom					/* This changes the address, even if it */
2468d5df125b895c5d5f31857c52dafa3cdea79ea05dtom					/* is already taken!			*/
2469d5df125b895c5d5f31857c52dafa3cdea79ea05dtom#define VKI_I2C_TENBIT		0x0704	/* 0 for 7 bit addrs, != 0 for 10 bit	*/
2470d5df125b895c5d5f31857c52dafa3cdea79ea05dtom#define VKI_I2C_FUNCS		0x0705	/* Get the adapter functionality */
2471d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_RDWR		0x0707	/* Combined R/W transfer (one STOP only) */
2472d5df125b895c5d5f31857c52dafa3cdea79ea05dtom#define VKI_I2C_PEC		0x0708	/* != 0 for SMBus PEC                   */
2473d5df125b895c5d5f31857c52dafa3cdea79ea05dtom
2474d543d742b81199f0a633f872a64d122cc2cd2427tomstruct vki_i2c_msg {
2475d543d742b81199f0a633f872a64d122cc2cd2427tom	__vki_u16 addr;		/* slave address			*/
2476d543d742b81199f0a633f872a64d122cc2cd2427tom	__vki_u16 flags;
2477d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_M_TEN		0x0010	/* this is a ten bit chip address */
2478d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_M_RD		0x0001	/* read data, from slave to master */
2479d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_M_NOSTART	0x4000	/* if I2C_FUNC_PROTOCOL_MANGLING */
2480d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_M_REV_DIR_ADDR	0x2000	/* if I2C_FUNC_PROTOCOL_MANGLING */
2481d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_M_IGNORE_NAK	0x1000	/* if I2C_FUNC_PROTOCOL_MANGLING */
2482d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_M_NO_RD_ACK	0x0800	/* if I2C_FUNC_PROTOCOL_MANGLING */
2483d543d742b81199f0a633f872a64d122cc2cd2427tom#define VKI_I2C_M_RECV_LEN	0x0400	/* length will be first received byte */
2484d543d742b81199f0a633f872a64d122cc2cd2427tom	__vki_u16 len;		/* msg length				*/
2485d543d742b81199f0a633f872a64d122cc2cd2427tom	__vki_u8 *buf;		/* pointer to msg data			*/
2486d543d742b81199f0a633f872a64d122cc2cd2427tom};
2487d543d742b81199f0a633f872a64d122cc2cd2427tom
2488d543d742b81199f0a633f872a64d122cc2cd2427tomstruct vki_i2c_rdwr_ioctl_data {
2489d543d742b81199f0a633f872a64d122cc2cd2427tom	struct vki_i2c_msg *msgs;	/* pointers to i2c_msgs */
2490d543d742b81199f0a633f872a64d122cc2cd2427tom	__vki_u32 nmsgs;		/* number of i2c_msgs */
2491d543d742b81199f0a633f872a64d122cc2cd2427tom};
2492d543d742b81199f0a633f872a64d122cc2cd2427tom
24937f4d7e42a880cd0872f93f5178a723beb56941a4tom//----------------------------------------------------------------------
24947f4d7e42a880cd0872f93f5178a723beb56941a4tom// From linux-2.6.20.1/include/linux/keyctl.h
24957f4d7e42a880cd0872f93f5178a723beb56941a4tom//----------------------------------------------------------------------
24967f4d7e42a880cd0872f93f5178a723beb56941a4tom
24977f4d7e42a880cd0872f93f5178a723beb56941a4tom/* keyctl commands */
24987f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_GET_KEYRING_ID	0	/* ask for a keyring's ID */
24997f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_JOIN_SESSION_KEYRING	1	/* join or start named session keyring */
25007f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_UPDATE		2	/* update a key */
25017f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_REVOKE		3	/* revoke a key */
25027f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_CHOWN		4	/* set ownership of a key */
25037f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_SETPERM		5	/* set perms on a key */
25047f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_DESCRIBE		6	/* describe a key */
25057f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_CLEAR		7	/* clear contents of a keyring */
25067f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_LINK			8	/* link a key into a keyring */
25077f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_UNLINK		9	/* unlink a key from a keyring */
25087f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_SEARCH		10	/* search for a key in a keyring */
25097f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_READ			11	/* read a key or keyring's contents */
25107f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_INSTANTIATE		12	/* instantiate a partially constructed key */
25117f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_NEGATE		13	/* negate a partially constructed key */
25127f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_SET_REQKEY_KEYRING	14	/* set default request-key keyring */
25137f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_SET_TIMEOUT		15	/* set key timeout */
25147f4d7e42a880cd0872f93f5178a723beb56941a4tom#define VKI_KEYCTL_ASSUME_AUTHORITY	16	/* assume request_key() authorisation */
25157f4d7e42a880cd0872f93f5178a723beb56941a4tom
25167f4d7e42a880cd0872f93f5178a723beb56941a4tom/*--------------------------------------------------------------------*/
25177f4d7e42a880cd0872f93f5178a723beb56941a4tom// From linux-2.6.20.1/include/linux/key.h
25187f4d7e42a880cd0872f93f5178a723beb56941a4tom/*--------------------------------------------------------------------*/
25197f4d7e42a880cd0872f93f5178a723beb56941a4tom
25207f4d7e42a880cd0872f93f5178a723beb56941a4tom/* key handle serial number */
25217f4d7e42a880cd0872f93f5178a723beb56941a4tomtypedef vki_int32_t vki_key_serial_t;
25227f4d7e42a880cd0872f93f5178a723beb56941a4tom
25237f4d7e42a880cd0872f93f5178a723beb56941a4tom/* key handle permissions mask */
25247f4d7e42a880cd0872f93f5178a723beb56941a4tomtypedef vki_uint32_t vki_key_perm_t;
25257f4d7e42a880cd0872f93f5178a723beb56941a4tom
25269b27b82dac450baac59c4f8d1cd3589bedead53csewardj//----------------------------------------------------------------------
25279b27b82dac450baac59c4f8d1cd3589bedead53csewardj// From linux-2.6.24.7/include/linux/wireless.h
25289b27b82dac450baac59c4f8d1cd3589bedead53csewardj// (wireless extensions version 22, 2007-03-16)
25299b27b82dac450baac59c4f8d1cd3589bedead53csewardj//----------------------------------------------------------------------
25309b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25319b27b82dac450baac59c4f8d1cd3589bedead53csewardj/*
25329b27b82dac450baac59c4f8d1cd3589bedead53csewardj * [[Wireless extensions ioctls.]]
25339b27b82dac450baac59c4f8d1cd3589bedead53csewardj */
25349b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25359b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Wireless Identification */
25369b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWCOMMIT	0x8B00	/* Commit pending changes to driver */
25379b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWNAME		0x8B01	/* get name == wireless protocol */
25389b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25399b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Basic operations */
25409b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWNWID		0x8B02	/* set network id (pre-802.11) */
25419b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWNWID		0x8B03	/* get network id (the cell) */
25429b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWFREQ		0x8B04	/* set channel/frequency (Hz) */
25439b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWFREQ		0x8B05	/* get channel/frequency (Hz) */
25449b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWMODE		0x8B06	/* set operation mode */
25459b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWMODE		0x8B07	/* get operation mode */
25469b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWSENS		0x8B08	/* set sensitivity (dBm) */
25479b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWSENS		0x8B09	/* get sensitivity (dBm) */
25489b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25499b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Informative stuff */
25509b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWRANGE	0x8B0A	/* Unused */
25519b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWRANGE	0x8B0B	/* Get range of parameters */
25529b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWPRIV		0x8B0C	/* Unused */
25539b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWPRIV		0x8B0D	/* get private ioctl interface info */
25549b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWSTATS	0x8B0E	/* Unused */
25559b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWSTATS	0x8B0F	/* Get /proc/net/wireless stats */
25569b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25579b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Spy support (statistics per MAC address - used for Mobile IP support) */
25589b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWSPY		0x8B10	/* set spy addresses */
25599b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWSPY		0x8B11	/* get spy info (quality of link) */
25609b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWTHRSPY	0x8B12	/* set spy threshold (spy event) */
25619b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWTHRSPY	0x8B13	/* get spy threshold */
25629b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25639b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Access Point manipulation */
25649b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWAP		0x8B14	/* set access point MAC addresses */
25659b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWAP		0x8B15	/* get access point MAC addresses */
25669b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWAPLIST	0x8B17	/* Deprecated in favor of scanning */
25679b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWSCAN         0x8B18	/* trigger scanning (list cells) */
25689b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWSCAN         0x8B19	/* get scanning results */
25699b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25709b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* 802.11 specific support */
25719b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWESSID	0x8B1A	/* set ESSID (network name) */
25729b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWESSID	0x8B1B	/* get ESSID */
25739b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWNICKN	0x8B1C	/* set node name/nickname */
25749b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWNICKN	0x8B1D	/* get node name/nickname */
25759b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25769b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Other parameters useful in 802.11 and some other devices */
25779b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWRATE		0x8B20	/* set default bit rate (bps) */
25789b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWRATE		0x8B21	/* get default bit rate (bps) */
25799b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWRTS		0x8B22	/* set RTS/CTS threshold (bytes) */
25809b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWRTS		0x8B23	/* get RTS/CTS threshold (bytes) */
25819b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWFRAG		0x8B24	/* set fragmentation thr (bytes) */
25829b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWFRAG		0x8B25	/* get fragmentation thr (bytes) */
25839b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWTXPOW	0x8B26	/* set transmit power (dBm) */
25849b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWTXPOW	0x8B27	/* get transmit power (dBm) */
25859b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWRETRY	0x8B28	/* set retry limits and lifetime */
25869b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWRETRY	0x8B29	/* get retry limits and lifetime */
25879b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25889b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Encoding stuff (scrambling, hardware security, WEP...) */
25899b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWENCODE	0x8B2A	/* set encoding token & mode */
25909b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWENCODE	0x8B2B	/* get encoding token & mode */
25919b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25929b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* Power saving stuff (power management, unicast and multicast) */
25939b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWPOWER	0x8B2C	/* set Power Management settings */
25949b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWPOWER	0x8B2D	/* get Power Management settings */
25959b27b82dac450baac59c4f8d1cd3589bedead53csewardj
25969b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* WPA : Generic IEEE 802.11 informatiom element (e.g., for WPA/RSN/WMM). */
25979b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWGENIE	0x8B30		/* set generic IE */
25989b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWGENIE	0x8B31		/* get generic IE */
25999b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26009b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* WPA : IEEE 802.11 MLME requests */
26019b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWMLME		0x8B16	/* request MLME operation; uses
26029b27b82dac450baac59c4f8d1cd3589bedead53csewardj					 * struct iw_mlme */
26039b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* WPA : Authentication mode parameters */
26049b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWAUTH		0x8B32	/* set authentication mode params */
26059b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWAUTH		0x8B33	/* get authentication mode params */
26069b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26079b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* WPA : Extended version of encoding configuration */
26089b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWENCODEEXT	0x8B34	/* set encoding token & mode */
26099b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCGIWENCODEEXT	0x8B35	/* get encoding token & mode */
26109b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26119b27b82dac450baac59c4f8d1cd3589bedead53csewardj/* WPA2 : PMKSA cache management */
26129b27b82dac450baac59c4f8d1cd3589bedead53csewardj#define VKI_SIOCSIWPMKSA	0x8B36	/* PMKSA cache operation */
26139b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26149b27b82dac450baac59c4f8d1cd3589bedead53csewardj/*
26159b27b82dac450baac59c4f8d1cd3589bedead53csewardj * [[Payload for the wireless extensions ioctls.]]
26169b27b82dac450baac59c4f8d1cd3589bedead53csewardj */
26179b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26189b27b82dac450baac59c4f8d1cd3589bedead53csewardjstruct	vki_iw_param
26199b27b82dac450baac59c4f8d1cd3589bedead53csewardj{
26209b27b82dac450baac59c4f8d1cd3589bedead53csewardj  __vki_s32	value;		/* The value of the parameter itself */
26219b27b82dac450baac59c4f8d1cd3589bedead53csewardj  __vki_u8	fixed;		/* Hardware should not use auto select */
26229b27b82dac450baac59c4f8d1cd3589bedead53csewardj  __vki_u8	disabled;	/* Disable the feature */
26239b27b82dac450baac59c4f8d1cd3589bedead53csewardj  __vki_u16	flags;		/* Various specifc flags (if any) */
26249b27b82dac450baac59c4f8d1cd3589bedead53csewardj};
26259b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26269b27b82dac450baac59c4f8d1cd3589bedead53csewardjstruct	vki_iw_point
26279b27b82dac450baac59c4f8d1cd3589bedead53csewardj{
26289b27b82dac450baac59c4f8d1cd3589bedead53csewardj  void __user	*pointer;	/* Pointer to the data  (in user space) */
26299b27b82dac450baac59c4f8d1cd3589bedead53csewardj  __vki_u16	length;		/* number of fields or size in bytes */
26309b27b82dac450baac59c4f8d1cd3589bedead53csewardj  __vki_u16	flags;		/* Optional params */
26319b27b82dac450baac59c4f8d1cd3589bedead53csewardj};
26329b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26339b27b82dac450baac59c4f8d1cd3589bedead53csewardjstruct	vki_iw_freq
26349b27b82dac450baac59c4f8d1cd3589bedead53csewardj{
26359b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_s32	m;		/* Mantissa */
26369b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_s16	e;		/* Exponent */
26379b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_u8	i;		/* List index (when in range struct) */
26389b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_u8	flags;		/* Flags (fixed/auto) */
26399b27b82dac450baac59c4f8d1cd3589bedead53csewardj};
26409b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26419b27b82dac450baac59c4f8d1cd3589bedead53csewardjstruct	vki_iw_quality
26429b27b82dac450baac59c4f8d1cd3589bedead53csewardj{
26439b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_u8	qual;		/* link quality (%retries, SNR,
26449b27b82dac450baac59c4f8d1cd3589bedead53csewardj					   %missed beacons or better...) */
26459b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_u8	level;		/* signal level (dBm) */
26469b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_u8	noise;		/* noise level (dBm) */
26479b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_u8	updated;	/* Flags to know if updated */
26489b27b82dac450baac59c4f8d1cd3589bedead53csewardj};
26499b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26509b27b82dac450baac59c4f8d1cd3589bedead53csewardjunion	vki_iwreq_data
26519b27b82dac450baac59c4f8d1cd3589bedead53csewardj{
26529b27b82dac450baac59c4f8d1cd3589bedead53csewardj	/* Config - generic */
26539b27b82dac450baac59c4f8d1cd3589bedead53csewardj	char		name[VKI_IFNAMSIZ];
26549b27b82dac450baac59c4f8d1cd3589bedead53csewardj	/* Name : used to verify the presence of  wireless extensions.
26559b27b82dac450baac59c4f8d1cd3589bedead53csewardj	 * Name of the protocol/provider... */
26569b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26579b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_point	essid;	/* Extended network name */
26589b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	nwid;	/* network id (or domain - the cell) */
26599b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_freq	freq;	/* frequency or channel :
26609b27b82dac450baac59c4f8d1cd3589bedead53csewardj					 * 0-1000 = channel
26619b27b82dac450baac59c4f8d1cd3589bedead53csewardj					 * > 1000 = frequency in Hz */
26629b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26639b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	sens;	/* signal level threshold */
26649b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	bitrate;/* default bit rate */
26659b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	txpower;/* default transmit power */
26669b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	rts;	/* RTS threshold threshold */
26679b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	frag;	/* Fragmentation threshold */
26689b27b82dac450baac59c4f8d1cd3589bedead53csewardj	__vki_u32		mode;	/* Operation mode */
26699b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	retry;	/* Retry limits & lifetime */
26709b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26719b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_point	encoding; /* Encoding stuff : tokens */
26729b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	power;	/* PM duration/timeout */
26739b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_quality	qual;	/* Quality part of statistics */
26749b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26759b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_sockaddr ap_addr;	/* Access point address */
26769b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_sockaddr addr;	/* Destination address (hw/mac) */
26779b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26789b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_param	param;	/* Other small parameters */
26799b27b82dac450baac59c4f8d1cd3589bedead53csewardj	struct vki_iw_point	data;	/* Other large parameters */
26809b27b82dac450baac59c4f8d1cd3589bedead53csewardj};
26819b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26829b27b82dac450baac59c4f8d1cd3589bedead53csewardjstruct	vki_iwreq
26839b27b82dac450baac59c4f8d1cd3589bedead53csewardj{
26849b27b82dac450baac59c4f8d1cd3589bedead53csewardj	union
26859b27b82dac450baac59c4f8d1cd3589bedead53csewardj	{
26869b27b82dac450baac59c4f8d1cd3589bedead53csewardj		char ifrn_name[VKI_IFNAMSIZ];	/* if name, e.g. "eth0" */
26879b27b82dac450baac59c4f8d1cd3589bedead53csewardj	} ifr_ifrn;
26889b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26899b27b82dac450baac59c4f8d1cd3589bedead53csewardj	/* Data part (defined just above) */
26909b27b82dac450baac59c4f8d1cd3589bedead53csewardj	union	vki_iwreq_data	u;
26919b27b82dac450baac59c4f8d1cd3589bedead53csewardj};
26929b27b82dac450baac59c4f8d1cd3589bedead53csewardj
26933fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom/*--------------------------------------------------------------------*/
2694c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom// From linux-2.6.31.5/include/linux/perf_event.h
26953fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom/*--------------------------------------------------------------------*/
26963fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
2697c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tomstruct vki_perf_event_attr {
26983fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
26993fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	/*
27003fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	 * Major type: hardware/software/tracepoint/etc.
27013fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	 */
27023fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	__vki_u32			type;
27033fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
27043fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	/*
27053fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	 * Size of the attr structure, for fwd/bwd compat.
27063fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	 */
27073fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	__vki_u32			size;
27083fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
27093fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	/*
27103fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	 * Type specific configuration information.
27113fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	 */
27123fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	__vki_u64			config;
27133fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
27143fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	union {
27153fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom		__vki_u64		sample_period;
27163fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom		__vki_u64		sample_freq;
27173fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	};
27183fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
27193fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	__vki_u64			sample_type;
27203fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	__vki_u64			read_format;
27213fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
27223fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom	__vki_u64			disabled       :  1, /* off by default        */
27233fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					inherit	       :  1, /* children inherit it   */
27243fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					pinned	       :  1, /* must always be on PMU */
27253fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					exclusive      :  1, /* only group on PMU     */
27263fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					exclude_user   :  1, /* don't count user      */
27273fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					exclude_kernel :  1, /* ditto kernel          */
27283fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					exclude_hv     :  1, /* ditto hypervisor      */
27293fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					exclude_idle   :  1, /* don't count when idle */
27303fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					mmap           :  1, /* include mmap data     */
27313fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					comm	       :  1, /* include comm data     */
27323fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					freq           :  1, /* use freq, not period  */
27333fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					inherit_stat   :  1, /* per task counts       */
27343fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					enable_on_exec :  1, /* next exec enables     */
27353fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom					task           :  1, /* trace fork/exit       */
2736c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					watermark      :  1, /* wakeup_watermark      */
2737c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					/*
2738c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 * precise_ip:
2739c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 *
2740c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 *  0 - SAMPLE_IP can have arbitrary skid
2741c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 *  1 - SAMPLE_IP must have constant skid
2742c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 *  2 - SAMPLE_IP requested to have 0 skid
2743c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 *  3 - SAMPLE_IP must have 0 skid
2744c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 *
2745c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 *  See also PERF_RECORD_MISC_EXACT_IP
2746c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					 */
2747c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					precise_ip     :  2, /* skid constraint       */
2748c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					mmap_data      :  1, /* non-exec mmap data    */
2749c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					sample_id_all  :  1, /* sample_type all events */
2750c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom
2751c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom					__reserved_1   : 45;
27523fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
2753c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom	union {
2754c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom		__vki_u32		wakeup_events;	  /* wakeup every n events */
2755c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom		__vki_u32		wakeup_watermark; /* bytes before wakeup   */
2756c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom	};
27573fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom
2758c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom	__vki_u32			bp_type;
2759c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom	union {
2760c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom		__vki_u64		bp_addr;
2761c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom		__vki_u64		config1; /* extension of config */
2762c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom	};
2763c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom	union {
2764c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom		__vki_u64		bp_len;
2765c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom		__vki_u64		config2; /* extension of config1 */
2766c8232f94b88c0b9ea62399fa5abe5a5a34d35c40tom	};
27673fbcceef22610e2b0b7eec05b5f612c9b22b2cdctom};
27689b27b82dac450baac59c4f8d1cd3589bedead53csewardj
2769472a34b16c3703e8d3adcb12abd194e20a021963tom/*--------------------------------------------------------------------*/
2770472a34b16c3703e8d3adcb12abd194e20a021963tom// From linux-2.6.32.4/include/linux/getcpu.h
2771472a34b16c3703e8d3adcb12abd194e20a021963tom/*--------------------------------------------------------------------*/
2772472a34b16c3703e8d3adcb12abd194e20a021963tom
2773472a34b16c3703e8d3adcb12abd194e20a021963tomstruct vki_getcpu_cache {
2774472a34b16c3703e8d3adcb12abd194e20a021963tom	unsigned long blob[128 / sizeof(long)];
2775472a34b16c3703e8d3adcb12abd194e20a021963tom};
2776472a34b16c3703e8d3adcb12abd194e20a021963tom
27770ee313efc43e3e6ed6bfedbf211769b07dffbc65tom//----------------------------------------------------------------------
27780ee313efc43e3e6ed6bfedbf211769b07dffbc65tom// From linux-2.6.33.3/include/linux/input.h
27790ee313efc43e3e6ed6bfedbf211769b07dffbc65tom//----------------------------------------------------------------------
27800ee313efc43e3e6ed6bfedbf211769b07dffbc65tom
27810ee313efc43e3e6ed6bfedbf211769b07dffbc65tom/*
27820ee313efc43e3e6ed6bfedbf211769b07dffbc65tom * IOCTLs (0x00 - 0x7f)
27830ee313efc43e3e6ed6bfedbf211769b07dffbc65tom */
27840ee313efc43e3e6ed6bfedbf211769b07dffbc65tom
27850ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGNAME(len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x06, len)		/* get device name */
27860ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGPHYS(len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x07, len)		/* get physical location */
27870ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGUNIQ(len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x08, len)		/* get unique identifier */
27880ee313efc43e3e6ed6bfedbf211769b07dffbc65tom
27890ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGKEY(len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x18, len)		/* get global keystate */
27900ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGLED(len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x19, len)		/* get all LEDs */
27910ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGSND(len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x1a, len)		/* get all sounds status */
27920ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGSW(len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x1b, len)		/* get all switch states */
27930ee313efc43e3e6ed6bfedbf211769b07dffbc65tom
27940ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EVIOCGBIT(ev,len)	_VKI_IOC(_VKI_IOC_READ, 'E', 0x20 + ev, len)	/* get event bits */
27950ee313efc43e3e6ed6bfedbf211769b07dffbc65tom
27960ee313efc43e3e6ed6bfedbf211769b07dffbc65tom/*
27970ee313efc43e3e6ed6bfedbf211769b07dffbc65tom * Event types
27980ee313efc43e3e6ed6bfedbf211769b07dffbc65tom */
27990ee313efc43e3e6ed6bfedbf211769b07dffbc65tom
28000ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_SYN		0x00
28010ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_KEY		0x01
28020ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_REL		0x02
28030ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_ABS		0x03
28040ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_MSC		0x04
28050ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_SW		0x05
28060ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_LED		0x11
28070ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_SND		0x12
28080ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_REP		0x14
28090ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_FF		0x15
28100ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_PWR		0x16
28110ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_FF_STATUS	0x17
28120ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_MAX		0x1f
28130ee313efc43e3e6ed6bfedbf211769b07dffbc65tom#define VKI_EV_CNT		(VKI_EV_MAX+1)
28140ee313efc43e3e6ed6bfedbf211769b07dffbc65tom
28156bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom//----------------------------------------------------------------------
28166bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom// From linux-2.6.39-rc2/include/asm_generic/ioctls.h
28176bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom//----------------------------------------------------------------------
28186bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom
28196bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom#ifndef VKI_FIOQSIZE
28206bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom#define VKI_FIOQSIZE 0x5460     /* Value differs on some platforms */
28216bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom#endif
28226bf71ef1f168feb8e014ce2d7c63594eb4a4bc1btom
2823a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj//----------------------------------------------------------------------
2824a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj// From kernel/common/include/linux/ashmem.h
2825a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj//----------------------------------------------------------------------
2826a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2827a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#if defined(VGPV_arm_linux_android)
2828a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2829a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_NAME_LEN 256
2830a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2831a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_NAME_DEF "dev/ashmem"
2832a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2833a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_NOT_PURGED 0
2834a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_WAS_PURGED 1
2835a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2836a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_IS_UNPINNED 0
2837a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_IS_PINNED 1
2838a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2839a3e7a48d5767431328115ee6fa05ce7855830aa9sewardjstruct vki_ashmem_pin {
2840a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj   vki_uint32_t offset;
2841a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj   vki_uint32_t len;
2842a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj};
2843a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2844a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define __VKI_ASHMEMIOC 0x77
2845a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2846a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_SET_NAME _VKI_IOW(__VKI_ASHMEMIOC, 1, char[VKI_ASHMEM_NAME_LEN])
2847a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_GET_NAME _VKI_IOR(__VKI_ASHMEMIOC, 2, char[VKI_ASHMEM_NAME_LEN])
2848a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_SET_SIZE _VKI_IOW(__VKI_ASHMEMIOC, 3, vki_size_t)
2849a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_GET_SIZE _VKI_IO(__VKI_ASHMEMIOC, 4)
2850a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_SET_PROT_MASK _VKI_IOW(__VKI_ASHMEMIOC, 5, unsigned long)
2851a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_GET_PROT_MASK _VKI_IO(__VKI_ASHMEMIOC, 6)
2852a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_PIN _VKI_IOW(__VKI_ASHMEMIOC, 7, struct vki_ashmem_pin)
2853a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_UNPIN _VKI_IOW(__VKI_ASHMEMIOC, 8, struct vki_ashmem_pin)
2854a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_GET_PIN_STATUS _VKI_IO(__VKI_ASHMEMIOC, 9)
2855a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_ASHMEM_PURGE_ALL_CACHES _VKI_IO(__VKI_ASHMEMIOC, 10)
2856a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2857a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj//----------------------------------------------------------------------
2858a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj// From kernel/common/include/linux/binder.h
2859a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj//----------------------------------------------------------------------
2860a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2861a3e7a48d5767431328115ee6fa05ce7855830aa9sewardjstruct vki_binder_write_read {
2862a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj signed long write_size;
2863a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj signed long write_consumed;
2864a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj unsigned long write_buffer;
2865a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj signed long read_size;
2866a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj signed long read_consumed;
2867a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj unsigned long read_buffer;
2868a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj};
2869a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2870a3e7a48d5767431328115ee6fa05ce7855830aa9sewardjstruct vki_binder_version {
2871a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj signed long protocol_version;
2872a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj};
2873a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2874a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_BINDER_WRITE_READ _VKI_IOWR('b', 1, struct vki_binder_write_read)
2875a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_BINDER_SET_IDLE_TIMEOUT _VKI_IOW('b', 3, vki_int64_t)
2876a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_BINDER_SET_MAX_THREADS _VKI_IOW('b', 5, vki_size_t)
2877a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_BINDER_SET_IDLE_PRIORITY _VKI_IOW('b', 6, int)
2878a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_BINDER_SET_CONTEXT_MGR _VKI_IOW('b', 7, int)
2879a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_BINDER_THREAD_EXIT _VKI_IOW('b', 8, int)
2880a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#define VKI_BINDER_VERSION _VKI_IOWR('b', 9, struct vki_binder_version)
2881a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
2882a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj#endif /* defined(VGPV_arm_linux_android) */
2883a3e7a48d5767431328115ee6fa05ce7855830aa9sewardj
28844cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj#endif // __VKI_LINUX_H
28854cfea4f9480393ed6799db463b2e0fb8865a1a2fsewardj
288673b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--------------------------------------------------------------------*/
288773b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--- end                                                          ---*/
288873b526fb4af0f60634f0078583d92b931d5c0eebnethercote/*--------------------------------------------------------------------*/
2889