diff options
| author | David S. Miller <davem@sunset.davemloft.net> | 2007-06-12 17:36:42 -0400 |
|---|---|---|
| committer | David S. Miller <davem@sunset.davemloft.net> | 2007-06-12 17:36:42 -0400 |
| commit | 3d7dbeac58d0669c37e35a3b91bb41c0146395ce (patch) | |
| tree | 8392d2e576f07635bda9684b2d65629ee40ecbab | |
| parent | 606f585e363527da9feaed79465132c0c661fd9e (diff) | |
[TCP]: Disable TSO if MD5SIG is enabled.
Signed-off-by: David S. Miller <davem@davemloft.net>
| -rw-r--r-- | net/ipv4/tcp_ipv4.c | 3 | ||||
| -rw-r--r-- | net/ipv6/tcp_ipv6.c | 2 |
2 files changed, 4 insertions, 1 deletions
diff --git a/net/ipv4/tcp_ipv4.c b/net/ipv4/tcp_ipv4.c index 97e294e82679..354721d67f69 100644 --- a/net/ipv4/tcp_ipv4.c +++ b/net/ipv4/tcp_ipv4.c | |||
| @@ -878,6 +878,7 @@ int tcp_v4_md5_do_add(struct sock *sk, __be32 addr, | |||
| 878 | kfree(newkey); | 878 | kfree(newkey); |
| 879 | return -ENOMEM; | 879 | return -ENOMEM; |
| 880 | } | 880 | } |
| 881 | sk->sk_route_caps &= ~NETIF_F_GSO_MASK; | ||
| 881 | } | 882 | } |
| 882 | if (tcp_alloc_md5sig_pool() == NULL) { | 883 | if (tcp_alloc_md5sig_pool() == NULL) { |
| 883 | kfree(newkey); | 884 | kfree(newkey); |
| @@ -1007,7 +1008,7 @@ static int tcp_v4_parse_md5_keys(struct sock *sk, char __user *optval, | |||
| 1007 | return -EINVAL; | 1008 | return -EINVAL; |
| 1008 | 1009 | ||
| 1009 | tp->md5sig_info = p; | 1010 | tp->md5sig_info = p; |
| 1010 | 1011 | sk->sk_route_caps &= ~NETIF_F_GSO_MASK; | |
| 1011 | } | 1012 | } |
| 1012 | 1013 | ||
| 1013 | newkey = kmemdup(cmd.tcpm_key, cmd.tcpm_keylen, GFP_KERNEL); | 1014 | newkey = kmemdup(cmd.tcpm_key, cmd.tcpm_keylen, GFP_KERNEL); |
diff --git a/net/ipv6/tcp_ipv6.c b/net/ipv6/tcp_ipv6.c index 4f06a51ad4fd..193d9d60bb7a 100644 --- a/net/ipv6/tcp_ipv6.c +++ b/net/ipv6/tcp_ipv6.c | |||
| @@ -590,6 +590,7 @@ static int tcp_v6_md5_do_add(struct sock *sk, struct in6_addr *peer, | |||
| 590 | kfree(newkey); | 590 | kfree(newkey); |
| 591 | return -ENOMEM; | 591 | return -ENOMEM; |
| 592 | } | 592 | } |
| 593 | sk->sk_route_caps &= ~NETIF_F_GSO_MASK; | ||
| 593 | } | 594 | } |
| 594 | tcp_alloc_md5sig_pool(); | 595 | tcp_alloc_md5sig_pool(); |
| 595 | if (tp->md5sig_info->alloced6 == tp->md5sig_info->entries6) { | 596 | if (tp->md5sig_info->alloced6 == tp->md5sig_info->entries6) { |
| @@ -724,6 +725,7 @@ static int tcp_v6_parse_md5_keys (struct sock *sk, char __user *optval, | |||
| 724 | return -ENOMEM; | 725 | return -ENOMEM; |
| 725 | 726 | ||
| 726 | tp->md5sig_info = p; | 727 | tp->md5sig_info = p; |
| 728 | sk->sk_route_caps &= ~NETIF_F_GSO_MASK; | ||
| 727 | } | 729 | } |
| 728 | 730 | ||
| 729 | newkey = kmemdup(cmd.tcpm_key, cmd.tcpm_keylen, GFP_KERNEL); | 731 | newkey = kmemdup(cmd.tcpm_key, cmd.tcpm_keylen, GFP_KERNEL); |
