diff options
author | Donald Sharp <sharpd@nvidia.com> | 2021-05-12 20:31:45 +0200 |
---|---|---|
committer | Donald Sharp <sharpd@nvidia.com> | 2021-05-12 20:36:59 +0200 |
commit | d3cc1e45182196a0b9b7146bcbaef04f346d9721 (patch) | |
tree | 2841feca90eae72f58a1c0c3e23af860db3f3b46 /pimd/pim_bsm.c | |
parent | pimd: There exists a path where on vrf bringup we do not create the pimreg (diff) | |
download | frr-d3cc1e45182196a0b9b7146bcbaef04f346d9721.tar.xz frr-d3cc1e45182196a0b9b7146bcbaef04f346d9721.zip |
pimd: Remove pim->vrf_id and use pim->vrf->vrf_id
VRF creation can happen from either cli or from
knowledged about the vrf learned from zebra.
In the case where we learn about the vrf from
the cli, the vrf id is UNKNOWN. Upon actual
creation of the vrf, lib/vrf.c touches up the vrf_id
and calls pim_vrf_enable to turn it on properly.
At this point in time we have a pim->vrf_id of
UNKNOWN and the vrf->vrf_id of the right value.
There is no point in duplicating this data. So just
remove all pim->vrf_id and use the vrf->vrf_id instead
since we keep a copy of the pim->vrf pointer.
This will remove some crashes where we expect the
pim->vrf_id to be usable and it's not.
Signed-off-by: Donald Sharp <sharpd@nvidia.com>
Diffstat (limited to 'pimd/pim_bsm.c')
-rw-r--r-- | pimd/pim_bsm.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/pimd/pim_bsm.c b/pimd/pim_bsm.c index 3fbe3317b..ad5257630 100644 --- a/pimd/pim_bsm.c +++ b/pimd/pim_bsm.c @@ -1320,7 +1320,7 @@ int pim_bsm_process(struct interface *ifp, struct ip *ip_hdr, uint8_t *buf, } } } else if (if_lookup_exact_address(&ip_hdr->ip_dst, AF_INET, - pim->vrf_id)) { + pim->vrf->vrf_id)) { /* Unicast BSM received - if ucast bsm not enabled on * the interface, drop it */ |