0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2025-01-03 15:41:54 +00:00

Moved table hostcache updater to table service routines to not bother the mainloop

This commit is contained in:
Maria Matejka 2023-03-06 13:16:12 +01:00
parent 9073eda854
commit 03bfb8b59d
2 changed files with 15 additions and 9 deletions

View File

@ -2573,6 +2573,14 @@ rt_flag_handler(struct birdloop_flag_handler *fh, u32 flags)
rt_prune_table(tab); rt_prune_table(tab);
} }
if (flags & RTF_DELETE)
{
if (tab->hostcache)
rt_stop_export(&tab->hostcache->req, NULL);
rt_unlock_table(tab);
}
rt_unlock_table(tab); rt_unlock_table(tab);
} }
} }
@ -4155,16 +4163,13 @@ rt_commit(struct config *new, struct config *old)
config_add_obstacle(old); config_add_obstacle(old);
rt_lock_table(tab); rt_lock_table(tab);
if (tab->hostcache)
{
rt_stop_export(&tab->hostcache->req, NULL);
if (ev_get_list(&tab->hostcache->update) == &rt_cork.queue)
ev_postpone(&tab->hostcache->update);
}
rt_check_cork_low(tab); rt_check_cork_low(tab);
rt_unlock_table(tab);
if (tab->hostcache && ev_get_list(&tab->hostcache->update) == &rt_cork.queue)
ev_postpone(&tab->hostcache->update);
/* Force one more loop run */
birdloop_flag(tab->loop, RTF_DELETE);
RT_UNLOCK(tab); RT_UNLOCK(tab);
} }
} }
@ -4583,7 +4588,7 @@ rt_init_hostcache(struct rtable_private *tab)
hc->req = (struct rt_export_request) { hc->req = (struct rt_export_request) {
.name = mb_sprintf(tab->rp, "%s.hcu.notifier", tab->name), .name = mb_sprintf(tab->rp, "%s.hcu.notifier", tab->name),
.list = &global_work_list, .list = birdloop_event_list(tab->loop),
.trace_routes = tab->config->debug, .trace_routes = tab->config->debug,
.dump_req = hc_notify_dump_req, .dump_req = hc_notify_dump_req,
.log_state_change = hc_notify_log_state_change, .log_state_change = hc_notify_log_state_change,

View File

@ -185,6 +185,7 @@ typedef union rtable {
#define RTF_CLEANUP 1 #define RTF_CLEANUP 1
#define RTF_NHU 2 #define RTF_NHU 2
#define RTF_EXPORT 4 #define RTF_EXPORT 4
#define RTF_DELETE 8
extern struct rt_cork { extern struct rt_cork {
_Atomic uint active; _Atomic uint active;