From 884147c5e225af3cce71900e47ce70abd260dfd5 Mon Sep 17 00:00:00 2001 From: Michael Sparmann Date: Sun, 14 Mar 2010 15:12:08 +0000 Subject: Nano 2G VFL: try slow read twice if fast read failed git-svn-id: svn://svn.rockbox.org/rockbox/trunk@25166 a1c6a512-1295-4272-9138-f99709370657 --- firmware/target/arm/s5l8700/ipodnano2g/ftl-nano2g.c | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) (limited to 'firmware/target/arm') diff --git a/firmware/target/arm/s5l8700/ipodnano2g/ftl-nano2g.c b/firmware/target/arm/s5l8700/ipodnano2g/ftl-nano2g.c index 9bac47e5bb..b5f179ce89 100644 --- a/firmware/target/arm/s5l8700/ipodnano2g/ftl-nano2g.c +++ b/firmware/target/arm/s5l8700/ipodnano2g/ftl-nano2g.c @@ -893,20 +893,27 @@ uint32_t ftl_vfl_read_fast(uint32_t vpage, void* buffer, void* sparebuffer, if ((rc >> (i << 2)) & 0x2) continue; if ((rc >> (i << 2)) & 0xf) { - rc &= ~(0xf << (i << 2)); nand_reset(i); uint32_t ret = nand_read_page(i, physpage, (void*)((uint32_t)buffer + 0x800 * i), (void*)((uint32_t)sparebuffer + 0x40 * i), 1, checkempty); + if ((ret & 0x11D) != 0 && (ret & 2) == 0) + { + ret = nand_read_page(i, physpage, + (void*)((uint32_t)buffer + 0x800 * i), + (void*)((uint32_t)sparebuffer + 0x40 * i), + 1, checkempty); #ifdef FTL_READONLY - (void)remaponfail; + (void)remaponfail; #else - if (remaponfail == 1 && (ret & 0x11D) != 0 && (ret & 2) == 0) - panicf("FTL: VFL fast read failed, RC %04X, bank %d, RET %03X, base %d", - rc, i, ret, vpage); -// ftl_vfl_schedule_block_for_remap(i, block); + if (remaponfail == 1 && (ret & 0x11D) != 0 && (ret & 2) == 0) + panicf("FTL: VFL fast read failed, RC %04X, bank %d, RET %03X, base %d", + rc, i, ret, vpage); +// ftl_vfl_schedule_block_for_remap(i, block); #endif + } + rc &= ~(0xf << (i << 2)); if (ret & 1) rc |= 1 << (i << 2); if (ret & 2) rc |= 2 << (i << 2); if (ret & 0x10) rc |= 4 << (i << 2); -- cgit v1.2.3