on demand as in very few cases it's called with env undefined.
it would be a very big patch to pass env through all the path
chains..
Change-Id: Ic6819215877891ad95f2937729941453abf981e7
Signed-off-by: Alex Zhuravlev <bzzz@whamcloud.com>
Reviewed-on: https://review.whamcloud.com/33321
Tested-by: Jenkins
Reviewed-by: Patrick Farrell <paf@cray.com>
Tested-by: Maloo <hpdd-maloo@intel.com>
Reviewed-by: Andreas Dilger <adilger@whamcloud.com>
Reviewed-by: Oleg Drokin <green@whamcloud.com>
struct lu_fid *fid;
struct mdt_object *obj = NULL;
struct md_object *child = NULL;
struct lu_fid *fid;
struct mdt_object *obj = NULL;
struct md_object *child = NULL;
+ if (!env) {
+ rc = lu_env_init(&_env, LCT_DT_THREAD);
+ if (rc)
+ RETURN(rc);
+ env = &_env;
+ }
+
mdt = ldlm_lock_to_ns(lock)->ns_lvbp;
if (IS_LQUOTA_RES(lock->l_resource)) {
if (mdt->mdt_qmt_dev == NULL)
mdt = ldlm_lock_to_ns(lock)->ns_lvbp;
if (IS_LQUOTA_RES(lock->l_resource)) {
if (mdt->mdt_qmt_dev == NULL)
/* call lvbo fill function of quota master */
rc = qmt_hdls.qmth_lvbo_fill(mdt->mdt_qmt_dev, lock, lvb,
*lvblen);
/* call lvbo fill function of quota master */
rc = qmt_hdls.qmth_lvbo_fill(mdt->mdt_qmt_dev, lock, lvb,
*lvblen);
}
info = lu_context_key_get(&env->le_ctx, &mdt_thread_key);
}
info = lu_context_key_get(&env->le_ctx, &mdt_thread_key);
out:
if (rc < 0 && rc != -ERANGE)
rc = 0;
out:
if (rc < 0 && rc != -ERANGE)
rc = 0;
+out_env:
+ if (env == &_env)
+ lu_env_fini(&_env);
struct ofd_device *ofd;
struct ofd_object *fo;
struct ofd_thread_info *info;
struct ofd_device *ofd;
struct ofd_object *fo;
struct ofd_thread_info *info;
+ struct lu_env _env;
+ int rc = 0;
- LASSERT(env);
- info = ofd_info(env);
LASSERT(res);
LASSERT(mutex_is_locked(&res->lr_lvb_mutex));
LASSERT(res);
LASSERT(mutex_is_locked(&res->lr_lvb_mutex));
if (OBD_FAIL_CHECK(OBD_FAIL_LDLM_OST_LVB))
RETURN(-ENOMEM);
if (OBD_FAIL_CHECK(OBD_FAIL_LDLM_OST_LVB))
RETURN(-ENOMEM);
+ if (!env) {
+ rc = lu_env_init(&_env, LCT_DT_THREAD);
+ if (rc)
+ RETURN(rc);
+ env = &_env;
+ }
+
OBD_ALLOC_PTR(lvb);
if (lvb == NULL)
GOTO(out, rc = -ENOMEM);
OBD_ALLOC_PTR(lvb);
if (lvb == NULL)
GOTO(out, rc = -ENOMEM);
res->lr_lvb_data = lvb;
res->lr_lvb_len = sizeof(*lvb);
res->lr_lvb_data = lvb;
res->lr_lvb_len = sizeof(*lvb);
OST_LVB_SET_ERR(lvb->lvb_blocks, rc);
out:
/* Don't free lvb data on lookup error */
OST_LVB_SET_ERR(lvb->lvb_blocks, rc);
out:
/* Don't free lvb data on lookup error */
+ if (env && env == &_env)
+ lu_env_fini(&_env);