diff options
Diffstat (limited to 'fs/kernfs/mount.c')
| -rw-r--r-- | fs/kernfs/mount.c | 20 | 
1 files changed, 17 insertions, 3 deletions
| diff --git a/fs/kernfs/mount.c b/fs/kernfs/mount.c index f73541fbe7af..63534f5f9073 100644 --- a/fs/kernfs/mount.c +++ b/fs/kernfs/mount.c @@ -15,6 +15,7 @@  #include <linux/slab.h>  #include <linux/pagemap.h>  #include <linux/namei.h> +#include <linux/seq_file.h>  #include "kernfs-internal.h" @@ -40,6 +41,19 @@ static int kernfs_sop_show_options(struct seq_file *sf, struct dentry *dentry)  	return 0;  } +static int kernfs_sop_show_path(struct seq_file *sf, struct dentry *dentry) +{ +	struct kernfs_node *node = dentry->d_fsdata; +	struct kernfs_root *root = kernfs_root(node); +	struct kernfs_syscall_ops *scops = root->syscall_ops; + +	if (scops && scops->show_path) +		return scops->show_path(sf, node, root); + +	seq_dentry(sf, dentry, " \t\n\\"); +	return 0; +} +  const struct super_operations kernfs_sops = {  	.statfs		= simple_statfs,  	.drop_inode	= generic_delete_inode, @@ -47,6 +61,7 @@ const struct super_operations kernfs_sops = {  	.remount_fs	= kernfs_sop_remount_fs,  	.show_options	= kernfs_sop_show_options, +	.show_path	= kernfs_sop_show_path,  };  /** @@ -120,9 +135,8 @@ struct dentry *kernfs_node_dentry(struct kernfs_node *kn,  		kntmp = find_next_ancestor(kn, knparent);  		if (WARN_ON(!kntmp))  			return ERR_PTR(-EINVAL); -		mutex_lock(&d_inode(dentry)->i_mutex); -		dtmp = lookup_one_len(kntmp->name, dentry, strlen(kntmp->name)); -		mutex_unlock(&d_inode(dentry)->i_mutex); +		dtmp = lookup_one_len_unlocked(kntmp->name, dentry, +					       strlen(kntmp->name));  		dput(dentry);  		if (IS_ERR(dtmp))  			return dtmp; | 
