[U-Boot] [PATCH v3 2/7] ARM: OMAP5: USB: Add OMAP5 common USB EHCI information

2013-07-17 Thread Dan Murphy
* Enable the OMAP5 EHCI host clocks
* Add OMAP5 EHCI register definitions
* Add OMAP5 ES2 host revision

Signed-off-by: Dan Murphy 
---
v3 - Updated per comments - http://patchwork.ozlabs.org/patch/258230/

 arch/arm/cpu/armv7/omap5/hw_data.c  |   17 
 arch/arm/include/asm/arch-omap5/clock.h |6 +
 arch/arm/include/asm/arch-omap5/ehci.h  |   43 +++
 arch/arm/include/asm/ehci-omap.h|1 +
 drivers/usb/host/ehci-omap.c|2 +-
 5 files changed, 68 insertions(+), 1 deletion(-)
 create mode 100644 arch/arm/include/asm/arch-omap5/ehci.h

diff --git a/arch/arm/cpu/armv7/omap5/hw_data.c 
b/arch/arm/cpu/armv7/omap5/hw_data.c
index 07b1108..b1be748 100644
--- a/arch/arm/cpu/armv7/omap5/hw_data.c
+++ b/arch/arm/cpu/armv7/omap5/hw_data.c
@@ -414,6 +414,10 @@ void enable_basic_clocks(void)
(*prcm)->cm_l4per_gpio6_clkctrl,
(*prcm)->cm_l4per_gpio7_clkctrl,
(*prcm)->cm_l4per_gpio8_clkctrl,
+#ifdef CONFIG_USB_EHCI_OMAP
+   (*prcm)->cm_clksel_usb_60mhz,
+   (*prcm)->cm_l3init_hsusbtll_clkctrl,
+#endif
0
};
 
@@ -425,6 +429,9 @@ void enable_basic_clocks(void)
(*prcm)->cm_wkup_wdtimer2_clkctrl,
(*prcm)->cm_l4per_uart3_clkctrl,
(*prcm)->cm_l4per_i2c1_clkctrl,
+#ifdef CONFIG_USB_EHCI_OMAP
+   (*prcm)->cm_l3init_hsusbhost_clkctrl,
+#endif
0
};
 
@@ -448,6 +455,16 @@ void enable_basic_clocks(void)
setbits_le32((*prcm)->cm_wkup_gptimer1_clkctrl,
GPTIMER1_CLKCTRL_CLKSEL_MASK);
 
