source: rtems/cpukit/libcsupport/include/sys/ioccom.h @ a009d94

4.104.114.84.95
Last change on this file since a009d94 was a009d94, checked in by Joel Sherrill <joel.sherrill@…>, on 08/31/06 at 01:10:02

2006-08-30 Joel Sherrill <joel@…>

  • ftpd/ftpd.c, libcsupport/include/sys/ioccom.h, libcsupport/src/ioctl.c, libnetworking/kern/uipc_mbuf.c, libnetworking/libc/inet_addr.c, libnetworking/net/ethernet.h, libnetworking/net/if.c, libnetworking/net/if_ethersubr.c, libnetworking/net/if_ppp.c, libnetworking/net/if_pppvar.h, libnetworking/net/if_var.h, libnetworking/net/ppp_tty.c, libnetworking/netinet/in_cksum.c, libnetworking/nfs/bootp_subr.c, libnetworking/rtems/rtems_bsdnet_internal.h, libnetworking/sys/mbuf.h, pppd/md4.c, pppd/pppd.h: Remove warnings due to improper use of int which shows up on 16 bit targets. Added ioctl_command_t since IOCTL command argument does not reliably fit into 16 bits.
  • Property mode set to 100644
File size: 4.1 KB
Line 
1/*-
2 * Copyright (c) 1982, 1986, 1990, 1993, 1994
3 *      The Regents of the University of California.  All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright
9 *    notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 *    notice, this list of conditions and the following disclaimer in the
12 *    documentation and/or other materials provided with the distribution.
13 * 4. Neither the name of the University nor the names of its contributors
14 *    may be used to endorse or promote products derived from this software
15 *    without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
18 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20 * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
21 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27 * SUCH DAMAGE.
28 *
29 *      @(#)ioccom.h    8.2 (Berkeley) 3/28/94
30 * $FreeBSD: src/sys/sys/ioccom.h,v 1.15 2004/04/07 04:19:49 imp Exp $
31 */
32/*
33 * $Id$
34 */
35
36#ifndef _SYS_IOCCOM_H_
37#define _SYS_IOCCOM_H_
38
39#include <sys/types.h>
40
41/*
42 * Ioctl's have the command encoded in the lower word, and the size of
43 * any in or out parameters in the upper word.  The high 3 bits of the
44 * upper word are used to encode the in/out status of the parameter.
45 */
46#define IOCPARM_MASK    0x1fff          /* parameter length, at most 13 bits */
47#define IOCPARM_LEN(x)  (((x) >> 16) & IOCPARM_MASK)
48#define IOCBASECMD(x)   ((x) & ~(IOCPARM_MASK << 16))
49#define IOCGROUP(x)     (((x) >> 8) & 0xff)
50
51#define IOCPARM_MAX     PAGE_SIZE               /* max size of ioctl, mult. of PAGE_SIZE */
52#define IOC_VOID        0x20000000      /* no parameters */
53#define IOC_OUT         0x40000000      /* copy out parameters */
54#define IOC_IN          0x80000000      /* copy in parameters */
55#define IOC_INOUT       (IOC_IN|IOC_OUT)
56#define IOC_DIRMASK     0xe0000000      /* mask for IN/OUT/VOID */
57
58#define _IOC(inout,group,num,len) \
59        (u_int32_t) ((u_int32_t)inout | \
60         (u_int32_t) ((u_int32_t)((u_int32_t)len & IOCPARM_MASK) << 16) | \
61         (u_int32_t)((group) << 8) | \
62         (u_int32_t)(num))
63#define _IO(g,n)        _IOC(IOC_VOID,  (g), (n), 0)
64#define _IOR(g,n,t)     _IOC(IOC_OUT,   (g), (n), sizeof(t))
65#define _IOW(g,n,t)     _IOC(IOC_IN,    (g), (n), sizeof(t))
66/* this should be _IORW, but stdio got there first */
67#define _IOWR(g,n,t)    _IOC(IOC_INOUT, (g), (n), sizeof(t))
68
69/*
70 *  IOCTL values
71 */
72
73#define       RTEMS_IO_GET_ATTRIBUTES 1
74#define       RTEMS_IO_SET_ATTRIBUTES 2
75#define       RTEMS_IO_TCDRAIN        3
76#define       RTEMS_IO_RCVWAKEUP      4
77#define       RTEMS_IO_SNDWAKEUP      5
78
79/* copied from libnetworking/sys/filio.h and commented out there */
80/* Generic file-descriptor ioctl's. */
81#define FIOCLEX          _IO('f', 1)            /* set close on exec on fd */
82#define FIONCLEX         _IO('f', 2)            /* remove close on exec */
83#define FIONREAD        _IOR('f', 127, int)     /* get # bytes to read */
84#define FIONBIO         _IOW('f', 126, int)     /* set/clear non-blocking i/o */
85#define FIOASYNC        _IOW('f', 125, int)     /* set/clear async i/o */
86#define FIOSETOWN       _IOW('f', 124, int)     /* set owner */
87#define FIOGETOWN       _IOR('f', 123, int)     /* get owner */
88
89#ifndef KERNEL
90
91#include <sys/cdefs.h>
92
93#ifndef __ioctl_command_defined
94typedef u_int32_t ioctl_command_t;
95#define __ioctl_command_defined
96#endif
97
98__BEGIN_DECLS
99int     ioctl(int, ioctl_command_t, ...);
100__END_DECLS
101
102#endif /* !KERNEL */
103
104#endif /* !_SYS_IOCCOM_H_ */
Note: See TracBrowser for help on using the repository browser.