]> Pileus Git - ~andy/linux/blobdiff - net/core/skbuff.c
Merge branch 'for-linus' of git://neil.brown.name/md
[~andy/linux] / net / core / skbuff.c
index 7ebeed0a877cf4bb244d488346e745d45da93959..46cbd28f40f9698bfbfad886047223c4bba16df2 100644 (file)
@@ -57,6 +57,7 @@
 #include <linux/init.h>
 #include <linux/scatterlist.h>
 #include <linux/errqueue.h>
+#include <linux/prefetch.h>
 
 #include <net/protocol.h>
 #include <net/dst.h>
@@ -2993,6 +2994,9 @@ int sock_queue_err_skb(struct sock *sk, struct sk_buff *skb)
        skb->destructor = sock_rmem_free;
        atomic_add(skb->truesize, &sk->sk_rmem_alloc);
 
+       /* before exiting rcu section, make sure dst is refcounted */
+       skb_dst_force(skb);
+
        skb_queue_tail(&sk->sk_error_queue, skb);
        if (!sock_flag(sk, SOCK_DEAD))
                sk->sk_data_ready(sk, skb->len);