Commit 7f37441c authored by Holger Schurig's avatar Holger Schurig Committed by John W. Linville

ssb: allow compilation on systems without PCI

Makes ssb work on system without a PCI bus.
Signed-off-by: default avatarHolger Schurig <hs4233@mail.mn-solutions.de>
Signed-off-by: default avatarMichael Buesch <mb@bu3sch.de>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent e10e0dfe
...@@ -1165,15 +1165,19 @@ EXPORT_SYMBOL(ssb_dma_translation); ...@@ -1165,15 +1165,19 @@ EXPORT_SYMBOL(ssb_dma_translation);
int ssb_dma_set_mask(struct ssb_device *dev, u64 mask) int ssb_dma_set_mask(struct ssb_device *dev, u64 mask)
{ {
#ifdef CONFIG_SSB_PCIHOST
int err; int err;
#endif
switch (dev->bus->bustype) { switch (dev->bus->bustype) {
case SSB_BUSTYPE_PCI: case SSB_BUSTYPE_PCI:
#ifdef CONFIG_SSB_PCIHOST
err = pci_set_dma_mask(dev->bus->host_pci, mask); err = pci_set_dma_mask(dev->bus->host_pci, mask);
if (err) if (err)
return err; return err;
err = pci_set_consistent_dma_mask(dev->bus->host_pci, mask); err = pci_set_consistent_dma_mask(dev->bus->host_pci, mask);
return err; return err;
#endif
case SSB_BUSTYPE_SSB: case SSB_BUSTYPE_SSB:
return dma_set_mask(dev->dev, mask); return dma_set_mask(dev->dev, mask);
default: default:
...@@ -1188,6 +1192,7 @@ void * ssb_dma_alloc_consistent(struct ssb_device *dev, size_t size, ...@@ -1188,6 +1192,7 @@ void * ssb_dma_alloc_consistent(struct ssb_device *dev, size_t size,
{ {
switch (dev->bus->bustype) { switch (dev->bus->bustype) {
case SSB_BUSTYPE_PCI: case SSB_BUSTYPE_PCI:
#ifdef CONFIG_SSB_PCIHOST
if (gfp_flags & GFP_DMA) { if (gfp_flags & GFP_DMA) {
/* Workaround: The PCI API does not support passing /* Workaround: The PCI API does not support passing
* a GFP flag. */ * a GFP flag. */
...@@ -1195,6 +1200,7 @@ void * ssb_dma_alloc_consistent(struct ssb_device *dev, size_t size, ...@@ -1195,6 +1200,7 @@ void * ssb_dma_alloc_consistent(struct ssb_device *dev, size_t size,
size, dma_handle, gfp_flags); size, dma_handle, gfp_flags);
} }
return pci_alloc_consistent(dev->bus->host_pci, size, dma_handle); return pci_alloc_consistent(dev->bus->host_pci, size, dma_handle);
#endif
case SSB_BUSTYPE_SSB: case SSB_BUSTYPE_SSB:
return dma_alloc_coherent(dev->dev, size, dma_handle, gfp_flags); return dma_alloc_coherent(dev->dev, size, dma_handle, gfp_flags);
default: default:
...@@ -1210,6 +1216,7 @@ void ssb_dma_free_consistent(struct ssb_device *dev, size_t size, ...@@ -1210,6 +1216,7 @@ void ssb_dma_free_consistent(struct ssb_device *dev, size_t size,
{ {
switch (dev->bus->bustype) { switch (dev->bus->bustype) {
case SSB_BUSTYPE_PCI: case SSB_BUSTYPE_PCI:
#ifdef CONFIG_SSB_PCIHOST
if (gfp_flags & GFP_DMA) { if (gfp_flags & GFP_DMA) {
/* Workaround: The PCI API does not support passing /* Workaround: The PCI API does not support passing
* a GFP flag. */ * a GFP flag. */
...@@ -1220,6 +1227,7 @@ void ssb_dma_free_consistent(struct ssb_device *dev, size_t size, ...@@ -1220,6 +1227,7 @@ void ssb_dma_free_consistent(struct ssb_device *dev, size_t size,
pci_free_consistent(dev->bus->host_pci, size, pci_free_consistent(dev->bus->host_pci, size,
vaddr, dma_handle); vaddr, dma_handle);
return; return;
#endif
case SSB_BUSTYPE_SSB: case SSB_BUSTYPE_SSB:
dma_free_coherent(dev->dev, size, vaddr, dma_handle); dma_free_coherent(dev->dev, size, vaddr, dma_handle);
return; return;
......
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