diff options
Diffstat (limited to 'net/ipv6/icmp.c')
| -rw-r--r-- | net/ipv6/icmp.c | 20 | 
1 files changed, 14 insertions, 6 deletions
| diff --git a/net/ipv6/icmp.c b/net/ipv6/icmp.c index eef8d945b362..f81f59686f21 100644 --- a/net/ipv6/icmp.c +++ b/net/ipv6/icmp.c @@ -67,6 +67,7 @@  #include <net/icmp.h>  #include <net/xfrm.h>  #include <net/inet_common.h> +#include <net/dsfield.h>  #include <asm/uaccess.h> @@ -315,8 +316,10 @@ static void mip6_addr_swap(struct sk_buff *skb)  static inline void mip6_addr_swap(struct sk_buff *skb) {}  #endif -struct dst_entry *icmpv6_route_lookup(struct net *net, struct sk_buff *skb, -				      struct sock *sk, struct flowi6 *fl6) +static struct dst_entry *icmpv6_route_lookup(struct net *net, +					     struct sk_buff *skb, +					     struct sock *sk, +					     struct flowi6 *fl6)  {  	struct dst_entry *dst, *dst2;  	struct flowi6 fl2; @@ -410,7 +413,8 @@ static void icmp6_send(struct sk_buff *skb, u8 type, u8 code, __u32 info)  	 */  	addr_type = ipv6_addr_type(&hdr->daddr); -	if (ipv6_chk_addr(net, &hdr->daddr, skb->dev, 0)) +	if (ipv6_chk_addr(net, &hdr->daddr, skb->dev, 0) || +	    ipv6_anycast_destination(skb))  		saddr = &hdr->daddr;  	/* @@ -551,10 +555,13 @@ static void icmpv6_echo_reply(struct sk_buff *skb)  	struct dst_entry *dst;  	int err = 0;  	int hlimit; +	u8 tclass;  	saddr = &ipv6_hdr(skb)->daddr; -	if (!ipv6_unicast_destination(skb)) +	if (!ipv6_unicast_destination(skb) && +	    !(net->ipv6.sysctl.anycast_src_echo_reply && +	      ipv6_anycast_destination(skb)))  		saddr = NULL;  	memcpy(&tmp_hdr, icmph, sizeof(tmp_hdr)); @@ -599,8 +606,9 @@ static void icmpv6_echo_reply(struct sk_buff *skb)  	msg.offset = 0;  	msg.type = ICMPV6_ECHO_REPLY; +	tclass = ipv6_get_dsfield(ipv6_hdr(skb));  	err = ip6_append_data(sk, icmpv6_getfrag, &msg, skb->len + sizeof(struct icmp6hdr), -				sizeof(struct icmp6hdr), hlimit, np->tclass, NULL, &fl6, +				sizeof(struct icmp6hdr), hlimit, tclass, NULL, &fl6,  				(struct rt6_info *)dst, MSG_DONTWAIT,  				np->dontfrag); @@ -984,7 +992,7 @@ int icmpv6_err_convert(u8 type, u8 code, int *err)  EXPORT_SYMBOL(icmpv6_err_convert);  #ifdef CONFIG_SYSCTL -struct ctl_table ipv6_icmp_table_template[] = { +static struct ctl_table ipv6_icmp_table_template[] = {  	{  		.procname	= "ratelimit",  		.data		= &init_net.ipv6.sysctl.icmpv6_time, | 
