X-Git-Url: http://www.aleph1.co.uk/gitweb/?p=yaffs2.git;a=blobdiff_plain;f=yaffs_nand.c;h=14ae3308a79333f419d5ae6e5800237c2b5e77b2;hp=cd39d516066564bd452bafd9e48e2a7da82e67c6;hb=c0d545a4291efbb95831518929a87f07aa3c1eb9;hpb=e1b8e63260986ab7afec3c379e7a320677c95846 diff --git a/yaffs_nand.c b/yaffs_nand.c index cd39d51..14ae330 100644 --- a/yaffs_nand.c +++ b/yaffs_nand.c @@ -13,7 +13,7 @@ */ const char *yaffs_nand_c_version = - "$Id: yaffs_nand.c,v 1.1 2006-05-08 10:13:34 charles Exp $"; + "$Id: yaffs_nand.c,v 1.5 2006-11-08 09:52:12 charles Exp $"; #include "yaffs_nand.h" #include "yaffs_tagscompat.h" @@ -24,16 +24,31 @@ int yaffs_ReadChunkWithTagsFromNAND(yaffs_Device * dev, int chunkInNAND, __u8 * buffer, yaffs_ExtendedTags * tags) { - chunkInNAND -= dev->chunkOffset; + int result; + yaffs_ExtendedTags localTags; + + int realignedChunkInNAND = chunkInNAND - dev->chunkOffset; + + /* If there are no tags provided, use local tags to get prioritised gc working */ + if(!tags) + tags = &localTags; if (dev->readChunkWithTagsFromNAND) - return dev->readChunkWithTagsFromNAND(dev, chunkInNAND, buffer, + result = dev->readChunkWithTagsFromNAND(dev, realignedChunkInNAND, buffer, tags); else - return yaffs_TagsCompatabilityReadChunkWithTagsFromNAND(dev, - chunkInNAND, + result = yaffs_TagsCompatabilityReadChunkWithTagsFromNAND(dev, + realignedChunkInNAND, buffer, - tags); + tags); + if(tags && + tags->eccResult > YAFFS_ECC_RESULT_NO_ERROR){ + + yaffs_BlockInfo *bi = yaffs_GetBlockInfo(dev, chunkInNAND/dev->nChunksPerBlock); + yaffs_HandleChunkError(dev,bi); + } + + return result; } int yaffs_WriteChunkWithTagsToNAND(yaffs_Device * dev, @@ -108,9 +123,6 @@ int yaffs_EraseBlockInNAND(struct yaffs_DeviceStruct *dev, dev->nBlockErasures++; result = dev->eraseBlockInNAND(dev, blockInNAND); - /* If at first we don't succeed, try again *once*.*/ - if (!result) - result = dev->eraseBlockInNAND(dev, blockInNAND); return result; }