Commit 216e8098 authored by Thomas Gleixner's avatar Thomas Gleixner

fs: jbd2: Replace bit spinlocks

Bit spinlocks are not really RT friendly and in general I don't like
them as they escape the lockdep debugging. Make it use the bh locks as
we already did for jdb.
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
parent 6f8efee4
...@@ -1451,7 +1451,7 @@ void __jbd2_journal_temp_unlink_buffer(struct journal_head *jh) ...@@ -1451,7 +1451,7 @@ void __jbd2_journal_temp_unlink_buffer(struct journal_head *jh)
transaction_t *transaction; transaction_t *transaction;
struct buffer_head *bh = jh2bh(jh); struct buffer_head *bh = jh2bh(jh);
J_ASSERT_JH(jh, jbd_is_locked_bh_state(bh)); J_ASSERT_JH_SMP(jh, jbd_is_locked_bh_state(bh));
transaction = jh->b_transaction; transaction = jh->b_transaction;
if (transaction) if (transaction)
assert_spin_locked(&transaction->t_journal->j_list_lock); assert_spin_locked(&transaction->t_journal->j_list_lock);
...@@ -1883,7 +1883,7 @@ void __jbd2_journal_file_buffer(struct journal_head *jh, ...@@ -1883,7 +1883,7 @@ void __jbd2_journal_file_buffer(struct journal_head *jh,
int was_dirty = 0; int was_dirty = 0;
struct buffer_head *bh = jh2bh(jh); struct buffer_head *bh = jh2bh(jh);
J_ASSERT_JH(jh, jbd_is_locked_bh_state(bh)); J_ASSERT_JH_SMP(jh, jbd_is_locked_bh_state(bh));
assert_spin_locked(&transaction->t_journal->j_list_lock); assert_spin_locked(&transaction->t_journal->j_list_lock);
J_ASSERT_JH(jh, jh->b_jlist < BJ_Types); J_ASSERT_JH(jh, jh->b_jlist < BJ_Types);
...@@ -1971,7 +1971,7 @@ void __jbd2_journal_refile_buffer(struct journal_head *jh) ...@@ -1971,7 +1971,7 @@ void __jbd2_journal_refile_buffer(struct journal_head *jh)
int was_dirty; int was_dirty;
struct buffer_head *bh = jh2bh(jh); struct buffer_head *bh = jh2bh(jh);
J_ASSERT_JH(jh, jbd_is_locked_bh_state(bh)); J_ASSERT_JH_SMP(jh, jbd_is_locked_bh_state(bh));
if (jh->b_transaction) if (jh->b_transaction)
assert_spin_locked(&jh->b_transaction->t_journal->j_list_lock); assert_spin_locked(&jh->b_transaction->t_journal->j_list_lock);
......
...@@ -319,6 +319,15 @@ void buffer_assertion_failure(struct buffer_head *bh); ...@@ -319,6 +319,15 @@ void buffer_assertion_failure(struct buffer_head *bh);
#define J_EXPECT_JH(jh, expr, why...) __journal_expect(expr, ## why) #define J_EXPECT_JH(jh, expr, why...) __journal_expect(expr, ## why)
#endif #endif
/*
* For assertions that are only valid on SMP (e.g. spin_is_locked()):
*/
#ifdef CONFIG_SMP
# define J_ASSERT_JH_SMP(jh, expr) J_ASSERT_JH(jh, expr)
#else
# define J_ASSERT_JH_SMP(jh, assert) do { } while (0)
#endif
enum jbd_state_bits { enum jbd_state_bits {
BH_JBD /* Has an attached ext3 journal_head */ BH_JBD /* Has an attached ext3 journal_head */
= BH_PrivateStart, = BH_PrivateStart,
...@@ -355,32 +364,32 @@ static inline struct journal_head *bh2jh(struct buffer_head *bh) ...@@ -355,32 +364,32 @@ static inline struct journal_head *bh2jh(struct buffer_head *bh)
static inline void jbd_lock_bh_state(struct buffer_head *bh) static inline void jbd_lock_bh_state(struct buffer_head *bh)
{ {
bit_spin_lock(BH_State, &bh->b_state); spin_lock(&bh->b_state_lock);
} }
static inline int jbd_trylock_bh_state(struct buffer_head *bh) static inline int jbd_trylock_bh_state(struct buffer_head *bh)
{ {
return bit_spin_trylock(BH_State, &bh->b_state); return spin_trylock(&bh->b_state_lock);
} }
static inline int jbd_is_locked_bh_state(struct buffer_head *bh) static inline int jbd_is_locked_bh_state(struct buffer_head *bh)
{ {
return bit_spin_is_locked(BH_State, &bh->b_state); return spin_is_locked(&bh->b_state_lock);
} }
static inline void jbd_unlock_bh_state(struct buffer_head *bh) static inline void jbd_unlock_bh_state(struct buffer_head *bh)
{ {
bit_spin_unlock(BH_State, &bh->b_state); spin_unlock(&bh->b_state_lock);
} }
static inline void jbd_lock_bh_journal_head(struct buffer_head *bh) static inline void jbd_lock_bh_journal_head(struct buffer_head *bh)
{ {
bit_spin_lock(BH_JournalHead, &bh->b_state); spin_lock(&bh->b_uptodate_lock);
} }
static inline void jbd_unlock_bh_journal_head(struct buffer_head *bh) static inline void jbd_unlock_bh_journal_head(struct buffer_head *bh)
{ {
bit_spin_unlock(BH_JournalHead, &bh->b_state); spin_unlock(&bh->b_uptodate_lock);
} }
/* Flags in jbd_inode->i_flags */ /* Flags in jbd_inode->i_flags */
......
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