Commit ee75fa2a authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Jens Axboe

mtip32xx: fully switch to the generic DMA API

The mtip32xx used an odd mix of the old PCI and the generic DMA API,
so switch it over to the generic API entirely.

Note that this also removes a weird fallback to just a 32-bit coherent
dma mask if the 64-bit dma mask doesn't work, as that can't even happen.
Reviewed-by: default avatarJohannes Thumshirn <jthumshirn@suse.de>
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 77a12e51
...@@ -1862,11 +1862,9 @@ static int exec_drive_taskfile(struct driver_data *dd, ...@@ -1862,11 +1862,9 @@ static int exec_drive_taskfile(struct driver_data *dd,
if (IS_ERR(outbuf)) if (IS_ERR(outbuf))
return PTR_ERR(outbuf); return PTR_ERR(outbuf);
outbuf_dma = pci_map_single(dd->pdev, outbuf_dma = dma_map_single(&dd->pdev->dev, outbuf,
outbuf, taskout, DMA_TO_DEVICE);
taskout, if (dma_mapping_error(&dd->pdev->dev, outbuf_dma)) {
DMA_TO_DEVICE);
if (pci_dma_mapping_error(dd->pdev, outbuf_dma)) {
err = -ENOMEM; err = -ENOMEM;
goto abort; goto abort;
} }
...@@ -1880,10 +1878,9 @@ static int exec_drive_taskfile(struct driver_data *dd, ...@@ -1880,10 +1878,9 @@ static int exec_drive_taskfile(struct driver_data *dd,
inbuf = NULL; inbuf = NULL;
goto abort; goto abort;
} }
inbuf_dma = pci_map_single(dd->pdev, inbuf_dma = dma_map_single(&dd->pdev->dev, inbuf,
inbuf, taskin, DMA_FROM_DEVICE);
taskin, DMA_FROM_DEVICE); if (dma_mapping_error(&dd->pdev->dev, inbuf_dma)) {
if (pci_dma_mapping_error(dd->pdev, inbuf_dma)) {
err = -ENOMEM; err = -ENOMEM;
goto abort; goto abort;
} }
...@@ -2002,11 +1999,11 @@ static int exec_drive_taskfile(struct driver_data *dd, ...@@ -2002,11 +1999,11 @@ static int exec_drive_taskfile(struct driver_data *dd,
/* reclaim the DMA buffers.*/ /* reclaim the DMA buffers.*/
if (inbuf_dma) if (inbuf_dma)
pci_unmap_single(dd->pdev, inbuf_dma, dma_unmap_single(&dd->pdev->dev, inbuf_dma, taskin,
taskin, DMA_FROM_DEVICE); DMA_FROM_DEVICE);
if (outbuf_dma) if (outbuf_dma)
pci_unmap_single(dd->pdev, outbuf_dma, dma_unmap_single(&dd->pdev->dev, outbuf_dma, taskout,
taskout, DMA_TO_DEVICE); DMA_TO_DEVICE);
inbuf_dma = 0; inbuf_dma = 0;
outbuf_dma = 0; outbuf_dma = 0;
...@@ -2053,11 +2050,11 @@ static int exec_drive_taskfile(struct driver_data *dd, ...@@ -2053,11 +2050,11 @@ static int exec_drive_taskfile(struct driver_data *dd,
} }
abort: abort:
if (inbuf_dma) if (inbuf_dma)
pci_unmap_single(dd->pdev, inbuf_dma, dma_unmap_single(&dd->pdev->dev, inbuf_dma, taskin,
taskin, DMA_FROM_DEVICE); DMA_FROM_DEVICE);
if (outbuf_dma) if (outbuf_dma)
pci_unmap_single(dd->pdev, outbuf_dma, dma_unmap_single(&dd->pdev->dev, outbuf_dma, taskout,
taskout, DMA_TO_DEVICE); DMA_TO_DEVICE);
kfree(outbuf); kfree(outbuf);
kfree(inbuf); kfree(inbuf);
...@@ -4216,18 +4213,10 @@ static int mtip_pci_probe(struct pci_dev *pdev, ...@@ -4216,18 +4213,10 @@ static int mtip_pci_probe(struct pci_dev *pdev,
goto iomap_err; goto iomap_err;
} }
if (!pci_set_dma_mask(pdev, DMA_BIT_MASK(64))) { rv = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(64));
rv = pci_set_consistent_dma_mask(pdev, DMA_BIT_MASK(64)); if (rv) {
dev_warn(&pdev->dev, "64-bit DMA enable failed\n");
if (rv) { goto setmask_err;
rv = pci_set_consistent_dma_mask(pdev,
DMA_BIT_MASK(32));
if (rv) {
dev_warn(&pdev->dev,
"64-bit DMA enable failed\n");
goto setmask_err;
}
}
} }
/* Copy the info we may need later into the private data structure. */ /* Copy the info we may need later into the private data structure. */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment