Commit 8afa62b4 authored by Juliusz Chroboczek's avatar Juliusz Chroboczek

Have change_route_metric take refmetrics too.

parent f3378dab
...@@ -237,13 +237,11 @@ switch_routes(struct route *old, struct route *new) ...@@ -237,13 +237,11 @@ switch_routes(struct route *old, struct route *new)
} }
static void static void
change_route_metric(struct route *route, unsigned cost, unsigned add) change_route_metric(struct route *route,
unsigned refmetric, unsigned cost, unsigned add)
{ {
int old, new; int old, new;
int newmetric = MIN(route->refmetric + cost + add, INFINITY); int newmetric = MIN(refmetric + cost + add, INFINITY);
if(route_metric(route) == newmetric)
return;
old = metric_to_kernel(route_metric(route)); old = metric_to_kernel(route_metric(route));
new = metric_to_kernel(newmetric); new = metric_to_kernel(newmetric);
...@@ -261,6 +259,7 @@ change_route_metric(struct route *route, unsigned cost, unsigned add) ...@@ -261,6 +259,7 @@ change_route_metric(struct route *route, unsigned cost, unsigned add)
} }
} }
route->refmetric = refmetric;
route->cost = cost; route->cost = cost;
route->add_metric = add; route->add_metric = add;
local_notify_route(route, LOCAL_CHANGE); local_notify_route(route, LOCAL_CHANGE);
...@@ -269,8 +268,7 @@ change_route_metric(struct route *route, unsigned cost, unsigned add) ...@@ -269,8 +268,7 @@ change_route_metric(struct route *route, unsigned cost, unsigned add)
static void static void
retract_route(struct route *route) retract_route(struct route *route)
{ {
route->refmetric = INFINITY; change_route_metric(route, INFINITY, INFINITY, 0);
change_route_metric(route, INFINITY, 0);
} }
int int
...@@ -375,7 +373,7 @@ update_route_metric(struct route *route) ...@@ -375,7 +373,7 @@ update_route_metric(struct route *route)
route->src->prefix, route->src->plen, route->src->prefix, route->src->plen,
neigh->address, neigh->address,
neigh->network->ifindex); neigh->network->ifindex);
change_route_metric(route, change_route_metric(route, route->refmetric,
neighbour_cost(route->neigh), add_metric); neighbour_cost(route->neigh), add_metric);
if(route_metric(route) != oldmetric) if(route_metric(route) != oldmetric)
route_changed(route, route->src, oldmetric); route_changed(route, route->src, oldmetric);
...@@ -471,8 +469,8 @@ update_route(const unsigned char *a, const unsigned char *p, unsigned char plen, ...@@ -471,8 +469,8 @@ update_route(const unsigned char *a, const unsigned char *p, unsigned char plen,
if(feasible && refmetric < INFINITY) if(feasible && refmetric < INFINITY)
route->time = now.tv_sec; route->time = now.tv_sec;
route->seqno = seqno; route->seqno = seqno;
route->refmetric = refmetric; change_route_metric(route,
change_route_metric(route, neighbour_cost(neigh), add_metric); refmetric, neighbour_cost(neigh), add_metric);
route->hold_time = hold_time; route->hold_time = hold_time;
route_changed(route, oldsrc, oldmetric); route_changed(route, oldsrc, oldmetric);
......
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