📄 vmx_assist.h
字号:
/* * vmx_assist.h: Context definitions for the VMXASSIST world switch. * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to * deal in the Software without restriction, including without limitation the * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or * sell copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. * * Leendert van Doorn, leendert@watson.ibm.com * Copyright (c) 2005, International Business Machines Corporation. */#ifndef _VMX_ASSIST_H_#define _VMX_ASSIST_H_#define VMXASSIST_BASE 0xD0000#define VMXASSIST_MAGIC 0x17101966#define VMXASSIST_MAGIC_OFFSET (VMXASSIST_BASE+8)#define VMXASSIST_NEW_CONTEXT (VMXASSIST_BASE + 12)#define VMXASSIST_OLD_CONTEXT (VMXASSIST_NEW_CONTEXT + 4)#ifndef __ASSEMBLY__#define NR_EXCEPTION_HANDLER 32#define NR_INTERRUPT_HANDLERS 16#define NR_TRAPS (NR_EXCEPTION_HANDLER+NR_INTERRUPT_HANDLERS)union vmcs_arbytes { struct arbyte_fields { unsigned int seg_type : 4, s : 1, dpl : 2, p : 1, reserved0 : 4, avl : 1, reserved1 : 1, default_ops_size: 1, g : 1, null_bit : 1, reserved2 : 15; } fields; unsigned int bytes;};/* * World switch state */struct vmx_assist_context { uint32_t eip; /* execution pointer */ uint32_t esp; /* stack pointer */ uint32_t eflags; /* flags register */ uint32_t cr0; uint32_t cr3; /* page table directory */ uint32_t cr4; uint32_t idtr_limit; /* idt */ uint32_t idtr_base; uint32_t gdtr_limit; /* gdt */ uint32_t gdtr_base; uint32_t cs_sel; /* cs selector */ uint32_t cs_limit; uint32_t cs_base; union vmcs_arbytes cs_arbytes; uint32_t ds_sel; /* ds selector */ uint32_t ds_limit; uint32_t ds_base; union vmcs_arbytes ds_arbytes; uint32_t es_sel; /* es selector */ uint32_t es_limit; uint32_t es_base; union vmcs_arbytes es_arbytes; uint32_t ss_sel; /* ss selector */ uint32_t ss_limit; uint32_t ss_base; union vmcs_arbytes ss_arbytes; uint32_t fs_sel; /* fs selector */ uint32_t fs_limit; uint32_t fs_base; union vmcs_arbytes fs_arbytes; uint32_t gs_sel; /* gs selector */ uint32_t gs_limit; uint32_t gs_base; union vmcs_arbytes gs_arbytes; uint32_t tr_sel; /* task selector */ uint32_t tr_limit; uint32_t tr_base; union vmcs_arbytes tr_arbytes; uint32_t ldtr_sel; /* ldtr selector */ uint32_t ldtr_limit; uint32_t ldtr_base; union vmcs_arbytes ldtr_arbytes; unsigned char rm_irqbase[2];};typedef struct vmx_assist_context vmx_assist_context_t;#endif /* __ASSEMBLY__ */#endif /* _VMX_ASSIST_H_ *//* * Local variables: * mode: C * c-set-style: "BSD" * c-basic-offset: 4 * tab-width: 4 * indent-tabs-mode: nil * End: */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -