]> www.infradead.org Git - users/hch/block.git/commitdiff
swiotlb-xen: remove XEN_PFN_PHYS
authorStefano Stabellini <stefano.stabellini@xilinx.com>
Fri, 10 Jul 2020 22:34:24 +0000 (15:34 -0700)
committerJuergen Gross <jgross@suse.com>
Tue, 4 Aug 2020 05:50:43 +0000 (07:50 +0200)
XEN_PFN_PHYS is only used in one place in swiotlb-xen making things more
complex than need to be.

Remove the definition of XEN_PFN_PHYS and open code the cast in the one
place where it is needed.

Signed-off-by: Stefano Stabellini <stefano.stabellini@xilinx.com>
Reviewed-by: Juergen Gross <jgross@suse.com>
Link: https://lore.kernel.org/r/20200710223427.6897-8-sstabellini@kernel.org
Signed-off-by: Juergen Gross <jgross@suse.com>
drivers/xen/swiotlb-xen.c
include/xen/page.h

index e2c35f45f91e7cc81114215f3100104516f3d067..03d118b6c1418c332718f2a567ed2cef9d66538e 100644 (file)
@@ -52,11 +52,6 @@ static unsigned long xen_io_tlb_nslabs;
  * Quick lookup value of the bus address of the IOTLB.
  */
 
-/*
- * Both of these functions should avoid XEN_PFN_PHYS because phys_addr_t
- * can be 32bit when dma_addr_t is 64bit leading to a loss in
- * information if the shift is done before casting to 64bit.
- */
 static inline dma_addr_t xen_phys_to_bus(struct device *dev, phys_addr_t paddr)
 {
        unsigned long bfn = pfn_to_bfn(XEN_PFN_DOWN(paddr));
@@ -101,7 +96,7 @@ static int is_xen_swiotlb_buffer(struct device *dev, dma_addr_t dma_addr)
 {
        unsigned long bfn = XEN_PFN_DOWN(dma_addr);
        unsigned long xen_pfn = bfn_to_local_pfn(bfn);
-       phys_addr_t paddr = XEN_PFN_PHYS(xen_pfn);
+       phys_addr_t paddr = (phys_addr_t)xen_pfn << XEN_PAGE_SHIFT;
 
        /* If the address is outside our domain, it CAN
         * have the same virtual address as another address
index df6d6b6ec66e9e75774c25d102ce0772b8275cf0..285677b42943ae03955dc96cc4c0e9c20f5570f9 100644 (file)
@@ -24,7 +24,6 @@
 
 #define XEN_PFN_DOWN(x)        ((x) >> XEN_PAGE_SHIFT)
 #define XEN_PFN_UP(x)  (((x) + XEN_PAGE_SIZE-1) >> XEN_PAGE_SHIFT)
-#define XEN_PFN_PHYS(x)        ((phys_addr_t)(x) << XEN_PAGE_SHIFT)
 
 #include <asm/xen/page.h>