Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932354AbbGTRcM (ORCPT ); Mon, 20 Jul 2015 13:32:12 -0400 Received: from mail-pa0-f47.google.com ([209.85.220.47]:35566 "EHLO mail-pa0-f47.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932232AbbGTRcH (ORCPT ); Mon, 20 Jul 2015 13:32:07 -0400 Date: Mon, 20 Jul 2015 10:32:03 -0700 From: Brian Norris To: Ivan Khoronzhuk Cc: dwmw2@infradead.org, santosh.shilimkar@ti.com, grygorii.strashko@ti.com, m-karicheri2@ti.com, linux-mtd@lists.infradead.org, linux-kernel@vger.kernel.org, wsa@the-dreams.de, Hao Zhang Subject: Re: [Patch v2] nand: davinci: add support for 4K page size nand devices Message-ID: <20150720173203.GB24125@google.com> References: <1408451514-4204-1-git-send-email-ivan.khoronzhuk@ti.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1408451514-4204-1-git-send-email-ivan.khoronzhuk@ti.com> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3230 Lines: 93 On Tue, Aug 19, 2014 at 03:31:54PM +0300, Ivan Khoronzhuk wrote: > From: Sandeep Paulraj > > It is needed for k2l keystone2 EVM which uses NAND flash with 4K page > size, hence add support for 4K page size nand devices. > > Signed-off-by: Sandeep Paulraj > Signed-off-by: Ivan Khoronzhuk > --- > > Based on l2-mtd/master > > v1..v2: > - fixed comment style, no functional changes This was resurrected Murali Karicheri. Since this one is nearly identical and much preceded it, I've pushed it to l2-mtd.git. Thanks, Brian > drivers/mtd/nand/davinci_nand.c | 42 ++++++++++++++++++++++++++++++----------- > 1 file changed, 31 insertions(+), 11 deletions(-) > > diff --git a/drivers/mtd/nand/davinci_nand.c b/drivers/mtd/nand/davinci_nand.c > index b922c8e..d7df32c 100644 > --- a/drivers/mtd/nand/davinci_nand.c > +++ b/drivers/mtd/nand/davinci_nand.c > @@ -520,6 +520,32 @@ static struct nand_ecclayout hwecc4_2048 = { > }, > }; > > +/* > + * An ECC layout for using 4-bit ECC with large-page (4096bytes) flash, > + * storing ten ECC bytes plus the manufacturer's bad block marker byte, > + * and not overlapping the default BBT markers. > + */ > +static struct nand_ecclayout hwecc4_4096 = { > + .eccbytes = 80, > + .eccpos = { > + /* at the end of spare sector */ > + 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, > + 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, > + 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, > + 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, > + 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, > + 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, > + 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, > + 118, 119, 120, 121, 122, 123, 124, 125, 126, 127, > + }, > + .oobfree = { > + /* 2 bytes at offset 0 hold manufacturer badblock markers */ > + {.offset = 2, .length = 46, }, > + /* 5 bytes at offset 8 hold BBT markers */ > + /* 8 bytes at offset 16 hold JFFS2 clean markers */ > + }, > +}; > + > #if defined(CONFIG_OF) > static const struct of_device_id davinci_nand_of_match[] = { > {.compatible = "ti,davinci-nand", }, > @@ -796,18 +822,12 @@ static int nand_davinci_probe(struct platform_device *pdev) > info->chip.ecc.mode = NAND_ECC_HW_OOB_FIRST; > goto syndrome_done; > } > + if (chunks == 8) { > + info->ecclayout = hwecc4_4096; > + info->chip.ecc.mode = NAND_ECC_HW_OOB_FIRST; > + goto syndrome_done; > + } > > - /* 4KiB page chips are not yet supported. The eccpos from > - * nand_ecclayout cannot hold 80 bytes and change to eccpos[] > - * breaks userspace ioctl interface with mtd-utils. Once we > - * resolve this issue, NAND_ECC_HW_OOB_FIRST mode can be used > - * for the 4KiB page chips. > - * > - * TODO: Note that nand_ecclayout has now been expanded and can > - * hold plenty of OOB entries. > - */ > - dev_warn(&pdev->dev, "no 4-bit ECC support yet " > - "for 4KiB-page NAND\n"); > ret = -EIO; > goto err; > > -- > 1.8.3.2 > -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/