mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
switch 9p
here we actually *want* ->d_op for root; setting it allows to get rid of kludge in v9fs_kill_super() since now we have proper ->d_release() for root and don't need to call it manually. Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
c74a1cbb3c
commit
98cd3fb0a2
4 changed files with 6 additions and 10 deletions
|
@ -59,7 +59,6 @@ void v9fs_stat2inode_dotl(struct p9_stat_dotl *, struct inode *);
|
||||||
int v9fs_dir_release(struct inode *inode, struct file *filp);
|
int v9fs_dir_release(struct inode *inode, struct file *filp);
|
||||||
int v9fs_file_open(struct inode *inode, struct file *file);
|
int v9fs_file_open(struct inode *inode, struct file *file);
|
||||||
void v9fs_inode2stat(struct inode *inode, struct p9_wstat *stat);
|
void v9fs_inode2stat(struct inode *inode, struct p9_wstat *stat);
|
||||||
void v9fs_dentry_release(struct dentry *);
|
|
||||||
int v9fs_uflags2omode(int uflags, int extended);
|
int v9fs_uflags2omode(int uflags, int extended);
|
||||||
|
|
||||||
ssize_t v9fs_file_readn(struct file *, char *, char __user *, u32, u64);
|
ssize_t v9fs_file_readn(struct file *, char *, char __user *, u32, u64);
|
||||||
|
|
|
@ -86,7 +86,7 @@ static int v9fs_cached_dentry_delete(const struct dentry *dentry)
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
void v9fs_dentry_release(struct dentry *dentry)
|
static void v9fs_dentry_release(struct dentry *dentry)
|
||||||
{
|
{
|
||||||
struct v9fs_dentry *dent;
|
struct v9fs_dentry *dent;
|
||||||
struct p9_fid *temp, *current_fid;
|
struct p9_fid *temp, *current_fid;
|
||||||
|
|
|
@ -699,11 +699,6 @@ struct dentry *v9fs_vfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
goto error_iput;
|
goto error_iput;
|
||||||
|
|
||||||
inst_out:
|
inst_out:
|
||||||
if (v9ses->cache)
|
|
||||||
d_set_d_op(dentry, &v9fs_cached_dentry_operations);
|
|
||||||
else
|
|
||||||
d_set_d_op(dentry, &v9fs_dentry_operations);
|
|
||||||
|
|
||||||
d_add(dentry, inode);
|
d_add(dentry, inode);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
|
|
@ -141,6 +141,11 @@ static struct dentry *v9fs_mount(struct file_system_type *fs_type, int flags,
|
||||||
}
|
}
|
||||||
v9fs_fill_super(sb, v9ses, flags, data);
|
v9fs_fill_super(sb, v9ses, flags, data);
|
||||||
|
|
||||||
|
if (v9ses->cache)
|
||||||
|
sb->s_d_op = &v9fs_cached_dentry_operations;
|
||||||
|
else
|
||||||
|
sb->s_d_op = &v9fs_dentry_operations;
|
||||||
|
|
||||||
inode = v9fs_get_inode(sb, S_IFDIR | mode);
|
inode = v9fs_get_inode(sb, S_IFDIR | mode);
|
||||||
if (IS_ERR(inode)) {
|
if (IS_ERR(inode)) {
|
||||||
retval = PTR_ERR(inode);
|
retval = PTR_ERR(inode);
|
||||||
|
@ -217,9 +222,6 @@ static void v9fs_kill_super(struct super_block *s)
|
||||||
|
|
||||||
P9_DPRINTK(P9_DEBUG_VFS, " %p\n", s);
|
P9_DPRINTK(P9_DEBUG_VFS, " %p\n", s);
|
||||||
|
|
||||||
if (s->s_root)
|
|
||||||
v9fs_dentry_release(s->s_root); /* clunk root */
|
|
||||||
|
|
||||||
kill_anon_super(s);
|
kill_anon_super(s);
|
||||||
|
|
||||||
v9fs_session_cancel(v9ses);
|
v9fs_session_cancel(v9ses);
|
||||||
|
|
Loading…
Reference in a new issue