Commit 29ac8e05 authored by NeilBrown's avatar NeilBrown Committed by Linus Torvalds

[PATCH] md: fix splitting of md/linear request that cross a device boundary

When a request crosses a boundary between devices, it needs to be split.
But where we should calculate the amount of the request before the boundary
to find the split-point, we care currently calculating the amount that is
*after* the boundary !!!
Signed-off-by: default avatarNeil Brown <neilb@cse.unsw.edu.au>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 8f332287
...@@ -269,9 +269,8 @@ static int linear_make_request (request_queue_t *q, struct bio *bio) ...@@ -269,9 +269,8 @@ static int linear_make_request (request_queue_t *q, struct bio *bio)
* split it. * split it.
*/ */
struct bio_pair *bp; struct bio_pair *bp;
bp = bio_split(bio, bio_split_pool, bp = bio_split(bio, bio_split_pool,
(bio->bi_sector + (bio->bi_size >> 9) - ((tmp_dev->offset + tmp_dev->size)<<1) - bio->bi_sector);
(tmp_dev->offset + tmp_dev->size))<<1);
if (linear_make_request(q, &bp->bio1)) if (linear_make_request(q, &bp->bio1))
generic_make_request(&bp->bio1); generic_make_request(&bp->bio1);
if (linear_make_request(q, &bp->bio2)) if (linear_make_request(q, &bp->bio2))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment