Commit 4d925f60 authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'ovl-update-6.8' of git://git.kernel.org/pub/scm/linux/kernel/git/overlayfs/vfs

Pull overlayfs updates from Amir Goldstein:
 "This is a very small update with no bug fixes and no new features.

  The larger update of overlayfs for this cycle, the re-factoring of
  overlayfs code into generic backing_file helpers, was already merged
  via Christian.

  Summary:

   - Simplify/clarify some code

     No bug fixes here, just some changes following questions from Al
     about overlayfs code that could be a little more simple to follow.

   - Overlayfs documentation style fixes

     Mainly fixes for ReST formatting suggested by documentation
     developers"

* tag 'ovl-update-6.8' of git://git.kernel.org/pub/scm/linux/kernel/git/overlayfs/vfs:
  overlayfs.rst: fix ReST formatting
  overlayfs.rst: use consistent feature names
  ovl: initialize ovl_copy_up_ctx.destname inside ovl_do_copy_up()
  ovl: remove redundant ofs->indexdir member
parents 0507d252 d17bb462
This diff is collapsed.
...@@ -952,6 +952,13 @@ static int ovl_do_copy_up(struct ovl_copy_up_ctx *c) ...@@ -952,6 +952,13 @@ static int ovl_do_copy_up(struct ovl_copy_up_ctx *c)
err = -EIO; err = -EIO;
goto out_free_fh; goto out_free_fh;
} else { } else {
/*
* c->dentry->d_name is stabilzed by ovl_copy_up_start(),
* because if we got here, it means that c->dentry has no upper
* alias and changing ->d_name means going through ovl_rename()
* that will call ovl_copy_up() on source and target dentry.
*/
c->destname = c->dentry->d_name;
/* /*
* Mark parent "impure" because it may now contain non-pure * Mark parent "impure" because it may now contain non-pure
* upper * upper
...@@ -1132,7 +1139,6 @@ static int ovl_copy_up_one(struct dentry *parent, struct dentry *dentry, ...@@ -1132,7 +1139,6 @@ static int ovl_copy_up_one(struct dentry *parent, struct dentry *dentry,
if (parent) { if (parent) {
ovl_path_upper(parent, &parentpath); ovl_path_upper(parent, &parentpath);
ctx.destdir = parentpath.dentry; ctx.destdir = parentpath.dentry;
ctx.destname = dentry->d_name;
err = vfs_getattr(&parentpath, &ctx.pstat, err = vfs_getattr(&parentpath, &ctx.pstat,
STATX_ATIME | STATX_MTIME, STATX_ATIME | STATX_MTIME,
......
...@@ -460,7 +460,7 @@ static struct dentry *ovl_lookup_real_inode(struct super_block *sb, ...@@ -460,7 +460,7 @@ static struct dentry *ovl_lookup_real_inode(struct super_block *sb,
* For decoded lower dir file handle, lookup index by origin to check * For decoded lower dir file handle, lookup index by origin to check
* if lower dir was copied up and and/or removed. * if lower dir was copied up and and/or removed.
*/ */
if (!this && layer->idx && ofs->indexdir && !WARN_ON(!d_is_dir(real))) { if (!this && layer->idx && ovl_indexdir(sb) && !WARN_ON(!d_is_dir(real))) {
index = ovl_lookup_index(ofs, NULL, real, false); index = ovl_lookup_index(ofs, NULL, real, false);
if (IS_ERR(index)) if (IS_ERR(index))
return index; return index;
...@@ -733,7 +733,7 @@ static struct dentry *ovl_lower_fh_to_d(struct super_block *sb, ...@@ -733,7 +733,7 @@ static struct dentry *ovl_lower_fh_to_d(struct super_block *sb,
} }
/* Then lookup indexed upper/whiteout by origin fh */ /* Then lookup indexed upper/whiteout by origin fh */
if (ofs->indexdir) { if (ovl_indexdir(sb)) {
index = ovl_get_index_fh(ofs, fh); index = ovl_get_index_fh(ofs, fh);
err = PTR_ERR(index); err = PTR_ERR(index);
if (IS_ERR(index)) { if (IS_ERR(index)) {
......
...@@ -754,7 +754,7 @@ struct dentry *ovl_get_index_fh(struct ovl_fs *ofs, struct ovl_fh *fh) ...@@ -754,7 +754,7 @@ struct dentry *ovl_get_index_fh(struct ovl_fs *ofs, struct ovl_fh *fh)
if (err) if (err)
return ERR_PTR(err); return ERR_PTR(err);
index = lookup_positive_unlocked(name.name, ofs->indexdir, name.len); index = lookup_positive_unlocked(name.name, ofs->workdir, name.len);
kfree(name.name); kfree(name.name);
if (IS_ERR(index)) { if (IS_ERR(index)) {
if (PTR_ERR(index) == -ENOENT) if (PTR_ERR(index) == -ENOENT)
...@@ -787,7 +787,7 @@ struct dentry *ovl_lookup_index(struct ovl_fs *ofs, struct dentry *upper, ...@@ -787,7 +787,7 @@ struct dentry *ovl_lookup_index(struct ovl_fs *ofs, struct dentry *upper,
return ERR_PTR(err); return ERR_PTR(err);
index = lookup_one_positive_unlocked(ovl_upper_mnt_idmap(ofs), name.name, index = lookup_one_positive_unlocked(ovl_upper_mnt_idmap(ofs), name.name,
ofs->indexdir, name.len); ofs->workdir, name.len);
if (IS_ERR(index)) { if (IS_ERR(index)) {
err = PTR_ERR(index); err = PTR_ERR(index);
if (err == -ENOENT) { if (err == -ENOENT) {
......
...@@ -63,10 +63,8 @@ struct ovl_fs { ...@@ -63,10 +63,8 @@ struct ovl_fs {
struct ovl_sb *fs; struct ovl_sb *fs;
/* workbasedir is the path at workdir= mount option */ /* workbasedir is the path at workdir= mount option */
struct dentry *workbasedir; struct dentry *workbasedir;
/* workdir is the 'work' directory under workbasedir */ /* workdir is the 'work' or 'index' directory under workbasedir */
struct dentry *workdir; struct dentry *workdir;
/* index directory listing overlay inodes by origin file handle */
struct dentry *indexdir;
long namelen; long namelen;
/* pathnames of lower and upper dirs, for show_options */ /* pathnames of lower and upper dirs, for show_options */
struct ovl_config config; struct ovl_config config;
...@@ -81,7 +79,6 @@ struct ovl_fs { ...@@ -81,7 +79,6 @@ struct ovl_fs {
/* Traps in ovl inode cache */ /* Traps in ovl inode cache */
struct inode *workbasedir_trap; struct inode *workbasedir_trap;
struct inode *workdir_trap; struct inode *workdir_trap;
struct inode *indexdir_trap;
/* -1: disabled, 0: same fs, 1..32: number of unused ino bits */ /* -1: disabled, 0: same fs, 1..32: number of unused ino bits */
int xino_mode; int xino_mode;
/* For allocation of non-persistent inode numbers */ /* For allocation of non-persistent inode numbers */
......
...@@ -743,10 +743,8 @@ void ovl_free_fs(struct ovl_fs *ofs) ...@@ -743,10 +743,8 @@ void ovl_free_fs(struct ovl_fs *ofs)
unsigned i; unsigned i;
iput(ofs->workbasedir_trap); iput(ofs->workbasedir_trap);
iput(ofs->indexdir_trap);
iput(ofs->workdir_trap); iput(ofs->workdir_trap);
dput(ofs->whiteout); dput(ofs->whiteout);
dput(ofs->indexdir);
dput(ofs->workdir); dput(ofs->workdir);
if (ofs->workdir_locked) if (ofs->workdir_locked)
ovl_inuse_unlock(ofs->workbasedir); ovl_inuse_unlock(ofs->workbasedir);
......
...@@ -1169,7 +1169,7 @@ int ovl_workdir_cleanup(struct ovl_fs *ofs, struct inode *dir, ...@@ -1169,7 +1169,7 @@ int ovl_workdir_cleanup(struct ovl_fs *ofs, struct inode *dir,
int ovl_indexdir_cleanup(struct ovl_fs *ofs) int ovl_indexdir_cleanup(struct ovl_fs *ofs)
{ {
int err; int err;
struct dentry *indexdir = ofs->indexdir; struct dentry *indexdir = ofs->workdir;
struct dentry *index = NULL; struct dentry *index = NULL;
struct inode *dir = indexdir->d_inode; struct inode *dir = indexdir->d_inode;
struct path path = { .mnt = ovl_upper_mnt(ofs), .dentry = indexdir }; struct path path = { .mnt = ovl_upper_mnt(ofs), .dentry = indexdir };
......
...@@ -853,10 +853,8 @@ static int ovl_get_indexdir(struct super_block *sb, struct ovl_fs *ofs, ...@@ -853,10 +853,8 @@ static int ovl_get_indexdir(struct super_block *sb, struct ovl_fs *ofs,
if (IS_ERR(indexdir)) { if (IS_ERR(indexdir)) {
err = PTR_ERR(indexdir); err = PTR_ERR(indexdir);
} else if (indexdir) { } else if (indexdir) {
ofs->indexdir = indexdir; ofs->workdir = indexdir;
ofs->workdir = dget(indexdir); err = ovl_setup_trap(sb, indexdir, &ofs->workdir_trap,
err = ovl_setup_trap(sb, ofs->indexdir, &ofs->indexdir_trap,
"indexdir"); "indexdir");
if (err) if (err)
goto out; goto out;
...@@ -869,16 +867,15 @@ static int ovl_get_indexdir(struct super_block *sb, struct ovl_fs *ofs, ...@@ -869,16 +867,15 @@ static int ovl_get_indexdir(struct super_block *sb, struct ovl_fs *ofs,
* ".overlay.upper" to indicate that index may have * ".overlay.upper" to indicate that index may have
* directory entries. * directory entries.
*/ */
if (ovl_check_origin_xattr(ofs, ofs->indexdir)) { if (ovl_check_origin_xattr(ofs, indexdir)) {
err = ovl_verify_origin_xattr(ofs, ofs->indexdir, err = ovl_verify_origin_xattr(ofs, indexdir,
OVL_XATTR_ORIGIN, OVL_XATTR_ORIGIN,
upperpath->dentry, true, upperpath->dentry, true,
false); false);
if (err) if (err)
pr_err("failed to verify index dir 'origin' xattr\n"); pr_err("failed to verify index dir 'origin' xattr\n");
} }
err = ovl_verify_upper(ofs, ofs->indexdir, upperpath->dentry, err = ovl_verify_upper(ofs, indexdir, upperpath->dentry, true);
true);
if (err) if (err)
pr_err("failed to verify index dir 'upper' xattr\n"); pr_err("failed to verify index dir 'upper' xattr\n");
...@@ -886,7 +883,7 @@ static int ovl_get_indexdir(struct super_block *sb, struct ovl_fs *ofs, ...@@ -886,7 +883,7 @@ static int ovl_get_indexdir(struct super_block *sb, struct ovl_fs *ofs,
if (!err) if (!err)
err = ovl_indexdir_cleanup(ofs); err = ovl_indexdir_cleanup(ofs);
} }
if (err || !ofs->indexdir) if (err || !indexdir)
pr_warn("try deleting index dir or mounting with '-o index=off' to disable inodes index.\n"); pr_warn("try deleting index dir or mounting with '-o index=off' to disable inodes index.\n");
out: out:
...@@ -1406,7 +1403,7 @@ int ovl_fill_super(struct super_block *sb, struct fs_context *fc) ...@@ -1406,7 +1403,7 @@ int ovl_fill_super(struct super_block *sb, struct fs_context *fc)
goto out_free_oe; goto out_free_oe;
/* Force r/o mount with no index dir */ /* Force r/o mount with no index dir */
if (!ofs->indexdir) if (!ofs->workdir)
sb->s_flags |= SB_RDONLY; sb->s_flags |= SB_RDONLY;
} }
...@@ -1415,7 +1412,7 @@ int ovl_fill_super(struct super_block *sb, struct fs_context *fc) ...@@ -1415,7 +1412,7 @@ int ovl_fill_super(struct super_block *sb, struct fs_context *fc)
goto out_free_oe; goto out_free_oe;
/* Show index=off in /proc/mounts for forced r/o mount */ /* Show index=off in /proc/mounts for forced r/o mount */
if (!ofs->indexdir) { if (!ofs->workdir) {
ofs->config.index = false; ofs->config.index = false;
if (ovl_upper_mnt(ofs) && ofs->config.nfs_export) { if (ovl_upper_mnt(ofs) && ofs->config.nfs_export) {
pr_warn("NFS export requires an index dir, falling back to nfs_export=off.\n"); pr_warn("NFS export requires an index dir, falling back to nfs_export=off.\n");
......
...@@ -91,7 +91,7 @@ struct dentry *ovl_indexdir(struct super_block *sb) ...@@ -91,7 +91,7 @@ struct dentry *ovl_indexdir(struct super_block *sb)
{ {
struct ovl_fs *ofs = OVL_FS(sb); struct ovl_fs *ofs = OVL_FS(sb);
return ofs->indexdir; return ofs->config.index ? ofs->workdir : NULL;
} }
/* Index all files on copy up. For now only enabled for NFS export */ /* Index all files on copy up. For now only enabled for NFS export */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment