mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2024-12-26 19:19:32 +03:00
Reduce stack usage of dsl_dir_tempreserve_impl
Buildbots and zfs-tests regularly see 7 kilobytes of stack usage with this function. Convert self-calls to iterations Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: DHE <git@dehacked.net> Closes #6219
This commit is contained in:
parent
851aa99c89
commit
419c80e6dc
@ -1119,11 +1119,16 @@ dsl_dir_tempreserve_impl(dsl_dir_t *dd, uint64_t asize, boolean_t netfree,
|
|||||||
boolean_t ignorequota, list_t *tr_list,
|
boolean_t ignorequota, list_t *tr_list,
|
||||||
dmu_tx_t *tx, boolean_t first)
|
dmu_tx_t *tx, boolean_t first)
|
||||||
{
|
{
|
||||||
uint64_t txg = tx->tx_txg;
|
uint64_t txg;
|
||||||
uint64_t quota;
|
uint64_t quota;
|
||||||
struct tempreserve *tr;
|
struct tempreserve *tr;
|
||||||
int retval = EDQUOT;
|
int retval;
|
||||||
uint64_t ref_rsrv = 0;
|
uint64_t ref_rsrv;
|
||||||
|
|
||||||
|
top_of_function:
|
||||||
|
txg = tx->tx_txg;
|
||||||
|
retval = EDQUOT;
|
||||||
|
ref_rsrv = 0;
|
||||||
|
|
||||||
ASSERT3U(txg, !=, 0);
|
ASSERT3U(txg, !=, 0);
|
||||||
ASSERT3S(asize, >, 0);
|
ASSERT3S(asize, >, 0);
|
||||||
@ -1220,10 +1225,18 @@ dsl_dir_tempreserve_impl(dsl_dir_t *dd, uint64_t asize, boolean_t netfree,
|
|||||||
|
|
||||||
/* see if it's OK with our parent */
|
/* see if it's OK with our parent */
|
||||||
if (dd->dd_parent != NULL && parent_rsrv != 0) {
|
if (dd->dd_parent != NULL && parent_rsrv != 0) {
|
||||||
boolean_t ismos = (dsl_dir_phys(dd)->dd_head_dataset_obj == 0);
|
/*
|
||||||
|
* Recurse on our parent without recursion. This has been
|
||||||
|
* observed to be potentially large stack usage even within
|
||||||
|
* the test suite. Largest seen stack was 7632 bytes on linux.
|
||||||
|
*/
|
||||||
|
|
||||||
|
dd = dd->dd_parent;
|
||||||
|
asize = parent_rsrv;
|
||||||
|
ignorequota = (dsl_dir_phys(dd)->dd_head_dataset_obj == 0);
|
||||||
|
first = B_FALSE;
|
||||||
|
goto top_of_function;
|
||||||
|
|
||||||
return (dsl_dir_tempreserve_impl(dd->dd_parent,
|
|
||||||
parent_rsrv, netfree, ismos, tr_list, tx, B_FALSE));
|
|
||||||
} else {
|
} else {
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user