diff options
| author | Avneesh Sachdev <avneesh@opensourcerouting.org> | 2012-04-11 23:51:08 -0700 | 
|---|---|---|
| committer | Avneesh Sachdev <avneesh@opensourcerouting.org> | 2012-04-11 23:51:08 -0700 | 
| commit | 14d2bbaa3f4aa53152472694c29f336808e47313 (patch) | |
| tree | e39bdddef4ea53207dd8fb61e1fd6b54d8c7721d /zebra/zebra_rib.c | |
| parent | 51d4ef832c1e58150325630e25c442866e5a6cf5 (diff) | |
| parent | e96b312150d8e376c1ef463793d1929eca3618d5 (diff) | |
Merge quagga mainline into the google ISIS code.
The steps were:
  $ git checkout google-is-is
  $ git merge quagga
  $ git checkout google-is-is -- isisd
  # Resolve conflicts in the following:
  lib/md5.h
  zebra/rt_netlink.c
  zebra/zebra_rib.c
  zebra/zserv.c
Note that the content in the isisd directory is left unchanged in the
merge. As a result, changes made to isisd as part of the following
commits on the quagga mainline are dropped.
  # 8ced4e82 is the merge base, e96b3121 is the current quagga master
  $ git log --oneline --reverse 8ced4e82..e96b3121 -- isisd
  5574999 isisd: fix crash on "no router isis" (BZ#536)
  8998075 isisd: raise hello rate for DIS (BZ#539)
  306ca83 isisd: include hash.h, not hash.c
  b82cdeb delete CVS keywords
  2f65867 isisd: indent longopts array
  b511468 quagga: option "-z" ("--socket <path>") added
  05e54ee build: delete .cvsignore files
  b4e45f6 fix zebra protocol after MP-BGP changes
  7fd6cd8 isisd: fix circuit state machine
  907fd95 isisd: send proper LSP after DIS election
  d034aa0 isisd: fix wrong next-hops from SPF
  c25eaff isisd: unexpected kernel routing table (BZ#544)
  e6b03b7 isisd: implement MD5 circuit authentication
Diffstat (limited to 'zebra/zebra_rib.c')
| -rw-r--r-- | zebra/zebra_rib.c | 101 | 
1 files changed, 76 insertions, 25 deletions
| diff --git a/zebra/zebra_rib.c b/zebra/zebra_rib.c index 8da6c84a..2fa439c0 100644 --- a/zebra/zebra_rib.c +++ b/zebra/zebra_rib.c @@ -55,18 +55,20 @@ static const struct  {      int key;    int distance; -} route_info[] = -{ -  {ZEBRA_ROUTE_SYSTEM,    0}, -  {ZEBRA_ROUTE_KERNEL,    0}, -  {ZEBRA_ROUTE_CONNECT,   0}, -  {ZEBRA_ROUTE_STATIC,    1}, -  {ZEBRA_ROUTE_RIP,     120}, -  {ZEBRA_ROUTE_RIPNG,   120}, -  {ZEBRA_ROUTE_OSPF,    110}, -  {ZEBRA_ROUTE_OSPF6,   110}, -  {ZEBRA_ROUTE_ISIS,    115}, -  {ZEBRA_ROUTE_BGP,      20  /* IBGP is 200. */} +} route_info[ZEBRA_ROUTE_MAX] = +{ +  [ZEBRA_ROUTE_SYSTEM]  = {ZEBRA_ROUTE_SYSTEM,    0}, +  [ZEBRA_ROUTE_KERNEL]  = {ZEBRA_ROUTE_KERNEL,    0}, +  [ZEBRA_ROUTE_CONNECT] = {ZEBRA_ROUTE_CONNECT,   0}, +  [ZEBRA_ROUTE_STATIC]  = {ZEBRA_ROUTE_STATIC,    1}, +  [ZEBRA_ROUTE_RIP]     = {ZEBRA_ROUTE_RIP,     120}, +  [ZEBRA_ROUTE_RIPNG]   = {ZEBRA_ROUTE_RIPNG,   120}, +  [ZEBRA_ROUTE_OSPF]    = {ZEBRA_ROUTE_OSPF,    110}, +  [ZEBRA_ROUTE_OSPF6]   = {ZEBRA_ROUTE_OSPF6,   110}, +  [ZEBRA_ROUTE_ISIS]    = {ZEBRA_ROUTE_ISIS,    115}, +  [ZEBRA_ROUTE_BGP]     = {ZEBRA_ROUTE_BGP,      20  /* IBGP is 200. */}, +  [ZEBRA_ROUTE_BABEL]   = {ZEBRA_ROUTE_BABEL,    95}, +  /* no entry/default: 150 */  };  /* Vector for routing table.  */ @@ -89,6 +91,11 @@ vrf_alloc (const char *name)    vrf->table[AFI_IP6][SAFI_UNICAST] = route_table_init ();    vrf->stable[AFI_IP][SAFI_UNICAST] = route_table_init ();    vrf->stable[AFI_IP6][SAFI_UNICAST] = route_table_init (); +  vrf->table[AFI_IP][SAFI_MULTICAST] = route_table_init (); +  vrf->table[AFI_IP6][SAFI_MULTICAST] = route_table_init (); +  vrf->stable[AFI_IP][SAFI_MULTICAST] = route_table_init (); +  vrf->stable[AFI_IP6][SAFI_MULTICAST] = route_table_init (); +    return vrf;  } @@ -1229,6 +1236,7 @@ static const u_char meta_queue_map[ZEBRA_ROUTE_MAX] = {    [ZEBRA_ROUTE_ISIS]    = 2,    [ZEBRA_ROUTE_BGP]     = 3,    [ZEBRA_ROUTE_HSLS]    = 4, +  [ZEBRA_ROUTE_BABEL]   = 2,  };  /* Look into the RN and queue it into one or more priority queues, @@ -1519,7 +1527,7 @@ int  rib_add_ipv4 (int type, int flags, struct prefix_ipv4 *p,   	      struct in_addr *gate, struct in_addr *src,  	      unsigned int ifindex, u_int32_t vrf_id, -	      u_int32_t metric, u_char distance) +	      u_int32_t metric, u_char distance, safi_t safi)  {    struct rib *rib;    struct rib *same = NULL; @@ -1528,7 +1536,7 @@ rib_add_ipv4 (int type, int flags, struct prefix_ipv4 *p,    struct nexthop *nexthop;    /* Lookup table.  */ -  table = vrf_table (AFI_IP, SAFI_UNICAST, 0); +  table = vrf_table (AFI_IP, safi, 0);    if (! table)      return 0; @@ -1538,7 +1546,10 @@ rib_add_ipv4 (int type, int flags, struct prefix_ipv4 *p,    /* Set default distance by route type. */    if (distance == 0)      { -      distance = route_info[type].distance; +      if ((unsigned)type >= sizeof(route_info) / sizeof(route_info[0])) +	distance = 150; +      else +        distance = route_info[type].distance;        /* iBGP distance is 200. */        if (type == ZEBRA_ROUTE_BGP && CHECK_FLAG (flags, ZEBRA_FLAG_IBGP)) @@ -1774,7 +1785,7 @@ void rib_lookup_and_pushup (struct prefix_ipv4 * p)  }  int -rib_add_ipv4_multipath (struct prefix_ipv4 *p, struct rib *rib) +rib_add_ipv4_multipath (struct prefix_ipv4 *p, struct rib *rib, safi_t safi)  {    struct route_table *table;    struct route_node *rn; @@ -1782,9 +1793,10 @@ rib_add_ipv4_multipath (struct prefix_ipv4 *p, struct rib *rib)    struct nexthop *nexthop;    /* Lookup table.  */ -  table = vrf_table (AFI_IP, SAFI_UNICAST, 0); +  table = vrf_table (AFI_IP, safi, 0);    if (! table)      return 0; +    /* Make it sure prefixlen is applied to the prefix. */    apply_mask_ipv4 (p); @@ -1847,7 +1859,7 @@ rib_add_ipv4_multipath (struct prefix_ipv4 *p, struct rib *rib)  /* XXX factor with rib_delete_ipv6 */  int  rib_delete_ipv4 (int type, int flags, struct prefix_ipv4 *p, -		 struct in_addr *gate, unsigned int ifindex, u_int32_t vrf_id) +		 struct in_addr *gate, unsigned int ifindex, u_int32_t vrf_id, safi_t safi)  {    struct route_table *table;    struct route_node *rn; @@ -1859,7 +1871,7 @@ rib_delete_ipv4 (int type, int flags, struct prefix_ipv4 *p,    char buf2[INET_ADDRSTRLEN];    /* Lookup table.  */ -  table = vrf_table (AFI_IP, SAFI_UNICAST, 0); +  table = vrf_table (AFI_IP, safi, 0);    if (! table)      return 0; @@ -1906,8 +1918,10 @@ rib_delete_ipv4 (int type, int flags, struct prefix_ipv4 *p,        if (rib->type != type)  	continue;        if (rib->type == ZEBRA_ROUTE_CONNECT && (nexthop = rib->nexthop) && -	  nexthop->type == NEXTHOP_TYPE_IFINDEX && nexthop->ifindex == ifindex) +	  nexthop->type == NEXTHOP_TYPE_IFINDEX)  	{ +	  if (nexthop->ifindex != ifindex) +	    continue;  	  if (rib->refcnt)  	    {  	      rib->refcnt--; @@ -2308,7 +2322,7 @@ rib_bogus_ipv6 (int type, struct prefix_ipv6 *p,  int  rib_add_ipv6 (int type, int flags, struct prefix_ipv6 *p,  	      struct in6_addr *gate, unsigned int ifindex, u_int32_t vrf_id, -	      u_int32_t metric, u_char distance) +	      u_int32_t metric, u_char distance, safi_t safi)  {    struct rib *rib;    struct rib *same = NULL; @@ -2317,7 +2331,7 @@ rib_add_ipv6 (int type, int flags, struct prefix_ipv6 *p,    struct nexthop *nexthop;    /* Lookup table.  */ -  table = vrf_table (AFI_IP6, SAFI_UNICAST, 0); +  table = vrf_table (AFI_IP6, safi, 0);    if (! table)      return 0; @@ -2402,7 +2416,7 @@ rib_add_ipv6 (int type, int flags, struct prefix_ipv6 *p,  /* XXX factor with rib_delete_ipv6 */  int  rib_delete_ipv6 (int type, int flags, struct prefix_ipv6 *p, -		 struct in6_addr *gate, unsigned int ifindex, u_int32_t vrf_id) +		 struct in6_addr *gate, unsigned int ifindex, u_int32_t vrf_id, safi_t safi)  {    struct route_table *table;    struct route_node *rn; @@ -2417,7 +2431,7 @@ rib_delete_ipv6 (int type, int flags, struct prefix_ipv6 *p,    apply_mask_ipv6 (p);    /* Lookup table.  */ -  table = vrf_table (AFI_IP6, SAFI_UNICAST, 0); +  table = vrf_table (AFI_IP6, safi, 0);    if (! table)      return 0; @@ -2454,8 +2468,10 @@ rib_delete_ipv6 (int type, int flags, struct prefix_ipv6 *p,        if (rib->type != type)          continue;        if (rib->type == ZEBRA_ROUTE_CONNECT && (nexthop = rib->nexthop) && -	  nexthop->type == NEXTHOP_TYPE_IFINDEX && nexthop->ifindex == ifindex) +	  nexthop->type == NEXTHOP_TYPE_IFINDEX)  	{ +	  if (nexthop->ifindex != ifindex) +	    continue;  	  if (rib->refcnt)  	    {  	      rib->refcnt--; @@ -2960,6 +2976,41 @@ rib_sweep_client_route (struct zserv *client)      }  } + +/* Remove specific by protocol routes from 'table'. */ +static unsigned long +rib_score_proto_table (u_char proto, struct route_table *table) +{ +  struct route_node *rn; +  struct rib *rib; +  struct rib *next; +  unsigned long n = 0; + +  if (table) +    for (rn = route_top (table); rn; rn = route_next (rn)) +      for (rib = rn->info; rib; rib = next) +        { +          next = rib->next; +          if (CHECK_FLAG (rib->status, RIB_ENTRY_REMOVED)) +            continue; +          if (rib->type == proto) +            { +              rib_delnode (rn, rib); +              n++; +            } +        } + +  return n; +} + +/* Remove specific by protocol routes. */ +unsigned long +rib_score_proto (u_char proto) +{ +  return  rib_score_proto_table (proto, vrf_table (AFI_IP,  SAFI_UNICAST, 0)) +         +rib_score_proto_table (proto, vrf_table (AFI_IP6, SAFI_UNICAST, 0)); +} +  /* Close RIB and clean up kernel routes. */  static void  rib_close_table (struct route_table *table) | 