+#ifdef CONFIG_USB_EHCI
+   /* Enable port 2 and 3 clocks*/
+   setbits_le32((*prcm)->cm_l3init_hsusbhost_clkctrl,
+   USB_HOST_HS_CLKCTRL_MASK);
+
+   /* Enable all 3 usb host ports tll clocks*/
+   setbits_le32((*prcm)->cm_l3init_hsusbtll_clkctrl,
+   USB_TLL_HS_CLKCTRL_MASK);
+#endif
+
do_enable_clocks(clk_domains_essential,
 clk_modules_hw_auto_essential,
 clk_modules_explicit_en_essential,
diff --git a/arch/arm/include/asm/arch-omap5/clock.h 
b/arch/arm/include/asm/arch-omap5/clock.h
index 4d2765d..3a58337 100644
--- a/arch/arm/include/asm/arch-omap5/clock.h
+++ b/arch/arm/include/asm/arch-omap5/clock.h
@@ -165,6 +165,12 @@
 /* CM_L3INIT_USBPHY_CLKCTRL */
 #define USBPHY_CLKCTRL_OPTFCLKEN_PHY_48M_MASK  8
 
+/* CM_L3INIT_USB_HOST_HS_CLKCTRL */
+#define USB_HOST_HS_CLKCTRL_MASK   0x56C0
+
+/* CM_L3INIT_USB_TLL_HS_CLKCTRL */
+#define USB_TLL_HS_CLKCTRL_MASK0x700
+
 /* CM_MPU_MPU_CLKCTRL */
 #define MPU_CLKCTRL_CLKSEL_EMIF_DIV_MODE_SHIFT 24
 #define MPU_CLKCTRL_CLKSEL_EMIF_DIV_MODE_MASK  (3 << 24)
diff --git a/arch/arm/include/asm/arch-omap5/ehci.h 
b/arch/arm/include/asm/arch-omap5/ehci.h
new file mode 100644
index 000..3921e4a
--- /dev/null
+++ b/arch/arm/include/asm/arch-omap5/ehci.h
@@ -0,0 +1,43 @@
+/*
+ * Copyright (C) 2013 Texas Instruments Incorporated - http://www.ti.com*
+ * Author: Govindraj R 
+ *
+ * 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., 59 Temple Place, Suite 330, Boston,
+ * MA 02111-1307 USA
+ */
+
+#ifndef _EHCI_H
+#define _EHCI_H
+
+#define OMAP_EHCI_BASE (OMAP54XX_L4_CORE_BASE + 
0x64C00)
+#define OMAP_UHH_BASE  (OMAP54XX_L4_CORE_BASE + 
0x64000)
+#define OMAP_USBTLL_BASE   (OMAP54XX_L4_CORE_BASE + 
0x62000)
+
+/* TLL Register Set */
+#define OMAP_USBTLL_SYSCONFIG_SIDLEMODE(1 << 3)
+#define OMAP_USBTLL_SYSCONFIG_ENAWAKEUP(1 << 2)
+#define OMAP_USBTLL_SYSCONFIG_SOFTRESET(1 << 1)
+#define OMAP_USBTLL_SYSCONFIG_CACTIVITY(1 << 8)
+#define OMAP_USBTLL_SYSSTATUS_RESETDONE1
+
+#define OMAP_UHH_SYSCONFIG_SOFTRESET   1
+#define OMAP_UHH_SYSSTATUS_EHCI_RESETDONE  (1 << 2)
+#define OMAP_UHH_SYSCONFIG_NOIDLE  (1 << 2)
+#define OMAP_UHH_SYSCONFIG_NOSTDBY (1 << 4)
+
+#define OMAP_UHH_SYSCONFIG_VAL (OMAP_UHH_SYSCONFIG_NOIDLE | \
+   OMAP_UHH_SYSCONFIG_NOSTDBY)
+
+#endif /* _EHCI_H */
diff --git a/arch/arm/include/asm/ehci-omap.h b/arch/arm/include/asm/ehci-omap.h
index 77e8170..0b09e9d 10064

Re: [U-Boot] [PATCH v3 2/7] ARM: OMAP5: USB: Add OMAP5 common USB EHCI information

2013-07-18 Thread Roger Quadros
Dan,

