d_path: Make d_path() use a struct path

d_path() is used on a <dentry,vfsmount> pair.  Lets use a struct path to
reflect this.

[akpm@linux-foundation.org: fix build in mm/memory.c]
Signed-off-by: Jan Blunck <jblunck@suse.de>
Acked-by: Bryan Wu <bryan.wu@analog.com>
Acked-by: Christoph Hellwig <hch@infradead.org>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Cc: "J. Bruce Fields" <bfields@fieldses.org>
Cc: Neil Brown <neilb@suse.de>
Cc: Michael Halcrow <mhalcrow@us.ibm.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
Jan Blunck 2008-02-14 19:38:44 -08:00 committed by Linus Torvalds
parent c32c2f63a9
commit cf28b4863f
12 changed files with 24 additions and 36 deletions

View File

@ -126,15 +126,13 @@ static void decode_address(char *buf, unsigned long address)
struct vm_area_struct *vma = vml->vma; struct vm_area_struct *vma = vml->vma;
if (address >= vma->vm_start && address < vma->vm_end) { if (address >= vma->vm_start && address < vma->vm_end) {
char _tmpbuf[256];
char *name = p->comm; char *name = p->comm;
struct file *file = vma->vm_file; struct file *file = vma->vm_file;
if (file) {
char _tmpbuf[256]; if (file)
name = d_path(file->f_dentry, name = d_path(&file->f_path, _tmpbuf,
file->f_vfsmnt, sizeof(_tmpbuf));
_tmpbuf,
sizeof(_tmpbuf));
}
/* FLAT does not have its text aligned to the start of /* FLAT does not have its text aligned to the start of
* the map while FDPIC ELF does ... * the map while FDPIC ELF does ...

View File

@ -206,16 +206,10 @@ static void bitmap_checkfree(struct bitmap *bitmap, unsigned long page)
/* copy the pathname of a file to a buffer */ /* copy the pathname of a file to a buffer */
char *file_path(struct file *file, char *buf, int count) char *file_path(struct file *file, char *buf, int count)
{ {
struct dentry *d;
struct vfsmount *v;
if (!buf) if (!buf)
return NULL; return NULL;
d = file->f_path.dentry; buf = d_path(&file->f_path, buf, count);
v = file->f_path.mnt;
buf = d_path(d, v, buf, count);
return IS_ERR(buf) ? NULL : buf; return IS_ERR(buf) ? NULL : buf;
} }

View File

@ -3563,8 +3563,7 @@ static ssize_t show_file(struct device *dev, struct device_attribute *attr,
down_read(&fsg->filesem); down_read(&fsg->filesem);
if (backing_file_is_open(curlun)) { // Get the complete pathname if (backing_file_is_open(curlun)) { // Get the complete pathname
p = d_path(curlun->filp->f_path.dentry, p = d_path(&curlun->filp->f_path, buf, PAGE_SIZE - 1);
curlun->filp->f_path.mnt, buf, PAGE_SIZE - 1);
if (IS_ERR(p)) if (IS_ERR(p))
rc = PTR_ERR(p); rc = PTR_ERR(p);
else { else {
@ -3981,9 +3980,8 @@ static int __init fsg_bind(struct usb_gadget *gadget)
if (backing_file_is_open(curlun)) { if (backing_file_is_open(curlun)) {
p = NULL; p = NULL;
if (pathbuf) { if (pathbuf) {
p = d_path(curlun->filp->f_path.dentry, p = d_path(&curlun->filp->f_path,
curlun->filp->f_path.mnt, pathbuf, PATH_MAX);
pathbuf, PATH_MAX);
if (IS_ERR(p)) if (IS_ERR(p))
p = NULL; p = NULL;
} }

View File

@ -2853,7 +2853,7 @@ static void compat_ioctl_error(struct file *filp, unsigned int fd,
/* find the name of the device. */ /* find the name of the device. */
path = (char *)__get_free_page(GFP_KERNEL); path = (char *)__get_free_page(GFP_KERNEL);
if (path) { if (path) {
fn = d_path(filp->f_path.dentry, filp->f_path.mnt, path, PAGE_SIZE); fn = d_path(&filp->f_path, path, PAGE_SIZE);
if (IS_ERR(fn)) if (IS_ERR(fn))
fn = "?"; fn = "?";
} }

View File

@ -1845,8 +1845,7 @@ Elong:
/** /**
* d_path - return the path of a dentry * d_path - return the path of a dentry
* @dentry: dentry to report * @path: path to report
* @vfsmnt: vfsmnt to which the dentry belongs
* @buf: buffer to return value in * @buf: buffer to return value in
* @buflen: buffer length * @buflen: buffer length
* *
@ -1857,8 +1856,7 @@ Elong:
* *
* "buflen" should be positive. Caller holds the dcache_lock. * "buflen" should be positive. Caller holds the dcache_lock.
*/ */
char *d_path(struct dentry *dentry, struct vfsmount *vfsmnt, char *d_path(struct path *path, char *buf, int buflen)
char *buf, int buflen)
{ {
char *res; char *res;
struct path root; struct path root;
@ -1870,15 +1868,15 @@ char *d_path(struct dentry *dentry, struct vfsmount *vfsmnt,
* user wants to identify the object in /proc/pid/fd/. The little hack * user wants to identify the object in /proc/pid/fd/. The little hack
* below allows us to generate a name for these objects on demand: * below allows us to generate a name for these objects on demand:
*/ */
if (dentry->d_op && dentry->d_op->d_dname) if (path->dentry->d_op && path->dentry->d_op->d_dname)
return dentry->d_op->d_dname(dentry, buf, buflen); return path->dentry->d_op->d_dname(path->dentry, buf, buflen);
read_lock(&current->fs->lock); read_lock(&current->fs->lock);
root = current->fs->root; root = current->fs->root;
path_get(&current->fs->root); path_get(&current->fs->root);
read_unlock(&current->fs->lock); read_unlock(&current->fs->lock);
spin_lock(&dcache_lock); spin_lock(&dcache_lock);
res = __d_path(dentry, vfsmnt, &root, buf, buflen); res = __d_path(path->dentry, path->mnt, &root, buf, buflen);
spin_unlock(&dcache_lock); spin_unlock(&dcache_lock);
path_put(&root); path_put(&root);
return res; return res;

View File

@ -171,7 +171,7 @@ asmlinkage long sys_lookup_dcookie(u64 cookie64, char __user * buf, size_t len)
goto out; goto out;
/* FIXME: (deleted) ? */ /* FIXME: (deleted) ? */
path = d_path(dcs->path.dentry, dcs->path.mnt, kbuf, PAGE_SIZE); path = d_path(&dcs->path, kbuf, PAGE_SIZE);
if (IS_ERR(path)) { if (IS_ERR(path)) {
err = PTR_ERR(path); err = PTR_ERR(path);

View File

@ -345,7 +345,7 @@ static void svc_export_request(struct cache_detail *cd,
char *pth; char *pth;
qword_add(bpp, blen, exp->ex_client->name); qword_add(bpp, blen, exp->ex_client->name);
pth = d_path(exp->ex_path.dentry, exp->ex_path.mnt, *bpp, *blen); pth = d_path(&exp->ex_path, *bpp, *blen);
if (IS_ERR(pth)) { if (IS_ERR(pth)) {
/* is this correct? */ /* is this correct? */
(*bpp)[0] = '\n'; (*bpp)[0] = '\n';

View File

@ -1185,7 +1185,7 @@ static int do_proc_readlink(struct path *path, char __user *buffer, int buflen)
if (!tmp) if (!tmp)
return -ENOMEM; return -ENOMEM;
pathname = d_path(path->dentry, path->mnt, tmp, PAGE_SIZE); pathname = d_path(path, tmp, PAGE_SIZE);
len = PTR_ERR(pathname); len = PTR_ERR(pathname);
if (IS_ERR(pathname)) if (IS_ERR(pathname))
goto out; goto out;

View File

@ -346,8 +346,7 @@ int seq_path(struct seq_file *m, struct path *path, char *esc)
{ {
if (m->count < m->size) { if (m->count < m->size) {
char *s = m->buf + m->count; char *s = m->buf + m->count;
char *p = d_path(path->dentry, path->mnt, s, char *p = d_path(path, s, m->size - m->count);
m->size - m->count);
if (!IS_ERR(p)) { if (!IS_ERR(p)) {
while (s <= p) { while (s <= p) {
char c = *p++; char c = *p++;

View File

@ -10,6 +10,7 @@
#include <linux/rcupdate.h> #include <linux/rcupdate.h>
struct nameidata; struct nameidata;
struct path;
struct vfsmount; struct vfsmount;
/* /*
@ -300,8 +301,8 @@ extern int d_validate(struct dentry *, struct dentry *);
*/ */
extern char *dynamic_dname(struct dentry *, char *, int, const char *, ...); extern char *dynamic_dname(struct dentry *, char *, int, const char *, ...);
extern char * d_path(struct dentry *, struct vfsmount *, char *, int); extern char *d_path(struct path *, char *, int);
/* Allocation counts.. */ /* Allocation counts.. */
/** /**

View File

@ -1325,7 +1325,7 @@ void audit_log_d_path(struct audit_buffer *ab, const char *prefix,
audit_log_format(ab, "<no memory>"); audit_log_format(ab, "<no memory>");
return; return;
} }
p = d_path(path->dentry, path->mnt, pathname, PATH_MAX+11); p = d_path(path, pathname, PATH_MAX+11);
if (IS_ERR(p)) { /* Should never happen since we send PATH_MAX */ if (IS_ERR(p)) { /* Should never happen since we send PATH_MAX */
/* FIXME: can we save some information here? */ /* FIXME: can we save some information here? */
audit_log_format(ab, "<too long>"); audit_log_format(ab, "<too long>");

View File

@ -2719,7 +2719,7 @@ void print_vma_addr(char *prefix, unsigned long ip)
if (buf) { if (buf) {
char *p, *s; char *p, *s;
p = d_path(f->f_dentry, f->f_vfsmnt, buf, PAGE_SIZE); p = d_path(&f->f_path, buf, PAGE_SIZE);
if (IS_ERR(p)) if (IS_ERR(p))
p = "?"; p = "?";
s = strrchr(p, '/'); s = strrchr(p, '/');