]>
Commit | Line | Data |
---|---|---|
bdfd59aa WJ |
1 | How to enable PMECC(Programmable Multibit ECC) for nand on Atmel SoCs |
2 | ----------------------------------------------------------- | |
3 | 2012-08-22 Josh Wu <[email protected]> | |
4 | ||
5 | The Programmable Multibit ECC (PMECC) controller is a programmable binary | |
6 | BCH(Bose, Chaudhuri and Hocquenghem) encoder and decoder. This controller | |
7 | can be used to support both SLC and MLC NAND Flash devices. It supports to | |
8 | generate ECC to correct 2, 4, 8, 12 or 24 bits of error per sector (512 or | |
9 | 1024 bytes) of data. | |
10 | ||
11 | Following Atmel AT91 products support PMECC. | |
12 | - AT91SAM9X25, X35, G25, G15, G35 (tested) | |
13 | - AT91SAM9N12 (not tested, Should work) | |
14 | ||
15 | As soon as your nand flash software ECC works, you can enable PMECC. | |
16 | ||
17 | To use PMECC in this driver, the user needs to set: | |
18 | 1. the PMECC correction error bits capability: CONFIG_PMECC_CAP. | |
19 | It can be 2, 4, 8, 12 or 24. | |
20 | 2. The PMECC sector size: CONFIG_PMECC_SECTOR_SIZE. | |
21 | It only can be 512 or 1024. | |
bdfd59aa | 22 | |
49ad4029 DW |
23 | Take 'configs/at91sam9x5ek_nandflash_defconfig' as an example, the board |
24 | configuration file has the following entries: | |
bdfd59aa | 25 | |
49ad4029 DW |
26 | CONFIG_PMECC_CAP=2 |
27 | CONFIG_PMECC_SECTOR_SIZE=512 | |
28 | CONFIG_SPL_GENERATE_ATMEL_PMECC_HEADER=y | |
5c390a5b AB |
29 | |
30 | How to enable PMECC header for direct programmable boot.bin | |
31 | ----------------------------------------------------------- | |
09c2b8f3 | 32 | 2014-05-19 Andreas Bießmann <[email protected]> |
5c390a5b AB |
33 | |
34 | The usual way to program SPL into NAND flash is to use the SAM-BA Atmel tool. | |
35 | This however is often not usable when doing field updates. To be able to | |
36 | program a SPL binary into NAND flash we need to add the PMECC header to the | |
37 | binary before. Chapter '12.4.4.1 NAND Flash Boot: NAND Flash Detection' in | |
38 | sama5d3 SoC spec (as of 03. April 2014) defines how this PMECC header has to | |
39 | look like. In order to do so we have a new image type added to mkimage to | |
40 | generate this PMECC header and integrated this into the build process of SPL. | |
41 | ||
49ad4029 | 42 | To enable the generation of atmel PMECC header for SPL one needs to define |
5c390a5b AB |
43 | CONFIG_SPL_GENERATE_ATMEL_PMECC_HEADER. The required parameters are taken from |
44 | board configuration and compiled into the host tools atmel_pmecc_params. This | |
45 | tool will be called in build process to parametrize mkimage for atmelimage | |
46 | type. The mkimage tool has intentionally _not_ compiled in those parameters. | |
47 | ||
48 | The mkimage image type atmelimage also set the 6'th interrupt vector to the | |
49 | correct value. This feature can also be used to setup a boot.bin for MMC boot. |