4KiB page OneNAND OOB
Adrian Hunter
adrian.hunter at nokia.com
Thu Jan 27 06:10:03 EST 2011
On 27/01/11 11:59, Kyungmin Park wrote:
> Hi Adrian,
>
> Umm strange, I also got the 4KiB page OneNAND, but it has 4 bytes free from
> 2 at each spare area, So current code is right.
>
> 8011h 10022h Managed by internal ECC logic
> 8012h 10024h Managed by internal ECC logic
>
OK. We have:
8010h 10020h BI
8011h 10022h Managed by Internal ECC logic
8012h 10024h Reserved for the internal use Managed by Internal ECC logic
8013h 10026h 4bit ECC parity values Reserved for the internal use
8014h 10028h 4bit ECC parity values
8015h 1002Ah 4bit ECC parity values
8016h 1002Ch 4bit ECC parity values
8017h 1002Eh 4bit ECC parity values
I will make a patch that will let the board select the 3-byte free option.
> Thank you,
> Kyungmin Park
>
> -----Original Message-----
> From: Adrian Hunter [mailto:adrian.hunter at nokia.com]
> Sent: Thursday, January 27, 2011 6:50 PM
> To: Kyungmin Park; Kyungmin Park
> Cc: linux-mtd Mailing List; Tereshonkov Roman (Nokia-D/Helsinki)
> Subject: 4KiB page OneNAND OOB
>
> Hi
>
> Current onenand_base.c has
>
> /**
> * onenand_oob_128 - oob info for Flex-Onenand with 4KB page
> * For now, we expose only 64 out of 80 ecc bytes
> */
> static struct nand_ecclayout onenand_oob_128 = {
> .eccbytes = 64,
> .eccpos = {
> 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
> 22, 23, 24, 25, 26, 27, 28, 29, 30, 31,
> 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
> 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
> 70, 71, 72, 73, 74, 75, 76, 77, 78, 79,
> 86, 87, 88, 89, 90, 91, 92, 93, 94, 95,
> 102, 103, 104, 105
> },
> .oobfree = {
> {2, 4}, {18, 4}, {34, 4}, {50, 4},
> {66, 4}, {82, 4}, {98, 4}, {114, 4}
> }
> };
>
> but our manual for a 4KiB Samsung OneNAND specifies
> that each 512 byte sector has 16 bytes of OOB
>
> 0-1 bad block info
> 2-3 free
> 5-6 reserved
> 7-15 ecc
>
> which implies ecc layout should be as follows for
> 4KiB pageOneNAND.
>
> /**
> * onenand_oob_128 - oob info for Onenand with 4KB page
> * For now, we expose only 64 out of 72 ecc bytes
> */
> static struct nand_ecclayout onenand_oob_128 = {
> .eccbytes = 64,
> .eccpos = {
> 7, 8, 9, 10, 11, 12, 13, 14, 15,
> 23, 24, 25, 26, 27, 28, 29, 30, 31,
> 39, 40, 41, 42, 43, 44, 45, 46, 47,
> 55, 56, 57, 58, 59, 60, 61, 62, 63,
> 71, 72, 73, 74, 75, 76, 77, 78, 79,
> 87, 88, 89, 90, 91, 92, 93, 94, 95,
> 103, 104, 105, 106, 107, 108, 109, 110, 111,
> 119
> },
> .oobfree = {
> {2, 3}, {18, 3}, {34, 3}, {50, 3},
> {66, 3}, {82, 3}, {98, 3}, {114, 3}
> }
> };
>
> Do 4KiB OneNANDs need a different onenand_oob_128 from
> FlexOneNAND?
>
>
> Regards
> Adrian
>
>
More information about the linux-mtd
mailing list