[PATCH v3] mtd/gpmi : add BBT support to gpmi nand driver
Marek Vasut
marek.vasut at gmail.com
Tue Jan 31 06:34:52 EST 2012
> Add a new field to gpmi_nand_platform_data{}.
> Make the BBT support to board specific.
>
> Signed-off-by: Huang Shijie <b32955 at freescale.com>
> ---
> drivers/mtd/nand/gpmi-nand/gpmi-nand.c | 2 ++
> include/linux/mtd/gpmi-nand.h | 2 ++
> 2 files changed, 4 insertions(+), 0 deletions(-)
>
> diff --git a/drivers/mtd/nand/gpmi-nand/gpmi-nand.c
> b/drivers/mtd/nand/gpmi-nand/gpmi-nand.c index 493ec2f..4d369df 100644
> --- a/drivers/mtd/nand/gpmi-nand/gpmi-nand.c
> +++ b/drivers/mtd/nand/gpmi-nand/gpmi-nand.c
> @@ -1493,6 +1493,8 @@ static int __devinit gpmi_nfc_init(struct
> gpmi_nand_data *this) chip->ecc.mode = NAND_ECC_HW;
> chip->ecc.size = 1;
> chip->ecc.layout = &gpmi_hw_ecclayout;
> + if (pdata->enable_bbt)
> + chip->bbt_options = NAND_BBT_USE_FLASH | NAND_BBT_NO_OOB;
>
> /* Allocate a temporary DMA buffer for reading ID in the nand_scan() */
> this->bch_geometry.payload_size = 1024;
> diff --git a/include/linux/mtd/gpmi-nand.h b/include/linux/mtd/gpmi-nand.h
> index 69b6dbf..04ab366 100644
> --- a/include/linux/mtd/gpmi-nand.h
> +++ b/include/linux/mtd/gpmi-nand.h
> @@ -51,6 +51,7 @@
> * @partitions: An optional pointer to an array of partition
> * descriptions.
> * @partition_count: The number of elements in the partitions
> array. + * @enable_bbt: Enable the BBT or not.
> */
> struct gpmi_nand_platform_data {
> /* SoC hardware information. */
> @@ -64,5 +65,6 @@ struct gpmi_nand_platform_data {
> /* Medium information. */
> struct mtd_partition *partitions;
> unsigned partition_count;
> + unsigned int enable_bbt:1;
> };
> #endif
Hi, we also need one more fix here /wrt subpage writes,
See: "GPMI-NAND: Wrong ECC size in driver" email.
Otherwise, this seems ok.
M
More information about the linux-arm-kernel
mailing list