#ifndef __VKI_XEN_MMUEXT_H #define __VKI_XEN_MMUEXT_H #define VKI_XEN_MMUEXT_PIN_L1_TABLE 0 #define VKI_XEN_MMUEXT_PIN_L2_TABLE 1 #define VKI_XEN_MMUEXT_PIN_L3_TABLE 2 #define VKI_XEN_MMUEXT_PIN_L4_TABLE 3 #define VKI_XEN_MMUEXT_UNPIN_TABLE 4 #define VKI_XEN_MMUEXT_NEW_BASEPTR 5 #define VKI_XEN_MMUEXT_TLB_FLUSH_LOCAL 6 #define VKI_XEN_MMUEXT_INVLPG_LOCAL 7 #define VKI_XEN_MMUEXT_TLB_FLUSH_MULTI 8 #define VKI_XEN_MMUEXT_INVLPG_MULTI 9 #define VKI_XEN_MMUEXT_TLB_FLUSH_ALL 10 #define VKI_XEN_MMUEXT_INVLPG_ALL 11 #define VKI_XEN_MMUEXT_FLUSH_CACHE 12 #define VKI_XEN_MMUEXT_SET_LDT 13 #define VKI_XEN_MMUEXT_NEW_USER_BASEPTR 15 #define VKI_XEN_MMUEXT_CLEAR_PAGE 16 #define VKI_XEN_MMUEXT_COPY_PAGE 17 #define VKI_XEN_MMUEXT_FLUSH_CACHE_GLOBAL 18 #define VKI_XEN_MMUEXT_MARK_SUPER 19 #define VKI_XEN_MMUEXT_UNMARK_SUPER 20 struct vki_xen_mmuext_op { unsigned int cmd; union { /* [UN]PIN_TABLE, NEW_BASEPTR, NEW_USER_BASEPTR * CLEAR_PAGE, COPY_PAGE, [UN]MARK_SUPER */ vki_xen_pfn_t mfn; /* INVLPG_LOCAL, INVLPG_ALL, SET_LDT */ unsigned long linear_addr; } arg1; union { /* SET_LDT */ unsigned int nr_ents; /* TLB_FLUSH_MULTI, INVLPG_MULTI */ VKI_XEN_GUEST_HANDLE(const_void) vcpumask; /* COPY_PAGE */ vki_xen_pfn_t src_mfn; } arg2; }; #endif // __VKI_XEN_MMUEXT_H /*--------------------------------------------------------------------*/ /*--- end ---*/ /*--------------------------------------------------------------------*/