mirror of
				https://github.com/torvalds/linux.git
				synced 2025-10-31 16:48:26 +02:00 
			
		
		
		
	 358cd9afd0
			
		
	
	
		358cd9afd0
		
	
	
	
	
		
			
			When running as a Xen PV guests passed through PCI devices only have a chance to work if the Xen supplied memory map has some PCI space reserved. Add a flag xen_pv_pci_possible which will be set in early boot in case the memory map has at least one area with the type E820_TYPE_RESERVED. Signed-off-by: Juergen Gross <jgross@suse.com> Signed-off-by: Christoph Hellwig <hch@lst.de>
		
			
				
	
	
		
			94 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef _XEN_XEN_H
 | |
| #define _XEN_XEN_H
 | |
| 
 | |
| #include <linux/types.h>
 | |
| 
 | |
| enum xen_domain_type {
 | |
| 	XEN_NATIVE,		/* running on bare hardware    */
 | |
| 	XEN_PV_DOMAIN,		/* running in a PV domain      */
 | |
| 	XEN_HVM_DOMAIN,		/* running in a Xen hvm domain */
 | |
| };
 | |
| 
 | |
| #ifdef CONFIG_XEN
 | |
| extern enum xen_domain_type xen_domain_type;
 | |
| #else
 | |
| #define xen_domain_type		XEN_NATIVE
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_XEN_PVH
 | |
| extern bool xen_pvh;
 | |
| #else
 | |
| #define xen_pvh			0
 | |
| #endif
 | |
| 
 | |
| #define xen_domain()		(xen_domain_type != XEN_NATIVE)
 | |
| #define xen_pv_domain()		(xen_domain_type == XEN_PV_DOMAIN)
 | |
| #define xen_hvm_domain()	(xen_domain_type == XEN_HVM_DOMAIN)
 | |
| #define xen_pvh_domain()	(xen_pvh)
 | |
| 
 | |
| extern uint32_t xen_start_flags;
 | |
| 
 | |
| #ifdef CONFIG_XEN_PV
 | |
| extern bool xen_pv_pci_possible;
 | |
| #else
 | |
| #define xen_pv_pci_possible	0
 | |
| #endif
 | |
| 
 | |
| #include <xen/interface/hvm/start_info.h>
 | |
| extern struct hvm_start_info pvh_start_info;
 | |
| void xen_prepare_pvh(void);
 | |
| struct pt_regs;
 | |
| void xen_pv_evtchn_do_upcall(struct pt_regs *regs);
 | |
| 
 | |
| #ifdef CONFIG_XEN_DOM0
 | |
| #include <xen/interface/xen.h>
 | |
| #include <asm/xen/hypervisor.h>
 | |
| 
 | |
| #define xen_initial_domain()	(xen_domain() && \
 | |
| 				 (xen_start_flags & SIF_INITDOMAIN))
 | |
| #else  /* !CONFIG_XEN_DOM0 */
 | |
| #define xen_initial_domain()	(0)
 | |
| #endif	/* CONFIG_XEN_DOM0 */
 | |
| 
 | |
| struct bio_vec;
 | |
| struct page;
 | |
| 
 | |
| bool xen_biovec_phys_mergeable(const struct bio_vec *vec1,
 | |
| 		const struct page *page);
 | |
| 
 | |
| #if defined(CONFIG_MEMORY_HOTPLUG) && defined(CONFIG_XEN_BALLOON)
 | |
| extern u64 xen_saved_max_mem_size;
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_XEN_UNPOPULATED_ALLOC
 | |
| int xen_alloc_unpopulated_pages(unsigned int nr_pages, struct page **pages);
 | |
| void xen_free_unpopulated_pages(unsigned int nr_pages, struct page **pages);
 | |
| #include <linux/ioport.h>
 | |
| int arch_xen_unpopulated_init(struct resource **res);
 | |
| #else
 | |
| #include <xen/balloon.h>
 | |
| static inline int xen_alloc_unpopulated_pages(unsigned int nr_pages,
 | |
| 		struct page **pages)
 | |
| {
 | |
| 	return xen_alloc_ballooned_pages(nr_pages, pages);
 | |
| }
 | |
| static inline void xen_free_unpopulated_pages(unsigned int nr_pages,
 | |
| 		struct page **pages)
 | |
| {
 | |
| 	xen_free_ballooned_pages(nr_pages, pages);
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #if defined(CONFIG_XEN_DOM0) && defined(CONFIG_ACPI) && defined(CONFIG_X86)
 | |
| bool __init xen_processor_present(uint32_t acpi_id);
 | |
| #else
 | |
| #include <linux/bug.h>
 | |
| static inline bool xen_processor_present(uint32_t acpi_id)
 | |
| {
 | |
| 	BUG();
 | |
| 	return false;
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif	/* _XEN_XEN_H */
 |