summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStephen Hemminger <stephen.hemminger@vyatta.com>2009-05-27 17:58:51 -0700
committerStephen Hemminger <stephen.hemminger@vyatta.com>2009-05-27 17:58:51 -0700
commit060f36a30a71a96ec2bf88e6d9e52ce7f6f37dbd (patch)
treef292bbe77652744e068041d3b166e4d326f2d0ab
parent3ea593d4664b070cdf638946a9dea57c7045b3dd (diff)
parent49a1b59f935674c35019c7f6bd8b8a5a83dd619c (diff)
downloadquagga-060f36a30a71a96ec2bf88e6d9e52ce7f6f37dbd.tar.bz2
quagga-060f36a30a71a96ec2bf88e6d9e52ce7f6f37dbd.tar.xz
Merge branch 'jenner' of 192.168.100.1:git/vyatta-quagga into jenner
-rw-r--r--zebra/zebra_rib.c6
-rw-r--r--zebra/zebra_vty.c3
2 files changed, 5 insertions, 4 deletions
diff --git a/zebra/zebra_rib.c b/zebra/zebra_rib.c
index 5ea93112..ade13578 100644
--- a/zebra/zebra_rib.c
+++ b/zebra/zebra_rib.c
@@ -451,8 +451,7 @@ nexthop_active_ipv4 (struct rib *rib, struct nexthop *nexthop, int set,
return 1;
}
}
- else if (CHECK_FLAG (rib->flags, ZEBRA_FLAG_INTERNAL)
- || match->type == ZEBRA_ROUTE_STATIC)
+ else if (CHECK_FLAG (rib->flags, ZEBRA_FLAG_INTERNAL))
{
for (newhop = match->nexthop; newhop; newhop = newhop->next)
if (CHECK_FLAG (newhop->flags, NEXTHOP_FLAG_FIB)
@@ -589,8 +588,7 @@ nexthop_active_ipv6 (struct rib *rib, struct nexthop *nexthop, int set,
return 1;
}
}
- else if (CHECK_FLAG (rib->flags, ZEBRA_FLAG_INTERNAL) ||
- match->type == ZEBRA_ROUTE_STATIC)
+ else if (CHECK_FLAG (rib->flags, ZEBRA_FLAG_INTERNAL))
{
for (newhop = match->nexthop; newhop; newhop = newhop->next)
if (CHECK_FLAG (newhop->flags, NEXTHOP_FLAG_FIB)
diff --git a/zebra/zebra_vty.c b/zebra/zebra_vty.c
index ecb5d10a..d4e3a4ae 100644
--- a/zebra/zebra_vty.c
+++ b/zebra/zebra_vty.c
@@ -87,6 +87,9 @@ zebra_static_ipv4 (struct vty *vty, int add_cmd, const char *dest_str,
return CMD_SUCCESS;
}
+ /* Mark static routes as internal so they get evaluated as recursive */
+ SET_FLAG (flag, ZEBRA_FLAG_INTERNAL);
+
/* Route flags */
if (flag_str) {
switch(flag_str[0]) {