| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218 | /* * Copyright (C) 2009 Nokia * Copyright (C) 2009 Texas Instruments * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. */#include <linux/module.h>#include <linux/init.h>#include "mux.h"#ifdef CONFIG_OMAP_MUX#define _OMAP3_MUXENTRY(M0, g, m0, m1, m2, m3, m4, m5, m6, m7)		\{									\	.reg_offset	= (OMAP3_CONTROL_PADCONF_##M0##_OFFSET),	\	.gpio		= (g),						\	.muxnames	= { m0, m1, m2, m3, m4, m5, m6, m7 },		\}#else#define _OMAP3_MUXENTRY(M0, g, m0, m1, m2, m3, m4, m5, m6, m7)		\{									\	.reg_offset	= (OMAP3_CONTROL_PADCONF_##M0##_OFFSET),	\	.gpio		= (g),						\}#endif#define _OMAP3_BALLENTRY(M0, bb, bt)					\{									\	.reg_offset	= (OMAP3_CONTROL_PADCONF_##M0##_OFFSET),	\	.balls		= { bb, bt },					\}/* * Superset of all mux modes for omap3 */static struct omap_mux __initdata omap3_muxmodes[] = {	_OMAP3_MUXENTRY(CAM_D0, 99,		"cam_d0", NULL, NULL, NULL,		"gpio_99", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_D1, 100,		"cam_d1", NULL, NULL, NULL,		"gpio_100", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_D10, 109,		"cam_d10", NULL, NULL, NULL,		"gpio_109", "hw_dbg8", NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_D11, 110,		"cam_d11", NULL, NULL, NULL,		"gpio_110", "hw_dbg9", NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_D2, 101,		"cam_d2", NULL, NULL, NULL,		"gpio_101", "hw_dbg4", NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_D3, 102,		"cam_d3", NULL, NULL, NULL,		"gpio_102", "hw_dbg5", NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_D4, 103,		"cam_d4", NULL, NULL, NULL,		"gpio_103", "hw_dbg6", NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_D5, 104,		"cam_d5", NULL, NULL, NULL,		"gpio_104", "hw_dbg7", NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_D6, 105,		"cam_d6", NULL, NULL, NULL,		"gpio_105", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_D7, 106,		"cam_d7", NULL, NULL, NULL,		"gpio_106", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_D8, 107,		"cam_d8", NULL, NULL, NULL,		"gpio_107", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_D9, 108,		"cam_d9", NULL, NULL, NULL,		"gpio_108", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_FLD, 98,		"cam_fld", NULL, "cam_global_reset", NULL,		"gpio_98", "hw_dbg3", NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_HS, 94,		"cam_hs", NULL, NULL, NULL,		"gpio_94", "hw_dbg0", NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_PCLK, 97,		"cam_pclk", NULL, NULL, NULL,		"gpio_97", "hw_dbg2", NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_STROBE, 126,		"cam_strobe", NULL, NULL, NULL,		"gpio_126", "hw_dbg11", NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_VS, 95,		"cam_vs", NULL, NULL, NULL,		"gpio_95", "hw_dbg1", NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_WEN, 167,		"cam_wen", NULL, "cam_shutter", NULL,		"gpio_167", "hw_dbg10", NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_XCLKA, 96,		"cam_xclka", NULL, NULL, NULL,		"gpio_96", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(CAM_XCLKB, 111,		"cam_xclkb", NULL, NULL, NULL,		"gpio_111", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(CSI2_DX0, 112,		"csi2_dx0", NULL, NULL, NULL,		"gpio_112", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(CSI2_DX1, 114,		"csi2_dx1", NULL, NULL, NULL,		"gpio_114", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(CSI2_DY0, 113,		"csi2_dy0", NULL, NULL, NULL,		"gpio_113", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(CSI2_DY1, 115,		"csi2_dy1", NULL, NULL, NULL,		"gpio_115", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_ACBIAS, 69,		"dss_acbias", NULL, NULL, NULL,		"gpio_69", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA0, 70,		"dss_data0", NULL, "uart1_cts", NULL,		"gpio_70", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA1, 71,		"dss_data1", NULL, "uart1_rts", NULL,		"gpio_71", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA10, 80,		"dss_data10", NULL, NULL, NULL,		"gpio_80", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA11, 81,		"dss_data11", NULL, NULL, NULL,		"gpio_81", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA12, 82,		"dss_data12", NULL, NULL, NULL,		"gpio_82", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA13, 83,		"dss_data13", NULL, NULL, NULL,		"gpio_83", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA14, 84,		"dss_data14", NULL, NULL, NULL,		"gpio_84", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA15, 85,		"dss_data15", NULL, NULL, NULL,		"gpio_85", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA16, 86,		"dss_data16", NULL, NULL, NULL,		"gpio_86", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA17, 87,		"dss_data17", NULL, NULL, NULL,		"gpio_87", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA18, 88,		"dss_data18", NULL, "mcspi3_clk", "dss_data0",		"gpio_88", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA19, 89,		"dss_data19", NULL, "mcspi3_simo", "dss_data1",		"gpio_89", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA20, 90,		"dss_data20", NULL, "mcspi3_somi", "dss_data2",		"gpio_90", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA21, 91,		"dss_data21", NULL, "mcspi3_cs0", "dss_data3",		"gpio_91", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA22, 92,		"dss_data22", NULL, "mcspi3_cs1", "dss_data4",		"gpio_92", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA23, 93,		"dss_data23", NULL, NULL, "dss_data5",		"gpio_93", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA2, 72,		"dss_data2", NULL, NULL, NULL,		"gpio_72", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA3, 73,		"dss_data3", NULL, NULL, NULL,		"gpio_73", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA4, 74,		"dss_data4", NULL, "uart3_rx_irrx", NULL,		"gpio_74", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA5, 75,		"dss_data5", NULL, "uart3_tx_irtx", NULL,		"gpio_75", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA6, 76,		"dss_data6", NULL, "uart1_tx", NULL,		"gpio_76", "hw_dbg14", NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA7, 77,		"dss_data7", NULL, "uart1_rx", NULL,		"gpio_77", "hw_dbg15", NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA8, 78,		"dss_data8", NULL, NULL, NULL,		"gpio_78", "hw_dbg16", NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_DATA9, 79,		"dss_data9", NULL, NULL, NULL,		"gpio_79", "hw_dbg17", NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_HSYNC, 67,		"dss_hsync", NULL, NULL, NULL,		"gpio_67", "hw_dbg13", NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_PCLK, 66,		"dss_pclk", NULL, NULL, NULL,		"gpio_66", "hw_dbg12", NULL, "safe_mode"),	_OMAP3_MUXENTRY(DSS_VSYNC, 68,		"dss_vsync", NULL, NULL, NULL,		"gpio_68", NULL, NULL, "safe_mode"),	_OMAP3_MUXENTRY(ETK_CLK, 12,		"etk_clk", "mcbsp5_clkx", "sdmmc3_clk", "hsusb1_stp",		"gpio_12", "mm1_rxdp", "hsusb1_tll_stp", "hw_dbg0"),	_OMAP3_MUXENTRY(ETK_CTL, 13,		"etk_ctl", NULL, "sdmmc3_cmd", "hsusb1_clk",		"gpio_13", NULL, "hsusb1_tll_clk", "hw_dbg1"),	_OMAP3_MUXENTRY(ETK_D0, 14,		"etk_d0", "mcspi3_simo", "sdmmc3_dat4", "hsusb1_data0",		"gpio_14", "mm1_rxrcv", "hsusb1_tll_data0", "hw_dbg2"),	_OMAP3_MUXENTRY(ETK_D1, 15,		"etk_d1", "mcspi3_somi", NULL, "hsusb1_data1",		"gpio_15", "mm1_txse0", "hsusb1_tll_data1", "hw_dbg3"),	_OMAP3_MUXENTRY(ETK_D10, 24,		"etk_d10", NULL, "uart1_rx", "hsusb2_clk",		"gpio_24", NULL, "hsusb2_tll_clk", "hw_dbg12"),	_OMAP3_MUXENTRY(ETK_D11, 25,		"etk_d11", NULL, NULL, "hsusb2_stp",		"gpio_25", "mm2_rxdp", "hsusb2_tll_stp", "hw_dbg13"),	_OMAP3_MUXENTRY(ETK_D12, 26,
 |