summaryrefslogtreecommitdiff
path: root/arch/arm/mach-omap2
diff options
context:
space:
mode:
authorMaulik Mankad <x0082077@ti.com>2009-10-29 11:34:41 +0530
committerSantosh Shilimkar <santosh.shilimkar@ti.com>2009-10-31 19:29:36 +0530
commit39a64fb46bc27f1f91ae3b0feb3bc21dbd35c642 (patch)
tree2eea4c3241ef901c24d7ab2c18f5dbaadf8f29c7 /arch/arm/mach-omap2
parent28eb9a494239cb9527b0ada83be29c8ea2621ebb (diff)
OMAP4: Adds MUX settings for EHCI PHY port 1
Signed-off-by: Maulik Mankad <x0082077@ti.com>
Diffstat (limited to 'arch/arm/mach-omap2')
-rw-r--r--arch/arm/mach-omap2/mux.c27
-rw-r--r--arch/arm/mach-omap2/usb-ehci.c73
2 files changed, 71 insertions, 29 deletions
diff --git a/arch/arm/mach-omap2/mux.c b/arch/arm/mach-omap2/mux.c
index ce8d0495f97e..4049693704df 100644
--- a/arch/arm/mach-omap2/mux.c
+++ b/arch/arm/mach-omap2/mux.c
@@ -686,7 +686,34 @@ MUX_CFG_34XX("PAD1_4430_SYS_NIRQ1", 0x019E, OMAP34XX_MUX_MODE0 | OMAP2_PULL_ENA
| OMAP2_PULL_UP | OMAP3_INPUT_EN)
MUX_CFG_34XX("PAD0_4430_SYS_NIRQ2", 0x01A0, OMAP34XX_MUX_MODE0 | OMAP2_PULL_ENA
| OMAP2_PULL_UP | OMAP3_INPUT_EN)
+
+/* PHY - HSUSB: 12-pin ULPI PHY: Port 1*/
+MUX_CFG_34XX("AE_4430_USB1HS_PHY_CLK", 0x0C2,
+ OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_OUTPUT)
+MUX_CFG_34XX("AG_4430_USB1HS_PHY_STP", 0x0C4,
+ OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_OUTPUT)
+MUX_CFG_34XX("AF_4430_USB1HS_PHY_DIR", 0x0C6,
+ OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_INPUT_PULLDOWN)
+MUX_CFG_34XX("AE_4430_USB1HS_PHY_NXT", 0x0C8,
+ OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_INPUT_PULLDOWN)
+MUX_CFG_34XX("AF_4430_USB1HS_PHY_D0", 0x0CA,
+ OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_INPUT_PULLDOWN)
+MUX_CFG_34XX("AG_4430_USB1HS_PHY_D1", 0x0CC,
+ OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_INPUT_PULLDOWN)
+MUX_CFG_34XX("AE_4430_USB1HS_PHY_D2", 0x0CE,
+ OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_INPUT_PULLDOWN)
+MUX_CFG_34XX("AF_4430_USB1HS_PHY_D3", 0x0D0,
+ OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_INPUT_PULLDOWN)
+MUX_CFG_34XX("AH_4430_USB1HS_PHY_D4", 0x0D2,
+ OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_INPUT_PULLDOWN)
+MUX_CFG_34XX("AE_4430_USB1HS_PHY_D5", 0x0D4,
+ OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_INPUT_PULLDOWN)
+MUX_CFG_34XX("AF_4430_USB1HS_PHY_D6", 0x0D6,
+ OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_INPUT_PULLDOWN)
+MUX_CFG_34XX("AG_4430_USB1HS_PHY_D7", 0x0D8,
+ OMAP34XX_MUX_MODE4 | OMAP34XX_PIN_INPUT_PULLDOWN)
};
+
#define OMAP44XX_PINS_SZ ARRAY_SIZE(omap44xx_pins)
#else
diff --git a/arch/arm/mach-omap2/usb-ehci.c b/arch/arm/mach-omap2/usb-ehci.c
index 438fa49a18f4..800d8c03f06c 100644
--- a/arch/arm/mach-omap2/usb-ehci.c
+++ b/arch/arm/mach-omap2/usb-ehci.c
@@ -112,34 +112,50 @@ static void setup_ehci_io_mux(enum ehci_hcd_omap_mode phy_mode)
* ISP1504 connected to Port1 and Port2
* Do Func Mux setting for 12-pin ULPI PHY mode
*/
- /* Port1 */
- omap_cfg_reg(Y9_3430_USB1HS_PHY_STP);
- omap_cfg_reg(Y8_3430_USB1HS_PHY_CLK);
- omap_cfg_reg(AA14_3430_USB1HS_PHY_DIR);
- omap_cfg_reg(AA11_3430_USB1HS_PHY_NXT);
- omap_cfg_reg(W13_3430_USB1HS_PHY_DATA0);
- omap_cfg_reg(W12_3430_USB1HS_PHY_DATA1);
- omap_cfg_reg(W11_3430_USB1HS_PHY_DATA2);
- omap_cfg_reg(Y11_3430_USB1HS_PHY_DATA3);
- omap_cfg_reg(W9_3430_USB1HS_PHY_DATA4);
- omap_cfg_reg(Y12_3430_USB1HS_PHY_DATA5);
- omap_cfg_reg(W8_3430_USB1HS_PHY_DATA6);
- omap_cfg_reg(Y13_3430_USB1HS_PHY_DATA7);
-
- /* Port2 */
- omap_cfg_reg(AA10_3430_USB2HS_PHY_STP);
- omap_cfg_reg(AA8_3430_USB2HS_PHY_CLK);
- omap_cfg_reg(AA9_3430_USB2HS_PHY_DIR);
- omap_cfg_reg(AB11_3430_USB2HS_PHY_NXT);
- omap_cfg_reg(AB10_3430_USB2HS_PHY_DATA0);
- omap_cfg_reg(AB9_3430_USB2HS_PHY_DATA1);
- omap_cfg_reg(W3_3430_USB2HS_PHY_DATA2);
- omap_cfg_reg(T4_3430_USB2HS_PHY_DATA3);
- omap_cfg_reg(T3_3430_USB2HS_PHY_DATA4);
- omap_cfg_reg(R3_3430_USB2HS_PHY_DATA5);
- omap_cfg_reg(R4_3430_USB2HS_PHY_DATA6);
- omap_cfg_reg(T2_3430_USB2HS_PHY_DATA7);
+ if (cpu_is_omap34xx()) {
+ /* Port1 */
+ omap_cfg_reg(Y9_3430_USB1HS_PHY_STP);
+ omap_cfg_reg(Y8_3430_USB1HS_PHY_CLK);
+ omap_cfg_reg(AA14_3430_USB1HS_PHY_DIR);
+ omap_cfg_reg(AA11_3430_USB1HS_PHY_NXT);
+ omap_cfg_reg(W13_3430_USB1HS_PHY_DATA0);
+ omap_cfg_reg(W12_3430_USB1HS_PHY_DATA1);
+ omap_cfg_reg(W11_3430_USB1HS_PHY_DATA2);
+ omap_cfg_reg(Y11_3430_USB1HS_PHY_DATA3);
+ omap_cfg_reg(W9_3430_USB1HS_PHY_DATA4);
+ omap_cfg_reg(Y12_3430_USB1HS_PHY_DATA5);
+ omap_cfg_reg(W8_3430_USB1HS_PHY_DATA6);
+ omap_cfg_reg(Y13_3430_USB1HS_PHY_DATA7);
+
+ /* Port2 */
+ omap_cfg_reg(AA10_3430_USB2HS_PHY_STP);
+ omap_cfg_reg(AA8_3430_USB2HS_PHY_CLK);
+ omap_cfg_reg(AA9_3430_USB2HS_PHY_DIR);
+ omap_cfg_reg(AB11_3430_USB2HS_PHY_NXT);
+ omap_cfg_reg(AB10_3430_USB2HS_PHY_DATA0);
+ omap_cfg_reg(AB9_3430_USB2HS_PHY_DATA1);
+ omap_cfg_reg(W3_3430_USB2HS_PHY_DATA2);
+ omap_cfg_reg(T4_3430_USB2HS_PHY_DATA3);
+ omap_cfg_reg(T3_3430_USB2HS_PHY_DATA4);
+ omap_cfg_reg(R3_3430_USB2HS_PHY_DATA5);
+ omap_cfg_reg(R4_3430_USB2HS_PHY_DATA6);
+ omap_cfg_reg(T2_3430_USB2HS_PHY_DATA7);
+ } else if (cpu_is_omap44xx()) {
+ /* Port 1 */
+ omap_cfg_reg(AE_4430_USB1HS_PHY_CLK);
+ omap_cfg_reg(AG_4430_USB1HS_PHY_STP);
+ omap_cfg_reg(AF_4430_USB1HS_PHY_DIR);
+ omap_cfg_reg(AE_4430_USB1HS_PHY_NXT);
+ omap_cfg_reg(AF_4430_USB1HS_PHY_D0);
+ omap_cfg_reg(AG_4430_USB1HS_PHY_D1);
+ omap_cfg_reg(AE_4430_USB1HS_PHY_D2);
+ omap_cfg_reg(AF_4430_USB1HS_PHY_D3);
+ omap_cfg_reg(AH_4430_USB1HS_PHY_D4);
+ omap_cfg_reg(AE_4430_USB1HS_PHY_D5);
+ omap_cfg_reg(AF_4430_USB1HS_PHY_D6);
+ omap_cfg_reg(AG_4430_USB1HS_PHY_D7);
+ }
} else {
/* Set Func mux for :
* TLL mode of operation
@@ -385,8 +401,7 @@ void __init usb_ehci_init(enum ehci_hcd_omap_mode phy_mode,
platform_device_add_data(&ehci_device, &pdata, sizeof(pdata));
/* Setup Pin IO MUX for EHCI */
- if (cpu_is_omap34xx())
- setup_ehci_io_mux(phy_mode);
+ setup_ehci_io_mux(phy_mode);
#define USBHOST_PORT1_GPIO 57
#define USBHOST_PORT2_GPIO 61