diff options
Diffstat (limited to 'block/blk-map.c')
-rw-r--r-- | block/blk-map.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/block/blk-map.c b/block/blk-map.c index ade0a08c9099..e663ac2d8e68 100644 --- a/block/blk-map.c +++ b/block/blk-map.c | |||
@@ -54,7 +54,7 @@ static int __blk_rq_map_user(struct request_queue *q, struct request *rq, | |||
54 | * direct dma. else, set up kernel bounce buffers | 54 | * direct dma. else, set up kernel bounce buffers |
55 | */ | 55 | */ |
56 | uaddr = (unsigned long) ubuf; | 56 | uaddr = (unsigned long) ubuf; |
57 | if (blk_rq_aligned(q, ubuf, len) && !map_data) | 57 | if (blk_rq_aligned(q, uaddr, len) && !map_data) |
58 | bio = bio_map_user(q, NULL, uaddr, len, reading, gfp_mask); | 58 | bio = bio_map_user(q, NULL, uaddr, len, reading, gfp_mask); |
59 | else | 59 | else |
60 | bio = bio_copy_user(q, map_data, uaddr, len, reading, gfp_mask); | 60 | bio = bio_copy_user(q, map_data, uaddr, len, reading, gfp_mask); |
@@ -201,6 +201,9 @@ int blk_rq_map_user_iov(struct request_queue *q, struct request *rq, | |||
201 | for (i = 0; i < iov_count; i++) { | 201 | for (i = 0; i < iov_count; i++) { |
202 | unsigned long uaddr = (unsigned long)iov[i].iov_base; | 202 | unsigned long uaddr = (unsigned long)iov[i].iov_base; |
203 | 203 | ||
204 | if (!iov[i].iov_len) | ||
205 | return -EINVAL; | ||
206 | |||
204 | if (uaddr & queue_dma_alignment(q)) { | 207 | if (uaddr & queue_dma_alignment(q)) { |
205 | unaligned = 1; | 208 | unaligned = 1; |
206 | break; | 209 | break; |
@@ -288,6 +291,7 @@ int blk_rq_map_kern(struct request_queue *q, struct request *rq, void *kbuf, | |||
288 | unsigned int len, gfp_t gfp_mask) | 291 | unsigned int len, gfp_t gfp_mask) |
289 | { | 292 | { |
290 | int reading = rq_data_dir(rq) == READ; | 293 | int reading = rq_data_dir(rq) == READ; |
294 | unsigned long addr = (unsigned long) kbuf; | ||
291 | int do_copy = 0; | 295 | int do_copy = 0; |
292 | struct bio *bio; | 296 | struct bio *bio; |
293 | int ret; | 297 | int ret; |
@@ -297,7 +301,7 @@ int blk_rq_map_kern(struct request_queue *q, struct request *rq, void *kbuf, | |||
297 | if (!len || !kbuf) | 301 | if (!len || !kbuf) |
298 | return -EINVAL; | 302 | return -EINVAL; |
299 | 303 | ||
300 | do_copy = !blk_rq_aligned(q, kbuf, len) || object_is_on_stack(kbuf); | 304 | do_copy = !blk_rq_aligned(q, addr, len) || object_is_on_stack(kbuf); |
301 | if (do_copy) | 305 | if (do_copy) |
302 | bio = bio_copy_kern(q, kbuf, len, gfp_mask, reading); | 306 | bio = bio_copy_kern(q, kbuf, len, gfp_mask, reading); |
303 | else | 307 | else |