struct inode *parent =
file_dentry(filp)->d_parent->d_inode;
- if (ll_have_md_lock(parent, &ibits, LCK_MINMODE))
+ if (ll_have_md_lock(ll_i2mdexp(parent), parent, &ibits,
+ LCK_MINMODE))
pfid = *ll_inode2fid(parent);
}
* \param l_req_mode [IN] searched lock mode
* \retval boolean, true iff all bits are found
*/
-int ll_have_md_lock(struct inode *inode, __u64 *bits, enum ldlm_mode l_req_mode)
+int ll_have_md_lock(struct obd_export *exp, struct inode *inode, __u64 *bits,
+ enum ldlm_mode l_req_mode)
{
struct lustre_handle lockh;
union ldlm_policy_data policy;
if (policy.l_inodebits.bits == 0)
continue;
- if (md_lock_match(ll_i2mdexp(inode), flags, fid, LDLM_IBITS,
- &policy, mode, &lockh)) {
+ if (md_lock_match(exp, flags, fid, LDLM_IBITS, &policy, mode,
+ &lockh)) {
struct ldlm_lock *lock;
lock = ldlm_handle2lock(&lockh);
/* llite/file.c */
extern const struct inode_operations ll_file_inode_operations;
const struct file_operations *ll_select_file_operations(struct ll_sb_info *sbi);
-extern int ll_have_md_lock(struct inode *inode, __u64 *bits,
- enum ldlm_mode l_req_mode);
+extern int ll_have_md_lock(struct obd_export *exp, struct inode *inode,
+ __u64 *bits, enum ldlm_mode l_req_mode);
extern enum ldlm_mode ll_take_md_lock(struct inode *inode, __u64 bits,
struct lustre_handle *lockh, __u64 flags,
enum ldlm_mode mode);
/* For OPEN locks we differentiate between lock modes
* LCK_CR, LCK_CW, LCK_PR - bug 22891 */
if (bits & MDS_INODELOCK_OPEN)
- ll_have_md_lock(inode, &bits, lock->l_req_mode);
+ ll_have_md_lock(lock->l_conn_export, inode, &bits,
+ lock->l_req_mode);
if (bits & MDS_INODELOCK_OPEN) {
fmode_t fmode;
if (bits & (MDS_INODELOCK_LOOKUP | MDS_INODELOCK_UPDATE |
MDS_INODELOCK_LAYOUT | MDS_INODELOCK_PERM |
MDS_INODELOCK_DOM))
- ll_have_md_lock(inode, &bits, LCK_MINMODE);
+ ll_have_md_lock(lock->l_conn_export, inode, &bits, LCK_MINMODE);
if (bits & MDS_INODELOCK_DOM) {
rc = ll_dom_lock_cancel(inode, lock);
unlock_res_and_lock(lock);
inode = ll_inode_from_resource_lock(lock);
- ll_have_md_lock(inode, &bits, mode);
+ ll_have_md_lock(lock->l_conn_export, inode, &bits, mode);
iput(inode);
return !!(bits);
}
{
struct obd_device *obd = exp->exp_obd;
struct lmv_obd *lmv = &obd->u.lmv;
- enum ldlm_mode rc;
struct lu_tgt_desc *tgt;
- int i;
+ __u64 bits = policy->l_inodebits.bits;
+ enum ldlm_mode rc = LCK_MINMODE;
int index;
+ int i;
- ENTRY;
-
- CDEBUG(D_INODE, "Lock match for "DFID"\n", PFID(fid));
-
- /*
- * With DNE every object can have two locks in different namespaces:
+ /* only one bit is set */
+ LASSERT(bits && !(bits & (bits - 1)));
+ /* With DNE every object can have two locks in different namespaces:
* lookup lock in space of MDT storing direntry and update/open lock in
* space of MDT storing inode. Try the MDT that the FID maps to first,
* since this can be easily found, and only try others if that fails.
*/
- for (i = 0, index = lmv_fid2tgt_index(lmv, fid);
- i < lmv->lmv_mdt_descs.ltd_tgts_size;
- i++, index = (index + 1) % lmv->lmv_mdt_descs.ltd_tgts_size) {
- if (index < 0) {
- CDEBUG(D_HA, "%s: "DFID" is inaccessible: rc = %d\n",
- obd->obd_name, PFID(fid), index);
- index = 0;
+ if (bits == MDS_INODELOCK_LOOKUP) {
+ for (i = 0, index = lmv_fid2tgt_index(lmv, fid);
+ i < lmv->lmv_mdt_descs.ltd_tgts_size; i++,
+ index = (index + 1) % lmv->lmv_mdt_descs.ltd_tgts_size) {
+ if (index < 0) {
+ CDEBUG(D_HA,
+ "%s: "DFID" is inaccessible: rc = %d\n",
+ obd->obd_name, PFID(fid), index);
+ index = 0;
+ }
+ tgt = lmv_tgt(lmv, index);
+ if (!tgt || !tgt->ltd_exp || !tgt->ltd_active)
+ continue;
+ rc = md_lock_match(tgt->ltd_exp, flags, fid, type,
+ policy, mode, lockh);
+ if (rc)
+ break;
}
-
- tgt = lmv_tgt(lmv, index);
- if (!tgt || !tgt->ltd_exp || !tgt->ltd_active)
- continue;
-
- rc = md_lock_match(tgt->ltd_exp, flags, fid, type, policy, mode,
- lockh);
- if (rc)
- RETURN(rc);
+ } else {
+ tgt = lmv_fid2tgt(lmv, fid);
+ if (!IS_ERR(tgt) && tgt->ltd_exp && tgt->ltd_active)
+ rc = md_lock_match(tgt->ltd_exp, flags, fid, type,
+ policy, mode, lockh);
}
- RETURN(0);
+ CDEBUG(D_INODE, "Lock match for "DFID": %d\n", PFID(fid), rc);
+
+ return rc;
}
static int