mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-13 19:50:25 +03:00
ztest: dmu_tx_assign() gets ENOSPC in spa_vdev_remove_thread()
When running zloop, we occasionally see the following crash: dmu_tx_assign(tx, TXG_WAIT) == 0 (0x1c == 0) ASSERT at ../../module/zfs/vdev_removal.c:1507:spa_vdev_remove_thread()/sbin/ztest(+0x89c3)[0x55faf567b9c3] The error value 0x1c is ENOSPC. The transaction used by spa_vdev_remove_thread() should not be able to fail due to being out of space. i.e. we should not call dmu_tx_hold_space(). This will allow the removal thread to schedule its work even when the pool is low on space. The "slop space" will provide enough free space to sync out the txg. Reviewed-by: Igor Kozhukhov <igor@dilos.org> Reviewed-by: Paul Dagnelie <pcd@delphix.com> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Matthew Ahrens <mahrens@delphix.com> External-issue: DLPX-37853 Closes #8889
This commit is contained in:
parent
4f809bddc6
commit
77e64c6fff
@ -1498,7 +1498,7 @@ spa_vdev_remove_thread(void *arg)
|
|||||||
|
|
||||||
dmu_tx_t *tx =
|
dmu_tx_t *tx =
|
||||||
dmu_tx_create_dd(spa_get_dsl(spa)->dp_mos_dir);
|
dmu_tx_create_dd(spa_get_dsl(spa)->dp_mos_dir);
|
||||||
dmu_tx_hold_space(tx, SPA_MAXBLOCKSIZE);
|
|
||||||
VERIFY0(dmu_tx_assign(tx, TXG_WAIT));
|
VERIFY0(dmu_tx_assign(tx, TXG_WAIT));
|
||||||
uint64_t txg = dmu_tx_get_txg(tx);
|
uint64_t txg = dmu_tx_get_txg(tx);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user