lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <2b09270f-eb8f-08bd-2133-1a92a34921c2@synopsys.com>
Date:   Fri, 10 Dec 2021 22:17:20 +0000
From:   Thinh Nguyen <Thinh.Nguyen@...opsys.com>
To:     Yaqin Pan <akingchen@...o.com>, Felipe Balbi <balbi@...nel.org>,
        Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
        "linux-usb@...r.kernel.org" <linux-usb@...r.kernel.org>,
        "linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>
CC:     "kernel@...o.com" <kernel@...o.com>
Subject: Re: [PATCH] usb: dwc3: add sprs_ctrl_trans_quirk

Hi,

Yaqin Pan wrote:
> Add a quirk to set GUCTL.SPRSCTRLTRANSEN bit.
> 
> Some special peripherals can't handle the control transfer well.

Can you explain the problem in more detail?

> For example, TF card reader (aaaa:8816):
> usb 1-1: new high-speed USB device number 2 using xhci-hcd
> usb 1-1: device descriptor read/all, error -110
> From the usb analyzer, always return NAK in the data phase.

And how this change help to resolve this issue.

Also note in the patch that this is for host mode.

> 
> Signed-off-by: Yaqin Pan <akingchen@...o.com>
> ---
>  drivers/usb/dwc3/core.c | 4 ++++
>  drivers/usb/dwc3/core.h | 3 +++
>  2 files changed, 7 insertions(+)
> 
> diff --git a/drivers/usb/dwc3/core.c b/drivers/usb/dwc3/core.c
> index ba74ad7f6995..93ac2c79a2c0 100644
> --- a/drivers/usb/dwc3/core.c
> +++ b/drivers/usb/dwc3/core.c
> @@ -1071,6 +1071,8 @@ static int dwc3_core_init(struct dwc3 *dwc)
>  		 * packet with Retry=1 & Nump != 0)
>  		 */
>  		reg |= DWC3_GUCTL_HSTINAUTORETRY;
> +		if (dwc->sprs_ctrl_trans_quirk)
> +			reg |= DWC3_GUCTL_SPRSCTRLTRANSEN;
>  
>  		dwc3_writel(dwc->regs, DWC3_GUCTL, reg);
>  	}
> @@ -1377,6 +1379,8 @@ static void dwc3_get_properties(struct dwc3 *dwc)
>  
>  	dwc->dis_split_quirk = device_property_read_bool(dev,
>  				"snps,dis-split-quirk");
> +	dwc->sprs_ctrl_trans_quirk = device_property_read_bool(dev,
> +				"snps,sprs-ctrl-trans-quirk");

Since you're adding a new device property, please add another patch to
document it in Documentation/devicetree/bindings/usb

BR,
Thinh

>  
>  	dwc->lpm_nyet_threshold = lpm_nyet_threshold;
>  	dwc->tx_de_emphasis = tx_de_emphasis;
> diff --git a/drivers/usb/dwc3/core.h b/drivers/usb/dwc3/core.h
> index 5991766239ba..6048087df1d1 100644
> --- a/drivers/usb/dwc3/core.h
> +++ b/drivers/usb/dwc3/core.h
> @@ -254,6 +254,7 @@
>  
>  /* Global User Control Register */
>  #define DWC3_GUCTL_HSTINAUTORETRY	BIT(14)
> +#define DWC3_GUCTL_SPRSCTRLTRANSEN	BIT(17)
>  
>  /* Global User Control 1 Register */
>  #define DWC3_GUCTL1_PARKMODE_DISABLE_SS	BIT(17)
> @@ -1077,6 +1078,7 @@ struct dwc3_scratchpad_array {
>   *	3	- Reserved
>   * @dis_metastability_quirk: set to disable metastability quirk.
>   * @dis_split_quirk: set to disable split boundary.
> + * @sprs_ctrl_trans_quirk: set to enable sparse control transaction quirk.
>   * @imod_interval: set the interrupt moderation interval in 250ns
>   *			increments or 0 to disable.
>   */
> @@ -1279,6 +1281,7 @@ struct dwc3 {
>  	unsigned		dis_metastability_quirk:1;
>  
>  	unsigned		dis_split_quirk:1;
> +	unsigned		sprs_ctrl_trans_quirk:1;
>  	unsigned		async_callbacks:1;
>  
>  	u16			imod_interval;
> 

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