Commit 0ebbe398 authored by Duc Dang's avatar Duc Dang Committed by Greg Kroah-Hartman

usb: make xhci platform driver use 64 bit or 32 bit DMA

The xhci platform driver needs to work on systems that
either only support 64-bit DMA or only support 32-bit DMA.
Attempt to set a coherent dma mask for 64-bit DMA, and
attempt again with 32-bit DMA if that fails.

[dhdang: regenerate the patch over v4.3-rc1 and address new comments]
Signed-off-by: default avatarMark Langsdorf <mlangsdo@redhat.com>
Tested-by: default avatarMark Salter <msalter@redhat.com>
Signed-off-by: default avatarDuc Dang <dhdang@apm.com>
Acked-by: default avatarArnd Bergmann <arnd@arndb.de>
Signed-off-by: default avatarMathias Nyman <mathias.nyman@linux.intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 8451a34f
...@@ -93,14 +93,20 @@ static int xhci_plat_probe(struct platform_device *pdev) ...@@ -93,14 +93,20 @@ static int xhci_plat_probe(struct platform_device *pdev)
if (irq < 0) if (irq < 0)
return -ENODEV; return -ENODEV;
/* Initialize dma_mask and coherent_dma_mask to 32-bits */ /* Try to set 64-bit DMA first */
ret = dma_set_coherent_mask(&pdev->dev, DMA_BIT_MASK(32)); if (WARN_ON(!pdev->dev.dma_mask))
if (ret) /* Platform did not initialize dma_mask */
return ret; ret = dma_coerce_mask_and_coherent(&pdev->dev,
if (!pdev->dev.dma_mask) DMA_BIT_MASK(64));
pdev->dev.dma_mask = &pdev->dev.coherent_dma_mask;
else else
dma_set_mask(&pdev->dev, DMA_BIT_MASK(32)); ret = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(64));
/* If seting 64-bit DMA mask fails, fall back to 32-bit DMA mask */
if (ret) {
ret = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(32));
if (ret)
return ret;
}
hcd = usb_create_hcd(driver, &pdev->dev, dev_name(&pdev->dev)); hcd = usb_create_hcd(driver, &pdev->dev, dev_name(&pdev->dev));
if (!hcd) if (!hcd)
......
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