0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2025-01-05 08:31:53 +00:00

BGP refeed and reload with Adj-RIB-In/Out is done without route refresh

This commit is contained in:
Maria Matejka 2022-10-11 19:26:31 +02:00
parent c1cb2dc31c
commit fdacb89a53
3 changed files with 20 additions and 0 deletions

View File

@ -661,6 +661,7 @@ channel_schedule_reload(struct channel *c)
{ {
ASSERT(c->in_req.hook); ASSERT(c->in_req.hook);
rt_refresh_begin(&c->in_req);
rt_request_export(c->table, &c->reload_req); rt_request_export(c->table, &c->reload_req);
} }
@ -677,8 +678,13 @@ channel_reload_stopped(struct rt_export_request *req)
static void static void
channel_reload_log_state_change(struct rt_export_request *req, u8 state) channel_reload_log_state_change(struct rt_export_request *req, u8 state)
{ {
struct channel *c = SKIP_BACK(struct channel, reload_req, req);
if (state == TES_READY) if (state == TES_READY)
{
rt_refresh_end(&c->in_req);
rt_stop_export(req, channel_reload_stopped); rt_stop_export(req, channel_reload_stopped);
}
} }
static void static void

View File

@ -1464,6 +1464,12 @@ bgp_feed_begin(struct channel *C, int initial)
if (initial && p->cf->gr_mode) if (initial && p->cf->gr_mode)
c->feed_state = BFS_LOADING; c->feed_state = BFS_LOADING;
if (!initial && C->out_table)
{
c->feed_out_table = 1;
return;
}
/* It is refeed and both sides support enhanced route refresh */ /* It is refeed and both sides support enhanced route refresh */
if (!initial && p->enhanced_refresh) if (!initial && p->enhanced_refresh)
{ {
@ -1482,6 +1488,12 @@ bgp_feed_end(struct channel *C)
struct bgp_proto *p = (void *) C->proto; struct bgp_proto *p = (void *) C->proto;
struct bgp_channel *c = (void *) C; struct bgp_channel *c = (void *) C;
if (c->feed_out_table)
{
c->feed_out_table = 0;
return;
}
/* This should not happen */ /* This should not happen */
if (!p->conn) if (!p->conn)
return; return;

View File

@ -383,6 +383,8 @@ struct bgp_channel {
u8 feed_state; /* Feed state (TX) for EoR, RR packets, see BFS_* */ u8 feed_state; /* Feed state (TX) for EoR, RR packets, see BFS_* */
u8 load_state; /* Load state (RX) for EoR, RR packets, see BFS_* */ u8 load_state; /* Load state (RX) for EoR, RR packets, see BFS_* */
u8 feed_out_table; /* Refeed into out_table */
}; };
struct bgp_prefix { struct bgp_prefix {