Eric Dumazet
c3f9b01849
tcp: tcp_release_cb() should release socket ownership
...
Lars Persson reported following deadlock :
-000 |M:0x0:0x802B6AF8(asm) <-- arch_spin_lock
-001 |tcp_v4_rcv(skb = 0x8BD527A0) <-- sk = 0x8BE6B2A0
-002 |ip_local_deliver_finish(skb = 0x8BD527A0)
-003 |__netif_receive_skb_core(skb = 0x8BD527A0, ?)
-004 |netif_receive_skb(skb = 0x8BD527A0)
-005 |elk_poll(napi = 0x8C770500, budget = 64)
-006 |net_rx_action(?)
-007 |__do_softirq()
-008 |do_softirq()
-009 |local_bh_enable()
-010 |tcp_rcv_established(sk = 0x8BE6B2A0, skb = 0x87D3A9E0, th = 0x814EBE14, ?)
-011 |tcp_v4_do_rcv(sk = 0x8BE6B2A0, skb = 0x87D3A9E0)
-012 |tcp_delack_timer_handler(sk = 0x8BE6B2A0)
-013 |tcp_release_cb(sk = 0x8BE6B2A0)
-014 |release_sock(sk = 0x8BE6B2A0)
-015 |tcp_sendmsg(?, sk = 0x8BE6B2A0, ?, ?)
-016 |sock_sendmsg(sock = 0x8518C4C0, msg = 0x87D8DAA8, size = 4096)
-017 |kernel_sendmsg(?, ?, ?, ?, size = 4096)
-018 |smb_send_kvec()
-019 |smb_send_rqst(server = 0x87C4D400, rqst = 0x87D8DBA0)
-020 |cifs_call_async()
-021 |cifs_async_writev(wdata = 0x87FD6580)
-022 |cifs_writepages(mapping = 0x852096E4, wbc = 0x87D8DC88)
-023 |__writeback_single_inode(inode = 0x852095D0, wbc = 0x87D8DC88)
-024 |writeback_sb_inodes(sb = 0x87D6D800, wb = 0x87E4A9C0, work = 0x87D8DD88)
-025 |__writeback_inodes_wb(wb = 0x87E4A9C0, work = 0x87D8DD88)
-026 |wb_writeback(wb = 0x87E4A9C0, work = 0x87D8DD88)
-027 |wb_do_writeback(wb = 0x87E4A9C0, force_wait = 0)
-028 |bdi_writeback_workfn(work = 0x87E4A9CC)
-029 |process_one_work(worker = 0x8B045880, work = 0x87E4A9CC)
-030 |worker_thread(__worker = 0x8B045880)
-031 |kthread(_create = 0x87CADD90)
-032 |ret_from_kernel_thread(asm)
Bug occurs because __tcp_checksum_complete_user() enables BH, assuming
it is running from softirq context.
Lars trace involved a NIC without RX checksum support but other points
are problematic as well, like the prequeue stuff.
Problem is triggered by a timer, that found socket being owned by user.
tcp_release_cb() should call tcp_write_timer_handler() or
tcp_delack_timer_handler() in the appropriate context :
BH disabled and socket lock held, but 'owned' field cleared,
as if they were running from timer handlers.
Fixes: 6f458dfb4092 ("tcp: improve latencies of timer triggered events")
Reported-by: Lars Persson <lars.persson@axis.com>
Tested-by: Lars Persson <lars.persson@axis.com>
Signed-off-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2014-03-11 16:45:59 -04:00
..
2014-02-14 11:37:36 +01:00
2014-02-25 18:27:06 -05:00
2013-06-03 00:07:42 -07:00
2014-01-02 00:08:38 -05:00
2013-12-26 13:43:21 -05:00
2013-12-06 07:24:39 +01:00
2014-02-06 20:02:15 -08:00
2013-10-29 06:39:42 +01:00
2014-01-24 15:51:26 -08:00
2013-12-28 17:01:46 -05:00
2013-12-10 17:54:23 -05:00
2013-12-28 17:01:46 -05:00
2013-11-15 09:32:20 +09:00
2014-01-06 20:28:34 -05:00
2014-01-16 16:08:27 -08:00
2014-01-13 11:22:55 -08:00
2014-01-14 15:15:25 -08:00
2014-01-14 15:15:25 -08:00
2014-01-13 22:35:46 -08:00
2014-03-06 15:28:45 -05:00
2013-10-19 19:45:35 -04:00
2013-12-29 16:34:25 -05:00
2013-10-08 23:19:24 -04:00
2013-12-28 17:03:20 -05:00
2014-02-13 17:17:02 -05:00
2013-12-17 16:36:21 -05:00
2014-01-27 20:38:26 -08:00
2014-01-27 16:22:11 -08:00
2014-01-02 03:30:36 -05:00
2014-02-17 11:20:12 +01:00
2014-01-19 19:53:18 -08:00
2014-03-03 15:56:40 -05:00
2014-02-20 13:13:50 -05:00
2014-01-18 23:08:02 -08:00
2013-06-03 00:07:42 -07:00
2014-02-14 00:14:23 -05:00
2014-01-18 23:08:02 -08:00
2014-01-18 00:55:41 -08:00
2013-09-03 21:41:43 -04:00
2014-01-06 20:28:34 -05:00
2013-04-18 20:27:55 +02:00
2014-01-21 16:59:19 -08:00
2014-01-02 03:30:36 -05:00
2013-11-28 18:47:51 -05:00
2014-01-18 23:04:16 -08:00
2014-02-17 16:54:42 -05:00
2013-12-26 13:43:21 -05:00
2014-01-13 11:22:54 -08:00
2013-11-04 19:57:59 -05:00
2014-02-24 19:13:38 -05:00
2013-11-04 19:57:59 -05:00
2013-11-04 19:57:47 -05:00
2013-11-04 19:57:59 -05:00
2013-11-04 19:57:59 -05:00
2013-11-04 19:57:59 -05:00
2014-01-23 16:36:55 -08:00
2014-03-03 15:33:02 -05:00
2014-01-21 16:52:31 -08:00
2013-11-04 19:57:59 -05:00
2013-12-05 21:01:01 -05:00
2014-01-23 12:48:28 -08:00
2014-01-17 17:56:33 -08:00
2014-01-14 18:53:48 -08:00
2014-03-11 16:45:59 -04:00
2013-12-26 13:43:21 -05:00
2013-11-04 19:57:59 -05:00
2013-10-29 22:50:41 -04:00
2013-11-04 19:57:59 -05:00
2013-10-19 19:12:11 -04:00
2013-11-04 19:57:59 -05:00
2013-03-21 11:47:50 -04:00
2013-12-26 13:43:55 -05:00
2014-02-22 00:05:21 -05:00
2012-03-11 23:42:51 -07:00
2013-04-19 14:57:56 -04:00
2013-10-19 19:12:11 -04:00
2014-02-04 20:01:55 -08:00
2014-01-18 23:04:16 -08:00
2012-03-12 17:05:21 -07:00
2013-02-15 15:10:37 -05:00
2013-12-26 13:43:21 -05:00
2013-09-30 15:24:57 -04:00
2013-08-26 12:40:53 +02:00
2013-11-01 07:08:46 +01:00
2013-12-18 16:58:20 -05:00
2013-05-31 17:19:05 -07:00