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.
next prev parent 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).