diff options
-rw-r--r-- | include/net/ipv6.h | 1 | ||||
-rw-r--r-- | net/ipv6/addrconf.c | 3 | ||||
-rw-r--r-- | net/ipv6/addrconf_core.c | 2 | ||||
-rw-r--r-- | net/ipv6/route.c | 2 |
4 files changed, 3 insertions, 5 deletions
diff --git a/include/net/ipv6.h b/include/net/ipv6.h index d067db1f88c7..e72fb10ce573 100644 --- a/include/net/ipv6.h +++ b/include/net/ipv6.h | |||
@@ -73,7 +73,6 @@ | |||
73 | #define IPV6_ADDR_SCOPE_MASK 0x00f0U | 73 | #define IPV6_ADDR_SCOPE_MASK 0x00f0U |
74 | 74 | ||
75 | #define IPV6_ADDR_MAPPED 0x1000U | 75 | #define IPV6_ADDR_MAPPED 0x1000U |
76 | #define IPV6_ADDR_RESERVED 0x2000U /* reserved address space */ | ||
77 | 76 | ||
78 | /* | 77 | /* |
79 | * Addr scopes | 78 | * Addr scopes |
diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c index 1b327f15e7e7..88fd8c5877ee 100644 --- a/net/ipv6/addrconf.c +++ b/net/ipv6/addrconf.c | |||
@@ -992,8 +992,7 @@ struct ipv6_saddr_dst { | |||
992 | 992 | ||
993 | static inline int ipv6_saddr_preferred(int type) | 993 | static inline int ipv6_saddr_preferred(int type) |
994 | { | 994 | { |
995 | if (type & (IPV6_ADDR_MAPPED|IPV6_ADDR_COMPATv4| | 995 | if (type & (IPV6_ADDR_MAPPED|IPV6_ADDR_COMPATv4|IPV6_ADDR_LOOPBACK)) |
996 | IPV6_ADDR_LOOPBACK|IPV6_ADDR_RESERVED)) | ||
997 | return 1; | 996 | return 1; |
998 | return 0; | 997 | return 0; |
999 | } | 998 | } |
diff --git a/net/ipv6/addrconf_core.c b/net/ipv6/addrconf_core.c index 3f82e9542eda..6b03826552e1 100644 --- a/net/ipv6/addrconf_core.c +++ b/net/ipv6/addrconf_core.c | |||
@@ -72,7 +72,7 @@ int __ipv6_addr_type(const struct in6_addr *addr) | |||
72 | IPV6_ADDR_SCOPE_TYPE(IPV6_ADDR_SCOPE_GLOBAL)); /* addr-select 3.3 */ | 72 | IPV6_ADDR_SCOPE_TYPE(IPV6_ADDR_SCOPE_GLOBAL)); /* addr-select 3.3 */ |
73 | } | 73 | } |
74 | 74 | ||
75 | return (IPV6_ADDR_RESERVED | | 75 | return (IPV6_ADDR_UNICAST | |
76 | IPV6_ADDR_SCOPE_TYPE(IPV6_ADDR_SCOPE_GLOBAL)); /* addr-select 3.4 */ | 76 | IPV6_ADDR_SCOPE_TYPE(IPV6_ADDR_SCOPE_GLOBAL)); /* addr-select 3.4 */ |
77 | } | 77 | } |
78 | EXPORT_SYMBOL(__ipv6_addr_type); | 78 | EXPORT_SYMBOL(__ipv6_addr_type); |
diff --git a/net/ipv6/route.c b/net/ipv6/route.c index 88c0a5c49ae8..b08879e97f22 100644 --- a/net/ipv6/route.c +++ b/net/ipv6/route.c | |||
@@ -1873,7 +1873,7 @@ static int ip6_pkt_drop(struct sk_buff *skb, u8 code, int ipstats_mib_noroutes) | |||
1873 | switch (ipstats_mib_noroutes) { | 1873 | switch (ipstats_mib_noroutes) { |
1874 | case IPSTATS_MIB_INNOROUTES: | 1874 | case IPSTATS_MIB_INNOROUTES: |
1875 | type = ipv6_addr_type(&ipv6_hdr(skb)->daddr); | 1875 | type = ipv6_addr_type(&ipv6_hdr(skb)->daddr); |
1876 | if (type == IPV6_ADDR_ANY || type == IPV6_ADDR_RESERVED) { | 1876 | if (type == IPV6_ADDR_ANY) { |
1877 | IP6_INC_STATS(dev_net(dst->dev), ip6_dst_idev(dst), | 1877 | IP6_INC_STATS(dev_net(dst->dev), ip6_dst_idev(dst), |
1878 | IPSTATS_MIB_INADDRERRORS); | 1878 | IPSTATS_MIB_INADDRERRORS); |
1879 | break; | 1879 | break; |