RE: [PATCH V2] USBIP: return correct port ENABLE status

2018-01-10 Thread Zhang, Pei
Hi Shuah,

Thanks for your response. It's on KVM hypervisor platform, while the Dom0 is 
the usbip server, and a DomU act as the client. This issue could be 100% 
reproduced with the specified devices referred in my patch comment.

I will prepare the environment and then send you related information later. 

*  * 
BRs, 
Pei Zhang

> -Original Message-
> From: Shuah Khan [mailto:sh...@kernel.org]
> Sent: Wednesday, January 10, 2018 1:44 AM
> To: Zhang, Pei <pei.zh...@intel.com>; valentina.mane...@gmail.com;
> gre...@linuxfoundation.org
> Cc: linux-...@vger.kernel.org; linux-kernel@vger.kernel.org; Shuah Khan
> <shua...@osg.samsung.com>; Shuah Khan <sh...@kernel.org>
> Subject: Re: [PATCH V2] USBIP: return correct port ENABLE status
> 
> On 12/18/2017 11:00 PM, pei.zh...@intel.com wrote:
> > From: Pei Zhang <pei.zh...@intel.com>
> >
> > USB system will clear port's ENABLE feature for some USB devices when
> > vdev is already assigned port address. This cause getPortStatus
> > reports to system that this device is not enabled, client OS will
> > failed to use this usb device.
> >
> > The failure devices include a SAMSUNG SSD storage, Logitech webcam
> C920.
> >
> > V2: send again to all related maintainers.
> >
> > Signed-off-by: Pei Zhang <pei.zh...@intel.com>
> 
> Hi Pei Zhang,
> 
> Can you elaborate on how you can trigger this condition? Can you send me
> more information on how to recreate the problem and demsg from server
> and client side when this problem happens.
> 
> thanks,
> -- Shuah


RE: [PATCH V2] USBIP: return correct port ENABLE status

2018-01-10 Thread Zhang, Pei
Hi Shuah,

Thanks for your response. It's on KVM hypervisor platform, while the Dom0 is 
the usbip server, and a DomU act as the client. This issue could be 100% 
reproduced with the specified devices referred in my patch comment.

I will prepare the environment and then send you related information later. 

*  * 
BRs, 
Pei Zhang

> -Original Message-
> From: Shuah Khan [mailto:sh...@kernel.org]
> Sent: Wednesday, January 10, 2018 1:44 AM
> To: Zhang, Pei ; valentina.mane...@gmail.com;
> gre...@linuxfoundation.org
> Cc: linux-...@vger.kernel.org; linux-kernel@vger.kernel.org; Shuah Khan
> ; Shuah Khan 
> Subject: Re: [PATCH V2] USBIP: return correct port ENABLE status
> 
> On 12/18/2017 11:00 PM, pei.zh...@intel.com wrote:
> > From: Pei Zhang 
> >
> > USB system will clear port's ENABLE feature for some USB devices when
> > vdev is already assigned port address. This cause getPortStatus
> > reports to system that this device is not enabled, client OS will
> > failed to use this usb device.
> >
> > The failure devices include a SAMSUNG SSD storage, Logitech webcam
> C920.
> >
> > V2: send again to all related maintainers.
> >
> > Signed-off-by: Pei Zhang 
> 
> Hi Pei Zhang,
> 
> Can you elaborate on how you can trigger this condition? Can you send me
> more information on how to recreate the problem and demsg from server
> and client side when this problem happens.
> 
> thanks,
> -- Shuah


Re: [PATCH V2] USBIP: return correct port ENABLE status

2018-01-09 Thread Shuah Khan
On 12/18/2017 11:00 PM, pei.zh...@intel.com wrote:
> From: Pei Zhang 
> 
> USB system will clear port's ENABLE feature for some USB devices when
> vdev is already assigned port address. This cause getPortStatus reports
> to system that this device is not enabled, client OS will failed to use
> this usb device.
> 
> The failure devices include a SAMSUNG SSD storage, Logitech webcam C920.
> 
> V2: send again to all related maintainers.
> 
> Signed-off-by: Pei Zhang 

Hi Pei Zhang,

Can you elaborate on how you can trigger this condition? Can you send me
more information on how to recreate the problem and demsg from server and
client side when this problem happens.

thanks,
-- Shuah


Re: [PATCH V2] USBIP: return correct port ENABLE status

2018-01-09 Thread Shuah Khan
On 12/18/2017 11:00 PM, pei.zh...@intel.com wrote:
> From: Pei Zhang 
> 
> USB system will clear port's ENABLE feature for some USB devices when
> vdev is already assigned port address. This cause getPortStatus reports
> to system that this device is not enabled, client OS will failed to use
> this usb device.
> 
> The failure devices include a SAMSUNG SSD storage, Logitech webcam C920.
> 
> V2: send again to all related maintainers.
> 
> Signed-off-by: Pei Zhang 

