tcp: Namespace-ify sysctl_tcp_workaround_signed_windows
Signed-off-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:

committed by
David S. Miller

parent
d06a990458
commit
ceef9ab6be
@@ -45,11 +45,6 @@
|
||||
|
||||
#include <trace/events/tcp.h>
|
||||
|
||||
/* People can turn this on to work with those rare, broken TCPs that
|
||||
* interpret the window field as a signed quantity.
|
||||
*/
|
||||
int sysctl_tcp_workaround_signed_windows __read_mostly = 0;
|
||||
|
||||
/* Default TSQ limit of four TSO segments */
|
||||
int sysctl_tcp_limit_output_bytes __read_mostly = 262144;
|
||||
|
||||
@@ -196,7 +191,7 @@ u32 tcp_default_init_rwnd(u32 mss)
|
||||
* be a multiple of mss if possible. We assume here that mss >= 1.
|
||||
* This MUST be enforced by all callers.
|
||||
*/
|
||||
void tcp_select_initial_window(int __space, __u32 mss,
|
||||
void tcp_select_initial_window(const struct sock *sk, int __space, __u32 mss,
|
||||
__u32 *rcv_wnd, __u32 *window_clamp,
|
||||
int wscale_ok, __u8 *rcv_wscale,
|
||||
__u32 init_rcv_wnd)
|
||||
@@ -220,7 +215,7 @@ void tcp_select_initial_window(int __space, __u32 mss,
|
||||
* which we interpret as a sign the remote TCP is not
|
||||
* misinterpreting the window field as a signed quantity.
|
||||
*/
|
||||
if (sysctl_tcp_workaround_signed_windows)
|
||||
if (sock_net(sk)->ipv4.sysctl_tcp_workaround_signed_windows)
|
||||
(*rcv_wnd) = min(space, MAX_TCP_WINDOW);
|
||||
else
|
||||
(*rcv_wnd) = space;
|
||||
@@ -280,7 +275,8 @@ static u16 tcp_select_window(struct sock *sk)
|
||||
/* Make sure we do not exceed the maximum possible
|
||||
* scaled window.
|
||||
*/
|
||||
if (!tp->rx_opt.rcv_wscale && sysctl_tcp_workaround_signed_windows)
|
||||
if (!tp->rx_opt.rcv_wscale &&
|
||||
sock_net(sk)->ipv4.sysctl_tcp_workaround_signed_windows)
|
||||
new_win = min(new_win, MAX_TCP_WINDOW);
|
||||
else
|
||||
new_win = min(new_win, (65535U << tp->rx_opt.rcv_wscale));
|
||||
@@ -3349,7 +3345,7 @@ static void tcp_connect_init(struct sock *sk)
|
||||
if (rcv_wnd == 0)
|
||||
rcv_wnd = dst_metric(dst, RTAX_INITRWND);
|
||||
|
||||
tcp_select_initial_window(tcp_full_space(sk),
|
||||
tcp_select_initial_window(sk, tcp_full_space(sk),
|
||||
tp->advmss - (tp->rx_opt.ts_recent_stamp ? tp->tcp_header_len - sizeof(struct tcphdr) : 0),
|
||||
&tp->rcv_wnd,
|
||||
&tp->window_clamp,
|
||||
|
Reference in New Issue
Block a user