From: Donald Sharp Date: Wed, 20 May 2015 01:04:23 +0000 (-0700) Subject: "clear ip bgp * soft out" does not trigger resending "neighbor x.x.x.x default-originate" X-Git-Tag: frr-2.0-rc1~1388 X-Git-Url: https://git.puffer.fish/?a=commitdiff_plain;h=6a646146718767de5947bc6845c7de717093cca7;p=matthieu%2Ffrr.git "clear ip bgp * soft out" does not trigger resending "neighbor x.x.x.x default-originate" --- diff --git a/bgpd/bgpd.c b/bgpd/bgpd.c index 61b2fb93c9..a5794af789 100644 --- a/bgpd/bgpd.c +++ b/bgpd/bgpd.c @@ -5588,6 +5588,8 @@ int peer_clear_soft (struct peer *peer, afi_t afi, safi_t safi, enum bgp_clear_type stype) { + struct peer_af *paf; + if (peer->status != Established) return 0; @@ -5603,7 +5605,15 @@ peer_clear_soft (struct peer *peer, afi_t afi, safi_t safi, } if (stype == BGP_CLEAR_SOFT_OUT || stype == BGP_CLEAR_SOFT_BOTH) - bgp_announce_route (peer, afi, safi); + { + /* Clear the "neighbor x.x.x.x default-originate" flag */ + paf = peer_af_find (peer, afi, safi); + if (paf && paf->subgroup && + CHECK_FLAG (paf->subgroup->sflags, SUBGRP_STATUS_DEFAULT_ORIGINATE)) + UNSET_FLAG (paf->subgroup->sflags, SUBGRP_STATUS_DEFAULT_ORIGINATE); + + bgp_announce_route (peer, afi, safi); + } if (stype == BGP_CLEAR_SOFT_IN_ORF_PREFIX) {