Annotation of embedaddon/quagga/lib/if.h, revision 1.1

1.1     ! misho       1: /* Interface related header.
        !             2:    Copyright (C) 1997, 98, 99 Kunihiro Ishiguro
        !             3: 
        !             4: This file is part of GNU Zebra.
        !             5: 
        !             6: GNU Zebra is free software; you can redistribute it and/or modify
        !             7: it under the terms of the GNU General Public License as published
        !             8: by the Free Software Foundation; either version 2, or (at your
        !             9: option) any later version.
        !            10: 
        !            11: GNU Zebra is distributed in the hope that it will be useful, but
        !            12: WITHOUT ANY WARRANTY; without even the implied warranty of
        !            13: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
        !            14: General Public License for more details.
        !            15: 
        !            16: You should have received a copy of the GNU General Public License
        !            17: along with GNU Zebra; see the file COPYING.  If not, write to the
        !            18: Free Software Foundation, Inc., 59 Temple Place - Suite 330,
        !            19: Boston, MA 02111-1307, USA.  */
        !            20: 
        !            21: #ifndef _ZEBRA_IF_H
        !            22: #define _ZEBRA_IF_H
        !            23: 
        !            24: #include "linklist.h"
        !            25: 
        !            26: /*
        !            27:   Interface name length.
        !            28: 
        !            29:    Linux define value in /usr/include/linux/if.h.
        !            30:    #define IFNAMSIZ        16
        !            31: 
        !            32:    FreeBSD define value in /usr/include/net/if.h.
        !            33:    #define IFNAMSIZ        16
        !            34: */
        !            35: 
        !            36: #define INTERFACE_NAMSIZ      20
        !            37: #define INTERFACE_HWADDR_MAX  20
        !            38: 
        !            39: #ifdef HAVE_PROC_NET_DEV
        !            40: struct if_stats
        !            41: {
        !            42:   unsigned long rx_packets;   /* total packets received       */
        !            43:   unsigned long tx_packets;   /* total packets transmitted    */
        !            44:   unsigned long rx_bytes;     /* total bytes received         */
        !            45:   unsigned long tx_bytes;     /* total bytes transmitted      */
        !            46:   unsigned long rx_errors;    /* bad packets received         */
        !            47:   unsigned long tx_errors;    /* packet transmit problems     */
        !            48:   unsigned long rx_dropped;   /* no space in linux buffers    */
        !            49:   unsigned long tx_dropped;   /* no space available in linux  */
        !            50:   unsigned long rx_multicast; /* multicast packets received   */
        !            51:   unsigned long rx_compressed;
        !            52:   unsigned long tx_compressed;
        !            53:   unsigned long collisions;
        !            54: 
        !            55:   /* detailed rx_errors: */
        !            56:   unsigned long rx_length_errors;
        !            57:   unsigned long rx_over_errors;       /* receiver ring buff overflow  */
        !            58:   unsigned long rx_crc_errors;        /* recved pkt with crc error    */
        !            59:   unsigned long rx_frame_errors;      /* recv'd frame alignment error */
        !            60:   unsigned long rx_fifo_errors;       /* recv'r fifo overrun          */
        !            61:   unsigned long rx_missed_errors;     /* receiver missed packet     */
        !            62:   /* detailed tx_errors */
        !            63:   unsigned long tx_aborted_errors;
        !            64:   unsigned long tx_carrier_errors;
        !            65:   unsigned long tx_fifo_errors;
        !            66:   unsigned long tx_heartbeat_errors;
        !            67:   unsigned long tx_window_errors;
        !            68: };
        !            69: #endif /* HAVE_PROC_NET_DEV */
        !            70: 
        !            71: /* Interface structure */
        !            72: struct interface 
        !            73: {
        !            74:   /* Interface name.  This should probably never be changed after the
        !            75:      interface is created, because the configuration info for this interface
        !            76:      is associated with this structure.  For that reason, the interface
        !            77:      should also never be deleted (to avoid losing configuration info).
        !            78:      To delete, just set ifindex to IFINDEX_INTERNAL to indicate that the
        !            79:      interface does not exist in the kernel.
        !            80:    */
        !            81:   char name[INTERFACE_NAMSIZ + 1];
        !            82: 
        !            83:   /* Interface index (should be IFINDEX_INTERNAL for non-kernel or
        !            84:      deleted interfaces). */
        !            85:   unsigned int ifindex;
        !            86: #define IFINDEX_INTERNAL       0
        !            87: 
        !            88:   /* Zebra internal interface status */
        !            89:   u_char status;
        !            90: #define ZEBRA_INTERFACE_ACTIVE     (1 << 0)
        !            91: #define ZEBRA_INTERFACE_SUB        (1 << 1)
        !            92: #define ZEBRA_INTERFACE_LINKDETECTION (1 << 2)
        !            93:   
        !            94:   /* Interface flags. */
        !            95:   uint64_t flags;
        !            96: 
        !            97:   /* Interface metric */
        !            98:   int metric;
        !            99: 
        !           100:   /* Interface MTU. */
        !           101:   unsigned int mtu;    /* IPv4 MTU */
        !           102:   unsigned int mtu6;   /* IPv6 MTU - probably, but not neccessarily same as mtu */
        !           103: 
        !           104:   /* Hardware address. */
        !           105: #ifdef HAVE_STRUCT_SOCKADDR_DL
        !           106:   struct sockaddr_dl sdl;
        !           107: #else
        !           108:   unsigned short hw_type;
        !           109:   u_char hw_addr[INTERFACE_HWADDR_MAX];
        !           110:   int hw_addr_len;
        !           111: #endif /* HAVE_STRUCT_SOCKADDR_DL */
        !           112: 
        !           113:   /* interface bandwidth, kbits */
        !           114:   unsigned int bandwidth;
        !           115:   
        !           116:   /* description of the interface. */
        !           117:   char *desc;                  
        !           118: 
        !           119:   /* Distribute list. */
        !           120:   void *distribute_in;
        !           121:   void *distribute_out;
        !           122: 
        !           123:   /* Connected address list. */
        !           124:   struct list *connected;
        !           125: 
        !           126:   /* Daemon specific interface data pointer. */
        !           127:   void *info;
        !           128: 
        !           129:   /* Statistics fileds. */
        !           130: #ifdef HAVE_PROC_NET_DEV
        !           131:   struct if_stats stats;
        !           132: #endif /* HAVE_PROC_NET_DEV */  
        !           133: #ifdef HAVE_NET_RT_IFLIST
        !           134:   struct if_data stats;
        !           135: #endif /* HAVE_NET_RT_IFLIST */
        !           136: };
        !           137: 
        !           138: /* Connected address structure. */
        !           139: struct connected
        !           140: {
        !           141:   /* Attached interface. */
        !           142:   struct interface *ifp;
        !           143: 
        !           144:   /* Flags for configuration. */
        !           145:   u_char conf;
        !           146: #define ZEBRA_IFC_REAL         (1 << 0)
        !           147: #define ZEBRA_IFC_CONFIGURED   (1 << 1)
        !           148:   /*
        !           149:      The ZEBRA_IFC_REAL flag should be set if and only if this address
        !           150:      exists in the kernel.
        !           151:      The ZEBRA_IFC_CONFIGURED flag should be set if and only if this address
        !           152:      was configured by the user from inside quagga.
        !           153:    */
        !           154: 
        !           155:   /* Flags for connected address. */
        !           156:   u_char flags;
        !           157: #define ZEBRA_IFA_SECONDARY    (1 << 0)
        !           158: #define ZEBRA_IFA_PEER         (1 << 1)
        !           159:   /* N.B. the ZEBRA_IFA_PEER flag should be set if and only if
        !           160:      a peer address has been configured.  If this flag is set,
        !           161:      the destination field must contain the peer address.  
        !           162:      Otherwise, if this flag is not set, the destination address
        !           163:      will either contain a broadcast address or be NULL.
        !           164:    */
        !           165: 
        !           166:   /* Address of connected network. */
        !           167:   struct prefix *address;
        !           168: 
        !           169:   /* Peer or Broadcast address, depending on whether ZEBRA_IFA_PEER is set.
        !           170:      Note: destination may be NULL if ZEBRA_IFA_PEER is not set. */
        !           171:   struct prefix *destination;
        !           172: 
        !           173:   /* Label for Linux 2.2.X and upper. */
        !           174:   char *label;
        !           175: };
        !           176: 
        !           177: /* Does the destination field contain a peer address? */
        !           178: #define CONNECTED_PEER(C) CHECK_FLAG((C)->flags, ZEBRA_IFA_PEER)
        !           179: 
        !           180: /* Prefix to insert into the RIB */
        !           181: #define CONNECTED_PREFIX(C) \
        !           182:        (CONNECTED_PEER(C) ? (C)->destination : (C)->address)
        !           183: 
        !           184: /* Identifying address.  We guess that if there's a peer address, but the
        !           185:    local address is in the same prefix, then the local address may be unique. */
        !           186: #define CONNECTED_ID(C)        \
        !           187:        ((CONNECTED_PEER(C) && !prefix_match((C)->destination, (C)->address)) ?\
        !           188:         (C)->destination : (C)->address)
        !           189: 
        !           190: /* Interface hook sort. */
        !           191: #define IF_NEW_HOOK   0
        !           192: #define IF_DELETE_HOOK 1
        !           193: 
        !           194: /* There are some interface flags which are only supported by some
        !           195:    operating system. */
        !           196: 
        !           197: #ifndef IFF_NOTRAILERS
        !           198: #define IFF_NOTRAILERS 0x0
        !           199: #endif /* IFF_NOTRAILERS */
        !           200: #ifndef IFF_OACTIVE
        !           201: #define IFF_OACTIVE 0x0
        !           202: #endif /* IFF_OACTIVE */
        !           203: #ifndef IFF_SIMPLEX
        !           204: #define IFF_SIMPLEX 0x0
        !           205: #endif /* IFF_SIMPLEX */
        !           206: #ifndef IFF_LINK0
        !           207: #define IFF_LINK0 0x0
        !           208: #endif /* IFF_LINK0 */
        !           209: #ifndef IFF_LINK1
        !           210: #define IFF_LINK1 0x0
        !           211: #endif /* IFF_LINK1 */
        !           212: #ifndef IFF_LINK2
        !           213: #define IFF_LINK2 0x0
        !           214: #endif /* IFF_LINK2 */
        !           215: #ifndef IFF_NOXMIT
        !           216: #define IFF_NOXMIT 0x0
        !           217: #endif /* IFF_NOXMIT */
        !           218: #ifndef IFF_NORTEXCH
        !           219: #define IFF_NORTEXCH 0x0
        !           220: #endif /* IFF_NORTEXCH */
        !           221: #ifndef IFF_IPV4
        !           222: #define IFF_IPV4 0x0
        !           223: #endif /* IFF_IPV4 */
        !           224: #ifndef IFF_IPV6
        !           225: #define IFF_IPV6 0x0
        !           226: #endif /* IFF_IPV6 */
        !           227: #ifndef IFF_VIRTUAL
        !           228: #define IFF_VIRTUAL 0x0
        !           229: #endif /* IFF_VIRTUAL */
        !           230: 
        !           231: /* Prototypes. */
        !           232: extern int if_cmp_func (struct interface *, struct interface *);
        !           233: extern struct interface *if_create (const char *name, int namelen);
        !           234: extern struct interface *if_lookup_by_index (unsigned int);
        !           235: extern struct interface *if_lookup_exact_address (struct in_addr);
        !           236: extern struct interface *if_lookup_address (struct in_addr);
        !           237: 
        !           238: /* These 2 functions are to be used when the ifname argument is terminated
        !           239:    by a '\0' character: */
        !           240: extern struct interface *if_lookup_by_name (const char *ifname);
        !           241: extern struct interface *if_get_by_name (const char *ifname);
        !           242: 
        !           243: /* For these 2 functions, the namelen argument should be the precise length
        !           244:    of the ifname string (not counting any optional trailing '\0' character).
        !           245:    In most cases, strnlen should be used to calculate the namelen value. */
        !           246: extern struct interface *if_lookup_by_name_len(const char *ifname,
        !           247:                                               size_t namelen);
        !           248: extern struct interface *if_get_by_name_len(const char *ifname, size_t namelen);
        !           249: 
        !           250: 
        !           251: /* Delete the interface, but do not free the structure, and leave it in the
        !           252:    interface list.  It is often advisable to leave the pseudo interface 
        !           253:    structure because there may be configuration information attached. */
        !           254: extern void if_delete_retain (struct interface *);
        !           255: 
        !           256: /* Delete and free the interface structure: calls if_delete_retain and then
        !           257:    deletes it from the interface list and frees the structure. */
        !           258: extern void if_delete (struct interface *);
        !           259: 
        !           260: extern int if_is_up (struct interface *);
        !           261: extern int if_is_running (struct interface *);
        !           262: extern int if_is_operative (struct interface *);
        !           263: extern int if_is_loopback (struct interface *);
        !           264: extern int if_is_broadcast (struct interface *);
        !           265: extern int if_is_pointopoint (struct interface *);
        !           266: extern int if_is_multicast (struct interface *);
        !           267: extern void if_add_hook (int, int (*)(struct interface *));
        !           268: extern void if_init (void);
        !           269: extern void if_terminate (void);
        !           270: extern void if_dump_all (void);
        !           271: extern const char *if_flag_dump(unsigned long);
        !           272: 
        !           273: /* Please use ifindex2ifname instead of if_indextoname where possible;
        !           274:    ifindex2ifname uses internal interface info, whereas if_indextoname must
        !           275:    make a system call. */
        !           276: extern const char *ifindex2ifname (unsigned int);
        !           277: 
        !           278: /* Please use ifname2ifindex instead of if_nametoindex where possible;
        !           279:    ifname2ifindex uses internal interface info, whereas if_nametoindex must
        !           280:    make a system call. */
        !           281: extern unsigned int ifname2ifindex(const char *ifname);
        !           282: 
        !           283: /* Connected address functions. */
        !           284: extern struct connected *connected_new (void);
        !           285: extern void connected_free (struct connected *);
        !           286: extern void connected_add (struct interface *, struct connected *);
        !           287: extern struct connected  *connected_add_by_prefix (struct interface *,
        !           288:                                             struct prefix *,
        !           289:                                             struct prefix *);
        !           290: extern struct connected  *connected_delete_by_prefix (struct interface *, 
        !           291:                                                struct prefix *);
        !           292: extern struct connected  *connected_lookup_address (struct interface *, 
        !           293:                                              struct in_addr);
        !           294: 
        !           295: #ifndef HAVE_IF_NAMETOINDEX
        !           296: extern unsigned int if_nametoindex (const char *);
        !           297: #endif
        !           298: #ifndef HAVE_IF_INDEXTONAME
        !           299: extern char *if_indextoname (unsigned int, char *);
        !           300: #endif
        !           301: 
        !           302: /* Exported variables. */
        !           303: extern struct list *iflist;
        !           304: extern struct cmd_element interface_desc_cmd;
        !           305: extern struct cmd_element no_interface_desc_cmd;
        !           306: extern struct cmd_element interface_cmd;
        !           307: extern struct cmd_element no_interface_cmd;
        !           308: extern struct cmd_element interface_pseudo_cmd;
        !           309: extern struct cmd_element no_interface_pseudo_cmd;
        !           310: extern struct cmd_element show_address_cmd;
        !           311: 
        !           312: #endif /* _ZEBRA_IF_H */

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>