From: Shaohua Li <shli@kernel.org>
To: Joshua Kinard <kumba@gentoo.org>
Cc: linux-raid@vger.kernel.org, Linux/MIPS <linux-mips@linux-mips.org>
Subject: Re: commit 8031c3ddc70a breaks RAID5 on MIPS kernel where PAGE_SIZE == 64K
Date: Mon, 9 Oct 2017 13:38:30 -0700 [thread overview]
Message-ID: <20171009203830.qu75s3i6ghdaf6s2@kernel.org> (raw)
In-Reply-To: <db0e511c-f5db-99fe-70ac-150864432db0@gentoo.org>
On Sun, Oct 08, 2017 at 04:34:52PM -0400, Joshua Kinard wrote:
> Hi,
>
> Testing 4.13.5 out on my SGI Octane, I discovered that my RAID5 arrays were no
> longer auto-assembling. The error being thrown was an "attempt to access
> beyond the end of the device". I've hand-transcribed a block of these errors
> from a manual attempt to assemble the array via mdadm from a netboot image:
>
> / # mdadm -A /dev/md0 /dev/sda1 /dev/sdb1 /dev/sdc1
> [ 56.303339] md: md0 stopped.
> [ 56.323565] md/raid:md0: device sda1 operational as raid disk 0
> [ 56.334556] md/raid:md0: device sdb1 operational as raid disk 2
> [ 56.345396] md/raid:md0: device sdc1 operational as raid disk 1
> [ 56.350750] md/raid:md0: raid level 5 active with 3 out of 3 devices,
> algorithm 2
> [ 56.369529] attempt to access beyond end of device
> [ 56.380149] sda1: rw=2048, want=4194312, limit=4194305
> [ 56.390823] attempt to access beyond end of device
> [ 56.401500] sdc1: rw=2048, want=4194312, limit=4194305
> [ 56.412313] attempt to access beyond end of device
> [ 56.423146] sdb1: rw=2048, want=4194312, limit=4194305
> [ 56.433985] md0: failed to create bitmap (-5)
> mdadm: failed to RUN_ARRAY /dev/md0: input/output error
> [ 56.457979] md: md0 stopped.
> / #
>
> I've traced the offending commit down to 8031c3ddc70a ("md/bitmap: copy correct
> data for bitmap super"):
>
> https://git.linux-mips.org/cgit/ralf/linux.git/commit/?id=8031c3ddc70ab93099e7d1814382dba39f57b43e
>
> Per the commit message, it makes an assumption that PAGE_SIZE is 4K. MIPS
> kernels allow you to change the value of PAGE_SIZE at compile time to something
> other than 4K. It appears that 4K and 16K both work, while 64K, which is what
> I use on this machine, is broken with this commit applied.
>
> Reverting this patch or setting PAGE_SIZE to 4K or 16K will resolve the issue,
> but there are advantages to using 64K PAGE_SIZEs on these platforms. I am not
> sure that 16K is wholly safe either, FWIW, given the assumption made in the commit.
Can you try below one?
diff --git a/drivers/md/bitmap.c b/drivers/md/bitmap.c
index d2121637b4ab..f68ec973fbdd 100644
--- a/drivers/md/bitmap.c
+++ b/drivers/md/bitmap.c
@@ -153,6 +153,7 @@ static int read_sb_page(struct mddev *mddev, loff_t offset,
struct md_rdev *rdev;
sector_t target;
+ int target_size;
rdev_for_each(rdev, mddev) {
if (! test_bit(In_sync, &rdev->flags)
@@ -161,9 +162,12 @@ static int read_sb_page(struct mddev *mddev, loff_t offset,
continue;
target = offset + index * (PAGE_SIZE/512);
+ target_size = min_t(u64, size, i_size_read(rdev->bdev->bd_inode) -
+ ((target + rdev->sb_start) << 9));
+ target_size = roundup(target_size,
+ bdev_logical_block_size(rdev->bdev));
- if (sync_page_io(rdev, target,
- roundup(size, bdev_logical_block_size(rdev->bdev)),
+ if (sync_page_io(rdev, target, target_size,
page, REQ_OP_READ, 0, true)) {
page->index = index;
return 0;
next prev parent reply other threads:[~2017-10-09 20:38 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-10-08 20:34 commit 8031c3ddc70a breaks RAID5 on MIPS kernel where PAGE_SIZE == 64K Joshua Kinard
2017-10-09 20:38 ` Shaohua Li [this message]
2017-10-10 4:24 ` Joshua Kinard
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20171009203830.qu75s3i6ghdaf6s2@kernel.org \
--to=shli@kernel.org \
--cc=kumba@gentoo.org \
--cc=linux-mips@linux-mips.org \
--cc=linux-raid@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).