Eric Dumazet
2dda640040
net: fix keepalive code vs TCP_FASTOPEN_CONNECT
syzkaller was able to trigger a divide by 0 in TCP stack [1]
Issue here is that keepalive timer needs to be updated to not attempt
to send a probe if the connection setup was deferred using
TCP_FASTOPEN_CONNECT socket option added in linux-4.11
[1]
divide error: 0000 [#1] SMP
CPU: 18 PID: 0 Comm: swapper/18 Not tainted
task: ffff986f62f4b040 ti: ffff986f62fa2000 task.ti: ffff986f62fa2000
RIP: 0010:[<ffffffff8409cc0d>] [<ffffffff8409cc0d>] __tcp_select_window+0x8d/0x160
Call Trace:
<IRQ>
[<ffffffff8409d951>] tcp_transmit_skb+0x11/0x20
[<ffffffff8409da21>] tcp_xmit_probe_skb+0xc1/0xe0
[<ffffffff840a0ee8>] tcp_write_wakeup+0x68/0x160
[<ffffffff840a151b>] tcp_keepalive_timer+0x17b/0x230
[<ffffffff83b3f799>] call_timer_fn+0x39/0xf0
[<ffffffff83b40797>] run_timer_softirq+0x1d7/0x280
[<ffffffff83a04ddb>] __do_softirq+0xcb/0x257
[<ffffffff83ae03ac>] irq_exit+0x9c/0xb0
[<ffffffff83a04c1a>] smp_apic_timer_interrupt+0x6a/0x80
[<ffffffff83a03eaf>] apic_timer_interrupt+0x7f/0x90
<EOI>
[<ffffffff83fed2ea>] ? cpuidle_enter_state+0x13a/0x3b0
[<ffffffff83fed2cd>] ? cpuidle_enter_state+0x11d/0x3b0
Tested:
Following packetdrill no longer crashes the kernel
`echo 0 >/proc/sys/net/ipv4/tcp_timestamps`
// Cache warmup: send a Fast Open cookie request
0 socket(..., SOCK_STREAM, IPPROTO_TCP) = 3
+0 fcntl(3, F_SETFL, O_RDWR|O_NONBLOCK) = 0
+0 setsockopt(3, SOL_TCP, TCP_FASTOPEN_CONNECT, [1], 4) = 0
+0 connect(3, ..., ...) = -1 EINPROGRESS (Operation is now in progress)
+0 > S 0:0(0) <mss 1460,nop,nop,sackOK,nop,wscale 8,FO,nop,nop>
+.01 < S. 123:123(0) ack 1 win 14600 <mss 1460,nop,nop,sackOK,nop,wscale 6,FO abcd1234,nop,nop>
+0 > . 1:1(0) ack 1
+0 close(3) = 0
+0 > F. 1:1(0) ack 1
+0 < F. 1:1(0) ack 2 win 92
+0 > . 2:2(0) ack 2
+0 socket(..., SOCK_STREAM, IPPROTO_TCP) = 4
+0 fcntl(4, F_SETFL, O_RDWR|O_NONBLOCK) = 0
+0 setsockopt(4, SOL_TCP, TCP_FASTOPEN_CONNECT, [1], 4) = 0
+0 setsockopt(4, SOL_SOCKET, SO_KEEPALIVE, [1], 4) = 0
+.01 connect(4, ..., ...) = 0
+0 setsockopt(4, SOL_TCP, TCP_KEEPIDLE, [5], 4) = 0
+10 close(4) = 0
`echo 1 >/proc/sys/net/ipv4/tcp_timestamps`
Fixes: 19f6d3f3c8 ("net/tcp-fastopen: Add new API support")
Signed-off-by: Eric Dumazet <edumazet@google.com>
Reported-by: Dmitry Vyukov <dvyukov@google.com>
Cc: Wei Wang <weiwan@google.com>
Cc: Yuchung Cheng <ycheng@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2017-08-03 09:34:51 -07:00
..
2017-07-17 17:02:44 +02:00
2017-07-01 07:39:08 -07:00
2017-06-23 14:17:31 -04:00
2017-06-16 11:48:39 -04:00
2017-08-01 15:31:23 -07:00
2017-07-01 07:39:08 -07:00
2017-04-19 07:48:57 +02:00
2017-07-01 07:39:08 -07:00
2017-07-20 15:24:45 -07:00
2017-05-30 11:55:32 -04:00
2017-03-10 09:45:09 -08:00
2017-03-16 10:18:34 -07:00
2017-07-31 17:51:11 -07:00
2017-07-04 01:29:04 -07:00
2017-08-01 16:09:14 -07:00
2016-06-30 05:03:36 -04:00
2016-10-20 14:32:22 -04:00
2017-06-15 11:59:32 -04:00
2017-07-01 07:39:08 -07:00
2017-07-01 07:39:08 -07:00
2017-01-13 22:37:16 -05:00
2017-07-01 07:39:09 -07:00
2017-07-03 03:29:14 -07:00
2017-07-01 07:39:08 -07:00
2017-07-01 07:39:07 -07:00
2016-11-03 16:10:26 -04:00
2017-07-01 07:39:09 -07:00
2017-06-26 23:13:22 -04:00
2017-03-24 13:17:07 -07:00
2016-12-24 11:46:01 -08:00
2017-07-15 14:38:31 -07:00
2017-06-30 02:04:09 -04:00
2017-06-25 11:42:01 -04:00
2017-06-16 12:01:29 -04:00
2017-06-26 23:13:22 -04:00
2017-06-16 11:48:35 -04:00
2017-06-26 23:13:22 -04:00
2017-07-12 08:18:46 -07:00
2017-02-16 21:25:49 -05:00
2017-06-15 12:12:40 -04:00
2017-02-28 12:49:36 +01:00
2017-07-01 07:39:08 -07:00
2017-06-08 11:26:19 -04:00
2017-03-24 13:17:07 -07:00
2016-11-03 15:25:26 -04:00
2017-07-01 07:39:08 -07:00
2017-07-15 12:44:02 -07:00
2017-07-18 11:22:51 -07:00
2017-06-15 12:12:40 -04:00
2017-07-15 14:43:29 -07:00
2017-05-17 16:06:01 -04:00
2017-03-02 08:42:27 +01:00
2017-07-01 16:15:14 -07:00
2017-05-17 16:06:01 -04:00
2016-12-06 11:34:24 -05:00
2016-08-23 23:11:36 -07:00
2017-07-01 16:15:14 -07:00
2016-11-21 13:20:17 -05:00
2017-05-17 16:06:01 -04:00
2016-11-21 13:20:17 -05:00
2016-11-21 13:20:17 -05:00
2017-08-02 10:51:07 -07:00
2017-07-06 10:54:15 +01:00
2017-05-17 16:06:01 -04:00
2017-05-17 16:06:01 -04:00
2017-07-01 16:15:13 -07:00
2017-05-21 13:42:36 -04:00
2017-07-01 07:39:08 -07:00
2017-07-29 23:26:29 -07:00
2017-02-21 13:26:03 -05:00
2017-06-15 12:12:40 -04:00
2017-05-17 16:06:01 -04:00
2016-11-21 13:20:17 -05:00
2017-08-03 09:34:51 -07:00
2017-06-23 14:10:05 -04:00
2016-11-21 13:20:17 -05:00
2016-11-21 13:20:17 -05:00
2017-05-17 16:06:01 -04:00
2016-11-21 13:20:17 -05:00
2017-07-01 16:15:14 -07:00
2016-07-11 13:27:06 -07:00
2017-07-01 07:39:08 -07:00
2017-05-18 10:23:33 -04:00
2017-04-24 13:48:54 -04:00
2016-06-17 20:23:32 -07:00
2017-07-29 14:19:03 -07:00
2016-11-24 15:32:14 -05:00
2017-02-15 11:04:11 +01:00
2017-06-16 11:48:39 -04:00
2017-04-14 10:07:39 +02:00
2017-04-14 10:07:39 +02:00
2017-04-14 10:06:10 +02:00
2017-02-09 10:22:19 +01:00
2017-02-09 10:22:17 +01:00
2017-01-10 10:57:12 +01:00