* Re: [PATCH] vhost: fix VDUSE devices   registration
@ 2025-01-31 17:34 Ariel Otilibili-Anieli
  2025-02-05 21:18 ` Maxime Coquelin
  0 siblings, 1 reply; 6+ messages in thread
From: Ariel Otilibili-Anieli @ 2025-01-31 17:34 UTC (permalink / raw)
  To: Maxime Coquelin; +Cc: dev, david.marchand, chenbox
Hello Maxime,
On Friday, January 31, 2025 14:09 CET, Maxime Coquelin <maxime.coquelin@redhat.com> wrote:
> This patch fixes a regression in vhost_driver_register()
> causing VDUSE devices registration to fail systematically
> because the return value was initialized to -1 and not
> changed later on for this type of devices.
> 
> Fixes: 4d2aa150769b ("vhost: remove check around mutex init")
Thanks for the heads up. I indeed committed 4d2aa150769b ("vhost: remove check around mutex init"); and it contained a hunk for vhost_driver_register().
I applied this patch against the tip of the main; from what I saw, there is no overlap with 4d2aa150769b ("vhost: remove check around mutex init").
It looks 4d2aa150769b ("vhost: remove check around mutex init") came up first, because I was the last person who edited the file.
The tags should be rather these ones:
Fixes: 0adb8eccc6a6 ("vhost: add VDUSE device creation and destruction")
Fixes: 78b2e3bae1af ("vhost: fix initialization")
Fixes: 64ab701c3d1e ("vhost: add vhost-user client mode")
Fixes: 8f972312b8f4 ("vhost: support vhost-user")
Does my reasoning make sense? Let me know.
:) For my understanding; now that 4d2aa150769b ("vhost: remove check around mutex init") needs a fix, is there a way by which I could have detect the regression?
Your help will be much appreciated,
Ariel
^ permalink raw reply	[flat|nested] 6+ messages in thread
* Re: [PATCH] vhost: fix VDUSE devices registration
  2025-01-31 17:34 [PATCH] vhost: fix VDUSE devices registration Ariel Otilibili-Anieli
@ 2025-02-05 21:18 ` Maxime Coquelin
  2025-02-06 21:05   ` Ariel Otilibili-Anieli
  0 siblings, 1 reply; 6+ messages in thread
From: Maxime Coquelin @ 2025-02-05 21:18 UTC (permalink / raw)
  To: Ariel Otilibili-Anieli; +Cc: dev, david.marchand, chenbox
Hi Ariel,
On 1/31/25 6:34 PM, Ariel Otilibili-Anieli wrote:
> Hello Maxime,
> 
> On Friday, January 31, 2025 14:09 CET, Maxime Coquelin <maxime.coquelin@redhat.com> wrote:
> 
>> This patch fixes a regression in vhost_driver_register()
>> causing VDUSE devices registration to fail systematically
>> because the return value was initialized to -1 and not
>> changed later on for this type of devices.
>>
>> Fixes: 4d2aa150769b ("vhost: remove check around mutex init")
> 
> Thanks for the heads up. I indeed committed 4d2aa150769b ("vhost: remove check around mutex init"); and it contained a hunk for vhost_driver_register().
> 
> I applied this patch against the tip of the main; from what I saw, there is no overlap with 4d2aa150769b ("vhost: remove check around mutex init").
> 
> It looks 4d2aa150769b ("vhost: remove check around mutex init") came up first, because I was the last person who edited the file.
> 
> The tags should be rather these ones:
> 
> Fixes: 0adb8eccc6a6 ("vhost: add VDUSE device creation and destruction")
> Fixes: 78b2e3bae1af ("vhost: fix initialization")
> Fixes: 64ab701c3d1e ("vhost: add vhost-user client mode")
> Fixes: 8f972312b8f4 ("vhost: support vhost-user")
> 
> Does my reasoning make sense? Let me know.
Not really :)
Without your patch, ret was assigned by the pthread_mutex_init() return,
so always 0. With your patch, this assignment is removed so ret will
always be -1 for VDUSE devices.
So before your patch, VDUSE devices registration was functional, with
your patch it breaks systematically.
We don't want to backport my patch to LTS that aren't imapcted, so
tagging your patch as the one introducing the regression is the right
thing to do.
> :) For my understanding; now that 4d2aa150769b ("vhost: remove check around mutex init") needs a fix, is there a way by which I could have detect the regression?
It could have been detected by testing VDUSE, that's how I noticed it.
But VDUSE is still fairly recent, and it is not yet tested by the CI.
Now that it is supported in at least Fedora without any kernel change,
we should work on adding CI testing for it.
> Your help will be much appreciated,
> Ariel
> 
Thanks for your contribution,
Maxime
^ permalink raw reply	[flat|nested] 6+ messages in thread
* Re: [PATCH] vhost: fix VDUSE devices  registration
  2025-02-05 21:18 ` Maxime Coquelin
@ 2025-02-06 21:05   ` Ariel Otilibili-Anieli
  0 siblings, 0 replies; 6+ messages in thread
From: Ariel Otilibili-Anieli @ 2025-02-06 21:05 UTC (permalink / raw)
  To: Maxime Coquelin; +Cc: dev, david.marchand, chenbox
Hi Maxime,
On Wednesday, February 05, 2025 22:18 CET, Maxime Coquelin <maxime.coquelin@redhat.com> wrote:
> Hi Ariel,
> 
> 
> Not really :)
> Without your patch, ret was assigned by the pthread_mutex_init() return,
> so always 0. With your patch, this assignment is removed so ret will
> always be -1 for VDUSE devices.
> 
> So before your patch, VDUSE devices registration was functional, with
> your patch it breaks systematically.
> 
> We don't want to backport my patch to LTS that aren't imapcted, so
> tagging your patch as the one introducing the regression is the right
> thing to do.
:) Gotcha; it is now clearer to me.
> 
> > :) For my understanding; now that 4d2aa150769b ("vhost: remove check around mutex init") needs a fix, is there a way by which I could have detect the regression?
> 
> It could have been detected by testing VDUSE, that's how I noticed it.
> But VDUSE is still fairly recent, and it is not yet tested by the CI.
> 
> Now that it is supported in at least Fedora without any kernel change,
> we should work on adding CI testing for it.
> 
> > Your help will be much appreciated,
> > Ariel
> > 
> 
> Thanks for your contribution,
> Maxime
Thanks for having put some of your time into the explanation. 
Have a good day,
Ariel
>
^ permalink raw reply	[flat|nested] 6+ messages in thread
* Re: [PATCH] vhost: fix VDUSE devices registration
  2025-01-31 13:09 Maxime Coquelin
  2025-02-06  8:35 ` Chenbo Xia
