diff --git a/nest/proto.c b/nest/proto.c index fcdedda5..0898dc36 100644 --- a/nest/proto.c +++ b/nest/proto.c @@ -880,14 +880,10 @@ channel_request_reload(struct channel *c) CD(c, "Reload requested"); - c->proto->reload_routes(c); - - /* - * Should this be done before reload_routes() hook? - * Perhaps, but routes are updated asynchronously. - */ - channel_reset_limit(c, &c->rx_limit, PLD_RX); - channel_reset_limit(c, &c->in_limit, PLD_IN); + if (c->in_keep & RIK_PREFILTER) + channel_schedule_reload(c); + else + c->proto->reload_routes(c); } const struct channel_class channel_basic = { diff --git a/proto/bgp/bgp.c b/proto/bgp/bgp.c index 36179eb8..1755c5e4 100644 --- a/proto/bgp/bgp.c +++ b/proto/bgp/bgp.c @@ -1447,12 +1447,8 @@ bgp_reload_routes(struct channel *C) struct bgp_proto *p = (void *) C->proto; struct bgp_channel *c = (void *) C; - ASSERT(p->conn && (p->route_refresh || (C->in_keep & RIK_PREFILTER))); - - if (C->in_keep & RIK_PREFILTER) - channel_schedule_reload(C); - else - bgp_schedule_packet(p->conn, c, PKT_ROUTE_REFRESH); + ASSERT(p->conn && p->route_refresh); + bgp_schedule_packet(p->conn, c, PKT_ROUTE_REFRESH); } static void