summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatthieu Boutier <boutier@pps.jussieu.fr>2012-01-20 15:32:16 +0100
committerPaul Jakma <paul@quagga.net>2012-03-25 17:06:53 +0100
commitec8d8d5ba648302cf9405f1346e3760d9b9d061c (patch)
treeec5a3e3677000458e17e941deccf9c0308ae759a
parent6dfeb3f6cfaf89ce0e11421b48feb2965a43ffd6 (diff)
babeld: change the modify route system.
Zebra doesn't set errno to EEXIST if we add a route who was already in the kernel, so we always returned after just doing "add; delete". This patch fix the problem by doing "delete; add" always.
-rw-r--r--babeld/kernel_zebra.c49
1 files changed, 14 insertions, 35 deletions
diff --git a/babeld/kernel_zebra.c b/babeld/kernel_zebra.c
index 82f03e43..7ddc797d 100644
--- a/babeld/kernel_zebra.c
+++ b/babeld/kernel_zebra.c
@@ -142,26 +142,7 @@ kernel_route(int operation, const unsigned char *pref, unsigned short plen,
if(newmetric == metric && memcmp(newgate, gate, 16) == 0 &&
newifindex == ifindex)
return 0;
- /* It is better to add the new route before removing the old
- one, to avoid losing packets. However, if the old and new
- priorities are equal, this only works if the kernel supports
- ECMP. So we first try the "right" order, and fall back on
- the "wrong" order if it fails with EEXIST. */
- rc = ipv4 ?
- kernel_route_add_v4(pref, plen,
- newgate, newifindex, newmetric,
- NULL, 0, 0):
- kernel_route_add_v6(pref, plen,
- newgate, newifindex, newmetric,
- NULL, 0, 0);
- if(rc < 0) {
- if(errno != EEXIST)
- return rc;
- added = 0;
- } else {
- added = 1;
- }
-
+ debugf(BABEL_DEBUG_ROUTE, "Modify route: delete old; add new.");
if (ipv4) {
kernel_route_delete_v4(pref, plen,
gate, ifindex, metric,
@@ -172,21 +153,19 @@ kernel_route(int operation, const unsigned char *pref, unsigned short plen,
NULL, 0, 0);
}
- if(!added) {
- rc = ipv4 ?
- kernel_route_add_v4(pref, plen,
- newgate, newifindex, newmetric,
- NULL, 0, 0):
- kernel_route_add_v6(pref, plen,
- newgate, newifindex, newmetric,
- NULL, 0, 0);
- if(rc < 0) {
- if(errno == EEXIST)
- rc = 1;
- /* In principle, we should try to re-install the flushed
- route on failure to preserve. However, this should
- hopefully not matter much in practice. */
- }
+ rc = ipv4 ?
+ kernel_route_add_v4(pref, plen,
+ newgate, newifindex, newmetric,
+ NULL, 0, 0):
+ kernel_route_add_v6(pref, plen,
+ newgate, newifindex, newmetric,
+ NULL, 0, 0);
+ if(rc < 0) {
+ if(errno == EEXIST)
+ rc = 1;
+ /* In principle, we should try to re-install the flushed
+ route on failure to preserve. However, this should
+ hopefully not matter much in practice. */
}
return rc;