home *** CD-ROM | disk | FTP | other *** search
/ Il CD di internet / CD.iso / SOURCE / N / TCPIP / NETKIT-B.05 / NETKIT-B / NetKit-B-0.05 / routed / interface.h,v < prev    next >
Encoding:
Text File  |  1994-05-23  |  4.2 KB  |  119 lines

  1. head    1.1;
  2. access;
  3. symbols;
  4. locks
  5.     rzsfl:1.1; strict;
  6. comment    @ * @;
  7.  
  8.  
  9. 1.1
  10. date    94.05.23.09.08.11;    author rzsfl;    state Exp;
  11. branches;
  12. next    ;
  13.  
  14.  
  15. desc
  16. @Original
  17. @
  18.  
  19.  
  20. 1.1
  21. log
  22. @Initial revision
  23. @
  24. text
  25. @/*
  26.  * Copyright (c) 1983 Regents of the University of California.
  27.  * All rights reserved.
  28.  *
  29.  * Redistribution and use in source and binary forms, with or without
  30.  * modification, are permitted provided that the following conditions
  31.  * are met:
  32.  * 1. Redistributions of source code must retain the above copyright
  33.  *    notice, this list of conditions and the following disclaimer.
  34.  * 2. Redistributions in binary form must reproduce the above copyright
  35.  *    notice, this list of conditions and the following disclaimer in the
  36.  *    documentation and/or other materials provided with the distribution.
  37.  * 3. All advertising materials mentioning features or use of this software
  38.  *    must display the following acknowledgement:
  39.  *    This product includes software developed by the University of
  40.  *    California, Berkeley and its contributors.
  41.  * 4. Neither the name of the University nor the names of its contributors
  42.  *    may be used to endorse or promote products derived from this software
  43.  *    without specific prior written permission.
  44.  *
  45.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  46.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  47.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  48.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  49.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  50.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  51.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  52.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  53.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  54.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  55.  * SUCH DAMAGE.
  56.  *
  57.  *    from: @@(#)interface.h    5.6 (Berkeley) 6/1/90
  58.  *    $Id: interface.h,v 1.5 1993/12/11 01:47:28 cgd Exp $
  59.  */
  60.  
  61. /*
  62.  * Routing table management daemon.
  63.  */
  64.  
  65. /*
  66.  * An ``interface'' is similar to an ifnet structure,
  67.  * except it doesn't contain q'ing info, and it also
  68.  * handles ``logical'' interfaces (remote gateways
  69.  * that we want to keep polling even if they go down).
  70.  * The list of interfaces which we maintain is used
  71.  * in supplying the gratuitous routing table updates.
  72.  */
  73. struct interface {
  74.     struct    interface *int_next;
  75.     struct    sockaddr int_addr;        /* address on this host */
  76.     union {
  77.         struct    sockaddr intu_broadaddr;
  78.         struct    sockaddr intu_dstaddr;
  79.     } int_intu;
  80. #define    int_broadaddr    int_intu.intu_broadaddr    /* broadcast address */
  81. #define    int_dstaddr    int_intu.intu_dstaddr    /* other end of p-to-p link */
  82.     int    int_metric;            /* init's routing entry */
  83.     int    int_flags;            /* see below */
  84.     /* START INTERNET SPECIFIC */
  85.     u_long    int_net;            /* network # */
  86.     u_long    int_netmask;            /* net mask for addr */
  87.     u_long    int_subnet;            /* subnet # */
  88.     u_long    int_subnetmask;            /* subnet mask for addr */
  89.     /* END INTERNET SPECIFIC */
  90.     struct    ifdebug int_input, int_output;    /* packet tracing stuff */
  91.     int    int_ipackets;            /* input packets received */
  92.     int    int_opackets;            /* output packets sent */
  93.     char    *int_name;            /* from kernel if structure */
  94.     u_short    int_transitions;        /* times gone up-down */
  95. };
  96.  
  97. /*
  98.  * 0x1 to 0x10 are reused from the kernel's ifnet definitions,
  99.  * the others agree with the RTS_ flags defined elsewhere.
  100.  */
  101. #define    IFF_UP        0x1        /* interface is up */
  102. #define    IFF_BROADCAST    0x2        /* broadcast address valid */
  103. #define    IFF_DEBUG    0x4        /* turn on debugging */
  104. #define    IFF_LOOPBACK    0x8        /* software loopback net */
  105. #define    IFF_POINTOPOINT    0x10        /* interface is point-to-point link */
  106.  
  107. #define    IFF_FLAGMASK    0x1f        /* mask for relevant int_flags bits */
  108.  
  109. #define    IFF_SUBNET    0x1000        /* interface on subnetted network */
  110. #define    IFF_PASSIVE    0x2000        /* can't tell if up/down */
  111. #define    IFF_INTERFACE    0x4000        /* hardware interface */
  112. #define    IFF_REMOTE    0x8000        /* interface isn't on this machine */
  113.  
  114. struct    interface *if_ifwithaddr();
  115. struct    interface *if_ifwithdstaddr();
  116. struct    interface *if_ifwithnet();
  117. struct    interface *if_iflookup();
  118. @
  119.