diff options
author | Frederic Weisbecker <fweisbec@gmail.com> | 2009-05-08 14:01:09 -0400 |
---|---|---|
committer | Frederic Weisbecker <fweisbec@gmail.com> | 2009-09-14 01:18:21 -0400 |
commit | c63e3c0b2498adec921b06c670d12c8c74b85538 (patch) | |
tree | 27ca06415b5fdd51e369361ea8aa8f8e8e1ac741 /fs/reiserfs/journal.c | |
parent | d6f5b0aa08078c3dabe377d5b1a6077e9c9352d3 (diff) |
kill-the-bkl/reiserfs: use mutex_lock in reiserfs_mutex_lock_safe
reiserfs_mutex_lock_safe() is a hack to avoid any dependency between
an internal reiserfs mutex and the write lock, it has been proposed
to follow the old bkl logic.
The code does the following:
while (!mutex_trylock(m)) {
reiserfs_write_unlock(s);
schedule();
reiserfs_write_lock(s);
}
It then imitate the implicit behaviour of the lock when it was
a Bkl and hadn't such dependency:
mutex_lock(m) {
if (fastpath)
let's go
else {
wait_for_mutex() {
schedule() {
unlock_kernel()
reacquire_lock_kernel()
}
}
}
}
The problem is that by using such explicit schedule(), we don't
benefit of the adaptive mutex spinning on owner.
The logic in use now is:
reiserfs_write_unlock(s);
mutex_lock(m); // -> possible adaptive spinning
reiserfs_write_lock(s);
[ Impact: restore the use of adaptive spinning mutexes in reiserfs ]
Cc: Jeff Mahoney <jeffm@suse.com>
Cc: Chris Mason <chris.mason@oracle.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Alexander Beregalov <a.beregalov@gmail.com>
Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com>
Diffstat (limited to 'fs/reiserfs/journal.c')
-rw-r--r-- | fs/reiserfs/journal.c | 8 |
1 files changed, 3 insertions, 5 deletions
diff --git a/fs/reiserfs/journal.c b/fs/reiserfs/journal.c index ffb7f50abc2f..e9a972bd0323 100644 --- a/fs/reiserfs/journal.c +++ b/fs/reiserfs/journal.c | |||
@@ -566,11 +566,9 @@ static inline void insert_journal_hash(struct reiserfs_journal_cnode **table, | |||
566 | static inline void reiserfs_mutex_lock_safe(struct mutex *m, | 566 | static inline void reiserfs_mutex_lock_safe(struct mutex *m, |
567 | struct super_block *s) | 567 | struct super_block *s) |
568 | { | 568 | { |
569 | while (!mutex_trylock(m)) { | 569 | reiserfs_write_unlock(s); |
570 | reiserfs_write_unlock(s); | 570 | mutex_lock(m); |
571 | schedule(); | 571 | reiserfs_write_lock(s); |
572 | reiserfs_write_lock(s); | ||
573 | } | ||
574 | } | 572 | } |
575 | 573 | ||
576 | /* lock the current transaction */ | 574 | /* lock the current transaction */ |