blob: 1568f39fba8bec5ee2b67e459bf861c62d406d29 [file] [log] [blame]
Uwe Kleine-König66384ee2010-06-15 18:14:19 +02001/*
2 * Copyright (C) 2009-2010 Pengutronix
3 * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de>
4 *
5 * This program is free software; you can redistribute it and/or modify it under
6 * the terms of the GNU General Public License version 2 as published by the
7 * Free Software Foundation.
8 */
9#include <asm/sizes.h>
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020010#include <mach/hardware.h>
Uwe Kleine-König66384ee2010-06-15 18:14:19 +020011#include <mach/devices-common.h>
12
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020013#define imx_mxc_nand_data_entry_single(soc, _size) \
14 { \
15 .iobase = soc ## _NFC_BASE_ADDR, \
16 .iosize = _size, \
17 .irq = soc ## _INT_NFC \
18 }
19
Sascha Hauer63a7c6d2010-08-03 11:59:46 +020020#define imx_mxc_nandv3_data_entry_single(soc, _size) \
21 { \
22 .id = -1, \
23 .iobase = soc ## _NFC_BASE_ADDR, \
24 .iosize = _size, \
25 .axibase = soc ## _NFC_AXI_BASE_ADDR, \
26 .irq = soc ## _INT_NFC \
27 }
28
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020029#ifdef CONFIG_SOC_IMX21
30const struct imx_mxc_nand_data imx21_mxc_nand_data __initconst =
31 imx_mxc_nand_data_entry_single(MX21, SZ_4K);
32#endif /* ifdef CONFIG_SOC_IMX21 */
33
Uwe Kleine-König972cc482010-11-11 18:35:01 +010034#ifdef CONFIG_SOC_IMX25
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020035const struct imx_mxc_nand_data imx25_mxc_nand_data __initconst =
36 imx_mxc_nand_data_entry_single(MX25, SZ_8K);
Uwe Kleine-König972cc482010-11-11 18:35:01 +010037#endif /* ifdef CONFIG_SOC_IMX25 */
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020038
39#ifdef CONFIG_SOC_IMX27
40const struct imx_mxc_nand_data imx27_mxc_nand_data __initconst =
41 imx_mxc_nand_data_entry_single(MX27, SZ_4K);
42#endif /* ifdef CONFIG_SOC_IMX27 */
43
Uwe Kleine-Königa528bc82010-11-12 10:11:42 +010044#ifdef CONFIG_SOC_IMX31
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020045const struct imx_mxc_nand_data imx31_mxc_nand_data __initconst =
46 imx_mxc_nand_data_entry_single(MX31, SZ_4K);
47#endif
48
Uwe Kleine-Königa528bc82010-11-12 10:11:42 +010049#ifdef CONFIG_SOC_IMX35
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020050const struct imx_mxc_nand_data imx35_mxc_nand_data __initconst =
51 imx_mxc_nand_data_entry_single(MX35, SZ_8K);
52#endif
53
Fabio Estevamd94ed122010-11-26 12:25:58 -020054#ifdef CONFIG_SOC_IMX51
Sascha Hauer63a7c6d2010-08-03 11:59:46 +020055const struct imx_mxc_nand_data imx51_mxc_nand_data __initconst =
56 imx_mxc_nandv3_data_entry_single(MX51, SZ_16K);
57#endif
58
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020059struct platform_device *__init imx_add_mxc_nand(
60 const struct imx_mxc_nand_data *data,
61 const struct mxc_nand_platform_data *pdata)
Uwe Kleine-König66384ee2010-06-15 18:14:19 +020062{
Sascha Hauer63a7c6d2010-08-03 11:59:46 +020063 /* AXI has to come first, that's how the mxc_nand driver expect it */
Uwe Kleine-König66384ee2010-06-15 18:14:19 +020064 struct resource res[] = {
65 {
Sascha Hauer63a7c6d2010-08-03 11:59:46 +020066 .start = data->axibase,
67 .end = data->axibase + SZ_16K - 1,
68 .flags = IORESOURCE_MEM,
69 }, {
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020070 .start = data->iobase,
71 .end = data->iobase + data->iosize - 1,
Uwe Kleine-König66384ee2010-06-15 18:14:19 +020072 .flags = IORESOURCE_MEM,
73 }, {
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020074 .start = data->irq,
75 .end = data->irq,
Uwe Kleine-König66384ee2010-06-15 18:14:19 +020076 .flags = IORESOURCE_IRQ,
77 },
78 };
Sascha Hauer63a7c6d2010-08-03 11:59:46 +020079 return imx_add_platform_device("mxc_nand", data->id,
80 res + !data->axibase,
81 ARRAY_SIZE(res) - !data->axibase,
Uwe Kleine-König66384ee2010-06-15 18:14:19 +020082 pdata, sizeof(*pdata));
83}