Commit ea1db081 authored by John L. Hammond's avatar John L. Hammond Committed by Greg Kroah-Hartman

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/6695Signed-off-by: default avatarJohn L. Hammond <john.hammond@intel.com>
Reviewed-by: default avatarFan Yong <fan.yong@intel.com>
Reviewed-by: default avatarMike Pershin <mike.pershin@intel.com>
Reviewed-by: default avatarOleg Drokin <oleg.drokin@intel.com>
Signed-off-by: default avatarPeng Tao <bergwolf@gmail.com>
Signed-off-by: default avatarAndreas Dilger <andreas.dilger@intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 28706a78
...@@ -431,22 +431,17 @@ void ll_ioepoch_open(struct ll_inode_info *lli, __u64 ioepoch) ...@@ -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, ...@@ -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) ...@@ -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);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment