2018-09-20 20:32:49

by Maciej Żenczykowski

[permalink] [raw]
Subject: [PATCH] usbip: fix vhci_hcd controller counting

From: Maciej Żenczykowski <[email protected]>

Without this usbip fails on a machine with devices
that lexicographically come after vhci_hcd.

ie.
$ ls -l /sys/devices/platform
...
drwxr-xr-x. 4 root root 0 Sep 19 16:21 serial8250
-rw-r--r--. 1 root root 4096 Sep 19 23:50 uevent
drwxr-xr-x. 6 root root 0 Sep 20 13:15 vhci_hcd.0
drwxr-xr-x. 4 root root 0 Sep 19 16:22 w83627hf.656

Because it detects 'w83627hf.656' as another vhci_hcd controller,
and then fails to be able to talk to it.

Note: this doesn't actually fix usbip's support for multiple
controllers... that's still broken for other reasons
("vhci_hcd.0" is hardcoded in a string macro), but is enough to
actually make it work on the above machine.

See also:
https://bugzilla.redhat.com/show_bug.cgi?id=1631148

Cc: Jonathan Dieter <[email protected]>
Cc: Valentina Manea <[email protected]>
Cc: Shuah Khan <[email protected]>
Cc: [email protected]
Signed-off-by: Maciej Żenczykowski <[email protected]>
---
tools/usb/usbip/libsrc/vhci_driver.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/tools/usb/usbip/libsrc/vhci_driver.c b/tools/usb/usbip/libsrc/vhci_driver.c
index 4204359c9fee..8159fd98680b 100644
--- a/tools/usb/usbip/libsrc/vhci_driver.c
+++ b/tools/usb/usbip/libsrc/vhci_driver.c
@@ -150,7 +150,7 @@ static int get_nports(struct udev_device *hc_device)

static int vhci_hcd_filter(const struct dirent *dirent)
{
- return strcmp(dirent->d_name, "vhci_hcd") >= 0;
+ return !strncmp(dirent->d_name, "vhci_hcd.", 9);
}

static int get_ncontrollers(void)
--
2.19.0.444.g18242da7ef-goog



2018-09-29 08:24:28

by Maciej Żenczykowski

[permalink] [raw]
Subject: Re: [PATCH] usbip: fix vhci_hcd controller counting

I'm not entirely sure who I should be CC'ing on this... but it's such
an obvious fix...

Thanks,
- Maciej

2018-09-29 10:48:22

by Jonathan Dieter

[permalink] [raw]
Subject: Re: [PATCH] usbip: fix vhci_hcd controller counting

For whatever it's worth, I've tested this on 4.18.9 and can verify that
there are no regressions there.

Tested-by: Jonathan Dieter <[email protected]>


2018-10-01 19:12:37

by Shuah Khan

[permalink] [raw]
Subject: Re: [PATCH] usbip: fix vhci_hcd controller counting

On 09/20/2018 02:29 PM, Maciej Żenczykowski wrote:
> From: Maciej Żenczykowski <[email protected]>
>
> Without this usbip fails on a machine with devices
> that lexicographically come after vhci_hcd.
>
> ie.
> $ ls -l /sys/devices/platform
> ...
> drwxr-xr-x. 4 root root 0 Sep 19 16:21 serial8250
> -rw-r--r--. 1 root root 4096 Sep 19 23:50 uevent
> drwxr-xr-x. 6 root root 0 Sep 20 13:15 vhci_hcd.0
> drwxr-xr-x. 4 root root 0 Sep 19 16:22 w83627hf.656
>
> Because it detects 'w83627hf.656' as another vhci_hcd controller,
> and then fails to be able to talk to it.
>
> Note: this doesn't actually fix usbip's support for multiple
> controllers... that's still broken for other reasons
> ("vhci_hcd.0" is hardcoded in a string macro), but is enough to
> actually make it work on the above machine.
>
> See also:
> https://bugzilla.redhat.com/show_bug.cgi?id=1631148
>
> Cc: Jonathan Dieter <[email protected]>
> Cc: Valentina Manea <[email protected]>
> Cc: Shuah Khan <[email protected]>
> Cc: [email protected]
> Signed-off-by: Maciej Żenczykowski <[email protected]>
> ---
> tools/usb/usbip/libsrc/vhci_driver.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/tools/usb/usbip/libsrc/vhci_driver.c b/tools/usb/usbip/libsrc/vhci_driver.c
> index 4204359c9fee..8159fd98680b 100644
> --- a/tools/usb/usbip/libsrc/vhci_driver.c
> +++ b/tools/usb/usbip/libsrc/vhci_driver.c
> @@ -150,7 +150,7 @@ static int get_nports(struct udev_device *hc_device)
>
> static int vhci_hcd_filter(const struct dirent *dirent)
> {
> - return strcmp(dirent->d_name, "vhci_hcd") >= 0;
> + return !strncmp(dirent->d_name, "vhci_hcd.", 9);
> }
>
> static int get_ncontrollers(void)
>

Thanks for the patch. Looks good to me.

Greg! Can you please pick this up.

Acked-by: Shuah Khan (Samsung OSG) <[email protected]>


thanks,
-- Shuah





thanks,
-- Shuah