[U-Boot] [PATCH 1/1] usb: host: xhci-dwc3: add missing #ifdef CONFIG_PHY

Marek Vasut marex at denx.de
Thu Jul 20 11:37:51 UTC 2017


On 07/20/2017 01:34 PM, patrice.chotard at st.com wrote:
> From: Patrice Chotard <patrice.chotard at st.com>
> 
> To avoid compilation breakage on platform that don't
> support DM PHY, add the missing CONFIG_PHY flag.

Can we fix this _without_ introducing boatload of ifdefs throughout the
code ?

> Introduced by patch :
> 84e53877 "usb: host: xhci-dwc3: Add generic PHY support"
> 
> Cc: Ran Wang <ran.wang_1 at nxp.com>
> Cc: Bin Meng <bmeng.cn at gmail.com>
> 
> Signed-off-by: Patrice Chotard <patrice.chotard at st.com>
> ---
>  drivers/usb/host/xhci-dwc3.c | 13 ++++++++++++-
>  1 file changed, 12 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/usb/host/xhci-dwc3.c b/drivers/usb/host/xhci-dwc3.c
> index 374fe74..e34f937 100644
> --- a/drivers/usb/host/xhci-dwc3.c
> +++ b/drivers/usb/host/xhci-dwc3.c
> @@ -21,9 +21,11 @@
>  
>  DECLARE_GLOBAL_DATA_PTR;
>  
> +#ifdef CONFIG_PHY
>  struct xhci_dwc3_platdata {
>  	struct phy usb_phy;
>  };
> +#endif
>  
>  void dwc3_set_mode(struct dwc3 *dwc3_reg, u32 mode)
>  {
> @@ -113,17 +115,21 @@ void dwc3_set_fladj(struct dwc3 *dwc3_reg, u32 val)
>  
>  static int xhci_dwc3_probe(struct udevice *dev)
>  {
> +#ifdef CONFIG_PHY
>  	struct xhci_dwc3_platdata *plat = dev_get_platdata(dev);
> +#endif
>  	struct xhci_hcor *hcor;
>  	struct xhci_hccr *hccr;
>  	struct dwc3 *dwc3_reg;
>  	enum usb_dr_mode dr_mode;
> -	int ret;
>  
>  	hccr = (struct xhci_hccr *)devfdt_get_addr(dev);
>  	hcor = (struct xhci_hcor *)((phys_addr_t)hccr +
>  			HC_LENGTH(xhci_readl(&(hccr)->cr_capbase)));
>  
> +#ifdef CONFIG_PHY
> +	int ret;
> +
>  	ret = generic_phy_get_by_index(dev, 0, &plat->usb_phy);
>  	if (ret) {
>  		if (ret != -ENOENT) {
> @@ -137,6 +143,7 @@ static int xhci_dwc3_probe(struct udevice *dev)
>  			return ret;
>  		}
>  	}
> +#endif
>  
>  	dwc3_reg = (struct dwc3 *)((char *)(hccr) + DWC3_REG_OFFSET);
>  
> @@ -154,6 +161,7 @@ static int xhci_dwc3_probe(struct udevice *dev)
>  
>  static int xhci_dwc3_remove(struct udevice *dev)
>  {
> +#ifdef CONFIG_PHY
>  	struct xhci_dwc3_platdata *plat = dev_get_platdata(dev);
>  	int ret;
>  
> @@ -164,6 +172,7 @@ static int xhci_dwc3_remove(struct udevice *dev)
>  			return ret;
>  		}
>  	}
> +#endif
>  
>  	return xhci_deregister(dev);
>  }
> @@ -181,6 +190,8 @@ U_BOOT_DRIVER(xhci_dwc3) = {
>  	.remove = xhci_dwc3_remove,
>  	.ops = &xhci_usb_ops,
>  	.priv_auto_alloc_size = sizeof(struct xhci_ctrl),
> +#ifdef CONFIG_PHY
>  	.platdata_auto_alloc_size = sizeof(struct xhci_dwc3_platdata),
> +#endif
>  	.flags = DM_FLAG_ALLOC_PRIV_DMA,
>  };
> 


-- 
Best regards,
Marek Vasut


More information about the U-Boot mailing list