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:
parent
d06a990458
commit
ceef9ab6be
|
@ -145,6 +145,7 @@ struct netns_ipv4 {
|
|||
int sysctl_tcp_nometrics_save;
|
||||
int sysctl_tcp_moderate_rcvbuf;
|
||||
int sysctl_tcp_tso_win_divisor;
|
||||
int sysctl_tcp_workaround_signed_windows;
|
||||
struct inet_timewait_death_row tcp_death_row;
|
||||
int sysctl_max_syn_backlog;
|
||||
int sysctl_tcp_fastopen;
|
||||
|
|
|
@ -247,7 +247,6 @@ extern int sysctl_tcp_max_orphans;
|
|||
extern long sysctl_tcp_mem[3];
|
||||
extern int sysctl_tcp_wmem[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 */
|
||||
|
||||
|
@ -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. */
|
||||
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,
|
||||
__u8 *rcv_wscale, __u32 init_rcv_wnd);
|
||||
|
||||
|
|
|
@ -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. */
|
||||
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,
|
||||
ireq->wscale_ok, &rcv_wscale,
|
||||
dst_metric(&rt->dst, RTAX_INITRWND));
|
||||
|
|
|
@ -457,13 +457,6 @@ static struct ctl_table ipv4_table[] = {
|
|||
.maxlen = TCP_CA_NAME_MAX,
|
||||
.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",
|
||||
.data = &sysctl_tcp_limit_output_bytes,
|
||||
|
@ -1145,6 +1138,13 @@ static struct ctl_table ipv4_net_table[] = {
|
|||
.mode = 0644,
|
||||
.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,
|
|||
full_space = rcv_wnd * mss;
|
||||
|
||||
/* 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),
|
||||
&req->rsk_rcv_wnd,
|
||||
&req->rsk_window_clamp,
|
||||
|
|
|
@ -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,
|
||||
|
|
|
@ -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);
|
||||
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,
|
||||
ireq->wscale_ok, &rcv_wscale,
|
||||
dst_metric(dst, RTAX_INITRWND));
|
||||
|
|
Loading…
Reference in New Issue