dm: zynq: usb: Convert to CONFIG_DM_USB

Convert zynq USB to driver model. Note this is tested on zynq-zybo only.

Signed-off-by: Simon Glass <sjg@chromium.org>
master
Simon Glass 8 years ago
parent 04e38905d7
commit dec49e862e
  1. 2
      arch/arm/Kconfig
  2. 103
      drivers/usb/host/ehci-zynq.c

@ -661,6 +661,7 @@ config ARCH_ZYNQ
select DM_SERIAL select DM_SERIAL
select DM_SPI_FLASH select DM_SPI_FLASH
select SPL_SEPARATE_BSS if SPL select SPL_SEPARATE_BSS if SPL
select DM_USB if USB
config ARCH_ZYNQMP config ARCH_ZYNQMP
bool "Support Xilinx ZynqMP Platform" bool "Support Xilinx ZynqMP Platform"
@ -671,6 +672,7 @@ config ARCH_ZYNQMP
select SUPPORT_SPL select SUPPORT_SPL
select CLK select CLK
select SPL_CLK select SPL_CLK
select DM_USB if USB
config TEGRA config TEGRA
bool "NVIDIA Tegra" bool "NVIDIA Tegra"

@ -7,55 +7,48 @@
*/ */
#include <common.h> #include <common.h>
#include <dm.h>
#include <usb.h>
#include <asm/arch/hardware.h> #include <asm/arch/hardware.h>
#include <asm/arch/sys_proto.h> #include <asm/arch/sys_proto.h>
#include <asm/io.h> #include <asm/io.h>
#include <usb.h>
#include <usb/ehci-ci.h> #include <usb/ehci-ci.h>
#include <usb/ulpi.h> #include <usb/ulpi.h>
#include "ehci.h" #include "ehci.h"
#define ZYNQ_USB_USBCMD_RST 0x0000002 struct zynq_ehci_priv {
#define ZYNQ_USB_USBCMD_STOP 0x0000000 struct ehci_ctrl ehcictrl;
#define ZYNQ_USB_NUM_MIO 12 struct usb_ehci *ehci;
};
/* static int ehci_zynq_ofdata_to_platdata(struct udevice *dev)
* Create the appropriate control structures to manage
* a new EHCI host controller.
*/
int ehci_hcd_init(int index, enum usb_init_type init, struct ehci_hccr **hccr,
struct ehci_hcor **hcor)
{ {
struct usb_ehci *ehci; struct zynq_ehci_priv *priv = dev_get_priv(dev);
priv->ehci = (struct usb_ehci *)dev_get_addr_ptr(dev);
if (!priv->ehci)
return -EINVAL;
return 0;
}
static int ehci_zynq_probe(struct udevice *dev)
{
struct usb_platdata *plat = dev_get_platdata(dev);
struct zynq_ehci_priv *priv = dev_get_priv(dev);
struct ehci_hccr *hccr;
struct ehci_hcor *hcor;
struct ulpi_viewport ulpi_vp; struct ulpi_viewport ulpi_vp;
int ret, mio_usb;
/* Used for writing the ULPI data address */ /* Used for writing the ULPI data address */
struct ulpi_regs *ulpi = (struct ulpi_regs *)0; struct ulpi_regs *ulpi = (struct ulpi_regs *)0;
int ret;
if (!index) { hccr = (struct ehci_hccr *)((uint32_t)&priv->ehci->caplength);
mio_usb = zynq_slcr_get_mio_pin_status("usb0"); hcor = (struct ehci_hcor *)((uint32_t) hccr +
if (mio_usb != ZYNQ_USB_NUM_MIO) { HC_LENGTH(ehci_readl(&hccr->cr_capbase)));
printf("usb0 wrong num MIO: %d, Index %d\n", mio_usb,
index);
return -1;
}
ehci = (struct usb_ehci *)ZYNQ_USB_BASEADDR0;
} else {
mio_usb = zynq_slcr_get_mio_pin_status("usb1");
if (mio_usb != ZYNQ_USB_NUM_MIO) {
printf("usb1 wrong num MIO: %d, Index %d\n", mio_usb,
index);
return -1;
}
ehci = (struct usb_ehci *)ZYNQ_USB_BASEADDR1;
}
*hccr = (struct ehci_hccr *)((uint32_t)&ehci->caplength);
*hcor = (struct ehci_hcor *)((uint32_t) *hccr +
HC_LENGTH(ehci_readl(&(*hccr)->cr_capbase)));
ulpi_vp.viewport_addr = (u32)&ehci->ulpi_viewpoint; ulpi_vp.viewport_addr = (u32)&priv->ehci->ulpi_viewpoint;
ulpi_vp.port_num = 0; ulpi_vp.port_num = 0;
ret = ulpi_init(&ulpi_vp); ret = ulpi_init(&ulpi_vp);
@ -77,28 +70,34 @@ int ehci_hcd_init(int index, enum usb_init_type init, struct ehci_hccr **hccr,
ulpi_write(&ulpi_vp, &ulpi->otg_ctrl_set, ulpi_write(&ulpi_vp, &ulpi->otg_ctrl_set,
ULPI_OTG_DRVVBUS | ULPI_OTG_DRVVBUS_EXT); ULPI_OTG_DRVVBUS | ULPI_OTG_DRVVBUS_EXT);
return 0; return ehci_register(dev, hccr, hcor, NULL, 0, plat->init_type);
} }
/* static int ehci_zynq_remove(struct udevice *dev)
* Destroy the appropriate control structures corresponding
* the the EHCI host controller.
*/
int ehci_hcd_stop(int index)
{ {
struct usb_ehci *ehci; int ret;
if (!index)
ehci = (struct usb_ehci *)ZYNQ_USB_BASEADDR0;
else
ehci = (struct usb_ehci *)ZYNQ_USB_BASEADDR1;
/* Stop controller */ ret = ehci_deregister(dev);
writel(ZYNQ_USB_USBCMD_STOP, &ehci->usbcmd); if (ret)
udelay(1000); return ret;
/* Initiate controller reset */
writel(ZYNQ_USB_USBCMD_RST, &ehci->usbcmd);
return 0; return 0;
} }
static const struct udevice_id ehci_zynq_ids[] = {
{ .compatible = "xlnx,zynq-usb-2.20a" },
{ }
};
U_BOOT_DRIVER(ehci_zynq) = {
.name = "ehci_zynq",
.id = UCLASS_USB,
.of_match = ehci_zynq_ids,
.ofdata_to_platdata = ehci_zynq_ofdata_to_platdata,
.probe = ehci_zynq_probe,
.remove = ehci_zynq_remove,
.ops = &ehci_usb_ops,
.platdata_auto_alloc_size = sizeof(struct usb_platdata),
.priv_auto_alloc_size = sizeof(struct zynq_ehci_priv),
.flags = DM_FLAG_ALLOC_PRIV_DMA,
};

Loading…
Cancel
Save