Skip to content

Commit 732f323

Browse files
hreineckemartinkpetersen
authored andcommitted
scsi: csiostor: fix calls to dma_set_mask_and_coherent()
The change to use dma_set_mask_and_coherent() incorrectly made a second call with the 32 bit DMA mask value when the call with the 64 bit DMA mask value succeeded. Fixes: c22b332 ("scsi: csiostor: switch to generic DMA API") Cc: <stable@vger.kernel.org> Signed-off-by: Hannes Reinecke <hare@suse.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Ewan D. Milne <emilne@redhat.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
1 parent 11ea382 commit 732f323

File tree

1 file changed

+5
-2
lines changed

1 file changed

+5
-2
lines changed

drivers/scsi/csiostor/csio_init.c

Lines changed: 5 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -210,8 +210,11 @@ csio_pci_init(struct pci_dev *pdev, int *bars)
210210
pci_set_master(pdev);
211211
pci_try_set_mwi(pdev);
212212

213-
if (dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(64)) ||
214-
dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(32))) {
213+
rv = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(64));
214+
if (rv)
215+
rv = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(32));
216+
if (rv) {
217+
rv = -ENODEV;
215218
dev_err(&pdev->dev, "No suitable DMA available.\n");
216219
goto err_release_regions;
217220
}

0 commit comments

Comments
 (0)