mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-13 11:40:25 +03:00
dmu_tx: Fix possible NULL pointer dereference
dmu_tx_hold_object_impl can return NULL on error. Check for this condition prior to dereferencing pointer. This can only occur if the passed object was invalid or unallocated. Signed-off-by: Nathaniel Clark <Nathaniel.Clark@misrule.us> Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Closes #1610
This commit is contained in:
parent
cb543e6b5e
commit
7d63721118
@ -773,12 +773,13 @@ void
|
|||||||
dmu_tx_hold_space(dmu_tx_t *tx, uint64_t space)
|
dmu_tx_hold_space(dmu_tx_t *tx, uint64_t space)
|
||||||
{
|
{
|
||||||
dmu_tx_hold_t *txh;
|
dmu_tx_hold_t *txh;
|
||||||
|
|
||||||
ASSERT(tx->tx_txg == 0);
|
ASSERT(tx->tx_txg == 0);
|
||||||
|
|
||||||
txh = dmu_tx_hold_object_impl(tx, tx->tx_objset,
|
txh = dmu_tx_hold_object_impl(tx, tx->tx_objset,
|
||||||
DMU_NEW_OBJECT, THT_SPACE, space, 0);
|
DMU_NEW_OBJECT, THT_SPACE, space, 0);
|
||||||
|
if (txh)
|
||||||
txh->txh_space_towrite += space;
|
txh->txh_space_towrite += space;
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
@ -1320,6 +1321,8 @@ dmu_tx_hold_spill(dmu_tx_t *tx, uint64_t object)
|
|||||||
|
|
||||||
txh = dmu_tx_hold_object_impl(tx, tx->tx_objset, object,
|
txh = dmu_tx_hold_object_impl(tx, tx->tx_objset, object,
|
||||||
THT_SPILL, 0, 0);
|
THT_SPILL, 0, 0);
|
||||||
|
if (txh == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
dn = txh->txh_dnode;
|
dn = txh->txh_dnode;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user