* [U-Boot] [RESEND Patch v3] Atmel : usb : add EHCI driver for Atmel SoC
@ 2012-06-28 7:58 Bo Shen
2012-06-28 10:51 ` Marek Vasut
2012-06-28 12:13 ` Andreas Bießmann
0 siblings, 2 replies; 5+ messages in thread
From: Bo Shen @ 2012-06-28 7:58 UTC (permalink / raw)
To: u-boot
Some Atmel SoC support USB EHCI, add the EHCI driver to support it.
To enable the USB EHCI, add the following configuration options into
board relative configuration file and remove USB OHCI options.
#define CONFIG_USB_EHCI
#define CONFIG_USB_EHCI_ATMEL
#define CONFIG_SYS_USB_EHCI_MAX_ROOT_PORTS 2
Signed-off-by: Bo Shen <voice.shen@atmel.com>
---
Change since v2:
Add timeout and change the coding style
Change since v1:
Add WATCHDOG_RESET to avoid infinite loop.
---
drivers/usb/host/Makefile | 1 +
drivers/usb/host/ehci-atmel.c | 89 +++++++++++++++++++++++++++++++++++++++++
2 files changed, 90 insertions(+)
create mode 100644 drivers/usb/host/ehci-atmel.c
diff --git a/drivers/usb/host/Makefile b/drivers/usb/host/Makefile
index 59c3e57..4547f37 100644
--- a/drivers/usb/host/Makefile
+++ b/drivers/usb/host/Makefile
@@ -36,6 +36,7 @@ COBJS-$(CONFIG_USB_SL811HS) += sl811-hcd.o
# echi
COBJS-$(CONFIG_USB_EHCI) += ehci-hcd.o
COBJS-$(CONFIG_USB_EHCI_ARMADA100) += ehci-armada100.o utmi-armada100.o
+COBJS-$(CONFIG_USB_EHCI_ATMEL) += ehci-atmel.o
ifdef CONFIG_MPC512X
COBJS-$(CONFIG_USB_EHCI_FSL) += ehci-mpc512x.o
else
diff --git a/drivers/usb/host/ehci-atmel.c b/drivers/usb/host/ehci-atmel.c
new file mode 100644
index 0000000..532db22
--- /dev/null
+++ b/drivers/usb/host/ehci-atmel.c
@@ -0,0 +1,89 @@
+/*
+ * (C) Copyright 2012
+ * Atmel Semiconductor <www.atmel.com>
+ * Written-by: Bo Shen <voice.shen@atmel.com>
+ *
+ * See file CREDITS for list of people who contributed to this
+ * project.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of
+ * the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
+ * MA 02110-1301 USA
+ */
+
+#include <common.h>
+#include <watchdog.h>
+#include <usb.h>
+#include <asm/io.h>
+#include <asm/arch/hardware.h>
+#include <asm/arch/at91_pmc.h>
+#include <asm/arch/clk.h>
+
+#include "ehci.h"
+#include "ehci-core.h"
+
+/* Enable UTMI PLL time out 500us
+ * 10 times as datasheet specified
+ */
+#define EN_UPLL_TIMEOUT 500UL
+
+int ehci_hcd_init(void)
+{
+ at91_pmc_t *pmc = (at91_pmc_t *)ATMEL_BASE_PMC;
+ ulong start_time, tmp_time;
+
+ start_time = get_timer(0);
+ /* Enable UTMI PLL */
+ writel(AT91_PMC_UPLLEN | AT91_PMC_BIASEN, &pmc->uckr);
+ while (readl(&pmc->sr) & AT91_PMC_LOCKU != AT91_PMC_LOCKU) {
+ WATCHDOG_RESET();
+ tmp_time = get_timer(0);
+ if ((tmp_time - start_time) > EN_UPLL_TIMEOUT) {
+ printf("ERROR: failed to enable UPLL\n");
+ return -1;
+ }
+ }
+
+ /* Enable USB Host clock */
+ writel(1 << ATMEL_ID_UHPHS, &pmc->pcer);
+
+ hccr = (struct ehci_hccr *)ATMEL_BASE_EHCI;
+ hcor = (struct ehci_hcor *)((uint32_t)hccr +
+ HC_LENGTH(ehci_readl(&hccr->cr_capbase)));
+
+ return 0;
+}
+
+int ehci_hcd_stop(void)
+{
+ at91_pmc_t *pmc = (at91_pmc_t *)ATMEL_BASE_PMC;
+ ulong start_time, tmp_time;
+
+ /* Disable USB Host Clock */
+ writel(1 << ATMEL_ID_UHPHS, &pmc->pcdr);
+
+ start_time = get_timer(0);
+ /* Disable UTMI PLL */
+ writel(readl(&pmc->uckr) & ~AT91_PMC_UPLLEN, &pmc->uckr);
+ while (readl(&pmc->sr) & AT91_PMC_LOCKU == AT91_PMC_LOCKU) {
+ WATCHDOG_RESET();
+ tmp_time = get_timer(0);
+ if ((tmp_time - start_time) > EN_UPLL_TIMEOUT) {
+ printf("ERROR: failed to stop UPLL\n");
+ return -1;
+ }
+ }
+
+ return 0;
+}
--
1.7.9.5
^ permalink raw reply related [flat|nested] 5+ messages in thread* [U-Boot] [RESEND Patch v3] Atmel : usb : add EHCI driver for Atmel SoC
2012-06-28 7:58 [U-Boot] [RESEND Patch v3] Atmel : usb : add EHCI driver for Atmel SoC Bo Shen
@ 2012-06-28 10:51 ` Marek Vasut
2012-06-28 11:26 ` Andreas Bießmann
2012-06-28 12:13 ` Andreas Bießmann
1 sibling, 1 reply; 5+ messages in thread
From: Marek Vasut @ 2012-06-28 10:51 UTC (permalink / raw)
To: u-boot
Dear Bo Shen,
> Some Atmel SoC support USB EHCI, add the EHCI driver to support it.
>
> To enable the USB EHCI, add the following configuration options into
> board relative configuration file and remove USB OHCI options.
>
> #define CONFIG_USB_EHCI
> #define CONFIG_USB_EHCI_ATMEL
> #define CONFIG_SYS_USB_EHCI_MAX_ROOT_PORTS 2
>
> Signed-off-by: Bo Shen <voice.shen@atmel.com>
> ---
> Change since v2:
> Add timeout and change the coding style
>
> Change since v1:
> Add WATCHDOG_RESET to avoid infinite loop.
Andreas, wanna apply this?
Best regards,
Marek Vasut
^ permalink raw reply [flat|nested] 5+ messages in thread
* [U-Boot] [RESEND Patch v3] Atmel : usb : add EHCI driver for Atmel SoC
2012-06-28 10:51 ` Marek Vasut
@ 2012-06-28 11:26 ` Andreas Bießmann
2012-06-28 11:38 ` Marek Vasut
0 siblings, 1 reply; 5+ messages in thread
From: Andreas Bießmann @ 2012-06-28 11:26 UTC (permalink / raw)
To: u-boot
Dear Marek Vasut,
On 28.06.2012 12:51, Marek Vasut wrote:
> Dear Bo Shen,
>
>> Some Atmel SoC support USB EHCI, add the EHCI driver to support it.
>>
>> To enable the USB EHCI, add the following configuration options into
>> board relative configuration file and remove USB OHCI options.
>>
>> #define CONFIG_USB_EHCI
>> #define CONFIG_USB_EHCI_ATMEL
>> #define CONFIG_SYS_USB_EHCI_MAX_ROOT_PORTS 2
>>
>> Signed-off-by: Bo Shen <voice.shen@atmel.com>
>> ---
>> Change since v2:
>> Add timeout and change the coding style
>>
>> Change since v1:
>> Add WATCHDOG_RESET to avoid infinite loop.
>
> Andreas, wanna apply this?
will do, can I get your ACK?
Best regards
Andreas Bie?mann
^ permalink raw reply [flat|nested] 5+ messages in thread
* [U-Boot] [RESEND Patch v3] Atmel : usb : add EHCI driver for Atmel SoC
2012-06-28 11:26 ` Andreas Bießmann
@ 2012-06-28 11:38 ` Marek Vasut
0 siblings, 0 replies; 5+ messages in thread
From: Marek Vasut @ 2012-06-28 11:38 UTC (permalink / raw)
To: u-boot
Dear Andreas Bie?mann,
> Dear Marek Vasut,
>
> On 28.06.2012 12:51, Marek Vasut wrote:
> > Dear Bo Shen,
> >
> >> Some Atmel SoC support USB EHCI, add the EHCI driver to support it.
> >>
> >> To enable the USB EHCI, add the following configuration options into
> >> board relative configuration file and remove USB OHCI options.
> >>
> >> #define CONFIG_USB_EHCI
> >> #define CONFIG_USB_EHCI_ATMEL
> >> #define CONFIG_SYS_USB_EHCI_MAX_ROOT_PORTS 2
> >>
> >> Signed-off-by: Bo Shen <voice.shen@atmel.com>
> >> ---
> >>
> >> Change since v2:
> >> Add timeout and change the coding style
> >>
> >> Change since v1:
> >> Add WATCHDOG_RESET to avoid infinite loop.
> >
> > Andreas, wanna apply this?
>
> will do, can I get your ACK?
Definitelly
Acked-by: Marek Vasut <marex@denx.de>
>
> Best regards
>
> Andreas Bie?mann
Best regards,
Marek Vasut
^ permalink raw reply [flat|nested] 5+ messages in thread
* [U-Boot] [RESEND Patch v3] Atmel : usb : add EHCI driver for Atmel SoC
2012-06-28 7:58 [U-Boot] [RESEND Patch v3] Atmel : usb : add EHCI driver for Atmel SoC Bo Shen
2012-06-28 10:51 ` Marek Vasut
@ 2012-06-28 12:13 ` Andreas Bießmann
1 sibling, 0 replies; 5+ messages in thread
From: Andreas Bießmann @ 2012-06-28 12:13 UTC (permalink / raw)
To: u-boot
Dear Bo Shen,
On 28.06.2012 09:58, Bo Shen wrote:
> Some Atmel SoC support USB EHCI, add the EHCI driver to support it.
>
> To enable the USB EHCI, add the following configuration options into
> board relative configuration file and remove USB OHCI options.
>
> #define CONFIG_USB_EHCI
> #define CONFIG_USB_EHCI_ATMEL
> #define CONFIG_SYS_USB_EHCI_MAX_ROOT_PORTS 2
>
> Signed-off-by: Bo Shen <voice.shen@atmel.com>
> ---
> Change since v2:
> Add timeout and change the coding style
>
> Change since v1:
> Add WATCHDOG_RESET to avoid infinite loop.
applied to u-boot-atmel/master, thnaks!
Best regards
Andreas Bie?mann
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2012-06-28 12:13 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-06-28 7:58 [U-Boot] [RESEND Patch v3] Atmel : usb : add EHCI driver for Atmel SoC Bo Shen
2012-06-28 10:51 ` Marek Vasut
2012-06-28 11:26 ` Andreas Bießmann
2012-06-28 11:38 ` Marek Vasut
2012-06-28 12:13 ` Andreas Bießmann
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox