diff options
Diffstat (limited to 'net/ipv4/route.c')
| -rw-r--r-- | net/ipv4/route.c | 22 | 
1 files changed, 13 insertions, 9 deletions
| diff --git a/net/ipv4/route.c b/net/ipv4/route.c index 727f4365bcdf..f428935c50db 100644 --- a/net/ipv4/route.c +++ b/net/ipv4/route.c @@ -295,7 +295,7 @@ static int rt_cpu_seq_show(struct seq_file *seq, void *v)  	seq_printf(seq,"%08x  %08x %08x %08x %08x %08x %08x %08x "  		   " %08x %08x %08x %08x %08x %08x %08x %08x %08x \n",  		   dst_entries_get_slow(&ipv4_dst_ops), -		   st->in_hit, +		   0, /* st->in_hit */  		   st->in_slow_tot,  		   st->in_slow_mc,  		   st->in_no_route, @@ -303,16 +303,16 @@ static int rt_cpu_seq_show(struct seq_file *seq, void *v)  		   st->in_martian_dst,  		   st->in_martian_src, -		   st->out_hit, +		   0, /* st->out_hit */  		   st->out_slow_tot,  		   st->out_slow_mc, -		   st->gc_total, -		   st->gc_ignored, -		   st->gc_goal_miss, -		   st->gc_dst_overflow, -		   st->in_hlist_search, -		   st->out_hlist_search +		   0, /* st->gc_total */ +		   0, /* st->gc_ignored */ +		   0, /* st->gc_goal_miss */ +		   0, /* st->gc_dst_overflow */ +		   0, /* st->in_hlist_search */ +		   0  /* st->out_hlist_search */  		);  	return 0;  } @@ -1036,6 +1036,10 @@ void ipv4_sk_update_pmtu(struct sk_buff *skb, struct sock *sk, u32 mtu)  	bool new = false;  	bh_lock_sock(sk); + +	if (!ip_sk_accept_pmtu(sk)) +		goto out; +  	rt = (struct rtable *) __sk_dst_get(sk);  	if (sock_owned_by_user(sk) || !rt) { @@ -2072,7 +2076,7 @@ struct rtable *__ip_route_output_key(struct net *net, struct flowi4 *fl4)  							      RT_SCOPE_LINK);  			goto make_route;  		} -		if (fl4->saddr) { +		if (!fl4->saddr) {  			if (ipv4_is_multicast(fl4->daddr))  				fl4->saddr = inet_select_addr(dev_out, 0,  							      fl4->flowi4_scope); | 
