blob: 24aaad1a58c9e32ef1ab0a69391ceb3abb36f1b3 [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>
Shawn Guoe0557c02012-09-13 15:51:15 +080011#include "devices-common.h"
Uwe Kleine-König66384ee2010-06-15 18:14:19 +020012
Shawn Guo4d624352012-09-15 13:34:09 +080013#define imx_mxc_nand_data_entry_single(soc, _devid, _size) \
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020014 { \
Shawn Guo4d624352012-09-15 13:34:09 +080015 .devid = _devid, \
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020016 .iobase = soc ## _NFC_BASE_ADDR, \
17 .iosize = _size, \
18 .irq = soc ## _INT_NFC \
19 }
20
Shawn Guo4d624352012-09-15 13:34:09 +080021#define imx_mxc_nandv3_data_entry_single(soc, _devid, _size) \
Sascha Hauer63a7c6d2010-08-03 11:59:46 +020022 { \
Shawn Guo4d624352012-09-15 13:34:09 +080023 .devid = _devid, \
Sascha Hauer63a7c6d2010-08-03 11:59:46 +020024 .id = -1, \
25 .iobase = soc ## _NFC_BASE_ADDR, \
26 .iosize = _size, \
27 .axibase = soc ## _NFC_AXI_BASE_ADDR, \
28 .irq = soc ## _INT_NFC \
29 }
30
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020031#ifdef CONFIG_SOC_IMX21
32const struct imx_mxc_nand_data imx21_mxc_nand_data __initconst =
Shawn Guo4d624352012-09-15 13:34:09 +080033 imx_mxc_nand_data_entry_single(MX21, "imx21-nand", SZ_4K);
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020034#endif /* ifdef CONFIG_SOC_IMX21 */
35
Uwe Kleine-König972cc482010-11-11 18:35:01 +010036#ifdef CONFIG_SOC_IMX25
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020037const struct imx_mxc_nand_data imx25_mxc_nand_data __initconst =
Shawn Guo4d624352012-09-15 13:34:09 +080038 imx_mxc_nand_data_entry_single(MX25, "imx25-nand", SZ_8K);
Uwe Kleine-König972cc482010-11-11 18:35:01 +010039#endif /* ifdef CONFIG_SOC_IMX25 */
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020040
41#ifdef CONFIG_SOC_IMX27
42const struct imx_mxc_nand_data imx27_mxc_nand_data __initconst =
Shawn Guo4d624352012-09-15 13:34:09 +080043 imx_mxc_nand_data_entry_single(MX27, "imx27-nand", SZ_4K);
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020044#endif /* ifdef CONFIG_SOC_IMX27 */
45
Uwe Kleine-Königa528bc82010-11-12 10:11:42 +010046#ifdef CONFIG_SOC_IMX31
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020047const struct imx_mxc_nand_data imx31_mxc_nand_data __initconst =
Shawn Guo4d624352012-09-15 13:34:09 +080048 imx_mxc_nand_data_entry_single(MX31, "imx27-nand", SZ_4K);
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020049#endif
50
Uwe Kleine-Königa528bc82010-11-12 10:11:42 +010051#ifdef CONFIG_SOC_IMX35
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020052const struct imx_mxc_nand_data imx35_mxc_nand_data __initconst =
Shawn Guo4d624352012-09-15 13:34:09 +080053 imx_mxc_nand_data_entry_single(MX35, "imx25-nand", SZ_8K);
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020054#endif
55
Fabio Estevamd94ed122010-11-26 12:25:58 -020056#ifdef CONFIG_SOC_IMX51
Sascha Hauer63a7c6d2010-08-03 11:59:46 +020057const struct imx_mxc_nand_data imx51_mxc_nand_data __initconst =
Shawn Guo4d624352012-09-15 13:34:09 +080058 imx_mxc_nandv3_data_entry_single(MX51, "imx51-nand", SZ_16K);
Sascha Hauer63a7c6d2010-08-03 11:59:46 +020059#endif
60
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020061struct platform_device *__init imx_add_mxc_nand(
62 const struct imx_mxc_nand_data *data,
63 const struct mxc_nand_platform_data *pdata)
Uwe Kleine-König66384ee2010-06-15 18:14:19 +020064{
Sascha Hauer63a7c6d2010-08-03 11:59:46 +020065 /* AXI has to come first, that's how the mxc_nand driver expect it */
Uwe Kleine-König66384ee2010-06-15 18:14:19 +020066 struct resource res[] = {
67 {
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020068 .start = data->iobase,
69 .end = data->iobase + data->iosize - 1,
Uwe Kleine-König66384ee2010-06-15 18:14:19 +020070 .flags = IORESOURCE_MEM,
71 }, {
Uwe Kleine-König00b57bf2010-08-23 11:25:52 +020072 .start = data->irq,
73 .end = data->irq,
Uwe Kleine-König66384ee2010-06-15 18:14:19 +020074 .flags = IORESOURCE_IRQ,
Sascha Hauer71885b62012-06-06 12:33:14 +020075 }, {
76 .start = data->axibase,
77 .end = data->axibase + SZ_16K - 1,
78 .flags = IORESOURCE_MEM,
Uwe Kleine-König66384ee2010-06-15 18:14:19 +020079 },
80 };
Shawn Guo4d624352012-09-15 13:34:09 +080081 return imx_add_platform_device(data->devid, data->id,
Sascha Hauer71885b62012-06-06 12:33:14 +020082 res, ARRAY_SIZE(res) - !data->axibase,
Uwe Kleine-König66384ee2010-06-15 18:14:19 +020083 pdata, sizeof(*pdata));
84}