aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/plat-mxc
diff options
context:
space:
mode:
Diffstat (limited to 'arch/arm/plat-mxc')
-rw-r--r--arch/arm/plat-mxc/gpio.c110
-rw-r--r--arch/arm/plat-mxc/include/mach/gpio.h15
2 files changed, 15 insertions, 110 deletions
diff --git a/arch/arm/plat-mxc/gpio.c b/arch/arm/plat-mxc/gpio.c
index e396df8faef8..57d59855f9ec 100644
--- a/arch/arm/plat-mxc/gpio.c
+++ b/arch/arm/plat-mxc/gpio.c
@@ -350,113 +350,3 @@ int __init mxc_gpio_init(struct mxc_gpio_port *port, int cnt)
350 350
351 return 0; 351 return 0;
352} 352}
353
354#define DEFINE_IMX_GPIO_PORT_IRQ_HIGH(soc, _id, _hwid, _irq, _irq_high) \
355 { \
356 .chip.label = "gpio-" #_id, \
357 .irq = _irq, \
358 .irq_high = _irq_high, \
359 .base = soc ## _IO_ADDRESS( \
360 soc ## _GPIO ## _hwid ## _BASE_ADDR), \
361 .virtual_irq_start = MXC_GPIO_IRQ_START + (_id) * 32, \
362 }
363
364#define DEFINE_IMX_GPIO_PORT_IRQ(soc, _id, _hwid, _irq) \
365 DEFINE_IMX_GPIO_PORT_IRQ_HIGH(soc, _id, _hwid, _irq, 0)
366#define DEFINE_IMX_GPIO_PORT(soc, _id, _hwid) \
367 DEFINE_IMX_GPIO_PORT_IRQ(soc, _id, _hwid, 0)
368
369#define DEFINE_REGISTER_FUNCTION(prefix) \
370int __init prefix ## _register_gpios(void) \
371{ \
372 return mxc_gpio_init(prefix ## _gpio_ports, \
373 ARRAY_SIZE(prefix ## _gpio_ports)); \
374}
375
376#if defined(CONFIG_SOC_IMX1)
377static struct mxc_gpio_port imx1_gpio_ports[] = {
378 DEFINE_IMX_GPIO_PORT_IRQ(MX1, 0, 1, MX1_GPIO_INT_PORTA),
379 DEFINE_IMX_GPIO_PORT_IRQ(MX1, 1, 2, MX1_GPIO_INT_PORTB),
380 DEFINE_IMX_GPIO_PORT_IRQ(MX1, 2, 3, MX1_GPIO_INT_PORTC),
381 DEFINE_IMX_GPIO_PORT_IRQ(MX1, 3, 4, MX1_GPIO_INT_PORTD),
382};
383
384DEFINE_REGISTER_FUNCTION(imx1)
385
386#endif /* if defined(CONFIG_SOC_IMX1) */
387
388#if defined(CONFIG_SOC_IMX21)
389static struct mxc_gpio_port imx21_gpio_ports[] = {
390 DEFINE_IMX_GPIO_PORT_IRQ(MX21, 0, 1, MX21_INT_GPIO),
391 DEFINE_IMX_GPIO_PORT(MX21, 1, 2),
392 DEFINE_IMX_GPIO_PORT(MX21, 2, 3),
393 DEFINE_IMX_GPIO_PORT(MX21, 3, 4),
394 DEFINE_IMX_GPIO_PORT(MX21, 4, 5),
395 DEFINE_IMX_GPIO_PORT(MX21, 5, 6),
396};
397
398DEFINE_REGISTER_FUNCTION(imx21)
399
400#endif /* if defined(CONFIG_SOC_IMX21) */
401
402#if defined(CONFIG_SOC_IMX25)
403static struct mxc_gpio_port imx25_gpio_ports[] = {
404 DEFINE_IMX_GPIO_PORT_IRQ(MX25, 0, 1, MX25_INT_GPIO1),
405 DEFINE_IMX_GPIO_PORT_IRQ(MX25, 1, 2, MX25_INT_GPIO2),
406 DEFINE_IMX_GPIO_PORT_IRQ(MX25, 2, 3, MX25_INT_GPIO3),
407 DEFINE_IMX_GPIO_PORT_IRQ(MX25, 3, 4, MX25_INT_GPIO4),
408};
409
410DEFINE_REGISTER_FUNCTION(imx25)
411
412#endif /* if defined(CONFIG_SOC_IMX25) */
413
414#if defined(CONFIG_SOC_IMX27)
415static struct mxc_gpio_port imx27_gpio_ports[] = {
416 DEFINE_IMX_GPIO_PORT_IRQ(MX27, 0, 1, MX27_INT_GPIO),
417 DEFINE_IMX_GPIO_PORT(MX27, 1, 2),
418 DEFINE_IMX_GPIO_PORT(MX27, 2, 3),
419 DEFINE_IMX_GPIO_PORT(MX27, 3, 4),
420 DEFINE_IMX_GPIO_PORT(MX27, 4, 5),
421 DEFINE_IMX_GPIO_PORT(MX27, 5, 6),
422};
423
424DEFINE_REGISTER_FUNCTION(imx27)
425
426#endif /* if defined(CONFIG_SOC_IMX27) */
427
428#if defined(CONFIG_SOC_IMX31)
429static struct mxc_gpio_port imx31_gpio_ports[] = {
430 DEFINE_IMX_GPIO_PORT_IRQ(MX31, 0, 1, MX31_INT_GPIO1),
431 DEFINE_IMX_GPIO_PORT_IRQ(MX31, 1, 2, MX31_INT_GPIO2),
432 DEFINE_IMX_GPIO_PORT_IRQ(MX31, 2, 3, MX31_INT_GPIO3),
433};
434
435DEFINE_REGISTER_FUNCTION(imx31)
436
437#endif /* if defined(CONFIG_SOC_IMX31) */
438
439#if defined(CONFIG_SOC_IMX35)
440static struct mxc_gpio_port imx35_gpio_ports[] = {
441 DEFINE_IMX_GPIO_PORT_IRQ(MX35, 0, 1, MX35_INT_GPIO1),
442 DEFINE_IMX_GPIO_PORT_IRQ(MX35, 1, 2, MX35_INT_GPIO2),
443 DEFINE_IMX_GPIO_PORT_IRQ(MX35, 2, 3, MX35_INT_GPIO3),
444};
445
446DEFINE_REGISTER_FUNCTION(imx35)
447
448#endif /* if defined(CONFIG_SOC_IMX35) */
449
450#if defined(CONFIG_SOC_IMX50)
451static struct mxc_gpio_port imx50_gpio_ports[] = {
452 DEFINE_IMX_GPIO_PORT_IRQ_HIGH(MX50, 0, 1, MX50_INT_GPIO1_LOW, MX50_INT_GPIO1_HIGH),
453 DEFINE_IMX_GPIO_PORT_IRQ_HIGH(MX50, 1, 2, MX50_INT_GPIO2_LOW, MX50_INT_GPIO2_HIGH),
454 DEFINE_IMX_GPIO_PORT_IRQ_HIGH(MX50, 2, 3, MX50_INT_GPIO3_LOW, MX50_INT_GPIO3_HIGH),
455 DEFINE_IMX_GPIO_PORT_IRQ_HIGH(MX50, 3, 4, MX50_INT_GPIO3_LOW, MX50_INT_GPIO3_HIGH),
456 DEFINE_IMX_GPIO_PORT_IRQ_HIGH(MX50, 4, 5, MX50_INT_GPIO3_LOW, MX50_INT_GPIO3_HIGH),
457 DEFINE_IMX_GPIO_PORT_IRQ_HIGH(MX50, 5, 6, MX50_INT_GPIO3_LOW, MX50_INT_GPIO3_HIGH),
458};
459
460DEFINE_REGISTER_FUNCTION(imx50)
461
462#endif /* if defined(CONFIG_SOC_IMX50) */
diff --git a/arch/arm/plat-mxc/include/mach/gpio.h b/arch/arm/plat-mxc/include/mach/gpio.h
index 0044e2f1bea8..a2747f12813e 100644
--- a/arch/arm/plat-mxc/include/mach/gpio.h
+++ b/arch/arm/plat-mxc/include/mach/gpio.h
@@ -46,6 +46,21 @@ struct mxc_gpio_port {
46 spinlock_t lock; 46 spinlock_t lock;
47}; 47};
48 48
49#define DEFINE_IMX_GPIO_PORT_IRQ_HIGH(soc, _id, _hwid, _irq, _irq_high) \
50 { \
51 .chip.label = "gpio-" #_id, \
52 .irq = _irq, \
53 .irq_high = _irq_high, \
54 .base = soc ## _IO_ADDRESS( \
55 soc ## _GPIO ## _hwid ## _BASE_ADDR), \
56 .virtual_irq_start = MXC_GPIO_IRQ_START + (_id) * 32, \
57 }
58
59#define DEFINE_IMX_GPIO_PORT_IRQ(soc, _id, _hwid, _irq) \
60 DEFINE_IMX_GPIO_PORT_IRQ_HIGH(soc, _id, _hwid, _irq, 0)
61#define DEFINE_IMX_GPIO_PORT(soc, _id, _hwid) \
62 DEFINE_IMX_GPIO_PORT_IRQ(soc, _id, _hwid, 0)
63
49int mxc_gpio_init(struct mxc_gpio_port*, int); 64int mxc_gpio_init(struct mxc_gpio_port*, int);
50 65
51#endif 66#endif