On 07/17/2013 11:16 PM, Dan Murphy wrote:
> * Enable the OMAP5 EHCI host clocks
> * Add OMAP5 EHCI register definitions
> * Add OMAP5 ES2 host revision
> 
> Signed-off-by: Dan Murphy 
> ---
> v3 - Updated per comments - http://patchwork.ozlabs.org/patch/258230/
> 
>  arch/arm/cpu/armv7/omap5/hw_data.c  |   17 
>  arch/arm/include/asm/arch-omap5/clock.h |6 +
>  arch/arm/include/asm/arch-omap5/ehci.h  |   43 
> +++
>  arch/arm/include/asm/ehci-omap.h|1 +
>  drivers/usb/host/ehci-omap.c|2 +-
>  5 files changed, 68 insertions(+), 1 deletion(-)
>  create mode 100644 arch/arm/include/asm/arch-omap5/ehci.h
> 
> diff --git a/arch/arm/cpu/armv7/omap5/hw_data.c 
> b/arch/arm/cpu/armv7/omap5/hw_data.c
> index 07b1108..b1be748 100644
> --- a/arch/arm/cpu/armv7/omap5/hw_data.c
> +++ b/arch/arm/cpu/armv7/omap5/hw_data.c
> @@ -414,6 +414,10 @@ void enable_basic_clocks(void)
>   (*prcm)->cm_l4per_gpio6_clkctrl,
>   (*prcm)->cm_l4per_gpio7_clkctrl,
>   (*prcm)->cm_l4per_gpio8_clkctrl,
> +#ifdef CONFIG_USB_EHCI_OMAP
> + (*prcm)->cm_clksel_usb_60mhz,
> + (*prcm)->cm_l3init_hsusbtll_clkctrl,
> +#endif
>   0
>   };
>  
> @@ -425,6 +429,9 @@ void enable_basic_clocks(void)
>   (*prcm)->cm_wkup_wdtimer2_clkctrl,
>   (*prcm)->cm_l4per_uart3_clkctrl,
>   (*prcm)->cm_l4per_i2c1_clkctrl,
> +#ifdef CONFIG_USB_EHCI_OMAP
> + (*prcm)->cm_l3init_hsusbhost_clkctrl,
> +#endif
>   0
>   };
>  
> @@ -448,6 +455,16 @@ void enable_basic_clocks(void)
>   setbits_le32((*prcm)->cm_wkup_gptimer1_clkctrl,
>   GPTIMER1_CLKCTRL_CLKSEL_MASK);
>  
> +#ifdef CONFIG_USB_EHCI
> + /* Enable port 2 and 3 clocks*/
> + setbits_le32((*prcm)->cm_l3init_hsusbhost_clkctrl,
> + USB_HOST_HS_CLKCTRL_MASK);

For consistency, maybe you should enable all 3 port clocks
since you are enabling all 3 TLL clocks below?
> +
> + /* Enable all 3 usb host ports tll clocks*/
> + setbits_le32((*prcm)->cm_l3init_hsusbtll_clkctrl,
> + USB_TLL_HS_CLKCTRL_MASK);
> +#endif
> +
>   do_enable_clocks(clk_domains_essential,
>clk_modules_hw_auto_essential,
>clk_modules_explicit_en_essential,
> diff --git a/arch/arm/include/asm/arch-omap5/clock.h 
> b/arch/arm/include/asm/arch-omap5/clock.h
> index 4d2765d..3a58337 100644
> --- a/arch/arm/include/asm/arch-omap5/clock.h
> +++ b/arch/arm/include/asm/arch-omap5/clock.h
> @@ -165,6 +165,12 @@
>  /* CM_L3INIT_USBPHY_CLKCTRL */
>  #define USBPHY_CLKCTRL_OPTFCLKEN_PHY_48M_MASK8
>  
> +/* CM_L3INIT_USB_HOST_HS_CLKCTRL */
> +#define USB_HOST_HS_CLKCTRL_MASK 0x56C0
> +
> +/* CM_L3INIT_USB_TLL_HS_CLKCTRL */
> +#define USB_TLL_HS_CLKCTRL_MASK  0x700
> +
>  /* CM_MPU_MPU_CLKCTRL */
>  #define MPU_CLKCTRL_CLKSEL_EMIF_DIV_MODE_SHIFT   24
>  #define MPU_CLKCTRL_CLKSEL_EMIF_DIV_MODE_MASK(3 << 24)
> diff --git a/arch/arm/include/asm/arch-omap5/ehci.h 
> b/arch/arm/include/asm/arch-omap5/ehci.h
> new file mode 100644
> index 000..3921e4a
> --- /dev/null
> +++ b/arch/arm/include/asm/arch-omap5/ehci.h
> @@ -0,0 +1,43 @@
> +/*
> + * Copyright (C) 2013 Texas Instruments Incorporated - http://www.ti.com*
> + * Author: Govindraj R 
> + *
> + * 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., 59 Temple Place, Suite 330, Boston,
> + * MA 02111-1307 USA
> + */
> +
> +#ifndef _EHCI_H
> +#define _EHCI_H
> +
> +#define OMAP_EHCI_BASE   (OMAP54XX_L4_CORE_BASE 
> + 0x64C00)
> +#define OMAP_UHH_BASE(OMAP54XX_L4_CORE_BASE 
> + 0x64000)
> +#define OMAP_USBTLL_BASE (OMAP54XX_L4_CORE_BASE + 
> 0x62000)
> +
> +/* TLL Register Set */
> +#define OMAP_USBTLL_SYSCONFIG_SIDLEMODE  (1 << 3)
> +#define OMAP_USBTLL_SYSCONFIG_ENAWAKEUP  (1 << 2)
> +#define OMAP_USBTLL_SYSCONFIG_SOFTRESET  (1 << 1)
> +#define OMAP_USBTLL_SYSCONFIG_CACTIVITY  (1 << 8)
> +#define OMAP_USBTLL_SYSSTATUS_RESETDONE  1
> +
> +#define OMAP_UHH_SYSCONFIG_SOFTRESET 1
> +#define OMAP_UHH_SYSSTATUS_EHCI_RESETDONE(1 << 2)
> +#define OMA

Re: [U-Boot] [PATCH v3 2/7] ARM: OMAP5: USB: Add OMAP5 common USB EHCI information

2013-07-18 Thread Dan Murphy
Dear Roger

On 07/18/2013 02:10 AM, Roger Quadros wrote:
> Dan,
>
> On 07/17/2013 11:16 PM, Dan Murphy wrote:
>> * Enable the OMAP5 EHCI host clocks
>> * Add OMAP5 EHCI register definitions
>> * Add OMAP5 ES2 host revision
>>
>> Signed-off-by: Dan Murphy 
>> ---
>> v3 - Updated per comments - http://patchwork.ozlabs.org/patch/258230/
>>
>>  arch/arm/cpu/armv7/omap5/hw_data.c  |   17 
>>  arch/arm/include/asm/arch-omap5/clock.h |6 +
>>  arch/arm/include/asm/arch-omap5/ehci.h  |   43 
>> +++
>>  arch/arm/include/asm/ehci-omap.h|1 +
>>  drivers/usb/host/ehci-omap.c|2 +-
>>  5 files changed, 68 insertions(+), 1 deletion(-)
>>  create mode 100644 arch/arm/include/asm/arch-omap5/ehci.h
>>
>> diff --git a/arch/arm/cpu/armv7/omap5/hw_data.c 
>> b/arch/arm/cpu/armv7/omap5/hw_data.c
>> index 07b1108..b1be748 100644
>> --- a/arch/arm/cpu/armv7/omap5/hw_data.c
>> +++ b/arch/arm/cpu/armv7/omap5/hw_data.c
>> @@ -414,6 +414,10 @@ void enable_basic_clocks(void)
>>  (*prcm)->cm_l4per_gpio6_clkctrl,
>>  (*prcm)->cm_l4per_gpio7_clkctrl,
>>  (*prcm)->cm_l4per_gpio8_clkctrl,
>> +#ifdef CONFIG_USB_EHCI_OMAP
>> +(*prcm)->cm_clksel_usb_60mhz,
>> +(*prcm)->cm_l3init_hsusbtll_clkctrl,
>> +#endif
>>  0
>>  };
>>  
>> @@ -425,6 +429,9 @@ void enable_basic_clocks(void)
>>  (*prcm)->cm_wkup_wdtimer2_clkctrl,
>>  (*prcm)->cm_l4per_uart3_clkctrl,
>>  (*prcm)->cm_l4per_i2c1_clkctrl,
>> +#ifdef CONFIG_USB_EHCI_OMAP
>> +(*prcm)->cm_l3init_hsusbhost_clkctrl,
>> +#endif
>>  0
>>  };
>>  
>> @@ -448,6 +455,16 @@ void enable_basic_clocks(void)
>>  setbits_le32((*prcm)->cm_wkup_gptimer1_clkctrl,
>>  GPTIMER1_CLKCTRL_CLKSEL_MASK);
>>  
>> +#ifdef CONFIG_USB_EHCI
>> +/* Enable port 2 and 3 clocks*/
>> +setbits_le32((*prcm)->cm_l3init_hsusbhost_clkctrl,
>> +USB_HOST_HS_CLKCTRL_MASK);
> For consistency, maybe you should enable all 3 port clocks
> since you are enabling all 3 TLL clocks below?
So I thought about this we should enable all 3 clocks since it is a common file 
and disable the unused clocks in the board file.

