提交 fb16043b 编写于 作者: M Miklos Szeredi

vfs: remove open_flags from d_real()

Opening regular files on overlayfs is now handled via ovl_open().  Remove
the now unused "open_flags" argument from d_op->d_real() and the d_real()
helper.
Signed-off-by: NMiklos Szeredi <mszeredi@redhat.com>
上级 573e1784
...@@ -21,8 +21,7 @@ prototypes: ...@@ -21,8 +21,7 @@ prototypes:
char *(*d_dname)((struct dentry *dentry, char *buffer, int buflen); char *(*d_dname)((struct dentry *dentry, char *buffer, int buflen);
struct vfsmount *(*d_automount)(struct path *path); struct vfsmount *(*d_automount)(struct path *path);
int (*d_manage)(const struct path *, bool); int (*d_manage)(const struct path *, bool);
struct dentry *(*d_real)(struct dentry *, const struct inode *, struct dentry *(*d_real)(struct dentry *, const struct inode *);
unsigned int);
locking rules: locking rules:
rename_lock ->d_lock may block rcu-walk rename_lock ->d_lock may block rcu-walk
......
...@@ -1000,8 +1000,7 @@ struct dentry_operations { ...@@ -1000,8 +1000,7 @@ struct dentry_operations {
char *(*d_dname)(struct dentry *, char *, int); char *(*d_dname)(struct dentry *, char *, int);
struct vfsmount *(*d_automount)(struct path *); struct vfsmount *(*d_automount)(struct path *);
int (*d_manage)(const struct path *, bool); int (*d_manage)(const struct path *, bool);
struct dentry *(*d_real)(struct dentry *, const struct inode *, struct dentry *(*d_real)(struct dentry *, const struct inode *);
unsigned int);
}; };
d_revalidate: called when the VFS needs to revalidate a dentry. This d_revalidate: called when the VFS needs to revalidate a dentry. This
...@@ -1135,22 +1134,15 @@ struct dentry_operations { ...@@ -1135,22 +1134,15 @@ struct dentry_operations {
dentry being transited from. dentry being transited from.
d_real: overlay/union type filesystems implement this method to return one of d_real: overlay/union type filesystems implement this method to return one of
the underlying dentries hidden by the overlay. It is used in three the underlying dentries hidden by the overlay. It is used in two
different modes: different modes:
Called from open it may need to copy-up the file depending on the
supplied open flags. This mode is selected with a non-zero flags
argument. In this mode the d_real method can return an error.
Called from file_dentry() it returns the real dentry matching the inode Called from file_dentry() it returns the real dentry matching the inode
argument. The real dentry may be from a lower layer already copied up, argument. The real dentry may be from a lower layer already copied up,
but still referenced from the file. This mode is selected with a but still referenced from the file. This mode is selected with a
non-NULL inode argument. This will always succeed. non-NULL inode argument.
With NULL inode and zero flags the topmost real underlying dentry is
returned. This will always succeed.
This method is never called with both non-NULL inode and non-zero flags. With NULL inode the topmost real underlying dentry is returned.
Each dentry has a pointer to its parent dentry, as well as a hash list Each dentry has a pointer to its parent dentry, as well as a hash list
of child dentries. Child dentries are basically like files in a of child dentries. Child dentries are basically like files in a
......
...@@ -74,28 +74,10 @@ static void ovl_dentry_release(struct dentry *dentry) ...@@ -74,28 +74,10 @@ static void ovl_dentry_release(struct dentry *dentry)
} }
} }
static int ovl_check_append_only(struct inode *inode, int flag)
{
/*
* This test was moot in vfs may_open() because overlay inode does
* not have the S_APPEND flag, so re-check on real upper inode
*/
if (IS_APPEND(inode)) {
if ((flag & O_ACCMODE) != O_RDONLY && !(flag & O_APPEND))
return -EPERM;
if (flag & O_TRUNC)
return -EPERM;
}
return 0;
}
static struct dentry *ovl_d_real(struct dentry *dentry, static struct dentry *ovl_d_real(struct dentry *dentry,
const struct inode *inode, const struct inode *inode)
unsigned int open_flags)
{ {
struct dentry *real; struct dentry *real;
int err;
/* It's an overlay file */ /* It's an overlay file */
if (inode && d_inode(dentry) == inode) if (inode && d_inode(dentry) == inode)
...@@ -107,28 +89,16 @@ static struct dentry *ovl_d_real(struct dentry *dentry, ...@@ -107,28 +89,16 @@ static struct dentry *ovl_d_real(struct dentry *dentry,
goto bug; goto bug;
} }
if (open_flags) {
err = ovl_open_maybe_copy_up(dentry, open_flags);
if (err)
return ERR_PTR(err);
}
real = ovl_dentry_upper(dentry); real = ovl_dentry_upper(dentry);
if (real && (!inode || inode == d_inode(real))) { if (real && (!inode || inode == d_inode(real)))
if (!inode) {
err = ovl_check_append_only(d_inode(real), open_flags);
if (err)
return ERR_PTR(err);
}
return real; return real;
}
real = ovl_dentry_lower(dentry); real = ovl_dentry_lower(dentry);
if (!real) if (!real)
goto bug; goto bug;
/* Handle recursion */ /* Handle recursion */
real = d_real(real, inode, open_flags); real = d_real(real, inode);
if (!inode || inode == d_inode(real)) if (!inode || inode == d_inode(real))
return real; return real;
......
...@@ -145,8 +145,7 @@ struct dentry_operations { ...@@ -145,8 +145,7 @@ struct dentry_operations {
char *(*d_dname)(struct dentry *, char *, int); char *(*d_dname)(struct dentry *, char *, int);
struct vfsmount *(*d_automount)(struct path *); struct vfsmount *(*d_automount)(struct path *);
int (*d_manage)(const struct path *, bool); int (*d_manage)(const struct path *, bool);
struct dentry *(*d_real)(struct dentry *, const struct inode *, struct dentry *(*d_real)(struct dentry *, const struct inode *);
unsigned int);
} ____cacheline_aligned; } ____cacheline_aligned;
/* /*
...@@ -568,7 +567,6 @@ static inline struct dentry *d_backing_dentry(struct dentry *upper) ...@@ -568,7 +567,6 @@ static inline struct dentry *d_backing_dentry(struct dentry *upper)
* d_real - Return the real dentry * d_real - Return the real dentry
* @dentry: the dentry to query * @dentry: the dentry to query
* @inode: inode to select the dentry from multiple layers (can be NULL) * @inode: inode to select the dentry from multiple layers (can be NULL)
* @flags: open flags to control copy-up behavior
* *
* If dentry is on a union/overlay, then return the underlying, real dentry. * If dentry is on a union/overlay, then return the underlying, real dentry.
* Otherwise return the dentry itself. * Otherwise return the dentry itself.
...@@ -576,11 +574,10 @@ static inline struct dentry *d_backing_dentry(struct dentry *upper) ...@@ -576,11 +574,10 @@ static inline struct dentry *d_backing_dentry(struct dentry *upper)
* See also: Documentation/filesystems/vfs.txt * See also: Documentation/filesystems/vfs.txt
*/ */
static inline struct dentry *d_real(struct dentry *dentry, static inline struct dentry *d_real(struct dentry *dentry,
const struct inode *inode, const struct inode *inode)
unsigned int flags)
{ {
if (unlikely(dentry->d_flags & DCACHE_OP_REAL)) if (unlikely(dentry->d_flags & DCACHE_OP_REAL))
return dentry->d_op->d_real(dentry, inode, flags); return dentry->d_op->d_real(dentry, inode);
else else
return dentry; return dentry;
} }
...@@ -595,7 +592,7 @@ static inline struct dentry *d_real(struct dentry *dentry, ...@@ -595,7 +592,7 @@ static inline struct dentry *d_real(struct dentry *dentry,
static inline struct inode *d_real_inode(const struct dentry *dentry) static inline struct inode *d_real_inode(const struct dentry *dentry)
{ {
/* This usage of d_real() results in const dentry */ /* This usage of d_real() results in const dentry */
return d_backing_inode(d_real((struct dentry *) dentry, NULL, 0)); return d_backing_inode(d_real((struct dentry *) dentry, NULL));
} }
struct name_snapshot { struct name_snapshot {
......
...@@ -1239,7 +1239,7 @@ static inline struct inode *file_inode(const struct file *f) ...@@ -1239,7 +1239,7 @@ static inline struct inode *file_inode(const struct file *f)
static inline struct dentry *file_dentry(const struct file *file) static inline struct dentry *file_dentry(const struct file *file)
{ {
return d_real(file->f_path.dentry, file_inode(file), 0); return d_real(file->f_path.dentry, file_inode(file));
} }
static inline int locks_lock_file_wait(struct file *filp, struct file_lock *fl) static inline int locks_lock_file_wait(struct file *filp, struct file_lock *fl)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册