Home | History | Annotate | Line # | Download | only in netinet
in.h revision 1.4
      1  1.1      cgd /*
      2  1.1      cgd  * Copyright (c) 1982, 1986, 1990 Regents of the University of California.
      3  1.1      cgd  * All rights reserved.
      4  1.1      cgd  *
      5  1.1      cgd  * Redistribution and use in source and binary forms, with or without
      6  1.1      cgd  * modification, are permitted provided that the following conditions
      7  1.1      cgd  * are met:
      8  1.1      cgd  * 1. Redistributions of source code must retain the above copyright
      9  1.1      cgd  *    notice, this list of conditions and the following disclaimer.
     10  1.1      cgd  * 2. Redistributions in binary form must reproduce the above copyright
     11  1.1      cgd  *    notice, this list of conditions and the following disclaimer in the
     12  1.1      cgd  *    documentation and/or other materials provided with the distribution.
     13  1.1      cgd  * 3. All advertising materials mentioning features or use of this software
     14  1.1      cgd  *    must display the following acknowledgement:
     15  1.1      cgd  *	This product includes software developed by the University of
     16  1.1      cgd  *	California, Berkeley and its contributors.
     17  1.1      cgd  * 4. Neither the name of the University nor the names of its contributors
     18  1.1      cgd  *    may be used to endorse or promote products derived from this software
     19  1.1      cgd  *    without specific prior written permission.
     20  1.1      cgd  *
     21  1.1      cgd  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     22  1.1      cgd  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     23  1.1      cgd  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     24  1.1      cgd  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     25  1.1      cgd  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     26  1.1      cgd  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     27  1.1      cgd  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     28  1.1      cgd  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     29  1.1      cgd  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     30  1.1      cgd  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     31  1.1      cgd  * SUCH DAMAGE.
     32  1.1      cgd  *
     33  1.3      cgd  *	from: @(#)in.h	7.11 (Berkeley) 4/20/91
     34  1.4  hpeyerl  *	$Id: in.h,v 1.4 1993/12/06 05:46:37 hpeyerl Exp $
     35  1.1      cgd  */
     36  1.1      cgd 
     37  1.2  mycroft #ifndef _NETINET_IN_H_
     38  1.2  mycroft #define _NETINET_IN_H_
     39  1.2  mycroft 
     40  1.1      cgd /*
     41  1.1      cgd  * Constants and structures defined by the internet system,
     42  1.1      cgd  * Per RFC 790, September 1981.
     43  1.1      cgd  */
     44  1.1      cgd 
     45  1.1      cgd /*
     46  1.1      cgd  * Protocols
     47  1.1      cgd  */
     48  1.1      cgd #define	IPPROTO_IP		0		/* dummy for IP */
     49  1.1      cgd #define	IPPROTO_ICMP		1		/* control message protocol */
     50  1.4  hpeyerl #define IPPROTO_IGMP		2		/* group control protocol */
     51  1.1      cgd #define	IPPROTO_GGP		3		/* gateway^2 (deprecated) */
     52  1.1      cgd #define	IPPROTO_TCP		6		/* tcp */
     53  1.1      cgd #define	IPPROTO_EGP		8		/* exterior gateway protocol */
     54  1.1      cgd #define	IPPROTO_PUP		12		/* pup */
     55  1.1      cgd #define	IPPROTO_UDP		17		/* user datagram protocol */
     56  1.1      cgd #define	IPPROTO_IDP		22		/* xns idp */
     57  1.1      cgd #define	IPPROTO_TP		29 		/* tp-4 w/ class negotiation */
     58  1.1      cgd #define	IPPROTO_EON		80		/* ISO cnlp */
     59  1.1      cgd 
     60  1.1      cgd #define	IPPROTO_RAW		255		/* raw IP packet */
     61  1.1      cgd #define	IPPROTO_MAX		256
     62  1.1      cgd 
     63  1.1      cgd 
     64  1.1      cgd /*
     65  1.1      cgd  * Local port number conventions:
     66  1.1      cgd  * Ports < IPPORT_RESERVED are reserved for
     67  1.1      cgd  * privileged processes (e.g. root).
     68  1.1      cgd  * Ports > IPPORT_USERRESERVED are reserved
     69  1.1      cgd  * for servers, not necessarily privileged.
     70  1.1      cgd  */
     71  1.1      cgd #define	IPPORT_RESERVED		1024
     72  1.1      cgd #define	IPPORT_USERRESERVED	5000
     73  1.1      cgd 
     74  1.1      cgd /*
     75  1.1      cgd  * Internet address (a structure for historical reasons)
     76  1.1      cgd  */
     77  1.1      cgd struct in_addr {
     78  1.1      cgd 	u_long s_addr;
     79  1.1      cgd };
     80  1.1      cgd 
     81  1.1      cgd /*
     82  1.1      cgd  * Definitions of bits in internet address integers.
     83  1.1      cgd  * On subnets, the decomposition of addresses to host and net parts
     84  1.1      cgd  * is done according to subnet mask, not the masks here.
     85  1.1      cgd  */
     86  1.1      cgd #define	IN_CLASSA(i)		(((long)(i) & 0x80000000) == 0)
     87  1.1      cgd #define	IN_CLASSA_NET		0xff000000
     88  1.1      cgd #define	IN_CLASSA_NSHIFT	24
     89  1.1      cgd #define	IN_CLASSA_HOST		0x00ffffff
     90  1.1      cgd #define	IN_CLASSA_MAX		128
     91  1.1      cgd 
     92  1.1      cgd #define	IN_CLASSB(i)		(((long)(i) & 0xc0000000) == 0x80000000)
     93  1.1      cgd #define	IN_CLASSB_NET		0xffff0000
     94  1.1      cgd #define	IN_CLASSB_NSHIFT	16
     95  1.1      cgd #define	IN_CLASSB_HOST		0x0000ffff
     96  1.1      cgd #define	IN_CLASSB_MAX		65536
     97  1.1      cgd 
     98  1.1      cgd #define	IN_CLASSC(i)		(((long)(i) & 0xe0000000) == 0xc0000000)
     99  1.1      cgd #define	IN_CLASSC_NET		0xffffff00
    100  1.1      cgd #define	IN_CLASSC_NSHIFT	8
    101  1.1      cgd #define	IN_CLASSC_HOST		0x000000ff
    102  1.1      cgd 
    103  1.1      cgd #define	IN_CLASSD(i)		(((long)(i) & 0xf0000000) == 0xe0000000)
    104  1.4  hpeyerl #define IN_CLASSD_NET		0xf0000000	/* These ones aren't really */
    105  1.4  hpeyerl #define IN_CLASSD_NSHIFT	28		/* net and host fields, but */
    106  1.4  hpeyerl #define IN_CLASSD_HOST		0x0fffffff	/* routing needn't know. */
    107  1.1      cgd #define	IN_MULTICAST(i)		IN_CLASSD(i)
    108  1.1      cgd 
    109  1.1      cgd #define	IN_EXPERIMENTAL(i)	(((long)(i) & 0xe0000000) == 0xe0000000)
    110  1.1      cgd #define	IN_BADCLASS(i)		(((long)(i) & 0xf0000000) == 0xf0000000)
    111  1.1      cgd 
    112  1.1      cgd #define	INADDR_ANY		(u_long)0x00000000
    113  1.4  hpeyerl #define INADDR_LOOPBACK		(u_long)0x7f000001
    114  1.1      cgd #define	INADDR_BROADCAST	(u_long)0xffffffff	/* must be masked */
    115  1.1      cgd #ifndef KERNEL
    116  1.1      cgd #define	INADDR_NONE		0xffffffff		/* -1 return */
    117  1.1      cgd #endif
    118  1.1      cgd 
    119  1.4  hpeyerl #define INADDR_UNSPEC_GROUP	(u_long)0xe0000000	/* 224.0.0.0  */
    120  1.4  hpeyerl #define INADDR_ALLHOSTS_GROUP	(u_long)0xe0000001	/* 224.0.0.1  */
    121  1.4  hpeyerl #define INADDR_MAX_LOCAL_GROUP	(u_long)0xe00000ff	/* 224.0.0.255 */
    122  1.4  hpeyerl 
    123  1.1      cgd #define	IN_LOOPBACKNET		127			/* official! */
    124  1.1      cgd 
    125  1.1      cgd /*
    126  1.4  hpeyerl  * Define a macro to stuff the loopback address into an Internet address
    127  1.4  hpeyerl  */
    128  1.4  hpeyerl #define IN_SET_LOOPBACK_ADDR(a) { \
    129  1.4  hpeyerl 	(a)->sin_addr.s_addr = htonl(INADDR_LOOPBACK); \
    130  1.4  hpeyerl 	(a)->sin_family = AF_INET; }
    131  1.4  hpeyerl /*
    132  1.1      cgd  * Socket address, internet style.
    133  1.1      cgd  */
    134  1.1      cgd struct sockaddr_in {
    135  1.1      cgd 	u_char	sin_len;
    136  1.1      cgd 	u_char	sin_family;
    137  1.1      cgd 	u_short	sin_port;
    138  1.1      cgd 	struct	in_addr sin_addr;
    139  1.1      cgd 	char	sin_zero[8];
    140  1.1      cgd };
    141  1.1      cgd 
    142  1.1      cgd /*
    143  1.1      cgd  * Structure used to describe IP options.
    144  1.1      cgd  * Used to store options internally, to pass them to a process,
    145  1.1      cgd  * or to restore options retrieved earlier.
    146  1.1      cgd  * The ip_dst is used for the first-hop gateway when using a source route
    147  1.1      cgd  * (this gets put into the header proper).
    148  1.1      cgd  */
    149  1.1      cgd struct ip_opts {
    150  1.1      cgd 	struct	in_addr ip_dst;		/* first hop, 0 w/o src rt */
    151  1.1      cgd 	char	ip_opts[40];		/* actually variable in size */
    152  1.1      cgd };
    153  1.1      cgd 
    154  1.1      cgd /*
    155  1.1      cgd  * Options for use with [gs]etsockopt at the IP level.
    156  1.1      cgd  * First word of comment is data type; bool is stored in int.
    157  1.1      cgd  */
    158  1.4  hpeyerl #define	IP_OPTIONS		1	/* buf/ip_opts; set/get IP per-packet options */
    159  1.4  hpeyerl #define IP_MULTICAST_IF		2	/* set/get IP multicast interface  */
    160  1.4  hpeyerl #define IP_MULTICAST_TTL	3	/* set/get IP multicast timetolive */
    161  1.4  hpeyerl #define IP_MULTICAST_LOOP	4	/* set/get IP multicast loopback   */
    162  1.4  hpeyerl #define IP_ADD_MEMBERSHIP	5	/* add  an IP group membership     */
    163  1.4  hpeyerl #define IP_DROP_MEMBERSHIP	6	/* drop an IP group membership     */
    164  1.4  hpeyerl 
    165  1.4  hpeyerl #define	IP_HDRINCL		7	/* int; header is included with data (raw) */
    166  1.4  hpeyerl #define	IP_TOS			8	/* int; IP type of service and precedence */
    167  1.4  hpeyerl #define	IP_TTL			9	/* int; IP time to live */
    168  1.4  hpeyerl #define	IP_RECVOPTS		10	/* bool; receive all IP options w/datagram */
    169  1.4  hpeyerl #define	IP_RECVRETOPTS		11	/* bool; receive IP options for response */
    170  1.4  hpeyerl #define	IP_RECVDSTADDR		12	/* bool; receive IP dst addr w/datagram */
    171  1.4  hpeyerl #define	IP_RETOPTS		13	/* ip_opts; set/get IP per-packet options */
    172  1.4  hpeyerl 
    173  1.4  hpeyerl #define IP_DEFAULT_MULTICAST_TTL   1    /* normally limit m'casts to 1 hop  */
    174  1.4  hpeyerl #define IP_DEFAULT_MULTICAST_LOOP  1    /* normally hear sends if a member  */
    175  1.4  hpeyerl #define IP_MAX_MEMBERSHIPS         20   /* per socket; must fit in one mbuf */
    176  1.4  hpeyerl 
    177  1.4  hpeyerl /*
    178  1.4  hpeyerl  * Argument structure for IP_ADD_MEMBERSHIP and IP_DROP_MEMBERSHIP.
    179  1.4  hpeyerl  */
    180  1.4  hpeyerl struct ip_mreq {
    181  1.4  hpeyerl         struct in_addr  imr_multiaddr;  /* IP multicast address of group */
    182  1.4  hpeyerl         struct in_addr  imr_interface;  /* local IP address of interface */
    183  1.4  hpeyerl };
    184  1.1      cgd 
    185  1.1      cgd #ifdef KERNEL
    186  1.1      cgd struct	in_addr in_makeaddr();
    187  1.1      cgd u_long	in_netof(), in_lnaof();
    188  1.1      cgd #endif
    189  1.2  mycroft 
    190  1.2  mycroft #endif /* !_NETINET_IN_H_ */
    191