diff options
author | Daniel Hill <daniel@gluo.nz> | 2023-12-06 21:26:00 +1300 |
---|---|---|
committer | Kent Overstreet <kent.overstreet@linux.dev> | 2023-12-06 17:43:21 -0500 |
commit | e59728883943c6820a0aa413db66a38f2e8c27bd (patch) | |
tree | 679df0a84118ac35c49923adb80e73788ec82eae /fs | |
parent | 5796230582f6131fa217f0a1700783c459c847d2 (diff) | |
download | lwn-e59728883943c6820a0aa413db66a38f2e8c27bd.tar.gz lwn-e59728883943c6820a0aa413db66a38f2e8c27bd.zip |
bcachefs: rebalance shouldn't attempt to compress unwritten extents
This fixes a bug where rebalance would loop repeatedly on the same
extents.
Signed-off-by: Daniel Hill <daniel@gluo.nz>
Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/bcachefs/extents.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/fs/bcachefs/extents.c b/fs/bcachefs/extents.c index f6c92df55270..9d8afcb5979a 100644 --- a/fs/bcachefs/extents.c +++ b/fs/bcachefs/extents.c @@ -1294,7 +1294,8 @@ unsigned bch2_bkey_ptrs_need_rebalance(struct bch_fs *c, struct bkey_s_c k, unsigned i = 0; bkey_for_each_ptr_decode(k.k, ptrs, p, entry) { - if (p.crc.compression_type == BCH_COMPRESSION_TYPE_incompressible) { + if (p.crc.compression_type == BCH_COMPRESSION_TYPE_incompressible || + p.ptr.unwritten) { rewrite_ptrs = 0; goto incompressible; } |