diff options
author | NeilBrown <neilb@suse.de> | 2014-09-09 06:20:28 +0200 |
---|---|---|
committer | NeilBrown <neilb@suse.de> | 2014-10-14 04:08:28 +0200 |
commit | 1967cd5616c4792ef9d3cbaafe5fbe12fc429c9e (patch) | |
tree | 2345878c17c5e2e4e133a85902fa32680e484dc0 /drivers/md/md.c | |
parent | md: be more relaxed about stopping an array which isn't started. (diff) | |
download | linux-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.c | 9 |
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, |