diff options
Diffstat (limited to 'arch/arm/include/asm/xen')
| -rw-r--r-- | arch/arm/include/asm/xen/hypervisor.h | 10 | ||||
| -rw-r--r-- | arch/arm/include/asm/xen/page-coherent.h | 26 | ||||
| -rw-r--r-- | arch/arm/include/asm/xen/page.h | 22 | 
3 files changed, 42 insertions, 16 deletions
| diff --git a/arch/arm/include/asm/xen/hypervisor.h b/arch/arm/include/asm/xen/hypervisor.h index 04ff8e7b3..95251512e 100644 --- a/arch/arm/include/asm/xen/hypervisor.h +++ b/arch/arm/include/asm/xen/hypervisor.h @@ -26,4 +26,14 @@ void __init xen_early_init(void);  static inline void xen_early_init(void) { return; }  #endif +#ifdef CONFIG_HOTPLUG_CPU +static inline void xen_arch_register_cpu(int num) +{ +} + +static inline void xen_arch_unregister_cpu(int num) +{ +} +#endif +  #endif /* _ASM_ARM_XEN_HYPERVISOR_H */ diff --git a/arch/arm/include/asm/xen/page-coherent.h b/arch/arm/include/asm/xen/page-coherent.h index efd562412..0375c8caa 100644 --- a/arch/arm/include/asm/xen/page-coherent.h +++ b/arch/arm/include/asm/xen/page-coherent.h @@ -35,11 +35,15 @@ static inline void xen_dma_map_page(struct device *hwdev, struct page *page,  	     dma_addr_t dev_addr, unsigned long offset, size_t size,  	     enum dma_data_direction dir, struct dma_attrs *attrs)  { -	bool local = PFN_DOWN(dev_addr) == page_to_pfn(page); -	/* Dom0 is mapped 1:1, so if pfn == mfn the page is local otherwise -	 * is a foreign page grant-mapped in dom0. If the page is local we -	 * can safely call the native dma_ops function, otherwise we call -	 * the xen specific function. */ +	bool local = XEN_PFN_DOWN(dev_addr) == page_to_xen_pfn(page); +	/* +	 * Dom0 is mapped 1:1, while the Linux page can be spanned accross +	 * multiple Xen page, it's not possible to have a mix of local and +	 * foreign Xen page. So if the first xen_pfn == mfn the page is local +	 * otherwise it's a foreign page grant-mapped in dom0. If the page is +	 * local we can safely call the native dma_ops function, otherwise we +	 * call the xen specific function. +	 */  	if (local)  		__generic_dma_ops(hwdev)->map_page(hwdev, page, offset, size, dir, attrs);  	else @@ -51,10 +55,14 @@ static inline void xen_dma_unmap_page(struct device *hwdev, dma_addr_t handle,  		struct dma_attrs *attrs)  {  	unsigned long pfn = PFN_DOWN(handle); -	/* Dom0 is mapped 1:1, so calling pfn_valid on a foreign mfn will -	 * always return false. If the page is local we can safely call the -	 * native dma_ops function, otherwise we call the xen specific -	 * function. */ +	/* +	 * Dom0 is mapped 1:1, while the Linux page can be spanned accross +	 * multiple Xen page, it's not possible to have a mix of local and +	 * foreign Xen page. Dom0 is mapped 1:1, so calling pfn_valid on a +	 * foreign mfn will always return false. If the page is local we can +	 * safely call the native dma_ops function, otherwise we call the xen +	 * specific function. +	 */  	if (pfn_valid(pfn)) {  		if (__generic_dma_ops(hwdev)->unmap_page)  			__generic_dma_ops(hwdev)->unmap_page(hwdev, handle, size, dir, attrs); diff --git a/arch/arm/include/asm/xen/page.h b/arch/arm/include/asm/xen/page.h index 127956353..415dbc6e4 100644 --- a/arch/arm/include/asm/xen/page.h +++ b/arch/arm/include/asm/xen/page.h @@ -13,9 +13,6 @@  #define phys_to_machine_mapping_valid(pfn) (1) -#define pte_mfn	    pte_pfn -#define mfn_pte	    pfn_pte -  /* Xen machine address */  typedef struct xmaddr {  	phys_addr_t maddr; @@ -31,6 +28,17 @@ typedef struct xpaddr {  #define INVALID_P2M_ENTRY      (~0UL) +/* + * The pseudo-physical frame (pfn) used in all the helpers is always based + * on Xen page granularity (i.e 4KB). + * + * A Linux page may be split across multiple non-contiguous Xen page so we + * have to keep track with frame based on 4KB page granularity. + * + * PV drivers should never make a direct usage of those helpers (particularly + * pfn_to_gfn and gfn_to_pfn). + */ +  unsigned long __pfn_to_mfn(unsigned long pfn);  extern struct rb_root phys_to_mach; @@ -67,8 +75,8 @@ static inline unsigned long bfn_to_pfn(unsigned long bfn)  #define bfn_to_local_pfn(bfn)	bfn_to_pfn(bfn)  /* 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)) +#define virt_to_gfn(v)		(pfn_to_gfn(virt_to_phys(v) >> XEN_PAGE_SHIFT)) +#define gfn_to_virt(m)		(__va(gfn_to_pfn(m) << XEN_PAGE_SHIFT))  /* Only used in PV code. But ARM guests are always HVM. */  static inline xmaddr_t arbitrary_virt_to_machine(void *vaddr) @@ -107,8 +115,8 @@ static inline bool set_phys_to_machine(unsigned long pfn, unsigned long mfn)  #define xen_unmap(cookie) iounmap((cookie))  bool xen_arch_need_swiotlb(struct device *dev, -			   unsigned long pfn, -			   unsigned long bfn); +			   phys_addr_t phys, +			   dma_addr_t dev_addr);  unsigned long xen_get_swiotlb_free_pages(unsigned int order);  #endif /* _ASM_ARM_XEN_PAGE_H */ | 
