|
@@ -223,7 +223,6 @@ struct dentry *ceph_lookup_open(struct inode *dir, struct dentry *dentry,
|
|
|
struct ceph_fs_client *fsc = ceph_sb_to_client(dir->i_sb);
|
|
|
struct ceph_mds_client *mdsc = fsc->mdsc;
|
|
|
struct file *file = nd->intent.open.file;
|
|
|
- struct inode *parent_inode = get_dentry_parent_inode(file->f_dentry);
|
|
|
struct ceph_mds_request *req;
|
|
|
int err;
|
|
|
int flags = nd->intent.open.flags - 1; /* silly vfs! */
|
|
@@ -242,7 +241,9 @@ struct dentry *ceph_lookup_open(struct inode *dir, struct dentry *dentry,
|
|
|
req->r_dentry_unless = CEPH_CAP_FILE_EXCL;
|
|
|
}
|
|
|
req->r_locked_dir = dir; /* caller holds dir->i_mutex */
|
|
|
- err = ceph_mdsc_do_request(mdsc, parent_inode, req);
|
|
|
+ err = ceph_mdsc_do_request(mdsc,
|
|
|
+ (flags & (O_CREAT|O_TRUNC)) ? dir : NULL,
|
|
|
+ req);
|
|
|
dentry = ceph_finish_lookup(req, dentry, err);
|
|
|
if (!err && (flags & O_CREAT) && !req->r_reply_info.head->is_dentry)
|
|
|
err = ceph_handle_notrace_create(dir, dentry);
|