[U-Boot] [PATCH] fsmc: Skip BBT scan for bad block management

Scott Wood scottwood at freescale.com
Sat Dec 8 01:18:41 CET 2012


On 12/06/2012 10:38:32 PM, Vipin Kumar wrote:
> On 12/7/2012 12:57 AM, Scott Wood wrote:
>> On 12/06/2012 01:21:28 AM, Vipin Kumar wrote:
>>> This patch forces to read the bad block marker from location 0 in
>>> large page
>>> nand devices and location 5 in small page devices.
>>> 
>>> Signed-off-by: Vipin Kumar<vipin.kumar at st.com>
>>> Reviewed-by: Shiraz Hashim<shiraz.hashim at st.com>
>>> ---
>>>   drivers/mtd/nand/fsmc_nand.c | 2 +-
>>>   1 file changed, 1 insertion(+), 1 deletion(-)
>>> 
>>> diff --git a/drivers/mtd/nand/fsmc_nand.c
>>> b/drivers/mtd/nand/fsmc_nand.c
>>> index 7a61d88..bce4298 100644
>>> --- a/drivers/mtd/nand/fsmc_nand.c
>>> +++ b/drivers/mtd/nand/fsmc_nand.c
>>> @@ -433,7 +433,7 @@ int fsmc_nand_init(struct nand_chip *nand)
>>>   	writel(FSMC_THIZ_1 | FSMC_THOLD_4 | FSMC_TWAIT_6 | FSMC_TSET_0,
>>>   			&fsmc_regs_p->attrib);
>>> 
>>> -	nand->options = 0;
>>> +	nand->options = NAND_SKIP_BBTSCAN;
>>>   #if defined(CONFIG_SYS_FSMC_NAND_16BIT)
>>>   	nand->options |= NAND_BUSWIDTH_16;
>>>   #endif
>> 
>> I don't think this will change the bad block marker behavior -- just
>> whether you use a BBT.  Why do you need this?  Why not
>> NAND_USE_FLASH_BBT instead?
>> 
> 
> It's because the BootROM which is fused in the device itself (ie  
> non-modifiable) is going to read the bad block markers from the oob  
> area.
> 
> Which means that anything written via u-boot is non-readable if it  
> uses flash bbt

The factory bad block markers will still be there.  The BBT is based on  
those markers, so you'll still avoid them when writing your boot  
image.  So I don't follow why you're having trouble with your current  
settings.  The main difference that NAND_SKIP_BBTSCAN makes is whether  
you scan for bad blocks up front, or whether you check each block on  
demand (and don't cache the results for next time).

Is your concern blocks that get marked bad later on -- not by the  
factory?  In that case, you're still writing real bad block markers  
with "nand->options = 0".  It's only when you specify  
NAND_USE_FLASH_BBT that you'll be updating an on-flash BBT instead of  
writing bad block markers.

Do you really expect to be marking blocks bad in your boot image?   
Normally that happens as part of a filesystem (or block management  
layer such as ubi) that does active bad-block management.

BTW, I've found an on-chip BBT to be nice during development.  A bug in  
the NAND driver can cause the filesystem to mark every block as bad.   
If you wipe the BBT, you still keep the factory bad block information.   
If you have to scrub everything, you lose that.

-Scott


More information about the U-Boot mailing list