John Pittman
120130a757
dm kcopyd: avoid softlockup in run_complete_job
[ Upstream commit 784c9a29e9 ]
It was reported that softlockups occur when using dm-snapshot ontop of
slow (rbd) storage. E.g.:
[ 4047.990647] watchdog: BUG: soft lockup - CPU#10 stuck for 22s! [kworker/10:23:26177]
...
[ 4048.034151] Workqueue: kcopyd do_work [dm_mod]
[ 4048.034156] RIP: 0010:copy_callback+0x41/0x160 [dm_snapshot]
...
[ 4048.034190] Call Trace:
[ 4048.034196] ? __chunk_is_tracked+0x70/0x70 [dm_snapshot]
[ 4048.034200] run_complete_job+0x5f/0xb0 [dm_mod]
[ 4048.034205] process_jobs+0x91/0x220 [dm_mod]
[ 4048.034210] ? kcopyd_put_pages+0x40/0x40 [dm_mod]
[ 4048.034214] do_work+0x46/0xa0 [dm_mod]
[ 4048.034219] process_one_work+0x171/0x370
[ 4048.034221] worker_thread+0x1fc/0x3f0
[ 4048.034224] kthread+0xf8/0x130
[ 4048.034226] ? max_active_store+0x80/0x80
[ 4048.034227] ? kthread_bind+0x10/0x10
[ 4048.034231] ret_from_fork+0x35/0x40
[ 4048.034233] Kernel panic - not syncing: softlockup: hung tasks
Fix this by calling cond_resched() after run_complete_job()'s callout to
the dm_kcopyd_notify_fn (which is dm-snap.c:copy_callback in the above
trace).
Signed-off-by: John Pittman <jpittman@redhat.com>
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
Signed-off-by: Sasha Levin <alexander.levin@microsoft.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2018-09-15 09:45:31 +02:00
..
2018-09-09 19:56:01 +02:00
2018-01-23 19:58:18 +01:00
2017-12-17 15:08:00 +01:00
2017-11-02 11:10:55 +01:00
2017-06-19 11:03:50 -04:00
2017-06-09 09:27:32 -06:00
2017-06-19 11:03:50 -04:00
2017-03-07 11:30:16 -05:00
2017-08-23 12:49:55 -06:00
2018-03-15 10:54:33 +01:00
2017-08-28 11:47:17 -04:00
2017-11-02 11:10:55 +01:00
2017-05-17 09:44:53 -04:00
2017-03-07 13:28:31 -05:00
2016-12-16 00:13:41 +02:00
2018-09-09 19:55:55 +02:00
2017-03-07 13:28:31 -05:00
2017-03-07 13:28:31 -05:00
2017-05-14 21:54:33 -04:00
2014-01-16 13:44:11 -05:00
2017-03-07 13:28:31 -05:00
2017-12-20 10:10:21 +01:00
2017-11-30 08:40:43 +00:00
2018-09-09 19:55:55 +02:00
2017-08-23 12:49:55 -06:00
2017-08-23 12:49:55 -06:00
2015-11-04 21:19:53 -08:00
2016-01-08 20:03:05 -05:00
2017-09-14 13:43:16 -07:00
2018-09-09 19:55:55 +02:00
2017-08-23 12:49:55 -06:00
2017-09-25 11:18:29 -04:00
2018-09-15 09:45:31 +02:00
2017-09-14 13:43:16 -07:00
2015-10-31 19:06:00 -04:00
2015-04-15 12:10:20 -04:00
2009-09-04 20:40:34 +01:00
2017-09-14 13:43:16 -07:00
2016-11-01 09:43:26 -06:00
2018-04-26 11:02:07 +02:00
2008-10-10 13:36:58 +01:00
2011-10-31 19:31:18 -04:00
2016-02-22 22:34:42 -05:00
2016-02-22 22:34:42 -05:00
2017-08-23 12:49:55 -06:00
2018-07-08 15:30:49 +02:00
2016-08-07 14:41:02 -06:00
2017-02-17 00:54:09 -05:00
2017-08-28 10:23:28 -04:00
2017-08-28 10:23:28 -04:00
2016-02-22 22:34:42 -05:00
2017-05-31 10:50:23 -04:00
2016-01-08 20:03:05 -05:00
2017-12-20 10:10:21 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-09-14 13:43:16 -07:00
2017-09-14 13:43:16 -07:00
2016-06-10 15:15:44 -04:00
2018-07-11 16:29:23 +02:00
2017-06-09 09:27:32 -06:00
2018-01-23 19:58:18 +01:00
2016-07-20 12:43:35 -04:00
2018-09-09 19:55:55 +02:00
2011-10-31 19:31:19 -04:00
2007-10-20 02:01:26 +01:00
2017-07-26 15:55:44 -04:00
2017-03-16 09:37:31 -04:00
2017-09-14 13:43:16 -07:00
2017-04-24 15:37:04 -04:00
2017-06-09 09:27:32 -06:00
2017-08-23 12:49:55 -06:00
2017-07-26 15:55:43 -04:00
2018-07-03 11:25:05 +02:00
2017-06-19 11:05:20 -04:00
2018-07-11 16:29:23 +02:00
2017-04-27 17:08:44 -04:00
2017-08-23 12:49:55 -06:00
2017-06-19 11:05:20 -04:00
2017-08-23 12:49:55 -06:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-07-08 15:30:50 +02:00
2017-11-02 11:10:55 +01:00
2018-08-03 07:50:33 +02:00
2018-07-08 15:30:50 +02:00
2017-08-23 12:49:55 -06:00
2017-11-02 11:10:55 +01:00
2018-07-08 15:30:50 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-08-03 07:50:33 +02:00
2017-11-02 11:10:55 +01:00
2018-07-08 15:30:50 +02:00
2018-07-08 15:30:50 +02:00
2017-12-20 10:10:36 +01:00
2018-07-08 15:30:50 +02:00
2017-11-02 11:10:55 +01:00
2018-08-24 13:09:08 +02:00
2017-11-02 11:10:55 +01:00