All of lore.kernel.org
 help / color / mirror / Atom feed
From: Minas Harutyunyan <Minas.Harutyunyan@synopsys.com>
To: John Keeping <john@metanate.com>,
	"linux-usb@vger.kernel.org" <linux-usb@vger.kernel.org>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
	Argishti Aleksanyan <argishti.aleksanyan@synopsys.com>,
	"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH] usb: dwc2: gadget: initialize max_speed from params
Date: Fri, 3 Dec 2021 05:49:36 +0000	[thread overview]
Message-ID: <a2ce248f-79d9-f9a3-f184-e033409fe2b8@synopsys.com> (raw)
In-Reply-To: <20211202171748.3035874-1-john@metanate.com>

Hi John,

On 12/2/2021 9:17 PM, John Keeping wrote:
> DWC2 may be paired with a full-speed PHY which is not capable of
> high-speed operation.  Report this correctly to the gadget core by
> setting max_speed from the core parameters.
> 
> Prior to commit 5324bad66f09f ("usb: dwc2: gadget: implement
> udc_set_speed()") this didn't cause the hardware to be configured
> incorrectly, although the speed may have been reported incorrectly.  But
> after that commit params.speed is updated based on a value passed in by
> the gadget core which may set it to a faster speed than is supported by
> the hardware.  Initialising the max_speed parameter ensures the speed
> passed to dwc2_gadget_set_speed() will be one supported by the hardware.
> 
> Fixes: 5324bad66f09f ("usb: dwc2: gadget: implement udc_set_speed()")
> Signed-off-by: John Keeping <john@metanate.com>
> ---
>   drivers/usb/dwc2/gadget.c | 13 ++++++++++++-
>   1 file changed, 12 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/usb/dwc2/gadget.c b/drivers/usb/dwc2/gadget.c
> index b884a83b26a6e..2bc03f41c70ad 100644
> --- a/drivers/usb/dwc2/gadget.c
> +++ b/drivers/usb/dwc2/gadget.c
> @@ -4974,7 +4974,18 @@ int dwc2_gadget_init(struct dwc2_hsotg *hsotg)
>   		hsotg->params.g_np_tx_fifo_size);
>   	dev_dbg(dev, "RXFIFO size: %d\n", hsotg->params.g_rx_fifo_size);
>   
> -	hsotg->gadget.max_speed = USB_SPEED_HIGH;
> +	switch (hsotg->params.speed) {
> +	case DWC2_SPEED_PARAM_LOW:
> +		hsotg->gadget.max_speed = USB_SPEED_LOW;
> +		break;
> +	case DWC2_SPEED_PARAM_FULL:
> +		hsotg->gadget.max_speed = USB_SPEED_FULL;
> +		break;
> +	default:
> +		hsotg->gadget.max_speed = USB_SPEED_HIGH;
> +		break;
> +	}
> +
>   	hsotg->gadget.ops = &dwc2_hsotg_gadget_ops;
>   	hsotg->gadget.name = dev_name(dev);
>   	hsotg->gadget.otg_caps = &hsotg->params.otg_caps;
> 

Just setting gadget's max_speed doesn't resolve described issue. After 
setting gadget's max_speed in your patch, it doesn't used in driver at 
all. Per me, you need also fix dwc2_gadget_set_speed() function by 
checking requested speed with max_speed: if requested speed higher than 
max_speed then set speed to max_speed.

Thanks,
Minas

  reply	other threads:[~2021-12-03  5:54 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-12-02 17:17 [PATCH] usb: dwc2: gadget: initialize max_speed from params John Keeping
2021-12-03  5:49 ` Minas Harutyunyan [this message]
2021-12-03 11:36   ` John Keeping
2021-12-06  5:21     ` Minas Harutyunyan

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=a2ce248f-79d9-f9a3-f184-e033409fe2b8@synopsys.com \
    --to=minas.harutyunyan@synopsys.com \
    --cc=argishti.aleksanyan@synopsys.com \
    --cc=gregkh@linuxfoundation.org \
    --cc=john@metanate.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-usb@vger.kernel.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.