diff options
Diffstat (limited to 'net/ipv6/tcp_ipv6.c')
-rw-r--r-- | net/ipv6/tcp_ipv6.c | 25 |
1 files changed, 6 insertions, 19 deletions
diff --git a/net/ipv6/tcp_ipv6.c b/net/ipv6/tcp_ipv6.c index 4a4e6d30c448..078e7d0f4cd8 100644 --- a/net/ipv6/tcp_ipv6.c +++ b/net/ipv6/tcp_ipv6.c | |||
@@ -633,8 +633,7 @@ clear_hash_noput: | |||
633 | return 1; | 633 | return 1; |
634 | } | 634 | } |
635 | 635 | ||
636 | static int __tcp_v6_inbound_md5_hash(struct sock *sk, | 636 | static bool tcp_v6_inbound_md5_hash(struct sock *sk, const struct sk_buff *skb) |
637 | const struct sk_buff *skb) | ||
638 | { | 637 | { |
639 | const __u8 *hash_location = NULL; | 638 | const __u8 *hash_location = NULL; |
640 | struct tcp_md5sig_key *hash_expected; | 639 | struct tcp_md5sig_key *hash_expected; |
@@ -648,16 +647,16 @@ static int __tcp_v6_inbound_md5_hash(struct sock *sk, | |||
648 | 647 | ||
649 | /* We've parsed the options - do we have a hash? */ | 648 | /* We've parsed the options - do we have a hash? */ |
650 | if (!hash_expected && !hash_location) | 649 | if (!hash_expected && !hash_location) |
651 | return 0; | 650 | return false; |
652 | 651 | ||
653 | if (hash_expected && !hash_location) { | 652 | if (hash_expected && !hash_location) { |
654 | NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_TCPMD5NOTFOUND); | 653 | NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_TCPMD5NOTFOUND); |
655 | return 1; | 654 | return true; |
656 | } | 655 | } |
657 | 656 | ||
658 | if (!hash_expected && hash_location) { | 657 | if (!hash_expected && hash_location) { |
659 | NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_TCPMD5UNEXPECTED); | 658 | NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_TCPMD5UNEXPECTED); |
660 | return 1; | 659 | return true; |
661 | } | 660 | } |
662 | 661 | ||
663 | /* check the signature */ | 662 | /* check the signature */ |
@@ -670,22 +669,10 @@ static int __tcp_v6_inbound_md5_hash(struct sock *sk, | |||
670 | genhash ? "failed" : "mismatch", | 669 | genhash ? "failed" : "mismatch", |
671 | &ip6h->saddr, ntohs(th->source), | 670 | &ip6h->saddr, ntohs(th->source), |
672 | &ip6h->daddr, ntohs(th->dest)); | 671 | &ip6h->daddr, ntohs(th->dest)); |
673 | return 1; | 672 | return true; |
674 | } | 673 | } |
675 | return 0; | 674 | return false; |
676 | } | ||
677 | |||
678 | static int tcp_v6_inbound_md5_hash(struct sock *sk, const struct sk_buff *skb) | ||
679 | { | ||
680 | int ret; | ||
681 | |||
682 | rcu_read_lock(); | ||
683 | ret = __tcp_v6_inbound_md5_hash(sk, skb); | ||
684 | rcu_read_unlock(); | ||
685 | |||
686 | return ret; | ||
687 | } | 675 | } |
688 | |||
689 | #endif | 676 | #endif |
690 | 677 | ||
691 | static void tcp_v6_init_req(struct request_sock *req, struct sock *sk, | 678 | static void tcp_v6_init_req(struct request_sock *req, struct sock *sk, |