Commit 7576594c authored by Miquel Raynal's avatar Miquel Raynal Committed by Boris Brezillon

mtd: nand: remove useless fields from pxa3xx NAND platform data

The "enable arbiter" bit is available only for pxa3xx based platforms
but it was experimentally shown that even if this bit is reserved,
some Marvell platforms (64-bit) actually need it to be set. The driver
always set this bit regardless of this property, which is harmless.
Then this property is not needed.

The "num_cs" field is always 1 and for a good reason, the old driver
(pxa3xx_nand.c) could only handle one. The new driver that replaces it
(marvell_nand.c) can handle more, but better use device tree for such
description. As there is only one available chip select, there is no
need for an array of partitions neither an array of partition numbers.
Signed-off-by: default avatarMiquel Raynal <miquel.raynal@bootlin.com>
Acked-by: default avatarRobert Jarzmik <robert.jarzmik@free.fr>
Signed-off-by: default avatarBoris Brezillon <boris.brezillon@bootlin.com>
parent cc396436
...@@ -172,10 +172,8 @@ static struct mtd_partition aspenite_nand_partitions[] = { ...@@ -172,10 +172,8 @@ static struct mtd_partition aspenite_nand_partitions[] = {
}; };
static struct pxa3xx_nand_platform_data aspenite_nand_info = { static struct pxa3xx_nand_platform_data aspenite_nand_info = {
.enable_arbiter = 1, .parts = aspenite_nand_partitions,
.num_cs = 1, .nr_parts = ARRAY_SIZE(aspenite_nand_partitions),
.parts[0] = aspenite_nand_partitions,
.nr_parts[0] = ARRAY_SIZE(aspenite_nand_partitions),
}; };
static struct i2c_board_info aspenite_i2c_info[] __initdata = { static struct i2c_board_info aspenite_i2c_info[] __initdata = {
......
...@@ -179,10 +179,7 @@ static struct mv_usb_platform_data ttc_usb_pdata = { ...@@ -179,10 +179,7 @@ static struct mv_usb_platform_data ttc_usb_pdata = {
#endif #endif
#if IS_ENABLED(CONFIG_MTD_NAND_MARVELL) #if IS_ENABLED(CONFIG_MTD_NAND_MARVELL)
static struct pxa3xx_nand_platform_data dkb_nand_info = { static struct pxa3xx_nand_platform_data dkb_nand_info = {};
.enable_arbiter = 1,
.num_cs = 1,
};
#endif #endif
#if IS_ENABLED(CONFIG_MMP_DISP) #if IS_ENABLED(CONFIG_MMP_DISP)
......
...@@ -429,11 +429,9 @@ static struct mtd_partition cm_x300_nand_partitions[] = { ...@@ -429,11 +429,9 @@ static struct mtd_partition cm_x300_nand_partitions[] = {
}; };
static struct pxa3xx_nand_platform_data cm_x300_nand_info = { static struct pxa3xx_nand_platform_data cm_x300_nand_info = {
.enable_arbiter = 1,
.keep_config = 1, .keep_config = 1,
.num_cs = 1, .parts = cm_x300_nand_partitions,
.parts[0] = cm_x300_nand_partitions, .nr_parts = ARRAY_SIZE(cm_x300_nand_partitions),
.nr_parts[0] = ARRAY_SIZE(cm_x300_nand_partitions),
}; };
static void __init cm_x300_init_nand(void) static void __init cm_x300_init_nand(void)
......
...@@ -138,11 +138,9 @@ static struct mtd_partition colibri_nand_partitions[] = { ...@@ -138,11 +138,9 @@ static struct mtd_partition colibri_nand_partitions[] = {
}; };
static struct pxa3xx_nand_platform_data colibri_nand_info = { static struct pxa3xx_nand_platform_data colibri_nand_info = {
.enable_arbiter = 1,
.keep_config = 1, .keep_config = 1,
.num_cs = 1, .parts = colibri_nand_partitions,
.parts[0] = colibri_nand_partitions, .nr_parts = ARRAY_SIZE(colibri_nand_partitions),
.nr_parts[0] = ARRAY_SIZE(colibri_nand_partitions),
}; };
void __init colibri_pxa3xx_init_nand(void) void __init colibri_pxa3xx_init_nand(void)
......
...@@ -329,10 +329,8 @@ static struct mtd_partition littleton_nand_partitions[] = { ...@@ -329,10 +329,8 @@ static struct mtd_partition littleton_nand_partitions[] = {
}; };
static struct pxa3xx_nand_platform_data littleton_nand_info = { static struct pxa3xx_nand_platform_data littleton_nand_info = {
.enable_arbiter = 1, .parts = littleton_nand_partitions,
.num_cs = 1, .nr_parts = ARRAY_SIZE(littleton_nand_partitions),
.parts[0] = littleton_nand_partitions,
.nr_parts[0] = ARRAY_SIZE(littleton_nand_partitions),
}; };
static void __init littleton_init_nand(void) static void __init littleton_init_nand(void)
......
...@@ -389,11 +389,9 @@ static struct mtd_partition mxm_8x10_nand_partitions[] = { ...@@ -389,11 +389,9 @@ static struct mtd_partition mxm_8x10_nand_partitions[] = {
}; };
static struct pxa3xx_nand_platform_data mxm_8x10_nand_info = { static struct pxa3xx_nand_platform_data mxm_8x10_nand_info = {
.enable_arbiter = 1,
.keep_config = 1, .keep_config = 1,
.num_cs = 1, .parts = mxm_8x10_nand_partitions,
.parts[0] = mxm_8x10_nand_partitions, .nr_parts = ARRAY_SIZE(mxm_8x10_nand_partitions)
.nr_parts[0] = ARRAY_SIZE(mxm_8x10_nand_partitions)
}; };
static void __init mxm_8x10_nand_init(void) static void __init mxm_8x10_nand_init(void)
......
...@@ -346,11 +346,9 @@ static struct mtd_partition raumfeld_nand_partitions[] = { ...@@ -346,11 +346,9 @@ static struct mtd_partition raumfeld_nand_partitions[] = {
}; };
static struct pxa3xx_nand_platform_data raumfeld_nand_info = { static struct pxa3xx_nand_platform_data raumfeld_nand_info = {
.enable_arbiter = 1,
.keep_config = 1, .keep_config = 1,
.num_cs = 1, .parts = raumfeld_nand_partitions,
.parts[0] = raumfeld_nand_partitions, .nr_parts = ARRAY_SIZE(raumfeld_nand_partitions),
.nr_parts[0] = ARRAY_SIZE(raumfeld_nand_partitions),
}; };
/** /**
......
...@@ -376,10 +376,8 @@ static struct mtd_partition zylonite_nand_partitions[] = { ...@@ -376,10 +376,8 @@ static struct mtd_partition zylonite_nand_partitions[] = {
}; };
static struct pxa3xx_nand_platform_data zylonite_nand_info = { static struct pxa3xx_nand_platform_data zylonite_nand_info = {
.enable_arbiter = 1, .parts = zylonite_nand_partitions,
.num_cs = 1, .nr_parts = ARRAY_SIZE(zylonite_nand_partitions),
.parts[0] = zylonite_nand_partitions,
.nr_parts[0] = ARRAY_SIZE(zylonite_nand_partitions),
}; };
static void __init zylonite_init_nand(void) static void __init zylonite_init_nand(void)
......
...@@ -2520,8 +2520,7 @@ static int marvell_nand_chip_init(struct device *dev, struct marvell_nfc *nfc, ...@@ -2520,8 +2520,7 @@ static int marvell_nand_chip_init(struct device *dev, struct marvell_nfc *nfc,
if (pdata) if (pdata)
/* Legacy bindings support only one chip */ /* Legacy bindings support only one chip */
ret = mtd_device_register(mtd, pdata->parts[0], ret = mtd_device_register(mtd, pdata->parts, pdata->nr_parts);
pdata->nr_parts[0]);
else else
ret = mtd_device_register(mtd, NULL, 0); ret = mtd_device_register(mtd, NULL, 0);
if (ret) { if (ret) {
......
...@@ -6,41 +6,22 @@ ...@@ -6,41 +6,22 @@
#include <linux/mtd/partitions.h> #include <linux/mtd/partitions.h>
/* /*
* Current pxa3xx_nand controller has two chip select which * Current pxa3xx_nand controller has two chip select which both be workable but
* both be workable. * historically all platforms remaining on platform data used only one. Switch
* * to device tree if you need more.
* Notice should be taken that:
* When you want to use this feature, you should not enable the
* keep configuration feature, for two chip select could be
* attached with different nand chip. The different page size
* and timing requirement make the keep configuration impossible.
*/ */
/* The max num of chip select current support */
#define NUM_CHIP_SELECT (2)
struct pxa3xx_nand_platform_data { struct pxa3xx_nand_platform_data {
/* Keep OBM/bootloader NFC timing configuration */
/* the data flash bus is shared between the Static Memory bool keep_config;
* Controller and the Data Flash Controller, the arbiter /* Use a flash-based bad block table */
* controls the ownership of the bus
*/
int enable_arbiter;
/* allow platform code to keep OBM/bootloader defined NFC config */
int keep_config;
/* indicate how many chip selects will be used */
int num_cs;
/* use an flash-based bad block table */
bool flash_bbt; bool flash_bbt;
/* Requested ECC strength and ECC step size */
/* requested ECC strength and ECC step size */
int ecc_strength, ecc_step_size; int ecc_strength, ecc_step_size;
/* Partitions */
const struct mtd_partition *parts[NUM_CHIP_SELECT]; const struct mtd_partition *parts;
unsigned int nr_parts[NUM_CHIP_SELECT]; unsigned int nr_parts;
}; };
extern void pxa3xx_set_nand_info(struct pxa3xx_nand_platform_data *info); extern void pxa3xx_set_nand_info(struct pxa3xx_nand_platform_data *info);
#endif /* __ASM_ARCH_PXA3XX_NAND_H */ #endif /* __ASM_ARCH_PXA3XX_NAND_H */
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