diff options
| author | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2011-07-27 00:54:47 -0700 | 
|---|---|---|
| committer | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2011-07-27 00:54:47 -0700 | 
| commit | aa7eb8e78d8ecd6cd0475d86ea8385ff9cb47ece (patch) | |
| tree | 3f9e98fadd5124fb05e8f6f9b06aa23698d4f215 /fs/proc/inode.c | |
| parent | cca8edfd2ec2a34d9f50f593bc753bb11e1bc1f5 (diff) | |
| parent | 3c6b50141ef9f0a8844bf1357b80c0cdf518bf05 (diff) | |
Merge branch 'next' into for-linus
Diffstat (limited to 'fs/proc/inode.c')
| -rw-r--r-- | fs/proc/inode.c | 7 | 
1 files changed, 7 insertions, 0 deletions
| diff --git a/fs/proc/inode.c b/fs/proc/inode.c index d15aa1b1cc8..74b48cfa1bb 100644 --- a/fs/proc/inode.c +++ b/fs/proc/inode.c @@ -28,6 +28,7 @@ static void proc_evict_inode(struct inode *inode)  {  	struct proc_dir_entry *de;  	struct ctl_table_header *head; +	const struct proc_ns_operations *ns_ops;  	truncate_inode_pages(&inode->i_data, 0);  	end_writeback(inode); @@ -44,6 +45,10 @@ static void proc_evict_inode(struct inode *inode)  		rcu_assign_pointer(PROC_I(inode)->sysctl, NULL);  		sysctl_head_put(head);  	} +	/* Release any associated namespace */ +	ns_ops = PROC_I(inode)->ns_ops; +	if (ns_ops && ns_ops->put) +		ns_ops->put(PROC_I(inode)->ns);  }  static struct kmem_cache * proc_inode_cachep; @@ -62,6 +67,8 @@ static struct inode *proc_alloc_inode(struct super_block *sb)  	ei->pde = NULL;  	ei->sysctl = NULL;  	ei->sysctl_entry = NULL; +	ei->ns = NULL; +	ei->ns_ops = NULL;  	inode = &ei->vfs_inode;  	inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME;  	return inode; | 
