diff options
| author | Donald Sharp <sharpd@cumulusnetworks.com> | 2019-10-24 15:09:18 -0400 | 
|---|---|---|
| committer | Donald Sharp <sharpd@cumulusnetworks.com> | 2019-12-04 14:23:20 -0500 | 
| commit | 85d25587bfd551e4ce39501dd54a07c4325bb7ae (patch) | |
| tree | afd6960e0cff1b508b26795547ca28aeb814e268 /eigrpd/eigrp_structs.h | |
| parent | c84355a93212939e98084137aa927ab911305614 (diff) | |
eigrpd, ospfd, pimd: Fix assumption that interface may not be up
Commit: ddbf3e60604019d4b38d51226700e2244cc531b6
This commit modified the interface up handling code in
ZAPI such that the zclient handled the decoding for you.
Prior to this commit ospf assumed that it could use the
old ifp pointer to know state before reading the stream.
This lead to a situation where ospf would `smartly` track
and do the right thing in this situation.  This commit
changed this assumption and in certain scenarios, say
a interface was changed after it was already up would
lead to situations where ospf would not properly handle
the new interface up.
Modify ospf to track data that is important to it in
it's interface->info pointer.
This code pattern was followed in both eigrp and pim.
In eigrp's case it was just behaving weirdly in any event
so fixing this pattern is not a big deal.  In pim's
case it was not properly using this so it's a no-op
to fix.
Signed-off-by: Donald Sharp <sharpd@cumulusnetworks.com>
Diffstat (limited to 'eigrpd/eigrp_structs.h')
| -rw-r--r-- | eigrpd/eigrp_structs.h | 2 | 
1 files changed, 2 insertions, 0 deletions
diff --git a/eigrpd/eigrp_structs.h b/eigrpd/eigrp_structs.h index e50858f071..82bddaaae3 100644 --- a/eigrpd/eigrp_structs.h +++ b/eigrpd/eigrp_structs.h @@ -176,6 +176,8 @@ struct eigrp_interface {  	/* To which multicast groups do we currently belong? */ +	uint32_t curr_bandwidth; +	uint32_t curr_mtu;  	uint8_t multicast_memberships;  | 
