Hi Kaustabh,

Thank you for the patch.

On Thu, Jan 08, 2026 at 18:03, Kaustabh Chakraborty <[email protected]> 
wrote:

> Documentation [1] states that the default value of the dr_mode property
> is "otg". It also isn't marked a mandatory node, so it may or may not be
> set. So, accordingly if dr_mode is not mentioned in the devicetree node,
> OTG mode must be assumed.
>
> In this driver however, this case is not handled. If dr_mode is not
> mentioned, USB_DR_MODE_UNKNOWN is set. The logic implemented raises an
> error, instead of falling back to USB_DR_MODE_OTG. Correct this to
> conform to the specification.
>
> Link: 
> https://git.kernel.org/pub/scm/linux/kernel/git/devicetree/devicetree-rebasing.git/tree/Bindings/usb/usb-drd.yaml?h=v6.18-dts
>  [1]
> Reviewed-by: Marek Vasut <[email protected]>
> Signed-off-by: Kaustabh Chakraborty <[email protected]>

Reviewed-by: Mattijs Korpershoek <[email protected]>

Note: there is a similar patch submitted by Casey here:
https://lore.kernel.org/all/[email protected]/

Can you have a look at that one please? You could review it or test it
to see if it works for you?

Thanks!
Mattijs

> ---
>  drivers/usb/dwc3/dwc3-generic.c | 9 +++++++--
>  1 file changed, 7 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/usb/dwc3/dwc3-generic.c b/drivers/usb/dwc3/dwc3-generic.c
> index c09014aec60..c15eda19e8f 100644
> --- a/drivers/usb/dwc3/dwc3-generic.c
> +++ b/drivers/usb/dwc3/dwc3-generic.c
> @@ -10,6 +10,7 @@
>  #include <dm.h>
>  #include <reset.h>
>  #include <asm/gpio.h>
> +#include <dm/device_compat.h>
>  #include <dm/lists.h>
>  #include <linux/delay.h>
>  #include <linux/usb/gadget.h>
> @@ -173,8 +174,8 @@ static int dwc3_generic_of_to_plat(struct udevice *dev)
>               node = dev_ofnode(dev->parent);
>               plat->dr_mode = usb_get_dr_mode(node);
>               if (plat->dr_mode == USB_DR_MODE_UNKNOWN) {
> -                     pr_err("Invalid usb mode setup\n");
> -                     return -ENODEV;
> +                     dev_info(dev, "No USB mode specified. Using 'otg'\n");
> +                     plat->dr_mode = USB_DR_MODE_OTG;
>               }
>       }
>  
> @@ -516,6 +517,10 @@ static int dwc3_glue_bind_common(struct udevice *parent, 
> ofnode node)
>       if (!dr_mode)
>               dr_mode = usb_get_dr_mode(node);
>  
> +     /* usb mode must fallback to peripheral if not known */
> +     if (dr_mode == USB_DR_MODE_UNKNOWN)
> +             dr_mode = USB_DR_MODE_OTG;
> +
>       if (CONFIG_IS_ENABLED(DM_USB_GADGET) &&
>           (dr_mode == USB_DR_MODE_PERIPHERAL || dr_mode == USB_DR_MODE_OTG)) {
>               debug("%s: dr_mode: OTG or Peripheral\n", __func__);
>
> -- 
> 2.52.0

Reply via email to