Message ID | 1297159362-8407-6-git-send-email-adrian.hunter@nokia.com |
---|---|
State | Accepted |
Commit | e6da85685b2dec1e69e58366c22d1f883d6da575 |
Headers | show |
Acked-by: Kyungmin Park <kyungmin.park@samsung.com> On Tue, Feb 8, 2011 at 7:02 PM, Adrian Hunter <adrian.hunter@nokia.com> wrote: > From: Roman Tereshonkov <roman.tereshonkov@nokia.com> > > In onenand_verify function the address can be writepage non-aligned. > When a page is read for comparing the right offset should be used > for "this->verify_buf" to get the right matching with compared > "buf" buffer. > > Signed-off-by: Roman Tereshonkov <roman.tereshonkov@nokia.com> > Signed-off-by: Adrian Hunter <adrian.hunter@nokia.com> > --- > drivers/mtd/onenand/onenand_base.c | 10 +++++----- > 1 files changed, 5 insertions(+), 5 deletions(-) > > diff --git a/drivers/mtd/onenand/onenand_base.c b/drivers/mtd/onenand/onenand_base.c > index 38e6d76..4205b94 100644 > --- a/drivers/mtd/onenand/onenand_base.c > +++ b/drivers/mtd/onenand/onenand_base.c > @@ -1648,11 +1648,10 @@ static int onenand_verify(struct mtd_info *mtd, const u_char *buf, loff_t addr, > int ret = 0; > int thislen, column; > > + column = addr & (this->writesize - 1); > + > while (len != 0) { > - thislen = min_t(int, this->writesize, len); > - column = addr & (this->writesize - 1); > - if (column + thislen > this->writesize) > - thislen = this->writesize - column; > + thislen = min_t(int, this->writesize - column, len); > > this->command(mtd, ONENAND_CMD_READ, addr, this->writesize); > > @@ -1666,12 +1665,13 @@ static int onenand_verify(struct mtd_info *mtd, const u_char *buf, loff_t addr, > > this->read_bufferram(mtd, ONENAND_DATARAM, this->verify_buf, 0, mtd->writesize); > > - if (memcmp(buf, this->verify_buf, thislen)) > + if (memcmp(buf, this->verify_buf + column, thislen)) > return -EBADMSG; > > len -= thislen; > buf += thislen; > addr += thislen; > + column = 0; > } > > return 0; > -- > 1.7.0.4 > > > ______________________________________________________ > Linux MTD discussion mailing list > http://lists.infradead.org/mailman/listinfo/linux-mtd/ >
diff --git a/drivers/mtd/onenand/onenand_base.c b/drivers/mtd/onenand/onenand_base.c index 38e6d76..4205b94 100644 --- a/drivers/mtd/onenand/onenand_base.c +++ b/drivers/mtd/onenand/onenand_base.c @@ -1648,11 +1648,10 @@ static int onenand_verify(struct mtd_info *mtd, const u_char *buf, loff_t addr, int ret = 0; int thislen, column; + column = addr & (this->writesize - 1); + while (len != 0) { - thislen = min_t(int, this->writesize, len); - column = addr & (this->writesize - 1); - if (column + thislen > this->writesize) - thislen = this->writesize - column; + thislen = min_t(int, this->writesize - column, len); this->command(mtd, ONENAND_CMD_READ, addr, this->writesize); @@ -1666,12 +1665,13 @@ static int onenand_verify(struct mtd_info *mtd, const u_char *buf, loff_t addr, this->read_bufferram(mtd, ONENAND_DATARAM, this->verify_buf, 0, mtd->writesize); - if (memcmp(buf, this->verify_buf, thislen)) + if (memcmp(buf, this->verify_buf + column, thislen)) return -EBADMSG; len -= thislen; buf += thislen; addr += thislen; + column = 0; } return 0;