-
Notifications
You must be signed in to change notification settings - Fork 1.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
babel: Clean babel related config on daemon stop #17715
Conversation
When disable and enable babel router network configurations are still present. This is an issue, cause it disrupts normal babel router usage. |
babeld/babeld.c
Outdated
@@ -310,6 +314,17 @@ void babel_clean_routing_process(void) | |||
resend_delay = BABEL_DEFAULT_RESEND_DELAY; | |||
change_smoothing_half_life(BABEL_DEFAULT_SMOOTHING_HALF_LIFE); | |||
|
|||
/* Clean babel network interfaces */ | |||
FOR_ALL_INTERFACES(vrf, ifp) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Shouldn't we do this inside babel_interface_close_all()
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
Makes sense
74fdb08
to
cfe7160
Compare
cfe7160
to
e5387fd
Compare
babeld/babel_interface.c
Outdated
interface_reset(ifp); | ||
} | ||
/* Disable babel redistribution */ | ||
for (type = 0; type < ZEBRA_ROUTE_MAX; type++) { | ||
zclient_redistribute (ZEBRA_REDISTRIBUTE_DELETE, zclient, family2afi(AF_INET), type, 0, VRF_DEFAULT); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why not directly AFI_IP
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Makes no difference to me. Fixed
babeld/babel_interface.c
Outdated
/* Disable babel redistribution */ | ||
for (type = 0; type < ZEBRA_ROUTE_MAX; type++) { | ||
zclient_redistribute (ZEBRA_REDISTRIBUTE_DELETE, zclient, family2afi(AF_INET), type, 0, VRF_DEFAULT); | ||
zclient_redistribute (ZEBRA_REDISTRIBUTE_DELETE, zclient, family2afi(AF_INET6), type, 0, VRF_DEFAULT); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why not directly AFI_IP6
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Makes no difference to me. Fixed
babeld/babel_interface.c
Outdated
@@ -719,6 +719,7 @@ babel_interface_close_all(void) | |||
{ | |||
struct vrf *vrf = vrf_lookup_by_id(VRF_DEFAULT); | |||
struct interface *ifp = NULL; | |||
int type = ZEBRA_ROUTE_ALL; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We don't need initialization here at all, because we do it inside the loop.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Cause I am afraid of uninitialized variables, regardless compiler settings
Fixed
When deactivating babel no router babel and later re-enabling it router babel the previous configuration is still in place. Steps to reproduce: Enable babel Configure babel Disable babel with "no router babel" Verify config Expected correct behavior: No config present Signed-off-by: Yaroslav Kholod <[email protected]>
e5387fd
to
a05c6af
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
When deactivating babel no router babel and later re-enabling it router babel the previous configuration is still in place.
Steps to reproduce:
Expected correct behavior: No config present