diff options
| author | Mark Brown <[email protected]> | 2015-10-12 18:09:27 +0100 | 
|---|---|---|
| committer | Mark Brown <[email protected]> | 2015-10-12 18:09:27 +0100 | 
| commit | 79828b4fa835f73cdaf4bffa48696abdcbea9d02 (patch) | |
| tree | 5e0fa7156acb75ba603022bc807df8f2fedb97a8 /arch/arm/include/asm/xen/page.h | |
| parent | 721b51fcf91898299d96f4b72cb9434cda29dce6 (diff) | |
| parent | 8c1a9d6323abf0fb1e5dad96cf3f1c783505ea5a (diff) | |
Merge remote-tracking branch 'asoc/fix/rt5645' into asoc-fix-rt5645
Diffstat (limited to 'arch/arm/include/asm/xen/page.h')
| -rw-r--r-- | arch/arm/include/asm/xen/page.h | 44 | 
1 files changed, 22 insertions, 22 deletions
diff --git a/arch/arm/include/asm/xen/page.h b/arch/arm/include/asm/xen/page.h index 1bee8ca12494..127956353b00 100644 --- a/arch/arm/include/asm/xen/page.h +++ b/arch/arm/include/asm/xen/page.h @@ -34,7 +34,19 @@ typedef struct xpaddr {  unsigned long __pfn_to_mfn(unsigned long pfn);  extern struct rb_root phys_to_mach; -static inline unsigned long pfn_to_mfn(unsigned long pfn) +/* Pseudo-physical <-> Guest conversion */ +static inline unsigned long pfn_to_gfn(unsigned long pfn) +{ +	return pfn; +} + +static inline unsigned long gfn_to_pfn(unsigned long gfn) +{ +	return gfn; +} + +/* Pseudo-physical <-> BUS conversion */ +static inline unsigned long pfn_to_bfn(unsigned long pfn)  {  	unsigned long mfn; @@ -47,33 +59,21 @@ static inline unsigned long pfn_to_mfn(unsigned long pfn)  	return pfn;  } -static inline unsigned long mfn_to_pfn(unsigned long mfn) +static inline unsigned long bfn_to_pfn(unsigned long bfn)  { -	return mfn; +	return bfn;  } -#define mfn_to_local_pfn(mfn) mfn_to_pfn(mfn) +#define bfn_to_local_pfn(bfn)	bfn_to_pfn(bfn) -static inline xmaddr_t phys_to_machine(xpaddr_t phys) -{ -	unsigned offset = phys.paddr & ~PAGE_MASK; -	return XMADDR(PFN_PHYS(pfn_to_mfn(PFN_DOWN(phys.paddr))) | offset); -} - -static inline xpaddr_t machine_to_phys(xmaddr_t machine) -{ -	unsigned offset = machine.maddr & ~PAGE_MASK; -	return XPADDR(PFN_PHYS(mfn_to_pfn(PFN_DOWN(machine.maddr))) | offset); -} -/* VIRT <-> MACHINE conversion */ -#define virt_to_machine(v)	(phys_to_machine(XPADDR(__pa(v)))) -#define virt_to_mfn(v)		(pfn_to_mfn(virt_to_pfn(v))) -#define mfn_to_virt(m)		(__va(mfn_to_pfn(m) << PAGE_SHIFT)) +/* VIRT <-> GUEST conversion */ +#define virt_to_gfn(v)		(pfn_to_gfn(virt_to_pfn(v))) +#define gfn_to_virt(m)		(__va(gfn_to_pfn(m) << PAGE_SHIFT)) +/* Only used in PV code. But ARM guests are always HVM. */  static inline xmaddr_t arbitrary_virt_to_machine(void *vaddr)  { -	/* TODO: assuming it is mapped in the kernel 1:1 */ -	return virt_to_machine(vaddr); +	BUG();  }  /* TODO: this shouldn't be here but it is because the frontend drivers @@ -108,7 +108,7 @@ static inline bool set_phys_to_machine(unsigned long pfn, unsigned long mfn)  bool xen_arch_need_swiotlb(struct device *dev,  			   unsigned long pfn, -			   unsigned long mfn); +			   unsigned long bfn);  unsigned long xen_get_swiotlb_free_pages(unsigned int order);  #endif /* _ASM_ARM_XEN_PAGE_H */  |