|
@@ -228,10 +228,15 @@ void tcp_select_initial_window(int __space, __u32 mss,
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- /* Set initial window to value enough for senders, following RFC5681. */
|
|
|
+ /* Set initial window to a value enough for senders starting with
|
|
|
+ * initial congestion window of TCP_DEFAULT_INIT_RCVWND. Place
|
|
|
+ * a limit on the initial window when mss is larger than 1460.
|
|
|
+ */
|
|
|
if (mss > (1 << *rcv_wscale)) {
|
|
|
- int init_cwnd = rfc3390_bytes_to_packets(mss);
|
|
|
-
|
|
|
+ int init_cwnd = TCP_DEFAULT_INIT_RCVWND;
|
|
|
+ if (mss > 1460)
|
|
|
+ init_cwnd =
|
|
|
+ max_t(u32, (1460 * TCP_DEFAULT_INIT_RCVWND) / mss, 2);
|
|
|
/* when initializing use the value from init_rcv_wnd
|
|
|
* rather than the default from above
|
|
|
*/
|