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

Partial import reload looks working

This commit is contained in:
Katerina Kubecova 2023-10-13 09:44:16 +02:00
parent 21e7d9c5c3
commit f9e46a8e31
4 changed files with 24 additions and 23 deletions

View File

@ -496,7 +496,6 @@ trie_add_prefix(struct f_trie *t, const net_addr *net, uint l, uint h)
static int static int
trie_match_net4(const struct f_trie *t, ip4_addr px, uint plen) trie_match_net4(const struct f_trie *t, ip4_addr px, uint plen)
{ {
log("net4 compare");
if (plen == 0) if (plen == 0)
return t->zero; return t->zero;
@ -533,7 +532,6 @@ trie_match_net4(const struct f_trie *t, ip4_addr px, uint plen)
static int static int
trie_match_net6(const struct f_trie *t, ip6_addr px, uint plen) trie_match_net6(const struct f_trie *t, ip6_addr px, uint plen)
{ {
log("net6 compare");
if (plen == 0) if (plen == 0)
return t->zero; return t->zero;
@ -579,7 +577,6 @@ trie_match_net6(const struct f_trie *t, ip6_addr px, uint plen)
int int
trie_match_net(const struct f_trie *t, const net_addr *n) trie_match_net(const struct f_trie *t, const net_addr *n)
{ {
log(L_DEBUG "trie match net - types %i %i", t->ipv4, n->type);
switch (n->type) switch (n->type)
{ {
case NET_IP4: case NET_IP4:

View File

@ -58,6 +58,8 @@ static void channel_stop_export(struct channel *c);
static void channel_export_stopped(struct rt_export_request *req); static void channel_export_stopped(struct rt_export_request *req);
static void channel_refeed_stopped(struct rt_export_request *req); static void channel_refeed_stopped(struct rt_export_request *req);
static void channel_check_stopped(struct channel *c); static void channel_check_stopped(struct channel *c);
static void channel_reload_in_done(struct channel_import_request *cir);
static void channel_request_partial_reload(struct channel *c, struct channel_import_request *cir);
static inline int proto_is_done(struct proto *p) static inline int proto_is_done(struct proto *p)
{ return (p->proto_state == PS_DOWN) && proto_is_inactive(p); } { return (p->proto_state == PS_DOWN) && proto_is_inactive(p); }
@ -355,7 +357,15 @@ channel_roa_in_changed(struct settle *se)
struct channel *c = s->c; struct channel *c = s->c;
CD(c, "Reload triggered by RPKI change"); CD(c, "Reload triggered by RPKI change");
channel_request_reload(c);
struct channel_import_request *cir = lp_alloc(s->trie->lp, sizeof *cir);
*cir = (struct channel_import_request) {
.trie = s->trie,
};
if (s->trie)
cir->done = channel_reload_in_done;
channel_request_partial_reload(c, cir);
} }
static void static void
@ -371,7 +381,7 @@ channel_roa_out_changed(struct settle *se)
struct channel *c = s->c; struct channel *c = s->c;
CD(c, "Feeding triggered by RPKI change"); CD(c, "Feeding triggered by RPKI change");
/* Setup feeding request */ /* Setup feeding request */
struct channel_feeding_request *cfr = lp_alloc(s->trie->lp, sizeof *cfr); struct channel_feeding_request *cfr = lp_alloc(s->trie->lp, sizeof *cfr);
*cfr = (struct channel_feeding_request) { *cfr = (struct channel_feeding_request) {
@ -558,10 +568,6 @@ channel_start_import(struct channel *c)
.dump_req = channel_dump_import_req, .dump_req = channel_dump_import_req,
.log_state_change = channel_import_log_state_change, .log_state_change = channel_import_log_state_change,
.preimport = channel_preimport, .preimport = channel_preimport,
.prefilter = {
.mode = c->out_subprefix ? TE_ADDR_IN : TE_ADDR_NONE,
.addr = c->out_subprefix,
},
}; };
ASSERT(c->channel_state == CS_UP); ASSERT(c->channel_state == CS_UP);
@ -775,12 +781,8 @@ channel_import_prefilter(const struct rt_prefilter *p, const net_addr *n)
ASSERT_DIE(c->importing); ASSERT_DIE(c->importing);
for (struct channel_import_request *cir = c->importing; cir; cir = cir->next) for (struct channel_import_request *cir = c->importing; cir; cir = cir->next)
{ {
log(L_DEBUG "in for cycle %x %x", cir->trie, cir->trie->root);
if (!cir->trie || trie_match_net(cir->trie, n)) if (!cir->trie || trie_match_net(cir->trie, n))
{
log(L_TRACE "Export this one");
return 1; return 1;
}
} }
log(L_TRACE "%N filtered out of import", n); log(L_TRACE "%N filtered out of import", n);
return 0; return 0;
@ -838,7 +840,6 @@ channel_feed_end(struct channel *c)
void void
channel_schedule_reload(struct channel *c, struct channel_import_request *cir) channel_schedule_reload(struct channel *c, struct channel_import_request *cir)
{ {
log(L_TRACE "channel_schedule_reload %i %i",cir, (cir && cir->trie));
ASSERT(c->in_req.hook); ASSERT(c->in_req.hook);
int no_trie = 0; int no_trie = 0;
if (cir) if (cir)
@ -846,8 +847,8 @@ channel_schedule_reload(struct channel *c, struct channel_import_request *cir)
cir->next = c->import_pending; cir->next = c->import_pending;
c->import_pending = cir; c->import_pending = cir;
} }
if (c->reload_req.hook) if (c->reload_req.hook)
{ {
CD(c, "Reload triggered before the previous one has finished"); CD(c, "Reload triggered before the previous one has finished");
c->reload_pending = 1; c->reload_pending = 1;
@ -860,7 +861,7 @@ channel_schedule_reload(struct channel *c, struct channel_import_request *cir)
no_trie = 1; no_trie = 1;
last = last->next; last = last->next;
} }
c->importing = c->import_pending; c->importing = c->import_pending;
c->import_pending = NULL; c->import_pending = NULL;
@ -1129,6 +1130,12 @@ channel_stop_export(struct channel *c)
rt_stop_export(&c->out_req, channel_export_stopped); rt_stop_export(&c->out_req, channel_export_stopped);
} }
static void
channel_import_request_done_dynamic(struct channel_import_request *req)
{
mb_free(req);
}
static void static void
channel_request_reload(struct channel *c) channel_request_reload(struct channel *c)
{ {
@ -1140,6 +1147,7 @@ channel_request_reload(struct channel *c)
if ((c->in_keep & RIK_PREFILTER) == RIK_PREFILTER) { if ((c->in_keep & RIK_PREFILTER) == RIK_PREFILTER) {
struct channel_import_request* cir = mb_alloc(c->proto->pool, sizeof *cir);; struct channel_import_request* cir = mb_alloc(c->proto->pool, sizeof *cir);;
cir->trie = NULL; cir->trie = NULL;
cir->done = channel_import_request_done_dynamic;
channel_schedule_reload(c, cir); channel_schedule_reload(c, cir);
} }
else else
@ -1153,10 +1161,10 @@ channel_request_partial_reload(struct channel *c, struct channel_import_request
ASSERT(channel_reloadable(c)); ASSERT(channel_reloadable(c));
CD(c, "Partial import reload requested"); CD(c, "Partial import reload requested");
if ((c->in_keep & RIK_PREFILTER) == RIK_PREFILTER) if ((c->in_keep & RIK_PREFILTER) == RIK_PREFILTER)
channel_schedule_reload(c, cir); channel_schedule_reload(c, cir);
/* TODO*/ /* TODO */
else else
CD(c, "Partial import reload requested, but with ric cosi"); CD(c, "Partial import reload requested, but with ric cosi");
/*c->proto->reload_routes(c); /*c->proto->reload_routes(c);

View File

@ -4402,7 +4402,6 @@ rt_process_feed(struct rt_table_export_hook *c, rt_feed_block *b)
static void static void
rt_feed_by_fib(void *data) rt_feed_by_fib(void *data)
{ {
log(L_TRACE "rt_feed_by_fib_function - here filtering starts");
struct rt_table_export_hook *c = data; struct rt_table_export_hook *c = data;
struct fib_iterator *fit = &c->feed_fit; struct fib_iterator *fit = &c->feed_fit;
rt_feed_block block = {}; rt_feed_block block = {};
@ -4416,10 +4415,8 @@ rt_feed_by_fib(void *data)
{ {
if (rt_prefilter_net(&c->h.req->prefilter, n->n.addr)) if (rt_prefilter_net(&c->h.req->prefilter, n->n.addr))
{ {
log("route passed");
if (!rt_prepare_feed(c, n, &block)) if (!rt_prepare_feed(c, n, &block))
{ {
log("inside ifs");
FIB_ITERATE_PUT(fit); FIB_ITERATE_PUT(fit);
RT_UNLOCK(tab); RT_UNLOCK(tab);
rt_process_feed(c, &block); rt_process_feed(c, &block);

View File

@ -274,7 +274,6 @@ struct rt_import_request {
struct rt_import_hook *hook; /* The table part of importer */ struct rt_import_hook *hook; /* The table part of importer */
char *name; char *name;
u8 trace_routes; u8 trace_routes;
struct rt_prefilter prefilter;
event_list *list; /* Where to schedule announce events */ event_list *list; /* Where to schedule announce events */