mirror of
https://github.com/smaeul/u-boot.git
synced 2025-10-24 01:28:15 +01:00
The Programmable Multibit ECC (PMECC) controller is a programmable binary BCH(Bose, Chaudhuri and Hocquenghem) encoder and decoder. This controller can be used to support both SLC and MLC NAND Flash devices. It supports to generate ECC to correct 2, 4, 8, 12 or 24 bits of error per sector of data. To use PMECC in this driver, the user needs to set the PMECC correction capability, the sector size and ROM lookup table offsets in board config file. This driver is ported from Linux kernel atmel_nand PMECC patch. The main difference is in this version it uses registers structure access hardware instead of using macros. It is tested in 9x5 serial boards. Signed-off-by: Josh Wu <josh.wu@atmel.com> [rebase] Signed-off-by: Andreas Bießmann <andreas.devel@googlemail.com>
45 lines
1.9 KiB
Plaintext
45 lines
1.9 KiB
Plaintext
How to enable PMECC(Programmable Multibit ECC) for nand on Atmel SoCs
|
|
-----------------------------------------------------------
|
|
2012-08-22 Josh Wu <josh.wu@atmel.com>
|
|
|
|
The Programmable Multibit ECC (PMECC) controller is a programmable binary
|
|
BCH(Bose, Chaudhuri and Hocquenghem) encoder and decoder. This controller
|
|
can be used to support both SLC and MLC NAND Flash devices. It supports to
|
|
generate ECC to correct 2, 4, 8, 12 or 24 bits of error per sector (512 or
|
|
1024 bytes) of data.
|
|
|
|
Following Atmel AT91 products support PMECC.
|
|
- AT91SAM9X25, X35, G25, G15, G35 (tested)
|
|
- AT91SAM9N12 (not tested, Should work)
|
|
|
|
As soon as your nand flash software ECC works, you can enable PMECC.
|
|
|
|
To use PMECC in this driver, the user needs to set:
|
|
1. the PMECC correction error bits capability: CONFIG_PMECC_CAP.
|
|
It can be 2, 4, 8, 12 or 24.
|
|
2. The PMECC sector size: CONFIG_PMECC_SECTOR_SIZE.
|
|
It only can be 512 or 1024.
|
|
3. The PMECC index lookup table's offsets in ROM code: CONFIG_PMECC_INDEX_TABLE_OFFSET.
|
|
In the chip datasheet section "Boot Stragegies", you can find
|
|
two Galois Field Table in the ROM code. One table is for 512-bytes
|
|
sector. Another is for 1024-byte sector. Each Galois Field includes
|
|
two sub-table: indext table & alpha table.
|
|
In the beginning of each Galois Field Table is the index table,
|
|
Alpha table is in the following.
|
|
So the index table's offset is same as the Galois Field Table.
|
|
|
|
Please set CONFIG_PMECC_INDEX_TABLE_OFFSET correctly according the
|
|
Galois Field Table's offset base on the sector size you used.
|
|
|
|
Take AT91SAM9X5EK as an example, the board definition file likes:
|
|
|
|
/* PMECC & PMERRLOC */
|
|
#define CONFIG_ATMEL_NAND_HWECC 1
|
|
#define CONFIG_ATMEL_NAND_HW_PMECC 1
|
|
#define CONFIG_PMECC_CAP 2
|
|
#define CONFIG_PMECC_SECTOR_SIZE 512
|
|
#define CONFIG_PMECC_INDEX_TABLE_OFFSET 0x8000
|
|
|
|
NOTE: If you use 1024 as the sector size, then need set 0x10000 as the
|
|
CONFIG_PMECC_INDEX_TABLE_OFFSET
|