summaryrefslogtreecommitdiff
path: root/drivers/usb/host/ehci-uniphier.c
diff options
context:
space:
mode:
authorMasahiro Yamada <yamada.m@jp.panasonic.com>2014-11-07 18:48:33 +0900
committerMasahiro Yamada <yamada.m@jp.panasonic.com>2014-11-12 00:21:28 +0900
commit048899ba8c54bc3e094185d69d6a62d7e7f9cf30 (patch)
treea28bf7a0be3c31389d722f5bccaac6643c89d677 /drivers/usb/host/ehci-uniphier.c
parent113ef59e45b35f95b3b6b914bae671d61721e9ca (diff)
downloadu-boot-imx-048899ba8c54bc3e094185d69d6a62d7e7f9cf30.zip
u-boot-imx-048899ba8c54bc3e094185d69d6a62d7e7f9cf30.tar.gz
u-boot-imx-048899ba8c54bc3e094185d69d6a62d7e7f9cf30.tar.bz2
usb: UniPhier: add UniPhier on-chip EHCI host driver support
Support EHCI host driver used on Panasonic UniPhier platform. Since Device Tree is not supported on UniPhier yet, the base address of USB cores are passed from board files (platdevice.c). TODO for me: Move the base address to device trees. Signed-off-by: Masahiro Yamada <yamada.m@jp.panasonic.com> Acked-by: Marek Vasut <marex@denx.de>
Diffstat (limited to 'drivers/usb/host/ehci-uniphier.c')
-rw-r--r--drivers/usb/host/ehci-uniphier.c39
1 files changed, 39 insertions, 0 deletions
diff --git a/drivers/usb/host/ehci-uniphier.c b/drivers/usb/host/ehci-uniphier.c
new file mode 100644
index 0000000..77f6c9d
--- /dev/null
+++ b/drivers/usb/host/ehci-uniphier.c
@@ -0,0 +1,39 @@
+/*
+ * Copyright (C) 2014 Panasonic Corporation
+ * Author: Masahiro Yamada <yamada.m@jp.panasonic.com>
+ *
+ * SPDX-License-Identifier: GPL-2.0+
+ */
+
+#include <common.h>
+#include <usb.h>
+#include <asm/arch/ehci-uniphier.h>
+#include "ehci.h"
+
+/*
+ * 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 ehci_hccr *cr;
+ struct ehci_hcor *or;
+
+ uniphier_ehci_reset(index, 0);
+
+ cr = (struct ehci_hccr *)(uniphier_ehci_platdata[index].base);
+ or = (void *)cr + HC_LENGTH(ehci_readl(&cr->cr_capbase));
+
+ *hccr = cr;
+ *hcor = or;
+
+ return 0;
+}
+
+int ehci_hcd_stop(int index)
+{
+ uniphier_ehci_reset(index, 1);
+
+ return 0;
+}