File:  [ELWIX - Embedded LightWeight unIX -] / embedaddon / quagga / ospfd / ospf_spf.h
Revision 1.1.1.1 (vendor branch): download - view: text, annotated - select for diffs - revision graph
Tue Feb 21 17:26:12 2012 UTC (12 years, 4 months ago) by misho
Branches: quagga, MAIN
CVS tags: v0_99_22p0, v0_99_22, v0_99_21, v0_99_20_1, v0_99_20, HEAD
quagga

    1: /*
    2:  * OSPF calculation.
    3:  * Copyright (C) 1999 Kunihiro Ishiguro
    4:  *
    5:  * This file is part of GNU Zebra.
    6:  *
    7:  * GNU Zebra is free software; you can redistribute it and/or modify it
    8:  * under the terms of the GNU General Public License as published by the
    9:  * Free Software Foundation; either version 2, or (at your option) any
   10:  * later version.
   11:  *
   12:  * GNU Zebra is distributed in the hope that it will be useful, but
   13:  * WITHOUT ANY WARRANTY; without even the implied warranty of
   14:  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   15:  * General Public License for more details.
   16:  *
   17:  * You should have received a copy of the GNU General Public License
   18:  * along with GNU Zebra; see the file COPYING.  If not, write to the Free
   19:  * Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
   20:  * 02111-1307, USA.
   21:  */
   22: 
   23: #ifndef _QUAGGA_OSPF_SPF_H
   24: #define _QUAGGA_OSPF_SPF_H
   25: 
   26: /* values for vertex->type */
   27: #define OSPF_VERTEX_ROUTER  1  /* for a Router-LSA */
   28: #define OSPF_VERTEX_NETWORK 2  /* for a Network-LSA */
   29: 
   30: /* values for vertex->flags */
   31: #define OSPF_VERTEX_PROCESSED      0x01
   32: 
   33: /* The "root" is the node running the SPF calculation */
   34: 
   35: /* A router or network in an area */
   36: struct vertex
   37: {
   38:   u_char flags;
   39:   u_char type;		/* copied from LSA header */
   40:   struct in_addr id;	/* copied from LSA header */
   41:   struct lsa_header *lsa; /* Router or Network LSA */
   42:   int *stat;		/* Link to LSA status. */
   43:   u_int32_t distance;	/* from root to this vertex */  
   44:   struct list *parents;		/* list of parents in SPF tree */
   45:   struct list *children;	/* list of children in SPF tree*/
   46: };
   47: 
   48: /* A nexthop taken on the root node to get to this (parent) vertex */
   49: struct vertex_nexthop
   50: {
   51:   struct ospf_interface *oi;	/* output intf on root node */
   52:   struct in_addr router;	/* router address to send to */
   53: };
   54: 
   55: struct vertex_parent
   56: {
   57:   struct vertex_nexthop *nexthop; /* link to nexthop info for this parent */
   58:   struct vertex *parent;	/* parent vertex */
   59:   int backlink;			/* index back to parent for router-lsa's */
   60: };
   61: 
   62: extern void ospf_spf_calculate_schedule (struct ospf *);
   63: extern void ospf_rtrs_free (struct route_table *);
   64: 
   65: /* void ospf_spf_calculate_timer_add (); */
   66: 
   67: #endif /* _QUAGGA_OSPF_SPF_H */

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