Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit c56ec763 authored by Linus Torvalds's avatar Linus Torvalds
Browse files

Merge branch 'for-linus' of git://git.kernel.dk/data/git/linux-2.6-block

* 'for-linus' of git://git.kernel.dk/data/git/linux-2.6-block:
  [BLOCK] blk_rq_map_sg() next_sg fixup
  Revert "[SCSI] Remove full sg table memset()"
parents fb9fc395 ba951841
Loading
Loading
Loading
Loading
+6 −4
Original line number Diff line number Diff line
@@ -1322,8 +1322,8 @@ int blk_rq_map_sg(struct request_queue *q, struct request *rq,
		  struct scatterlist *sglist)
{
	struct bio_vec *bvec, *bvprv;
	struct scatterlist *next_sg, *sg;
	struct req_iterator iter;
	struct scatterlist *sg;
	int nsegs, cluster;

	nsegs = 0;
@@ -1333,7 +1333,7 @@ int blk_rq_map_sg(struct request_queue *q, struct request *rq,
	 * for each bio in rq
	 */
	bvprv = NULL;
	sg = next_sg = &sglist[0];
	sg = NULL;
	rq_for_each_segment(bvec, rq, iter) {
		int nbytes = bvec->bv_len;

@@ -1349,8 +1349,10 @@ int blk_rq_map_sg(struct request_queue *q, struct request *rq,
			sg->length += nbytes;
		} else {
new_segment:
			sg = next_sg;
			next_sg = sg_next(sg);
			if (!sg)
				sg = sglist;
			else
				sg = sg_next(sg);

			memset(sg, 0, sizeof(*sg));
			sg->page = bvec->bv_page;
+2 −0
Original line number Diff line number Diff line
@@ -764,6 +764,8 @@ struct scatterlist *scsi_alloc_sgtable(struct scsi_cmnd *cmd, gfp_t gfp_mask)
		if (unlikely(!sgl))
			goto enomem;

		memset(sgl, 0, sizeof(*sgl) * sgp->size);

		/*
		 * first loop through, set initial index and return value
		 */