diff options
author | Babis Chalios <mail@bchalios.io> | 2020-10-01 11:07:54 +0200 |
---|---|---|
committer | Babis Chalios <mail@bchalios.io> | 2020-10-15 11:16:01 +0200 |
commit | 8ab046a480e8287e0451ed746bc1e37428816942 (patch) | |
tree | 816c4287f97c4a1aedae6fdde6874cd366660652 /ospfd | |
parent | Merge pull request #7278 from donaldsharp/fix_blame_code (diff) | |
download | frr-8ab046a480e8287e0451ed746bc1e37428816942.tar.xz frr-8ab046a480e8287e0451ed746bc1e37428816942.zip |
ospfd: fix invocation of ospfTrapNbrStateChange
ospfNbrStateChange is generated when the state of neighbor regresses or
it progresses to a terminal state. When transitioning to or from Full
state on non-broadcast multi-access and broadcast networks the trap
should be sent by the designated router. This last condition was not
taken into account when checking for the conditions of generating the
trap.
Fixes volta/volta-stack#1811
Signed-off-by: Babis Chalios <mail@bchalios.io>
Diffstat (limited to 'ospfd')
-rw-r--r-- | ospfd/ospf_snmp.c | 33 |
1 files changed, 19 insertions, 14 deletions
diff --git a/ospfd/ospf_snmp.c b/ospfd/ospf_snmp.c index 63191d5cb..8e5cb5bb3 100644 --- a/ospfd/ospf_snmp.c +++ b/ospfd/ospf_snmp.c @@ -2486,20 +2486,25 @@ static void ospfTrapVirtNbrStateChange(struct ospf_neighbor *on) static int ospf_snmp_nsm_change(struct ospf_neighbor *nbr, int next_state, int old_state) { - /* Terminal state or regression */ - if ((next_state == NSM_Full) || (next_state == NSM_TwoWay) - || (next_state < old_state)) { - /* ospfVirtNbrStateChange */ - if (nbr->oi->type == OSPF_IFTYPE_VIRTUALLINK) - ospfTrapVirtNbrStateChange(nbr); - /* ospfNbrStateChange trap */ - else - /* To/From FULL, only managed by DR */ - if (((next_state != NSM_Full) - && (nbr->state != NSM_Full)) - || (nbr->oi->state == ISM_DR)) - ospfTrapNbrStateChange(nbr); - } + /* Transition to/from state Full should be handled only by + * DR when in Broadcast or Non-Brodcast Multi-Access networks + */ + if ((next_state == NSM_Full || old_state == NSM_Full) + && (nbr->oi->state != ISM_DR) + && (nbr->oi->type == OSPF_IFTYPE_BROADCAST + || nbr->oi->type == OSPF_IFTYPE_NBMA)) + return 0; + + /* State progression to non-terminal state */ + if (next_state > old_state && next_state != NSM_Full + && next_state != NSM_TwoWay) + return 0; + + if (nbr->oi->type == OSPF_IFTYPE_VIRTUALLINK) + ospfTrapVirtNbrStateChange(nbr); + else + ospfTrapNbrStateChange(nbr); + return 0; } |