0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2025-01-07 17:41:58 +00:00

Implement stats_reconfigure()

This commit is contained in:
Vojtech Vilimek 2022-07-15 13:33:42 +02:00
parent b53d869405
commit 3f9b92d273
2 changed files with 50 additions and 10 deletions

View File

@ -33,6 +33,7 @@ static void
stats_rt_notify(struct proto *P, struct channel *src_ch, const net_addr *n, rte *new, const rte *old) stats_rt_notify(struct proto *P, struct channel *src_ch, const net_addr *n, rte *new, const rte *old)
{ {
struct stats_proto *p = (void *) P; struct stats_proto *p = (void *) P;
struct stats_config *cf = (void *) P->cf;
log(L_INFO "stats_rf_notify()"); log(L_INFO "stats_rf_notify()");
if (new && old) if (new && old)
@ -70,9 +71,22 @@ stats_reload_routes(struct channel *C)
struct stats_proto *p = (void *) C->proto; struct stats_proto *p = (void *) C->proto;
/* Route reload on one channel is just refeed on the other */ /* Route reload on one channel is just refeed on the other */
channel_request_feeding(p->c); //channel_request_feeding(p->c);
} }
static void
stats_configure_channels(struct proto *P, struct proto_config *CF)
{
struct stats_proto *p = (void *) P;
struct stats_config *cf = (void *) CF;
struct channel_config *cc;
WALK_LIST(cc, CF->channels)
{
struct channel *c = NULL;
proto_configure_channel(P, &c, cc);
}
}
static struct proto * static struct proto *
stats_init(struct proto_config *CF) stats_init(struct proto_config *CF)
@ -88,16 +102,22 @@ stats_init(struct proto_config *CF)
p->rl_gen = (struct tbf) TBF_DEFAULT_LOG_LIMITS; p->rl_gen = (struct tbf) TBF_DEFAULT_LOG_LIMITS;
struct channel_config *cc; stats_configure_channels(P, CF);
WALK_LIST(cc, CF->channels)
{
struct channel *c = NULL;
proto_configure_channel(P, &c, cc);
}
return P; return P;
} }
static struct channel *
stats_find_channel(struct stats_proto *p, const char *name)
{
struct channel *c;
WALK_LIST(c, p->p.channels)
if (strcmp(c->name, name))
return c;
return NULL;
}
static int static int
stats_start(struct proto *P) stats_start(struct proto *P)
{ {
@ -113,9 +133,30 @@ static int
stats_reconfigure(struct proto *P, struct proto_config *CF) stats_reconfigure(struct proto *P, struct proto_config *CF)
{ {
struct stats_proto *p = (void *) P; struct stats_proto *p = (void *) P;
struct stats_config *cf = (void *) CF; struct stats_config *new = (void *) CF;
struct stats_config *old = (void *) P->cf;
log(L_INFO "stats_reconfigure()");
struct channel *c;
WALK_LIST(c, p->p.channels)
c->stale = 1;
struct channel_config *cc;
WALK_LIST(cc, new->c.channels)
{
c = (struct channel *) stats_find_channel(p, cc->name);
if (!proto_configure_channel(P, &c, cc))
return 0;
if (c)
c->stale = 0;
}
struct channel *c2;
WALK_LIST_DELSAFE(c, c2, p->p.channels)
if (c->stale && !proto_configure_channel(P, &c, NULL))
return 0;
//return stats_configure_channels(p, cf);
return 1; return 1;
} }

View File

@ -12,7 +12,6 @@
struct stats_config { struct stats_config {
struct proto_config c; struct proto_config c;
const net_addr *in_subprefix;
u8 max_generation; u8 max_generation;
}; };