diff options
author | Adrian Hunter <hunter.programmer@gmail.com> | 2007-01-10 06:51:26 +0100 |
---|---|---|
committer | Kyungmin Park <kyungmin.park@samsung.com> | 2007-01-18 02:59:44 +0100 |
commit | 9d03280129e84f8cdfd83f84803a4548e3bf697d (patch) | |
tree | 2cce5d630864168ffd2427062094479d3bcf3ec5 /drivers/mtd/onenand/onenand_base.c | |
parent | [MTD] OneNAND: Fix unlock all status error (diff) | |
download | linux-9d03280129e84f8cdfd83f84803a4548e3bf697d.tar.xz linux-9d03280129e84f8cdfd83f84803a4548e3bf697d.zip |
[MTD] OneNAND: Return an error if a read timeout occurs
If OneNAND is operating within specification, all operations should easily be
completed within the 20 millisecond timeout.
This patch faithlessly adds a check for the timeout and returns an error in
that case.
Signed-off-by: Adrian Hunter <ext-adrian.hunter@nokia.com>
Signed-off-by: Kyungmin Park <kyungmin.park@samsung.com>
Diffstat (limited to 'drivers/mtd/onenand/onenand_base.c')
-rw-r--r-- | drivers/mtd/onenand/onenand_base.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/mtd/onenand/onenand_base.c b/drivers/mtd/onenand/onenand_base.c index d0f31183d58f..ce1cbdcd355a 100644 --- a/drivers/mtd/onenand/onenand_base.c +++ b/drivers/mtd/onenand/onenand_base.c @@ -333,6 +333,9 @@ static int onenand_wait(struct mtd_info *mtd, int state) } else if (ecc & ONENAND_ECC_1BIT_ALL) mtd->ecc_stats.corrected++; } + } else if (state == FL_READING) { + printk(KERN_ERR "onenand_wait: read timeout! ctrl=0x%04x intr=0x%04x\n", ctrl, interrupt); + return -EIO; } return 0; |