Commit f23c144d authored by Greg Ungerer's avatar Greg Ungerer

m68knommu: make duplicated ColdFire GPIO init code common for all

The code that adds each ColdFire platforms GPIO signals is duplicated in
each platforms specific code. Remove it from each platforms code and put
a single version in the existing ColdFire gpio subsystem init code.
Signed-off-by: default avatarGreg Ungerer <gerg@uclinux.org>
Acked-by: default avatarSteven King <sfking@fdwdc.com>
parent 943c0cd0
...@@ -29,6 +29,9 @@ struct mcf_gpio_chip { ...@@ -29,6 +29,9 @@ struct mcf_gpio_chip {
const u8 *gpio_to_pinmux; const u8 *gpio_to_pinmux;
}; };
extern struct mcf_gpio_chip mcf_gpio_chips[];
extern unsigned int mcf_gpio_chips_size;
int mcf_gpio_direction_input(struct gpio_chip *, unsigned); int mcf_gpio_direction_input(struct gpio_chip *, unsigned);
int mcf_gpio_get_value(struct gpio_chip *, unsigned); int mcf_gpio_get_value(struct gpio_chip *, unsigned);
int mcf_gpio_direction_output(struct gpio_chip *, unsigned, int); int mcf_gpio_direction_output(struct gpio_chip *, unsigned, int);
......
...@@ -20,16 +20,8 @@ ...@@ -20,16 +20,8 @@
#include <asm/mcfsim.h> #include <asm/mcfsim.h>
#include <asm/mcfgpio.h> #include <asm/mcfgpio.h>
static struct mcf_gpio_chip mcf_gpio_chips[] = { struct mcf_gpio_chip mcf_gpio_chips[] = {
MCFGPS(PP, 0, 8, MCFSIM_PADDR, MCFSIM_PADAT, MCFSIM_PADAT), MCFGPS(PP, 0, 8, MCFSIM_PADDR, MCFSIM_PADAT, MCFSIM_PADAT),
}; };
static int __init mcf_gpio_init(void) unsigned int mcf_gpio_chips_size = ARRAY_SIZE(mcf_gpio_chips);
{
unsigned i = 0;
while (i < ARRAY_SIZE(mcf_gpio_chips))
(void)gpiochip_add((struct gpio_chip *)&mcf_gpio_chips[i++]);
return 0;
}
core_initcall(mcf_gpio_init);
...@@ -20,7 +20,7 @@ ...@@ -20,7 +20,7 @@
#include <asm/mcfsim.h> #include <asm/mcfsim.h>
#include <asm/mcfgpio.h> #include <asm/mcfgpio.h>
static struct mcf_gpio_chip mcf_gpio_chips[] = { struct mcf_gpio_chip mcf_gpio_chips[] = {
MCFGPS(PIRQ, 0, 8, MCFEPORT_EPDDR, MCFEPORT_EPDR, MCFEPORT_EPPDR), MCFGPS(PIRQ, 0, 8, MCFEPORT_EPDDR, MCFEPORT_EPDR, MCFEPORT_EPPDR),
MCFGPF(CS, 9, 3), MCFGPF(CS, 9, 3),
MCFGPF(FECI2C, 16, 4), MCFGPF(FECI2C, 16, 4),
...@@ -31,12 +31,4 @@ static struct mcf_gpio_chip mcf_gpio_chips[] = { ...@@ -31,12 +31,4 @@ static struct mcf_gpio_chip mcf_gpio_chips[] = {
MCFGPF(FECL, 56, 8), MCFGPF(FECL, 56, 8),
}; };
static int __init mcf_gpio_init(void) unsigned int mcf_gpio_chips_size = ARRAY_SIZE(mcf_gpio_chips);
{
unsigned i = 0;
while (i < ARRAY_SIZE(mcf_gpio_chips))
(void)gpiochip_add((struct gpio_chip *)&mcf_gpio_chips[i++]);
return 0;
}
core_initcall(mcf_gpio_init);
...@@ -20,7 +20,7 @@ ...@@ -20,7 +20,7 @@
#include <asm/mcfsim.h> #include <asm/mcfsim.h>
#include <asm/mcfgpio.h> #include <asm/mcfgpio.h>
static struct mcf_gpio_chip mcf_gpio_chips[] = { struct mcf_gpio_chip mcf_gpio_chips[] = {
MCFGPS(PIRQ, 1, 7, MCFEPORT_EPDDR, MCFEPORT_EPDR, MCFEPORT_EPPDR), MCFGPS(PIRQ, 1, 7, MCFEPORT_EPDDR, MCFEPORT_EPDR, MCFEPORT_EPPDR),
MCFGPF(ADDR, 13, 3), MCFGPF(ADDR, 13, 3),
MCFGPF(DATAH, 16, 8), MCFGPF(DATAH, 16, 8),
...@@ -37,12 +37,4 @@ static struct mcf_gpio_chip mcf_gpio_chips[] = { ...@@ -37,12 +37,4 @@ static struct mcf_gpio_chip mcf_gpio_chips[] = {
MCFGPF(ETPU, 104, 3), MCFGPF(ETPU, 104, 3),
}; };
static int __init mcf_gpio_init(void) unsigned int mcf_gpio_chips_size = ARRAY_SIZE(mcf_gpio_chips);
{
unsigned i = 0;
while (i < ARRAY_SIZE(mcf_gpio_chips))
(void)gpiochip_add((struct gpio_chip *)&mcf_gpio_chips[i++]);
return 0;
}
core_initcall(mcf_gpio_init);
...@@ -20,17 +20,9 @@ ...@@ -20,17 +20,9 @@
#include <asm/mcfsim.h> #include <asm/mcfsim.h>
#include <asm/mcfgpio.h> #include <asm/mcfgpio.h>
static struct mcf_gpio_chip mcf_gpio_chips[] = { struct mcf_gpio_chip mcf_gpio_chips[] = {
MCFGPS(GPIO0, 0, 32, MCFSIM2_GPIOENABLE, MCFSIM2_GPIOWRITE, MCFSIM2_GPIOREAD), MCFGPS(GPIO0, 0, 32, MCFSIM2_GPIOENABLE, MCFSIM2_GPIOWRITE, MCFSIM2_GPIOREAD),
MCFGPS(GPIO1, 32, 32, MCFSIM2_GPIO1ENABLE, MCFSIM2_GPIO1WRITE, MCFSIM2_GPIO1READ), MCFGPS(GPIO1, 32, 32, MCFSIM2_GPIO1ENABLE, MCFSIM2_GPIO1WRITE, MCFSIM2_GPIO1READ),
}; };
static int __init mcf_gpio_init(void) unsigned int mcf_gpio_chips_size = ARRAY_SIZE(mcf_gpio_chips);
{
unsigned i = 0;
while (i < ARRAY_SIZE(mcf_gpio_chips))
(void)gpiochip_add((struct gpio_chip *)&mcf_gpio_chips[i++]);
return 0;
}
core_initcall(mcf_gpio_init);
...@@ -20,18 +20,10 @@ ...@@ -20,18 +20,10 @@
#include <asm/mcfsim.h> #include <asm/mcfsim.h>
#include <asm/mcfgpio.h> #include <asm/mcfgpio.h>
static struct mcf_gpio_chip mcf_gpio_chips[] = { struct mcf_gpio_chip mcf_gpio_chips[] = {
MCFGPS(PA, 0, 16, MCFSIM_PADDR, MCFSIM_PADAT, MCFSIM_PADAT), MCFGPS(PA, 0, 16, MCFSIM_PADDR, MCFSIM_PADAT, MCFSIM_PADAT),
MCFGPS(PB, 16, 16, MCFSIM_PBDDR, MCFSIM_PBDAT, MCFSIM_PBDAT), MCFGPS(PB, 16, 16, MCFSIM_PBDDR, MCFSIM_PBDAT, MCFSIM_PBDAT),
MCFGPS(Pc, 32, 16, MCFSIM_PCDDR, MCFSIM_PCDAT, MCFSIM_PCDAT), MCFGPS(Pc, 32, 16, MCFSIM_PCDDR, MCFSIM_PCDAT, MCFSIM_PCDAT),
}; };
static int __init mcf_gpio_init(void) unsigned int mcf_gpio_chips_size = ARRAY_SIZE(mcf_gpio_chips);
{
unsigned i = 0;
while (i < ARRAY_SIZE(mcf_gpio_chips))
(void)gpiochip_add((struct gpio_chip *)&mcf_gpio_chips[i++]);
return 0;
}
core_initcall(mcf_gpio_init);
...@@ -20,7 +20,7 @@ ...@@ -20,7 +20,7 @@
#include <asm/mcfsim.h> #include <asm/mcfsim.h>
#include <asm/mcfgpio.h> #include <asm/mcfgpio.h>
static struct mcf_gpio_chip mcf_gpio_chips[] = { struct mcf_gpio_chip mcf_gpio_chips[] = {
#if defined(CONFIG_M5271) #if defined(CONFIG_M5271)
MCFGPS(PIRQ, 1, 7, MCFEPORT_EPDDR, MCFEPORT_EPDR, MCFEPORT_EPPDR), MCFGPS(PIRQ, 1, 7, MCFEPORT_EPDDR, MCFEPORT_EPDR, MCFEPORT_EPPDR),
MCFGPF(ADDR, 13, 3), MCFGPF(ADDR, 13, 3),
...@@ -58,12 +58,4 @@ static struct mcf_gpio_chip mcf_gpio_chips[] = { ...@@ -58,12 +58,4 @@ static struct mcf_gpio_chip mcf_gpio_chips[] = {
#endif #endif
}; };
static int __init mcf_gpio_init(void) unsigned int mcf_gpio_chips_size = ARRAY_SIZE(mcf_gpio_chips);
{
unsigned i = 0;
while (i < ARRAY_SIZE(mcf_gpio_chips))
(void)gpiochip_add((struct gpio_chip *)&mcf_gpio_chips[i++]);
return 0;
}
core_initcall(mcf_gpio_init);
...@@ -20,7 +20,7 @@ ...@@ -20,7 +20,7 @@
#include <asm/mcfsim.h> #include <asm/mcfsim.h>
#include <asm/mcfgpio.h> #include <asm/mcfgpio.h>
static struct mcf_gpio_chip mcf_gpio_chips[] = { struct mcf_gpio_chip mcf_gpio_chips[] = {
MCFGPS(NQ, 1, 7, MCFEPORT_EPDDR, MCFEPORT_EPDR, MCFEPORT_EPPDR), MCFGPS(NQ, 1, 7, MCFEPORT_EPDDR, MCFEPORT_EPDR, MCFEPORT_EPPDR),
MCFGPS(TA, 8, 4, MCFGPTA_GPTDDR, MCFGPTA_GPTPORT, MCFGPTB_GPTPORT), MCFGPS(TA, 8, 4, MCFGPTA_GPTDDR, MCFGPTA_GPTPORT, MCFGPTB_GPTPORT),
MCFGPS(TB, 16, 4, MCFGPTB_GPTDDR, MCFGPTB_GPTPORT, MCFGPTB_GPTPORT), MCFGPS(TB, 16, 4, MCFGPTB_GPTDDR, MCFGPTB_GPTPORT, MCFGPTB_GPTPORT),
...@@ -46,12 +46,4 @@ static struct mcf_gpio_chip mcf_gpio_chips[] = { ...@@ -46,12 +46,4 @@ static struct mcf_gpio_chip mcf_gpio_chips[] = {
MCFGPF(UA, 176, 4), MCFGPF(UA, 176, 4),
}; };
static int __init mcf_gpio_init(void) unsigned int mcf_gpio_chips_size = ARRAY_SIZE(mcf_gpio_chips);
{
unsigned i = 0;
while (i < ARRAY_SIZE(mcf_gpio_chips))
(void)gpiochip_add((struct gpio_chip *)&mcf_gpio_chips[i++]);
return 0;
}
core_initcall(mcf_gpio_init);
...@@ -20,16 +20,8 @@ ...@@ -20,16 +20,8 @@
#include <asm/mcfsim.h> #include <asm/mcfsim.h>
#include <asm/mcfgpio.h> #include <asm/mcfgpio.h>
static struct mcf_gpio_chip mcf_gpio_chips[] = { struct mcf_gpio_chip mcf_gpio_chips[] = {
MCFGPS(PP, 0, 16, MCFSIM_PADDR, MCFSIM_PADAT, MCFSIM_PADAT), MCFGPS(PP, 0, 16, MCFSIM_PADDR, MCFSIM_PADAT, MCFSIM_PADAT),
}; };
static int __init mcf_gpio_init(void) unsigned int mcf_gpio_chips_size = ARRAY_SIZE(mcf_gpio_chips);
{
unsigned i = 0;
while (i < ARRAY_SIZE(mcf_gpio_chips))
(void)gpiochip_add((struct gpio_chip *)&mcf_gpio_chips[i++]);
return 0;
}
core_initcall(mcf_gpio_init);
...@@ -20,7 +20,7 @@ ...@@ -20,7 +20,7 @@
#include <asm/mcfsim.h> #include <asm/mcfsim.h>
#include <asm/mcfgpio.h> #include <asm/mcfgpio.h>
static struct mcf_gpio_chip mcf_gpio_chips[] = { struct mcf_gpio_chip mcf_gpio_chips[] = {
MCFGPS(PIRQ, 0, 8, MCFEPORT_EPDDR, MCFEPORT_EPDR, MCFEPORT_EPPDR), MCFGPS(PIRQ, 0, 8, MCFEPORT_EPDDR, MCFEPORT_EPDR, MCFEPORT_EPPDR),
MCFGPF(FECH, 8, 8), MCFGPF(FECH, 8, 8),
MCFGPF(FECL, 16, 8), MCFGPF(FECL, 16, 8),
...@@ -40,12 +40,4 @@ static struct mcf_gpio_chip mcf_gpio_chips[] = { ...@@ -40,12 +40,4 @@ static struct mcf_gpio_chip mcf_gpio_chips[] = {
MCFGPF(LCDCTLL, 128, 8), MCFGPF(LCDCTLL, 128, 8),
}; };
static int __init mcf_gpio_init(void) unsigned int mcf_gpio_chips_size = ARRAY_SIZE(mcf_gpio_chips);
{
unsigned i = 0;
while (i < ARRAY_SIZE(mcf_gpio_chips))
(void)gpiochip_add((struct gpio_chip *)&mcf_gpio_chips[i++]);
return 0;
}
core_initcall(mcf_gpio_init);
...@@ -20,16 +20,8 @@ ...@@ -20,16 +20,8 @@
#include <asm/mcfsim.h> #include <asm/mcfsim.h>
#include <asm/mcfgpio.h> #include <asm/mcfgpio.h>
static struct mcf_gpio_chip mcf_gpio_chips[] = { struct mcf_gpio_chip mcf_gpio_chips[] = {
MCFGPS(PP, 0, 16, MCFSIM_PADDR, MCFSIM_PADAT, MCFSIM_PADAT), MCFGPS(PP, 0, 16, MCFSIM_PADDR, MCFSIM_PADAT, MCFSIM_PADAT),
}; };
static int __init mcf_gpio_init(void) unsigned int mcf_gpio_chips_size = ARRAY_SIZE(mcf_gpio_chips);
{
unsigned i = 0;
while (i < ARRAY_SIZE(mcf_gpio_chips))
(void)gpiochip_add((struct gpio_chip *)&mcf_gpio_chips[i++]);
return 0;
}
core_initcall(mcf_gpio_init);
...@@ -21,12 +21,19 @@ ...@@ -21,12 +21,19 @@
#include <asm/m54xxsim.h> #include <asm/m54xxsim.h>
#include <asm/mcfuart.h> #include <asm/mcfuart.h>
#include <asm/m54xxgpt.h> #include <asm/m54xxgpt.h>
#include <asm/mcfgpio.h>
#ifdef CONFIG_MMU #ifdef CONFIG_MMU
#include <asm/mmu_context.h> #include <asm/mmu_context.h>
#endif #endif
/***************************************************************************/ /***************************************************************************/
struct mcf_gpio_chip mcf_gpio_chips[] = { };
unsigned int mcf_gpio_chips_size = ARRAY_SIZE(mcf_gpio_chips);
/***************************************************************************/
static void __init m54xx_uarts_init(void) static void __init m54xx_uarts_init(void)
{ {
/* enable io pins */ /* enable io pins */
......
...@@ -122,6 +122,10 @@ struct bus_type mcf_gpio_subsys = { ...@@ -122,6 +122,10 @@ struct bus_type mcf_gpio_subsys = {
static int __init mcf_gpio_sysinit(void) static int __init mcf_gpio_sysinit(void)
{ {
unsigned int i = 0;
while (i < mcf_gpio_chips_size)
gpiochip_add((struct gpio_chip *)&mcf_gpio_chips[i++]);
return subsys_system_register(&mcf_gpio_subsys, NULL); return subsys_system_register(&mcf_gpio_subsys, NULL);
} }
......
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