summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKent Overstreet <kent.overstreet@linux.dev>2022-09-01 22:05:16 -0400
committerKent Overstreet <kent.overstreet@linux.dev>2022-10-03 23:53:47 -0400
commit1f060a564f47597615f4028c751643f05b85f97e (patch)
tree381721cd45dba75a99abe2ccf6f3b20a80a1af1b
parentd8f3f60dc22b81dc531230d7d3eae5e0fddd4e47 (diff)
bcachefs: Fix six_lock_readers_add()
Have to be careful with bit fields - when subtracting, this was overflowing into the write_locking bit. Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
-rw-r--r--fs/bcachefs/btree_locking.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/fs/bcachefs/btree_locking.c b/fs/bcachefs/btree_locking.c
index 87718c647fbb..2c3d44564d50 100644
--- a/fs/bcachefs/btree_locking.c
+++ b/fs/bcachefs/btree_locking.c
@@ -10,10 +10,12 @@ struct lock_class_key bch2_btree_node_lock_key;
static inline void six_lock_readers_add(struct six_lock *lock, int nr)
{
- if (!lock->readers)
+ if (lock->readers)
+ this_cpu_add(*lock->readers, nr);
+ else if (nr > 0)
atomic64_add(__SIX_VAL(read_lock, nr), &lock->state.counter);
else
- this_cpu_add(*lock->readers, nr);
+ atomic64_sub(__SIX_VAL(read_lock, -nr), &lock->state.counter);
}
struct six_lock_count bch2_btree_node_lock_counts(struct btree_trans *trans,