Or we should enable the specific port clocks during ehci_hcd_init in the board 
file only since it is a board implementation detail.

Thoughts?
>> +
>> +/* Enable all 3 usb host ports tll clocks*/
>> +setbits_le32((*prcm)->cm_l3init_hsusbtll_clkctrl,
>> +USB_TLL_HS_CLKCTRL_MASK);
>> +#endif
>> +
>>  do_enable_clocks(clk_domains_essential,
>>   clk_modules_hw_auto_essential,
>>   clk_modules_explicit_en_essential,
>> diff --git a/arch/arm/include/asm/arch-omap5/clock.h 
>> b/arch/arm/include/asm/arch-omap5/clock.h
>> index 4d2765d..3a58337 100644
>> --- a/arch/arm/include/asm/arch-omap5/clock.h
>> +++ b/arch/arm/include/asm/arch-omap5/clock.h
>> @@ -165,6 +165,12 @@
>>  /* CM_L3INIT_USBPHY_CLKCTRL */
>>  #define USBPHY_CLKCTRL_OPTFCLKEN_PHY_48M_MASK   8
>>  
>> +/* CM_L3INIT_USB_HOST_HS_CLKCTRL */
>> +#define USB_HOST_HS_CLKCTRL_MASK0x56C0
>> +
>> +/* CM_L3INIT_USB_TLL_HS_CLKCTRL */
>> +#define USB_TLL_HS_CLKCTRL_MASK 0x700
>> +
>>  /* CM_MPU_MPU_CLKCTRL */
>>  #define MPU_CLKCTRL_CLKSEL_EMIF_DIV_MODE_SHIFT  24
>>  #define MPU_CLKCTRL_CLKSEL_EMIF_DIV_MODE_MASK   (3 << 24)
>> diff --git a/arch/arm/include/asm/arch-omap5/ehci.h 
>> b/arch/arm/include/asm/arch-omap5/ehci.h
>> new file mode 100644
>> index 000..3921e4a
>> --- /dev/null
>> +++ b/arch/arm/include/asm/arch-omap5/ehci.h
>> @@ -0,0 +1,43 @@
>> +/*
>> + * Copyright (C) 2013 Texas Instruments Incorporated - http://www.ti.com*
>> + * Author: Govindraj R 
>> + *
>> + * 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., 59 Temple Place, Suite 330, Boston,
>> + * MA 02111-1307 USA
>> + */
>> +
>> +#ifndef _EHCI_H
>> +#define _EHCI_H
>> +
>> +#define OMAP_EHCI_BASE  (OMAP54XX_L4_CORE_BASE 
>> + 0x64C00)
>> +#define OMAP_UHH_BASE   (OMAP54XX_L4_CORE_BASE 
>> + 0x64000)
>> +#define OMAP_USBTLL_BASE(OMAP54XX_L4_CORE_BASE + 
>> 0x62000)
>> +
>> +/* TLL Register Set */
>> +#define OMAP_USBTL

Re: [U-Boot] [PATCH v3 2/7] ARM: OMAP5: USB: Add OMAP5 common USB EHCI information

2013-07-19 Thread Roger Quadros
On 07/18/2013 08:48 PM, Dan Murphy wrote:
> Dear Roger
> 
> On 07/18/2013 02:10 AM, Roger Quadros wrote:
>> Dan,
>>
>> On 07/17/2013 11:16 PM, Dan Murphy wrote:
>>> * Enable the OMAP5 EHCI host clocks
>>> * Add OMAP5 EHCI register definitions
>>> * Add OMAP5 ES2 host revision
>>>
>>> Signed-off-by: Dan Murphy 
>>> ---
>>> v3 - Updated per comments - http://patchwork.ozlabs.org/patch/258230/
>>>
>>>  arch/arm/cpu/armv7/omap5/hw_data.c  |   17 
>>>  arch/arm/include/asm/arch-omap5/clock.h |6 +
>>>  arch/arm/include/asm/arch-omap5/ehci.h  |   43 
>>> +++
>>>  arch/arm/include/asm/ehci-omap.h|1 +
>>>  drivers/usb/host/ehci-omap.c|2 +-
>>>  5 files changed, 68 insertions(+), 1 deletion(-)
>>>  create mode 100644 arch/arm/include/asm/arch-omap5/ehci.h
>>>
>>> diff --git a/arch/arm/cpu/armv7/omap5/hw_data.c 
>>> b/arch/arm/cpu/armv7/omap5/hw_data.c
>>> index 07b1108..b1be748 100644
>>> --- a/arch/arm/cpu/armv7/omap5/hw_data.c
>>> +++ b/arch/arm/cpu/armv7/omap5/hw_data.c
>>> @@ -414,6 +414,10 @@ void enable_basic_clocks(void)
>>> (*prcm)->cm_l4per_gpio6_clkctrl,
>>> (*prcm)->cm_l4per_gpio7_clkctrl,
>>> (*prcm)->cm_l4per_gpio8_clkctrl,
>>> +#ifdef CONFIG_USB_EHCI_OMAP
>>> +   (*prcm)->cm_clksel_usb_60mhz,
>>> +   (*prcm)->cm_l3init_hsusbtll_clkctrl,
>>> +#endif
>>> 0
>>> };
>>>  
>>> @@ -425,6 +429,9 @@ void enable_basic_clocks(void)
>>> (*prcm)->cm_wkup_wdtimer2_clkctrl,
>>> (*prcm)->cm_l4per_uart3_clkctrl,
>>> (*prcm)->cm_l4per_i2c1_clkctrl,
>>> +#ifdef CONFIG_USB_EHCI_OMAP
>>> +   (*prcm)->cm_l3init_hsusbhost_clkctrl,
>>> +#endif
>>> 0
>>> };
>>>  
>>> @@ -448,6 +455,16 @@ void enable_basic_clocks(void)
>>> setbits_le32((*prcm)->cm_wkup_gptimer1_clkctrl,
>>> GPTIMER1_CLKCTRL_CLKSEL_MASK);
>>>  
>>> +#ifdef CONFIG_USB_EHCI
>>> +   /* Enable port 2 and 3 clocks*/
>>> +   setbits_le32((*prcm)->cm_l3init_hsusbhost_clkctrl,
>>> +   USB_HOST_HS_CLKCTRL_MASK);
>> For consistency, maybe you should enable all 3 port clocks
>> since you are enabling all 3 TLL clocks below?
> So I thought about this we should enable all 3 clocks since it is a common 
> file and disable the unused clocks in the board file.
> 
> Or we should enable the specific port clocks during ehci_hcd_init in the 
> board file only since it is a board implementation detail.
> 
> Thoughts?

IMHO enabling the clocks based on board is best.

cheers,
-roger

___
U-Boot mailing list
U-Boot@lists.denx.de
http://lists.denx.de/mailman/listinfo/u-boot


Re: [U-Boot] [PATCH v3 2/7] ARM: OMAP5: USB: Add OMAP5 common USB EHCI information

