On 05/22/2017 09:42 AM, patrice.chot...@st.com wrote:
> From: Patrice Chotard <patrice.chot...@st.com>
> 
> DWC3 dual role mode is selected using DT "dr_mode"
> property. If not found, DWC3 controller is configured
> in HOST mode by default
> 
> Signed-off-by: Patrice Chotard <patrice.chot...@st.com>

Reviewed-by: Marek Vasut <ma...@denx.de>

> ---
> 
> v2:   _ none
> 
>  drivers/usb/host/xhci-dwc3.c | 9 +++++++++
>  1 file changed, 9 insertions(+)
> 
> diff --git a/drivers/usb/host/xhci-dwc3.c b/drivers/usb/host/xhci-dwc3.c
> index ab75fb7..8367ba2 100644
> --- a/drivers/usb/host/xhci-dwc3.c
> +++ b/drivers/usb/host/xhci-dwc3.c
> @@ -15,6 +15,7 @@
>  #include "xhci.h"
>  #include <asm/io.h>
>  #include <linux/usb/dwc3.h>
> +#include <linux/usb/otg.h>
>  
>  DECLARE_GLOBAL_DATA_PTR;
>  
> @@ -114,6 +115,7 @@ static int xhci_dwc3_probe(struct udevice *dev)
>       struct xhci_hcor *hcor;
>       struct xhci_hccr *hccr;
>       struct dwc3 *dwc3_reg;
> +     enum usb_dr_mode dr_mode;
>  
>       hccr = (struct xhci_hccr *)dev_get_addr(dev);
>       hcor = (struct xhci_hcor *)((phys_addr_t)hccr +
> @@ -123,6 +125,13 @@ static int xhci_dwc3_probe(struct udevice *dev)
>  
>       dwc3_core_init(dwc3_reg);
>  
> +     dr_mode = usb_get_dr_mode(dev_of_offset(dev));
> +     if (dr_mode == USB_DR_MODE_UNKNOWN)
> +             /* by default set dual role mode to HOST */
> +             dr_mode = USB_DR_MODE_HOST;
> +
> +     dwc3_set_mode(dwc3_reg, dr_mode);
> +
>       return xhci_register(dev, hccr, hcor);
>  }
>  
> 


-- 
Best regards,
Marek Vasut
_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
https://lists.denx.de/listinfo/u-boot

Reply via email to