mirror of
git://git.yoctoproject.org/linux-yocto.git
synced 2025-07-05 21:35:46 +02:00
ipv4: set the tcp_min_rtt_wlen range from 0 to one day
[ Upstream commit19fad20d15
] There is a UBSAN report as below: UBSAN: Undefined behaviour in net/ipv4/tcp_input.c:2877:56 signed integer overflow: 2147483647 * 1000 cannot be represented in type 'int' CPU: 3 PID: 0 Comm: swapper/3 Not tainted 5.1.0-rc4-00058-g582549e #1 Call Trace: <IRQ> dump_stack+0x8c/0xba ubsan_epilogue+0x11/0x60 handle_overflow+0x12d/0x170 ? ttwu_do_wakeup+0x21/0x320 __ubsan_handle_mul_overflow+0x12/0x20 tcp_ack_update_rtt+0x76c/0x780 tcp_clean_rtx_queue+0x499/0x14d0 tcp_ack+0x69e/0x1240 ? __wake_up_sync_key+0x2c/0x50 ? update_group_capacity+0x50/0x680 tcp_rcv_established+0x4e2/0xe10 tcp_v4_do_rcv+0x22b/0x420 tcp_v4_rcv+0xfe8/0x1190 ip_protocol_deliver_rcu+0x36/0x180 ip_local_deliver+0x15b/0x1a0 ip_rcv+0xac/0xd0 __netif_receive_skb_one_core+0x7f/0xb0 __netif_receive_skb+0x33/0xc0 netif_receive_skb_internal+0x84/0x1c0 napi_gro_receive+0x2a0/0x300 receive_buf+0x3d4/0x2350 ? detach_buf_split+0x159/0x390 virtnet_poll+0x198/0x840 ? reweight_entity+0x243/0x4b0 net_rx_action+0x25c/0x770 __do_softirq+0x19b/0x66d irq_exit+0x1eb/0x230 do_IRQ+0x7a/0x150 common_interrupt+0xf/0xf </IRQ> It can be reproduced by: echo 2147483647 > /proc/sys/net/ipv4/tcp_min_rtt_wlen Fixes:f672258391
("tcp: track min RTT using windowed min-filter") Signed-off-by: ZhangXiaoxu <zhangxiaoxu5@huawei.com> Signed-off-by: David S. Miller <davem@davemloft.net> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
617d240365
commit
d69b7c8c8a
|
@ -422,6 +422,7 @@ tcp_min_rtt_wlen - INTEGER
|
||||||
minimum RTT when it is moved to a longer path (e.g., due to traffic
|
minimum RTT when it is moved to a longer path (e.g., due to traffic
|
||||||
engineering). A longer window makes the filter more resistant to RTT
|
engineering). A longer window makes the filter more resistant to RTT
|
||||||
inflations such as transient congestion. The unit is seconds.
|
inflations such as transient congestion. The unit is seconds.
|
||||||
|
Possible values: 0 - 86400 (1 day)
|
||||||
Default: 300
|
Default: 300
|
||||||
|
|
||||||
tcp_moderate_rcvbuf - BOOLEAN
|
tcp_moderate_rcvbuf - BOOLEAN
|
||||||
|
|
|
@ -49,6 +49,7 @@ static int ip_ping_group_range_min[] = { 0, 0 };
|
||||||
static int ip_ping_group_range_max[] = { GID_T_MAX, GID_T_MAX };
|
static int ip_ping_group_range_max[] = { GID_T_MAX, GID_T_MAX };
|
||||||
static int comp_sack_nr_max = 255;
|
static int comp_sack_nr_max = 255;
|
||||||
static u32 u32_max_div_HZ = UINT_MAX / HZ;
|
static u32 u32_max_div_HZ = UINT_MAX / HZ;
|
||||||
|
static int one_day_secs = 24 * 3600;
|
||||||
|
|
||||||
/* obsolete */
|
/* obsolete */
|
||||||
static int sysctl_tcp_low_latency __read_mostly;
|
static int sysctl_tcp_low_latency __read_mostly;
|
||||||
|
@ -1151,7 +1152,9 @@ static struct ctl_table ipv4_net_table[] = {
|
||||||
.data = &init_net.ipv4.sysctl_tcp_min_rtt_wlen,
|
.data = &init_net.ipv4.sysctl_tcp_min_rtt_wlen,
|
||||||
.maxlen = sizeof(int),
|
.maxlen = sizeof(int),
|
||||||
.mode = 0644,
|
.mode = 0644,
|
||||||
.proc_handler = proc_dointvec
|
.proc_handler = proc_dointvec_minmax,
|
||||||
|
.extra1 = &zero,
|
||||||
|
.extra2 = &one_day_secs
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
.procname = "tcp_autocorking",
|
.procname = "tcp_autocorking",
|
||||||
|
|
Loading…
Reference in New Issue
Block a user