diff options
author | Eric Dumazet <edumazet@google.com> | 2014-02-20 10:09:18 -0800 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-02-22 00:05:21 -0500 |
commit | f5ddcbbb40aa0ba7fbfe22355d287603dbeeaaac (patch) | |
tree | 891b56a6481cf19747018c832be557613e5b5a02 /include/net/tcp.h | |
parent | 68ad785c007246490b220ae958b544671339059b (diff) | |
download | lwn-f5ddcbbb40aa0ba7fbfe22355d287603dbeeaaac.tar.gz lwn-f5ddcbbb40aa0ba7fbfe22355d287603dbeeaaac.zip |
net-tcp: fastopen: fix high order allocations
This patch fixes two bugs in fastopen :
1) The tcp_sendmsg(..., @size) argument was ignored.
Code was relying on user not fooling the kernel with iovec mismatches
2) When MTU is about 64KB, tcp_send_syn_data() attempts order-5
allocations, which are likely to fail when memory gets fragmented.
Fixes: 783237e8daf13 ("net-tcp: Fast Open client - sending SYN-data")
Signed-off-by: Eric Dumazet <edumazet@google.com>
Cc: Yuchung Cheng <ycheng@google.com>
Acked-by: Yuchung Cheng <ycheng@google.com>
Tested-by: Yuchung Cheng <ycheng@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/net/tcp.h')
-rw-r--r-- | include/net/tcp.h | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/include/net/tcp.h b/include/net/tcp.h index 56fc366da6d5..8c4dd63134d4 100644 --- a/include/net/tcp.h +++ b/include/net/tcp.h @@ -1303,7 +1303,8 @@ struct tcp_fastopen_request { /* Fast Open cookie. Size 0 means a cookie request */ struct tcp_fastopen_cookie cookie; struct msghdr *data; /* data in MSG_FASTOPEN */ - u16 copied; /* queued in tcp_connect() */ + size_t size; + int copied; /* queued in tcp_connect() */ }; void tcp_free_fastopen_req(struct tcp_sock *tp); |