diff options
| author | Matthieu Boutier <boutier@pps.jussieu.fr> | 2012-01-20 15:32:16 +0100 | 
|---|---|---|
| committer | Paul Jakma <paul@quagga.net> | 2012-03-25 17:06:53 +0100 | 
| commit | ec8d8d5ba648302cf9405f1346e3760d9b9d061c (patch) | |
| tree | ec5a3e3677000458e17e941deccf9c0308ae759a /babeld | |
| parent | 6dfeb3f6cfaf89ce0e11421b48feb2965a43ffd6 (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.
Diffstat (limited to 'babeld')
| -rw-r--r-- | babeld/kernel_zebra.c | 49 | 
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; | 
