public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
From: Scott Wood <scottwood@freescale.com>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH] fsmc: Skip BBT scan for bad block management
Date: Fri, 7 Dec 2012 18:18:41 -0600	[thread overview]
Message-ID: <1354925921.23313.0@snotra> (raw)
In-Reply-To: <50C172C8.3050202@st.com> (from vipin.kumar@st.com on Thu Dec 6 22:38:32 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@st.com>
>>> Reviewed-by: Shiraz Hashim<shiraz.hashim@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

      reply	other threads:[~2012-12-08  0:18 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-12-06  7:21 [U-Boot] [PATCH] fsmc: Skip BBT scan for bad block management Vipin Kumar
2012-12-06 19:27 ` Scott Wood
2012-12-07  4:38   ` Vipin Kumar
2012-12-08  0:18     ` Scott Wood [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1354925921.23313.0@snotra \
    --to=scottwood@freescale.com \
    --cc=u-boot@lists.denx.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox