aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/scsi/initio.c36
1 files changed, 11 insertions, 25 deletions
diff --git a/drivers/scsi/initio.c b/drivers/scsi/initio.c
index 65ca1424954e..d9dfb69ae031 100644
--- a/drivers/scsi/initio.c
+++ b/drivers/scsi/initio.c
@@ -2563,7 +2563,7 @@ static void initio_build_scb(struct initio_host * host, struct scsi_ctrl_blk * c
2563{ /* Create corresponding SCB */ 2563{ /* Create corresponding SCB */
2564 struct scatterlist *sglist; 2564 struct scatterlist *sglist;
2565 struct sg_entry *sg; /* Pointer to SG list */ 2565 struct sg_entry *sg; /* Pointer to SG list */
2566 int i; 2566 int i, nseg;
2567 long total_len; 2567 long total_len;
2568 dma_addr_t dma_addr; 2568 dma_addr_t dma_addr;
2569 2569
@@ -2600,34 +2600,26 @@ static void initio_build_scb(struct initio_host * host, struct scsi_ctrl_blk * c
2600 } 2600 }
2601 2601
2602 /* todo handle map_sg error */ 2602 /* todo handle map_sg error */
2603 if (cmnd->use_sg) { 2603 nseg = scsi_dma_map(cmnd);
2604 BUG_ON(nseg < 0);
2605 if (nseg) {
2604 dma_addr = dma_map_single(&host->pci_dev->dev, &cblk->sglist[0], 2606 dma_addr = dma_map_single(&host->pci_dev->dev, &cblk->sglist[0],
2605 sizeof(struct sg_entry) * TOTAL_SG_ENTRY, 2607 sizeof(struct sg_entry) * TOTAL_SG_ENTRY,
2606 DMA_BIDIRECTIONAL); 2608 DMA_BIDIRECTIONAL);
2607 cblk->bufptr = cpu_to_le32((u32)dma_addr); 2609 cblk->bufptr = cpu_to_le32((u32)dma_addr);
2608 cmnd->SCp.dma_handle = dma_addr; 2610 cmnd->SCp.dma_handle = dma_addr;
2609 2611
2610 sglist = (struct scatterlist *) cmnd->request_buffer;
2611 cblk->sglen = dma_map_sg(&host->pci_dev->dev, sglist,
2612 cmnd->use_sg, cmnd->sc_data_direction);
2613 2612
2614 cblk->flags |= SCF_SG; /* Turn on SG list flag */ 2613 cblk->flags |= SCF_SG; /* Turn on SG list flag */
2615 for (i = 0, total_len = 0, sg = &cblk->sglist[0]; /* 1.01g */ 2614 total_len = 0;
2616 i < cblk->sglen; i++, sg++, sglist++) { 2615 sg = &cblk->sglist[0];
2616 scsi_for_each_sg(cmnd, sglist, cblk->sglen, i) {
2617 sg->data = cpu_to_le32((u32)sg_dma_address(sglist)); 2617 sg->data = cpu_to_le32((u32)sg_dma_address(sglist));
2618 total_len += sg->len = cpu_to_le32((u32)sg_dma_len(sglist)); 2618 total_len += sg->len = cpu_to_le32((u32)sg_dma_len(sglist));
2619 } 2619 }
2620 2620
2621 cblk->buflen = (cmnd->request_bufflen > total_len) ? 2621 cblk->buflen = (scsi_bufflen(cmnd) > total_len) ?
2622 total_len : cmnd->request_bufflen; 2622 total_len : scsi_bufflen(cmnd);
2623 } else if (cmnd->request_bufflen) { /* Non SG */
2624 dma_addr = dma_map_single(&host->pci_dev->dev, cmnd->request_buffer,
2625 cmnd->request_bufflen,
2626 cmnd->sc_data_direction);
2627 cmnd->SCp.dma_handle = dma_addr;
2628 cblk->bufptr = cpu_to_le32((u32)dma_addr);
2629 cblk->buflen = cpu_to_le32((u32)cmnd->request_bufflen);
2630 cblk->sglen = 0;
2631 } else { /* No data transfer required */ 2623 } else { /* No data transfer required */
2632 cblk->buflen = 0; 2624 cblk->buflen = 0;
2633 cblk->sglen = 0; 2625 cblk->sglen = 0;
@@ -2750,18 +2742,12 @@ static void i91u_unmap_scb(struct pci_dev *pci_dev, struct scsi_cmnd *cmnd)
2750 } 2742 }
2751 2743
2752 /* request buffer */ 2744 /* request buffer */
2753 if (cmnd->use_sg) { 2745 if (scsi_sg_count(cmnd)) {
2754 dma_unmap_single(&pci_dev->dev, cmnd->SCp.dma_handle, 2746 dma_unmap_single(&pci_dev->dev, cmnd->SCp.dma_handle,
2755 sizeof(struct sg_entry) * TOTAL_SG_ENTRY, 2747 sizeof(struct sg_entry) * TOTAL_SG_ENTRY,
2756 DMA_BIDIRECTIONAL); 2748 DMA_BIDIRECTIONAL);
2757 2749
2758 dma_unmap_sg(&pci_dev->dev, cmnd->request_buffer, 2750 scsi_dma_unmap(cmnd);
2759 cmnd->use_sg,
2760 cmnd->sc_data_direction);
2761 } else if (cmnd->request_bufflen) {
2762 dma_unmap_single(&pci_dev->dev, cmnd->SCp.dma_handle,
2763 cmnd->request_bufflen,
2764 cmnd->sc_data_direction);
2765 } 2751 }
2766} 2752}
2767 2753