Skip to content

Commit 0a34c05

Browse files
author
Kent Overstreet
committed
bcachefs: Ensure bch_sb_field_ext always exists
This makes bch_sb_field_ext more consistent with the rest of -o nochanges - we don't want to be varying other codepaths based on -o nochanges, since it's used for testing in dry run mode; also fixes some potential null ptr derefs. Signed-off-by: Kent Overstreet <[email protected]>
1 parent 4fe0eee commit 0a34c05

File tree

2 files changed

+16
-17
lines changed

2 files changed

+16
-17
lines changed

fs/bcachefs/recovery.c

Lines changed: 8 additions & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -592,16 +592,9 @@ int bch2_fs_recovery(struct bch_fs *c)
592592

593593
if (!c->opts.nochanges) {
594594
mutex_lock(&c->sb_lock);
595+
struct bch_sb_field_ext *ext = bch2_sb_field_get(c->disk_sb.sb, ext);
595596
bool write_sb = false;
596597

597-
struct bch_sb_field_ext *ext =
598-
bch2_sb_field_get_minsize(&c->disk_sb, ext, sizeof(*ext) / sizeof(u64));
599-
if (!ext) {
600-
ret = -BCH_ERR_ENOSPC_sb;
601-
mutex_unlock(&c->sb_lock);
602-
goto err;
603-
}
604-
605598
if (BCH_SB_HAS_TOPOLOGY_ERRORS(c->disk_sb.sb)) {
606599
ext->recovery_passes_required[0] |=
607600
cpu_to_le64(bch2_recovery_passes_to_stable(BIT_ULL(BCH_RECOVERY_PASS_check_topology)));
@@ -832,6 +825,7 @@ int bch2_fs_recovery(struct bch_fs *c)
832825
}
833826

834827
mutex_lock(&c->sb_lock);
828+
struct bch_sb_field_ext *ext = bch2_sb_field_get(c->disk_sb.sb, ext);
835829
bool write_sb = false;
836830

837831
if (BCH_SB_VERSION_UPGRADE_COMPLETE(c->disk_sb.sb) != le16_to_cpu(c->disk_sb.sb->version)) {
@@ -845,15 +839,12 @@ int bch2_fs_recovery(struct bch_fs *c)
845839
write_sb = true;
846840
}
847841

848-
if (!test_bit(BCH_FS_error, &c->flags)) {
849-
struct bch_sb_field_ext *ext = bch2_sb_field_get(c->disk_sb.sb, ext);
850-
if (ext &&
851-
(!bch2_is_zero(ext->recovery_passes_required, sizeof(ext->recovery_passes_required)) ||
852-
!bch2_is_zero(ext->errors_silent, sizeof(ext->errors_silent)))) {
853-
memset(ext->recovery_passes_required, 0, sizeof(ext->recovery_passes_required));
854-
memset(ext->errors_silent, 0, sizeof(ext->errors_silent));
855-
write_sb = true;
856-
}
842+
if (!test_bit(BCH_FS_error, &c->flags) &&
843+
(!bch2_is_zero(ext->recovery_passes_required, sizeof(ext->recovery_passes_required)) ||
844+
!bch2_is_zero(ext->errors_silent, sizeof(ext->errors_silent)))) {
845+
memset(ext->recovery_passes_required, 0, sizeof(ext->recovery_passes_required));
846+
memset(ext->errors_silent, 0, sizeof(ext->errors_silent));
847+
write_sb = true;
857848
}
858849

859850
if (c->opts.fsck &&

fs/bcachefs/super.c

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1015,8 +1015,16 @@ int bch2_fs_start(struct bch_fs *c)
10151015
for_each_online_member(c, ca)
10161016
bch2_members_v2_get_mut(c->disk_sb.sb, ca->dev_idx)->last_mount = cpu_to_le64(now);
10171017

1018+
struct bch_sb_field_ext *ext =
1019+
bch2_sb_field_get_minsize(&c->disk_sb, ext, sizeof(*ext) / sizeof(u64));
10181020
mutex_unlock(&c->sb_lock);
10191021

1022+
if (!ext) {
1023+
bch_err(c, "insufficient space in superblock for sb_field_ext");
1024+
ret = -BCH_ERR_ENOSPC_sb;
1025+
goto err;
1026+
}
1027+
10201028
for_each_rw_member(c, ca)
10211029
bch2_dev_allocator_add(c, ca);
10221030
bch2_recalc_capacity(c);

0 commit comments

Comments
 (0)