49 lines
1.3 KiB
C
49 lines
1.3 KiB
C
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||
|
#ifndef __KVM_HYP_MEMORY_H
|
||
|
#define __KVM_HYP_MEMORY_H
|
||
|
|
||
|
#include <asm/kvm_mmu.h>
|
||
|
#include <asm/page.h>
|
||
|
|
||
|
#include <linux/types.h>
|
||
|
|
||
|
struct hyp_page {
|
||
|
unsigned short refcount;
|
||
|
unsigned short order;
|
||
|
};
|
||
|
|
||
|
extern u64 __hyp_vmemmap;
|
||
|
#define hyp_vmemmap ((struct hyp_page *)__hyp_vmemmap)
|
||
|
|
||
|
#define __hyp_va(phys) ((void *)((phys_addr_t)(phys) - hyp_physvirt_offset))
|
||
|
|
||
|
static inline void *hyp_phys_to_virt(phys_addr_t phys)
|
||
|
{
|
||
|
return __hyp_va(phys);
|
||
|
}
|
||
|
|
||
|
static inline phys_addr_t hyp_virt_to_phys(void *addr)
|
||
|
{
|
||
|
return __hyp_pa(addr);
|
||
|
}
|
||
|
|
||
|
#define hyp_phys_to_pfn(phys) ((phys) >> PAGE_SHIFT)
|
||
|
#define hyp_pfn_to_phys(pfn) ((phys_addr_t)((pfn) << PAGE_SHIFT))
|
||
|
#define hyp_phys_to_page(phys) (&hyp_vmemmap[hyp_phys_to_pfn(phys)])
|
||
|
#define hyp_virt_to_page(virt) hyp_phys_to_page(__hyp_pa(virt))
|
||
|
#define hyp_virt_to_pfn(virt) hyp_phys_to_pfn(__hyp_pa(virt))
|
||
|
|
||
|
#define hyp_page_to_pfn(page) ((struct hyp_page *)(page) - hyp_vmemmap)
|
||
|
#define hyp_page_to_phys(page) hyp_pfn_to_phys((hyp_page_to_pfn(page)))
|
||
|
#define hyp_page_to_virt(page) __hyp_va(hyp_page_to_phys(page))
|
||
|
#define hyp_page_to_pool(page) (((struct hyp_page *)page)->pool)
|
||
|
|
||
|
static inline int hyp_page_count(void *addr)
|
||
|
{
|
||
|
struct hyp_page *p = hyp_virt_to_page(addr);
|
||
|
|
||
|
return p->refcount;
|
||
|
}
|
||
|
|
||
|
#endif /* __KVM_HYP_MEMORY_H */
|