diff options
Diffstat (limited to 'include/xen')
| -rw-r--r-- | include/xen/hvm.h | 34 | ||||
| -rw-r--r-- | include/xen/interface/event_channel.h | 13 | ||||
| -rw-r--r-- | include/xen/interface/memory.h | 44 | ||||
| -rw-r--r-- | include/xen/interface/platform.h | 17 | ||||
| -rw-r--r-- | include/xen/xen-ops.h | 9 | 
5 files changed, 111 insertions, 6 deletions
| diff --git a/include/xen/hvm.h b/include/xen/hvm.h index b193fa2f9fdd..13e43e41637d 100644 --- a/include/xen/hvm.h +++ b/include/xen/hvm.h @@ -5,6 +5,36 @@  #include <xen/interface/hvm/params.h>  #include <asm/xen/hypercall.h> +static const char *param_name(int op) +{ +#define PARAM(x) [HVM_PARAM_##x] = #x +	static const char *const names[] = { +		PARAM(CALLBACK_IRQ), +		PARAM(STORE_PFN), +		PARAM(STORE_EVTCHN), +		PARAM(PAE_ENABLED), +		PARAM(IOREQ_PFN), +		PARAM(BUFIOREQ_PFN), +		PARAM(TIMER_MODE), +		PARAM(HPET_ENABLED), +		PARAM(IDENT_PT), +		PARAM(DM_DOMAIN), +		PARAM(ACPI_S_STATE), +		PARAM(VM86_TSS), +		PARAM(VPT_ALIGN), +		PARAM(CONSOLE_PFN), +		PARAM(CONSOLE_EVTCHN), +	}; +#undef PARAM + +	if (op >= ARRAY_SIZE(names)) +		return "unknown"; + +	if (!names[op]) +		return "reserved"; + +	return names[op]; +}  static inline int hvm_get_parameter(int idx, uint64_t *value)  {  	struct xen_hvm_param xhv; @@ -14,8 +44,8 @@ static inline int hvm_get_parameter(int idx, uint64_t *value)  	xhv.index = idx;  	r = HYPERVISOR_hvm_op(HVMOP_get_param, &xhv);  	if (r < 0) { -		printk(KERN_ERR "Cannot get hvm parameter %d: %d!\n", -			idx, r); +		printk(KERN_ERR "Cannot get hvm parameter %s (%d): %d!\n", +			param_name(idx), idx, r);  		return r;  	}  	*value = xhv.value; diff --git a/include/xen/interface/event_channel.h b/include/xen/interface/event_channel.h index 2090881c3650..f4942921e202 100644 --- a/include/xen/interface/event_channel.h +++ b/include/xen/interface/event_channel.h @@ -177,6 +177,19 @@ struct evtchn_unmask {  	evtchn_port_t port;  }; +/* + * EVTCHNOP_reset: Close all event channels associated with specified domain. + * NOTES: + *  1. <dom> may be specified as DOMID_SELF. + *  2. Only a sufficiently-privileged domain may specify other than DOMID_SELF. + */ +#define EVTCHNOP_reset		 10 +struct evtchn_reset { +	/* IN parameters. */ +	domid_t dom; +}; +typedef struct evtchn_reset evtchn_reset_t; +  struct evtchn_op {  	uint32_t cmd; /* EVTCHNOP_* */  	union { diff --git a/include/xen/interface/memory.h b/include/xen/interface/memory.h index 90712e2072d5..b40a4315cb8b 100644 --- a/include/xen/interface/memory.h +++ b/include/xen/interface/memory.h @@ -153,6 +153,14 @@ struct xen_machphys_mapping {  };  DEFINE_GUEST_HANDLE_STRUCT(xen_machphys_mapping_t); +#define XENMAPSPACE_shared_info  0 /* shared info page */ +#define XENMAPSPACE_grant_table  1 /* grant table page */ +#define XENMAPSPACE_gmfn         2 /* GMFN */ +#define XENMAPSPACE_gmfn_range   3 /* GMFN range, XENMEM_add_to_physmap only. */ +#define XENMAPSPACE_gmfn_foreign 4 /* GMFN from another dom, +				    * XENMEM_add_to_physmap_range only. +				    */ +  /*   * Sets the GPFN at which a particular page appears in the specified guest's   * pseudophysical address space. @@ -167,8 +175,6 @@ struct xen_add_to_physmap {      uint16_t    size;      /* Source mapping space. */ -#define XENMAPSPACE_shared_info 0 /* shared info page */ -#define XENMAPSPACE_grant_table 1 /* grant table page */      unsigned int space;      /* Index into source mapping space. */ @@ -182,6 +188,24 @@ DEFINE_GUEST_HANDLE_STRUCT(xen_add_to_physmap);  /*** REMOVED ***/  /*#define XENMEM_translate_gpfn_list  8*/ +#define XENMEM_add_to_physmap_range 23 +struct xen_add_to_physmap_range { +    /* Which domain to change the mapping for. */ +    domid_t domid; +    uint16_t space; /* => enum phys_map_space */ + +    /* Number of pages to go through */ +    uint16_t size; +    domid_t foreign_domid; /* IFF gmfn_foreign */ + +    /* Indexes into space being mapped. */ +    GUEST_HANDLE(xen_ulong_t) idxs; + +    /* GPFN in domid where the source mapping page should appear. */ +    GUEST_HANDLE(xen_pfn_t) gpfns; +}; +DEFINE_GUEST_HANDLE_STRUCT(xen_add_to_physmap_range); +  /*   * Returns the pseudo-physical memory map as it was when the domain   * was started (specified by XENMEM_set_memory_map). @@ -217,4 +241,20 @@ DEFINE_GUEST_HANDLE_STRUCT(xen_memory_map);   * during a driver critical region.   */  extern spinlock_t xen_reservation_lock; + +/* + * Unmaps the page appearing at a particular GPFN from the specified guest's + * pseudophysical address space. + * arg == addr of xen_remove_from_physmap_t. + */ +#define XENMEM_remove_from_physmap      15 +struct xen_remove_from_physmap { +    /* Which domain to change the mapping for. */ +    domid_t domid; + +    /* GPFN of the current mapping of the page. */ +    xen_pfn_t gpfn; +}; +DEFINE_GUEST_HANDLE_STRUCT(xen_remove_from_physmap); +  #endif /* __XEN_PUBLIC_MEMORY_H__ */ diff --git a/include/xen/interface/platform.h b/include/xen/interface/platform.h index 4755b5fac9c7..5e36932ab407 100644 --- a/include/xen/interface/platform.h +++ b/include/xen/interface/platform.h @@ -324,6 +324,22 @@ struct xenpf_cpu_ol {  };  DEFINE_GUEST_HANDLE_STRUCT(xenpf_cpu_ol); +/* + * CMD 58 and 59 are reserved for cpu hotadd and memory hotadd, + * which are already occupied at Xen hypervisor side. + */ +#define XENPF_core_parking     60 +struct xenpf_core_parking { +	/* IN variables */ +#define XEN_CORE_PARKING_SET   1 +#define XEN_CORE_PARKING_GET   2 +	uint32_t type; +	/* IN variables:  set cpu nums expected to be idled */ +	/* OUT variables: get cpu nums actually be idled */ +	uint32_t idle_nums; +}; +DEFINE_GUEST_HANDLE_STRUCT(xenpf_core_parking); +  struct xen_platform_op {  	uint32_t cmd;  	uint32_t interface_version; /* XENPF_INTERFACE_VERSION */ @@ -341,6 +357,7 @@ struct xen_platform_op {  		struct xenpf_set_processor_pminfo set_pminfo;  		struct xenpf_pcpuinfo          pcpu_info;  		struct xenpf_cpu_ol            cpu_ol; +		struct xenpf_core_parking      core_parking;  		uint8_t                        pad[128];  	} u;  }; diff --git a/include/xen/xen-ops.h b/include/xen/xen-ops.h index 6a198e46ab6e..d6fe062cad6b 100644 --- a/include/xen/xen-ops.h +++ b/include/xen/xen-ops.h @@ -2,6 +2,7 @@  #define INCLUDE_XEN_OPS_H  #include <linux/percpu.h> +#include <asm/xen/interface.h>  DECLARE_PER_CPU(struct vcpu_info *, xen_vcpu); @@ -26,7 +27,11 @@ void xen_destroy_contiguous_region(unsigned long vstart, unsigned int order);  struct vm_area_struct;  int xen_remap_domain_mfn_range(struct vm_area_struct *vma,  			       unsigned long addr, -			       unsigned long mfn, int nr, -			       pgprot_t prot, unsigned domid); +			       xen_pfn_t mfn, int nr, +			       pgprot_t prot, unsigned domid, +			       struct page **pages); +int xen_unmap_domain_mfn_range(struct vm_area_struct *vma, +			       int numpgs, struct page **pages); +bool xen_running_on_version_or_later(unsigned int major, unsigned int minor);  #endif /* INCLUDE_XEN_OPS_H */ | 
