staging/lustre/llite: use correct FID in ll_och_fill()
When ll_intent_file_open() is called on a file with a stale dentry, ll_och_fill() may incorrectly use the FID from the struct ll_inode_info rather than the FID from the response body (which is the correct FID for the close). Fix this, remove the ll_inode_info parameter from ll_och_fill(), and move the call to ll_ioepoch_open() from ll_och_fill() to ll_local_open(). Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-3233 Lustre-change: http://review.whamcloud.com/6695 Signed-off-by: John L. Hammond <john.hammond@intel.com> Reviewed-by: Fan Yong <fan.yong@intel.com> Reviewed-by: Mike Pershin <mike.pershin@intel.com> Reviewed-by: Oleg Drokin <oleg.drokin@intel.com> Signed-off-by: Peng Tao <bergwolf@gmail.com> Signed-off-by: Andreas Dilger <andreas.dilger@intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
28706a78d8
commit
ea1db0814c
@ -431,22 +431,17 @@ void ll_ioepoch_open(struct ll_inode_info *lli, __u64 ioepoch)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ll_och_fill(struct obd_export *md_exp, struct ll_inode_info *lli,
|
static int ll_och_fill(struct obd_export *md_exp, struct lookup_intent *it,
|
||||||
struct lookup_intent *it, struct obd_client_handle *och)
|
struct obd_client_handle *och)
|
||||||
{
|
{
|
||||||
struct ptlrpc_request *req = it->d.lustre.it_data;
|
struct ptlrpc_request *req = it->d.lustre.it_data;
|
||||||
struct mdt_body *body;
|
struct mdt_body *body;
|
||||||
|
|
||||||
LASSERT(och);
|
|
||||||
|
|
||||||
body = req_capsule_server_get(&req->rq_pill, &RMF_MDT_BODY);
|
body = req_capsule_server_get(&req->rq_pill, &RMF_MDT_BODY);
|
||||||
LASSERT(body != NULL); /* reply already checked out */
|
och->och_fh = body->handle;
|
||||||
|
och->och_fid = body->fid1;
|
||||||
memcpy(&och->och_fh, &body->handle, sizeof(body->handle));
|
|
||||||
och->och_magic = OBD_CLIENT_HANDLE_MAGIC;
|
och->och_magic = OBD_CLIENT_HANDLE_MAGIC;
|
||||||
och->och_fid = lli->lli_fid;
|
|
||||||
och->och_flags = it->it_flags;
|
och->och_flags = it->it_flags;
|
||||||
ll_ioepoch_open(lli, body->ioepoch);
|
|
||||||
|
|
||||||
return md_set_open_replay_data(md_exp, och, req);
|
return md_set_open_replay_data(md_exp, och, req);
|
||||||
}
|
}
|
||||||
@ -466,15 +461,12 @@ int ll_local_open(struct file *file, struct lookup_intent *it,
|
|||||||
struct mdt_body *body;
|
struct mdt_body *body;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
rc = ll_och_fill(ll_i2sbi(inode)->ll_md_exp, lli, it, och);
|
rc = ll_och_fill(ll_i2sbi(inode)->ll_md_exp, it, och);
|
||||||
if (rc)
|
if (rc != 0)
|
||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
body = req_capsule_server_get(&req->rq_pill, &RMF_MDT_BODY);
|
body = req_capsule_server_get(&req->rq_pill, &RMF_MDT_BODY);
|
||||||
if ((it->it_flags & FMODE_WRITE) &&
|
ll_ioepoch_open(lli, body->ioepoch);
|
||||||
(body->valid & OBD_MD_FLSIZE))
|
|
||||||
CDEBUG(D_INODE, "Epoch "LPU64" opened on "DFID"\n",
|
|
||||||
lli->lli_ioepoch, PFID(&lli->lli_fid));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
LUSTRE_FPRIVATE(file) = fd;
|
LUSTRE_FPRIVATE(file) = fd;
|
||||||
@ -1482,8 +1474,7 @@ int ll_release_openhandle(struct dentry *dentry, struct lookup_intent *it)
|
|||||||
if (!och)
|
if (!och)
|
||||||
GOTO(out, rc = -ENOMEM);
|
GOTO(out, rc = -ENOMEM);
|
||||||
|
|
||||||
ll_och_fill(ll_i2sbi(inode)->ll_md_exp,
|
ll_och_fill(ll_i2sbi(inode)->ll_md_exp, it, och);
|
||||||
ll_i2info(inode), it, och);
|
|
||||||
|
|
||||||
rc = ll_close_inode_openhandle(ll_i2sbi(inode)->ll_md_exp,
|
rc = ll_close_inode_openhandle(ll_i2sbi(inode)->ll_md_exp,
|
||||||
inode, och);
|
inode, och);
|
||||||
|
Loading…
Reference in New Issue
Block a user