Commit 856bb832 authored by Juliusz Chroboczek's avatar Juliusz Chroboczek

Fix route expiration routines to avoid crash in edge case.

Reported by Dave Taht.
parent 0585047f
...@@ -260,9 +260,9 @@ flush_neighbour_routes(struct neighbour *neigh) ...@@ -260,9 +260,9 @@ flush_neighbour_routes(struct neighbour *neigh)
{ {
int i; int i;
for(i = 0; i < route_slots; i++) { i = 0;
while(i < route_slots) {
struct route *r; struct route *r;
again:
r = routes[i]; r = routes[i];
while(r) { while(r) {
if(r->neigh == neigh) { if(r->neigh == neigh) {
...@@ -271,6 +271,9 @@ flush_neighbour_routes(struct neighbour *neigh) ...@@ -271,6 +271,9 @@ flush_neighbour_routes(struct neighbour *neigh)
} }
r = r->next; r = r->next;
} }
i++;
again:
;
} }
} }
...@@ -279,9 +282,9 @@ flush_interface_routes(struct interface *ifp, int v4only) ...@@ -279,9 +282,9 @@ flush_interface_routes(struct interface *ifp, int v4only)
{ {
int i; int i;
for(i = 0; i < route_slots; i++) { i = 0;
while(i < route_slots) {
struct route *r; struct route *r;
again:
r = routes[i]; r = routes[i];
while(r) { while(r) {
if(r->neigh->ifp == ifp && if(r->neigh->ifp == ifp &&
...@@ -291,6 +294,9 @@ flush_interface_routes(struct interface *ifp, int v4only) ...@@ -291,6 +294,9 @@ flush_interface_routes(struct interface *ifp, int v4only)
} }
r = r->next; r = r->next;
} }
i++;
again:
;
} }
} }
...@@ -983,8 +989,8 @@ expire_routes(void) ...@@ -983,8 +989,8 @@ expire_routes(void)
debugf("Expiring old routes.\n"); debugf("Expiring old routes.\n");
for(i = 0; i < route_slots; i++) { i = 0;
again: while(i < route_slots) {
r = routes[i]; r = routes[i];
while(r) { while(r) {
/* Protect against clock being stepped. */ /* Protect against clock being stepped. */
...@@ -1003,5 +1009,8 @@ expire_routes(void) ...@@ -1003,5 +1009,8 @@ expire_routes(void)
} }
r = r->next; r = r->next;
} }
i++;
again:
;
} }
} }
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