Re: [U-Boot] [PATCH 2/4] drivers:usb:fsl: Add XHCI driver support
> -Original Message- > From: Marek Vasut [mailto:ma...@denx.de] > Sent: Wednesday, April 22, 2015 5:17 PM > To: Mehresh Ramneek-B31383 > Cc: u-boot@lists.denx.de > Subject: Re: [PATCH 2/4] drivers:usb:fsl: Add XHCI driver support > > On Wednesday, April 22, 2015 at 08:49:41 AM, Ramneek Mehresh wrote: > > Add xhci driver support for all FSL socs > > > > Signed-off-by: Ramneek Mehresh > > Hi! > > [...] > > > diff --git a/drivers/usb/host/xhci-fsl.c b/drivers/usb/host/xhci-fsl.c > > new file mode 100644 index 000..9d89313 > > --- /dev/null > > +++ b/drivers/usb/host/xhci-fsl.c > > @@ -0,0 +1,110 @@ > > +/* > > + * Copyright 2015 Freescale Semiconductor, Inc. > > + * > > + * FSL USB HOST xHCI Controller > > + * > > + * Author: Ramneek Mehresh > > + * > > + * SPDX-License-Identifier:GPL-2.0+ > > + */ > > + > > +#include > > +#include > > +#include > > +/*#include */ > > +/*#include */ > > Remove these please . > Oops, my bad, will do > > +#include > > +#include > > +#include > > +#include "xhci.h" > > + > > +/* Declare global data pointer */ > > +DECLARE_GLOBAL_DATA_PTR; > > + > > +static struct fsl_xhci fsl_xhci; > > + > > This will do: > agreed > __weak int board_usb_init(...) > { > return 0; > } > > > +inline int __board_usb_init(int index, enum usb_init_type init) { > > + return 0; > > +} > > + > > +int board_usb_init(int index, enum usb_init_type init) > > + __attribute__((weak, alias("__board_usb_init"))); > > Drop the above, just use __weak . > > > +void usb_phy_reset(struct dwc3 *dwc3_reg) { > > + /* Assert USB3 PHY reset */ > > + setbits_le32(&dwc3_reg->g_usb3pipectl[0], > > +DWC3_GUSB3PIPECTL_PHYSOFTRST); > > + > > + /* Assert USB2 PHY reset */ > > + setbits_le32(&dwc3_reg->g_usb2phycfg, > DWC3_GUSB2PHYCFG_PHYSOFTRST); > > + > > + mdelay(200); > > + > > + /* Clear USB3 PHY reset */ > > + clrbits_le32(&dwc3_reg->g_usb3pipectl[0], > > +DWC3_GUSB3PIPECTL_PHYSOFTRST); > > + > > + /* Clear USB2 PHY reset */ > > + clrbits_le32(&dwc3_reg->g_usb2phycfg, > DWC3_GUSB2PHYCFG_PHYSOFTRST); > > +} > > + > > +static int fsl_xhci_core_init(struct fsl_xhci *fsl_xhci) { > > + int ret = 0; > > + > > + ret = dwc3_core_init(fsl_xhci->dwc3_reg); > > + if (ret) { > > + debug("%s:failed to initialize core\n", __func__); > > + return ret; > > + } > > + > > + /* We are hard-coding DWC3 core to Host Mode */ > > + dwc3_set_mode(fsl_xhci->dwc3_reg, DWC3_GCTL_PRTCAP_HOST); > > + > > + return ret; > > +} > > + > > +static int fsl_xhci_core_exit(struct fsl_xhci *fsl_xhci) { > > + /* Currently fsl socs do not support PHY shutdown from > > +* sw. But this support may be added in future socs */ > > Multiline comment should be in this form: > Will correct > /* > * foo > * bar > */ > > > + return 0; > > +} > > + > > +int xhci_hcd_init(int index, struct xhci_hccr **hccr, struct > > +xhci_hcor > > **hcor) +{ > > + struct fsl_xhci *ctx = &fsl_xhci; > > + int ret = 0; > > + > > + ctx->hcd = (struct xhci_hccr *)FSL_XHCI_BASE; > > + ctx->dwc3_reg = (struct dwc3 *)(FSL_XHCI_BASE + > DWC3_REG_OFFSET); > > + > > + ret = board_usb_init(index, USB_INIT_HOST); > > + if (ret != 0) { > > + puts("Failed to initialize board for USB\n"); > > + return ret; > > + } > > + > > + ret = fsl_xhci_core_init(ctx); > > + if (ret < 0) { > > + puts("Failed to initialize xhci\n"); > > + return ret; > > + } > > + > > + *hccr = (struct xhci_hccr *)(FSL_XHCI_BASE); > > + *hcor = (struct xhci_hcor *)((uint32_t) *hccr > > + + HC_LENGTH(xhci_readl(&(*hccr)- > >cr_capbase))); > > + > > + debug("fsl-xhci: init hccr %x and hcor %x hc_length %d\n", > > + (uint32_t)*hccr, (uint32_t)*hcor, > > + (uint32_t)HC_LENGTH(xhci_readl(&(*hccr)->cr_capbase))); > > + > > + return ret; > > +} > > + > > +void xhci_hcd_stop(int index) > > +{ > > + struct fsl_xhci *ctx = &fsl_xhci; > > + > > + fsl_xhci_core_exit(ctx); > > +} > > diff --git a/include/linux/usb/xhci-fsl.h > > b/include/linux/usb/xhci-fsl.h new file mode 100644 index > > 000..1751c7a > > --- /dev/null > > +++ b/include/linux/usb/xhci-fsl.h > > @@ -0,0 +1,58 @@ > > +/* > > + * Copyright 2015 Freescale Semiconductor, Inc. > > + * > > + * FSL USB HOST xHCI Controller > > + * > > + * Author: Ramneek Mehresh > > + * > > + * SPDX-License-Identifier:GPL-2.0+ > > + */ > > + > > +#ifndef _ASM_ARCH_XHCI_FSL_H_ > > +#define _ASM_ARCH_XHCI_FSL_H_ > > + > > +/* Default to the FSL XHCI defines */ #define FSL_XHCI_BASE 0x310 > > +#define FSL_OCP1_SCP_BASE 0x4a084c00 #define > FSL_OTG_WRAPPER_BASE > > +0x4A02 > > This should be in CPU-specific file I guess, not in IP-specific one. > Agreed, let me check which file can be used for this > [...] ___ U-Boot mailing list U-Boot@lists.denx.de http://lists.denx.de/mailman/listinfo/u-boot
Re: [U-Boot] [PATCH 2/4] drivers:usb:fsl: Add XHCI driver support
On Wednesday, April 22, 2015 at 08:49:41 AM, Ramneek Mehresh wrote: > Add xhci driver support for all FSL socs > > Signed-off-by: Ramneek Mehresh Hi! [...] > diff --git a/drivers/usb/host/xhci-fsl.c b/drivers/usb/host/xhci-fsl.c > new file mode 100644 > index 000..9d89313 > --- /dev/null > +++ b/drivers/usb/host/xhci-fsl.c > @@ -0,0 +1,110 @@ > +/* > + * Copyright 2015 Freescale Semiconductor, Inc. > + * > + * FSL USB HOST xHCI Controller > + * > + * Author: Ramneek Mehresh > + * > + * SPDX-License-Identifier: GPL-2.0+ > + */ > + > +#include > +#include > +#include > +/*#include */ > +/*#include */ Remove these please . > +#include > +#include > +#include > +#include "xhci.h" > + > +/* Declare global data pointer */ > +DECLARE_GLOBAL_DATA_PTR; > + > +static struct fsl_xhci fsl_xhci; > + This will do: __weak int board_usb_init(...) { return 0; } > +inline int __board_usb_init(int index, enum usb_init_type init) > +{ > + return 0; > +} > + > +int board_usb_init(int index, enum usb_init_type init) > + __attribute__((weak, alias("__board_usb_init"))); Drop the above, just use __weak . > +void usb_phy_reset(struct dwc3 *dwc3_reg) > +{ > + /* Assert USB3 PHY reset */ > + setbits_le32(&dwc3_reg->g_usb3pipectl[0], DWC3_GUSB3PIPECTL_PHYSOFTRST); > + > + /* Assert USB2 PHY reset */ > + setbits_le32(&dwc3_reg->g_usb2phycfg, DWC3_GUSB2PHYCFG_PHYSOFTRST); > + > + mdelay(200); > + > + /* Clear USB3 PHY reset */ > + clrbits_le32(&dwc3_reg->g_usb3pipectl[0], DWC3_GUSB3PIPECTL_PHYSOFTRST); > + > + /* Clear USB2 PHY reset */ > + clrbits_le32(&dwc3_reg->g_usb2phycfg, DWC3_GUSB2PHYCFG_PHYSOFTRST); > +} > + > +static int fsl_xhci_core_init(struct fsl_xhci *fsl_xhci) > +{ > + int ret = 0; > + > + ret = dwc3_core_init(fsl_xhci->dwc3_reg); > + if (ret) { > + debug("%s:failed to initialize core\n", __func__); > + return ret; > + } > + > + /* We are hard-coding DWC3 core to Host Mode */ > + dwc3_set_mode(fsl_xhci->dwc3_reg, DWC3_GCTL_PRTCAP_HOST); > + > + return ret; > +} > + > +static int fsl_xhci_core_exit(struct fsl_xhci *fsl_xhci) > +{ > + /* Currently fsl socs do not support PHY shutdown from > + * sw. But this support may be added in future socs */ Multiline comment should be in this form: /* * foo * bar */ > + return 0; > +} > + > +int xhci_hcd_init(int index, struct xhci_hccr **hccr, struct xhci_hcor > **hcor) +{ > + struct fsl_xhci *ctx = &fsl_xhci; > + int ret = 0; > + > + ctx->hcd = (struct xhci_hccr *)FSL_XHCI_BASE; > + ctx->dwc3_reg = (struct dwc3 *)(FSL_XHCI_BASE + DWC3_REG_OFFSET); > + > + ret = board_usb_init(index, USB_INIT_HOST); > + if (ret != 0) { > + puts("Failed to initialize board for USB\n"); > + return ret; > + } > + > + ret = fsl_xhci_core_init(ctx); > + if (ret < 0) { > + puts("Failed to initialize xhci\n"); > + return ret; > + } > + > + *hccr = (struct xhci_hccr *)(FSL_XHCI_BASE); > + *hcor = (struct xhci_hcor *)((uint32_t) *hccr > + + HC_LENGTH(xhci_readl(&(*hccr)->cr_capbase))); > + > + debug("fsl-xhci: init hccr %x and hcor %x hc_length %d\n", > + (uint32_t)*hccr, (uint32_t)*hcor, > + (uint32_t)HC_LENGTH(xhci_readl(&(*hccr)->cr_capbase))); > + > + return ret; > +} > + > +void xhci_hcd_stop(int index) > +{ > + struct fsl_xhci *ctx = &fsl_xhci; > + > + fsl_xhci_core_exit(ctx); > +} > diff --git a/include/linux/usb/xhci-fsl.h b/include/linux/usb/xhci-fsl.h > new file mode 100644 > index 000..1751c7a > --- /dev/null > +++ b/include/linux/usb/xhci-fsl.h > @@ -0,0 +1,58 @@ > +/* > + * Copyright 2015 Freescale Semiconductor, Inc. > + * > + * FSL USB HOST xHCI Controller > + * > + * Author: Ramneek Mehresh > + * > + * SPDX-License-Identifier: GPL-2.0+ > + */ > + > +#ifndef _ASM_ARCH_XHCI_FSL_H_ > +#define _ASM_ARCH_XHCI_FSL_H_ > + > +/* Default to the FSL XHCI defines */ > +#define FSL_XHCI_BASE 0x310 > +#define FSL_OCP1_SCP_BASE 0x4a084c00 > +#define FSL_OTG_WRAPPER_BASE 0x4A02 This should be in CPU-specific file I guess, not in IP-specific one. [...] ___ U-Boot mailing list U-Boot@lists.denx.de http://lists.denx.de/mailman/listinfo/u-boot
[U-Boot] [PATCH 2/4] drivers:usb:fsl: Add XHCI driver support
Add xhci driver support for all FSL socs Signed-off-by: Ramneek Mehresh --- drivers/usb/host/Makefile| 1 + drivers/usb/host/xhci-fsl.c | 110 +++ include/linux/usb/xhci-fsl.h | 58 +++ 3 files changed, 169 insertions(+) create mode 100644 drivers/usb/host/xhci-fsl.c create mode 100644 include/linux/usb/xhci-fsl.h diff --git a/drivers/usb/host/Makefile b/drivers/usb/host/Makefile index c0d95cf..7c94439 100644 --- a/drivers/usb/host/Makefile +++ b/drivers/usb/host/Makefile @@ -52,6 +52,7 @@ obj-$(CONFIG_USB_XHCI) += xhci.o xhci-mem.o xhci-ring.o obj-$(CONFIG_USB_XHCI_DWC3) += xhci-dwc3.o obj-$(CONFIG_USB_XHCI_KEYSTONE) += xhci-keystone.o obj-$(CONFIG_USB_XHCI_EXYNOS) += xhci-exynos5.o +obj-$(CONFIG_USB_XHCI_FSL) += xhci-fsl.o obj-$(CONFIG_USB_XHCI_OMAP) += xhci-omap.o obj-$(CONFIG_USB_XHCI_PCI) += xhci-pci.o obj-$(CONFIG_USB_XHCI_UNIPHIER) += xhci-uniphier.o diff --git a/drivers/usb/host/xhci-fsl.c b/drivers/usb/host/xhci-fsl.c new file mode 100644 index 000..9d89313 --- /dev/null +++ b/drivers/usb/host/xhci-fsl.c @@ -0,0 +1,110 @@ +/* + * Copyright 2015 Freescale Semiconductor, Inc. + * + * FSL USB HOST xHCI Controller + * + * Author: Ramneek Mehresh + * + * SPDX-License-Identifier:GPL-2.0+ + */ + +#include +#include +#include +/*#include */ +/*#include */ +#include +#include +#include +#include "xhci.h" + +/* Declare global data pointer */ +DECLARE_GLOBAL_DATA_PTR; + +static struct fsl_xhci fsl_xhci; + +inline int __board_usb_init(int index, enum usb_init_type init) +{ + return 0; +} + +int board_usb_init(int index, enum usb_init_type init) + __attribute__((weak, alias("__board_usb_init"))); + +void usb_phy_reset(struct dwc3 *dwc3_reg) +{ + /* Assert USB3 PHY reset */ + setbits_le32(&dwc3_reg->g_usb3pipectl[0], DWC3_GUSB3PIPECTL_PHYSOFTRST); + + /* Assert USB2 PHY reset */ + setbits_le32(&dwc3_reg->g_usb2phycfg, DWC3_GUSB2PHYCFG_PHYSOFTRST); + + mdelay(200); + + /* Clear USB3 PHY reset */ + clrbits_le32(&dwc3_reg->g_usb3pipectl[0], DWC3_GUSB3PIPECTL_PHYSOFTRST); + + /* Clear USB2 PHY reset */ + clrbits_le32(&dwc3_reg->g_usb2phycfg, DWC3_GUSB2PHYCFG_PHYSOFTRST); +} + +static int fsl_xhci_core_init(struct fsl_xhci *fsl_xhci) +{ + int ret = 0; + + ret = dwc3_core_init(fsl_xhci->dwc3_reg); + if (ret) { + debug("%s:failed to initialize core\n", __func__); + return ret; + } + + /* We are hard-coding DWC3 core to Host Mode */ + dwc3_set_mode(fsl_xhci->dwc3_reg, DWC3_GCTL_PRTCAP_HOST); + + return ret; +} + +static int fsl_xhci_core_exit(struct fsl_xhci *fsl_xhci) +{ + /* Currently fsl socs do not support PHY shutdown from +* sw. But this support may be added in future socs */ + return 0; +} + +int xhci_hcd_init(int index, struct xhci_hccr **hccr, struct xhci_hcor **hcor) +{ + struct fsl_xhci *ctx = &fsl_xhci; + int ret = 0; + + ctx->hcd = (struct xhci_hccr *)FSL_XHCI_BASE; + ctx->dwc3_reg = (struct dwc3 *)(FSL_XHCI_BASE + DWC3_REG_OFFSET); + + ret = board_usb_init(index, USB_INIT_HOST); + if (ret != 0) { + puts("Failed to initialize board for USB\n"); + return ret; + } + + ret = fsl_xhci_core_init(ctx); + if (ret < 0) { + puts("Failed to initialize xhci\n"); + return ret; + } + + *hccr = (struct xhci_hccr *)(FSL_XHCI_BASE); + *hcor = (struct xhci_hcor *)((uint32_t) *hccr + + HC_LENGTH(xhci_readl(&(*hccr)->cr_capbase))); + + debug("fsl-xhci: init hccr %x and hcor %x hc_length %d\n", + (uint32_t)*hccr, (uint32_t)*hcor, + (uint32_t)HC_LENGTH(xhci_readl(&(*hccr)->cr_capbase))); + + return ret; +} + +void xhci_hcd_stop(int index) +{ + struct fsl_xhci *ctx = &fsl_xhci; + + fsl_xhci_core_exit(ctx); +} diff --git a/include/linux/usb/xhci-fsl.h b/include/linux/usb/xhci-fsl.h new file mode 100644 index 000..1751c7a --- /dev/null +++ b/include/linux/usb/xhci-fsl.h @@ -0,0 +1,58 @@ +/* + * Copyright 2015 Freescale Semiconductor, Inc. + * + * FSL USB HOST xHCI Controller + * + * Author: Ramneek Mehresh + * + * SPDX-License-Identifier:GPL-2.0+ + */ + +#ifndef _ASM_ARCH_XHCI_FSL_H_ +#define _ASM_ARCH_XHCI_FSL_H_ + +/* Default to the FSL XHCI defines */ +#define FSL_XHCI_BASE 0x310 +#define FSL_OCP1_SCP_BASE 0x4a084c00 +#define FSL_OTG_WRAPPER_BASE 0x4A02 + +#define USB3_PWRCTL_CLK_CMD_MASK 0x3FE000 +#define USB3_PWRCTL_CLK_FREQ_MASK 0xFFC +#define USB3_PHY_PARTIAL_RX_POWERON BIT(6) +#define USB3_PHY_RX_POWERONBIT(14) +#define USB3_PHY_TX_POWERONBIT(15) +#define USB3_PHY_TX_RX_POWERON (USB3_PHY_RX_POWERON | USB3_PHY_TX_POWERON) +#define USB3_PWRCTL_CLK_CMD_SHIFT 14 +#define USB3_PWRCTL_CLK_FREQ_SHIFT 22 + +/* USBOTGSS_WRA