Mike Galbraith
5c16520bdc
reiserfs: Unlock superblock before calling reiserfs_quota_on_mount()
...
commit 420902c9d086848a7548c83e0a49021514bd71b7 upstream.
If we hold the superblock lock while calling reiserfs_quota_on_mount(), we can
deadlock our own worker - mount blocks kworker/3:2, sleeps forever more.
crash> ps|grep UN
715 2 3 ffff880220734d30 UN 0.0 0 0 [kworker/3:2]
9369 9341 2 ffff88021ffb7560 UN 1.3 493404 123184 Xorg
9665 9664 3 ffff880225b92ab0 UN 0.0 47368 812 udisks-daemon
10635 10403 3 ffff880222f22c70 UN 0.0 14904 936 mount
crash> bt ffff880220734d30
PID: 715 TASK: ffff880220734d30 CPU: 3 COMMAND: "kworker/3:2"
#0 [ffff8802244c3c20] schedule at ffffffff8144584b
#1 [ffff8802244c3cc8] __rt_mutex_slowlock at ffffffff814472b3
#2 [ffff8802244c3d28] rt_mutex_slowlock at ffffffff814473f5
#3 [ffff8802244c3dc8] reiserfs_write_lock at ffffffffa05f28fd [reiserfs]
#4 [ffff8802244c3de8] flush_async_commits at ffffffffa05ec91d [reiserfs]
#5 [ffff8802244c3e08] process_one_work at ffffffff81073726
#6 [ffff8802244c3e68] worker_thread at ffffffff81073eba
#7 [ffff8802244c3ec8] kthread at ffffffff810782e0
#8 [ffff8802244c3f48] kernel_thread_helper at ffffffff81450064
crash> rd ffff8802244c3cc8 10
ffff8802244c3cc8: ffffffff814472b3 ffff880222f23250 .rD.....P2."....
ffff8802244c3cd8: 0000000000000000 0000000000000286 ................
ffff8802244c3ce8: ffff8802244c3d30 ffff880220734d80 0=L$.....Ms ....
ffff8802244c3cf8: ffff880222e8f628 0000000000000000 (.."............
ffff8802244c3d08: 0000000000000000 0000000000000002 ................
crash> struct rt_mutex ffff880222e8f628
struct rt_mutex {
wait_lock = {
raw_lock = {
slock = 65537
}
},
wait_list = {
node_list = {
next = 0xffff8802244c3d48,
prev = 0xffff8802244c3d48
}
},
owner = 0xffff880222f22c71,
save_state = 0
}
crash> bt 0xffff880222f22c70
PID: 10635 TASK: ffff880222f22c70 CPU: 3 COMMAND: "mount"
#0 [ffff8802216a9868] schedule at ffffffff8144584b
#1 [ffff8802216a9910] schedule_timeout at ffffffff81446865
#2 [ffff8802216a99a0] wait_for_common at ffffffff81445f74
#3 [ffff8802216a9a30] flush_work at ffffffff810712d3
#4 [ffff8802216a9ab0] schedule_on_each_cpu at ffffffff81074463
#5 [ffff8802216a9ae0] invalidate_bdev at ffffffff81178aba
#6 [ffff8802216a9af0] vfs_load_quota_inode at ffffffff811a3632
#7 [ffff8802216a9b50] dquot_quota_on_mount at ffffffff811a375c
#8 [ffff8802216a9b80] finish_unfinished at ffffffffa05dd8b0 [reiserfs]
#9 [ffff8802216a9cc0] reiserfs_fill_super at ffffffffa05de825 [reiserfs]
RIP: 00007f7b9303997a RSP: 00007ffff443c7a8 RFLAGS: 00010202
RAX: 00000000000000a5 RBX: ffffffff8144ef12 RCX: 00007f7b932e9ee0
RDX: 00007f7b93d9a400 RSI: 00007f7b93d9a3e0 RDI: 00007f7b93d9a3c0
RBP: 00007f7b93d9a2c0 R8: 00007f7b93d9a550 R9: 0000000000000001
R10: ffffffffc0ed040e R11: 0000000000000202 R12: 000000000000040e
R13: 0000000000000000 R14: 00000000c0ed040e R15: 00007ffff443ca20
ORIG_RAX: 00000000000000a5 CS: 0033 SS: 002b
Signed-off-by: Mike Galbraith <efault@gmx.de>
Acked-by: Frederic Weisbecker <fweisbec@gmail.com>
Acked-by: Mike Galbraith <mgalbraith@suse.de>
Signed-off-by: Jan Kara <jack@suse.cz>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2016-10-22 12:26:55 +02:00
..
2016-08-10 11:49:27 +02:00
2015-06-30 19:44:57 -07:00
2016-06-07 18:14:32 -07:00
2016-09-30 10:18:37 +02:00
2015-07-04 19:36:06 -07:00
2016-10-22 12:26:54 +02:00
2015-11-16 20:38:43 -05:00
2016-10-07 15:23:42 +02:00
2016-08-20 18:09:20 +02:00
2015-09-10 13:29:01 -07:00
2015-11-20 16:17:32 -08:00
2016-05-04 14:48:41 -07:00
2016-08-16 09:30:49 +02:00
2015-12-01 15:45:05 -05:00
2016-09-15 08:27:47 +02:00
2016-03-03 15:07:09 -08:00
2015-12-12 10:15:34 -08:00
2015-11-16 09:43:54 -08:00
2016-09-24 10:07:35 +02:00
2016-09-24 10:07:34 +02:00
2015-11-20 16:17:32 -08:00
2015-08-07 13:59:24 +02:00
2015-11-11 02:11:02 -05:00
2016-10-22 12:26:55 +02:00
2015-11-13 18:02:30 -08:00
2015-09-10 13:29:01 -07:00
2015-11-13 20:34:32 -05:00
2016-09-30 10:18:39 +02:00
2016-06-01 12:15:54 -07:00
2016-02-25 12:01:22 -08:00
2016-05-18 17:06:54 -07:00
2016-08-20 18:09:20 +02:00
2016-03-16 08:42:58 -07:00
2015-11-09 15:11:24 -08:00
2016-09-24 10:07:36 +02:00
2015-11-11 20:11:28 -08:00
2015-11-06 17:50:42 -08:00
2015-07-04 19:36:06 -07:00
2016-03-16 08:42:59 -07:00
2016-10-07 15:23:45 +02:00
2015-08-13 10:22:06 -04:00
2016-09-24 10:07:36 +02:00
2016-08-10 11:49:25 +02:00
2016-09-30 10:18:37 +02:00
2015-11-06 17:50:42 -08:00
2016-09-30 10:18:34 +02:00
2016-09-15 08:27:52 +02:00
2016-09-24 10:07:36 +02:00
2016-10-07 15:23:44 +02:00
2016-04-12 09:08:56 -07:00
2015-10-16 11:42:28 -07:00
2016-10-22 12:26:55 +02:00
2015-11-13 20:34:33 -05:00
2016-09-07 08:32:46 +02:00
2015-11-23 21:11:08 -05:00
2015-11-04 22:13:45 -05:00
2016-09-15 08:27:53 +02:00
2016-02-25 12:01:18 -08:00
2015-09-09 10:43:12 -07:00
2016-09-30 10:18:37 +02:00
2016-10-07 15:23:47 +02:00
2015-11-10 12:07:22 -08:00
2015-11-11 09:45:24 -08:00
2015-12-04 11:02:17 -07:00
2015-11-11 02:19:33 -05:00
2015-08-05 13:49:35 -07:00
2015-10-23 23:26:43 +02:00
2016-04-12 09:08:58 -07:00
2015-11-16 23:54:45 -08:00
2016-08-16 09:30:50 +02:00
2016-03-03 15:07:28 -08:00
2015-08-17 18:39:46 -04:00
2015-07-10 10:39:25 -05:00
2016-04-12 09:08:58 -07:00
2015-08-07 04:39:40 +03:00
2015-11-05 23:05:32 -08:00
2016-04-12 09:09:04 -07:00
2016-08-10 11:49:30 +02:00
2015-08-17 23:38:10 -04:00
2015-11-16 23:54:45 -08:00
2015-08-12 15:28:45 -05:00
2016-08-10 11:49:27 +02:00
2015-10-15 10:33:21 -04:00
2015-06-30 19:44:56 -07:00
2015-11-06 17:50:42 -08:00
2016-09-15 08:27:49 +02:00
2016-08-10 11:49:27 +02:00
2015-09-11 15:21:34 -07:00
2016-05-18 17:06:48 -07:00
2016-06-07 18:14:35 -07:00
2016-05-11 11:21:19 +02:00
2015-07-22 20:33:27 -05:00
2016-07-27 09:47:30 -07:00
2016-04-12 09:08:55 -07:00
2016-09-07 08:32:43 +02:00
2015-08-07 04:39:40 +03:00
2016-04-12 09:08:55 -07:00
2015-11-09 15:11:24 -08:00
2016-03-09 15:34:52 -08:00
2015-11-06 17:50:42 -08:00
2016-02-25 12:01:25 -08:00
2016-03-16 08:43:01 -07:00
2015-11-13 20:34:33 -05:00