diff options
author | Mathieu Goessens <gebura@poolp.org> | 2009-06-23 15:59:45 +0100 |
---|---|---|
committer | Paul Jakma <paul@quagga.net> | 2009-06-23 15:59:45 +0100 |
commit | d13c3b4fcf802f904ef47ad82fdc9763fc704fdf (patch) | |
tree | b95426a542d8b931b731d8138b296c22ec9ac05e /zebra/zserv.c | |
parent | ba803bd51cdf3decfc740b3d7287fe51228f78fb (diff) |
[zebra] linux policy routing support with ipv6
Quagga support linux policy routing (ip route ... table $X) with zebra.conf
table $X option. It works fine on ipv4. On ipv6 the parameter is ignored
(table 0 is used).
* zebra/...: Pass appropriate table arg to rib_{add,delete}_ipv6
Diffstat (limited to 'zebra/zserv.c')
-rw-r--r-- | zebra/zserv.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/zebra/zserv.c b/zebra/zserv.c index 05380d62..a566e6d4 100644 --- a/zebra/zserv.c +++ b/zebra/zserv.c @@ -964,10 +964,10 @@ zread_ipv6_add (struct zserv *client, u_short length) api.metric = 0; if (IN6_IS_ADDR_UNSPECIFIED (&nexthop)) - rib_add_ipv6 (api.type, api.flags, &p, NULL, ifindex, 0, api.metric, + rib_add_ipv6 (api.type, api.flags, &p, NULL, ifindex, zebrad.rtm_table_default, api.metric, api.distance); else - rib_add_ipv6 (api.type, api.flags, &p, &nexthop, ifindex, 0, api.metric, + rib_add_ipv6 (api.type, api.flags, &p, &nexthop, ifindex, zebrad.rtm_table_default, api.metric, api.distance); return 0; } @@ -1030,9 +1030,9 @@ zread_ipv6_delete (struct zserv *client, u_short length) api.metric = 0; if (IN6_IS_ADDR_UNSPECIFIED (&nexthop)) - rib_delete_ipv6 (api.type, api.flags, &p, NULL, ifindex, 0); + rib_delete_ipv6 (api.type, api.flags, &p, NULL, ifindex, client->rtm_table); else - rib_delete_ipv6 (api.type, api.flags, &p, &nexthop, ifindex, 0); + rib_delete_ipv6 (api.type, api.flags, &p, &nexthop, ifindex, client->rtm_table); return 0; } |