qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Jean-Louis Dupond <jean-louis@dupond.be>
To: qemu-devel@nongnu.org, michael.roth@amd.com, kkostiuk@redhat.com
Subject: Re: [PATCH] qga: skip bind mounts in fs list
Date: Wed, 9 Oct 2024 10:34:33 +0200	[thread overview]
Message-ID: <b0a518bc-a600-4d0d-b1c9-5b43f95c90b9@dupond.be> (raw)
In-Reply-To: <20241002100634.162499-2-jean-louis@dupond.be>

On 2/10/2024 12:06, Jean-Louis Dupond wrote:
> The filesystem list in build_fs_mount_list should skip bind mounts.
> This because we end up in locking situations when doing fsFreeze. Like
> mentioned in [1] and [2].
>
> Next to that, the build_fs_mount_list call did a fallback via
> build_fs_mount_list_from_mtab if mountinfo did not exist.
> There it skipped bind mounts, but this is broken for newer OS.
> This as mounts does not return the path of the bind mount but the
> underlying dev/partition, so S_ISDIR will never return true in
> dev_major_minor call.
>
> This patch simply checks the existing devmajor:devminor tuple in the
> mounts, and if it already exists, this means we have the same devices
> mounted again, a bind mount. So skip this.
>
> Same approach is used in open-vm-tools [3].
>
> [1]: https://gitlab.com/qemu-project/qemu/-/issues/592
> [2]: https://gitlab.com/qemu-project/qemu/-/issues/520
> [3]: https://github.com/vmware/open-vm-tools/commit/d58847b497e212737007958c945af1df22a8ab58
>
> Signed-off-by: Jean-Louis Dupond <jean-louis@dupond.be>
> ---
>   qga/commands-linux.c | 25 +++++++++++++++++++++++++
>   1 file changed, 25 insertions(+)
>
> diff --git a/qga/commands-linux.c b/qga/commands-linux.c
> index 51d5e3d927..426b040ab8 100644
> --- a/qga/commands-linux.c
> +++ b/qga/commands-linux.c
> @@ -59,6 +59,22 @@ static int dev_major_minor(const char *devpath,
>       return -1;
>   }
>   
> +/*
> + * Check if we already have the devmajor:devminor in the mounts
> + * If thats the case return true.
> + */
> +static bool dev_exists(FsMountList *mounts, unsigned int devmajor, unsigned int devminor)
> +{
> +    FsMount *mount;
> +
> +    QTAILQ_FOREACH(mount, mounts, next) {
> +        if (mount->devmajor == devmajor && mount->devminor == devminor) {
> +            return true;
> +        }
> +    }
> +    return false;
> +}
> +
>   static bool build_fs_mount_list_from_mtab(FsMountList *mounts, Error **errp)
>   {
>       struct mntent *ment;
> @@ -89,6 +105,10 @@ static bool build_fs_mount_list_from_mtab(FsMountList *mounts, Error **errp)
>               /* Skip bind mounts */
>               continue;
>           }
> +        if (dev_exists(mounts, devmajor, devminor)) {
> +            /* Skip already existing devices (bind mounts) */
> +            continue;
> +        }
>   
>           mount = g_new0(FsMount, 1);
>           mount->dirname = g_strdup(ment->mnt_dir);
> @@ -172,6 +192,11 @@ bool build_fs_mount_list(FsMountList *mounts, Error **errp)
>               }
>           }
>   
> +        if (dev_exists(mounts, devmajor, devminor)) {
> +            /* Skip already existing devices (bind mounts) */
> +            continue;
> +        }
> +
>           mount = g_new0(FsMount, 1);
>           mount->dirname = g_strdup(line + dir_s);
>           mount->devtype = g_strdup(dash + type_s);


Ping + add kkostiuk@redhat.com as I missed him in the initial mail.



  reply	other threads:[~2024-10-09  8:35 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-10-02 10:06 [PATCH] qga: skip bind mounts in fs list Jean-Louis Dupond
2024-10-09  8:34 ` Jean-Louis Dupond [this message]
2024-10-25 10:06   ` Jean-Louis Dupond
2024-10-28 10:57     ` Konstantin Kostiuk
2024-10-28 12:15       ` Jean-Louis Dupond
2024-11-26 10:40         ` Konstantin Kostiuk

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=b0a518bc-a600-4d0d-b1c9-5b43f95c90b9@dupond.be \
    --to=jean-louis@dupond.be \
    --cc=kkostiuk@redhat.com \
    --cc=michael.roth@amd.com \
    --cc=qemu-devel@nongnu.org \
    /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).