reiserfs: convert j_commit_lock to mutex

j_commit_lock is a semaphore but uses it as if it were a mutex.  This patch
converts it to a mutex.

[akpm@linux-foundation.org: coding-style fixes]
Signed-off-by: Jeff Mahoney <jeffm@suse.com>
Cc: Matthew Wilcox <matthew@wil.cx>
Cc: Chris Mason <chris.mason@oracle.com>
Cc: Edward Shishkin <edward.shishkin@gmail.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
Jeff Mahoney 2008-07-25 01:46:40 -07:00 committed by Linus Torvalds
parent afe7025907
commit 90415deac7
2 changed files with 11 additions and 13 deletions

View File

@ -34,15 +34,10 @@
** from within kupdate, it will ignore the immediate flag ** from within kupdate, it will ignore the immediate flag
*/ */
#include <asm/uaccess.h>
#include <asm/system.h>
#include <linux/time.h> #include <linux/time.h>
#include <linux/semaphore.h> #include <linux/semaphore.h>
#include <linux/vmalloc.h> #include <linux/vmalloc.h>
#include <linux/reiserfs_fs.h> #include <linux/reiserfs_fs.h>
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/errno.h> #include <linux/errno.h>
#include <linux/fcntl.h> #include <linux/fcntl.h>
@ -54,6 +49,9 @@
#include <linux/writeback.h> #include <linux/writeback.h>
#include <linux/blkdev.h> #include <linux/blkdev.h>
#include <linux/backing-dev.h> #include <linux/backing-dev.h>
#include <linux/uaccess.h>
#include <asm/system.h>
/* gets a struct reiserfs_journal_list * from a list head */ /* gets a struct reiserfs_journal_list * from a list head */
#define JOURNAL_LIST_ENTRY(h) (list_entry((h), struct reiserfs_journal_list, \ #define JOURNAL_LIST_ENTRY(h) (list_entry((h), struct reiserfs_journal_list, \
@ -1045,9 +1043,9 @@ static int flush_commit_list(struct super_block *s,
} }
/* make sure nobody is trying to flush this one at the same time */ /* make sure nobody is trying to flush this one at the same time */
down(&jl->j_commit_lock); mutex_lock(&jl->j_commit_mutex);
if (!journal_list_still_alive(s, trans_id)) { if (!journal_list_still_alive(s, trans_id)) {
up(&jl->j_commit_lock); mutex_unlock(&jl->j_commit_mutex);
goto put_jl; goto put_jl;
} }
BUG_ON(jl->j_trans_id == 0); BUG_ON(jl->j_trans_id == 0);
@ -1057,7 +1055,7 @@ static int flush_commit_list(struct super_block *s,
if (flushall) { if (flushall) {
atomic_set(&(jl->j_older_commits_done), 1); atomic_set(&(jl->j_older_commits_done), 1);
} }
up(&jl->j_commit_lock); mutex_unlock(&jl->j_commit_mutex);
goto put_jl; goto put_jl;
} }
@ -1181,7 +1179,7 @@ static int flush_commit_list(struct super_block *s,
if (flushall) { if (flushall) {
atomic_set(&(jl->j_older_commits_done), 1); atomic_set(&(jl->j_older_commits_done), 1);
} }
up(&jl->j_commit_lock); mutex_unlock(&jl->j_commit_mutex);
put_jl: put_jl:
put_journal_list(s, jl); put_journal_list(s, jl);
@ -2556,7 +2554,7 @@ static struct reiserfs_journal_list *alloc_journal_list(struct super_block *s)
INIT_LIST_HEAD(&jl->j_working_list); INIT_LIST_HEAD(&jl->j_working_list);
INIT_LIST_HEAD(&jl->j_tail_bh_list); INIT_LIST_HEAD(&jl->j_tail_bh_list);
INIT_LIST_HEAD(&jl->j_bh_list); INIT_LIST_HEAD(&jl->j_bh_list);
sema_init(&jl->j_commit_lock, 1); mutex_init(&jl->j_commit_mutex);
SB_JOURNAL(s)->j_num_lists++; SB_JOURNAL(s)->j_num_lists++;
get_journal_list(jl); get_journal_list(jl);
return jl; return jl;
@ -4030,7 +4028,7 @@ static int do_journal_end(struct reiserfs_transaction_handle *th,
* the new transaction is fully setup, and we've already flushed the * the new transaction is fully setup, and we've already flushed the
* ordered bh list * ordered bh list
*/ */
down(&jl->j_commit_lock); mutex_lock(&jl->j_commit_mutex);
/* save the transaction id in case we need to commit it later */ /* save the transaction id in case we need to commit it later */
commit_trans_id = jl->j_trans_id; commit_trans_id = jl->j_trans_id;
@ -4196,7 +4194,7 @@ static int do_journal_end(struct reiserfs_transaction_handle *th,
lock_kernel(); lock_kernel();
} }
BUG_ON(!list_empty(&jl->j_tail_bh_list)); BUG_ON(!list_empty(&jl->j_tail_bh_list));
up(&jl->j_commit_lock); mutex_unlock(&jl->j_commit_mutex);
/* honor the flush wishes from the caller, simple commits can /* honor the flush wishes from the caller, simple commits can
** be done outside the journal lock, they are done below ** be done outside the journal lock, they are done below

View File

@ -152,7 +152,7 @@ struct reiserfs_journal_list {
atomic_t j_nonzerolen; atomic_t j_nonzerolen;
atomic_t j_commit_left; atomic_t j_commit_left;
atomic_t j_older_commits_done; /* all commits older than this on disk */ atomic_t j_older_commits_done; /* all commits older than this on disk */
struct semaphore j_commit_lock; struct mutex j_commit_mutex;
unsigned long j_trans_id; unsigned long j_trans_id;
time_t j_timestamp; time_t j_timestamp;
struct reiserfs_list_bitmap *j_list_bitmap; struct reiserfs_list_bitmap *j_list_bitmap;