|
@@ -330,9 +330,10 @@ static void icmp_push_reply(struct icmp_bxm *icmp_param,
|
|
if (ip_append_data(sk, icmp_glue_bits, icmp_param,
|
|
if (ip_append_data(sk, icmp_glue_bits, icmp_param,
|
|
icmp_param->data_len+icmp_param->head_len,
|
|
icmp_param->data_len+icmp_param->head_len,
|
|
icmp_param->head_len,
|
|
icmp_param->head_len,
|
|
- ipc, rt, MSG_DONTWAIT) < 0)
|
|
|
|
|
|
+ ipc, rt, MSG_DONTWAIT) < 0) {
|
|
|
|
+ ICMP_INC_STATS_BH(sock_net(sk), ICMP_MIB_OUTERRORS);
|
|
ip_flush_pending_frames(sk);
|
|
ip_flush_pending_frames(sk);
|
|
- else if ((skb = skb_peek(&sk->sk_write_queue)) != NULL) {
|
|
|
|
|
|
+ } else if ((skb = skb_peek(&sk->sk_write_queue)) != NULL) {
|
|
struct icmphdr *icmph = icmp_hdr(skb);
|
|
struct icmphdr *icmph = icmp_hdr(skb);
|
|
__wsum csum = 0;
|
|
__wsum csum = 0;
|
|
struct sk_buff *skb1;
|
|
struct sk_buff *skb1;
|