aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel/amd_iommu.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86/kernel/amd_iommu.c')
-rw-r--r--arch/x86/kernel/amd_iommu.c20
1 files changed, 18 insertions, 2 deletions
diff --git a/arch/x86/kernel/amd_iommu.c b/arch/x86/kernel/amd_iommu.c
index 59ee1b94a7ce..d129d8feba07 100644
--- a/arch/x86/kernel/amd_iommu.c
+++ b/arch/x86/kernel/amd_iommu.c
@@ -1403,10 +1403,26 @@ static dma_addr_t __map_single(struct device *dev,
1403 if (align) 1403 if (align)
1404 align_mask = (1UL << get_order(size)) - 1; 1404 align_mask = (1UL << get_order(size)) - 1;
1405 1405
1406retry:
1406 address = dma_ops_alloc_addresses(dev, dma_dom, pages, align_mask, 1407 address = dma_ops_alloc_addresses(dev, dma_dom, pages, align_mask,
1407 dma_mask); 1408 dma_mask);
1408 if (unlikely(address == bad_dma_address)) 1409 if (unlikely(address == bad_dma_address)) {
1409 goto out; 1410 /*
1411 * setting next_address here will let the address
1412 * allocator only scan the new allocated range in the
1413 * first run. This is a small optimization.
1414 */
1415 dma_dom->next_address = dma_dom->aperture_size;
1416
1417 if (alloc_new_range(iommu, dma_dom, false, GFP_ATOMIC))
1418 goto out;
1419
1420 /*
1421 * aperture was sucessfully enlarged by 128 MB, try
1422 * allocation again
1423 */
1424 goto retry;
1425 }
1410 1426
1411 start = address; 1427 start = address;
1412 for (i = 0; i < pages; ++i) { 1428 for (i = 0; i < pages; ++i) {