ip_mroute.h
上传用户:tjbfgc
上传日期:2013-03-31
资源大小:140k
文件大小:6k
源码类别:

网络编程

开发平台:

C/C++

  1. /*
  2.  * Copyright (c) 1989 Stephen Deering.
  3.  * Copyright (c) 1992, 1993
  4.  * The Regents of the University of California.  All rights reserved.
  5.  *
  6.  * This code is derived from software contributed to Berkeley by
  7.  * Stephen Deering of Stanford University.
  8.  *
  9.  * Redistribution and use in source and binary forms, with or without
  10.  * modification, are permitted provided that the following conditions
  11.  * are met:
  12.  * 1. Redistributions of source code must retain the above copyright
  13.  *    notice, this list of conditions and the following disclaimer.
  14.  * 2. Redistributions in binary form must reproduce the above copyright
  15.  *    notice, this list of conditions and the following disclaimer in the
  16.  *    documentation and/or other materials provided with the distribution.
  17.  * 3. All advertising materials mentioning features or use of this software
  18.  *    must display the following acknowledgement:
  19.  * This product includes software developed by the University of
  20.  * California, Berkeley and its contributors.
  21.  * 4. Neither the name of the University nor the names of its contributors
  22.  *    may be used to endorse or promote products derived from this software
  23.  *    without specific prior written permission.
  24.  *
  25.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  26.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  27.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  28.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  29.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  30.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  31.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  32.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  33.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  34.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  35.  * SUCH DAMAGE.
  36.  *
  37.  * @(#)ip_mroute.h 8.1 (Berkeley) 6/10/93
  38.  */
  39. /*
  40.  * Definitions for the kernel part of DVMRP,
  41.  * a Distance-Vector Multicast Routing Protocol.
  42.  * (See RFC-1075.)
  43.  *
  44.  * Written by David Waitzman, BBN Labs, August 1988.
  45.  * Modified by Steve Deering, Stanford, February 1989.
  46.  *
  47.  * MROUTING 1.0
  48.  */
  49. /*
  50.  * DVMRP-specific setsockopt commands.
  51.  */
  52. #define DVMRP_INIT 100
  53. #define DVMRP_DONE 101
  54. #define DVMRP_ADD_VIF 102
  55. #define DVMRP_DEL_VIF 103
  56. #define DVMRP_ADD_LGRP 104
  57. #define DVMRP_DEL_LGRP 105
  58. #define DVMRP_ADD_MRT 106
  59. #define DVMRP_DEL_MRT 107
  60. /*
  61.  * Types and macros for handling bitmaps with one bit per virtual interface.
  62.  */
  63. #define MAXVIFS 32
  64. typedef u_long vifbitmap_t;
  65. typedef u_short vifi_t; /* type of a vif index */
  66. #define VIFM_SET(n, m) ((m) |= (1 << (n)))
  67. #define VIFM_CLR(n, m) ((m) &= ~(1 << (n)))
  68. #define VIFM_ISSET(n, m) ((m) & (1 << (n)))
  69. #define VIFM_CLRALL(m) ((m) = 0x00000000)
  70. #define VIFM_COPY(mfrom, mto) ((mto) = (mfrom))
  71. #define VIFM_SAME(m1, m2) ((m1) == (m2))
  72. /*
  73.  * Agument structure for DVMRP_ADD_VIF.
  74.  * (DVMRP_DEL_VIF takes a single vifi_t argument.)
  75.  */
  76. struct vifctl {
  77. vifi_t     vifc_vifi;      /* the index of the vif to be added */
  78. u_char     vifc_flags;      /* VIFF_ flags defined below */
  79. u_char     vifc_threshold;  /* min ttl required to forward on vif */
  80. struct in_addr vifc_lcl_addr; /* local interface address */
  81. struct in_addr vifc_rmt_addr; /* remote address (tunnels only) */
  82. };
  83. #define VIFF_TUNNEL 0x1 /* vif represents a tunnel end-point */
  84. /*
  85.  * Argument structure for DVMRP_ADD_LGRP and DVMRP_DEL_LGRP.
  86.  */
  87. struct lgrplctl {
  88. vifi_t lgc_vifi;
  89. struct in_addr lgc_gaddr;
  90. };
  91. /*
  92.  * Argument structure for DVMRP_ADD_MRT.
  93.  * (DVMRP_DEL_MRT takes a single struct in_addr argument, containing origin.)
  94.  */
  95. struct mrtctl {
  96. struct in_addr mrtc_origin; /* subnet origin of multicasts */
  97. struct in_addr mrtc_originmask; /* subnet mask for origin */
  98. vifi_t mrtc_parent;     /* incoming vif */
  99. vifbitmap_t mrtc_children; /* outgoing children vifs */
  100. vifbitmap_t mrtc_leaves; /* subset of outgoing children vifs */
  101. };
  102. #ifdef KERNEL
  103. /*
  104.  * The kernel's virtual-interface structure.
  105.  */
  106. struct vif {
  107. u_char v_flags; /* VIFF_ flags defined above */
  108. u_char v_threshold; /* min ttl required to forward on vif */
  109. struct in_addr v_lcl_addr; /* local interface address */
  110. struct in_addr v_rmt_addr; /* remote address (tunnels only) */
  111. struct ifnet  *v_ifp; /* pointer to interface */
  112. struct in_addr *v_lcl_grps; /* list of local grps (phyints only) */
  113. int v_lcl_grps_max; /* malloc'ed number of v_lcl_grps */
  114. int v_lcl_grps_n; /* used number of v_lcl_grps */
  115. u_long v_cached_group; /* last grp looked-up (phyints only) */
  116. int v_cached_result; /* last look-up result (phyints only) */
  117. };
  118. /*
  119.  * The kernel's multicast route structure.
  120.  */
  121. struct mrt {
  122. struct in_addr mrt_origin; /* subnet origin of multicasts */
  123. struct in_addr mrt_originmask; /* subnet mask for origin */
  124. vifi_t mrt_parent;     /* incoming vif */
  125. vifbitmap_t mrt_children; /* outgoing children vifs */
  126. vifbitmap_t mrt_leaves; /* subset of outgoing children vifs */
  127. struct mrt *mrt_next; /* forward link */
  128. };
  129. #define MRTHASHSIZ 64
  130. #if (MRTHASHSIZ & (MRTHASHSIZ - 1)) == 0   /* from sys:route.h */
  131. #define MRTHASHMOD(h) ((h) & (MRTHASHSIZ - 1))
  132. #else
  133. #define MRTHASHMOD(h) ((h) % MRTHASHSIZ)
  134. #endif
  135. /*
  136.  * The kernel's multicast routing statistics.
  137.  */
  138. struct mrtstat {
  139. u_long mrts_mrt_lookups; /* # multicast route lookups */
  140. u_long mrts_mrt_misses; /* # multicast route cache misses */
  141. u_long mrts_grp_lookups; /* # group address lookups */
  142. u_long mrts_grp_misses; /* # group address cache misses */
  143. u_long mrts_no_route; /* no route for packet's origin */
  144. u_long mrts_bad_tunnel; /* malformed tunnel options */
  145. u_long mrts_cant_tunnel; /* no room for tunnel options */
  146. };
  147. int ip_mrouter_cmd __P((int, struct socket *, struct mbuf *));
  148. int ip_mrouter_done __P((void));
  149. #endif /* KERNEL */