home *** CD-ROM | disk | FTP | other *** search
/ ARM Club 3 / TheARMClub_PDCD3.iso / hensa / network / netlib_1 / !NetLib / netinet / h / in next >
Text File  |  1995-05-23  |  7KB  |  177 lines

  1. /*
  2.  * Copyright (c) 1982, 1986, 1990, 1993
  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.  * 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    8.3 (Berkeley) 1/3/94
  34.  */
  35.  
  36. #ifndef __netinet_in_h
  37. #define __netinet_in_h
  38.  
  39. /* Freenet programmers interface - netinet/in.h - edited by andy 23/5/95 */
  40.  
  41. #include "sys/types.h"
  42. /*
  43.  * Constants and structures defined by the internet system,
  44.  * Per RFC 790, September 1981, and numerous additions.
  45.  */
  46.  
  47. /*
  48.  * Protocols
  49.  */
  50. #define    IPPROTO_IP          0    /* Dummy for IP */
  51. #define IPPROTO_ICMP        1    /* Internet Control Message Protocol */
  52. #define IPPROTO_IGMP        2     /* Group management protocol */
  53. #define IPPROTO_GGP        3    /* gateway^2 (deprecated) */
  54. #define IPPROTO_TCP         6    /* Transmission Control Protocol */
  55. #define    IPPROTO_EGP        8     /* exterior gateway protocol */
  56. #define    IPPROTO_PUP        12     /* pup */
  57.  
  58. #define IPPROTO_UDP         17   /* User Datagram Protocol */
  59. #define    IPPROTO_IDP        22        /* xns idp */
  60. #define    IPPROTO_TP        29         /* tp-4 w/ class negotiation */
  61. #define    IPPROTO_EON        80        /* ISO cnlp */
  62. #define    IPPROTO_ENCAP        98        /* encapsulation header */
  63.  
  64. #define IPPROTO_RAW         255  /* Raw socket */
  65. #define    IPPROTO_MAX        256
  66.  
  67. /*
  68.  * Ports below this are reserved for 'well-known' services
  69.  */
  70. #define IPPORT_RESERVED     1024
  71.  
  72. /*
  73.  * Ports above this are reserved for other servers
  74.  */
  75. #define IPPORT_USERRESERVED 5000
  76.  
  77. /*
  78.  * Internet address (a structure for historical reasons)
  79.  */
  80. struct in_addr {
  81.   u_long s_addr;
  82. };
  83.  
  84. /*
  85.  * Macros for decomposing class A addresses
  86.  */
  87. #define    IN_CLASSA(i)        (((long)(i) & 0x80000000) == 0)
  88. #define    IN_CLASSA_NET       0xff000000
  89. #define    IN_CLASSA_NSHIFT    24
  90. #define    IN_CLASSA_HOST      0x00ffffff
  91. #define    IN_CLASSA_MAX       128
  92.  
  93. /*
  94.  * Macros for decomposing class B addresses
  95.  */
  96. #define    IN_CLASSB(i)        (((long)(i) & 0xc0000000) == 0x80000000)
  97. #define    IN_CLASSB_NET       0xffff0000
  98. #define    IN_CLASSB_NSHIFT    16
  99. #define    IN_CLASSB_HOST      0x0000ffff
  100. #define    IN_CLASSB_MAX       65536
  101.  
  102. /*
  103.  * Macros for decomposing class C addresses
  104.  */
  105. #define    IN_CLASSC(i)        (((long)(i) & 0xe0000000) == 0xc0000000)
  106. #define    IN_CLASSC_NET       0xffffff00
  107. #define    IN_CLASSC_NSHIFT    8
  108. #define    IN_CLASSC_HOST      0x000000ff
  109.  
  110.  
  111. #define    IN_CLASSD(i)        (((long)(i) & 0xf0000000) == 0xe0000000)
  112. #define    IN_CLASSD_NET        0xf0000000  /* These ones aren't really */
  113. #define    IN_CLASSD_NSHIFT    28        /* net and host fields, but */
  114. #define    IN_CLASSD_HOST        0x0fffffff  /* routing needn't know.    */
  115. #define    IN_MULTICAST(i)        IN_CLASSD(i)
  116.  
  117. #define    IN_EXPERIMENTAL(i)    (((long)(i) & 0xf0000000) == 0xf0000000)
  118. #define    IN_BADCLASS(i)        (((long)(i) & 0xf0000000) == 0xf0000000)
  119.  
  120. /*
  121.  * Some useful addresses
  122.  */
  123. #define INADDR_ANY          (u_long)0x00000000  /* Wildcard address */
  124. #define INADDR_LOOPBACK     (u_long)0x7f000001  /* Loopback address */
  125. #define INADDR_BROADCAST    (u_long)0xffffffff  /* Broadcast address */
  126.  
  127. #define    INADDR_UNSPEC_GROUP    (u_long)0xe0000000    /* 224.0.0.0 */
  128. #define    INADDR_ALLHOSTS_GROUP    (u_long)0xe0000001    /* 224.0.0.1 */
  129. #define    INADDR_MAX_LOCAL_GROUP    (u_long)0xe00000ff    /* 224.0.0.255 */
  130.  
  131. #define    IN_LOOPBACKNET        127            /* official! */
  132.  
  133. /*
  134.  * Definition of an internet style socket address
  135.  */
  136. struct sockaddr_in {
  137.   short          sin_family;     /* Family (AF_INET) */
  138.   u_short        sin_port;       /* Port number */
  139.   struct in_addr sin_addr;       /* Internet address */
  140.   char           sin_zero[8];    /* Padding */
  141. };
  142.  
  143. /*
  144.  * Options for use with [gs]etsockopt at the IP level. First word of
  145.  * comment is data type; bool is stored in int.
  146.  */
  147. #define    IP_OPTIONS        1    /* buf/ip_opts; set/get IP options */
  148. #define    IP_HDRINCL        2    /* int; header is included with data */
  149. #define    IP_TOS            3    /* int; IP type of service and preced. */
  150. #define    IP_TTL            4    /* int; IP time to live */
  151. #define    IP_RECVOPTS        5    /* bool; receive all IP opts w/dgram */
  152. #define    IP_RECVRETOPTS        6    /* bool; receive IP opts for response */
  153. #define    IP_RECVDSTADDR        7    /* bool; receive IP dst addr w/dgram */
  154. #define    IP_RETOPTS        8    /* ip_opts; set/get IP options */
  155. #define    IP_MULTICAST_IF        9    /* u_char; set/get IP multicast i/f  */
  156. #define    IP_MULTICAST_TTL    10   /* u_char; set/get IP multicast ttl */
  157. #define    IP_MULTICAST_LOOP    11   /* u_char; set/get IP multicast loopback */
  158. #define    IP_ADD_MEMBERSHIP    12   /* ip_mreq; add an IP group membership */
  159. #define    IP_DROP_MEMBERSHIP    13   /* ip_mreq; drop an IP group membership */
  160.  
  161. /*
  162.  * Defaults and limits for options
  163.  */
  164. #define    IP_DEFAULT_MULTICAST_TTL  1    /* normally limit m'casts to 1 hop  */
  165. #define    IP_DEFAULT_MULTICAST_LOOP 1    /* normally hear sends if a member  */
  166. #define    IP_MAX_MEMBERSHIPS    20    /* per socket; must fit in one mbuf */
  167.  
  168. /*
  169.  * Argument structure for IP_ADD_MEMBERSHIP and IP_DROP_MEMBERSHIP.
  170.  */
  171. struct ip_mreq {
  172.     struct    in_addr imr_multiaddr;    /* IP multicast address of group */
  173.     struct    in_addr imr_interface;    /* local IP address of interface */
  174. };
  175.  
  176. #endif
  177.