nanddump: correct rounding to next page (lead to infinite loop)
The rounding to next page formula was wrong: ex: (len | ~(meminfo->writesize - 1)) + 1; len=128K writesize=4K (len | ~(meminfo->writesize - 1)) + 1 => 4 294 963 201 ?! correct rounding formula: ((len - 1) | (meminfo->writesize - 1)) + 1 => 128K len = 130K ((len - 1) | (meminfo->writesize - 1)) + 1 => 132K modprobe nandsim parts="20,20" badblocks="22,23" without patch: nanddump /dev/mtd1 | wc -c [...] infinite loop with the patch: nanddump /dev/mtd1 | wc -c 327680 Signed-off-by: Richard Genoud <richard.genoud@gmail.com> Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
de3cae1348
commit
cbf3bfa57a
@ -64,8 +64,8 @@ static void dump_bad(struct mtd_info_user *meminfo, unsigned len, int oob)
|
||||
unsigned char buf[meminfo->writesize];
|
||||
unsigned count;
|
||||
|
||||
/* round len to the next page */
|
||||
len = (len | ~(meminfo->writesize - 1)) + 1;
|
||||
/* round len to the next page only if len is not already on a page */
|
||||
len = ((len - 1) | (meminfo->writesize - 1)) + 1;
|
||||
|
||||
memset(buf, 0xff, sizeof(buf));
|
||||
for (count = 0; count < len; count += meminfo->writesize) {
|
||||
|
Loading…
Reference in New Issue
Block a user