diff options
| -rw-r--r-- | arch/x86/kernel/pci-dma.c | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/arch/x86/kernel/pci-dma.c b/arch/x86/kernel/pci-dma.c index 0c37f16b6950..c5ef1af8e79d 100644 --- a/arch/x86/kernel/pci-dma.c +++ b/arch/x86/kernel/pci-dma.c | |||
| @@ -385,11 +385,13 @@ dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, | |||
| 385 | if (dma_alloc_from_coherent_mem(dev, size, dma_handle, &memory)) | 385 | if (dma_alloc_from_coherent_mem(dev, size, dma_handle, &memory)) |
| 386 | return memory; | 386 | return memory; |
| 387 | 387 | ||
| 388 | if (!dev) | 388 | if (!dev) { |
| 389 | dev = &fallback_dev; | 389 | dev = &fallback_dev; |
| 390 | gfp |= GFP_DMA; | ||
| 391 | } | ||
| 390 | dma_mask = dev->coherent_dma_mask; | 392 | dma_mask = dev->coherent_dma_mask; |
| 391 | if (dma_mask == 0) | 393 | if (dma_mask == 0) |
| 392 | dma_mask = DMA_32BIT_MASK; | 394 | dma_mask = (gfp & GFP_DMA) ? DMA_24BIT_MASK : DMA_32BIT_MASK; |
| 393 | 395 | ||
| 394 | /* Device not DMA able */ | 396 | /* Device not DMA able */ |
| 395 | if (dev->dma_mask == NULL) | 397 | if (dev->dma_mask == NULL) |
| @@ -403,7 +405,7 @@ dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, | |||
| 403 | larger than 16MB and in this case we have a chance of | 405 | larger than 16MB and in this case we have a chance of |
| 404 | finding fitting memory in the next higher zone first. If | 406 | finding fitting memory in the next higher zone first. If |
| 405 | not retry with true GFP_DMA. -AK */ | 407 | not retry with true GFP_DMA. -AK */ |
| 406 | if (dma_mask <= DMA_32BIT_MASK) | 408 | if (dma_mask <= DMA_32BIT_MASK && !(gfp & GFP_DMA)) |
| 407 | gfp |= GFP_DMA32; | 409 | gfp |= GFP_DMA32; |
| 408 | #endif | 410 | #endif |
| 409 | 411 | ||
