Use the mux framework to initialise the musb mux pins.

Signed-off-by: sricharan <[email protected]>
---
 arch/arm/mach-omap2/usb-musb.c |   41 ++++++++++++++++++++++++++++++++++++++++
 1 files changed, 41 insertions(+), 0 deletions(-)

diff --git a/arch/arm/mach-omap2/usb-musb.c b/arch/arm/mach-omap2/usb-musb.c
index 33a5cde..27cb348 100644
--- a/arch/arm/mach-omap2/usb-musb.c
+++ b/arch/arm/mach-omap2/usb-musb.c
@@ -29,6 +29,7 @@
 #include <mach/hardware.h>
 #include <mach/irqs.h>
 #include <plat/usb.h>
+#include "mux.h"
 
 #ifdef CONFIG_USB_MUSB_SOC
 
@@ -85,6 +86,44 @@ static struct platform_device musb_device = {
        .resource       = musb_resources,
 };
 
+static void __init usb_musb_mux_init(struct omap_musb_board_data *board_data)
+{
+       if (board_data->interface_type == MUSB_INTERFACE_UTMI) {
+               /* MUSB - UTMI PIN MUX configurations */
+               omap_mux_init_signal("usba0_otg_ce.usba0_otg_ce",
+                                               OMAP_PIN_OUTPUT);
+               omap_mux_init_signal("usba0_otg_dp.usba0_otg_dp",
+                                               OMAP_PIN_INPUT);
+               omap_mux_init_signal("usba0_otg_dm.usba0_otg_dm",
+                                               OMAP_PIN_INPUT);
+       } else {
+               /* MUSB - ULPI PIN MUX configurations */
+               omap_mux_init_signal("usbb1_ulpitll_clk.usbb1_ulpiphy_clk",
+                                               OMAP_PIN_INPUT);
+               omap_mux_init_signal("usbb1_ulpitll_stp.usbb1_ulpiphy_stp",
+                                               OMAP_PIN_OUTPUT);
+               omap_mux_init_signal("usbb1_ulpitll_dir.usbb1_ulpiphy_dir",
+                                               OMAP_PIN_INPUT);
+               omap_mux_init_signal("usbb1_ulpitll_nxt.usbb1_ulpiphy_nxt",
+                                               OMAP_PIN_INPUT);
+               omap_mux_init_signal("usbb1_ulpitll_dat0.usbb1_ulpiphy_dat0",
+                                               OMAP_PIN_INPUT);
+               omap_mux_init_signal("usbb1_ulpitll_dat1.usbb1_ulpiphy_dat1",
+                                               OMAP_PIN_INPUT);
+               omap_mux_init_signal("usbb1_ulpitll_dat2.usbb1_ulpiphy_dat2",
+                                               OMAP_PIN_INPUT);
+               omap_mux_init_signal("usbb1_ulpitll_dat3.usbb1_ulpiphy_dat3",
+                                               OMAP_PIN_INPUT);
+               omap_mux_init_signal("usbb1_ulpitll_dat4.usbb1_ulpiphy_dat4",
+                                               OMAP_PIN_INPUT);
+               omap_mux_init_signal("usbb1_ulpitll_dat5.usbb1_ulpiphy_dat5",
+                                               OMAP_PIN_INPUT);
+               omap_mux_init_signal("usbb1_ulpitll_dat6.usbb1_ulpiphy_dat6",
+                                               OMAP_PIN_INPUT);
+               omap_mux_init_signal("usbb1_ulpitll_dat7.usbb1_ulpiphy_dat7",
+                                               OMAP_PIN_INPUT);
+       }
+}
 void __init usb_musb_init(struct omap_musb_board_data *board_data)
 {
        if (cpu_is_omap243x()) {
@@ -95,6 +134,8 @@ void __init usb_musb_init(struct omap_musb_board_data 
*board_data)
                musb_resources[0].start = OMAP44XX_HSUSB_OTG_BASE;
                musb_resources[1].start = OMAP44XX_IRQ_HS_USB_MC_N;
                musb_resources[2].start = OMAP44XX_IRQ_HS_USB_DMA_N;
+
+               usb_musb_mux_init(board_data);
        }
        musb_resources[0].end = musb_resources[0].start + SZ_4K - 1;
 
-- 
1.7.0.4

--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to