提交 fae683f7 编写于 作者: S Suresh Jayaraman 提交者: Steve French

cifs: add comments explaining cifs_new_fileinfo behavior

The comments make it clear the otherwise subtle behavior of cifs_new_fileinfo().
Signed-off-by: NSuresh Jayaraman <sjayaraman@suse.de>
Reviewed-by: NShirish Pargaonkar <shirishp@us.ibm.com>
--
 fs/cifs/dir.c |   18 ++++++++++++++++--
 1 files changed, 16 insertions(+), 2 deletions(-)
Signed-off-by: NSteve French <sfrench@us.ibm.com>
上级 51c81764
...@@ -129,6 +129,12 @@ build_path_from_dentry(struct dentry *direntry) ...@@ -129,6 +129,12 @@ build_path_from_dentry(struct dentry *direntry)
return full_path; return full_path;
} }
/*
* When called with struct file pointer set to NULL, there is no way we could
* update file->private_data, but getting it stuck on openFileList provides a
* way to access it from cifs_fill_filedata and thereby set file->private_data
* from cifs_open.
*/
struct cifsFileInfo * struct cifsFileInfo *
cifs_new_fileinfo(struct inode *newinode, __u16 fileHandle, cifs_new_fileinfo(struct inode *newinode, __u16 fileHandle,
struct file *file, struct vfsmount *mnt, unsigned int oflags) struct file *file, struct vfsmount *mnt, unsigned int oflags)
...@@ -251,6 +257,10 @@ int cifs_posix_open(char *full_path, struct inode **pinode, ...@@ -251,6 +257,10 @@ int cifs_posix_open(char *full_path, struct inode **pinode,
cifs_fattr_to_inode(*pinode, &fattr); cifs_fattr_to_inode(*pinode, &fattr);
} }
/*
* cifs_fill_filedata() takes care of setting cifsFileInfo pointer to
* file->private_data.
*/
if (mnt) if (mnt)
cifs_new_fileinfo(*pinode, *pnetfid, NULL, mnt, oflags); cifs_new_fileinfo(*pinode, *pnetfid, NULL, mnt, oflags);
...@@ -466,8 +476,12 @@ cifs_create(struct inode *inode, struct dentry *direntry, int mode, ...@@ -466,8 +476,12 @@ cifs_create(struct inode *inode, struct dentry *direntry, int mode,
/* mknod case - do not leave file open */ /* mknod case - do not leave file open */
CIFSSMBClose(xid, tcon, fileHandle); CIFSSMBClose(xid, tcon, fileHandle);
} else if (!(posix_create) && (newinode)) { } else if (!(posix_create) && (newinode)) {
cifs_new_fileinfo(newinode, fileHandle, NULL, /*
nd->path.mnt, oflags); * cifs_fill_filedata() takes care of setting cifsFileInfo
* pointer to file->private_data.
*/
cifs_new_fileinfo(newinode, fileHandle, NULL, nd->path.mnt,
oflags);
} }
cifs_create_out: cifs_create_out:
kfree(buf); kfree(buf);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册