Commit 014dcad0 authored by Tony Lindgren's avatar Tony Lindgren

ARM: OMAP: Allow registering pin mux function

This patch changes pin multiplexing init to allow registering
custom function. The omap_cfg_reg() func will be split into
omap processor specific functions in later patch.

This is done to make adding omap3 pin multiplexing easier.
Signed-off-by: default avatarTony Lindgren <tony@atomide.com>
parent d9ba4122
...@@ -32,6 +32,8 @@ ...@@ -32,6 +32,8 @@
#ifdef CONFIG_OMAP_MUX #ifdef CONFIG_OMAP_MUX
static struct omap_mux_cfg arch_mux_cfg;
#ifdef CONFIG_ARCH_OMAP730 #ifdef CONFIG_ARCH_OMAP730
struct pin_config __initdata_or_module omap730_pins[] = { struct pin_config __initdata_or_module omap730_pins[] = {
MUX_CFG_730("E2_730_KBR0", 12, 21, 0, 20, 1, 0) MUX_CFG_730("E2_730_KBR0", 12, 21, 0, 20, 1, 0)
...@@ -310,18 +312,31 @@ MUX_CFG("Y14_1610_CCP_DATAM", 9, 21, 6, 2, 3, 1, 2, 0, 0) ...@@ -310,18 +312,31 @@ MUX_CFG("Y14_1610_CCP_DATAM", 9, 21, 6, 2, 3, 1, 2, 0, 0)
}; };
#endif /* CONFIG_ARCH_OMAP15XX || CONFIG_ARCH_OMAP16XX */ #endif /* CONFIG_ARCH_OMAP15XX || CONFIG_ARCH_OMAP16XX */
int __init_or_module omap1_cfg_reg(const struct pin_config *cfg)
{
return 0;
}
int __init omap1_mux_init(void) int __init omap1_mux_init(void)
{ {
#ifdef CONFIG_ARCH_OMAP730 #ifdef CONFIG_ARCH_OMAP730
omap_mux_register(omap730_pins, ARRAY_SIZE(omap730_pins)); if (cpu_is_omap730()) {
arch_mux_cfg.pins = omap730_pins;
arch_mux_cfg.size = ARRAY_SIZE(omap730_pins);
arch_mux_cfg.cfg_reg = omap1_cfg_reg;
}
#endif #endif
#if defined(CONFIG_ARCH_OMAP15XX) || defined(CONFIG_ARCH_OMAP16XX) #if defined(CONFIG_ARCH_OMAP15XX) || defined(CONFIG_ARCH_OMAP16XX)
omap_mux_register(omap1xxx_pins, ARRAY_SIZE(omap1xxx_pins)); if (cpu_is_omap15xx() || cpu_is_omap16xx()) {
arch_mux_cfg.pins = omap1xxx_pins;
arch_mux_cfg.size = ARRAY_SIZE(omap1xxx_pins);
arch_mux_cfg.cfg_reg = omap1_cfg_reg;
}
#endif #endif
return 0; return omap_mux_register(&arch_mux_cfg);
} }
#endif #endif
...@@ -32,6 +32,8 @@ ...@@ -32,6 +32,8 @@
#ifdef CONFIG_OMAP_MUX #ifdef CONFIG_OMAP_MUX
static struct omap_mux_cfg arch_mux_cfg;
/* NOTE: See mux.h for the enumeration */ /* NOTE: See mux.h for the enumeration */
struct pin_config __initdata_or_module omap24xx_pins[] = { struct pin_config __initdata_or_module omap24xx_pins[] = {
...@@ -207,10 +209,25 @@ MUX_CFG_24XX("AE13_2430_MCBSP2_DX_OFF", 0x0130, 0, 0, 0, 1) ...@@ -207,10 +209,25 @@ MUX_CFG_24XX("AE13_2430_MCBSP2_DX_OFF", 0x0130, 0, 0, 0, 1)
MUX_CFG_24XX("AD13_2430_MCBSP2_DR_OFF", 0x0131, 0, 0, 0, 1) MUX_CFG_24XX("AD13_2430_MCBSP2_DR_OFF", 0x0131, 0, 0, 0, 1)
}; };
int __init omap2_mux_init(void) #ifdef CONFIG_ARCH_OMAP24XX
int __init_or_module omap24xx_cfg_reg(const struct pin_config *cfg)
{ {
omap_mux_register(omap24xx_pins, ARRAY_SIZE(omap24xx_pins));
return 0; return 0;
} }
#endif
int __init omap2_mux_init(void)
{
#ifdef CONFIG_ARCH_OMAP24XX
if (cpu_is_omap24xx()) {
arch_mux_cfg.pins = omap24xx_pins;
arch_mux_cfg.size = ARRAY_SIZE(omap24xx_pins);
arch_mux_cfg.cfg_reg = omap24xx_cfg_reg;
}
#endif
return omap_mux_register(&arch_mux_cfg);
}
#endif #endif
...@@ -39,17 +39,17 @@ ...@@ -39,17 +39,17 @@
#define OMAP24XX_PULL_ENA (1 << 3) #define OMAP24XX_PULL_ENA (1 << 3)
#define OMAP24XX_PULL_UP (1 << 4) #define OMAP24XX_PULL_UP (1 << 4)
static struct pin_config * pin_table; static struct omap_mux_cfg *mux_cfg;
static unsigned long pin_table_sz;
extern struct pin_config * omap730_pins; int __init omap_mux_register(struct omap_mux_cfg *arch_mux_cfg)
extern struct pin_config * omap1xxx_pins;
extern struct pin_config * omap24xx_pins;
int __init omap_mux_register(struct pin_config * pins, unsigned long size)
{ {
pin_table = pins; if (!arch_mux_cfg || !arch_mux_cfg->pins || arch_mux_cfg->size == 0
pin_table_sz = size; || !arch_mux_cfg->cfg_reg) {
printk(KERN_ERR "Invalid pin table\n");
return -EINVAL;
}
mux_cfg = arch_mux_cfg;
return 0; return 0;
} }
...@@ -67,17 +67,19 @@ int __init_or_module omap_cfg_reg(const unsigned long index) ...@@ -67,17 +67,19 @@ int __init_or_module omap_cfg_reg(const unsigned long index)
pull_orig = 0, pull = 0; pull_orig = 0, pull = 0;
unsigned int mask, warn = 0; unsigned int mask, warn = 0;
if (!pin_table) if (mux_cfg == NULL) {
BUG(); printk(KERN_ERR "Pin mux table not initialized\n");
return -ENODEV;
}
if (index >= pin_table_sz) { if (index >= mux_cfg->size) {
printk(KERN_ERR "Invalid pin mux index: %lu (%lu)\n", printk(KERN_ERR "Invalid pin mux index: %lu (%lu)\n",
index, pin_table_sz); index, mux_cfg->size);
dump_stack(); dump_stack();
return -ENODEV; return -ENODEV;
} }
cfg = (struct pin_config *)&pin_table[index]; cfg = (struct pin_config *)&mux_cfg->pins[index];
#ifdef CONFIG_ARCH_OMAP24XX #ifdef CONFIG_ARCH_OMAP24XX
/* REVISIT: Convert this code to use ctrl_{read,write}_reg */ /* REVISIT: Convert this code to use ctrl_{read,write}_reg */
if (cpu_is_omap24xx()) { if (cpu_is_omap24xx()) {
......
...@@ -599,11 +599,17 @@ enum omap24xx_index { ...@@ -599,11 +599,17 @@ enum omap24xx_index {
AD13_2430_MCBSP2_DR_OFF, AD13_2430_MCBSP2_DR_OFF,
}; };
struct omap_mux_cfg {
struct pin_config *pins;
unsigned long size;
int (*cfg_reg)(const struct pin_config *cfg);
};
#ifdef CONFIG_OMAP_MUX #ifdef CONFIG_OMAP_MUX
/* setup pin muxing in Linux */ /* setup pin muxing in Linux */
extern int omap1_mux_init(void); extern int omap1_mux_init(void);
extern int omap2_mux_init(void); extern int omap2_mux_init(void);
extern int omap_mux_register(struct pin_config * pins, unsigned long size); extern int omap_mux_register(struct omap_mux_cfg *);
extern int omap_cfg_reg(unsigned long reg_cfg); extern int omap_cfg_reg(unsigned long reg_cfg);
#else #else
/* boot loader does it all (no warnings from CONFIG_OMAP_MUX_WARNINGS) */ /* boot loader does it all (no warnings from CONFIG_OMAP_MUX_WARNINGS) */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment