stripe = le32_to_cpu(ma->ma_lmm->lmm_stripe_count);
log_credits = stripe * dto_txn_credits[DTO_LOG_REC];
- mdd_env_info(env)->mti_param.tp_credits += log_credits;
+ txn_param_credit_add(&mdd_env_info(env)->mti_param, log_credits);
RETURN(rc);
}
mdd_txn_param_build(env, mdd, op);
if (ma->ma_attr.la_valid & (LA_UID | LA_GID))
- mdd_env_info(env)->mti_param.tp_credits =
- dto_txn_credits[DTO_ATTR_SET_CHOWN];
+ txn_param_credit_add(&mdd_env_info(env)->mti_param,
+ dto_txn_credits[DTO_ATTR_SET_CHOWN]);
+
+ /* permission changes may require sync operation */
+ if (ma->ma_attr.la_valid & (LA_MODE|LA_UID|LA_GID) &&
+ mdd->mdd_sync_permission == 1)
+ txn_param_sync(&mdd_env_info(env)->mti_param);
RETURN(0);
}
for (op = 0; op < DTO_NR; op++) {
credits = mdd_child_ops(mdd)->dt_credit_get(env, mdd->mdd_child,
op);
- LASSERT(credits > 0);
+ LASSERT(credits >= 0);
dto_txn_credits[op] = credits;
}
}
{
struct txn_param *p = &mdd_env_info(env)->mti_param;
struct thandle *th;
-
+
th = mdd_child_ops(mdd)->dt_trans_start(env, mdd->mdd_child, p);
return th;
}