From: Eric Dumazet Date: Tue, 21 Sep 2010 21:17:29 +0000 (+0000) Subject: netfilter: tproxy: nf_tproxy_assign_sock() can handle tw sockets X-Git-Tag: upstream/snapshot3+hdmi~12792^2~73 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=d485d500cf6b13a33bc7a6c09091deea7ea603ca;p=platform%2Fadaptation%2Frenesas_rcar%2Frenesas_kernel.git netfilter: tproxy: nf_tproxy_assign_sock() can handle tw sockets transparent field of a socket is either inet_twsk(sk)->tw_transparent for timewait sockets, or inet_sk(sk)->transparent for other sockets (TCP/UDP). Signed-off-by: Eric Dumazet Acked-by: David S. Miller Signed-off-by: Patrick McHardy Signed-off-by: David S. Miller --- diff --git a/net/netfilter/nf_tproxy_core.c b/net/netfilter/nf_tproxy_core.c index 5490fc3..daab8c4 100644 --- a/net/netfilter/nf_tproxy_core.c +++ b/net/netfilter/nf_tproxy_core.c @@ -70,7 +70,11 @@ nf_tproxy_destructor(struct sk_buff *skb) int nf_tproxy_assign_sock(struct sk_buff *skb, struct sock *sk) { - if (inet_sk(sk)->transparent) { + bool transparent = (sk->sk_state == TCP_TIME_WAIT) ? + inet_twsk(sk)->tw_transparent : + inet_sk(sk)->transparent; + + if (transparent) { skb_orphan(skb); skb->sk = sk; skb->destructor = nf_tproxy_destructor;