diff --git a/pimd/pim_nb_config.c b/pimd/pim_nb_config.c index 61b2b7d4fbc8..1f0e7793a06b 100644 --- a/pimd/pim_nb_config.c +++ b/pimd/pim_nb_config.c @@ -1774,6 +1774,7 @@ int routing_control_plane_protocols_control_plane_protocol_pim_address_family_mc struct vrf *vrf; struct pim_instance *pim; const char *mode; + enum pim_rpf_lookup_mode old_mode; switch (args->event) { case NB_EV_VALIDATE: @@ -1785,9 +1786,8 @@ int routing_control_plane_protocols_control_plane_protocol_pim_address_family_mc pim = vrf->info; mode = yang_dnode_get_string(args->dnode, NULL); - if (strmatch(mode, "none")) - pim->rpf_mode = MCAST_NO_CONFIG; - else if (strmatch(mode, "urib-only")) + old_mode = pim->rpf_mode; + if (strmatch(mode, "urib-only")) pim->rpf_mode = MCAST_URIB_ONLY; else if (strmatch(mode, "mrib-only")) pim->rpf_mode = MCAST_MRIB_ONLY; @@ -1803,7 +1803,12 @@ int routing_control_plane_protocols_control_plane_protocol_pim_address_family_mc return CMD_WARNING_CONFIG_FAILED; } - /* TODO: Signal to redo lookups? */ + if (pim->rpf_mode != old_mode && + /* MCAST_MIX_MRIB_FIRST is the default if not configured */ + (old_mode != MCAST_NO_CONFIG && pim->rpf_mode != MCAST_MIX_MRIB_FIRST)) { + pim_nht_mode_changed(pim); + } + break; } diff --git a/pimd/pim_nht.h b/pimd/pim_nht.h index 0d185aad03d3..144139f406fa 100644 --- a/pimd/pim_nht.h +++ b/pimd/pim_nht.h @@ -117,6 +117,9 @@ int pim_nht_lookup_ecmp_if_vif_index(struct pim_instance *pim, pim_addr src, str /* Tracked nexthop update from zebra */ void pim_nexthop_update(struct vrf *vrf, struct prefix *match, struct zapi_route *nhr); +/* RPF lookup mode changed via configuration */ +void pim_nht_mode_changed(struct pim_instance *pim); + /* NHT init and finish funcitons */ void pim_nht_init(struct pim_instance *pim); void pim_nht_terminate(struct pim_instance *pim);