Commit f61b68e1 authored by Aditya Pakki's avatar Aditya Pakki Committed by Greg Kroah-Hartman

md: Fix failed allocation of md_register_thread

commit e406f12d upstream.

mddev->sync_thread can be set to NULL on kzalloc failure downstream.
The patch checks for such a scenario and frees allocated resources.

Committer node:

Added similar fix to raid5.c, as suggested by Guoqing.

Cc: stable@vger.kernel.org # v3.16+
Acked-by: default avatarGuoqing Jiang <gqjiang@suse.com>
Signed-off-by: default avatarAditya Pakki <pakki001@umn.edu>
Signed-off-by: default avatarSong Liu <songliubraving@fb.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 5ed7a8f6
...@@ -3798,6 +3798,8 @@ static int raid10_run(struct mddev *mddev) ...@@ -3798,6 +3798,8 @@ static int raid10_run(struct mddev *mddev)
set_bit(MD_RECOVERY_RUNNING, &mddev->recovery); set_bit(MD_RECOVERY_RUNNING, &mddev->recovery);
mddev->sync_thread = md_register_thread(md_do_sync, mddev, mddev->sync_thread = md_register_thread(md_do_sync, mddev,
"reshape"); "reshape");
if (!mddev->sync_thread)
goto out_free_conf;
} }
return 0; return 0;
......
...@@ -6977,6 +6977,8 @@ static int raid5_run(struct mddev *mddev) ...@@ -6977,6 +6977,8 @@ static int raid5_run(struct mddev *mddev)
set_bit(MD_RECOVERY_RUNNING, &mddev->recovery); set_bit(MD_RECOVERY_RUNNING, &mddev->recovery);
mddev->sync_thread = md_register_thread(md_do_sync, mddev, mddev->sync_thread = md_register_thread(md_do_sync, mddev,
"reshape"); "reshape");
if (!mddev->sync_thread)
goto abort;
} }
/* Ok, everything is just fine now */ /* Ok, everything is just fine now */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment