|
@@ -1064,7 +1064,7 @@ static int sdhci_pci_enable_dma(struct sdhci_host *host)
|
|
{
|
|
{
|
|
struct sdhci_pci_slot *slot;
|
|
struct sdhci_pci_slot *slot;
|
|
struct pci_dev *pdev;
|
|
struct pci_dev *pdev;
|
|
- int ret;
|
|
|
|
|
|
+ int ret = -1;
|
|
|
|
|
|
slot = sdhci_priv(host);
|
|
slot = sdhci_priv(host);
|
|
pdev = slot->chip->pdev;
|
|
pdev = slot->chip->pdev;
|
|
@@ -1076,7 +1076,17 @@ static int sdhci_pci_enable_dma(struct sdhci_host *host)
|
|
"doesn't fully claim to support it.\n");
|
|
"doesn't fully claim to support it.\n");
|
|
}
|
|
}
|
|
|
|
|
|
- ret = pci_set_dma_mask(pdev, DMA_BIT_MASK(32));
|
|
|
|
|
|
+ if (host->flags & SDHCI_USE_64_BIT_DMA) {
|
|
|
|
+ if (host->quirks2 & SDHCI_QUIRK2_BROKEN_64_BIT_DMA) {
|
|
|
|
+ host->flags &= ~SDHCI_USE_64_BIT_DMA;
|
|
|
|
+ } else {
|
|
|
|
+ ret = pci_set_dma_mask(pdev, DMA_BIT_MASK(64));
|
|
|
|
+ if (ret)
|
|
|
|
+ dev_warn(&pdev->dev, "Failed to set 64-bit DMA mask\n");
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ if (ret)
|
|
|
|
+ ret = pci_set_dma_mask(pdev, DMA_BIT_MASK(32));
|
|
if (ret)
|
|
if (ret)
|
|
return ret;
|
|
return ret;
|
|
|
|
|