Skip to content

Commit 0e49d3f

Browse files
author
Kent Overstreet
committed
bcachefs: Fix locking in __bch2_trans_mark_dev_sb()
We run this in full RW mode now, so we have to guard against the superblock buffer being reallocated. Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
1 parent 99c87fe commit 0e49d3f

File tree

2 files changed

+10
-9
lines changed

2 files changed

+10
-9
lines changed

fs/bcachefs/btree_gc.c

Lines changed: 1 addition & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -741,12 +741,9 @@ static int bch2_gc_btrees(struct bch_fs *c)
741741

742742
static int bch2_mark_superblocks(struct bch_fs *c)
743743
{
744-
mutex_lock(&c->sb_lock);
745744
gc_pos_set(c, gc_phase(GC_PHASE_sb));
746745

747-
int ret = bch2_trans_mark_dev_sbs_flags(c, BTREE_TRIGGER_gc);
748-
mutex_unlock(&c->sb_lock);
749-
return ret;
746+
return bch2_trans_mark_dev_sbs_flags(c, BTREE_TRIGGER_gc);
750747
}
751748

752749
static void bch2_gc_free(struct bch_fs *c)

fs/bcachefs/buckets.c

Lines changed: 9 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -915,7 +915,6 @@ static int __bch2_trans_mark_metadata_bucket(struct btree_trans *trans,
915915
enum bch_data_type type,
916916
unsigned sectors)
917917
{
918-
struct bch_fs *c = trans->c;
919918
struct btree_iter iter;
920919
int ret = 0;
921920

@@ -1046,13 +1045,18 @@ static int bch2_trans_mark_metadata_sectors(struct btree_trans *trans,
10461045
static int __bch2_trans_mark_dev_sb(struct btree_trans *trans, struct bch_dev *ca,
10471046
enum btree_iter_update_trigger_flags flags)
10481047
{
1049-
struct bch_sb_layout *layout = &ca->disk_sb.sb->layout;
1048+
struct bch_fs *c = trans->c;
1049+
1050+
mutex_lock(&c->sb_lock);
1051+
struct bch_sb_layout layout = ca->disk_sb.sb->layout;
1052+
mutex_unlock(&c->sb_lock);
1053+
10501054
u64 bucket = 0;
10511055
unsigned i, bucket_sectors = 0;
10521056
int ret;
10531057

1054-
for (i = 0; i < layout->nr_superblocks; i++) {
1055-
u64 offset = le64_to_cpu(layout->sb_offset[i]);
1058+
for (i = 0; i < layout.nr_superblocks; i++) {
1059+
u64 offset = le64_to_cpu(layout.sb_offset[i]);
10561060

10571061
if (offset == BCH_SB_SECTOR) {
10581062
ret = bch2_trans_mark_metadata_sectors(trans, ca,
@@ -1063,7 +1067,7 @@ static int __bch2_trans_mark_dev_sb(struct btree_trans *trans, struct bch_dev *c
10631067
}
10641068

10651069
ret = bch2_trans_mark_metadata_sectors(trans, ca, offset,
1066-
offset + (1 << layout->sb_max_size_bits),
1070+
offset + (1 << layout.sb_max_size_bits),
10671071
BCH_DATA_sb, &bucket, &bucket_sectors, flags);
10681072
if (ret)
10691073
return ret;

0 commit comments

Comments
 (0)