summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormajianpeng <majianpeng@gmail.com>2012-11-08 08:56:27 +0800
committerNeilBrown <neilb@suse.de>2012-11-20 10:27:17 +1100
commit35f9ac2dcec8f79d7059ce174fd7b7ee3290d620 (patch)
tree0192c0d2874221bf8672e278c86fd0239cb32b08
parentab05613a0646dcc11049692d54bae76ca9ffa910 (diff)
downloadlinux-stable-35f9ac2dcec8f79d7059ce174fd7b7ee3290d620.tar.gz
linux-stable-35f9ac2dcec8f79d7059ce174fd7b7ee3290d620.tar.bz2
linux-stable-35f9ac2dcec8f79d7059ce174fd7b7ee3290d620.zip
md: Avoid write invalid address if read_seqretry returned true.
If read_seqretry returned true and bbp was changed, it will write invalid address which can cause some serious problem. This bug was introduced by commit v3.0-rc7-130-g2699b67. So fix is suitable for 3.0.y thru 3.6.y. Reported-by: zhuwenfeng@kedacom.com Tested-by: zhuwenfeng@kedacom.com Cc: stable@vger.kernel.org Signed-off-by: Jianpeng Ma <majianpeng@gmail.com> Signed-off-by: NeilBrown <neilb@suse.de>
-rw-r--r--drivers/md/md.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/md/md.c b/drivers/md/md.c
index 14db6abb2c42..4c7d880a60a4 100644
--- a/drivers/md/md.c
+++ b/drivers/md/md.c
@@ -1817,10 +1817,10 @@ retry:
memset(bbp, 0xff, PAGE_SIZE);
for (i = 0 ; i < bb->count ; i++) {
- u64 internal_bb = *p++;
+ u64 internal_bb = p[i];
u64 store_bb = ((BB_OFFSET(internal_bb) << 10)
| BB_LEN(internal_bb));
- *bbp++ = cpu_to_le64(store_bb);
+ bbp[i] = cpu_to_le64(store_bb);
}
bb->changed = 0;
if (read_seqretry(&bb->lock, seq))