public inbox for linux-mtd@lists.infradead.org
 help / color / mirror / Atom feed
From: Miquel RAYNAL <miquel.raynal@free-electrons.com>
To: "Sean Nyekjær" <sean.nyekjaer@prevas.dk>
Cc: <ezequiel.garcia@free-electrons.com>,
	<linux-mtd@lists.infradead.org>,
	"Kasper Revsbech (KREV)" <krev@triax.com>,
	Boris Brezillon <Boris.Brezillon@free-electrons.com>
Subject: Re: [BUG] pxa3xx: wait time out when scanning for bb
Date: Mon, 11 Dec 2017 15:09:29 +0100	[thread overview]
Message-ID: <20171211150929.722a361a@xps13> (raw)
In-Reply-To: <20171211150200.51c7f3b4@xps13>

On Mon, 11 Dec 2017 15:02:00 +0100
Miquel RAYNAL <miquel.raynal@free-electrons.com> wrote:

> On Mon, 11 Dec 2017 14:22:18 +0100
> Sean Nyekjær <sean.nyekjaer@prevas.dk> wrote:
> 
> > Hi Miquel,  
> > >>> Actually, if you look carefully to the trace behind, you are not
> > >>> using the same bad block table with the bootloader ("Bad block
> > >>> table not found for chip 0") so the core then reads the OOB area
> > >>> of every first page for each block and looks at the first OOB
> > >>> bytes for the bad block markers. If there was data there, the
> > >>> block will be declared as bad.    
> > >> With the new NFC driver, is the bad block table located
> > >> elsewhere? I have not done any changes to my bootloader when i
> > >> did the switch to the new driver,
> > >> so i guess it should work as before.    
> > >>> Can you please check that by using the configuration that
> > >>> actually boots and use nanddump in raw mode with the OOB area
> > >>> (options -n and -o)
> > >>> to show us the content of the first page of any block of the
> > >>> last NAND MTD device?
> > >>>
> > >>>    
> > >> Will do
> > >>    
> > > Dumped from uboot:    
> > > => nand dump.oob 0xffc0000    
> > > Page 0ffc0000 dump:
> > > OOB:
> > >         ff ff ff ff ff ff ff ff
> > >         31 74 62 42 56 4d 01 ff
> > >         ff ff ff ff ff ff ff ff
> > >         ff ff ff ff ff ff ff ff
> > >         ff ff ff ff ff ff ff ff
> > >         ff ff ff ff ff ff ff ff
> > >         ff ff ff ff ff ff ff ff
> > >         ff ff ff ff ff ff ff ff    
> > > => nand dump.oob 0xffe0000    
> > > Page 0ffe0000 dump:
> > > OOB:
> > >         ff ff ff ff ff ff ff ff
> > >         4d 56 42 62 74 30 01 ff
> > >         ff ff ff ff ff ff ff ff
> > >         ff ff ff ff ff ff ff ff
> > >         ff ff ff ff ff ff ff ff
> > >         ff ff ff ff ff ff ff ff
> > >         ff ff ff ff ff ff ff ff
> > >         ff ff ff ff ff ff ff ff
> > >
> > > I have tried to dump some random pages, and they all contain
> > > 0xFF's. I'll try to trace what the NFC driver is reading from the
> > > OOBs. 
> > What function is called in the marvel_nand.c driver here [1].
> >  From my tracing i can see:
> > mtd->_read_oob(mtd, from, ops);  
> > ->    marvell_nfc_hw_ecc_bch_read_oob
> > ->        marvell_nfc_hw_ecc_bch_read_page    
> > marvell_nfc_hw_ecc_bch_read_page is returning 0 (bitflips)
> > But the mtd->_read_oob is returning -74.  
> 
> This means the hardware detected an ECC error (and the page was not
> empty).
> 
> > 
> > Some of the tracing:
> > [    2.947220] Scanning device for bad blocks
> > [    2.951334] mtd_read_oob
> > [    2.953874] marvell_nfc_hw_ecc_bch_read_oob
> > [    2.958393] marvell_nfc_hw_ecc_bch_read_page: max_bitflips: 0,
> > page 0x0 [    2.965034] marvell_nfc_hw_ecc_bch_read_oob: returns 0
> > [    2.970194] mtd_read_oob: ret_code -74
> > [    2.983669] Bad eraseblock 0 at 0x000000000000  
> 
> This behavior is "normal", it is because the number of failure has
> been incremented (probably by marvell_nfc_hw_ecc_correct()).
> 
> 
> Can you hack the code right before this line [1] and add:
> 1/ A dump of both the data buffer and the oob buffer (entirely)
> 2/ Add a memset(mtd->oob_poi, 0xff, mtd->oobsize) conditionally until
> the probe is finished (you may want to add a global boolean value that
> changes its state after the nand_scan_tail() call).

Instead of hacking this way, to boot until you get a prompt, you may
add this property to the nand controller node:

nand-ecc-mode = "none";

Then please use nanddump over a programmed page, including the OOB area.


> 
> Then please do a raw dump with nanddump from Linux.
> 
> 
> Also, please try booting without the nand-keep-config property.
> 
> Thank you,
> Miquèl
> 
> [1]
> https://github.com/miquelraynal/linux/blob/marvell/nand-next/nfc-rework/drivers/mtd/nand/marvell_nand.c#L1351



-- 
Miquel Raynal, Free Electrons
Embedded Linux and Kernel engineering
http://free-electrons.com

  reply	other threads:[~2017-12-11 14:10 UTC|newest]

Thread overview: 85+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-11-28  9:12 [BUG] pxa3xx: wait time out when scanning for bb Sean Nyekjær
2017-11-28 13:02 ` Miquel RAYNAL
2017-11-28 13:12   ` Sean Nyekjær
2017-11-28 13:30     ` Miquel RAYNAL
2017-11-28 13:42       ` Sean Nyekjær
2017-11-28 14:04         ` Miquel RAYNAL
2017-11-29  7:14           ` Sean Nyekjær
2017-11-29  8:03             ` Miquel RAYNAL
2017-11-30 12:00               ` Sean Nyekjær
2017-11-30 17:18                 ` Miquel RAYNAL
2017-11-30 18:13                   ` Sean Nyekjær
2017-12-01  8:15                     ` Miquel RAYNAL
2017-12-01  8:54                       ` Sean Nyekjær
2017-12-07 20:38                         ` Miquel RAYNAL
2017-12-08  9:04                           ` Sean Nyekjær
2017-12-08  9:21                             ` Miquel RAYNAL
2017-12-11  8:25                               ` Sean Nyekjær
2017-12-11  8:45                                 ` Sean Nyekjær
2017-12-11  9:53                                 ` Miquel RAYNAL
2017-12-11 10:20                                   ` Sean Nyekjær
2017-12-11 11:35                                     ` Sean Nyekjær
2017-12-11 13:22                                       ` Sean Nyekjær
2017-12-11 14:02                                         ` Miquel RAYNAL
2017-12-11 14:09                                           ` Miquel RAYNAL [this message]
2017-12-11 14:49                                             ` Boris Brezillon
2017-12-12  8:44                                             ` Sean Nyekjær
2017-12-12  8:51                                               ` Miquel RAYNAL
2017-12-12  8:56                                                 ` Sean Nyekjær
2017-12-12 10:12                                                   ` Miquel RAYNAL
2017-12-12 10:55                                                     ` Sean Nyekjær
2017-12-12 11:08                                                       ` Miquel RAYNAL
2017-12-12 11:28                                                         ` Sean Nyekjær
2017-12-12 11:35                                                           ` Miquel RAYNAL
2017-12-12 11:49                                                             ` Sean Nyekjær
2017-12-12 12:47                                                               ` Miquel RAYNAL
2017-12-12 13:09                                                                 ` Sean Nyekjær
2017-12-12 13:35                                                                   ` Miquel RAYNAL
2017-12-12 18:10                                                                     ` Sean Nyekjær
2017-12-12 18:23                                                                       ` Miquel RAYNAL
2017-12-13  6:25                                                                         ` Sean Nyekjær
2017-12-13  8:41                                                                           ` Miquel RAYNAL
2017-12-13  9:31                                                                             ` Sean Nyekjær
2017-12-15 17:25                                                                             ` Miquel RAYNAL
2017-12-15 18:56                                                                               ` Sean Nyekjær
2017-12-15 19:19                                                                                 ` Miquel RAYNAL
2017-12-17 11:56                                                                                   ` Sean Nyekjaer
2017-12-17 13:19                                                                                     ` Boris Brezillon
2017-12-17 21:47                                                                                       ` Sean Nyekjaer
2017-12-17 22:00                                                                                         ` Boris Brezillon
2017-12-17 22:15                                                                                           ` [SPAM] " Sean Nyekjær
2017-12-17 22:19                                                                                             ` Boris Brezillon
2017-12-17 22:19                                                                                             ` Miquel RAYNAL
2017-12-18  6:23                                                                                               ` Sean Nyekjær
2017-12-18  8:56                                                                                                 ` Miquel RAYNAL
2017-12-18  9:26                                                                                                   ` Sean Nyekjær
2017-12-18  9:35                                                                                                     ` Miquel RAYNAL
2017-12-18 10:12                                                                                                       ` Sean Nyekjær
2017-12-18 10:19                                                                                                         ` Miquel RAYNAL
2017-12-18 10:26                                                                                                           ` Sean Nyekjær
2017-12-18 10:45                                                                                                             ` Boris Brezillon
2017-12-18 10:48                                                                                                               ` Sean Nyekjær
2017-12-18 12:43                                                                                                                 ` Boris Brezillon
2017-12-18  8:57                                                                                                 ` [SPAM] " Boris Brezillon
2017-12-17 13:48                                                                                     ` Boris Brezillon
2017-12-11 20:11                                     ` Miquel RAYNAL
2017-12-09 23:18       ` Ezequiel Garcia
2017-12-10 14:17         ` Miquel RAYNAL
2017-12-11 12:30           ` Ezequiel Garcia
2017-12-11 13:13             ` Miquel RAYNAL
2017-12-11 16:08               ` Ezequiel Garcia
2017-12-11 16:41                 ` Miquel RAYNAL
     [not found]             ` <CAL92e2W7fLjVOWFgH2PpRLRP7Tf5L1vta0jduWm+bTVm647MNQ@mail.gmail.com>
2017-12-11 16:24               ` Ezequiel Garcia
2017-12-11 16:45                 ` Boris Brezillon
2017-12-11 21:16                 ` Boris Brezillon
2017-12-12  6:01                   ` Greg Cook
2017-12-12  7:09                     ` Ezequiel Garcia
2017-12-12  7:30                       ` Greg Cook
2017-12-12  8:15                         ` Boris Brezillon
2017-12-12 16:22                           ` Ezequiel Garcia
2017-12-12  6:36               ` Sean Nyekjær
2017-12-12  6:50                 ` Ezequiel Garcia
2017-12-12  7:17                   ` Greg Cook
2017-12-09 23:04   ` Ezequiel Garcia
2017-12-09 23:22 ` Ezequiel Garcia
2017-12-09 23:24   ` Ezequiel Garcia

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=20171211150929.722a361a@xps13 \
    --to=miquel.raynal@free-electrons.com \
    --cc=Boris.Brezillon@free-electrons.com \
    --cc=ezequiel.garcia@free-electrons.com \
    --cc=krev@triax.com \
    --cc=linux-mtd@lists.infradead.org \
    --cc=sean.nyekjaer@prevas.dk \
    /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