kill-the-BKL/reiserfs: release the write lock inside get_neighbors()
authorFrederic Weisbecker <fweisbec@gmail.com>
Thu, 30 Apr 2009 23:10:52 +0000 (01:10 +0200)
committerFrederic Weisbecker <fweisbec@gmail.com>
Mon, 14 Sep 2009 05:18:10 +0000 (07:18 +0200)
commit148d3504c1d9f964cf14fafc46d2b7d1f0bed2b1
tree6b17f1361099e8b579d10e892a8d919eae037354
parent5e69e3a4492ea5abfd2e8ddc575448becf28e4d9
kill-the-BKL/reiserfs: release the write lock inside get_neighbors()

get_neighbors() is used to get the left and/or right blocks
against a given one in order to balance a tree.

sb_bread() is used to read the buffer of these neighors blocks and
while it waits for this operation, it might sleep.

The bkl was released at this point, and then we can also release
the write lock before calling sb_bread().

This is safe because if the filesystem is changed after this
lock release, the function returns REPEAT_SEARCH (aka SCHEDULE_OCCURRED
in the function header comments) in order to repeat the neighbhor
research.

[ Impact: release the reiserfs write lock when it is not needed ]

Cc: Jeff Mahoney <jeffm@suse.com>
Cc: Chris Mason <chris.mason@oracle.com>
Cc: Alexander Beregalov <a.beregalov@gmail.com>
Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com>
fs/reiserfs/fix_node.c