diff options
-rw-r--r-- | block/ll_rw_blk.c | 10 | ||||
-rw-r--r-- | drivers/scsi/scsi_lib.c | 2 |
2 files changed, 8 insertions, 4 deletions
diff --git a/block/ll_rw_blk.c b/block/ll_rw_blk.c index 9e3f3cc85d0d..3935469e3662 100644 --- a/block/ll_rw_blk.c +++ b/block/ll_rw_blk.c | |||
@@ -1322,8 +1322,8 @@ int blk_rq_map_sg(struct request_queue *q, struct request *rq, | |||
1322 | struct scatterlist *sglist) | 1322 | struct scatterlist *sglist) |
1323 | { | 1323 | { |
1324 | struct bio_vec *bvec, *bvprv; | 1324 | struct bio_vec *bvec, *bvprv; |
1325 | struct scatterlist *next_sg, *sg; | ||
1326 | struct req_iterator iter; | 1325 | struct req_iterator iter; |
1326 | struct scatterlist *sg; | ||
1327 | int nsegs, cluster; | 1327 | int nsegs, cluster; |
1328 | 1328 | ||
1329 | nsegs = 0; | 1329 | nsegs = 0; |
@@ -1333,7 +1333,7 @@ int blk_rq_map_sg(struct request_queue *q, struct request *rq, | |||
1333 | * for each bio in rq | 1333 | * for each bio in rq |
1334 | */ | 1334 | */ |
1335 | bvprv = NULL; | 1335 | bvprv = NULL; |
1336 | sg = next_sg = &sglist[0]; | 1336 | sg = NULL; |
1337 | rq_for_each_segment(bvec, rq, iter) { | 1337 | rq_for_each_segment(bvec, rq, iter) { |
1338 | int nbytes = bvec->bv_len; | 1338 | int nbytes = bvec->bv_len; |
1339 | 1339 | ||
@@ -1349,8 +1349,10 @@ int blk_rq_map_sg(struct request_queue *q, struct request *rq, | |||
1349 | sg->length += nbytes; | 1349 | sg->length += nbytes; |
1350 | } else { | 1350 | } else { |
1351 | new_segment: | 1351 | new_segment: |
1352 | sg = next_sg; | 1352 | if (!sg) |
1353 | next_sg = sg_next(sg); | 1353 | sg = sglist; |
1354 | else | ||
1355 | sg = sg_next(sg); | ||
1354 | 1356 | ||
1355 | memset(sg, 0, sizeof(*sg)); | 1357 | memset(sg, 0, sizeof(*sg)); |
1356 | sg->page = bvec->bv_page; | 1358 | sg->page = bvec->bv_page; |
diff --git a/drivers/scsi/scsi_lib.c b/drivers/scsi/scsi_lib.c index 0c86be71bb33..aac8a02cbe80 100644 --- a/drivers/scsi/scsi_lib.c +++ b/drivers/scsi/scsi_lib.c | |||
@@ -764,6 +764,8 @@ struct scatterlist *scsi_alloc_sgtable(struct scsi_cmnd *cmd, gfp_t gfp_mask) | |||
764 | if (unlikely(!sgl)) | 764 | if (unlikely(!sgl)) |
765 | goto enomem; | 765 | goto enomem; |
766 | 766 | ||
767 | memset(sgl, 0, sizeof(*sgl) * sgp->size); | ||
768 | |||
767 | /* | 769 | /* |
768 | * first loop through, set initial index and return value | 770 | * first loop through, set initial index and return value |
769 | */ | 771 | */ |