Commit f474c8fa authored by Juliusz Chroboczek's avatar Juliusz Chroboczek

Use kernel_route(MODIFY) when updating xroutes.

parent bdc27e89
...@@ -283,6 +283,7 @@ update_xroute_metric(struct xroute *xroute, int cost) ...@@ -283,6 +283,7 @@ update_xroute_metric(struct xroute *xroute, int cost)
{ {
struct route *gwroute; struct route *gwroute;
int oldmetric, newmetric; int oldmetric, newmetric;
int rc;
gwroute = find_installed_route(xroute->gateway); gwroute = find_installed_route(xroute->gateway);
if(!gwroute) if(!gwroute)
...@@ -292,22 +293,29 @@ update_xroute_metric(struct xroute *xroute, int cost) ...@@ -292,22 +293,29 @@ update_xroute_metric(struct xroute *xroute, int cost)
newmetric = gwroute->metric + cost; newmetric = gwroute->metric + cost;
if(xroute->cost != cost || oldmetric != newmetric) { if(xroute->cost != cost || oldmetric != newmetric) {
int install = 0;
if(xroute->installed &&
metric_to_kernel(oldmetric) != metric_to_kernel(newmetric)) {
uninstall_xroute(xroute);
install = 1;
}
xroute->cost = cost; xroute->cost = cost;
if(xroute->installed) {
struct route *gwroute = find_installed_route(xroute->gateway);
if(gwroute == NULL) {
fprintf(stderr, "Found installed blackhole xroute!.\n");
return;
}
rc = kernel_route(ROUTE_MODIFY, xroute->prefix, xroute->plen,
gwroute->nexthop->address,
gwroute->nexthop->network->ifindex,
metric_to_kernel(oldmetric),
metric_to_kernel(newmetric));
if(rc < 0) {
perror("kernel_route(MODIFY)");
return;
}
}
xroute->metric = newmetric; xroute->metric = newmetric;
if(newmetric > oldmetric) { if(newmetric > oldmetric) {
struct xroute *best; struct xroute *best;
best = find_best_xroute(xroute->prefix, xroute->plen); best = find_best_xroute(xroute->prefix, xroute->plen);
if(best) if(best)
consider_xroute(best); consider_xroute(best);
} else if(install) {
install_xroute(xroute);
} }
} }
} }
......
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