diff options
author | Vincent Bernat <vincent@bernat.im> | 2016-09-18 17:46:07 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-09-20 03:28:29 -0400 |
commit | a435a07f9164dda7c0c26e8ad758881f4bafc127 (patch) | |
tree | 4a0524e90433779f1b5a1571f2af703085f5828d /block/blk-map.c | |
parent | 7675bb2b176ea05bf4904223d760d1889f819714 (diff) | |
download | linux-a435a07f9164dda7c0c26e8ad758881f4bafc127.tar.bz2 |
net: ipv6: fallback to full lookup if table lookup is unsuitable
Commit 8c14586fc320 ("net: ipv6: Use passed in table for nexthop
lookups") introduced a regression: insertion of an IPv6 route in a table
not containing the appropriate connected route for the gateway but which
contained a non-connected route (like a default gateway) fails while it
was previously working:
$ ip link add eth0 type dummy
$ ip link set up dev eth0
$ ip addr add 2001:db8::1/64 dev eth0
$ ip route add ::/0 via 2001:db8::5 dev eth0 table 20
$ ip route add 2001:db8:cafe::1/128 via 2001:db8::6 dev eth0 table 20
RTNETLINK answers: No route to host
$ ip -6 route show table 20
default via 2001:db8::5 dev eth0 metric 1024 pref medium
After this patch, we get:
$ ip route add 2001:db8:cafe::1/128 via 2001:db8::6 dev eth0 table 20
$ ip -6 route show table 20
2001:db8:cafe::1 via 2001:db8::6 dev eth0 metric 1024 pref medium
default via 2001:db8::5 dev eth0 metric 1024 pref medium
Fixes: 8c14586fc320 ("net: ipv6: Use passed in table for nexthop lookups")
Signed-off-by: Vincent Bernat <vincent@bernat.im>
Acked-by: David Ahern <dsa@cumulusnetworks.com>
Tested-by: David Ahern <dsa@cumulusnetworks.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'block/blk-map.c')
0 files changed, 0 insertions, 0 deletions