aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/mtd/devices/mtd_dataflash.c
diff options
context:
space:
mode:
authorPeter Korsgaard <jacmet@sunsite.dk>2009-05-18 11:13:54 +0100
committerLinus Torvalds <torvalds@linux-foundation.org>2009-05-18 08:36:21 -0700
commitdbf8c11f821b6ff83302c34f2403b4f7231f50ae (patch)
treeba637dc39a49ae0dce4430b44b07d2f7638d5fd2 /drivers/mtd/devices/mtd_dataflash.c
parentbac9caf016bf147af7d3afbe7580a7f773cb1566 (diff)
downloadkernel_samsung_smdk4412-dbf8c11f821b6ff83302c34f2403b4f7231f50ae.zip
kernel_samsung_smdk4412-dbf8c11f821b6ff83302c34f2403b4f7231f50ae.tar.gz
kernel_samsung_smdk4412-dbf8c11f821b6ff83302c34f2403b4f7231f50ae.tar.bz2
mtd_dataflash: unbreak erase support
Commit 5b7f3a50 (fix dataflash 64-bit divisions) unfortunately introduced a typo. Erase addr and len were swapped in the pageaddr calculation, causing the wrong sectors to get erased. Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk> Acked-by: Artem Bityutskiy <Artem.Bityutskiy@nokia.com> Signed-off-by: David Woodhouse <David.Woodhouse@intel.com> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/mtd/devices/mtd_dataflash.c')
-rw-r--r--drivers/mtd/devices/mtd_dataflash.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/mtd/devices/mtd_dataflash.c b/drivers/mtd/devices/mtd_dataflash.c
index 62dee54..43976aa 100644
--- a/drivers/mtd/devices/mtd_dataflash.c
+++ b/drivers/mtd/devices/mtd_dataflash.c
@@ -178,7 +178,7 @@ static int dataflash_erase(struct mtd_info *mtd, struct erase_info *instr)
/* Calculate flash page address; use block erase (for speed) if
* we're at a block boundary and need to erase the whole block.
*/
- pageaddr = div_u64(instr->len, priv->page_size);
+ pageaddr = div_u64(instr->addr, priv->page_size);
do_block = (pageaddr & 0x7) == 0 && instr->len >= blocksize;
pageaddr = pageaddr << priv->page_offset;