Commit 61e76b17 authored by Jiri Bohac's avatar Jiri Bohac Committed by David S. Miller

ICMPv6: treat dest unreachable codes 5 and 6 as EACCES, not EPROTO

RFC 4443 has defined two additional codes for ICMPv6 type 1 (destination
unreachable) messages:
        5 - Source address failed ingress/egress policy
	6 - Reject route to destination

Now they are treated as protocol error and icmpv6_err_convert() converts them
to EPROTO.

RFC 4443 says:
	"Codes 5 and 6 are more informative subsets of code 1."

Treat codes 5 and 6 as code 1 (EACCES)

Btw, connect() returning -EPROTO confuses firefox, so that fallback to
other/IPv4 addresses does not work:
https://bugzilla.mozilla.org/show_bug.cgi?id=910773Signed-off-by: default avatarJiri Bohac <jbohac@suse.cz>
Acked-by: default avatarHannes Frederic Sowa <hannes@stressinduktion.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent a8787645
...@@ -115,6 +115,8 @@ struct icmp6hdr { ...@@ -115,6 +115,8 @@ struct icmp6hdr {
#define ICMPV6_NOT_NEIGHBOUR 2 #define ICMPV6_NOT_NEIGHBOUR 2
#define ICMPV6_ADDR_UNREACH 3 #define ICMPV6_ADDR_UNREACH 3
#define ICMPV6_PORT_UNREACH 4 #define ICMPV6_PORT_UNREACH 4
#define ICMPV6_POLICY_FAIL 5
#define ICMPV6_REJECT_ROUTE 6
/* /*
* Codes for Time Exceeded * Codes for Time Exceeded
......
...@@ -940,6 +940,14 @@ static const struct icmp6_err { ...@@ -940,6 +940,14 @@ static const struct icmp6_err {
.err = ECONNREFUSED, .err = ECONNREFUSED,
.fatal = 1, .fatal = 1,
}, },
{ /* POLICY_FAIL */
.err = EACCES,
.fatal = 1,
},
{ /* REJECT_ROUTE */
.err = EACCES,
.fatal = 1,
},
}; };
int icmpv6_err_convert(u8 type, u8 code, int *err) int icmpv6_err_convert(u8 type, u8 code, int *err)
...@@ -951,7 +959,7 @@ int icmpv6_err_convert(u8 type, u8 code, int *err) ...@@ -951,7 +959,7 @@ int icmpv6_err_convert(u8 type, u8 code, int *err)
switch (type) { switch (type) {
case ICMPV6_DEST_UNREACH: case ICMPV6_DEST_UNREACH:
fatal = 1; fatal = 1;
if (code <= ICMPV6_PORT_UNREACH) { if (code < ARRAY_SIZE(tab_unreach)) {
*err = tab_unreach[code].err; *err = tab_unreach[code].err;
fatal = tab_unreach[code].fatal; fatal = tab_unreach[code].fatal;
} }
......
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