|
@@ -306,11 +306,15 @@ static inline struct sock *__udp4_lib_lookup_skb(struct sk_buff *skb,
|
|
|
__be16 sport, __be16 dport,
|
|
|
struct hlist_head udptable[])
|
|
|
{
|
|
|
+ struct sock *sk;
|
|
|
const struct iphdr *iph = ip_hdr(skb);
|
|
|
|
|
|
- return __udp4_lib_lookup(dev_net(skb->dst->dev), iph->saddr, sport,
|
|
|
- iph->daddr, dport, inet_iif(skb),
|
|
|
- udptable);
|
|
|
+ if (unlikely(sk = skb_steal_sock(skb)))
|
|
|
+ return sk;
|
|
|
+ else
|
|
|
+ return __udp4_lib_lookup(dev_net(skb->dst->dev), iph->saddr, sport,
|
|
|
+ iph->daddr, dport, inet_iif(skb),
|
|
|
+ udptable);
|
|
|
}
|
|
|
|
|
|
struct sock *udp4_lib_lookup(struct net *net, __be32 saddr, __be16 sport,
|