Hi Pei Zhang,

Can you elaborate on how you can trigger this condition? Can you send me
more information on how to recreate the problem and demsg from server and
client side when this problem happens.

thanks,
-- Shuah


[PATCH V2] USBIP: return correct port ENABLE status

2017-12-18 Thread pei . zhang
From: Pei Zhang 

USB system will clear port's ENABLE feature for some USB devices when
vdev is already assigned port address. This cause getPortStatus reports
to system that this device is not enabled, client OS will failed to use
this usb device.

The failure devices include a SAMSUNG SSD storage, Logitech webcam C920.

V2: send again to all related maintainers.

Signed-off-by: Pei Zhang 
---
 drivers/usb/usbip/vhci_hcd.c | 63 
 1 file changed, 35 insertions(+), 28 deletions(-)

diff --git a/drivers/usb/usbip/vhci_hcd.c b/drivers/usb/usbip/vhci_hcd.c
index 713e941..7970bab 100644
--- a/drivers/usb/usbip/vhci_hcd.c
+++ b/drivers/usb/usbip/vhci_hcd.c
@@ -430,38 +430,45 @@ static int vhci_hub_control(struct usb_hcd *hcd, u16 
typeReq, u16 wValue,
vhci_hcd->re_timeout = 0;
}
 
-   if ((vhci_hcd->port_status[rhport] & (1 << 
USB_PORT_FEAT_RESET)) !=
-   0 && time_after(jiffies, vhci_hcd->re_timeout)) {
-   vhci_hcd->port_status[rhport] |= (1 << 
USB_PORT_FEAT_C_RESET);
-   vhci_hcd->port_status[rhport] &= ~(1 << 
USB_PORT_FEAT_RESET);
-   vhci_hcd->re_timeout = 0;
-
-   if (vhci_hcd->vdev[rhport].ud.status ==
-   VDEV_ST_NOTASSIGNED) {
-   usbip_dbg_vhci_rh(
-   " enable rhport %d (status %u)\n",
-   rhport,
-   vhci_hcd->vdev[rhport].ud.status);
-   vhci_hcd->port_status[rhport] |=
-   USB_PORT_STAT_ENABLE;
-   }
-
-   if (hcd->speed < HCD_USB3) {
-   switch (vhci_hcd->vdev[rhport].speed) {
-   case USB_SPEED_HIGH:
-   vhci_hcd->port_status[rhport] |=
- USB_PORT_STAT_HIGH_SPEED;
-   break;
-   case USB_SPEED_LOW:
+   if ((vhci_hcd->port_status[rhport] & (1 << 
USB_PORT_FEAT_RESET))) {
+   if (time_after(jiffies, vhci_hcd->re_timeout)) {
+   vhci_hcd->port_status[rhport] |= (1 << 
USB_PORT_FEAT_C_RESET);
+   vhci_hcd->port_status[rhport] &= ~(1 << 
USB_PORT_FEAT_RESET);
+   vhci_hcd->re_timeout = 0;
+
+   if (vhci_hcd->vdev[rhport].ud.status ==
+   VDEV_ST_NOTASSIGNED) {
+   usbip_dbg_vhci_rh(
+   " enable rhport %d (status 
%u)\n",
+   rhport, 
vhci_hcd->vdev[rhport].ud.status);
vhci_hcd->port_status[rhport] |=
-   USB_PORT_STAT_LOW_SPEED;
-   break;
-   default:
-   pr_err("vhci_device speed not set\n");
-   break;
+   USB_PORT_STAT_ENABLE;
+   }
+
+   if (hcd->speed < HCD_USB3) {
+   switch (vhci_hcd->vdev[rhport].speed) {
+   case USB_SPEED_HIGH:
+   vhci_hcd->port_status[rhport] |=
+   
USB_PORT_STAT_HIGH_SPEED;
+   break;
+   case USB_SPEED_LOW:
+   vhci_hcd->port_status[rhport] |=
+   USB_PORT_STAT_LOW_SPEED;
+   break;
+   default:
+   pr_err("vhci_device speed not 
set\n");
+   break;
+   }
}
}
+   } else {
+   /* Port would be disabled by clearing FEAT_ENABLE,
+* make it enabled again here.
+*/
+   if (vhci_hcd->vdev[rhport].ud.status == VDEV_ST_USED)
+   vhci_hcd->port_status[rhport] |= 
USB_PORT_STAT_ENABLE;
}
+
((__le16 *) buf)[0] = 
cpu_to_le16(vhci_hcd->port_status[rhport]);
((__le16 *) buf)[1] =

[PATCH V2] USBIP: return correct port ENABLE status

2017-12-18 Thread pei . zhang
From: Pei Zhang 

USB system will clear port's ENABLE feature for some USB devices when
vdev is already assigned port address. This cause getPortStatus reports
to system that this device is not enabled, client OS will failed to use
this usb device.

The failure devices include a SAMSUNG SSD storage, Logitech webcam C920.

V2: send again to all related maintainers.

Signed-off-by: Pei Zhang 
---
 drivers/usb/usbip/vhci_hcd.c | 63 
 1 file changed, 35 insertions(+), 28 deletions(-)

diff --git a/drivers/usb/usbip/vhci_hcd.c b/drivers/usb/usbip/vhci_hcd.c
index 713e941..7970bab 100644
--- a/drivers/usb/usbip/vhci_hcd.c
+++ b/drivers/usb/usbip/vhci_hcd.c
@@ -430,38 +430,45 @@ static int vhci_hub_control(struct usb_hcd *hcd, u16 
typeReq, u16 wValue,
vhci_hcd->re_timeout = 0;
}
 
-   if ((vhci_hcd->port_status[rhport] & (1 << 
USB_PORT_FEAT_RESET)) !=
-   0 && time_after(jiffies, vhci_hcd->re_timeout)) {
-   vhci_hcd->port_status[rhport] |= (1 << 
USB_PORT_FEAT_C_RESET);
-   vhci_hcd->port_status[rhport] &= ~(1 << 
USB_PORT_FEAT_RESET);
-   vhci_hcd->re_timeout = 0;
-
-   if (vhci_hcd->vdev[rhport].ud.status ==
-   VDEV_ST_NOTASSIGNED) {
-   usbip_dbg_vhci_rh(
-   " enable rhport %d (status %u)\n",
-   rhport,
-   vhci_hcd->vdev[rhport].ud.status);
-   vhci_hcd->port_status[rhport] |=
-   USB_PORT_STAT_ENABLE;
-   }
-
-   if (hcd->speed < HCD_USB3) {
-   switch (vhci_hcd->vdev[rhport].speed) {
-   case USB_SPEED_HIGH:
-   vhci_hcd->port_status[rhport] |=
- USB_PORT_STAT_HIGH_SPEED;
-   break;
-   case USB_SPEED_LOW:
+   if ((vhci_hcd->port_status[rhport] & (1 << 
USB_PORT_FEAT_RESET))) {
+   if (time_after(jiffies, vhci_hcd->re_timeout)) {
+   vhci_hcd->port_status[rhport] |= (1 << 
USB_PORT_FEAT_C_RESET);
+   vhci_hcd->port_status[rhport] &= ~(1 << 
USB_PORT_FEAT_RESET);
+   vhci_hcd->re_timeout = 0;
+
+   if (vhci_hcd->vdev[rhport].ud.status ==
+   VDEV_ST_NOTASSIGNED) {
+   usbip_dbg_vhci_rh(
+   " enable rhport %d (status 
%u)\n",
+   rhport, 
vhci_hcd->vdev[rhport].ud.status);
vhci_hcd->port_status[rhport] |=
-   USB_PORT_STAT_LOW_SPEED;
-   break;
-   default:
-   pr_err("vhci_device speed not set\n");
-   break;
+   USB_PORT_STAT_ENABLE;
+   }
+
+   if (hcd->speed < HCD_USB3) {
+   switch (vhci_hcd->vdev[rhport].speed) {
+   case USB_SPEED_HIGH:
+   vhci_hcd->port_status[rhport] |=
+   
USB_PORT_STAT_HIGH_SPEED;
+   break;
+   case USB_SPEED_LOW:
+   vhci_hcd->port_status[rhport] |=
+   USB_PORT_STAT_LOW_SPEED;
+   break;
+   default:
+   pr_err("vhci_device speed not 
set\n");
+   break;
+   }
}
}
+   } else {
+   /* Port would be disabled by clearing FEAT_ENABLE,
+* make it enabled again here.
+*/
+   if (vhci_hcd->vdev[rhport].ud.status == VDEV_ST_USED)
+   vhci_hcd->port_status[rhport] |= 
USB_PORT_STAT_ENABLE;
}
+
((__le16 *) buf)[0] = 
cpu_to_le16(vhci_hcd->port_status[rhport]);
((__le16 *) buf)[1] =
cpu_to_le16(vhci_hcd->port_status[rhport] >>