|
@@ -3754,8 +3754,11 @@ struct sk_buff *sock_dequeue_err_skb(struct sock *sk)
|
|
|
|
|
|
spin_lock_irqsave(&q->lock, flags);
|
|
spin_lock_irqsave(&q->lock, flags);
|
|
skb = __skb_dequeue(q);
|
|
skb = __skb_dequeue(q);
|
|
- if (skb && (skb_next = skb_peek(q)))
|
|
|
|
|
|
+ if (skb && (skb_next = skb_peek(q))) {
|
|
icmp_next = is_icmp_err_skb(skb_next);
|
|
icmp_next = is_icmp_err_skb(skb_next);
|
|
|
|
+ if (icmp_next)
|
|
|
|
+ sk->sk_err = SKB_EXT_ERR(skb_next)->ee.ee_origin;
|
|
|
|
+ }
|
|
spin_unlock_irqrestore(&q->lock, flags);
|
|
spin_unlock_irqrestore(&q->lock, flags);
|
|
|
|
|
|
if (is_icmp_err_skb(skb) && !icmp_next)
|
|
if (is_icmp_err_skb(skb) && !icmp_next)
|