Commit 7a559c78 authored by Grazvydas Ignotas's avatar Grazvydas Ignotas Committed by Tony Lindgren

omap: cleanup NAND platform data

omap_nand_platform_data fields 'options', 'gpio_irq', 'nand_setup' and
'dma_channel' are never referenced by the NAND driver, yet various
board files are initializing those fields. This is both incorrect and
confusing, so remove them. This allows to get rid of a global
variable in gpmc-nand.c.

This also corrects an issue where some boards are trying to pass NAND
16bit flag through .options, but the driver is using .devsize instead
and ignoring .options.

Finally, .dev_ready is treated as a flag by the driver, so make it bool
instead of a function pointer.
Signed-off-by: default avatarGrazvydas Ignotas <notasas@gmail.com>
Signed-off-by: default avatarTony Lindgren <tony@atomide.com>
parent fd4a0286
...@@ -162,9 +162,7 @@ static struct mtd_partition cm_t35_nand_partitions[] = { ...@@ -162,9 +162,7 @@ static struct mtd_partition cm_t35_nand_partitions[] = {
static struct omap_nand_platform_data cm_t35_nand_data = { static struct omap_nand_platform_data cm_t35_nand_data = {
.parts = cm_t35_nand_partitions, .parts = cm_t35_nand_partitions,
.nr_parts = ARRAY_SIZE(cm_t35_nand_partitions), .nr_parts = ARRAY_SIZE(cm_t35_nand_partitions),
.dma_channel = -1, /* disable DMA in OMAP NAND driver */
.cs = 0, .cs = 0,
}; };
static void __init cm_t35_init_nand(void) static void __init cm_t35_init_nand(void)
......
...@@ -236,7 +236,6 @@ static struct mtd_partition cm_t3517_nand_partitions[] = { ...@@ -236,7 +236,6 @@ static struct mtd_partition cm_t3517_nand_partitions[] = {
static struct omap_nand_platform_data cm_t3517_nand_data = { static struct omap_nand_platform_data cm_t3517_nand_data = {
.parts = cm_t3517_nand_partitions, .parts = cm_t3517_nand_partitions,
.nr_parts = ARRAY_SIZE(cm_t3517_nand_partitions), .nr_parts = ARRAY_SIZE(cm_t3517_nand_partitions),
.dma_channel = -1, /* disable DMA in OMAP NAND driver */
.cs = 0, .cs = 0,
}; };
......
...@@ -132,11 +132,7 @@ static struct gpmc_timings nand_timings = { ...@@ -132,11 +132,7 @@ static struct gpmc_timings nand_timings = {
}; };
static struct omap_nand_platform_data board_nand_data = { static struct omap_nand_platform_data board_nand_data = {
.nand_setup = NULL,
.gpmc_t = &nand_timings, .gpmc_t = &nand_timings,
.dma_channel = -1, /* disable DMA in OMAP NAND driver */
.dev_ready = NULL,
.devsize = 0, /* '0' for 8-bit, '1' for 16-bit device */
}; };
void void
......
...@@ -115,9 +115,7 @@ void __init omap_ads7846_init(int bus_num, int gpio_pendown, int gpio_debounce, ...@@ -115,9 +115,7 @@ void __init omap_ads7846_init(int bus_num, int gpio_pendown, int gpio_debounce,
#endif #endif
#if defined(CONFIG_MTD_NAND_OMAP2) || defined(CONFIG_MTD_NAND_OMAP2_MODULE) #if defined(CONFIG_MTD_NAND_OMAP2) || defined(CONFIG_MTD_NAND_OMAP2_MODULE)
static struct omap_nand_platform_data nand_data = { static struct omap_nand_platform_data nand_data;
.dma_channel = -1, /* disable DMA in OMAP NAND driver */
};
void __init omap_nand_flash_init(int options, struct mtd_partition *parts, void __init omap_nand_flash_init(int options, struct mtd_partition *parts,
int nr_parts) int nr_parts)
...@@ -148,7 +146,7 @@ void __init omap_nand_flash_init(int options, struct mtd_partition *parts, ...@@ -148,7 +146,7 @@ void __init omap_nand_flash_init(int options, struct mtd_partition *parts,
nand_data.cs = nandcs; nand_data.cs = nandcs;
nand_data.parts = parts; nand_data.parts = parts;
nand_data.nr_parts = nr_parts; nand_data.nr_parts = nr_parts;
nand_data.options = options; nand_data.devsize = options;
printk(KERN_INFO "Registering NAND on CS%d\n", nandcs); printk(KERN_INFO "Registering NAND on CS%d\n", nandcs);
if (gpmc_nand_init(&nand_data) < 0) if (gpmc_nand_init(&nand_data) < 0)
......
...@@ -20,8 +20,6 @@ ...@@ -20,8 +20,6 @@
#include <plat/board.h> #include <plat/board.h>
#include <plat/gpmc.h> #include <plat/gpmc.h>
static struct omap_nand_platform_data *gpmc_nand_data;
static struct resource gpmc_nand_resource = { static struct resource gpmc_nand_resource = {
.flags = IORESOURCE_MEM, .flags = IORESOURCE_MEM,
}; };
...@@ -33,7 +31,7 @@ static struct platform_device gpmc_nand_device = { ...@@ -33,7 +31,7 @@ static struct platform_device gpmc_nand_device = {
.resource = &gpmc_nand_resource, .resource = &gpmc_nand_resource,
}; };
static int omap2_nand_gpmc_retime(void) static int omap2_nand_gpmc_retime(struct omap_nand_platform_data *gpmc_nand_data)
{ {
struct gpmc_timings t; struct gpmc_timings t;
int err; int err;
...@@ -83,13 +81,11 @@ static int omap2_nand_gpmc_retime(void) ...@@ -83,13 +81,11 @@ static int omap2_nand_gpmc_retime(void)
return 0; return 0;
} }
int __init gpmc_nand_init(struct omap_nand_platform_data *_nand_data) int __init gpmc_nand_init(struct omap_nand_platform_data *gpmc_nand_data)
{ {
int err = 0; int err = 0;
struct device *dev = &gpmc_nand_device.dev; struct device *dev = &gpmc_nand_device.dev;
gpmc_nand_data = _nand_data;
gpmc_nand_data->nand_setup = omap2_nand_gpmc_retime;
gpmc_nand_device.dev.platform_data = gpmc_nand_data; gpmc_nand_device.dev.platform_data = gpmc_nand_data;
err = gpmc_cs_request(gpmc_nand_data->cs, NAND_IO_SIZE, err = gpmc_cs_request(gpmc_nand_data->cs, NAND_IO_SIZE,
...@@ -100,7 +96,7 @@ int __init gpmc_nand_init(struct omap_nand_platform_data *_nand_data) ...@@ -100,7 +96,7 @@ int __init gpmc_nand_init(struct omap_nand_platform_data *_nand_data)
} }
/* Set timings in GPMC */ /* Set timings in GPMC */
err = omap2_nand_gpmc_retime(); err = omap2_nand_gpmc_retime(gpmc_nand_data);
if (err < 0) { if (err < 0) {
dev_err(dev, "Unable to set gpmc timings: %d\n", err); dev_err(dev, "Unable to set gpmc timings: %d\n", err);
return err; return err;
......
...@@ -19,15 +19,11 @@ enum nand_io { ...@@ -19,15 +19,11 @@ enum nand_io {
}; };
struct omap_nand_platform_data { struct omap_nand_platform_data {
unsigned int options;
int cs; int cs;
int gpio_irq;
struct mtd_partition *parts; struct mtd_partition *parts;
struct gpmc_timings *gpmc_t; struct gpmc_timings *gpmc_t;
int nr_parts; int nr_parts;
int (*nand_setup)(void); bool dev_ready;
int (*dev_ready)(struct omap_nand_platform_data *);
int dma_channel;
int gpmc_irq; int gpmc_irq;
enum nand_io xfer_type; enum nand_io xfer_type;
unsigned long phys_base; unsigned long phys_base;
......
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