aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlexander Motin <[email protected]>2024-11-21 11:20:22 -0500
committerGitHub <[email protected]>2024-11-21 08:20:22 -0800
commitae1d11882d10afb388e749684f8020b38de8504a (patch)
treef6746cfc729803411d2cca70e8d0aa4aeed42be5
parent225e76cd7d43939751bfbcdefaea28b58699cbf1 (diff)
BRT: Clear bv_entcount_dirty on destroy
This fixes assertion in brt_sync_table() on debug builds when last cloned block on the vdev is freed and bv_meta_dirty is cleared, while bv_entcount_dirty is not. Should not matter in production. Reviewed-by: Brian Behlendorf <[email protected]> Signed-off-by: Alexander Motin <[email protected]> Sponsored by: iXsystems, Inc. Closes #16791
-rw-r--r--module/zfs/brt.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/module/zfs/brt.c b/module/zfs/brt.c
index c48527db7..9afee4e20 100644
--- a/module/zfs/brt.c
+++ b/module/zfs/brt.c
@@ -642,6 +642,7 @@ brt_vdev_destroy(spa_t *spa, brt_vdev_t *brtvd, dmu_tx_t *tx)
BRT_DEBUG("MOS BRT VDEV destroyed, object=%llu",
(u_longlong_t)brtvd->bv_mos_brtvdev);
brtvd->bv_mos_brtvdev = 0;
+ brtvd->bv_entcount_dirty = FALSE;
snprintf(name, sizeof (name), "%s%llu", BRT_OBJECT_VDEV_PREFIX,
(u_longlong_t)brtvd->bv_vdevid);