Commit 68c94b40 authored by Uwe Kleine-König's avatar Uwe Kleine-König

arm/mx2: use cpp magic to create spi_imx devices

This makes the source shorter and easier to verify.  While at it switch
to use the SoC-prefixed constants.
Signed-off-by: default avatarUwe Kleine-König <u.kleine-koenig@pengutronix.de>
parent e27bf724
...@@ -46,65 +46,31 @@ ...@@ -46,65 +46,31 @@
* - i.MX21: 2 channel * - i.MX21: 2 channel
* - i.MX27: 3 channel * - i.MX27: 3 channel
*/ */
static struct resource mxc_spi_resources0[] = { #define DEFINE_IMX_SPI_DEVICE(n, baseaddr, irq) \
{ static struct resource mxc_spi_resources ## n[] = { \
.start = CSPI1_BASE_ADDR, { \
.end = CSPI1_BASE_ADDR + SZ_4K - 1, .start = baseaddr, \
.flags = IORESOURCE_MEM, .end = baseaddr + SZ_4K - 1, \
}, { .flags = IORESOURCE_MEM, \
.start = MXC_INT_CSPI1, }, { \
.end = MXC_INT_CSPI1, .start = irq, \
.flags = IORESOURCE_IRQ, .end = irq, \
}, .flags = IORESOURCE_IRQ, \
}; }, \
}; \
static struct resource mxc_spi_resources1[] = { \
{ struct platform_device mxc_spi_device ## n = { \
.start = CSPI2_BASE_ADDR, .name = "spi_imx", \
.end = CSPI2_BASE_ADDR + SZ_4K - 1, .id = n, \
.flags = IORESOURCE_MEM, .num_resources = ARRAY_SIZE(mxc_spi_resources ## n), \
}, { .resource = mxc_spi_resources ## n, \
.start = MXC_INT_CSPI2, }
.end = MXC_INT_CSPI2,
.flags = IORESOURCE_IRQ,
},
};
#ifdef CONFIG_MACH_MX27
static struct resource mxc_spi_resources2[] = {
{
.start = CSPI3_BASE_ADDR,
.end = CSPI3_BASE_ADDR + SZ_4K - 1,
.flags = IORESOURCE_MEM,
}, {
.start = MXC_INT_CSPI3,
.end = MXC_INT_CSPI3,
.flags = IORESOURCE_IRQ,
},
};
#endif
struct platform_device mxc_spi_device0 = {
.name = "spi_imx",
.id = 0,
.num_resources = ARRAY_SIZE(mxc_spi_resources0),
.resource = mxc_spi_resources0,
};
struct platform_device mxc_spi_device1 = { DEFINE_IMX_SPI_DEVICE(0, MX2x_CSPI1_BASE_ADDR, MX2x_INT_CSPI1);
.name = "spi_imx", DEFINE_IMX_SPI_DEVICE(1, MX2x_CSPI2_BASE_ADDR, MX2x_INT_CSPI2);
.id = 1,
.num_resources = ARRAY_SIZE(mxc_spi_resources1),
.resource = mxc_spi_resources1,
};
#ifdef CONFIG_MACH_MX27 #ifdef CONFIG_MACH_MX27
struct platform_device mxc_spi_device2 = { DEFINE_IMX_SPI_DEVICE(2, MX27_CSPI3_BASE_ADDR, MX27_INT_CSPI3);
.name = "spi_imx",
.id = 2,
.num_resources = ARRAY_SIZE(mxc_spi_resources2),
.resource = mxc_spi_resources2,
};
#endif #endif
/* /*
......
...@@ -25,6 +25,8 @@ extern struct platform_device mxc_usbh1; ...@@ -25,6 +25,8 @@ extern struct platform_device mxc_usbh1;
extern struct platform_device mxc_usbh2; extern struct platform_device mxc_usbh2;
extern struct platform_device mxc_spi_device0; extern struct platform_device mxc_spi_device0;
extern struct platform_device mxc_spi_device1; extern struct platform_device mxc_spi_device1;
#ifdef CONFIG_MACH_MX27
extern struct platform_device mxc_spi_device2; extern struct platform_device mxc_spi_device2;
#endif
extern struct platform_device imx_ssi_device0; extern struct platform_device imx_ssi_device0;
extern struct platform_device imx_ssi_device1; extern struct platform_device imx_ssi_device1;
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