These new architecture-specific interfaces subsume the existing __weak function hooks.
Signed-off-by: Ian Campbell <ian.campb...@citrix.com> Cc: FUJITA Tomonori <fujita.tomon...@lab.ntt.co.jp> Cc: Jeremy Fitzhardinge <jer...@goop.org> Cc: Olaf Kirch <o...@suse.de> Cc: Greg KH <gre...@suse.de> Cc: Tony Luck <tony.l...@intel.com> Cc: Becky Bruce <bec...@kernel.crashing.org> Cc: Benjamin Herrenschmidt <b...@kernel.crashing.org> Cc: Kumar Gala <ga...@kernel.crashing.org> Cc: Jeremy Fitzhardinge <jer...@goop.org> Cc: x...@kernel.org Cc: linux-i...@vger.kernel.org Cc: linuxppc-dev@ozlabs.org --- include/linux/swiotlb.h | 5 ----- lib/swiotlb.c | 18 ++++-------------- 2 files changed, 4 insertions(+), 19 deletions(-) diff --git a/include/linux/swiotlb.h b/include/linux/swiotlb.h index cb1a663..954feec 100644 --- a/include/linux/swiotlb.h +++ b/include/linux/swiotlb.h @@ -27,11 +27,6 @@ swiotlb_init(void); extern void *swiotlb_alloc_boot(size_t bytes, unsigned long nslabs); extern void *swiotlb_alloc(unsigned order, unsigned long nslabs); -extern dma_addr_t swiotlb_phys_to_bus(struct device *hwdev, - phys_addr_t address); -extern phys_addr_t swiotlb_bus_to_phys(struct device *hwdev, - dma_addr_t address); - extern int swiotlb_arch_range_needs_mapping(phys_addr_t paddr, size_t size); extern void diff --git a/lib/swiotlb.c b/lib/swiotlb.c index bffe6d7..baa1991 100644 --- a/lib/swiotlb.c +++ b/lib/swiotlb.c @@ -124,25 +124,15 @@ void * __weak swiotlb_alloc(unsigned order, unsigned long nslabs) return (void *)__get_free_pages(GFP_DMA | __GFP_NOWARN, order); } -dma_addr_t __weak swiotlb_phys_to_bus(struct device *hwdev, phys_addr_t paddr) -{ - return paddr; -} - -phys_addr_t __weak swiotlb_bus_to_phys(struct device *hwdev, dma_addr_t baddr) -{ - return baddr; -} - static dma_addr_t swiotlb_virt_to_bus(struct device *hwdev, volatile void *address) { - return swiotlb_phys_to_bus(hwdev, virt_to_phys(address)); + return phys_to_dma(hwdev, virt_to_phys(address)); } void * __weak swiotlb_bus_to_virt(struct device *hwdev, dma_addr_t address) { - return phys_to_virt(swiotlb_bus_to_phys(hwdev, address)); + return phys_to_virt(dma_to_phys(hwdev, address)); } int __weak swiotlb_arch_address_needs_mapping(struct device *hwdev, @@ -646,7 +636,7 @@ dma_addr_t swiotlb_map_page(struct device *dev, struct page *page, struct dma_attrs *attrs) { phys_addr_t phys = page_to_phys(page) + offset; - dma_addr_t dev_addr = swiotlb_phys_to_bus(dev, phys); + dma_addr_t dev_addr = phys_to_dma(dev, phys); void *map; BUG_ON(dir == DMA_NONE); @@ -817,7 +807,7 @@ swiotlb_map_sg_attrs(struct device *hwdev, struct scatterlist *sgl, int nelems, for_each_sg(sgl, sg, nelems, i) { phys_addr_t paddr = sg_phys(sg); - dma_addr_t dev_addr = swiotlb_phys_to_bus(hwdev, paddr); + dma_addr_t dev_addr = phys_to_dma(hwdev, paddr); if (range_needs_mapping(paddr, sg->length) || address_needs_mapping(hwdev, dev_addr, sg->length)) { -- 1.5.6.5 _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@ozlabs.org https://ozlabs.org/mailman/listinfo/linuxppc-dev