@ 2025-02-07 14:12 ` Maxime Coquelin
  1 sibling, 0 replies; 6+ messages in thread
From: Maxime Coquelin @ 2025-02-07 14:12 UTC (permalink / raw)
  To: dev, otilibil, david.marchand, chenbox
On 1/31/25 2:09 PM, Maxime Coquelin wrote:
> This patch fixes a regression in vhost_driver_register()
> causing VDUSE devices registration to fail systematically
> because the return value was initialized to -1 and not
> changed later on for this type of devices.
> 
> Fixes: 4d2aa150769b ("vhost: remove check around mutex init")
> 
> Signed-off-by: Maxime Coquelin <maxime.coquelin@redhat.com>
> ---
>   lib/vhost/socket.c | 10 +++-------
>   1 file changed, 3 insertions(+), 7 deletions(-)
> 
Applied to next-virtio/for-next-net.
Thanks,
Maxime
^ permalink raw reply	[flat|nested] 6+ messages in thread
* Re: [PATCH] vhost: fix VDUSE devices registration
  2025-01-31 13:09 Maxime Coquelin
@ 2025-02-06  8:35 ` Chenbo Xia
  2025-02-07 14:12 ` Maxime Coquelin
  1 sibling, 0 replies; 6+ messages in thread
From: Chenbo Xia @ 2025-02-06  8:35 UTC (permalink / raw)
  To: Maxime Coquelin; +Cc: dev, otilibil, david.marchand
> On Jan 31, 2025, at 21:09, Maxime Coquelin <maxime.coquelin@redhat.com> wrote:
> 
> External email: Use caution opening links or attachments
> 
> 
> This patch fixes a regression in vhost_driver_register()
> causing VDUSE devices registration to fail systematically
> because the return value was initialized to -1 and not
> changed later on for this type of devices.
> 
> Fixes: 4d2aa150769b ("vhost: remove check around mutex init")
> 
> Signed-off-by: Maxime Coquelin <maxime.coquelin@redhat.com>
> ---
> lib/vhost/socket.c | 10 +++-------
> 1 file changed, 3 insertions(+), 7 deletions(-)
> 
> diff --git a/lib/vhost/socket.c b/lib/vhost/socket.c
> index 433a42bf80..894a0f0dcb 100644
> --- a/lib/vhost/socket.c
> +++ b/lib/vhost/socket.c
> @@ -893,7 +893,6 @@ vhost_user_socket_mem_free(struct vhost_user_socket *vsocket)
> int
> rte_vhost_driver_register(const char *path, uint64_t flags)
> {
> -       int ret = -1;
>        struct vhost_user_socket *vsocket;
> 
>        if (!path)
> @@ -997,7 +996,6 @@ rte_vhost_driver_register(const char *path, uint64_t flags)
>        } else {
> #ifndef RTE_LIBRTE_VHOST_POSTCOPY
>                VHOST_CONFIG_LOG(path, ERR, "Postcopy requested but not compiled");
> -               ret = -1;
>                goto out_mutex;
> #endif
>        }
> @@ -1012,15 +1010,14 @@ rte_vhost_driver_register(const char *path, uint64_t flags)
>                } else {
>                        vsocket->is_server = true;
>                }
> -               ret = create_unix_socket(vsocket);
> -               if (ret < 0)
> +               if (create_unix_socket(vsocket) < 0)
>                        goto out_mutex;
>        }
> 
>        vhost_user.vsockets[vhost_user.vsocket_cnt++] = vsocket;
> 
>        pthread_mutex_unlock(&vhost_user.mutex);
> -       return ret;
> +       return 0;
> 
> out_mutex:
>        if (pthread_mutex_destroy(&vsocket->conn_mutex)) {
> @@ -1028,8 +1025,7 @@ rte_vhost_driver_register(const char *path, uint64_t flags)
>        }
> out:
>        pthread_mutex_unlock(&vhost_user.mutex);
> -
> -       return ret;
> +       return -1;
> }
> 
> static bool
> --
> 2.48.1
> 
Reviewed-by: Chenbo Xia <chenbox@nvidia.com>
^ permalink raw reply	[flat|nested] 6+ messages in thread
* [PATCH] vhost: fix VDUSE devices registration
@ 2025-01-31 13:09 Maxime Coquelin
  2025-02-06  8:35 ` Chenbo Xia
  2025-02-07 14:12 ` Maxime Coquelin
  0 siblings, 2 replies; 6+ messages in thread
From: Maxime Coquelin @ 2025-01-31 13:09 UTC (permalink / raw)
  To: dev, otilibil, david.marchand, chenbox; +Cc: Maxime Coquelin
This patch fixes a regression in vhost_driver_register()
causing VDUSE devices registration to fail systematically
because the return value was initialized to -1 and not
changed later on for this type of devices.
Fixes: 4d2aa150769b ("vhost: remove check around mutex init")
Signed-off-by: Maxime Coquelin <maxime.coquelin@redhat.com>
---
 lib/vhost/socket.c | 10 +++-------
 1 file changed, 3 insertions(+), 7 deletions(-)
diff --git a/lib/vhost/socket.c b/lib/vhost/socket.c
index 433a42bf80..894a0f0dcb 100644
--- a/lib/vhost/socket.c
+++ b/lib/vhost/socket.c
@@ -893,7 +893,6 @@ vhost_user_socket_mem_free(struct vhost_user_socket *vsocket)
 int
 rte_vhost_driver_register(const char *path, uint64_t flags)
 {
-	int ret = -1;
 	struct vhost_user_socket *vsocket;
 
 	if (!path)
@@ -997,7 +996,6 @@ rte_vhost_driver_register(const char *path, uint64_t flags)
 	} else {
 #ifndef RTE_LIBRTE_VHOST_POSTCOPY
 		VHOST_CONFIG_LOG(path, ERR, "Postcopy requested but not compiled");
-		ret = -1;
 		goto out_mutex;
 #endif
 	}
@@ -1012,15 +1010,14 @@ rte_vhost_driver_register(const char *path, uint64_t flags)
 		} else {
 			vsocket->is_server = true;
 		}
-		ret = create_unix_socket(vsocket);
-		if (ret < 0)
+		if (create_unix_socket(vsocket) < 0)
 			goto out_mutex;
 	}
 
 	vhost_user.vsockets[vhost_user.vsocket_cnt++] = vsocket;
 
 	pthread_mutex_unlock(&vhost_user.mutex);
-	return ret;
+	return 0;
 
 out_mutex:
 	if (pthread_mutex_destroy(&vsocket->conn_mutex)) {
@@ -1028,8 +1025,7 @@ rte_vhost_driver_register(const char *path, uint64_t flags)
 	}
 out:
 	pthread_mutex_unlock(&vhost_user.mutex);
-
-	return ret;
+	return -1;
 }
 
 static bool
-- 
2.48.1
^ permalink raw reply	[flat|nested] 6+ messages in thread
end of thread, other threads:[~2025-02-07 14:12 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2025-01-31 17:34 [PATCH] vhost: fix VDUSE devices registration Ariel Otilibili-Anieli
2025-02-05 21:18 ` Maxime Coquelin
2025-02-06 21:05   ` Ariel Otilibili-Anieli
  -- strict thread matches above, loose matches on Subject: below --
2025-01-31 13:09 Maxime Coquelin
2025-02-06  8:35 ` Chenbo Xia
2025-02-07 14:12 ` Maxime Coquelin
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).