Skip to content

Commit a25381a

Browse files
author
Christoph Hellwig
committed
swiotlb: refactor coherent buffer freeing
Factor out a new swiotlb_free_buffer helper that checks if an address is allocated from the swiotlb bounce buffer, and if yes frees it. This allows to simplify the swiotlb_free implemenation that uses dma_direct_free to free the non-bounce buffer allocations. Signed-off-by: Christoph Hellwig <[email protected]> Acked-by: Christian König <[email protected]>
1 parent aaf796d commit a25381a

File tree

1 file changed

+21
-14
lines changed

1 file changed

+21
-14
lines changed

lib/swiotlb.c

Lines changed: 21 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -780,22 +780,31 @@ swiotlb_alloc_coherent(struct device *hwdev, size_t size,
780780
}
781781
EXPORT_SYMBOL(swiotlb_alloc_coherent);
782782

783+
static bool swiotlb_free_buffer(struct device *dev, size_t size,
784+
dma_addr_t dma_addr)
785+
{
786+
phys_addr_t phys_addr = dma_to_phys(dev, dma_addr);
787+
788+
WARN_ON_ONCE(irqs_disabled());
789+
790+
if (!is_swiotlb_buffer(phys_addr))
791+
return false;
792+
793+
/*
794+
* DMA_TO_DEVICE to avoid memcpy in swiotlb_tbl_unmap_single.
795+
* DMA_ATTR_SKIP_CPU_SYNC is optional.
796+
*/
797+
swiotlb_tbl_unmap_single(dev, phys_addr, size, DMA_TO_DEVICE,
798+
DMA_ATTR_SKIP_CPU_SYNC);
799+
return true;
800+
}
801+
783802
void
784803
swiotlb_free_coherent(struct device *hwdev, size_t size, void *vaddr,
785804
dma_addr_t dev_addr)
786805
{
787-
phys_addr_t paddr = dma_to_phys(hwdev, dev_addr);
788-
789-
WARN_ON(irqs_disabled());
790-
if (!is_swiotlb_buffer(paddr))
806+
if (!swiotlb_free_buffer(hwdev, size, dev_addr))
791807
free_pages((unsigned long)vaddr, get_order(size));
792-
else
793-
/*
794-
* DMA_TO_DEVICE to avoid memcpy in swiotlb_tbl_unmap_single.
795-
* DMA_ATTR_SKIP_CPU_SYNC is optional.
796-
*/
797-
swiotlb_tbl_unmap_single(hwdev, paddr, size, DMA_TO_DEVICE,
798-
DMA_ATTR_SKIP_CPU_SYNC);
799808
}
800809
EXPORT_SYMBOL(swiotlb_free_coherent);
801810

@@ -1110,9 +1119,7 @@ void *swiotlb_alloc(struct device *dev, size_t size, dma_addr_t *dma_handle,
11101119
void swiotlb_free(struct device *dev, size_t size, void *vaddr,
11111120
dma_addr_t dma_addr, unsigned long attrs)
11121121
{
1113-
if (is_swiotlb_buffer(dma_to_phys(dev, dma_addr)))
1114-
swiotlb_free_coherent(dev, size, vaddr, dma_addr);
1115-
else
1122+
if (!swiotlb_free_buffer(dev, size, dma_addr))
11161123
dma_direct_free(dev, size, vaddr, dma_addr, attrs);
11171124
}
11181125

0 commit comments

Comments
 (0)