Commit 39f9d028 authored by Liu Bo's avatar Liu Bo Committed by Josef Bacik

Btrfs: save us a read_lock

This does not change the logic of code, but can save us a read_lock.
Signed-off-by: default avatarLiu Bo <bo.li.liu@oracle.com>
Signed-off-by: default avatarJosef Bacik <jbacik@fusionio.com>
parent 51fab693
...@@ -113,11 +113,10 @@ void btrfs_tree_read_lock(struct extent_buffer *eb) ...@@ -113,11 +113,10 @@ void btrfs_tree_read_lock(struct extent_buffer *eb)
read_unlock(&eb->lock); read_unlock(&eb->lock);
return; return;
} }
read_unlock(&eb->lock);
wait_event(eb->write_lock_wq, atomic_read(&eb->blocking_writers) == 0);
read_lock(&eb->lock);
if (atomic_read(&eb->blocking_writers)) { if (atomic_read(&eb->blocking_writers)) {
read_unlock(&eb->lock); read_unlock(&eb->lock);
wait_event(eb->write_lock_wq,
atomic_read(&eb->blocking_writers) == 0);
goto again; goto again;
} }
atomic_inc(&eb->read_locks); atomic_inc(&eb->read_locks);
......
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