2013-07-23 Thread Tom Rini
On Fri, Jul 19, 2013 at 12:30:54PM +0300, Roger Quadros wrote:
> On 07/18/2013 08:48 PM, Dan Murphy wrote:
> > Dear Roger
> > 
> > On 07/18/2013 02:10 AM, Roger Quadros wrote:
> >> Dan,
> >>
> >> On 07/17/2013 11:16 PM, Dan Murphy wrote:
> >>> * Enable the OMAP5 EHCI host clocks
> >>> * Add OMAP5 EHCI register definitions
> >>> * Add OMAP5 ES2 host revision
> >>>
> >>> Signed-off-by: Dan Murphy 
> >>> ---
> >>> v3 - Updated per comments - http://patchwork.ozlabs.org/patch/258230/
> >>>
> >>>  arch/arm/cpu/armv7/omap5/hw_data.c  |   17 
> >>>  arch/arm/include/asm/arch-omap5/clock.h |6 +
> >>>  arch/arm/include/asm/arch-omap5/ehci.h  |   43 
> >>> +++
> >>>  arch/arm/include/asm/ehci-omap.h|1 +
> >>>  drivers/usb/host/ehci-omap.c|2 +-
> >>>  5 files changed, 68 insertions(+), 1 deletion(-)
> >>>  create mode 100644 arch/arm/include/asm/arch-omap5/ehci.h
> >>>
> >>> diff --git a/arch/arm/cpu/armv7/omap5/hw_data.c 
> >>> b/arch/arm/cpu/armv7/omap5/hw_data.c
> >>> index 07b1108..b1be748 100644
> >>> --- a/arch/arm/cpu/armv7/omap5/hw_data.c
> >>> +++ b/arch/arm/cpu/armv7/omap5/hw_data.c
> >>> @@ -414,6 +414,10 @@ void enable_basic_clocks(void)
> >>>   (*prcm)->cm_l4per_gpio6_clkctrl,
> >>>   (*prcm)->cm_l4per_gpio7_clkctrl,
> >>>   (*prcm)->cm_l4per_gpio8_clkctrl,
> >>> +#ifdef CONFIG_USB_EHCI_OMAP
> >>> + (*prcm)->cm_clksel_usb_60mhz,
> >>> + (*prcm)->cm_l3init_hsusbtll_clkctrl,
> >>> +#endif
> >>>   0
> >>>   };
> >>>  
> >>> @@ -425,6 +429,9 @@ void enable_basic_clocks(void)
> >>>   (*prcm)->cm_wkup_wdtimer2_clkctrl,
> >>>   (*prcm)->cm_l4per_uart3_clkctrl,
> >>>   (*prcm)->cm_l4per_i2c1_clkctrl,
> >>> +#ifdef CONFIG_USB_EHCI_OMAP
> >>> + (*prcm)->cm_l3init_hsusbhost_clkctrl,
> >>> +#endif
> >>>   0
> >>>   };
> >>>  
> >>> @@ -448,6 +455,16 @@ void enable_basic_clocks(void)
> >>>   setbits_le32((*prcm)->cm_wkup_gptimer1_clkctrl,
> >>>   GPTIMER1_CLKCTRL_CLKSEL_MASK);
> >>>  
> >>> +#ifdef CONFIG_USB_EHCI
> >>> + /* Enable port 2 and 3 clocks*/
> >>> + setbits_le32((*prcm)->cm_l3init_hsusbhost_clkctrl,
> >>> + USB_HOST_HS_CLKCTRL_MASK);
> >> For consistency, maybe you should enable all 3 port clocks
> >> since you are enabling all 3 TLL clocks below?
> > So I thought about this we should enable all 3 clocks since it is a common 
> > file and disable the unused clocks in the board file.
> > 
> > Or we should enable the specific port clocks during ehci_hcd_init in the 
> > board file only since it is a board implementation detail.
> > 
> > Thoughts?
> 
> IMHO enabling the clocks based on board is best.

Agree.  We only enable what we need, not enable and then disable as
someone will forget to disable (or not know they need to).  Even if this
means adding a define or 3 for which ports we do have.

-- 
Tom


signature.asc
Description: Digital signature
___
U-Boot mailing list
U-Boot@lists.denx.de
http://lists.denx.de/mailman/listinfo/u-boot