home *** CD-ROM | disk | FTP | other *** search
/ InfoMagic Source Code 1993 July / THE_SOURCE_CODE_CD_ROM.iso / bsd_srcs / sys / netinet / in.h < prev    next >
Encoding:
C/C++ Source or Header  |  1991-05-08  |  5.2 KB  |  152 lines

  1. /*
  2.  * Copyright (c) 1982, 1986, 1990 Regents of the University of California.
  3.  * 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.  * 3. All advertising materials mentioning features or use of this software
  14.  *    must display the following acknowledgement:
  15.  *    This product includes software developed by the University of
  16.  *    California, Berkeley and its contributors.
  17.  * 4. Neither the name of the University nor the names of its contributors
  18.  *    may be used to endorse or promote products derived from this software
  19.  *    without specific prior written permission.
  20.  *
  21.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  22.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  23.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  24.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  25.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  26.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  27.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  28.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  29.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  30.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  31.  * SUCH DAMAGE.
  32.  *
  33.  *    @(#)in.h    7.11 (Berkeley) 4/20/91
  34.  */
  35.  
  36. /*
  37.  * Constants and structures defined by the internet system,
  38.  * Per RFC 790, September 1981.
  39.  */
  40.  
  41. /*
  42.  * Protocols
  43.  */
  44. #define    IPPROTO_IP        0        /* dummy for IP */
  45. #define    IPPROTO_ICMP        1        /* control message protocol */
  46. #define    IPPROTO_GGP        3        /* gateway^2 (deprecated) */
  47. #define    IPPROTO_TCP        6        /* tcp */
  48. #define    IPPROTO_EGP        8        /* exterior gateway protocol */
  49. #define    IPPROTO_PUP        12        /* pup */
  50. #define    IPPROTO_UDP        17        /* user datagram protocol */
  51. #define    IPPROTO_IDP        22        /* xns idp */
  52. #define    IPPROTO_TP        29         /* tp-4 w/ class negotiation */
  53. #define    IPPROTO_EON        80        /* ISO cnlp */
  54.  
  55. #define    IPPROTO_RAW        255        /* raw IP packet */
  56. #define    IPPROTO_MAX        256
  57.  
  58.  
  59. /*
  60.  * Local port number conventions:
  61.  * Ports < IPPORT_RESERVED are reserved for
  62.  * privileged processes (e.g. root).
  63.  * Ports > IPPORT_USERRESERVED are reserved
  64.  * for servers, not necessarily privileged.
  65.  */
  66. #define    IPPORT_RESERVED        1024
  67. #define    IPPORT_USERRESERVED    5000
  68.  
  69. /*
  70.  * Internet address (a structure for historical reasons)
  71.  */
  72. struct in_addr {
  73.     u_long s_addr;
  74. };
  75.  
  76. /*
  77.  * Definitions of bits in internet address integers.
  78.  * On subnets, the decomposition of addresses to host and net parts
  79.  * is done according to subnet mask, not the masks here.
  80.  */
  81. #define    IN_CLASSA(i)        (((long)(i) & 0x80000000) == 0)
  82. #define    IN_CLASSA_NET        0xff000000
  83. #define    IN_CLASSA_NSHIFT    24
  84. #define    IN_CLASSA_HOST        0x00ffffff
  85. #define    IN_CLASSA_MAX        128
  86.  
  87. #define    IN_CLASSB(i)        (((long)(i) & 0xc0000000) == 0x80000000)
  88. #define    IN_CLASSB_NET        0xffff0000
  89. #define    IN_CLASSB_NSHIFT    16
  90. #define    IN_CLASSB_HOST        0x0000ffff
  91. #define    IN_CLASSB_MAX        65536
  92.  
  93. #define    IN_CLASSC(i)        (((long)(i) & 0xe0000000) == 0xc0000000)
  94. #define    IN_CLASSC_NET        0xffffff00
  95. #define    IN_CLASSC_NSHIFT    8
  96. #define    IN_CLASSC_HOST        0x000000ff
  97.  
  98. #define    IN_CLASSD(i)        (((long)(i) & 0xf0000000) == 0xe0000000)
  99. #define    IN_MULTICAST(i)        IN_CLASSD(i)
  100.  
  101. #define    IN_EXPERIMENTAL(i)    (((long)(i) & 0xe0000000) == 0xe0000000)
  102. #define    IN_BADCLASS(i)        (((long)(i) & 0xf0000000) == 0xf0000000)
  103.  
  104. #define    INADDR_ANY        (u_long)0x00000000
  105. #define    INADDR_BROADCAST    (u_long)0xffffffff    /* must be masked */
  106. #ifndef KERNEL
  107. #define    INADDR_NONE        0xffffffff        /* -1 return */
  108. #endif
  109.  
  110. #define    IN_LOOPBACKNET        127            /* official! */
  111.  
  112. /*
  113.  * Socket address, internet style.
  114.  */
  115. struct sockaddr_in {
  116.     u_char    sin_len;
  117.     u_char    sin_family;
  118.     u_short    sin_port;
  119.     struct    in_addr sin_addr;
  120.     char    sin_zero[8];
  121. };
  122.  
  123. /*
  124.  * Structure used to describe IP options.
  125.  * Used to store options internally, to pass them to a process,
  126.  * or to restore options retrieved earlier.
  127.  * The ip_dst is used for the first-hop gateway when using a source route
  128.  * (this gets put into the header proper).
  129.  */
  130. struct ip_opts {
  131.     struct    in_addr ip_dst;        /* first hop, 0 w/o src rt */
  132.     char    ip_opts[40];        /* actually variable in size */
  133. };
  134.  
  135. /*
  136.  * Options for use with [gs]etsockopt at the IP level.
  137.  * First word of comment is data type; bool is stored in int.
  138.  */
  139. #define    IP_OPTIONS    1    /* buf/ip_opts; set/get IP per-packet options */
  140. #define    IP_HDRINCL    2    /* int; header is included with data (raw) */
  141. #define    IP_TOS        3    /* int; IP type of service and precedence */
  142. #define    IP_TTL        4    /* int; IP time to live */
  143. #define    IP_RECVOPTS    5    /* bool; receive all IP options w/datagram */
  144. #define    IP_RECVRETOPTS    6    /* bool; receive IP options for response */
  145. #define    IP_RECVDSTADDR    7    /* bool; receive IP dst addr w/datagram */
  146. #define    IP_RETOPTS    8    /* ip_opts; set/get IP per-packet options */
  147.  
  148. #ifdef KERNEL
  149. struct    in_addr in_makeaddr();
  150. u_long    in_netof(), in_lnaof();
  151. #endif
  152.