aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv6/ah6.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/ipv6/ah6.c')
-rw-r--r--net/ipv6/ah6.c16
1 files changed, 9 insertions, 7 deletions
diff --git a/net/ipv6/ah6.c b/net/ipv6/ah6.c
index 4eaf55072b1b..fb0d07a15e93 100644
--- a/net/ipv6/ah6.c
+++ b/net/ipv6/ah6.c
@@ -370,6 +370,7 @@ static int ah6_input(struct xfrm_state *x, struct sk_buff *skb)
370 ip6h->flow_lbl[2] = 0; 370 ip6h->flow_lbl[2] = 0;
371 ip6h->hop_limit = 0; 371 ip6h->hop_limit = 0;
372 372
373 spin_lock(&x->lock);
373 { 374 {
374 u8 auth_data[MAX_AH_AUTH_LEN]; 375 u8 auth_data[MAX_AH_AUTH_LEN];
375 376
@@ -378,14 +379,15 @@ static int ah6_input(struct xfrm_state *x, struct sk_buff *skb)
378 skb_push(skb, hdr_len); 379 skb_push(skb, hdr_len);
379 err = ah_mac_digest(ahp, skb, ah->auth_data); 380 err = ah_mac_digest(ahp, skb, ah->auth_data);
380 if (err) 381 if (err)
381 goto free_out; 382 goto unlock;
382 err = -EINVAL; 383 if (memcmp(ahp->work_icv, auth_data, ahp->icv_trunc_len))
383 if (memcmp(ahp->work_icv, auth_data, ahp->icv_trunc_len)) { 384 err = -EBADMSG;
384 LIMIT_NETDEBUG(KERN_WARNING "ipsec ah authentication error\n");
385 x->stats.integrity_failed++;
386 goto free_out;
387 }
388 } 385 }
386unlock:
387 spin_unlock(&x->lock);
388
389 if (err)
390 goto free_out;
389 391
390 skb->network_header += ah_hlen; 392 skb->network_header += ah_hlen;
391 memcpy(skb_network_header(skb), tmp_hdr, hdr_len); 393 memcpy(skb_network_header(skb), tmp_hdr, hdr_len);