public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
* [U-Boot] [Patch v3 0/2] Add EHCI driver for Atmel SoC
@ 2012-06-28  7:24 Bo Shen
  2012-06-28  7:24 ` [U-Boot] [Patch v3 1/2] Atmel : usb : add " Bo Shen
  2012-06-28  7:24 ` [U-Boot] [Patch v3 2/2] AT91: at91sam9m10g45ek : Enable EHCI instead OHCI Bo Shen
  0 siblings, 2 replies; 8+ messages in thread
From: Bo Shen @ 2012-06-28  7:24 UTC (permalink / raw)
  To: u-boot

This patch series is to add EHCI driver for Atmel SoC, and enable EHCI
support in at91sam9m10g45ek board

Bo Shen (2):
  Atmel : usb : add EHCI driver for Atmel SoC
  AT91: at91sam9m10g45ek : Enable EHCI instead OHCI

 drivers/usb/host/Makefile          |    1 +
 drivers/usb/host/ehci-atmel.c      |   93 ++++++++++++++++++++++++++++++++++++
 include/configs/at91sam9m10g45ek.h |   20 ++------
 3 files changed, 97 insertions(+), 17 deletions(-)
 create mode 100644 drivers/usb/host/ehci-atmel.c

-- 
1.7.9.5

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [U-Boot] [Patch v3 1/2] Atmel : usb : add EHCI driver for Atmel SoC
  2012-06-28  7:24 [U-Boot] [Patch v3 0/2] Add EHCI driver for Atmel SoC Bo Shen
@ 2012-06-28  7:24 ` Bo Shen
  2012-06-28 12:16   ` Andreas Bießmann
  2012-06-28  7:24 ` [U-Boot] [Patch v3 2/2] AT91: at91sam9m10g45ek : Enable EHCI instead OHCI Bo Shen
  1 sibling, 1 reply; 8+ messages in thread
From: Bo Shen @ 2012-06-28  7:24 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

Change since v1:
  Add WATCHDOG_RESET to avoid infinite loop.
---
 drivers/usb/host/Makefile     |    1 +
 drivers/usb/host/ehci-atmel.c |   93 +++++++++++++++++++++++++++++++++++++++++
 2 files changed, 94 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..6b22f6d
--- /dev/null
+++ b/drivers/usb/host/ehci-atmel.c
@@ -0,0 +1,93 @@
+/*
+ * (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] 8+ messages in thread

* [U-Boot] [Patch v3 2/2] AT91: at91sam9m10g45ek : Enable EHCI instead OHCI
  2012-06-28  7:24 [U-Boot] [Patch v3 0/2] Add EHCI driver for Atmel SoC Bo Shen
  2012-06-28  7:24 ` [U-Boot] [Patch v3 1/2] Atmel : usb : add " Bo Shen
@ 2012-06-28  7:24 ` Bo Shen
  2012-06-28  7:40   ` Andreas Bießmann
  2012-06-28 12:14   ` Andreas Bießmann
  1 sibling, 2 replies; 8+ messages in thread
From: Bo Shen @ 2012-06-28  7:24 UTC (permalink / raw)
  To: u-boot

Enable EHCI support instead OHCI

Signed-off-by: Bo Shen <voice.shen@atmel.com>
---
 include/configs/at91sam9m10g45ek.h |   20 +++-----------------
 1 file changed, 3 insertions(+), 17 deletions(-)

diff --git a/include/configs/at91sam9m10g45ek.h b/include/configs/at91sam9m10g45ek.h
index f8b3095..1d5fc8f 100644
--- a/include/configs/at91sam9m10g45ek.h
+++ b/include/configs/at91sam9m10g45ek.h
@@ -59,17 +59,6 @@
 #define CONFIG_USART_BASE		ATMEL_BASE_DBGU
 #define	CONFIG_USART_ID			ATMEL_ID_SYS
 
-/*
- * This needs to be defined for the OHCI code to work but it is defined as
- * ATMEL_ID_UHPHS in the CPU specific header files.
- */
-#define ATMEL_ID_UHP		ATMEL_ID_UHPHS
-
-/*
- * Specify the clock enable bit in the PMC_SCER register.
- */
-#define ATMEL_PMC_UHP		AT91SAM926x_PMC_UHP
-
 /* LCD */
 #define CONFIG_LCD
 #define LCD_BPP				LCD_COLOR8
@@ -147,13 +136,10 @@
 #define CONFIG_RESET_PHY_R
 
 /* USB */
-#define CONFIG_USB_ATMEL
-#define CONFIG_USB_OHCI_NEW
+#define CONFIG_USB_EHCI
+#define CONFIG_USB_EHCI_ATMEL
+#define CONFIG_SYS_USB_EHCI_MAX_ROOT_PORTS	2
 #define CONFIG_DOS_PARTITION
-#define CONFIG_SYS_USB_OHCI_CPU_INIT
-#define CONFIG_SYS_USB_OHCI_REGS_BASE	ATMEL_BASE_HCI
-#define CONFIG_SYS_USB_OHCI_SLOT_NAME	"at91sam9g45"
-#define CONFIG_SYS_USB_OHCI_MAX_ROOT_PORTS	2
 #define CONFIG_USB_STORAGE
 
 #define CONFIG_SYS_LOAD_ADDR		0x22000000	/* load address */
-- 
1.7.9.5

^ permalink raw reply related	[flat|nested] 8+ messages in thread

* [U-Boot] [Patch v3 2/2] AT91: at91sam9m10g45ek : Enable EHCI instead OHCI
  2012-06-28  7:24 ` [U-Boot] [Patch v3 2/2] AT91: at91sam9m10g45ek : Enable EHCI instead OHCI Bo Shen
