Commit ebaa1afd authored by Juliusz Chroboczek's avatar Juliusz Chroboczek

Rewrite send_update.

parent 649ffa50
......@@ -737,7 +737,7 @@ void
send_update(struct network *net, int urgent,
const unsigned char *prefix, unsigned char plen)
{
int i;
int i, selfonly;
struct request *request;
if(prefix) {
......@@ -758,8 +758,6 @@ send_update(struct network *net, int urgent,
if(net == NULL) {
for(i = 0; i < numnets; i++) {
send_update(&nets[i], urgent, prefix, plen);
if(!nets[i].up)
continue;
}
return;
}
......@@ -767,17 +765,10 @@ send_update(struct network *net, int urgent,
if(!net->up)
return;
if(parasitic || (silent_time && now.tv_sec < reboot_time + silent_time)) {
if(prefix == NULL) {
send_self_update(net, 0);
delay_jitter(&net->update_time, &net->update_timeout,
update_interval);
} else if(find_xroute(prefix, plen)) {
buffer_update(net, prefix, plen);
}
return;
}
selfonly =
parasitic || (silent_time && now.tv_sec < reboot_time + silent_time);
if(!selfonly)
silent_time = 0;
if(prefix) {
......@@ -785,19 +776,24 @@ send_update(struct network *net, int urgent,
/* Update won't fit in current packet */
flushupdates();
}
if(!selfonly || find_xroute(prefix, plen)) {
debugf("Sending update to %s for %s.\n",
net->ifname, format_prefix(prefix, plen));
buffer_update(net, prefix, plen);
}
} else {
send_self_update(net, 0);
/* Don't send full route dumps more than ten times per second */
if(net->update_time.tv_sec > 0 &&
timeval_minus_msec(&now, &net->update_time) < 100)
return;
if(!selfonly) {
debugf("Sending update to %s for any.\n", net->ifname);
for(i = 0; i < numroutes; i++)
if(routes[i].installed)
buffer_update(net, routes[i].src->prefix, routes[i].src->plen);
buffer_update(net,
routes[i].src->prefix, routes[i].src->plen);
}
delay_jitter(&net->update_time, &net->update_timeout,
update_interval);
}
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment