Commit 389b8be6 authored by Al Viro's avatar Al Viro

get rid of open-coded grab_super() in get_active_super()

Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent 79d7e39e
...@@ -487,22 +487,9 @@ struct super_block *get_active_super(struct block_device *bdev) ...@@ -487,22 +487,9 @@ struct super_block *get_active_super(struct block_device *bdev)
if (sb->s_bdev != bdev) if (sb->s_bdev != bdev)
continue; continue;
sb->s_count++; if (grab_super(sb)) /* drops sb_lock */
spin_unlock(&sb_lock);
down_write(&sb->s_umount);
if (sb->s_root) {
spin_lock(&sb_lock);
if (sb->s_count > S_BIAS) {
atomic_inc(&sb->s_active);
sb->s_count--;
spin_unlock(&sb_lock);
return sb; return sb;
}
spin_unlock(&sb_lock);
}
up_write(&sb->s_umount);
put_super(sb);
yield();
spin_lock(&sb_lock); spin_lock(&sb_lock);
} }
spin_unlock(&sb_lock); spin_unlock(&sb_lock);
......
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