diff options
author | Adrian Hunter <ext-adrian.hunter@nokia.com> | 2007-02-06 01:15:39 +0100 |
---|---|---|
committer | Kyungmin Park <kyungmin.park@samsung.com> | 2007-02-06 01:15:39 +0100 |
commit | 52e4200a6da2d98c537b95f7c502ddadf96a6934 (patch) | |
tree | 9fc09f25af0a74daa46ace5e91b0d606108967c9 | |
parent | [MTD] OneNAND: Fix typo and remove unnecessary goto statement (diff) | |
download | linux-52e4200a6da2d98c537b95f7c502ddadf96a6934.tar.xz linux-52e4200a6da2d98c537b95f7c502ddadf96a6934.zip |
[MTD] OneNAND: Do not allow oob write past end of page
OneNAND can write oob to successive pages, but NAND
does not do that. For compatibility, disallow OneNAND
from writing past the end of the page.
Signed-off-by: Adrian Hunter <ext-adrian.hunter@nokia.com>
Signed-off-by: Kyungmin Park <kyungmin.park@samsung.com>
-rw-r--r-- | drivers/mtd/onenand/onenand_base.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/drivers/mtd/onenand/onenand_base.c b/drivers/mtd/onenand/onenand_base.c index 6df309b89e9a..553b24d93335 100644 --- a/drivers/mtd/onenand/onenand_base.c +++ b/drivers/mtd/onenand/onenand_base.c @@ -1186,6 +1186,13 @@ static int onenand_do_write_oob(struct mtd_info *mtd, loff_t to, size_t len, return -EINVAL; } + /* For compatibility with NAND: Do not allow write past end of page */ + if (column + len > oobsize) { + DEBUG(MTD_DEBUG_LEVEL0, "onenand_write_oob: " + "Attempt to write past end of page\n"); + return -EINVAL; + } + /* Do not allow reads past end of device */ if (unlikely(to >= mtd->size || column + len > ((mtd->size >> this->page_shift) - |