summaryrefslogtreecommitdiffstats
path: root/drivers/md/md.c
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2014-09-09 06:20:28 +0200
committerNeilBrown <neilb@suse.de>2014-10-14 04:08:28 +0200
commit1967cd5616c4792ef9d3cbaafe5fbe12fc429c9e (patch)
tree2345878c17c5e2e4e133a85902fa32680e484dc0 /drivers/md/md.c
parentmd: be more relaxed about stopping an array which isn't started. (diff)
downloadlinux-1967cd5616c4792ef9d3cbaafe5fbe12fc429c9e.tar.xz
linux-1967cd5616c4792ef9d3cbaafe5fbe12fc429c9e.zip
md: use wait_event() to simplify md_super_wait()
md_super_wait is really just wait_event() open-coded. So use the macro instead. Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'drivers/md/md.c')
-rw-r--r--drivers/md/md.c9
1 files changed, 1 insertions, 8 deletions
diff --git a/drivers/md/md.c b/drivers/md/md.c
index 4c72e9626eff..6be7146be5b3 100644
--- a/drivers/md/md.c
+++ b/drivers/md/md.c
@@ -766,14 +766,7 @@ void md_super_write(struct mddev *mddev, struct md_rdev *rdev,
void md_super_wait(struct mddev *mddev)
{
/* wait for all superblock writes that were scheduled to complete */
- DEFINE_WAIT(wq);
- for(;;) {
- prepare_to_wait(&mddev->sb_wait, &wq, TASK_UNINTERRUPTIBLE);
- if (atomic_read(&mddev->pending_writes)==0)
- break;
- schedule();
- }
- finish_wait(&mddev->sb_wait, &wq);
+ wait_event(mddev->sb_wait, atomic_read(&mddev->pending_writes)==0);
}
int sync_page_io(struct md_rdev *rdev, sector_t sector, int size,