mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-07 16:50:26 +03:00
Fix infinite scan on a pool with only special allocations
Attempt to run scrub or resilver on a new pool containing only special allocations (special vdev added on creation) caused infinite loop because of dsl_scan_should_clear() limiting memory usage to 5% of pool size, which it calculated accounting only normal allocation class. Addition of special and just in case dedup classes fixes the issue. Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Alexander Motin <mav@FreeBSD.org> Sponsored-By: iXsystems, Inc. Closes #10106 Closes #8694
This commit is contained in:
parent
0cbed7f026
commit
4e55349857
@ -1187,10 +1187,13 @@ scan_ds_queue_sync(dsl_scan_t *scn, dmu_tx_t *tx)
|
|||||||
static boolean_t
|
static boolean_t
|
||||||
dsl_scan_should_clear(dsl_scan_t *scn)
|
dsl_scan_should_clear(dsl_scan_t *scn)
|
||||||
{
|
{
|
||||||
|
spa_t *spa = scn->scn_dp->dp_spa;
|
||||||
vdev_t *rvd = scn->scn_dp->dp_spa->spa_root_vdev;
|
vdev_t *rvd = scn->scn_dp->dp_spa->spa_root_vdev;
|
||||||
uint64_t mlim_hard, mlim_soft, mused;
|
uint64_t alloc, mlim_hard, mlim_soft, mused;
|
||||||
uint64_t alloc = metaslab_class_get_alloc(spa_normal_class(
|
|
||||||
scn->scn_dp->dp_spa));
|
alloc = metaslab_class_get_alloc(spa_normal_class(spa));
|
||||||
|
alloc += metaslab_class_get_alloc(spa_special_class(spa));
|
||||||
|
alloc += metaslab_class_get_alloc(spa_dedup_class(spa));
|
||||||
|
|
||||||
mlim_hard = MAX((physmem / zfs_scan_mem_lim_fact) * PAGESIZE,
|
mlim_hard = MAX((physmem / zfs_scan_mem_lim_fact) * PAGESIZE,
|
||||||
zfs_scan_mem_lim_min);
|
zfs_scan_mem_lim_min);
|
||||||
|
Loading…
Reference in New Issue
Block a user