X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=block%2Fblk-merge.c;h=b5c5c4a9e3f08d051a25d44e92689580d19cbce5;hb=b912b5e2cfb35c02c9c79d3f6e31753f3be4dd83;hp=d3b84bbb776a5fd0b3ba3238c7de20e7df93eaeb;hpb=6a306e8b4c81a1c1f538e390d92bfe80d04b254c;p=linux-2.6 diff --git a/block/blk-merge.c b/block/blk-merge.c index d3b84bbb77..b5c5c4a9e3 100644 --- a/block/blk-merge.c +++ b/block/blk-merge.c @@ -220,7 +220,19 @@ new_segment: bvprv = bvec; } /* segments in rq */ - if (q->dma_drain_size) { + + if (unlikely(rq->cmd_flags & REQ_COPY_USER) && + (rq->data_len & q->dma_pad_mask)) { + unsigned int pad_len = (q->dma_pad_mask & ~rq->data_len) + 1; + + sg->length += pad_len; + rq->extra_len += pad_len; + } + + if (q->dma_drain_size && q->dma_drain_needed(rq)) { + if (rq->cmd_flags & REQ_RW) + memset(q->dma_drain_buffer, 0, q->dma_drain_size); + sg->page_link &= ~0x02; sg = sg_next(sg); sg_set_page(sg, virt_to_page(q->dma_drain_buffer), @@ -228,6 +240,7 @@ new_segment: ((unsigned long)q->dma_drain_buffer) & (PAGE_SIZE - 1)); nsegs++; + rq->extra_len += q->dma_drain_size; } if (sg)