From: majianpeng Date: Tue, 6 Nov 2012 09:13:44 +0000 (+0800) Subject: md: Reassigned the parameters if read_seqretry returned true in func md_is_badblock. X-Git-Tag: v3.2.35~25 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=e76f340714e8ad61cf6dba03ba460afe4bb04624;p=thirdparty%2Fkernel%2Fstable.git md: Reassigned the parameters if read_seqretry returned true in func md_is_badblock. commit ab05613a0646dcc11049692d54bae76ca9ffa910 upstream. This bug was introduced by commit(v3.0-rc7-126-g2230dfe). So fix is suitable for 3.0.y thru 3.6.y. Signed-off-by: Jianpeng Ma Signed-off-by: NeilBrown Signed-off-by: Ben Hutchings --- diff --git a/drivers/md/md.c b/drivers/md/md.c index 2887f2287aca1..b4ce8919ae9b9 100644 --- a/drivers/md/md.c +++ b/drivers/md/md.c @@ -7650,9 +7650,9 @@ int md_is_badblock(struct badblocks *bb, sector_t s, int sectors, sector_t *first_bad, int *bad_sectors) { int hi; - int lo = 0; + int lo; u64 *p = bb->page; - int rv = 0; + int rv; sector_t target = s + sectors; unsigned seq; @@ -7667,7 +7667,8 @@ int md_is_badblock(struct badblocks *bb, sector_t s, int sectors, retry: seq = read_seqbegin(&bb->lock); - + lo = 0; + rv = 0; hi = bb->count; /* Binary search between lo and hi for 'target'