aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/ipv4/ip_gre.c21
-rw-r--r--net/ipv6/ip6_gre.c14
2 files changed, 10 insertions, 25 deletions
diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c
index 0d4c3832d490..1c012cb2cb94 100644
--- a/net/ipv4/ip_gre.c
+++ b/net/ipv4/ip_gre.c
@@ -557,37 +557,34 @@ static void ipgre_err(struct sk_buff *skb, u32 info)
557 break; 557 break;
558 } 558 }
559 559
560 rcu_read_lock();
561 t = ipgre_tunnel_lookup(skb->dev, iph->daddr, iph->saddr, 560 t = ipgre_tunnel_lookup(skb->dev, iph->daddr, iph->saddr,
562 flags, key, p[1]); 561 flags, key, p[1]);
563 562
564 if (t == NULL) 563 if (t == NULL)
565 goto out; 564 return;
566 565
567 if (type == ICMP_DEST_UNREACH && code == ICMP_FRAG_NEEDED) { 566 if (type == ICMP_DEST_UNREACH && code == ICMP_FRAG_NEEDED) {
568 ipv4_update_pmtu(skb, dev_net(skb->dev), info, 567 ipv4_update_pmtu(skb, dev_net(skb->dev), info,
569 t->parms.link, 0, IPPROTO_GRE, 0); 568 t->parms.link, 0, IPPROTO_GRE, 0);
570 goto out; 569 return;
571 } 570 }
572 if (type == ICMP_REDIRECT) { 571 if (type == ICMP_REDIRECT) {
573 ipv4_redirect(skb, dev_net(skb->dev), t->parms.link, 0, 572 ipv4_redirect(skb, dev_net(skb->dev), t->parms.link, 0,
574 IPPROTO_GRE, 0); 573 IPPROTO_GRE, 0);
575 goto out; 574 return;
576 } 575 }
577 if (t->parms.iph.daddr == 0 || 576 if (t->parms.iph.daddr == 0 ||
578 ipv4_is_multicast(t->parms.iph.daddr)) 577 ipv4_is_multicast(t->parms.iph.daddr))
579 goto out; 578 return;
580 579
581 if (t->parms.iph.ttl == 0 && type == ICMP_TIME_EXCEEDED) 580 if (t->parms.iph.ttl == 0 && type == ICMP_TIME_EXCEEDED)
582 goto out; 581 return;
583 582
584 if (time_before(jiffies, t->err_time + IPTUNNEL_ERR_TIMEO)) 583 if (time_before(jiffies, t->err_time + IPTUNNEL_ERR_TIMEO))
585 t->err_count++; 584 t->err_count++;
586 else 585 else
587 t->err_count = 1; 586 t->err_count = 1;
588 t->err_time = jiffies; 587 t->err_time = jiffies;
589out:
590 rcu_read_unlock();
591} 588}
592 589
593static inline void ipgre_ecn_decapsulate(const struct iphdr *iph, struct sk_buff *skb) 590static inline void ipgre_ecn_decapsulate(const struct iphdr *iph, struct sk_buff *skb)
@@ -625,7 +622,7 @@ static int ipgre_rcv(struct sk_buff *skb)
625 __be16 gre_proto; 622 __be16 gre_proto;
626 623
627 if (!pskb_may_pull(skb, 16)) 624 if (!pskb_may_pull(skb, 16))
628 goto drop_nolock; 625 goto drop;
629 626
630 iph = ip_hdr(skb); 627 iph = ip_hdr(skb);
631 h = skb->data; 628 h = skb->data;
@@ -636,7 +633,7 @@ static int ipgre_rcv(struct sk_buff *skb)
636 - We do not support routing headers. 633 - We do not support routing headers.
637 */ 634 */
638 if (flags&(GRE_VERSION|GRE_ROUTING)) 635 if (flags&(GRE_VERSION|GRE_ROUTING))
639 goto drop_nolock; 636 goto drop;
640 637
641 if (flags&GRE_CSUM) { 638 if (flags&GRE_CSUM) {
642 switch (skb->ip_summed) { 639 switch (skb->ip_summed) {
@@ -664,7 +661,6 @@ static int ipgre_rcv(struct sk_buff *skb)
664 661
665 gre_proto = *(__be16 *)(h + 2); 662 gre_proto = *(__be16 *)(h + 2);
666 663
667 rcu_read_lock();
668 tunnel = ipgre_tunnel_lookup(skb->dev, 664 tunnel = ipgre_tunnel_lookup(skb->dev,
669 iph->saddr, iph->daddr, flags, key, 665 iph->saddr, iph->daddr, flags, key,
670 gre_proto); 666 gre_proto);
@@ -740,14 +736,11 @@ static int ipgre_rcv(struct sk_buff *skb)
740 736
741 netif_rx(skb); 737 netif_rx(skb);
742 738
743 rcu_read_unlock();
744 return 0; 739 return 0;
745 } 740 }
746 icmp_send(skb, ICMP_DEST_UNREACH, ICMP_PORT_UNREACH, 0); 741 icmp_send(skb, ICMP_DEST_UNREACH, ICMP_PORT_UNREACH, 0);
747 742
748drop: 743drop:
749 rcu_read_unlock();
750drop_nolock:
751 kfree_skb(skb); 744 kfree_skb(skb);
752 return 0; 745 return 0;
753} 746}
diff --git a/net/ipv6/ip6_gre.c b/net/ipv6/ip6_gre.c
index 424d11a4e7ff..b987d4db790f 100644
--- a/net/ipv6/ip6_gre.c
+++ b/net/ipv6/ip6_gre.c
@@ -437,14 +437,12 @@ static void ip6gre_err(struct sk_buff *skb, struct inet6_skb_parm *opt,
437 ipv6h = (const struct ipv6hdr *)skb->data; 437 ipv6h = (const struct ipv6hdr *)skb->data;
438 p = (__be16 *)(skb->data + offset); 438 p = (__be16 *)(skb->data + offset);
439 439
440 rcu_read_lock();
441
442 t = ip6gre_tunnel_lookup(skb->dev, &ipv6h->daddr, &ipv6h->saddr, 440 t = ip6gre_tunnel_lookup(skb->dev, &ipv6h->daddr, &ipv6h->saddr,
443 flags & GRE_KEY ? 441 flags & GRE_KEY ?
444 *(((__be32 *)p) + (grehlen / 4) - 1) : 0, 442 *(((__be32 *)p) + (grehlen / 4) - 1) : 0,
445 p[1]); 443 p[1]);
446 if (t == NULL) 444 if (t == NULL)
447 goto out; 445 return;
448 446
449 switch (type) { 447 switch (type) {
450 __u32 teli; 448 __u32 teli;
@@ -489,8 +487,6 @@ static void ip6gre_err(struct sk_buff *skb, struct inet6_skb_parm *opt,
489 else 487 else
490 t->err_count = 1; 488 t->err_count = 1;
491 t->err_time = jiffies; 489 t->err_time = jiffies;
492out:
493 rcu_read_unlock();
494} 490}
495 491
496static inline void ip6gre_ecn_decapsulate_ipv4(const struct ip6_tnl *t, 492static inline void ip6gre_ecn_decapsulate_ipv4(const struct ip6_tnl *t,
@@ -528,7 +524,7 @@ static int ip6gre_rcv(struct sk_buff *skb)
528 __be16 gre_proto; 524 __be16 gre_proto;
529 525
530 if (!pskb_may_pull(skb, sizeof(struct in6_addr))) 526 if (!pskb_may_pull(skb, sizeof(struct in6_addr)))
531 goto drop_nolock; 527 goto drop;
532 528
533 ipv6h = ipv6_hdr(skb); 529 ipv6h = ipv6_hdr(skb);
534 h = skb->data; 530 h = skb->data;
@@ -539,7 +535,7 @@ static int ip6gre_rcv(struct sk_buff *skb)
539 - We do not support routing headers. 535 - We do not support routing headers.
540 */ 536 */
541 if (flags&(GRE_VERSION|GRE_ROUTING)) 537 if (flags&(GRE_VERSION|GRE_ROUTING))
542 goto drop_nolock; 538 goto drop;
543 539
544 if (flags&GRE_CSUM) { 540 if (flags&GRE_CSUM) {
545 switch (skb->ip_summed) { 541 switch (skb->ip_summed) {
@@ -567,7 +563,6 @@ static int ip6gre_rcv(struct sk_buff *skb)
567 563
568 gre_proto = *(__be16 *)(h + 2); 564 gre_proto = *(__be16 *)(h + 2);
569 565
570 rcu_read_lock();
571 tunnel = ip6gre_tunnel_lookup(skb->dev, 566 tunnel = ip6gre_tunnel_lookup(skb->dev,
572 &ipv6h->saddr, &ipv6h->daddr, key, 567 &ipv6h->saddr, &ipv6h->daddr, key,
573 gre_proto); 568 gre_proto);
@@ -646,14 +641,11 @@ static int ip6gre_rcv(struct sk_buff *skb)
646 641
647 netif_rx(skb); 642 netif_rx(skb);
648 643
649 rcu_read_unlock();
650 return 0; 644 return 0;
651 } 645 }
652 icmpv6_send(skb, ICMPV6_DEST_UNREACH, ICMPV6_PORT_UNREACH, 0); 646 icmpv6_send(skb, ICMPV6_DEST_UNREACH, ICMPV6_PORT_UNREACH, 0);
653 647
654drop: 648drop:
655 rcu_read_unlock();
656drop_nolock:
657 kfree_skb(skb); 649 kfree_skb(skb);
658 return 0; 650 return 0;
659} 651}