mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-04 04:02:26 +00:00
asm-generic: provide generic page_to_phys and phys_to_page implementations
page_to_phys is duplicated by all architectures, and from some strange reason placed in <asm/io.h> where it doesn't fit at all. phys_to_page is only provided by a few architectures despite having a lot of open coded users. Provide generic versions in <asm-generic/memory_model.h> to make these helpers more easily usable. Note with this patch powerpc loses the CONFIG_DEBUG_VIRTUAL pfn_valid check. It will be added back in a generic version later. Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Arnd Bergmann <arnd@arndb.de>
This commit is contained in:
parent
6f043e7574
commit
c5c3238d9b
@ -88,7 +88,6 @@ static inline void * phys_to_virt(unsigned long address)
|
|||||||
|
|
||||||
#define virt_to_phys virt_to_phys
|
#define virt_to_phys virt_to_phys
|
||||||
#define phys_to_virt phys_to_virt
|
#define phys_to_virt phys_to_virt
|
||||||
#define page_to_phys(page) page_to_pa(page)
|
|
||||||
|
|
||||||
/* Maximum PIO space address supported? */
|
/* Maximum PIO space address supported? */
|
||||||
#define IO_SPACE_LIMIT 0xffff
|
#define IO_SPACE_LIMIT 0xffff
|
||||||
|
@ -42,9 +42,6 @@ static inline void ioport_unmap(void __iomem *addr)
|
|||||||
#define iowrite16be(v,p) ({ __iowmb(); __raw_writew((__force u16)cpu_to_be16(v), p); })
|
#define iowrite16be(v,p) ({ __iowmb(); __raw_writew((__force u16)cpu_to_be16(v), p); })
|
||||||
#define iowrite32be(v,p) ({ __iowmb(); __raw_writel((__force u32)cpu_to_be32(v), p); })
|
#define iowrite32be(v,p) ({ __iowmb(); __raw_writel((__force u32)cpu_to_be32(v), p); })
|
||||||
|
|
||||||
/* Change struct page to physical address */
|
|
||||||
#define page_to_phys(page) (page_to_pfn(page) << PAGE_SHIFT)
|
|
||||||
|
|
||||||
#define __raw_readb __raw_readb
|
#define __raw_readb __raw_readb
|
||||||
static inline u8 __raw_readb(const volatile void __iomem *addr)
|
static inline u8 __raw_readb(const volatile void __iomem *addr)
|
||||||
{
|
{
|
||||||
|
@ -147,12 +147,6 @@ extern unsigned long vectors_base;
|
|||||||
#define DTCM_OFFSET UL(0xfffe8000)
|
#define DTCM_OFFSET UL(0xfffe8000)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
|
||||||
* Convert a page to/from a physical address
|
|
||||||
*/
|
|
||||||
#define page_to_phys(page) (__pfn_to_phys(page_to_pfn(page)))
|
|
||||||
#define phys_to_page(phys) (pfn_to_page(__phys_to_pfn(phys)))
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* PLAT_PHYS_OFFSET is the offset (from zero) of the start of physical
|
* PLAT_PHYS_OFFSET is the offset (from zero) of the start of physical
|
||||||
* memory. This is used for XIP and NoMMU kernels, and on platforms that don't
|
* memory. This is used for XIP and NoMMU kernels, and on platforms that don't
|
||||||
|
@ -353,12 +353,6 @@ extern phys_addr_t __phys_addr_symbol(unsigned long x);
|
|||||||
#define __phys_to_virt(x) ((unsigned long)((x) - PHYS_OFFSET) | PAGE_OFFSET)
|
#define __phys_to_virt(x) ((unsigned long)((x) - PHYS_OFFSET) | PAGE_OFFSET)
|
||||||
#define __phys_to_kimg(x) ((unsigned long)((x) + kimage_voffset))
|
#define __phys_to_kimg(x) ((unsigned long)((x) + kimage_voffset))
|
||||||
|
|
||||||
/*
|
|
||||||
* Convert a page to/from a physical address
|
|
||||||
*/
|
|
||||||
#define page_to_phys(page) (__pfn_to_phys(page_to_pfn(page)))
|
|
||||||
#define phys_to_page(phys) (pfn_to_page(__phys_to_pfn(phys)))
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Note: Drivers should NOT use these. They are the wrong
|
* Note: Drivers should NOT use these. They are the wrong
|
||||||
* translation for translating DMA addresses. Use the driver
|
* translation for translating DMA addresses. Use the driver
|
||||||
|
@ -43,9 +43,6 @@ extern void *memcpy(void *to, const void *from, size_t l);
|
|||||||
#define clear_page(page) memset((page), 0, PAGE_SIZE)
|
#define clear_page(page) memset((page), 0, PAGE_SIZE)
|
||||||
#define copy_page(to, from) memcpy((to), (from), PAGE_SIZE)
|
#define copy_page(to, from) memcpy((to), (from), PAGE_SIZE)
|
||||||
|
|
||||||
#define page_to_phys(page) (page_to_pfn(page) << PAGE_SHIFT)
|
|
||||||
#define phys_to_page(paddr) (pfn_to_page(PFN_DOWN(paddr)))
|
|
||||||
|
|
||||||
struct page;
|
struct page;
|
||||||
|
|
||||||
#include <abi/page.h>
|
#include <abi/page.h>
|
||||||
|
@ -118,12 +118,6 @@ static inline void clear_page(void *page)
|
|||||||
#define clear_user_page(page, vaddr, pg) clear_page(page)
|
#define clear_user_page(page, vaddr, pg) clear_page(page)
|
||||||
#define copy_user_page(to, from, vaddr, pg) copy_page(to, from)
|
#define copy_user_page(to, from, vaddr, pg) copy_page(to, from)
|
||||||
|
|
||||||
/*
|
|
||||||
* page_to_phys - convert page to physical address
|
|
||||||
* @page - pointer to page entry in mem_map
|
|
||||||
*/
|
|
||||||
#define page_to_phys(page) (page_to_pfn(page) << PAGE_SHIFT)
|
|
||||||
|
|
||||||
static inline unsigned long virt_to_pfn(const void *kaddr)
|
static inline unsigned long virt_to_pfn(const void *kaddr)
|
||||||
{
|
{
|
||||||
return __pa(kaddr) >> PAGE_SHIFT;
|
return __pa(kaddr) >> PAGE_SHIFT;
|
||||||
|
@ -81,9 +81,6 @@ struct page *tlb_virt_to_page(unsigned long kaddr);
|
|||||||
#define pfn_to_phys(pfn) __pfn_to_phys(pfn)
|
#define pfn_to_phys(pfn) __pfn_to_phys(pfn)
|
||||||
#define phys_to_pfn(paddr) __phys_to_pfn(paddr)
|
#define phys_to_pfn(paddr) __phys_to_pfn(paddr)
|
||||||
|
|
||||||
#define page_to_phys(page) pfn_to_phys(page_to_pfn(page))
|
|
||||||
#define phys_to_page(paddr) pfn_to_page(phys_to_pfn(paddr))
|
|
||||||
|
|
||||||
#ifndef CONFIG_KFENCE
|
#ifndef CONFIG_KFENCE
|
||||||
|
|
||||||
#define page_to_virt(page) __va(page_to_phys(page))
|
#define page_to_virt(page) __va(page_to_phys(page))
|
||||||
|
@ -28,9 +28,6 @@ static inline void *phys_to_virt(unsigned long address)
|
|||||||
return __va(address);
|
return __va(address);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Permanent address of a page. */
|
|
||||||
#define page_to_phys(page) (page_to_pfn(page) << PAGE_SHIFT)
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* IO bus memory addresses are 1:1 with the physical address,
|
* IO bus memory addresses are 1:1 with the physical address,
|
||||||
* deprecated globally but still used on two machines.
|
* deprecated globally but still used on two machines.
|
||||||
|
@ -101,7 +101,6 @@ extern int page_is_ram(unsigned long pfn);
|
|||||||
|
|
||||||
# define virt_to_page(kaddr) (pfn_to_page(__pa(kaddr) >> PAGE_SHIFT))
|
# define virt_to_page(kaddr) (pfn_to_page(__pa(kaddr) >> PAGE_SHIFT))
|
||||||
# define page_to_virt(page) __va(page_to_pfn(page) << PAGE_SHIFT)
|
# define page_to_virt(page) __va(page_to_pfn(page) << PAGE_SHIFT)
|
||||||
# define page_to_phys(page) (page_to_pfn(page) << PAGE_SHIFT)
|
|
||||||
|
|
||||||
# define ARCH_PFN_OFFSET (memory_start >> PAGE_SHIFT)
|
# define ARCH_PFN_OFFSET (memory_start >> PAGE_SHIFT)
|
||||||
# endif /* __ASSEMBLY__ */
|
# endif /* __ASSEMBLY__ */
|
||||||
|
@ -125,11 +125,6 @@ static inline unsigned long isa_virt_to_bus(volatile void *address)
|
|||||||
return virt_to_phys(address);
|
return virt_to_phys(address);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Change "struct page" to physical address.
|
|
||||||
*/
|
|
||||||
#define page_to_phys(page) ((dma_addr_t)page_to_pfn(page) << PAGE_SHIFT)
|
|
||||||
|
|
||||||
void __iomem *ioremap_prot(phys_addr_t offset, unsigned long size,
|
void __iomem *ioremap_prot(phys_addr_t offset, unsigned long size,
|
||||||
unsigned long prot_val);
|
unsigned long prot_val);
|
||||||
void iounmap(const volatile void __iomem *addr);
|
void iounmap(const volatile void __iomem *addr);
|
||||||
|
@ -28,9 +28,6 @@
|
|||||||
void __iomem *ioremap(unsigned long physaddr, unsigned long size);
|
void __iomem *ioremap(unsigned long physaddr, unsigned long size);
|
||||||
void iounmap(void __iomem *addr);
|
void iounmap(void __iomem *addr);
|
||||||
|
|
||||||
/* Pages to physical address... */
|
|
||||||
#define page_to_phys(page) virt_to_phys(page_to_virt(page))
|
|
||||||
|
|
||||||
/* Macros used for converting between virtual and physical mappings. */
|
/* Macros used for converting between virtual and physical mappings. */
|
||||||
#define phys_to_virt(vaddr) \
|
#define phys_to_virt(vaddr) \
|
||||||
((void *)((unsigned long)(vaddr) | CONFIG_NIOS2_KERNEL_REGION_BASE))
|
((void *)((unsigned long)(vaddr) | CONFIG_NIOS2_KERNEL_REGION_BASE))
|
||||||
|
@ -80,8 +80,6 @@ static inline unsigned long virt_to_pfn(const void *kaddr)
|
|||||||
#define virt_to_page(addr) \
|
#define virt_to_page(addr) \
|
||||||
(mem_map + (((unsigned long)(addr)-PAGE_OFFSET) >> PAGE_SHIFT))
|
(mem_map + (((unsigned long)(addr)-PAGE_OFFSET) >> PAGE_SHIFT))
|
||||||
|
|
||||||
#define page_to_phys(page) ((dma_addr_t)page_to_pfn(page) << PAGE_SHIFT)
|
|
||||||
|
|
||||||
#define virt_addr_valid(kaddr) (pfn_valid(virt_to_pfn(kaddr)))
|
#define virt_addr_valid(kaddr) (pfn_valid(virt_to_pfn(kaddr)))
|
||||||
|
|
||||||
#endif /* __ASSEMBLY__ */
|
#endif /* __ASSEMBLY__ */
|
||||||
|
@ -168,7 +168,6 @@ extern int npmem_ranges;
|
|||||||
|
|
||||||
#define virt_addr_valid(kaddr) pfn_valid(__pa(kaddr) >> PAGE_SHIFT)
|
#define virt_addr_valid(kaddr) pfn_valid(__pa(kaddr) >> PAGE_SHIFT)
|
||||||
|
|
||||||
#define page_to_phys(page) (page_to_pfn(page) << PAGE_SHIFT)
|
|
||||||
#define virt_to_page(kaddr) pfn_to_page(__pa(kaddr) >> PAGE_SHIFT)
|
#define virt_to_page(kaddr) pfn_to_page(__pa(kaddr) >> PAGE_SHIFT)
|
||||||
|
|
||||||
#include <asm-generic/memory_model.h>
|
#include <asm-generic/memory_model.h>
|
||||||
|
@ -969,18 +969,6 @@ static inline void * phys_to_virt(unsigned long address)
|
|||||||
}
|
}
|
||||||
#define phys_to_virt phys_to_virt
|
#define phys_to_virt phys_to_virt
|
||||||
|
|
||||||
/*
|
|
||||||
* Change "struct page" to physical address.
|
|
||||||
*/
|
|
||||||
static inline phys_addr_t page_to_phys(struct page *page)
|
|
||||||
{
|
|
||||||
unsigned long pfn = page_to_pfn(page);
|
|
||||||
|
|
||||||
WARN_ON(IS_ENABLED(CONFIG_DEBUG_VIRTUAL) && !pfn_valid(pfn));
|
|
||||||
|
|
||||||
return PFN_PHYS(pfn);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 32 bits still uses virt_to_bus() for its implementation of DMA
|
* 32 bits still uses virt_to_bus() for its implementation of DMA
|
||||||
* mappings se we have to keep it defined here. We also have some old
|
* mappings se we have to keep it defined here. We also have some old
|
||||||
|
@ -194,9 +194,6 @@ extern phys_addr_t __phys_addr_symbol(unsigned long x);
|
|||||||
#define virt_to_page(vaddr) (pfn_to_page(virt_to_pfn(vaddr)))
|
#define virt_to_page(vaddr) (pfn_to_page(virt_to_pfn(vaddr)))
|
||||||
#define page_to_virt(page) (pfn_to_virt(page_to_pfn(page)))
|
#define page_to_virt(page) (pfn_to_virt(page_to_pfn(page)))
|
||||||
|
|
||||||
#define page_to_phys(page) (pfn_to_phys(page_to_pfn(page)))
|
|
||||||
#define phys_to_page(paddr) (pfn_to_page(phys_to_pfn(paddr)))
|
|
||||||
|
|
||||||
#define sym_to_pfn(x) __phys_to_pfn(__pa_symbol(x))
|
#define sym_to_pfn(x) __phys_to_pfn(__pa_symbol(x))
|
||||||
|
|
||||||
unsigned long kaslr_offset(void);
|
unsigned long kaslr_offset(void);
|
||||||
|
@ -245,9 +245,7 @@ static inline unsigned long __phys_addr(unsigned long x, bool is_31bit)
|
|||||||
#define phys_to_pfn(phys) ((phys) >> PAGE_SHIFT)
|
#define phys_to_pfn(phys) ((phys) >> PAGE_SHIFT)
|
||||||
#define pfn_to_phys(pfn) ((pfn) << PAGE_SHIFT)
|
#define pfn_to_phys(pfn) ((pfn) << PAGE_SHIFT)
|
||||||
|
|
||||||
#define phys_to_page(phys) pfn_to_page(phys_to_pfn(phys))
|
|
||||||
#define phys_to_folio(phys) page_folio(phys_to_page(phys))
|
#define phys_to_folio(phys) page_folio(phys_to_page(phys))
|
||||||
#define page_to_phys(page) pfn_to_phys(page_to_pfn(page))
|
|
||||||
#define folio_to_phys(page) pfn_to_phys(folio_pfn(folio))
|
#define folio_to_phys(page) pfn_to_phys(folio_pfn(folio))
|
||||||
|
|
||||||
static inline void *pfn_to_virt(unsigned long pfn)
|
static inline void *pfn_to_virt(unsigned long pfn)
|
||||||
|
@ -147,7 +147,6 @@ typedef struct page *pgtable_t;
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define pfn_to_kaddr(pfn) __va((pfn) << PAGE_SHIFT)
|
#define pfn_to_kaddr(pfn) __va((pfn) << PAGE_SHIFT)
|
||||||
#define page_to_phys(page) (page_to_pfn(page) << PAGE_SHIFT)
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* PFN = physical frame number (ie PFN 0 == physical address 0)
|
* PFN = physical frame number (ie PFN 0 == physical address 0)
|
||||||
|
@ -2,8 +2,6 @@
|
|||||||
#ifndef ___ASM_SPARC_PAGE_H
|
#ifndef ___ASM_SPARC_PAGE_H
|
||||||
#define ___ASM_SPARC_PAGE_H
|
#define ___ASM_SPARC_PAGE_H
|
||||||
|
|
||||||
#define page_to_phys(page) (page_to_pfn(page) << PAGE_SHIFT)
|
|
||||||
|
|
||||||
#if defined(__sparc__) && defined(__arch64__)
|
#if defined(__sparc__) && defined(__arch64__)
|
||||||
#include <asm/page_64.h>
|
#include <asm/page_64.h>
|
||||||
#else
|
#else
|
||||||
|
@ -287,9 +287,7 @@ static inline int pte_same(pte_t pte_a, pte_t pte_b)
|
|||||||
* and a page entry and page directory to the page they refer to.
|
* and a page entry and page directory to the page they refer to.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define phys_to_page(phys) pfn_to_page(phys_to_pfn(phys))
|
|
||||||
#define __virt_to_page(virt) phys_to_page(__pa(virt))
|
#define __virt_to_page(virt) phys_to_page(__pa(virt))
|
||||||
#define page_to_phys(page) pfn_to_phys(page_to_pfn(page))
|
|
||||||
#define virt_to_page(addr) __virt_to_page((const unsigned long) addr)
|
#define virt_to_page(addr) __virt_to_page((const unsigned long) addr)
|
||||||
|
|
||||||
#define mk_pte(page, pgprot) \
|
#define mk_pte(page, pgprot) \
|
||||||
|
@ -151,11 +151,6 @@ static inline void *phys_to_virt(phys_addr_t address)
|
|||||||
}
|
}
|
||||||
#define phys_to_virt phys_to_virt
|
#define phys_to_virt phys_to_virt
|
||||||
|
|
||||||
/*
|
|
||||||
* Change "struct page" to physical address.
|
|
||||||
*/
|
|
||||||
#define page_to_phys(page) ((dma_addr_t)page_to_pfn(page) << PAGE_SHIFT)
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* ISA I/O bus memory addresses are 1:1 with the physical address.
|
* ISA I/O bus memory addresses are 1:1 with the physical address.
|
||||||
* However, we truncate the address to unsigned int to avoid undesirable
|
* However, we truncate the address to unsigned int to avoid undesirable
|
||||||
|
@ -195,7 +195,6 @@ static inline unsigned long ___pa(unsigned long va)
|
|||||||
#define virt_to_page(kaddr) pfn_to_page(__pa(kaddr) >> PAGE_SHIFT)
|
#define virt_to_page(kaddr) pfn_to_page(__pa(kaddr) >> PAGE_SHIFT)
|
||||||
#define page_to_virt(page) __va(page_to_pfn(page) << PAGE_SHIFT)
|
#define page_to_virt(page) __va(page_to_pfn(page) << PAGE_SHIFT)
|
||||||
#define virt_addr_valid(kaddr) pfn_valid(__pa(kaddr) >> PAGE_SHIFT)
|
#define virt_addr_valid(kaddr) pfn_valid(__pa(kaddr) >> PAGE_SHIFT)
|
||||||
#define page_to_phys(page) (page_to_pfn(page) << PAGE_SHIFT)
|
|
||||||
|
|
||||||
#endif /* __ASSEMBLY__ */
|
#endif /* __ASSEMBLY__ */
|
||||||
|
|
||||||
|
@ -64,6 +64,9 @@ static inline int pfn_valid(unsigned long pfn)
|
|||||||
#define page_to_pfn __page_to_pfn
|
#define page_to_pfn __page_to_pfn
|
||||||
#define pfn_to_page __pfn_to_page
|
#define pfn_to_page __pfn_to_page
|
||||||
|
|
||||||
|
#define page_to_phys(page) PFN_PHYS(page_to_pfn(page))
|
||||||
|
#define phys_to_page(phys) pfn_to_page(PHYS_PFN(phys))
|
||||||
|
|
||||||
#endif /* __ASSEMBLY__ */
|
#endif /* __ASSEMBLY__ */
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user