summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sys/netinet/tcp_input.c11
-rw-r--r--sys/netinet/tcp_reass.c11
2 files changed, 18 insertions, 4 deletions
diff --git a/sys/netinet/tcp_input.c b/sys/netinet/tcp_input.c
index 91c90d8..c80cf8b 100644
--- a/sys/netinet/tcp_input.c
+++ b/sys/netinet/tcp_input.c
@@ -129,6 +129,11 @@ static int tcp_do_rfc3042 = 0;
SYSCTL_INT(_net_inet_tcp, OID_AUTO, rfc3042, CTLFLAG_RW,
&tcp_do_rfc3042, 0, "Enable RFC 3042 (Limited Transmit)");
+static int tcp_do_rfc3390 = 0;
+SYSCTL_INT(_net_inet_tcp, OID_AUTO, rfc3390, CTLFLAG_RW,
+ &tcp_do_rfc3390, 0,
+ "Enable RFC 3390 (Increasing TCP's Initial Congestion Window)");
+
struct inpcbhead tcb;
#define tcb6 tcb /* for KAME src sync over BSD*'s */
struct inpcbinfo tcbinfo;
@@ -2745,10 +2750,12 @@ tcp_mss(tp, offer)
* Set the slow-start flight size depending on whether this
* is a local network or not.
*/
- if ((isipv6 && in6_localaddr(&inp->in6p_faddr)) ||
+ if (tcp_do_rfc3390)
+ tp->snd_cwnd = min(4 * mss, max(2 * mss, 4380));
+ else if ((isipv6 && in6_localaddr(&inp->in6p_faddr)) ||
(!isipv6 && in_localaddr(inp->inp_faddr)))
tp->snd_cwnd = mss * ss_fltsz_local;
- else
+ else
tp->snd_cwnd = mss * ss_fltsz;
if (rt->rt_rmx.rmx_ssthresh) {
diff --git a/sys/netinet/tcp_reass.c b/sys/netinet/tcp_reass.c
index 91c90d8..c80cf8b 100644
--- a/sys/netinet/tcp_reass.c
+++ b/sys/netinet/tcp_reass.c
@@ -129,6 +129,11 @@ static int tcp_do_rfc3042 = 0;
SYSCTL_INT(_net_inet_tcp, OID_AUTO, rfc3042, CTLFLAG_RW,
&tcp_do_rfc3042, 0, "Enable RFC 3042 (Limited Transmit)");
+static int tcp_do_rfc3390 = 0;
+SYSCTL_INT(_net_inet_tcp, OID_AUTO, rfc3390, CTLFLAG_RW,
+ &tcp_do_rfc3390, 0,
+ "Enable RFC 3390 (Increasing TCP's Initial Congestion Window)");
+
struct inpcbhead tcb;
#define tcb6 tcb /* for KAME src sync over BSD*'s */
struct inpcbinfo tcbinfo;
@@ -2745,10 +2750,12 @@ tcp_mss(tp, offer)
* Set the slow-start flight size depending on whether this
* is a local network or not.
*/
- if ((isipv6 && in6_localaddr(&inp->in6p_faddr)) ||
+ if (tcp_do_rfc3390)
+ tp->snd_cwnd = min(4 * mss, max(2 * mss, 4380));
+ else if ((isipv6 && in6_localaddr(&inp->in6p_faddr)) ||
(!isipv6 && in_localaddr(inp->inp_faddr)))
tp->snd_cwnd = mss * ss_fltsz_local;
- else
+ else
tp->snd_cwnd = mss * ss_fltsz;
if (rt->rt_rmx.rmx_ssthresh) {
OpenPOWER on IntegriCloud