On 08/19/2011 03:57 AM, Matthieu CASTET wrote: > LiuShuo a écrit : >> 于 2011年08月19日 01:00, Matthieu CASTET 写道: >>> b35...@freescale.com a écrit : >>>> From: Liu Shuo<b35...@freescale.com> >>>> >>>> Freescale FCM controller has a 2K size limitation of buffer RAM. In order >>>> to support the Nand flash chip whose page size is larger than 2K bytes, >>>> we divide a page into multi-2K pages for MTD layer driver. In that case, >>>> we force to set the page size to 2K bytes. We convert the page address of >>>> MTD layer driver to a real page address in flash chips and a column index >>>> in fsl_elbc driver. We can issue any column address by UA instruction of >>>> elbc controller. >>>> >>> Why do you need to do that ? >>> >>> When mtd send you a 4k page, why can't you write it by 2*2k pages write ? >> 1. It's easy to implement. >> 2. We don't need to move the data in buffer more times, because we >> want to use the HW_ECC. >> >> In flash chip per Page: >> ---------------------------------------------------------------- >> | first data | first oob | second data | second oob | >> ---------------------------------------------------------------- > How the bad block marker are handled with this remapping ?
It has to be migrated prior to first use (this needs to be documented, and ideally a U-Boot command provided do do this), or else special handling would be needed when building the BBT. The only way around this would be to do ECC in software, and do the buffering needed to let MTD treat it as a 4K chip. -Scott _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev