提交 ceef9ab6 编写于 作者: E Eric Dumazet 提交者: David S. Miller

tcp: Namespace-ify sysctl_tcp_workaround_signed_windows

Signed-off-by: NEric Dumazet <edumazet@google.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 d06a9904
...@@ -145,6 +145,7 @@ struct netns_ipv4 { ...@@ -145,6 +145,7 @@ struct netns_ipv4 {
int sysctl_tcp_nometrics_save; int sysctl_tcp_nometrics_save;
int sysctl_tcp_moderate_rcvbuf; int sysctl_tcp_moderate_rcvbuf;
int sysctl_tcp_tso_win_divisor; int sysctl_tcp_tso_win_divisor;
int sysctl_tcp_workaround_signed_windows;
struct inet_timewait_death_row tcp_death_row; struct inet_timewait_death_row tcp_death_row;
int sysctl_max_syn_backlog; int sysctl_max_syn_backlog;
int sysctl_tcp_fastopen; int sysctl_tcp_fastopen;
......
...@@ -247,7 +247,6 @@ extern int sysctl_tcp_max_orphans; ...@@ -247,7 +247,6 @@ extern int sysctl_tcp_max_orphans;
extern long sysctl_tcp_mem[3]; extern long sysctl_tcp_mem[3];
extern int sysctl_tcp_wmem[3]; extern int sysctl_tcp_wmem[3];
extern int sysctl_tcp_rmem[3]; extern int sysctl_tcp_rmem[3];
extern int sysctl_tcp_workaround_signed_windows;
#define TCP_RACK_LOSS_DETECTION 0x1 /* Use RACK to detect losses */ #define TCP_RACK_LOSS_DETECTION 0x1 /* Use RACK to detect losses */
...@@ -1302,7 +1301,8 @@ static inline void tcp_slow_start_after_idle_check(struct sock *sk) ...@@ -1302,7 +1301,8 @@ static inline void tcp_slow_start_after_idle_check(struct sock *sk)
} }
/* Determine a window scaling and initial window to offer. */ /* Determine a window scaling and initial window to offer. */
void tcp_select_initial_window(int __space, __u32 mss, __u32 *rcv_wnd, void tcp_select_initial_window(const struct sock *sk, int __space,
__u32 mss, __u32 *rcv_wnd,
__u32 *window_clamp, int wscale_ok, __u32 *window_clamp, int wscale_ok,
__u8 *rcv_wscale, __u32 init_rcv_wnd); __u8 *rcv_wscale, __u32 init_rcv_wnd);
......
...@@ -385,7 +385,7 @@ struct sock *cookie_v4_check(struct sock *sk, struct sk_buff *skb) ...@@ -385,7 +385,7 @@ struct sock *cookie_v4_check(struct sock *sk, struct sk_buff *skb)
/* Try to redo what tcp_v4_send_synack did. */ /* Try to redo what tcp_v4_send_synack did. */
req->rsk_window_clamp = tp->window_clamp ? :dst_metric(&rt->dst, RTAX_WINDOW); req->rsk_window_clamp = tp->window_clamp ? :dst_metric(&rt->dst, RTAX_WINDOW);
tcp_select_initial_window(tcp_full_space(sk), req->mss, tcp_select_initial_window(sk, tcp_full_space(sk), req->mss,
&req->rsk_rcv_wnd, &req->rsk_window_clamp, &req->rsk_rcv_wnd, &req->rsk_window_clamp,
ireq->wscale_ok, &rcv_wscale, ireq->wscale_ok, &rcv_wscale,
dst_metric(&rt->dst, RTAX_INITRWND)); dst_metric(&rt->dst, RTAX_INITRWND));
......
...@@ -457,13 +457,6 @@ static struct ctl_table ipv4_table[] = { ...@@ -457,13 +457,6 @@ static struct ctl_table ipv4_table[] = {
.maxlen = TCP_CA_NAME_MAX, .maxlen = TCP_CA_NAME_MAX,
.proc_handler = proc_tcp_congestion_control, .proc_handler = proc_tcp_congestion_control,
}, },
{
.procname = "tcp_workaround_signed_windows",
.data = &sysctl_tcp_workaround_signed_windows,
.maxlen = sizeof(int),
.mode = 0644,
.proc_handler = proc_dointvec
},
{ {
.procname = "tcp_limit_output_bytes", .procname = "tcp_limit_output_bytes",
.data = &sysctl_tcp_limit_output_bytes, .data = &sysctl_tcp_limit_output_bytes,
...@@ -1145,6 +1138,13 @@ static struct ctl_table ipv4_net_table[] = { ...@@ -1145,6 +1138,13 @@ static struct ctl_table ipv4_net_table[] = {
.mode = 0644, .mode = 0644,
.proc_handler = proc_dointvec, .proc_handler = proc_dointvec,
}, },
{
.procname = "tcp_workaround_signed_windows",
.data = &init_net.ipv4.sysctl_tcp_workaround_signed_windows,
.maxlen = sizeof(int),
.mode = 0644,
.proc_handler = proc_dointvec
},
{ } { }
}; };
......
...@@ -369,7 +369,7 @@ void tcp_openreq_init_rwin(struct request_sock *req, ...@@ -369,7 +369,7 @@ void tcp_openreq_init_rwin(struct request_sock *req,
full_space = rcv_wnd * mss; full_space = rcv_wnd * mss;
/* tcp_full_space because it is guaranteed to be the first packet */ /* tcp_full_space because it is guaranteed to be the first packet */
tcp_select_initial_window(full_space, tcp_select_initial_window(sk_listener, full_space,
mss - (ireq->tstamp_ok ? TCPOLEN_TSTAMP_ALIGNED : 0), mss - (ireq->tstamp_ok ? TCPOLEN_TSTAMP_ALIGNED : 0),
&req->rsk_rcv_wnd, &req->rsk_rcv_wnd,
&req->rsk_window_clamp, &req->rsk_window_clamp,
......
...@@ -45,11 +45,6 @@ ...@@ -45,11 +45,6 @@
#include <trace/events/tcp.h> #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 */ /* Default TSQ limit of four TSO segments */
int sysctl_tcp_limit_output_bytes __read_mostly = 262144; int sysctl_tcp_limit_output_bytes __read_mostly = 262144;
...@@ -196,7 +191,7 @@ u32 tcp_default_init_rwnd(u32 mss) ...@@ -196,7 +191,7 @@ u32 tcp_default_init_rwnd(u32 mss)
* be a multiple of mss if possible. We assume here that mss >= 1. * be a multiple of mss if possible. We assume here that mss >= 1.
* This MUST be enforced by all callers. * 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, __u32 *rcv_wnd, __u32 *window_clamp,
int wscale_ok, __u8 *rcv_wscale, int wscale_ok, __u8 *rcv_wscale,
__u32 init_rcv_wnd) __u32 init_rcv_wnd)
...@@ -220,7 +215,7 @@ void tcp_select_initial_window(int __space, __u32 mss, ...@@ -220,7 +215,7 @@ void tcp_select_initial_window(int __space, __u32 mss,
* which we interpret as a sign the remote TCP is not * which we interpret as a sign the remote TCP is not
* misinterpreting the window field as a signed quantity. * 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); (*rcv_wnd) = min(space, MAX_TCP_WINDOW);
else else
(*rcv_wnd) = space; (*rcv_wnd) = space;
...@@ -280,7 +275,8 @@ static u16 tcp_select_window(struct sock *sk) ...@@ -280,7 +275,8 @@ static u16 tcp_select_window(struct sock *sk)
/* Make sure we do not exceed the maximum possible /* Make sure we do not exceed the maximum possible
* scaled window. * 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); new_win = min(new_win, MAX_TCP_WINDOW);
else else
new_win = min(new_win, (65535U << tp->rx_opt.rcv_wscale)); new_win = min(new_win, (65535U << tp->rx_opt.rcv_wscale));
...@@ -3349,7 +3345,7 @@ static void tcp_connect_init(struct sock *sk) ...@@ -3349,7 +3345,7 @@ static void tcp_connect_init(struct sock *sk)
if (rcv_wnd == 0) if (rcv_wnd == 0)
rcv_wnd = dst_metric(dst, RTAX_INITRWND); 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->advmss - (tp->rx_opt.ts_recent_stamp ? tp->tcp_header_len - sizeof(struct tcphdr) : 0),
&tp->rcv_wnd, &tp->rcv_wnd,
&tp->window_clamp, &tp->window_clamp,
......
...@@ -244,7 +244,7 @@ struct sock *cookie_v6_check(struct sock *sk, struct sk_buff *skb) ...@@ -244,7 +244,7 @@ struct sock *cookie_v6_check(struct sock *sk, struct sk_buff *skb)
} }
req->rsk_window_clamp = tp->window_clamp ? :dst_metric(dst, RTAX_WINDOW); req->rsk_window_clamp = tp->window_clamp ? :dst_metric(dst, RTAX_WINDOW);
tcp_select_initial_window(tcp_full_space(sk), req->mss, tcp_select_initial_window(sk, tcp_full_space(sk), req->mss,
&req->rsk_rcv_wnd, &req->rsk_window_clamp, &req->rsk_rcv_wnd, &req->rsk_window_clamp,
ireq->wscale_ok, &rcv_wscale, ireq->wscale_ok, &rcv_wscale,
dst_metric(dst, RTAX_INITRWND)); dst_metric(dst, RTAX_INITRWND));
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册