@ 2012-06-28  7:40   ` Andreas Bießmann
  2012-06-28  7:57     ` Bo Shen
  2012-06-28  8:01     ` Bo Shen
  2012-06-28 12:14   ` Andreas Bießmann
  1 sibling, 2 replies; 8+ messages in thread
From: Andreas Bießmann @ 2012-06-28  7:40 UTC (permalink / raw)
  To: u-boot

Dear Bo Shen,

On 28.06.2012 09:24, Bo Shen wrote:
> Enable EHCI support instead OHCI
> 
> Signed-off-by: Bo Shen <voice.shen@atmel.com>

I've already acked the v2. Will pick this one ASAP and push to u-boot-atmel.

Best regards

Andreas Bie?mann

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [U-Boot] [Patch v3 2/2] AT91: at91sam9m10g45ek : Enable EHCI instead OHCI
  2012-06-28  7:40   ` Andreas Bießmann
@ 2012-06-28  7:57     ` Bo Shen
  2012-06-28  8:01     ` Bo Shen
  1 sibling, 0 replies; 8+ messages in thread
From: Bo Shen @ 2012-06-28  7:57 UTC (permalink / raw)
  To: u-boot

Hi Andreas,

On 6/28/2012 15:40, Andreas Bie?mann wrote:
> Dear Bo Shen,
>
> On 28.06.2012 09:24, Bo Shen wrote:
>> Enable EHCI support instead OHCI
>>
>> Signed-off-by: Bo Shen <voice.shen@atmel.com>
>
> I've already acked the v2. Will pick this one ASAP and push to u-boot-atmel.

OK!
Thanks.

>
> Best regards
>
> Andreas Bie?mann
>

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [U-Boot] [Patch v3 2/2] AT91: at91sam9m10g45ek : Enable EHCI instead OHCI
  2012-06-28  7:40   ` Andreas Bießmann
  2012-06-28  7:57     ` Bo Shen
@ 2012-06-28  8:01     ` Bo Shen
  1 sibling, 0 replies; 8+ messages in thread
From: Bo Shen @ 2012-06-28  8:01 UTC (permalink / raw)
  To: u-boot

On 6/28/2012 15:40, Andreas Bie?mann wrote:
> Dear Bo Shen,
>
> On 28.06.2012 09:24, Bo Shen wrote:
>> Enable EHCI support instead OHCI
>>
>> Signed-off-by: Bo Shen <voice.shen@atmel.com>
>
> I've already acked the v2. Will pick this one ASAP and push to u-boot-atmel.

OK.
Thanks

I resend the EHCI driver separately to Marex.

>
> Best regards
>
> Andreas Bie?mann
>

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [U-Boot] [Patch v3 2/2] AT91: at91sam9m10g45ek : Enable EHCI instead OHCI
  2012-06-28  7:24 ` [U-Boot] [Patch v3 2/2] AT91: at91sam9m10g45ek : Enable EHCI instead OHCI Bo Shen
  2012-06-28  7:40   ` Andreas Bießmann
@ 2012-06-28 12:14   ` Andreas Bießmann
  1 sibling, 0 replies; 8+ messages in thread
From: Andreas Bießmann @ 2012-06-28 12:14 UTC (permalink / raw)
  To: u-boot

Dear Bo Shen,

On 28.06.2012 09:24, Bo Shen wrote:
> Enable EHCI support instead OHCI
> 
> Signed-off-by: Bo Shen <voice.shen@atmel.com>
> ---
>  include/configs/at91sam9m10g45ek.h |   20 +++-----------------
>  1 file changed, 3 insertions(+), 17 deletions(-)

applied to u-boot-atmel/master, thanks!

Best regards

Andreas Bie?mann

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [U-Boot] [Patch v3 1/2] Atmel : usb : add EHCI driver for Atmel SoC
  2012-06-28  7:24 ` [U-Boot] [Patch v3 1/2] Atmel : usb : add " Bo Shen
@ 2012-06-28 12:16   ` Andreas Bießmann
  0 siblings, 0 replies; 8+ messages in thread
From: Andreas Bießmann @ 2012-06-28 12:16 UTC (permalink / raw)
  To: u-boot

Dear Bo Shen,

On 28.06.2012 09:24, 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
> 
> Change since v1:
>   Add WATCHDOG_RESET to avoid infinite loop.

applied to u-boot-atmel/master, thanks!

Best regards

Andreas Bie?mann

^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2012-06-28 12:16 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-06-28  7:24 [U-Boot] [Patch v3 0/2] Add EHCI driver for Atmel SoC Bo Shen
2012-06-28  7:24 ` [U-Boot] [Patch v3 1/2] Atmel : usb : add " Bo Shen
2012-06-28 12:16   ` Andreas Bießmann
2012-06-28  7:24 ` [U-Boot] [Patch v3 2/2] AT91: at91sam9m10g45ek : Enable EHCI instead OHCI Bo Shen
2012-06-28  7:40   ` Andreas Bießmann
2012-06-28  7:57     ` Bo Shen
2012-06-28  8:01     ` Bo Shen
2012-06-28 12:14   ` 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