mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
stop passing nameidata to ->lookup()
Just the flags; only NFS cares even about that, but there are legitimate uses for such argument. And getting rid of that completely would require splitting ->lookup() into a couple of methods (at least), so let's leave that alone for now... Signed-off-by: Al Viro <viro@zeniv.linux.org.uk> Change-Id: Id5a9a96c3202f724156c32fb266190334e7dbe48
This commit is contained in:
parent
fe5cfc12d0
commit
66c4da2876
82 changed files with 121 additions and 123 deletions
|
@ -38,8 +38,7 @@ d_manage: no no yes (ref-walk) maybe
|
||||||
--------------------------- inode_operations ---------------------------
|
--------------------------- inode_operations ---------------------------
|
||||||
prototypes:
|
prototypes:
|
||||||
int (*create) (struct inode *,struct dentry *,umode_t, struct nameidata *);
|
int (*create) (struct inode *,struct dentry *,umode_t, struct nameidata *);
|
||||||
struct dentry * (*lookup) (struct inode *,struct dentry *, struct nameid
|
struct dentry * (*lookup) (struct inode *,struct dentry *, unsigned int);
|
||||||
ata *);
|
|
||||||
int (*link) (struct dentry *,struct inode *,struct dentry *);
|
int (*link) (struct dentry *,struct inode *,struct dentry *);
|
||||||
int (*unlink) (struct inode *,struct dentry *);
|
int (*unlink) (struct inode *,struct dentry *);
|
||||||
int (*symlink) (struct inode *,struct dentry *,const char *);
|
int (*symlink) (struct inode *,struct dentry *,const char *);
|
||||||
|
|
|
@ -438,5 +438,5 @@ d_make_root() drops the reference to inode if dentry allocation fails.
|
||||||
|
|
||||||
--
|
--
|
||||||
[mandatory]
|
[mandatory]
|
||||||
The witch is dead! Well, 1/3 of it, anyway. ->d_revalidate() does *not*
|
The witch is dead! Well, 2/3 of it, anyway. ->d_revalidate() and
|
||||||
take struct nameidata anymore; just the flags.
|
->lookup() do *not* take struct nameidata anymore; just the flags.
|
||||||
|
|
|
@ -342,7 +342,7 @@ filesystem. As of kernel 2.6.22, the following members are defined:
|
||||||
|
|
||||||
struct inode_operations {
|
struct inode_operations {
|
||||||
int (*create) (struct inode *,struct dentry *, umode_t, struct nameidata *);
|
int (*create) (struct inode *,struct dentry *, umode_t, struct nameidata *);
|
||||||
struct dentry * (*lookup) (struct inode *,struct dentry *, struct nameidata *);
|
struct dentry * (*lookup) (struct inode *,struct dentry *, unsigned int);
|
||||||
int (*link) (struct dentry *,struct inode *,struct dentry *);
|
int (*link) (struct dentry *,struct inode *,struct dentry *);
|
||||||
int (*unlink) (struct inode *,struct dentry *);
|
int (*unlink) (struct inode *,struct dentry *);
|
||||||
int (*symlink) (struct inode *,struct dentry *,const char *);
|
int (*symlink) (struct inode *,struct dentry *,const char *);
|
||||||
|
|
|
@ -144,7 +144,7 @@ extern void v9fs_session_close(struct v9fs_session_info *v9ses);
|
||||||
extern void v9fs_session_cancel(struct v9fs_session_info *v9ses);
|
extern void v9fs_session_cancel(struct v9fs_session_info *v9ses);
|
||||||
extern void v9fs_session_begin_cancel(struct v9fs_session_info *v9ses);
|
extern void v9fs_session_begin_cancel(struct v9fs_session_info *v9ses);
|
||||||
extern struct dentry *v9fs_vfs_lookup(struct inode *dir, struct dentry *dentry,
|
extern struct dentry *v9fs_vfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nameidata);
|
unsigned int flags);
|
||||||
extern int v9fs_vfs_unlink(struct inode *i, struct dentry *d);
|
extern int v9fs_vfs_unlink(struct inode *i, struct dentry *d);
|
||||||
extern int v9fs_vfs_rmdir(struct inode *i, struct dentry *d);
|
extern int v9fs_vfs_rmdir(struct inode *i, struct dentry *d);
|
||||||
extern int v9fs_vfs_rename(struct inode *old_dir, struct dentry *old_dentry,
|
extern int v9fs_vfs_rename(struct inode *old_dir, struct dentry *old_dentry,
|
||||||
|
|
|
@ -784,7 +784,7 @@ static int v9fs_vfs_mkdir(struct inode *dir, struct dentry *dentry, umode_t mode
|
||||||
*/
|
*/
|
||||||
|
|
||||||
struct dentry *v9fs_vfs_lookup(struct inode *dir, struct dentry *dentry,
|
struct dentry *v9fs_vfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nameidata)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct dentry *res;
|
struct dentry *res;
|
||||||
struct super_block *sb;
|
struct super_block *sb;
|
||||||
|
@ -794,8 +794,8 @@ struct dentry *v9fs_vfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
char *name;
|
char *name;
|
||||||
int result = 0;
|
int result = 0;
|
||||||
|
|
||||||
p9_debug(P9_DEBUG_VFS, "dir: %p dentry: (%s) %p nameidata: %p\n",
|
p9_debug(P9_DEBUG_VFS, "dir: %p dentry: (%s) %p flags: %x\n",
|
||||||
dir, dentry->d_name.name, dentry, nameidata);
|
dir, dentry->d_name.name, dentry, flags);
|
||||||
|
|
||||||
if (dentry->d_name.len > NAME_MAX)
|
if (dentry->d_name.len > NAME_MAX)
|
||||||
return ERR_PTR(-ENAMETOOLONG);
|
return ERR_PTR(-ENAMETOOLONG);
|
||||||
|
@ -868,7 +868,7 @@ v9fs_vfs_atomic_open(struct inode *dir, struct dentry *dentry,
|
||||||
struct dentry *res = NULL;
|
struct dentry *res = NULL;
|
||||||
|
|
||||||
if (d_unhashed(dentry)) {
|
if (d_unhashed(dentry)) {
|
||||||
res = v9fs_vfs_lookup(dir, dentry, NULL);
|
res = v9fs_vfs_lookup(dir, dentry, 0);
|
||||||
if (IS_ERR(res))
|
if (IS_ERR(res))
|
||||||
return PTR_ERR(res);
|
return PTR_ERR(res);
|
||||||
|
|
||||||
|
|
|
@ -276,7 +276,7 @@ v9fs_vfs_atomic_open_dotl(struct inode *dir, struct dentry *dentry,
|
||||||
struct dentry *res = NULL;
|
struct dentry *res = NULL;
|
||||||
|
|
||||||
if (d_unhashed(dentry)) {
|
if (d_unhashed(dentry)) {
|
||||||
res = v9fs_vfs_lookup(dir, dentry, NULL);
|
res = v9fs_vfs_lookup(dir, dentry, 0);
|
||||||
if (IS_ERR(res))
|
if (IS_ERR(res))
|
||||||
return PTR_ERR(res);
|
return PTR_ERR(res);
|
||||||
|
|
||||||
|
|
|
@ -266,7 +266,7 @@ const struct dentry_operations adfs_dentry_operations = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct dentry *
|
static struct dentry *
|
||||||
adfs_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd)
|
adfs_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode *inode = NULL;
|
struct inode *inode = NULL;
|
||||||
struct object_info obj;
|
struct object_info obj;
|
||||||
|
|
|
@ -154,7 +154,7 @@ extern void affs_free_bitmap(struct super_block *sb);
|
||||||
/* namei.c */
|
/* namei.c */
|
||||||
|
|
||||||
extern int affs_hash_name(struct super_block *sb, const u8 *name, unsigned int len);
|
extern int affs_hash_name(struct super_block *sb, const u8 *name, unsigned int len);
|
||||||
extern struct dentry *affs_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *);
|
extern struct dentry *affs_lookup(struct inode *dir, struct dentry *dentry, unsigned int);
|
||||||
extern int affs_unlink(struct inode *dir, struct dentry *dentry);
|
extern int affs_unlink(struct inode *dir, struct dentry *dentry);
|
||||||
extern int affs_create(struct inode *dir, struct dentry *dentry, umode_t mode, struct nameidata *);
|
extern int affs_create(struct inode *dir, struct dentry *dentry, umode_t mode, struct nameidata *);
|
||||||
extern int affs_mkdir(struct inode *dir, struct dentry *dentry, umode_t mode);
|
extern int affs_mkdir(struct inode *dir, struct dentry *dentry, umode_t mode);
|
||||||
|
|
|
@ -211,7 +211,7 @@ affs_find_entry(struct inode *dir, struct dentry *dentry)
|
||||||
}
|
}
|
||||||
|
|
||||||
struct dentry *
|
struct dentry *
|
||||||
affs_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd)
|
affs_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct super_block *sb = dir->i_sb;
|
struct super_block *sb = dir->i_sb;
|
||||||
struct buffer_head *bh;
|
struct buffer_head *bh;
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
#include "internal.h"
|
#include "internal.h"
|
||||||
|
|
||||||
static struct dentry *afs_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *afs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd);
|
unsigned int flags);
|
||||||
static int afs_dir_open(struct inode *inode, struct file *file);
|
static int afs_dir_open(struct inode *inode, struct file *file);
|
||||||
static int afs_readdir(struct file *file, void *dirent, filldir_t filldir);
|
static int afs_readdir(struct file *file, void *dirent, filldir_t filldir);
|
||||||
static int afs_d_revalidate(struct dentry *dentry, unsigned int flags);
|
static int afs_d_revalidate(struct dentry *dentry, unsigned int flags);
|
||||||
|
@ -516,7 +516,7 @@ out:
|
||||||
* look up an entry in a directory
|
* look up an entry in a directory
|
||||||
*/
|
*/
|
||||||
static struct dentry *afs_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *afs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct afs_vnode *vnode;
|
struct afs_vnode *vnode;
|
||||||
struct afs_fid fid;
|
struct afs_fid fid;
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
static struct dentry *afs_mntpt_lookup(struct inode *dir,
|
static struct dentry *afs_mntpt_lookup(struct inode *dir,
|
||||||
struct dentry *dentry,
|
struct dentry *dentry,
|
||||||
struct nameidata *nd);
|
unsigned int flags);
|
||||||
static int afs_mntpt_open(struct inode *inode, struct file *file);
|
static int afs_mntpt_open(struct inode *inode, struct file *file);
|
||||||
static void afs_mntpt_expiry_timed_out(struct work_struct *work);
|
static void afs_mntpt_expiry_timed_out(struct work_struct *work);
|
||||||
|
|
||||||
|
@ -104,7 +104,7 @@ out:
|
||||||
*/
|
*/
|
||||||
static struct dentry *afs_mntpt_lookup(struct inode *dir,
|
static struct dentry *afs_mntpt_lookup(struct inode *dir,
|
||||||
struct dentry *dentry,
|
struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
_enter("%p,%p{%p{%s},%s}",
|
_enter("%p,%p{%p{%s},%s}",
|
||||||
dir,
|
dir,
|
||||||
|
|
|
@ -32,7 +32,7 @@ static long autofs4_root_ioctl(struct file *,unsigned int,unsigned long);
|
||||||
static long autofs4_root_compat_ioctl(struct file *,unsigned int,unsigned long);
|
static long autofs4_root_compat_ioctl(struct file *,unsigned int,unsigned long);
|
||||||
#endif
|
#endif
|
||||||
static int autofs4_dir_open(struct inode *inode, struct file *file);
|
static int autofs4_dir_open(struct inode *inode, struct file *file);
|
||||||
static struct dentry *autofs4_lookup(struct inode *,struct dentry *, struct nameidata *);
|
static struct dentry *autofs4_lookup(struct inode *,struct dentry *, unsigned int);
|
||||||
static struct vfsmount *autofs4_d_automount(struct path *);
|
static struct vfsmount *autofs4_d_automount(struct path *);
|
||||||
static int autofs4_d_manage(struct dentry *, bool);
|
static int autofs4_d_manage(struct dentry *, bool);
|
||||||
static void autofs4_dentry_release(struct dentry *);
|
static void autofs4_dentry_release(struct dentry *);
|
||||||
|
@ -460,7 +460,7 @@ int autofs4_d_manage(struct dentry *dentry, bool rcu_walk)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Lookups in the root directory */
|
/* Lookups in the root directory */
|
||||||
static struct dentry *autofs4_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd)
|
static struct dentry *autofs4_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct autofs_sb_info *sbi;
|
struct autofs_sb_info *sbi;
|
||||||
struct autofs_info *ino;
|
struct autofs_info *ino;
|
||||||
|
|
|
@ -179,7 +179,7 @@ static int bad_inode_create (struct inode *dir, struct dentry *dentry,
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *bad_inode_lookup(struct inode *dir,
|
static struct dentry *bad_inode_lookup(struct inode *dir,
|
||||||
struct dentry *dentry, struct nameidata *nd)
|
struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
return ERR_PTR(-EIO);
|
return ERR_PTR(-EIO);
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,7 +34,7 @@ static int befs_readdir(struct file *, void *, filldir_t);
|
||||||
static int befs_get_block(struct inode *, sector_t, struct buffer_head *, int);
|
static int befs_get_block(struct inode *, sector_t, struct buffer_head *, int);
|
||||||
static int befs_readpage(struct file *file, struct page *page);
|
static int befs_readpage(struct file *file, struct page *page);
|
||||||
static sector_t befs_bmap(struct address_space *mapping, sector_t block);
|
static sector_t befs_bmap(struct address_space *mapping, sector_t block);
|
||||||
static struct dentry *befs_lookup(struct inode *, struct dentry *, struct nameidata *);
|
static struct dentry *befs_lookup(struct inode *, struct dentry *, unsigned int);
|
||||||
static struct inode *befs_iget(struct super_block *, unsigned long);
|
static struct inode *befs_iget(struct super_block *, unsigned long);
|
||||||
static struct inode *befs_alloc_inode(struct super_block *sb);
|
static struct inode *befs_alloc_inode(struct super_block *sb);
|
||||||
static void befs_destroy_inode(struct inode *inode);
|
static void befs_destroy_inode(struct inode *inode);
|
||||||
|
@ -159,7 +159,7 @@ befs_get_block(struct inode *inode, sector_t block,
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *
|
static struct dentry *
|
||||||
befs_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd)
|
befs_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode *inode = NULL;
|
struct inode *inode = NULL;
|
||||||
struct super_block *sb = dir->i_sb;
|
struct super_block *sb = dir->i_sb;
|
||||||
|
|
|
@ -133,7 +133,7 @@ static int bfs_create(struct inode *dir, struct dentry *dentry, umode_t mode,
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *bfs_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *bfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode *inode = NULL;
|
struct inode *inode = NULL;
|
||||||
struct buffer_head *bh;
|
struct buffer_head *bh;
|
||||||
|
|
|
@ -4187,7 +4187,7 @@ static void btrfs_dentry_release(struct dentry *dentry)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *btrfs_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *btrfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct dentry *ret;
|
struct dentry *ret;
|
||||||
|
|
||||||
|
|
|
@ -576,7 +576,7 @@ static int is_root_ceph_dentry(struct inode *inode, struct dentry *dentry)
|
||||||
* the MDS so that it gets our 'caps wanted' value in a single op.
|
* the MDS so that it gets our 'caps wanted' value in a single op.
|
||||||
*/
|
*/
|
||||||
static struct dentry *ceph_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *ceph_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct ceph_fs_client *fsc = ceph_sb_to_client(dir->i_sb);
|
struct ceph_fs_client *fsc = ceph_sb_to_client(dir->i_sb);
|
||||||
struct ceph_mds_client *mdsc = fsc->mdsc;
|
struct ceph_mds_client *mdsc = fsc->mdsc;
|
||||||
|
@ -653,7 +653,7 @@ int ceph_atomic_open(struct inode *dir, struct dentry *dentry,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (d_unhashed(dentry)) {
|
if (d_unhashed(dentry)) {
|
||||||
res = ceph_lookup(dir, dentry, NULL);
|
res = ceph_lookup(dir, dentry, 0);
|
||||||
if (IS_ERR(res))
|
if (IS_ERR(res))
|
||||||
return PTR_ERR(res);
|
return PTR_ERR(res);
|
||||||
|
|
||||||
|
@ -678,7 +678,7 @@ int ceph_atomic_open(struct inode *dir, struct dentry *dentry,
|
||||||
*/
|
*/
|
||||||
int ceph_handle_notrace_create(struct inode *dir, struct dentry *dentry)
|
int ceph_handle_notrace_create(struct inode *dir, struct dentry *dentry)
|
||||||
{
|
{
|
||||||
struct dentry *result = ceph_lookup(dir, dentry, NULL);
|
struct dentry *result = ceph_lookup(dir, dentry, 0);
|
||||||
|
|
||||||
if (result && !IS_ERR(result)) {
|
if (result && !IS_ERR(result)) {
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -54,7 +54,7 @@ extern int cifs_atomic_open(struct inode *, struct dentry *,
|
||||||
struct file *, unsigned, umode_t,
|
struct file *, unsigned, umode_t,
|
||||||
int *);
|
int *);
|
||||||
extern struct dentry *cifs_lookup(struct inode *, struct dentry *,
|
extern struct dentry *cifs_lookup(struct inode *, struct dentry *,
|
||||||
struct nameidata *);
|
unsigned int);
|
||||||
extern int cifs_unlink(struct inode *dir, struct dentry *dentry);
|
extern int cifs_unlink(struct inode *dir, struct dentry *dentry);
|
||||||
extern int cifs_hardlink(struct dentry *, struct inode *, struct dentry *);
|
extern int cifs_hardlink(struct dentry *, struct inode *, struct dentry *);
|
||||||
extern int cifs_mknod(struct inode *, struct dentry *, umode_t, dev_t);
|
extern int cifs_mknod(struct inode *, struct dentry *, umode_t, dev_t);
|
||||||
|
|
|
@ -401,7 +401,7 @@ cifs_atomic_open(struct inode *inode, struct dentry *direntry,
|
||||||
* in network traffic in the other paths.
|
* in network traffic in the other paths.
|
||||||
*/
|
*/
|
||||||
if (!(oflags & O_CREAT)) {
|
if (!(oflags & O_CREAT)) {
|
||||||
struct dentry *res = cifs_lookup(inode, direntry, NULL);
|
struct dentry *res = cifs_lookup(inode, direntry, 0);
|
||||||
if (IS_ERR(res))
|
if (IS_ERR(res))
|
||||||
return PTR_ERR(res);
|
return PTR_ERR(res);
|
||||||
|
|
||||||
|
@ -621,7 +621,7 @@ mknod_out:
|
||||||
|
|
||||||
struct dentry *
|
struct dentry *
|
||||||
cifs_lookup(struct inode *parent_dir_inode, struct dentry *direntry,
|
cifs_lookup(struct inode *parent_dir_inode, struct dentry *direntry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
int xid;
|
int xid;
|
||||||
int rc = 0; /* to get around spurious gcc warning, set to zero here */
|
int rc = 0; /* to get around spurious gcc warning, set to zero here */
|
||||||
|
|
|
@ -31,7 +31,7 @@
|
||||||
|
|
||||||
/* dir inode-ops */
|
/* dir inode-ops */
|
||||||
static int coda_create(struct inode *dir, struct dentry *new, umode_t mode, struct nameidata *nd);
|
static int coda_create(struct inode *dir, struct dentry *new, umode_t mode, struct nameidata *nd);
|
||||||
static struct dentry *coda_lookup(struct inode *dir, struct dentry *target, struct nameidata *nd);
|
static struct dentry *coda_lookup(struct inode *dir, struct dentry *target, unsigned int flags);
|
||||||
static int coda_link(struct dentry *old_dentry, struct inode *dir_inode,
|
static int coda_link(struct dentry *old_dentry, struct inode *dir_inode,
|
||||||
struct dentry *entry);
|
struct dentry *entry);
|
||||||
static int coda_unlink(struct inode *dir_inode, struct dentry *entry);
|
static int coda_unlink(struct inode *dir_inode, struct dentry *entry);
|
||||||
|
@ -94,7 +94,7 @@ const struct file_operations coda_dir_operations = {
|
||||||
|
|
||||||
/* inode operations for directories */
|
/* inode operations for directories */
|
||||||
/* access routines: lookup, readlink, permission */
|
/* access routines: lookup, readlink, permission */
|
||||||
static struct dentry *coda_lookup(struct inode *dir, struct dentry *entry, struct nameidata *nd)
|
static struct dentry *coda_lookup(struct inode *dir, struct dentry *entry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct super_block *sb = dir->i_sb;
|
struct super_block *sb = dir->i_sb;
|
||||||
const char *name = entry->d_name.name;
|
const char *name = entry->d_name.name;
|
||||||
|
|
|
@ -454,7 +454,7 @@ static int configfs_attach_attr(struct configfs_dirent * sd, struct dentry * den
|
||||||
|
|
||||||
static struct dentry * configfs_lookup(struct inode *dir,
|
static struct dentry * configfs_lookup(struct inode *dir,
|
||||||
struct dentry *dentry,
|
struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct configfs_dirent * parent_sd = dentry->d_parent->d_fsdata;
|
struct configfs_dirent * parent_sd = dentry->d_parent->d_fsdata;
|
||||||
struct configfs_dirent * sd;
|
struct configfs_dirent * sd;
|
||||||
|
|
|
@ -417,7 +417,7 @@ static int cramfs_readdir(struct file *filp, void *dirent, filldir_t filldir)
|
||||||
/*
|
/*
|
||||||
* Lookup and fill in the inode data..
|
* Lookup and fill in the inode data..
|
||||||
*/
|
*/
|
||||||
static struct dentry * cramfs_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd)
|
static struct dentry * cramfs_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
unsigned int offset = 0;
|
unsigned int offset = 0;
|
||||||
struct inode *inode = NULL;
|
struct inode *inode = NULL;
|
||||||
|
|
|
@ -403,7 +403,7 @@ static int ecryptfs_lookup_interpose(struct dentry *dentry,
|
||||||
*/
|
*/
|
||||||
static struct dentry *ecryptfs_lookup(struct inode *ecryptfs_dir_inode,
|
static struct dentry *ecryptfs_lookup(struct inode *ecryptfs_dir_inode,
|
||||||
struct dentry *ecryptfs_dentry,
|
struct dentry *ecryptfs_dentry,
|
||||||
struct nameidata *ecryptfs_nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
char *encrypted_and_encoded_name = NULL;
|
char *encrypted_and_encoded_name = NULL;
|
||||||
size_t encrypted_and_encoded_name_size;
|
size_t encrypted_and_encoded_name_size;
|
||||||
|
|
|
@ -129,7 +129,7 @@ extern struct inode *efs_iget(struct super_block *, unsigned long);
|
||||||
extern efs_block_t efs_map_block(struct inode *, efs_block_t);
|
extern efs_block_t efs_map_block(struct inode *, efs_block_t);
|
||||||
extern int efs_get_block(struct inode *, sector_t, struct buffer_head *, int);
|
extern int efs_get_block(struct inode *, sector_t, struct buffer_head *, int);
|
||||||
|
|
||||||
extern struct dentry *efs_lookup(struct inode *, struct dentry *, struct nameidata *);
|
extern struct dentry *efs_lookup(struct inode *, struct dentry *, unsigned int);
|
||||||
extern struct dentry *efs_fh_to_dentry(struct super_block *sb, struct fid *fid,
|
extern struct dentry *efs_fh_to_dentry(struct super_block *sb, struct fid *fid,
|
||||||
int fh_len, int fh_type);
|
int fh_len, int fh_type);
|
||||||
extern struct dentry *efs_fh_to_parent(struct super_block *sb, struct fid *fid,
|
extern struct dentry *efs_fh_to_parent(struct super_block *sb, struct fid *fid,
|
||||||
|
|
|
@ -58,7 +58,8 @@ static efs_ino_t efs_find_entry(struct inode *inode, const char *name, int len)
|
||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct dentry *efs_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd) {
|
struct dentry *efs_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
|
{
|
||||||
efs_ino_t inodenum;
|
efs_ino_t inodenum;
|
||||||
struct inode *inode = NULL;
|
struct inode *inode = NULL;
|
||||||
|
|
||||||
|
|
|
@ -46,7 +46,7 @@ static inline int exofs_add_nondir(struct dentry *dentry, struct inode *inode)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *exofs_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *exofs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode *inode;
|
struct inode *inode;
|
||||||
ino_t ino;
|
ino_t ino;
|
||||||
|
|
|
@ -55,7 +55,7 @@ static inline int ext2_add_nondir(struct dentry *dentry, struct inode *inode)
|
||||||
* Methods themselves.
|
* Methods themselves.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static struct dentry *ext2_lookup(struct inode * dir, struct dentry *dentry, struct nameidata *nd)
|
static struct dentry *ext2_lookup(struct inode * dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode * inode;
|
struct inode * inode;
|
||||||
ino_t ino;
|
ino_t ino;
|
||||||
|
|
|
@ -1008,7 +1008,7 @@ errout:
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *ext3_lookup(struct inode * dir, struct dentry *dentry, struct nameidata *nd)
|
static struct dentry *ext3_lookup(struct inode * dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode * inode;
|
struct inode * inode;
|
||||||
struct ext3_dir_entry_2 * de;
|
struct ext3_dir_entry_2 * de;
|
||||||
|
|
|
@ -1025,7 +1025,7 @@ errout:
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *ext4_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd)
|
static struct dentry *ext4_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode *inode;
|
struct inode *inode;
|
||||||
struct ext4_dir_entry_2 *de;
|
struct ext4_dir_entry_2 *de;
|
||||||
|
|
|
@ -253,7 +253,7 @@ out:
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *f2fs_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *f2fs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode *inode = NULL;
|
struct inode *inode = NULL;
|
||||||
struct f2fs_dir_entry *de;
|
struct f2fs_dir_entry *de;
|
||||||
|
|
|
@ -201,7 +201,7 @@ static const struct dentry_operations msdos_dentry_operations = {
|
||||||
|
|
||||||
/***** Get inode using directory and name */
|
/***** Get inode using directory and name */
|
||||||
static struct dentry *msdos_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *msdos_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct super_block *sb = dir->i_sb;
|
struct super_block *sb = dir->i_sb;
|
||||||
struct fat_slot_info sinfo;
|
struct fat_slot_info sinfo;
|
||||||
|
|
|
@ -714,7 +714,7 @@ static int vfat_d_anon_disconn(struct dentry *dentry)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *vfat_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *vfat_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct super_block *sb = dir->i_sb;
|
struct super_block *sb = dir->i_sb;
|
||||||
struct fat_slot_info sinfo;
|
struct fat_slot_info sinfo;
|
||||||
|
|
|
@ -48,7 +48,7 @@
|
||||||
#define VXFS_BLOCK_PER_PAGE(sbp) ((PAGE_CACHE_SIZE / (sbp)->s_blocksize))
|
#define VXFS_BLOCK_PER_PAGE(sbp) ((PAGE_CACHE_SIZE / (sbp)->s_blocksize))
|
||||||
|
|
||||||
|
|
||||||
static struct dentry * vxfs_lookup(struct inode *, struct dentry *, struct nameidata *);
|
static struct dentry * vxfs_lookup(struct inode *, struct dentry *, unsigned int);
|
||||||
static int vxfs_readdir(struct file *, void *, filldir_t);
|
static int vxfs_readdir(struct file *, void *, filldir_t);
|
||||||
|
|
||||||
const struct inode_operations vxfs_dir_inode_ops = {
|
const struct inode_operations vxfs_dir_inode_ops = {
|
||||||
|
@ -203,7 +203,7 @@ vxfs_inode_by_name(struct inode *dip, struct dentry *dp)
|
||||||
* in the return pointer.
|
* in the return pointer.
|
||||||
*/
|
*/
|
||||||
static struct dentry *
|
static struct dentry *
|
||||||
vxfs_lookup(struct inode *dip, struct dentry *dp, struct nameidata *nd)
|
vxfs_lookup(struct inode *dip, struct dentry *dp, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode *ip = NULL;
|
struct inode *ip = NULL;
|
||||||
ino_t ino;
|
ino_t ino;
|
||||||
|
|
|
@ -361,7 +361,7 @@ int fuse_lookup_name(struct super_block *sb, u64 nodeid, struct qstr *name,
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *fuse_lookup(struct inode *dir, struct dentry *entry,
|
static struct dentry *fuse_lookup(struct inode *dir, struct dentry *entry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
struct fuse_entry_out outarg;
|
struct fuse_entry_out outarg;
|
||||||
|
@ -523,7 +523,7 @@ static int fuse_atomic_open(struct inode *dir, struct dentry *entry,
|
||||||
struct dentry *res = NULL;
|
struct dentry *res = NULL;
|
||||||
|
|
||||||
if (d_unhashed(entry)) {
|
if (d_unhashed(entry)) {
|
||||||
res = fuse_lookup(dir, entry, NULL);
|
res = fuse_lookup(dir, entry, 0);
|
||||||
if (IS_ERR(res))
|
if (IS_ERR(res))
|
||||||
return PTR_ERR(res);
|
return PTR_ERR(res);
|
||||||
|
|
||||||
|
|
|
@ -775,7 +775,7 @@ static int gfs2_create(struct inode *dir, struct dentry *dentry,
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static struct dentry *gfs2_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *gfs2_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode *inode = gfs2_lookupi(dir, &dentry->d_name, 0);
|
struct inode *inode = gfs2_lookupi(dir, &dentry->d_name, 0);
|
||||||
if (inode && !IS_ERR(inode)) {
|
if (inode && !IS_ERR(inode)) {
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
* hfs_lookup()
|
* hfs_lookup()
|
||||||
*/
|
*/
|
||||||
static struct dentry *hfs_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *hfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
hfs_cat_rec rec;
|
hfs_cat_rec rec;
|
||||||
struct hfs_find_data fd;
|
struct hfs_find_data fd;
|
||||||
|
|
|
@ -489,7 +489,7 @@ out:
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *hfs_file_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *hfs_file_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode *inode = NULL;
|
struct inode *inode = NULL;
|
||||||
hfs_cat_rec rec;
|
hfs_cat_rec rec;
|
||||||
|
|
|
@ -25,7 +25,7 @@ static inline void hfsplus_instantiate(struct dentry *dentry,
|
||||||
|
|
||||||
/* Find the entry inside dir named dentry->d_name */
|
/* Find the entry inside dir named dentry->d_name */
|
||||||
static struct dentry *hfsplus_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *hfsplus_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode *inode = NULL;
|
struct inode *inode = NULL;
|
||||||
struct hfs_find_data fd;
|
struct hfs_find_data fd;
|
||||||
|
|
|
@ -168,7 +168,7 @@ const struct dentry_operations hfsplus_dentry_operations = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct dentry *hfsplus_file_lookup(struct inode *dir,
|
static struct dentry *hfsplus_file_lookup(struct inode *dir,
|
||||||
struct dentry *dentry, struct nameidata *nd)
|
struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct hfs_find_data fd;
|
struct hfs_find_data fd;
|
||||||
struct super_block *sb = dir->i_sb;
|
struct super_block *sb = dir->i_sb;
|
||||||
|
|
|
@ -595,7 +595,7 @@ int hostfs_create(struct inode *dir, struct dentry *dentry, umode_t mode,
|
||||||
}
|
}
|
||||||
|
|
||||||
struct dentry *hostfs_lookup(struct inode *ino, struct dentry *dentry,
|
struct dentry *hostfs_lookup(struct inode *ino, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode *inode;
|
struct inode *inode;
|
||||||
char *name;
|
char *name;
|
||||||
|
|
|
@ -191,7 +191,7 @@ out:
|
||||||
* to tell read_inode to read fnode or not.
|
* to tell read_inode to read fnode or not.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
struct dentry *hpfs_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd)
|
struct dentry *hpfs_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
const unsigned char *name = dentry->d_name.name;
|
const unsigned char *name = dentry->d_name.name;
|
||||||
unsigned len = dentry->d_name.len;
|
unsigned len = dentry->d_name.len;
|
||||||
|
|
|
@ -227,7 +227,7 @@ extern const struct dentry_operations hpfs_dentry_operations;
|
||||||
|
|
||||||
/* dir.c */
|
/* dir.c */
|
||||||
|
|
||||||
struct dentry *hpfs_lookup(struct inode *, struct dentry *, struct nameidata *);
|
struct dentry *hpfs_lookup(struct inode *, struct dentry *, unsigned int);
|
||||||
extern const struct file_operations hpfs_dir_ops;
|
extern const struct file_operations hpfs_dir_ops;
|
||||||
|
|
||||||
/* dnode.c */
|
/* dnode.c */
|
||||||
|
|
|
@ -138,7 +138,7 @@ static int file_removed(struct dentry *dentry, const char *file)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *hppfs_lookup(struct inode *ino, struct dentry *dentry,
|
static struct dentry *hppfs_lookup(struct inode *ino, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct dentry *proc_dentry, *parent;
|
struct dentry *proc_dentry, *parent;
|
||||||
struct qstr *name = &dentry->d_name;
|
struct qstr *name = &dentry->d_name;
|
||||||
|
|
|
@ -114,7 +114,7 @@ extern int isofs_name_translate(struct iso_directory_record *, char *, struct in
|
||||||
int get_joliet_filename(struct iso_directory_record *, unsigned char *, struct inode *);
|
int get_joliet_filename(struct iso_directory_record *, unsigned char *, struct inode *);
|
||||||
int get_acorn_filename(struct iso_directory_record *, char *, struct inode *);
|
int get_acorn_filename(struct iso_directory_record *, char *, struct inode *);
|
||||||
|
|
||||||
extern struct dentry *isofs_lookup(struct inode *, struct dentry *, struct nameidata *);
|
extern struct dentry *isofs_lookup(struct inode *, struct dentry *, unsigned int flags);
|
||||||
extern struct buffer_head *isofs_bread(struct inode *, sector_t);
|
extern struct buffer_head *isofs_bread(struct inode *, sector_t);
|
||||||
extern int isofs_get_blocks(struct inode *, sector_t, struct buffer_head **, unsigned long);
|
extern int isofs_get_blocks(struct inode *, sector_t, struct buffer_head **, unsigned long);
|
||||||
|
|
||||||
|
|
|
@ -163,7 +163,7 @@ isofs_find_entry(struct inode *dir, struct dentry *dentry,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct dentry *isofs_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd)
|
struct dentry *isofs_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
int found;
|
int found;
|
||||||
unsigned long uninitialized_var(block);
|
unsigned long uninitialized_var(block);
|
||||||
|
|
|
@ -27,7 +27,7 @@ static int jffs2_readdir (struct file *, void *, filldir_t);
|
||||||
static int jffs2_create (struct inode *,struct dentry *,umode_t,
|
static int jffs2_create (struct inode *,struct dentry *,umode_t,
|
||||||
struct nameidata *);
|
struct nameidata *);
|
||||||
static struct dentry *jffs2_lookup (struct inode *,struct dentry *,
|
static struct dentry *jffs2_lookup (struct inode *,struct dentry *,
|
||||||
struct nameidata *);
|
unsigned int);
|
||||||
static int jffs2_link (struct dentry *,struct inode *,struct dentry *);
|
static int jffs2_link (struct dentry *,struct inode *,struct dentry *);
|
||||||
static int jffs2_unlink (struct inode *,struct dentry *);
|
static int jffs2_unlink (struct inode *,struct dentry *);
|
||||||
static int jffs2_symlink (struct inode *,struct dentry *,const char *);
|
static int jffs2_symlink (struct inode *,struct dentry *,const char *);
|
||||||
|
@ -74,7 +74,7 @@ const struct inode_operations jffs2_dir_inode_operations =
|
||||||
nice and simple
|
nice and simple
|
||||||
*/
|
*/
|
||||||
static struct dentry *jffs2_lookup(struct inode *dir_i, struct dentry *target,
|
static struct dentry *jffs2_lookup(struct inode *dir_i, struct dentry *target,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct jffs2_inode_info *dir_f;
|
struct jffs2_inode_info *dir_f;
|
||||||
struct jffs2_full_dirent *fd = NULL, *fd_list;
|
struct jffs2_full_dirent *fd = NULL, *fd_list;
|
||||||
|
|
|
@ -1436,7 +1436,7 @@ static int jfs_mknod(struct inode *dir, struct dentry *dentry,
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *jfs_lookup(struct inode *dip, struct dentry *dentry, struct nameidata *nd)
|
static struct dentry *jfs_lookup(struct inode *dip, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct btstack btstack;
|
struct btstack btstack;
|
||||||
ino_t inum;
|
ino_t inum;
|
||||||
|
|
|
@ -53,7 +53,7 @@ static int simple_delete_dentry(const struct dentry *dentry)
|
||||||
* Lookup the data. This is trivial - if the dentry didn't already
|
* Lookup the data. This is trivial - if the dentry didn't already
|
||||||
* exist, we know it is negative. Set d_op to delete negative dentries.
|
* exist, we know it is negative. Set d_op to delete negative dentries.
|
||||||
*/
|
*/
|
||||||
struct dentry *simple_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd)
|
struct dentry *simple_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
static const struct dentry_operations simple_dentry_operations = {
|
static const struct dentry_operations simple_dentry_operations = {
|
||||||
.d_delete = simple_delete_dentry,
|
.d_delete = simple_delete_dentry,
|
||||||
|
|
|
@ -349,7 +349,7 @@ static void logfs_set_name(struct logfs_disk_dentry *dd, struct qstr *name)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *logfs_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *logfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct page *page;
|
struct page *page;
|
||||||
struct logfs_disk_dentry *dd;
|
struct logfs_disk_dentry *dd;
|
||||||
|
|
|
@ -18,7 +18,7 @@ static int add_nondir(struct dentry *dentry, struct inode *inode)
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *minix_lookup(struct inode * dir, struct dentry *dentry, struct nameidata *nd)
|
static struct dentry *minix_lookup(struct inode * dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode * inode = NULL;
|
struct inode * inode = NULL;
|
||||||
ino_t ino;
|
ino_t ino;
|
||||||
|
|
|
@ -1138,7 +1138,7 @@ static struct dentry *lookup_real(struct inode *dir, struct dentry *dentry,
|
||||||
return ERR_PTR(-ENOENT);
|
return ERR_PTR(-ENOENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
old = dir->i_op->lookup(dir, dentry, nd);
|
old = dir->i_op->lookup(dir, dentry, nd ? nd->flags : 0);
|
||||||
if (unlikely(old)) {
|
if (unlikely(old)) {
|
||||||
dput(dentry);
|
dput(dentry);
|
||||||
dentry = old;
|
dentry = old;
|
||||||
|
|
|
@ -31,7 +31,7 @@ static void ncp_do_readdir(struct file *, void *, filldir_t,
|
||||||
static int ncp_readdir(struct file *, void *, filldir_t);
|
static int ncp_readdir(struct file *, void *, filldir_t);
|
||||||
|
|
||||||
static int ncp_create(struct inode *, struct dentry *, umode_t, struct nameidata *);
|
static int ncp_create(struct inode *, struct dentry *, umode_t, struct nameidata *);
|
||||||
static struct dentry *ncp_lookup(struct inode *, struct dentry *, struct nameidata *);
|
static struct dentry *ncp_lookup(struct inode *, struct dentry *, unsigned int);
|
||||||
static int ncp_unlink(struct inode *, struct dentry *);
|
static int ncp_unlink(struct inode *, struct dentry *);
|
||||||
static int ncp_mkdir(struct inode *, struct dentry *, umode_t);
|
static int ncp_mkdir(struct inode *, struct dentry *, umode_t);
|
||||||
static int ncp_rmdir(struct inode *, struct dentry *);
|
static int ncp_rmdir(struct inode *, struct dentry *);
|
||||||
|
@ -836,7 +836,7 @@ out:
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *ncp_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd)
|
static struct dentry *ncp_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct ncp_server *server = NCP_SERVER(dir);
|
struct ncp_server *server = NCP_SERVER(dir);
|
||||||
struct inode *inode = NULL;
|
struct inode *inode = NULL;
|
||||||
|
|
|
@ -46,7 +46,7 @@
|
||||||
static int nfs_opendir(struct inode *, struct file *);
|
static int nfs_opendir(struct inode *, struct file *);
|
||||||
static int nfs_closedir(struct inode *, struct file *);
|
static int nfs_closedir(struct inode *, struct file *);
|
||||||
static int nfs_readdir(struct file *, void *, filldir_t);
|
static int nfs_readdir(struct file *, void *, filldir_t);
|
||||||
static struct dentry *nfs_lookup(struct inode *, struct dentry *, struct nameidata *);
|
static struct dentry *nfs_lookup(struct inode *, struct dentry *, unsigned int);
|
||||||
static int nfs_create(struct inode *, struct dentry *, umode_t, struct nameidata *);
|
static int nfs_create(struct inode *, struct dentry *, umode_t, struct nameidata *);
|
||||||
static int nfs_mkdir(struct inode *, struct dentry *, umode_t);
|
static int nfs_mkdir(struct inode *, struct dentry *, umode_t);
|
||||||
static int nfs_rmdir(struct inode *, struct dentry *);
|
static int nfs_rmdir(struct inode *, struct dentry *);
|
||||||
|
@ -1247,7 +1247,7 @@ const struct dentry_operations nfs_dentry_operations = {
|
||||||
.d_release = nfs_d_release,
|
.d_release = nfs_d_release,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct dentry *nfs_lookup(struct inode *dir, struct dentry * dentry, struct nameidata *nd)
|
static struct dentry *nfs_lookup(struct inode *dir, struct dentry * dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct dentry *res;
|
struct dentry *res;
|
||||||
struct dentry *parent;
|
struct dentry *parent;
|
||||||
|
@ -1268,7 +1268,7 @@ static struct dentry *nfs_lookup(struct inode *dir, struct dentry * dentry, stru
|
||||||
* If we're doing an exclusive create, optimize away the lookup
|
* If we're doing an exclusive create, optimize away the lookup
|
||||||
* but don't hash the dentry.
|
* but don't hash the dentry.
|
||||||
*/
|
*/
|
||||||
if (nd && nfs_is_exclusive_create(dir, nd->flags)) {
|
if (nfs_is_exclusive_create(dir, flags)) {
|
||||||
d_instantiate(dentry, NULL);
|
d_instantiate(dentry, NULL);
|
||||||
res = NULL;
|
res = NULL;
|
||||||
goto out;
|
goto out;
|
||||||
|
@ -1456,7 +1456,7 @@ out:
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
no_open:
|
no_open:
|
||||||
res = nfs_lookup(dir, dentry, NULL);
|
res = nfs_lookup(dir, dentry, 0);
|
||||||
err = PTR_ERR(res);
|
err = PTR_ERR(res);
|
||||||
if (IS_ERR(res))
|
if (IS_ERR(res))
|
||||||
goto out;
|
goto out;
|
||||||
|
|
|
@ -63,7 +63,7 @@ static inline int nilfs_add_nondir(struct dentry *dentry, struct inode *inode)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static struct dentry *
|
static struct dentry *
|
||||||
nilfs_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd)
|
nilfs_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode *inode;
|
struct inode *inode;
|
||||||
ino_t ino;
|
ino_t ino;
|
||||||
|
|
|
@ -101,7 +101,7 @@
|
||||||
* Locking: Caller must hold i_mutex on the directory.
|
* Locking: Caller must hold i_mutex on the directory.
|
||||||
*/
|
*/
|
||||||
static struct dentry *ntfs_lookup(struct inode *dir_ino, struct dentry *dent,
|
static struct dentry *ntfs_lookup(struct inode *dir_ino, struct dentry *dent,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
ntfs_volume *vol = NTFS_SB(dir_ino->i_sb);
|
ntfs_volume *vol = NTFS_SB(dir_ino->i_sb);
|
||||||
struct inode *dent_inode;
|
struct inode *dent_inode;
|
||||||
|
|
|
@ -98,7 +98,7 @@ static int ocfs2_create_symlink_data(struct ocfs2_super *osb,
|
||||||
#define OCFS2_ORPHAN_NAMELEN ((int)(2 * sizeof(u64)))
|
#define OCFS2_ORPHAN_NAMELEN ((int)(2 * sizeof(u64)))
|
||||||
|
|
||||||
static struct dentry *ocfs2_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *ocfs2_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
int status;
|
int status;
|
||||||
u64 blkno;
|
u64 blkno;
|
||||||
|
|
|
@ -291,7 +291,7 @@ static int omfs_create(struct inode *dir, struct dentry *dentry, umode_t mode,
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *omfs_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *omfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct buffer_head *bh;
|
struct buffer_head *bh;
|
||||||
struct inode *inode = NULL;
|
struct inode *inode = NULL;
|
||||||
|
|
|
@ -170,13 +170,13 @@ static const struct file_operations openprom_operations = {
|
||||||
.llseek = generic_file_llseek,
|
.llseek = generic_file_llseek,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct dentry *openpromfs_lookup(struct inode *, struct dentry *, struct nameidata *);
|
static struct dentry *openpromfs_lookup(struct inode *, struct dentry *, unsigned int);
|
||||||
|
|
||||||
static const struct inode_operations openprom_inode_operations = {
|
static const struct inode_operations openprom_inode_operations = {
|
||||||
.lookup = openpromfs_lookup,
|
.lookup = openpromfs_lookup,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct dentry *openpromfs_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd)
|
static struct dentry *openpromfs_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct op_inode_info *ent_oi, *oi = OP_I(dir);
|
struct op_inode_info *ent_oi, *oi = OP_I(dir);
|
||||||
struct device_node *dp, *child;
|
struct device_node *dp, *child;
|
||||||
|
|
|
@ -1955,7 +1955,7 @@ out_no_task:
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *proc_lookupfd(struct inode *dir, struct dentry *dentry,
|
static struct dentry *proc_lookupfd(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
return proc_lookupfd_common(dir, dentry, proc_fd_instantiate);
|
return proc_lookupfd_common(dir, dentry, proc_fd_instantiate);
|
||||||
}
|
}
|
||||||
|
@ -2148,7 +2148,7 @@ proc_map_files_instantiate(struct inode *dir, struct dentry *dentry,
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *proc_map_files_lookup(struct inode *dir,
|
static struct dentry *proc_map_files_lookup(struct inode *dir,
|
||||||
struct dentry *dentry, struct nameidata *nd)
|
struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
unsigned long vm_start, vm_end;
|
unsigned long vm_start, vm_end;
|
||||||
struct vm_area_struct *vma;
|
struct vm_area_struct *vma;
|
||||||
|
@ -2391,7 +2391,7 @@ static struct dentry *proc_fdinfo_instantiate(struct inode *dir,
|
||||||
|
|
||||||
static struct dentry *proc_lookupfdinfo(struct inode *dir,
|
static struct dentry *proc_lookupfdinfo(struct inode *dir,
|
||||||
struct dentry *dentry,
|
struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
return proc_lookupfd_common(dir, dentry, proc_fdinfo_instantiate);
|
return proc_lookupfd_common(dir, dentry, proc_fdinfo_instantiate);
|
||||||
}
|
}
|
||||||
|
@ -2641,7 +2641,7 @@ static const struct file_operations proc_attr_dir_operations = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct dentry *proc_attr_dir_lookup(struct inode *dir,
|
static struct dentry *proc_attr_dir_lookup(struct inode *dir,
|
||||||
struct dentry *dentry, struct nameidata *nd)
|
struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
return proc_pident_lookup(dir, dentry,
|
return proc_pident_lookup(dir, dentry,
|
||||||
attr_dir_stuff, ARRAY_SIZE(attr_dir_stuff));
|
attr_dir_stuff, ARRAY_SIZE(attr_dir_stuff));
|
||||||
|
@ -3053,7 +3053,8 @@ static const struct file_operations proc_tgid_base_operations = {
|
||||||
.llseek = default_llseek,
|
.llseek = default_llseek,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct dentry *proc_tgid_base_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd){
|
static struct dentry *proc_tgid_base_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
|
{
|
||||||
return proc_pident_lookup(dir, dentry,
|
return proc_pident_lookup(dir, dentry,
|
||||||
tgid_base_stuff, ARRAY_SIZE(tgid_base_stuff));
|
tgid_base_stuff, ARRAY_SIZE(tgid_base_stuff));
|
||||||
}
|
}
|
||||||
|
@ -3182,7 +3183,7 @@ out:
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct dentry *proc_pid_lookup(struct inode *dir, struct dentry * dentry, struct nameidata *nd)
|
struct dentry *proc_pid_lookup(struct inode *dir, struct dentry * dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct dentry *result;
|
struct dentry *result;
|
||||||
struct task_struct *task;
|
struct task_struct *task;
|
||||||
|
@ -3402,7 +3403,8 @@ static int proc_tid_base_readdir(struct file * filp,
|
||||||
tid_base_stuff,ARRAY_SIZE(tid_base_stuff));
|
tid_base_stuff,ARRAY_SIZE(tid_base_stuff));
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *proc_tid_base_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd){
|
static struct dentry *proc_tid_base_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
|
{
|
||||||
return proc_pident_lookup(dir, dentry,
|
return proc_pident_lookup(dir, dentry,
|
||||||
tid_base_stuff, ARRAY_SIZE(tid_base_stuff));
|
tid_base_stuff, ARRAY_SIZE(tid_base_stuff));
|
||||||
}
|
}
|
||||||
|
@ -3446,7 +3448,7 @@ out:
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *proc_task_lookup(struct inode *dir, struct dentry * dentry, struct nameidata *nd)
|
static struct dentry *proc_task_lookup(struct inode *dir, struct dentry * dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct dentry *result = ERR_PTR(-ENOENT);
|
struct dentry *result = ERR_PTR(-ENOENT);
|
||||||
struct task_struct *task;
|
struct task_struct *task;
|
||||||
|
|
|
@ -448,7 +448,7 @@ out_unlock:
|
||||||
}
|
}
|
||||||
|
|
||||||
struct dentry *proc_lookup(struct inode *dir, struct dentry *dentry,
|
struct dentry *proc_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
return proc_lookup_de(PDE(dir), dir, dentry);
|
return proc_lookup_de(PDE(dir), dir, dentry);
|
||||||
}
|
}
|
||||||
|
|
|
@ -107,7 +107,7 @@ void pde_users_dec(struct proc_dir_entry *pde);
|
||||||
|
|
||||||
extern spinlock_t proc_subdir_lock;
|
extern spinlock_t proc_subdir_lock;
|
||||||
|
|
||||||
struct dentry *proc_pid_lookup(struct inode *dir, struct dentry * dentry, struct nameidata *);
|
struct dentry *proc_pid_lookup(struct inode *dir, struct dentry * dentry, unsigned int);
|
||||||
int proc_pid_readdir(struct file * filp, void * dirent, filldir_t filldir);
|
int proc_pid_readdir(struct file * filp, void * dirent, filldir_t filldir);
|
||||||
unsigned long task_vsize(struct mm_struct *);
|
unsigned long task_vsize(struct mm_struct *);
|
||||||
unsigned long task_statm(struct mm_struct *,
|
unsigned long task_statm(struct mm_struct *,
|
||||||
|
@ -133,7 +133,7 @@ int proc_remount(struct super_block *sb, int *flags, char *data);
|
||||||
* of the /proc/<pid> subdirectories.
|
* of the /proc/<pid> subdirectories.
|
||||||
*/
|
*/
|
||||||
int proc_readdir(struct file *, void *, filldir_t);
|
int proc_readdir(struct file *, void *, filldir_t);
|
||||||
struct dentry *proc_lookup(struct inode *, struct dentry *, struct nameidata *);
|
struct dentry *proc_lookup(struct inode *, struct dentry *, unsigned int);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -280,7 +280,7 @@ const struct file_operations proc_ns_dir_operations = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct dentry *proc_ns_dir_lookup(struct inode *dir,
|
static struct dentry *proc_ns_dir_lookup(struct inode *dir,
|
||||||
struct dentry *dentry, struct nameidata *nd)
|
struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct dentry *error;
|
struct dentry *error;
|
||||||
struct task_struct *task = get_proc_task(dir);
|
struct task_struct *task = get_proc_task(dir);
|
||||||
|
|
|
@ -119,7 +119,7 @@ static struct net *get_proc_task_net(struct inode *dir)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *proc_tgid_net_lookup(struct inode *dir,
|
static struct dentry *proc_tgid_net_lookup(struct inode *dir,
|
||||||
struct dentry *dentry, struct nameidata *nd)
|
struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct dentry *de;
|
struct dentry *de;
|
||||||
struct net *net;
|
struct net *net;
|
||||||
|
|
|
@ -433,7 +433,7 @@ static struct ctl_table_header *grab_header(struct inode *inode)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *proc_sys_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *proc_sys_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct ctl_table_header *head = grab_header(dir);
|
struct ctl_table_header *head = grab_header(dir);
|
||||||
struct ctl_table_header *h = NULL;
|
struct ctl_table_header *h = NULL;
|
||||||
|
|
|
@ -200,13 +200,12 @@ static int proc_root_getattr(struct vfsmount *mnt, struct dentry *dentry, struct
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *proc_root_lookup(struct inode * dir, struct dentry * dentry, struct nameidata *nd)
|
static struct dentry *proc_root_lookup(struct inode * dir, struct dentry * dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
if (!proc_lookup(dir, dentry, nd)) {
|
if (!proc_lookup(dir, dentry, flags))
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
|
||||||
|
|
||||||
return proc_pid_lookup(dir, dentry, nd);
|
return proc_pid_lookup(dir, dentry, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int proc_root_readdir(struct file * filp,
|
static int proc_root_readdir(struct file * filp,
|
||||||
|
|
|
@ -95,7 +95,7 @@ static struct buffer_head *qnx4_find_entry(int len, struct inode *dir,
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct dentry * qnx4_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd)
|
struct dentry * qnx4_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
int ino;
|
int ino;
|
||||||
struct qnx4_inode_entry *de;
|
struct qnx4_inode_entry *de;
|
||||||
|
|
|
@ -23,7 +23,7 @@ struct qnx4_inode_info {
|
||||||
};
|
};
|
||||||
|
|
||||||
extern struct inode *qnx4_iget(struct super_block *, unsigned long);
|
extern struct inode *qnx4_iget(struct super_block *, unsigned long);
|
||||||
extern struct dentry *qnx4_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd);
|
extern struct dentry *qnx4_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags);
|
||||||
extern unsigned long qnx4_count_free_blocks(struct super_block *sb);
|
extern unsigned long qnx4_count_free_blocks(struct super_block *sb);
|
||||||
extern unsigned long qnx4_block_map(struct inode *inode, long iblock);
|
extern unsigned long qnx4_block_map(struct inode *inode, long iblock);
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
#include "qnx6.h"
|
#include "qnx6.h"
|
||||||
|
|
||||||
struct dentry *qnx6_lookup(struct inode *dir, struct dentry *dentry,
|
struct dentry *qnx6_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
unsigned ino;
|
unsigned ino;
|
||||||
struct page *page;
|
struct page *page;
|
||||||
|
|
|
@ -45,7 +45,7 @@ struct qnx6_inode_info {
|
||||||
|
|
||||||
extern struct inode *qnx6_iget(struct super_block *sb, unsigned ino);
|
extern struct inode *qnx6_iget(struct super_block *sb, unsigned ino);
|
||||||
extern struct dentry *qnx6_lookup(struct inode *dir, struct dentry *dentry,
|
extern struct dentry *qnx6_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd);
|
unsigned int flags);
|
||||||
|
|
||||||
#ifdef CONFIG_QNX6FS_DEBUG
|
#ifdef CONFIG_QNX6FS_DEBUG
|
||||||
extern void qnx6_superblock_debug(struct qnx6_super_block *,
|
extern void qnx6_superblock_debug(struct qnx6_super_block *,
|
||||||
|
|
|
@ -322,7 +322,7 @@ static int reiserfs_find_entry(struct inode *dir, const char *name, int namelen,
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *reiserfs_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *reiserfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
int retval;
|
int retval;
|
||||||
int lock_depth;
|
int lock_depth;
|
||||||
|
|
|
@ -210,7 +210,7 @@ out:
|
||||||
* look up an entry in a directory
|
* look up an entry in a directory
|
||||||
*/
|
*/
|
||||||
static struct dentry *romfs_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *romfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
unsigned long offset, maxoff;
|
unsigned long offset, maxoff;
|
||||||
struct inode *inode;
|
struct inode *inode;
|
||||||
|
|
|
@ -229,7 +229,7 @@ int sdcardfs_interpose(struct dentry *dentry, struct super_block *sb,
|
||||||
* Fills in lower_parent_path with <dentry,mnt> on success.
|
* Fills in lower_parent_path with <dentry,mnt> on success.
|
||||||
*/
|
*/
|
||||||
static struct dentry *__sdcardfs_lookup(struct dentry *dentry,
|
static struct dentry *__sdcardfs_lookup(struct dentry *dentry,
|
||||||
struct nameidata *nd, struct path *lower_parent_path, userid_t id)
|
unsigned int flags, struct path *lower_parent_path, userid_t id)
|
||||||
{
|
{
|
||||||
int err = 0;
|
int err = 0;
|
||||||
struct vfsmount *lower_dir_mnt;
|
struct vfsmount *lower_dir_mnt;
|
||||||
|
@ -358,10 +358,7 @@ static struct dentry *__sdcardfs_lookup(struct dentry *dentry,
|
||||||
* the VFS will continue the process of making this negative dentry
|
* the VFS will continue the process of making this negative dentry
|
||||||
* into a positive one.
|
* into a positive one.
|
||||||
*/
|
*/
|
||||||
if (nd) {
|
if (flags & (LOOKUP_CREATE|LOOKUP_RENAME_TARGET))
|
||||||
if (nd->flags & (LOOKUP_CREATE|LOOKUP_RENAME_TARGET))
|
|
||||||
err = 0;
|
|
||||||
} else
|
|
||||||
err = 0;
|
err = 0;
|
||||||
|
|
||||||
out:
|
out:
|
||||||
|
@ -382,7 +379,7 @@ out:
|
||||||
* @nd : nameidata of parent inode
|
* @nd : nameidata of parent inode
|
||||||
*/
|
*/
|
||||||
struct dentry *sdcardfs_lookup(struct inode *dir, struct dentry *dentry,
|
struct dentry *sdcardfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct dentry *ret = NULL, *parent;
|
struct dentry *ret = NULL, *parent;
|
||||||
struct path lower_parent_path;
|
struct path lower_parent_path;
|
||||||
|
@ -408,7 +405,7 @@ struct dentry *sdcardfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = __sdcardfs_lookup(dentry, nd, &lower_parent_path,
|
ret = __sdcardfs_lookup(dentry, flags, &lower_parent_path,
|
||||||
SDCARDFS_I(dir)->data->userid);
|
SDCARDFS_I(dir)->data->userid);
|
||||||
if (IS_ERR(ret))
|
if (IS_ERR(ret))
|
||||||
goto out;
|
goto out;
|
||||||
|
|
|
@ -169,7 +169,7 @@ extern void sdcardfs_destroy_dentry_cache(void);
|
||||||
extern int new_dentry_private_data(struct dentry *dentry);
|
extern int new_dentry_private_data(struct dentry *dentry);
|
||||||
extern void free_dentry_private_data(struct dentry *dentry);
|
extern void free_dentry_private_data(struct dentry *dentry);
|
||||||
extern struct dentry *sdcardfs_lookup(struct inode *dir, struct dentry *dentry,
|
extern struct dentry *sdcardfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd);
|
unsigned int flags);
|
||||||
extern struct inode *sdcardfs_iget(struct super_block *sb,
|
extern struct inode *sdcardfs_iget(struct super_block *sb,
|
||||||
struct inode *lower_inode, userid_t id);
|
struct inode *lower_inode, userid_t id);
|
||||||
extern int sdcardfs_interpose(struct dentry *dentry, struct super_block *sb,
|
extern int sdcardfs_interpose(struct dentry *dentry, struct super_block *sb,
|
||||||
|
|
|
@ -134,7 +134,7 @@ out:
|
||||||
|
|
||||||
|
|
||||||
static struct dentry *squashfs_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *squashfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
const unsigned char *name = dentry->d_name.name;
|
const unsigned char *name = dentry->d_name.name;
|
||||||
int len = dentry->d_name.len;
|
int len = dentry->d_name.len;
|
||||||
|
|
|
@ -743,7 +743,7 @@ int sysfs_create_dir(struct kobject * kobj)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry * sysfs_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry * sysfs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct dentry *ret = NULL;
|
struct dentry *ret = NULL;
|
||||||
struct dentry *parent = dentry->d_parent;
|
struct dentry *parent = dentry->d_parent;
|
||||||
|
|
|
@ -43,7 +43,7 @@ const struct dentry_operations sysv_dentry_operations = {
|
||||||
.d_hash = sysv_hash,
|
.d_hash = sysv_hash,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct dentry *sysv_lookup(struct inode * dir, struct dentry * dentry, struct nameidata *nd)
|
static struct dentry *sysv_lookup(struct inode * dir, struct dentry * dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode * inode = NULL;
|
struct inode * inode = NULL;
|
||||||
ino_t ino;
|
ino_t ino;
|
||||||
|
|
|
@ -192,7 +192,7 @@ static int dbg_check_name(const struct ubifs_info *c,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static struct dentry *ubifs_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *ubifs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
union ubifs_key key;
|
union ubifs_key key;
|
||||||
|
|
|
@ -252,7 +252,7 @@ out_ok:
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *udf_lookup(struct inode *dir, struct dentry *dentry,
|
static struct dentry *udf_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode *inode = NULL;
|
struct inode *inode = NULL;
|
||||||
struct fileIdentDesc cfi;
|
struct fileIdentDesc cfi;
|
||||||
|
|
|
@ -46,7 +46,7 @@ static inline int ufs_add_nondir(struct dentry *dentry, struct inode *inode)
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dentry *ufs_lookup(struct inode * dir, struct dentry *dentry, struct nameidata *nd)
|
static struct dentry *ufs_lookup(struct inode * dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct inode * inode = NULL;
|
struct inode * inode = NULL;
|
||||||
ino_t ino;
|
ino_t ino;
|
||||||
|
|
|
@ -200,7 +200,7 @@ STATIC struct dentry *
|
||||||
xfs_vn_lookup(
|
xfs_vn_lookup(
|
||||||
struct inode *dir,
|
struct inode *dir,
|
||||||
struct dentry *dentry,
|
struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct xfs_inode *cip;
|
struct xfs_inode *cip;
|
||||||
struct xfs_name name;
|
struct xfs_name name;
|
||||||
|
@ -225,7 +225,7 @@ STATIC struct dentry *
|
||||||
xfs_vn_ci_lookup(
|
xfs_vn_ci_lookup(
|
||||||
struct inode *dir,
|
struct inode *dir,
|
||||||
struct dentry *dentry,
|
struct dentry *dentry,
|
||||||
struct nameidata *nd)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct xfs_inode *ip;
|
struct xfs_inode *ip;
|
||||||
struct xfs_name xname;
|
struct xfs_name xname;
|
||||||
|
|
|
@ -1680,7 +1680,7 @@ struct file_operations {
|
||||||
};
|
};
|
||||||
|
|
||||||
struct inode_operations {
|
struct inode_operations {
|
||||||
struct dentry * (*lookup) (struct inode *,struct dentry *, struct nameidata *);
|
struct dentry * (*lookup) (struct inode *,struct dentry *, unsigned int);
|
||||||
void * (*follow_link) (struct dentry *, struct nameidata *);
|
void * (*follow_link) (struct dentry *, struct nameidata *);
|
||||||
int (*permission) (struct inode *, int);
|
int (*permission) (struct inode *, int);
|
||||||
int (*permission2) (struct vfsmount *, struct inode *, int);
|
int (*permission2) (struct vfsmount *, struct inode *, int);
|
||||||
|
@ -2611,7 +2611,7 @@ extern int simple_write_end(struct file *file, struct address_space *mapping,
|
||||||
loff_t pos, unsigned len, unsigned copied,
|
loff_t pos, unsigned len, unsigned copied,
|
||||||
struct page *page, void *fsdata);
|
struct page *page, void *fsdata);
|
||||||
|
|
||||||
extern struct dentry *simple_lookup(struct inode *, struct dentry *, struct nameidata *);
|
extern struct dentry *simple_lookup(struct inode *, struct dentry *, unsigned int flags);
|
||||||
extern ssize_t generic_read_dir(struct file *, char __user *, size_t, loff_t *);
|
extern ssize_t generic_read_dir(struct file *, char __user *, size_t, loff_t *);
|
||||||
extern const struct file_operations simple_dir_operations;
|
extern const struct file_operations simple_dir_operations;
|
||||||
extern const struct inode_operations simple_dir_inode_operations;
|
extern const struct inode_operations simple_dir_inode_operations;
|
||||||
|
|
|
@ -817,7 +817,7 @@ EXPORT_SYMBOL_GPL(cgroup_unlock);
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static int cgroup_mkdir(struct inode *dir, struct dentry *dentry, umode_t mode);
|
static int cgroup_mkdir(struct inode *dir, struct dentry *dentry, umode_t mode);
|
||||||
static struct dentry *cgroup_lookup(struct inode *, struct dentry *, struct nameidata *);
|
static struct dentry *cgroup_lookup(struct inode *, struct dentry *, unsigned int);
|
||||||
static int cgroup_rmdir(struct inode *unused_dir, struct dentry *dentry);
|
static int cgroup_rmdir(struct inode *unused_dir, struct dentry *dentry);
|
||||||
static int cgroup_populate_dir(struct cgroup *cgrp);
|
static int cgroup_populate_dir(struct cgroup *cgrp);
|
||||||
static const struct inode_operations cgroup_dir_inode_operations;
|
static const struct inode_operations cgroup_dir_inode_operations;
|
||||||
|
@ -2544,7 +2544,7 @@ static const struct inode_operations cgroup_dir_inode_operations = {
|
||||||
.rename = cgroup_rename,
|
.rename = cgroup_rename,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct dentry *cgroup_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd)
|
static struct dentry *cgroup_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
|
||||||
{
|
{
|
||||||
if (dentry->d_name.len > NAME_MAX)
|
if (dentry->d_name.len > NAME_MAX)
|
||||||
return ERR_PTR(-ENAMETOOLONG);
|
return ERR_PTR(-ENAMETOOLONG);
|
||||||
|
|
Loading…
Reference in a new issue