From: Amir Goldstein <amir73il@gmail.com>
To: NeilBrown <neil@brown.name>
Cc: Miklos Szeredi <miklos@szeredi.hu>,
linux-unionfs@vger.kernel.org, linux-fsdevel@vger.kernel.org
Subject: Re: [PATCH v3 08/21] ovl: simplify gotos in ovl_rename()
Date: Wed, 16 Jul 2025 09:13:39 +0200 [thread overview]
Message-ID: <CAOQ4uxgoArVv-BUPWphhyVhqjAto5efHNMf7xerB-sjsVm8AkQ@mail.gmail.com> (raw)
In-Reply-To: <20250716004725.1206467-9-neil@brown.name>
On Wed, Jul 16, 2025 at 2:47 AM NeilBrown <neil@brown.name> wrote:
>
> Rather than having three separate goto label: out_unlock, out_dput_old,
> and out_dput, make use of that fact that dput() happily accepts a NULL
> pointer to reduce this to just one goto label: out_unlock.
>
> olddentry and newdentry are initialised to NULL and only set once a
> value dentry is found. They are then dput() late in the function.
>
> Suggested-by: Amir Goldstein <amir73il@gmail.com>
> Signed-off-by: NeilBrown <neil@brown.name>
Reviewed-by: Amir Goldstein <amir73il@gmail.com>
> ---
> fs/overlayfs/dir.c | 54 +++++++++++++++++++++++-----------------------
> 1 file changed, 27 insertions(+), 27 deletions(-)
>
> diff --git a/fs/overlayfs/dir.c b/fs/overlayfs/dir.c
> index 7c92ffb6e312..138dd85d2242 100644
> --- a/fs/overlayfs/dir.c
> +++ b/fs/overlayfs/dir.c
> @@ -1082,9 +1082,9 @@ static int ovl_rename(struct mnt_idmap *idmap, struct inode *olddir,
> int err;
> struct dentry *old_upperdir;
> struct dentry *new_upperdir;
> - struct dentry *olddentry;
> - struct dentry *newdentry;
> - struct dentry *trap;
> + struct dentry *olddentry = NULL;
> + struct dentry *newdentry = NULL;
> + struct dentry *trap, *de;
> bool old_opaque;
> bool new_opaque;
> bool cleanup_whiteout = false;
> @@ -1197,21 +1197,23 @@ static int ovl_rename(struct mnt_idmap *idmap, struct inode *olddir,
> goto out_revert_creds;
> }
>
> - olddentry = ovl_lookup_upper(ofs, old->d_name.name, old_upperdir,
> - old->d_name.len);
> - err = PTR_ERR(olddentry);
> - if (IS_ERR(olddentry))
> + de = ovl_lookup_upper(ofs, old->d_name.name, old_upperdir,
> + old->d_name.len);
> + err = PTR_ERR(de);
> + if (IS_ERR(de))
> goto out_unlock;
> + olddentry = de;
>
> err = -ESTALE;
> if (!ovl_matches_upper(old, olddentry))
> - goto out_dput_old;
> + goto out_unlock;
>
> - newdentry = ovl_lookup_upper(ofs, new->d_name.name, new_upperdir,
> - new->d_name.len);
> - err = PTR_ERR(newdentry);
> - if (IS_ERR(newdentry))
> - goto out_dput_old;
> + de = ovl_lookup_upper(ofs, new->d_name.name, new_upperdir,
> + new->d_name.len);
> + err = PTR_ERR(de);
> + if (IS_ERR(de))
> + goto out_unlock;
> + newdentry = de;
>
> old_opaque = ovl_dentry_is_opaque(old);
> new_opaque = ovl_dentry_is_opaque(new);
> @@ -1220,28 +1222,28 @@ static int ovl_rename(struct mnt_idmap *idmap, struct inode *olddir,
> if (d_inode(new) && ovl_dentry_upper(new)) {
> if (opaquedir) {
> if (newdentry != opaquedir)
> - goto out_dput;
> + goto out_unlock;
> } else {
> if (!ovl_matches_upper(new, newdentry))
> - goto out_dput;
> + goto out_unlock;
> }
> } else {
> if (!d_is_negative(newdentry)) {
> if (!new_opaque || !ovl_upper_is_whiteout(ofs, newdentry))
> - goto out_dput;
> + goto out_unlock;
> } else {
> if (flags & RENAME_EXCHANGE)
> - goto out_dput;
> + goto out_unlock;
> }
> }
>
> if (olddentry == trap)
> - goto out_dput;
> + goto out_unlock;
> if (newdentry == trap)
> - goto out_dput;
> + goto out_unlock;
>
> if (olddentry->d_inode == newdentry->d_inode)
> - goto out_dput;
> + goto out_unlock;
>
> err = 0;
> if (ovl_type_merge_or_lower(old))
> @@ -1249,7 +1251,7 @@ static int ovl_rename(struct mnt_idmap *idmap, struct inode *olddir,
> else if (is_dir && !old_opaque && ovl_type_merge(new->d_parent))
> err = ovl_set_opaque_xerr(old, olddentry, -EXDEV);
> if (err)
> - goto out_dput;
> + goto out_unlock;
>
> if (!overwrite && ovl_type_merge_or_lower(new))
> err = ovl_set_redirect(new, samedir);
> @@ -1257,12 +1259,12 @@ static int ovl_rename(struct mnt_idmap *idmap, struct inode *olddir,
> ovl_type_merge(old->d_parent))
> err = ovl_set_opaque_xerr(new, newdentry, -EXDEV);
> if (err)
> - goto out_dput;
> + goto out_unlock;
>
> err = ovl_do_rename(ofs, old_upperdir, olddentry,
> new_upperdir, newdentry, flags);
> if (err)
> - goto out_dput;
> + goto out_unlock;
>
> if (cleanup_whiteout)
> ovl_cleanup(ofs, old_upperdir->d_inode, newdentry);
> @@ -1284,10 +1286,6 @@ static int ovl_rename(struct mnt_idmap *idmap, struct inode *olddir,
> if (d_inode(new) && ovl_dentry_upper(new))
> ovl_copyattr(d_inode(new));
>
> -out_dput:
> - dput(newdentry);
> -out_dput_old:
> - dput(olddentry);
> out_unlock:
> unlock_rename(new_upperdir, old_upperdir);
> out_revert_creds:
> @@ -1297,6 +1295,8 @@ static int ovl_rename(struct mnt_idmap *idmap, struct inode *olddir,
> else
> ovl_drop_write(old);
> out:
> + dput(newdentry);
> + dput(olddentry);
> dput(opaquedir);
> ovl_cache_free(&list);
> return err;
> --
> 2.49.0
>
next prev parent reply other threads:[~2025-07-16 7:13 UTC|newest]
Thread overview: 41+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-07-16 0:44 [PATCH v3 00/21] ovl: narrow regions protected by i_rw_sem NeilBrown
2025-07-16 0:44 ` [PATCH v3 01/21] ovl: simplify an error path in ovl_copy_up_workdir() NeilBrown
2025-07-16 7:12 ` Amir Goldstein
2025-08-04 8:57 ` Miklos Szeredi
2025-07-16 0:44 ` [PATCH v3 02/21] ovl: change ovl_create_index() to take dir locks NeilBrown
2025-07-16 0:44 ` [PATCH v3 03/21] ovl: Call ovl_create_temp() without lock held NeilBrown
2025-07-16 0:44 ` [PATCH v3 04/21] ovl: narrow the locked region in ovl_copy_up_workdir() NeilBrown
2025-07-16 7:13 ` Amir Goldstein
2025-07-16 0:44 ` [PATCH v3 05/21] ovl: narrow locking in ovl_create_upper() NeilBrown
2025-07-16 0:44 ` [PATCH v3 06/21] ovl: narrow locking in ovl_clear_empty() NeilBrown
2025-07-16 0:44 ` [PATCH v3 07/21] ovl: narrow locking in ovl_create_over_whiteout() NeilBrown
2025-07-16 0:44 ` [PATCH v3 08/21] ovl: simplify gotos in ovl_rename() NeilBrown
2025-07-16 7:13 ` Amir Goldstein [this message]
2025-07-16 0:44 ` [PATCH v3 09/21] ovl: narrow locking " NeilBrown
2025-07-16 7:13 ` Amir Goldstein
2025-07-16 0:44 ` [PATCH v3 10/21] ovl: narrow locking in ovl_cleanup_whiteouts() NeilBrown
2025-07-16 0:44 ` [PATCH v3 11/21] ovl: narrow locking in ovl_cleanup_index() NeilBrown
2025-07-16 7:14 ` Amir Goldstein
2025-07-16 0:44 ` [PATCH v3 12/21] ovl: narrow locking in ovl_workdir_create() NeilBrown
2025-07-16 7:15 ` Amir Goldstein
2025-07-16 0:44 ` [PATCH v3 13/21] ovl: narrow locking in ovl_indexdir_cleanup() NeilBrown
2025-07-16 7:15 ` Amir Goldstein
2025-07-16 0:44 ` [PATCH v3 14/21] ovl: narrow locking in ovl_workdir_cleanup_recurse() NeilBrown
2025-07-16 7:16 ` Amir Goldstein
2025-07-16 0:44 ` [PATCH v3 15/21] ovl: change ovl_workdir_cleanup() to take dir lock as needed NeilBrown
2025-07-16 7:16 ` Amir Goldstein
2025-07-16 0:44 ` [PATCH v3 16/21] ovl: narrow locking on ovl_remove_and_whiteout() NeilBrown
2025-07-16 7:16 ` Amir Goldstein
2025-07-16 0:44 ` [PATCH v3 17/21] ovl: change ovl_cleanup_and_whiteout() to take rename lock as needed NeilBrown
2025-07-16 0:44 ` [PATCH v3 18/21] ovl: narrow locking in ovl_whiteout() NeilBrown
2025-07-16 7:15 ` Amir Goldstein
2025-07-16 0:44 ` [PATCH v3 19/21] ovl: narrow locking in ovl_check_rename_whiteout() NeilBrown
2025-07-16 0:44 ` [PATCH v3 20/21] ovl: change ovl_create_real() to receive dentry parent NeilBrown
2025-07-16 0:44 ` [PATCH v3 21/21] ovl: rename ovl_cleanup_unlocked() to ovl_cleanup() NeilBrown
2025-07-16 7:14 ` Amir Goldstein
2025-07-16 7:10 ` [PATCH v3 00/21] ovl: narrow regions protected by i_rw_sem Amir Goldstein
2025-07-16 7:19 ` NeilBrown
2025-07-16 7:35 ` Amir Goldstein
2025-07-16 8:05 ` NeilBrown
2025-07-16 9:09 ` Amir Goldstein
2025-07-18 9:11 ` Christian Brauner
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=CAOQ4uxgoArVv-BUPWphhyVhqjAto5efHNMf7xerB-sjsVm8AkQ@mail.gmail.com \
--to=amir73il@gmail.com \
--cc=linux-fsdevel@vger.kernel.org \
--cc=linux-unionfs@vger.kernel.org \
--cc=miklos@szeredi.hu \
--cc=neil@brown.name \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).