[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1385024065-29965-1-git-send-email-zhanghonghui@innofidei.com>
Date: Thu, 21 Nov 2013 16:54:25 +0800
From: Hans Zhang <zhanghonghui@...ofidei.com>
To: dwmw2@...radead.org, linux-mtd@...ts.infradead.org,
linux-kernel@...r.kernel.org
Cc: zhouguangming@...ofidei.com,
Hans Zhang <zhanghonghui@...ofidei.com>
Subject: [PATCH] Make the mtdblock read/write skip the bad nand sector
When read/write the nandblock device, it will abort writing if
there's a bad block, it's reasonable to skip the bad block and
finish the data writing.
The data reading procedure should also skip the bad block since
there's no data write to the block.
--v2:
use the wrapped mtd_block_isbad instand of mtd->block_isbad
Signed-off-by: Hans Zhang <zhanghonghui@...ofidei.com>
---
drivers/mtd/mtdblock.c | 17 +++++++++++++++++
1 files changed, 17 insertions(+), 0 deletions(-)
diff --git a/drivers/mtd/mtdblock.c b/drivers/mtd/mtdblock.c
index 485ea75..4f6acd1 100644
--- a/drivers/mtd/mtdblock.c
+++ b/drivers/mtd/mtdblock.c
@@ -124,6 +124,13 @@ static int write_cached_data (struct mtdblk_dev *mtdblk)
"at 0x%lx, size 0x%x\n", mtd->name,
mtdblk->cache_offset, mtdblk->cache_size);
+retry:
+ ret = mtd_block_isbad(mtd, mtdblk->cache_offset);
+ if (ret > 0) {
+ mtdblk->cache_offset += mtdblk->cache_size;
+ goto retry;
+ }
+
ret = erase_write (mtd, mtdblk->cache_offset,
mtdblk->cache_size, mtdblk->cache_data);
if (ret)
@@ -163,6 +170,11 @@ static int do_cached_write (struct mtdblk_dev *mtdblk, unsigned long pos,
size = len;
if (size == sect_size) {
+ ret = mtd_block_isbad(mtd, pos);
+ if (ret > 0) {
+ pos += sect_size;
+ continue;
+ }
/*
* We are covering a whole sector. Thus there is no
* need to bother with the cache while it may still be
@@ -242,6 +254,11 @@ static int do_cached_read (struct mtdblk_dev *mtdblk, unsigned long pos,
mtdblk->cache_offset == sect_start) {
memcpy (buf, mtdblk->cache_data + offset, size);
} else {
+ ret = mtd_block_isbad(mtd, pos);
+ if (ret > 0) {
+ pos += sect_size;
+ continue;
+ }
ret = mtd_read(mtd, pos, size, &retlen, buf);
if (ret)
return ret;
--
1.7.1
“This E-mail and its attachments may contain legally privileged or confidential information from Innofidei Corporation. Any unauthorized copy, use, disclosure or distribution of this information is strictly prohibited. If you are not the intended recipient, please notify the sender immediately by E-mail or telephone and delete this E-mail and all its attachments immediately.
本邮件及其附件内容可能包含创毅公司享有专有法律权利的或者需要保密的信息。严禁任何人未经发件人许可以任何形式复制、使用、披露或者散发此项信息。如果您不是该收件人,请您立即通过邮件或者电话通知发件人并立即删除本邮件及其附件内容.”
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists