blob: e7a331041b0540fb1038469c902cf056cb3a457e [file] [log] [blame]
#ifndef __VKI_XEN_EVTCHN_H
#define __VKI_XEN_EVTCHN_H
#define VKI_XEN_EVTCHNOP_bind_interdomain 0
#define VKI_XEN_EVTCHNOP_bind_virq 1
#define VKI_XEN_EVTCHNOP_bind_pirq 2
#define VKI_XEN_EVTCHNOP_close 3
#define VKI_XEN_EVTCHNOP_send 4
#define VKI_XEN_EVTCHNOP_status 5
#define VKI_XEN_EVTCHNOP_alloc_unbound 6
#define VKI_XEN_EVTCHNOP_bind_ipi 7
#define VKI_XEN_EVTCHNOP_bind_vcpu 8
#define VKI_XEN_EVTCHNOP_unmask 9
#define VKI_XEN_EVTCHNOP_reset 10
typedef vki_uint32_t vki_xen_evtchn_port_t;
DEFINE_VKI_XEN_GUEST_HANDLE(vki_xen_evtchn_port_t);
struct vki_xen_evtchn_alloc_unbound {
/* IN parameters */
vki_xen_domid_t dom, remote_dom;
/* OUT parameters */
vki_xen_evtchn_port_t port;
};
struct vki_xen_evtchn_op {
vki_uint32_t cmd; /* enum event_channel_op */
union {
struct vki_xen_evtchn_alloc_unbound alloc_unbound;
//struct vki_xen_evtchn_bind_interdomain bind_interdomain;
//struct vki_xen_evtchn_bind_virq bind_virq;
//struct vki_xen_evtchn_bind_pirq bind_pirq;
//struct vki_xen_evtchn_bind_ipi bind_ipi;
//struct vki_xen_evtchn_close close;
//struct vki_xen_evtchn_send send;
//struct vki_xen_evtchn_status status;
//struct vki_xen_evtchn_bind_vcpu bind_vcpu;
//struct vki_xen_evtchn_unmask unmask;
} u;
};
#endif // __VKI_XEN_EVTCHN_H
/*--------------------------------------------------------------------*/
/*--- end ---*/
/*--------------------------------------------------------------------*/