Song Liu
b91d4797b3
md/raid5: fix oops during stripe resizing
...
commit b44c018cdf748b96b676ba09fdbc5b34fc443ada upstream.
KoWei reported crash during raid5 reshape:
[ 1032.252932] Oops: 0002 [#1 ] SMP PTI
[...]
[ 1032.252943] RIP: 0010:memcpy_erms+0x6/0x10
[...]
[ 1032.252947] RSP: 0018:ffffba1ac0c03b78 EFLAGS: 00010286
[ 1032.252949] RAX: 0000784ac0000000 RBX: ffff91bec3d09740 RCX: 0000000000001000
[ 1032.252951] RDX: 0000000000001000 RSI: ffff91be6781c000 RDI: 0000784ac0000000
[ 1032.252953] RBP: ffffba1ac0c03bd8 R08: 0000000000001000 R09: ffffba1ac0c03bf8
[ 1032.252954] R10: 0000000000000000 R11: 0000000000000000 R12: ffffba1ac0c03bf8
[ 1032.252955] R13: 0000000000001000 R14: 0000000000000000 R15: 0000000000000000
[ 1032.252958] FS: 0000000000000000(0000) GS:ffff91becf500000(0000) knlGS:0000000000000000
[ 1032.252959] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
[ 1032.252961] CR2: 0000784ac0000000 CR3: 000000031780a002 CR4: 00000000001606e0
[ 1032.252962] Call Trace:
[ 1032.252969] ? async_memcpy+0x179/0x1000 [async_memcpy]
[ 1032.252977] ? raid5_release_stripe+0x8e/0x110 [raid456]
[ 1032.252982] handle_stripe_expansion+0x15a/0x1f0 [raid456]
[ 1032.252988] handle_stripe+0x592/0x1270 [raid456]
[ 1032.252993] handle_active_stripes.isra.0+0x3cb/0x5a0 [raid456]
[ 1032.252999] raid5d+0x35c/0x550 [raid456]
[ 1032.253002] ? schedule+0x42/0xb0
[ 1032.253006] ? schedule_timeout+0x10e/0x160
[ 1032.253011] md_thread+0x97/0x160
[ 1032.253015] ? wait_woken+0x80/0x80
[ 1032.253019] kthread+0x104/0x140
[ 1032.253022] ? md_start_sync+0x60/0x60
[ 1032.253024] ? kthread_park+0x90/0x90
[ 1032.253027] ret_from_fork+0x35/0x40
This is because cache_size_mutex was unlocked too early in resize_stripes,
which races with grow_one_stripe() that grow_one_stripe() allocates a
stripe with wrong pool_size.
Fix this issue by unlocking cache_size_mutex after updating pool_size.
Cc: <stable@vger.kernel.org> # v4.4+
Reported-by: KoWei Sung <winders@amazon.com>
Signed-off-by: Song Liu <songliubraving@fb.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2020-11-05 11:43:22 +01:00
..
2020-10-01 13:17:18 +02:00
2020-09-09 19:12:36 +02:00
2018-06-08 11:53:14 -04:00
2018-06-08 11:53:14 -04:00
2020-03-25 08:25:48 +01:00
2019-09-13 17:00:21 -04:00
2020-09-09 19:12:35 +02:00
2018-10-16 14:34:59 -04:00
2020-03-12 13:00:23 +01:00
2020-04-17 10:50:24 +02:00
2020-04-17 10:50:23 +02:00
2020-04-17 10:50:24 +02:00
2019-04-04 15:33:59 -04:00
2020-09-09 19:12:35 +02:00
2019-04-26 11:29:32 -04:00
2019-08-21 11:27:17 -04:00
2019-05-21 10:50:45 +02:00
2019-05-16 15:55:48 -07:00
2019-07-11 20:04:37 -06:00
2019-07-15 11:03:01 -03:00
2020-09-09 19:12:35 +02:00
2018-06-05 08:47:43 -06:00
2019-09-16 10:18:01 -04:00
2019-08-15 15:57:39 -04:00
2019-07-11 20:04:37 -06:00
2018-05-30 15:33:32 -06:00
2019-07-09 14:13:33 -04:00
2020-09-09 19:12:35 +02:00
2019-08-26 11:05:32 -04:00
2019-09-11 16:18:23 -04:00
2018-06-12 18:28:00 -07:00
2020-08-21 13:05:33 +02:00
2019-03-05 14:48:50 -05:00
2020-01-23 08:22:32 +01:00
2019-10-10 09:46:05 -04:00
2019-09-04 09:39:22 -04:00
2018-05-22 23:18:31 -07:00
2019-03-05 14:48:51 -05:00
2018-10-11 11:36:09 -04:00
2020-10-01 13:17:14 +02:00
2019-04-25 15:38:52 -04:00
2020-09-09 19:12:36 +02:00
2019-12-21 11:05:01 +01:00
2020-02-24 08:36:49 +01:00
2019-05-30 11:26:35 -07:00
2019-05-30 11:26:35 -07:00
2018-12-18 09:02:26 -05:00
2020-05-06 08:15:10 +02:00
2019-05-30 11:26:32 -07:00
2019-08-23 10:13:14 -04:00
2019-08-23 10:13:14 -04:00
2019-08-23 10:13:14 -04:00
2019-08-23 10:13:14 -04:00
2020-09-09 19:12:35 +02:00
2020-06-24 17:50:31 +02:00
2020-06-24 17:50:31 +02:00
2020-07-09 09:37:57 +02:00
2019-12-17 19:56:12 +01:00
2020-10-01 13:18:25 +02:00
2019-08-23 10:13:12 -04:00
2019-09-12 09:32:31 -04:00
2019-09-12 09:32:31 -04:00
2020-11-05 11:43:20 +01:00
2018-08-01 15:49:39 -07:00
2020-10-29 09:58:01 +01:00
2018-10-18 09:36:35 -07:00
2019-05-24 17:27:13 +02:00
2019-12-17 19:56:14 +01:00
2019-12-17 19:56:14 +01:00
2018-05-30 15:33:32 -06:00
2020-08-19 08:15:58 +02:00
2019-12-17 19:56:14 +01:00
2020-01-23 08:22:32 +01:00
2019-09-13 13:10:05 -07:00
2019-06-15 01:37:35 -06:00
2020-01-09 10:19:48 +01:00
2018-05-30 15:33:32 -06:00
2019-06-05 17:36:37 +02:00
2019-03-12 10:15:18 -07:00
2019-06-05 17:36:37 +02:00
2020-11-05 11:43:22 +01:00
2019-09-13 13:14:43 -07:00
2019-12-17 19:56:14 +01:00
2018-05-30 15:33:32 -06:00