Commit 7653fc288a964ce5bb0cff9176444260731d0f90

Authored by Stefan Agner
Committed by Scott Wood
1 parent 004a1fdb45

mtd: vf610_nfc: mark page as dirty on block erase

The driver tries to re-use the page buffer by storing the page
number of the current page in the buffer. The page is only read
if the requested page number is not currently in the buffer. When
a block is erased, the page number is marked as invalid if the
erased page equals the one currently in the cache. However, since
a erase block consists of multiple pages, also other page numbers
could be affected.

The commands to reproduce this issue (on a written page):
> nand dump 0x800
> nand erase 0x0 0x20000
> nand dump 0x800

The second nand dump command returns the data from the buffer,
while in fact the page is erased (0xff).

Avoid the hassle to calculate whether the page is affected or not,
but set the page buffer unconditionally to invalid instead.

Signed-off-by: Stefan Agner <stefan@agner.ch>

Showing 1 changed file with 1 additions and 2 deletions Side-by-side Diff

drivers/mtd/nand/vf610_nfc.c
... ... @@ -369,8 +369,7 @@
369 369 break;
370 370  
371 371 case NAND_CMD_ERASE1:
372   - if (nfc->page == page)
373   - nfc->page = -1;
  372 + nfc->page = -1;
374 373 vf610_nfc_send_commands(nfc->regs, command,
375 374 NAND_CMD_ERASE2, ERASE_CMD_CODE);
376 375 vf610_nfc_addr_cycle(mtd, column, page);