Blame view

arch/x86/include/asm/vmx.h 19.6 KB
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
  #ifndef VMX_H
  #define VMX_H
  
  /*
   * vmx.h: VMX Architecture related definitions
   * Copyright (c) 2004, Intel Corporation.
   *
   * This program is free software; you can redistribute it and/or modify it
   * under the terms and conditions of the GNU General Public License,
   * version 2, as published by the Free Software Foundation.
   *
   * This program is distributed in the hope it will be useful, but WITHOUT
   * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
   * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
   * more details.
   *
   * You should have received a copy of the GNU General Public License along with
   * this program; if not, write to the Free Software Foundation, Inc., 59 Temple
   * Place - Suite 330, Boston, MA 02111-1307 USA.
   *
   * A few random additions are:
   * Copyright (C) 2006 Qumranet
   *    Avi Kivity <avi@qumranet.com>
   *    Yaniv Kamay <yaniv@qumranet.com>
   *
   */
19b95dba0   Avi Kivity   KVM: VMX: Add def...
27
  #include <linux/types.h>
8a70cc3d0   Eddie Dong   KVM: VMX: Comment...
28
29
30
  /*
   * Definitions of Primary Processor-Based VM-Execution Controls.
   */
62b3ffb8b   Yang, Sheng   KVM: VMX: Import ...
31
32
33
34
35
36
37
  #define CPU_BASED_VIRTUAL_INTR_PENDING          0x00000004
  #define CPU_BASED_USE_TSC_OFFSETING             0x00000008
  #define CPU_BASED_HLT_EXITING                   0x00000080
  #define CPU_BASED_INVLPG_EXITING                0x00000200
  #define CPU_BASED_MWAIT_EXITING                 0x00000400
  #define CPU_BASED_RDPMC_EXITING                 0x00000800
  #define CPU_BASED_RDTSC_EXITING                 0x00001000
d56f546db   Sheng Yang   KVM: VMX: EPT Fea...
38
39
  #define CPU_BASED_CR3_LOAD_EXITING		0x00008000
  #define CPU_BASED_CR3_STORE_EXITING		0x00010000
62b3ffb8b   Yang, Sheng   KVM: VMX: Import ...
40
41
42
  #define CPU_BASED_CR8_LOAD_EXITING              0x00080000
  #define CPU_BASED_CR8_STORE_EXITING             0x00100000
  #define CPU_BASED_TPR_SHADOW                    0x00200000
f08864b42   Sheng Yang   KVM: VMX: Enable ...
43
  #define CPU_BASED_VIRTUAL_NMI_PENDING		0x00400000
62b3ffb8b   Yang, Sheng   KVM: VMX: Import ...
44
45
46
47
48
49
50
  #define CPU_BASED_MOV_DR_EXITING                0x00800000
  #define CPU_BASED_UNCOND_IO_EXITING             0x01000000
  #define CPU_BASED_USE_IO_BITMAPS                0x02000000
  #define CPU_BASED_USE_MSR_BITMAPS               0x10000000
  #define CPU_BASED_MONITOR_EXITING               0x20000000
  #define CPU_BASED_PAUSE_EXITING                 0x40000000
  #define CPU_BASED_ACTIVATE_SECONDARY_CONTROLS   0x80000000
8a70cc3d0   Eddie Dong   KVM: VMX: Comment...
51
52
53
54
  /*
   * Definitions of Secondary Processor-Based VM-Execution Controls.
   */
  #define SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES 0x00000001
d56f546db   Sheng Yang   KVM: VMX: EPT Fea...
55
  #define SECONDARY_EXEC_ENABLE_EPT               0x00000002
4e47c7a6d   Sheng Yang   KVM: VMX: Add ins...
56
  #define SECONDARY_EXEC_RDTSCP			0x00000008
2384d2b32   Sheng Yang   KVM: VMX: Enable ...
57
  #define SECONDARY_EXEC_ENABLE_VPID              0x00000020
e5edaa01c   Eddie Dong   KVM: VMX: wbinvd ...
58
  #define SECONDARY_EXEC_WBINVD_EXITING		0x00000040
3a624e29c   Nitin A Kamble   KVM: VMX: Support...
59
  #define SECONDARY_EXEC_UNRESTRICTED_GUEST	0x00000080
4b8d54f97   Zhai, Edwin   KVM: VMX: Add sup...
60
  #define SECONDARY_EXEC_PAUSE_LOOP_EXITING	0x00000400
8a70cc3d0   Eddie Dong   KVM: VMX: Comment...
61

6aa8b732c   Avi Kivity   [PATCH] kvm: user...
62

62b3ffb8b   Yang, Sheng   KVM: VMX: Import ...
63
64
65
  #define PIN_BASED_EXT_INTR_MASK                 0x00000001
  #define PIN_BASED_NMI_EXITING                   0x00000008
  #define PIN_BASED_VIRTUAL_NMIS                  0x00000020
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
66

07c116d2f   Avi Kivity   KVM: VMX: Add def...
67
  #define VM_EXIT_SAVE_DEBUG_CONTROLS             0x00000002
62b3ffb8b   Yang, Sheng   KVM: VMX: Import ...
68
  #define VM_EXIT_HOST_ADDR_SPACE_SIZE            0x00000200
07c116d2f   Avi Kivity   KVM: VMX: Add def...
69
  #define VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL      0x00001000
62b3ffb8b   Yang, Sheng   KVM: VMX: Import ...
70
  #define VM_EXIT_ACK_INTR_ON_EXIT                0x00008000
468d472f3   Sheng Yang   KVM: VMX: Add PAT...
71
72
  #define VM_EXIT_SAVE_IA32_PAT			0x00040000
  #define VM_EXIT_LOAD_IA32_PAT			0x00080000
07c116d2f   Avi Kivity   KVM: VMX: Add def...
73
74
75
  #define VM_EXIT_SAVE_IA32_EFER                  0x00100000
  #define VM_EXIT_LOAD_IA32_EFER                  0x00200000
  #define VM_EXIT_SAVE_VMX_PREEMPTION_TIMER       0x00400000
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
76

07c116d2f   Avi Kivity   KVM: VMX: Add def...
77
  #define VM_ENTRY_LOAD_DEBUG_CONTROLS            0x00000002
62b3ffb8b   Yang, Sheng   KVM: VMX: Import ...
78
79
80
  #define VM_ENTRY_IA32E_MODE                     0x00000200
  #define VM_ENTRY_SMM                            0x00000400
  #define VM_ENTRY_DEACT_DUAL_MONITOR             0x00000800
07c116d2f   Avi Kivity   KVM: VMX: Add def...
81
  #define VM_ENTRY_LOAD_IA32_PERF_GLOBAL_CTRL     0x00002000
468d472f3   Sheng Yang   KVM: VMX: Add PAT...
82
  #define VM_ENTRY_LOAD_IA32_PAT			0x00004000
07c116d2f   Avi Kivity   KVM: VMX: Add def...
83
  #define VM_ENTRY_LOAD_IA32_EFER                 0x00008000
62b3ffb8b   Yang, Sheng   KVM: VMX: Import ...
84

6aa8b732c   Avi Kivity   [PATCH] kvm: user...
85
86
  /* VMCS Encodings */
  enum vmcs_field {
2384d2b32   Sheng Yang   KVM: VMX: Enable ...
87
  	VIRTUAL_PROCESSOR_ID            = 0x00000000,
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
  	GUEST_ES_SELECTOR               = 0x00000800,
  	GUEST_CS_SELECTOR               = 0x00000802,
  	GUEST_SS_SELECTOR               = 0x00000804,
  	GUEST_DS_SELECTOR               = 0x00000806,
  	GUEST_FS_SELECTOR               = 0x00000808,
  	GUEST_GS_SELECTOR               = 0x0000080a,
  	GUEST_LDTR_SELECTOR             = 0x0000080c,
  	GUEST_TR_SELECTOR               = 0x0000080e,
  	HOST_ES_SELECTOR                = 0x00000c00,
  	HOST_CS_SELECTOR                = 0x00000c02,
  	HOST_SS_SELECTOR                = 0x00000c04,
  	HOST_DS_SELECTOR                = 0x00000c06,
  	HOST_FS_SELECTOR                = 0x00000c08,
  	HOST_GS_SELECTOR                = 0x00000c0a,
  	HOST_TR_SELECTOR                = 0x00000c0c,
  	IO_BITMAP_A                     = 0x00002000,
  	IO_BITMAP_A_HIGH                = 0x00002001,
  	IO_BITMAP_B                     = 0x00002002,
  	IO_BITMAP_B_HIGH                = 0x00002003,
  	MSR_BITMAP                      = 0x00002004,
  	MSR_BITMAP_HIGH                 = 0x00002005,
  	VM_EXIT_MSR_STORE_ADDR          = 0x00002006,
  	VM_EXIT_MSR_STORE_ADDR_HIGH     = 0x00002007,
  	VM_EXIT_MSR_LOAD_ADDR           = 0x00002008,
  	VM_EXIT_MSR_LOAD_ADDR_HIGH      = 0x00002009,
  	VM_ENTRY_MSR_LOAD_ADDR          = 0x0000200a,
  	VM_ENTRY_MSR_LOAD_ADDR_HIGH     = 0x0000200b,
  	TSC_OFFSET                      = 0x00002010,
  	TSC_OFFSET_HIGH                 = 0x00002011,
  	VIRTUAL_APIC_PAGE_ADDR          = 0x00002012,
  	VIRTUAL_APIC_PAGE_ADDR_HIGH     = 0x00002013,
f78e0e2ee   Sheng Yang   KVM: VMX: Enable ...
119
120
  	APIC_ACCESS_ADDR		= 0x00002014,
  	APIC_ACCESS_ADDR_HIGH		= 0x00002015,
d56f546db   Sheng Yang   KVM: VMX: EPT Fea...
121
122
123
124
  	EPT_POINTER                     = 0x0000201a,
  	EPT_POINTER_HIGH                = 0x0000201b,
  	GUEST_PHYSICAL_ADDRESS          = 0x00002400,
  	GUEST_PHYSICAL_ADDRESS_HIGH     = 0x00002401,
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
125
126
127
128
  	VMCS_LINK_POINTER               = 0x00002800,
  	VMCS_LINK_POINTER_HIGH          = 0x00002801,
  	GUEST_IA32_DEBUGCTL             = 0x00002802,
  	GUEST_IA32_DEBUGCTL_HIGH        = 0x00002803,
468d472f3   Sheng Yang   KVM: VMX: Add PAT...
129
130
  	GUEST_IA32_PAT			= 0x00002804,
  	GUEST_IA32_PAT_HIGH		= 0x00002805,
5dfa3d170   Avi Kivity   KVM: VMX: Add def...
131
132
  	GUEST_IA32_EFER			= 0x00002806,
  	GUEST_IA32_EFER_HIGH		= 0x00002807,
4704d0bef   Nadav Har'El   KVM: nVMX: Exitin...
133
134
  	GUEST_IA32_PERF_GLOBAL_CTRL	= 0x00002808,
  	GUEST_IA32_PERF_GLOBAL_CTRL_HIGH= 0x00002809,
d56f546db   Sheng Yang   KVM: VMX: EPT Fea...
135
136
137
138
139
140
141
142
  	GUEST_PDPTR0                    = 0x0000280a,
  	GUEST_PDPTR0_HIGH               = 0x0000280b,
  	GUEST_PDPTR1                    = 0x0000280c,
  	GUEST_PDPTR1_HIGH               = 0x0000280d,
  	GUEST_PDPTR2                    = 0x0000280e,
  	GUEST_PDPTR2_HIGH               = 0x0000280f,
  	GUEST_PDPTR3                    = 0x00002810,
  	GUEST_PDPTR3_HIGH               = 0x00002811,
468d472f3   Sheng Yang   KVM: VMX: Add PAT...
143
144
  	HOST_IA32_PAT			= 0x00002c00,
  	HOST_IA32_PAT_HIGH		= 0x00002c01,
5dfa3d170   Avi Kivity   KVM: VMX: Add def...
145
146
  	HOST_IA32_EFER			= 0x00002c02,
  	HOST_IA32_EFER_HIGH		= 0x00002c03,
4704d0bef   Nadav Har'El   KVM: nVMX: Exitin...
147
148
  	HOST_IA32_PERF_GLOBAL_CTRL	= 0x00002c04,
  	HOST_IA32_PERF_GLOBAL_CTRL_HIGH	= 0x00002c05,
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
  	PIN_BASED_VM_EXEC_CONTROL       = 0x00004000,
  	CPU_BASED_VM_EXEC_CONTROL       = 0x00004002,
  	EXCEPTION_BITMAP                = 0x00004004,
  	PAGE_FAULT_ERROR_CODE_MASK      = 0x00004006,
  	PAGE_FAULT_ERROR_CODE_MATCH     = 0x00004008,
  	CR3_TARGET_COUNT                = 0x0000400a,
  	VM_EXIT_CONTROLS                = 0x0000400c,
  	VM_EXIT_MSR_STORE_COUNT         = 0x0000400e,
  	VM_EXIT_MSR_LOAD_COUNT          = 0x00004010,
  	VM_ENTRY_CONTROLS               = 0x00004012,
  	VM_ENTRY_MSR_LOAD_COUNT         = 0x00004014,
  	VM_ENTRY_INTR_INFO_FIELD        = 0x00004016,
  	VM_ENTRY_EXCEPTION_ERROR_CODE   = 0x00004018,
  	VM_ENTRY_INSTRUCTION_LEN        = 0x0000401a,
  	TPR_THRESHOLD                   = 0x0000401c,
  	SECONDARY_VM_EXEC_CONTROL       = 0x0000401e,
4b8d54f97   Zhai, Edwin   KVM: VMX: Add sup...
165
166
  	PLE_GAP                         = 0x00004020,
  	PLE_WINDOW                      = 0x00004022,
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
  	VM_INSTRUCTION_ERROR            = 0x00004400,
  	VM_EXIT_REASON                  = 0x00004402,
  	VM_EXIT_INTR_INFO               = 0x00004404,
  	VM_EXIT_INTR_ERROR_CODE         = 0x00004406,
  	IDT_VECTORING_INFO_FIELD        = 0x00004408,
  	IDT_VECTORING_ERROR_CODE        = 0x0000440a,
  	VM_EXIT_INSTRUCTION_LEN         = 0x0000440c,
  	VMX_INSTRUCTION_INFO            = 0x0000440e,
  	GUEST_ES_LIMIT                  = 0x00004800,
  	GUEST_CS_LIMIT                  = 0x00004802,
  	GUEST_SS_LIMIT                  = 0x00004804,
  	GUEST_DS_LIMIT                  = 0x00004806,
  	GUEST_FS_LIMIT                  = 0x00004808,
  	GUEST_GS_LIMIT                  = 0x0000480a,
  	GUEST_LDTR_LIMIT                = 0x0000480c,
  	GUEST_TR_LIMIT                  = 0x0000480e,
  	GUEST_GDTR_LIMIT                = 0x00004810,
  	GUEST_IDTR_LIMIT                = 0x00004812,
  	GUEST_ES_AR_BYTES               = 0x00004814,
  	GUEST_CS_AR_BYTES               = 0x00004816,
  	GUEST_SS_AR_BYTES               = 0x00004818,
  	GUEST_DS_AR_BYTES               = 0x0000481a,
  	GUEST_FS_AR_BYTES               = 0x0000481c,
  	GUEST_GS_AR_BYTES               = 0x0000481e,
  	GUEST_LDTR_AR_BYTES             = 0x00004820,
  	GUEST_TR_AR_BYTES               = 0x00004822,
  	GUEST_INTERRUPTIBILITY_INFO     = 0x00004824,
  	GUEST_ACTIVITY_STATE            = 0X00004826,
  	GUEST_SYSENTER_CS               = 0x0000482A,
  	HOST_IA32_SYSENTER_CS           = 0x00004c00,
  	CR0_GUEST_HOST_MASK             = 0x00006000,
  	CR4_GUEST_HOST_MASK             = 0x00006002,
  	CR0_READ_SHADOW                 = 0x00006004,
  	CR4_READ_SHADOW                 = 0x00006006,
  	CR3_TARGET_VALUE0               = 0x00006008,
  	CR3_TARGET_VALUE1               = 0x0000600a,
  	CR3_TARGET_VALUE2               = 0x0000600c,
  	CR3_TARGET_VALUE3               = 0x0000600e,
  	EXIT_QUALIFICATION              = 0x00006400,
  	GUEST_LINEAR_ADDRESS            = 0x0000640a,
  	GUEST_CR0                       = 0x00006800,
  	GUEST_CR3                       = 0x00006802,
  	GUEST_CR4                       = 0x00006804,
  	GUEST_ES_BASE                   = 0x00006806,
  	GUEST_CS_BASE                   = 0x00006808,
  	GUEST_SS_BASE                   = 0x0000680a,
  	GUEST_DS_BASE                   = 0x0000680c,
  	GUEST_FS_BASE                   = 0x0000680e,
  	GUEST_GS_BASE                   = 0x00006810,
  	GUEST_LDTR_BASE                 = 0x00006812,
  	GUEST_TR_BASE                   = 0x00006814,
  	GUEST_GDTR_BASE                 = 0x00006816,
  	GUEST_IDTR_BASE                 = 0x00006818,
  	GUEST_DR7                       = 0x0000681a,
  	GUEST_RSP                       = 0x0000681c,
  	GUEST_RIP                       = 0x0000681e,
  	GUEST_RFLAGS                    = 0x00006820,
  	GUEST_PENDING_DBG_EXCEPTIONS    = 0x00006822,
  	GUEST_SYSENTER_ESP              = 0x00006824,
  	GUEST_SYSENTER_EIP              = 0x00006826,
  	HOST_CR0                        = 0x00006c00,
  	HOST_CR3                        = 0x00006c02,
  	HOST_CR4                        = 0x00006c04,
  	HOST_FS_BASE                    = 0x00006c06,
  	HOST_GS_BASE                    = 0x00006c08,
  	HOST_TR_BASE                    = 0x00006c0a,
  	HOST_GDTR_BASE                  = 0x00006c0c,
  	HOST_IDTR_BASE                  = 0x00006c0e,
  	HOST_IA32_SYSENTER_ESP          = 0x00006c10,
  	HOST_IA32_SYSENTER_EIP          = 0x00006c12,
  	HOST_RSP                        = 0x00006c14,
  	HOST_RIP                        = 0x00006c16,
  };
  
  #define VMX_EXIT_REASONS_FAILED_VMENTRY         0x80000000
  
  #define EXIT_REASON_EXCEPTION_NMI       0
  #define EXIT_REASON_EXTERNAL_INTERRUPT  1
988ad74ff   Avi Kivity   [PATCH] kvm: vmx:...
245
  #define EXIT_REASON_TRIPLE_FAULT        2
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
246
247
  
  #define EXIT_REASON_PENDING_INTERRUPT   7
f08864b42   Sheng Yang   KVM: VMX: Enable ...
248
  #define EXIT_REASON_NMI_WINDOW		8
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
249
250
251
  #define EXIT_REASON_TASK_SWITCH         9
  #define EXIT_REASON_CPUID               10
  #define EXIT_REASON_HLT                 12
ec25d5e66   Gleb Natapov   KVM: handle exit ...
252
  #define EXIT_REASON_INVD                13
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
  #define EXIT_REASON_INVLPG              14
  #define EXIT_REASON_RDPMC               15
  #define EXIT_REASON_RDTSC               16
  #define EXIT_REASON_VMCALL              18
  #define EXIT_REASON_VMCLEAR             19
  #define EXIT_REASON_VMLAUNCH            20
  #define EXIT_REASON_VMPTRLD             21
  #define EXIT_REASON_VMPTRST             22
  #define EXIT_REASON_VMREAD              23
  #define EXIT_REASON_VMRESUME            24
  #define EXIT_REASON_VMWRITE             25
  #define EXIT_REASON_VMOFF               26
  #define EXIT_REASON_VMON                27
  #define EXIT_REASON_CR_ACCESS           28
  #define EXIT_REASON_DR_ACCESS           29
  #define EXIT_REASON_IO_INSTRUCTION      30
  #define EXIT_REASON_MSR_READ            31
  #define EXIT_REASON_MSR_WRITE           32
c8174f7b3   Mohammed Gamal   KVM: VMX: Add con...
271
  #define EXIT_REASON_INVALID_STATE	33
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
272
  #define EXIT_REASON_MWAIT_INSTRUCTION   36
59708670b   Sheng Yang   KVM: VMX: Trap an...
273
  #define EXIT_REASON_MONITOR_INSTRUCTION 39
4b8d54f97   Zhai, Edwin   KVM: VMX: Add sup...
274
  #define EXIT_REASON_PAUSE_INSTRUCTION   40
a0861c02a   Andi Kleen   KVM: Add VT-x mac...
275
  #define EXIT_REASON_MCE_DURING_VMENTRY	 41
6e5d865c0   Yang, Sheng   KVM: VMX: Use sha...
276
  #define EXIT_REASON_TPR_BELOW_THRESHOLD 43
f78e0e2ee   Sheng Yang   KVM: VMX: Enable ...
277
  #define EXIT_REASON_APIC_ACCESS         44
d56f546db   Sheng Yang   KVM: VMX: EPT Fea...
278
279
  #define EXIT_REASON_EPT_VIOLATION       48
  #define EXIT_REASON_EPT_MISCONFIG       49
e5edaa01c   Eddie Dong   KVM: VMX: wbinvd ...
280
  #define EXIT_REASON_WBINVD		54
2acf923e3   Dexuan Cui   KVM: VMX: Enable ...
281
  #define EXIT_REASON_XSETBV		55
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
282
283
284
285
286
287
  
  /*
   * Interruption-information format
   */
  #define INTR_INFO_VECTOR_MASK           0xff            /* 7:0 */
  #define INTR_INFO_INTR_TYPE_MASK        0x700           /* 10:8 */
2e11384c2   Ryan Harper   KVM: VMX: fix typ...
288
  #define INTR_INFO_DELIVER_CODE_MASK     0x800           /* 11 */
f08864b42   Sheng Yang   KVM: VMX: Enable ...
289
  #define INTR_INFO_UNBLOCK_NMI		0x1000		/* 12 */
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
290
  #define INTR_INFO_VALID_MASK            0x80000000      /* 31 */
f08864b42   Sheng Yang   KVM: VMX: Enable ...
291
  #define INTR_INFO_RESVD_BITS_MASK       0x7ffff000
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
292
293
294
  
  #define VECTORING_INFO_VECTOR_MASK           	INTR_INFO_VECTOR_MASK
  #define VECTORING_INFO_TYPE_MASK        	INTR_INFO_INTR_TYPE_MASK
2e11384c2   Ryan Harper   KVM: VMX: fix typ...
295
  #define VECTORING_INFO_DELIVER_CODE_MASK    	INTR_INFO_DELIVER_CODE_MASK
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
296
297
298
  #define VECTORING_INFO_VALID_MASK       	INTR_INFO_VALID_MASK
  
  #define INTR_TYPE_EXT_INTR              (0 << 8) /* external interrupt */
f08864b42   Sheng Yang   KVM: VMX: Enable ...
299
  #define INTR_TYPE_NMI_INTR		(2 << 8) /* NMI */
8ab2d2e23   Jan Kiszka   KVM: VMX: Support...
300
  #define INTR_TYPE_HARD_EXCEPTION	(3 << 8) /* processor exception */
9c5623e3e   Avi Kivity   KVM: VMX: Use vmx...
301
  #define INTR_TYPE_SOFT_INTR             (4 << 8) /* software interrupt */
8ab2d2e23   Jan Kiszka   KVM: VMX: Support...
302
  #define INTR_TYPE_SOFT_EXCEPTION	(6 << 8) /* software exception */
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
303

f08864b42   Sheng Yang   KVM: VMX: Enable ...
304
305
306
307
308
  /* GUEST_INTERRUPTIBILITY_INFO flags. */
  #define GUEST_INTR_STATE_STI		0x00000001
  #define GUEST_INTR_STATE_MOV_SS		0x00000002
  #define GUEST_INTR_STATE_SMI		0x00000004
  #define GUEST_INTR_STATE_NMI		0x00000008
443381a82   Anthony Liguori   KVM: VMX: add mod...
309
310
311
312
313
  /* GUEST_ACTIVITY_STATE flags */
  #define GUEST_ACTIVITY_ACTIVE		0
  #define GUEST_ACTIVITY_HLT		1
  #define GUEST_ACTIVITY_SHUTDOWN		2
  #define GUEST_ACTIVITY_WAIT_SIPI	3
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
314
315
316
  /*
   * Exit Qualifications for MOV for Control Register Access
   */
d77c26fce   Mike Day   KVM: CodingStyle ...
317
  #define CONTROL_REG_ACCESS_NUM          0x7     /* 2:0, number of control reg.*/
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
318
  #define CONTROL_REG_ACCESS_TYPE         0x30    /* 5:4, access type */
d77c26fce   Mike Day   KVM: CodingStyle ...
319
  #define CONTROL_REG_ACCESS_REG          0xf00   /* 10:8, general purpose reg. */
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
  #define LMSW_SOURCE_DATA_SHIFT 16
  #define LMSW_SOURCE_DATA  (0xFFFF << LMSW_SOURCE_DATA_SHIFT) /* 16:31 lmsw source */
  #define REG_EAX                         (0 << 8)
  #define REG_ECX                         (1 << 8)
  #define REG_EDX                         (2 << 8)
  #define REG_EBX                         (3 << 8)
  #define REG_ESP                         (4 << 8)
  #define REG_EBP                         (5 << 8)
  #define REG_ESI                         (6 << 8)
  #define REG_EDI                         (7 << 8)
  #define REG_R8                         (8 << 8)
  #define REG_R9                         (9 << 8)
  #define REG_R10                        (10 << 8)
  #define REG_R11                        (11 << 8)
  #define REG_R12                        (12 << 8)
  #define REG_R13                        (13 << 8)
  #define REG_R14                        (14 << 8)
  #define REG_R15                        (15 << 8)
  
  /*
   * Exit Qualifications for MOV for Debug Register Access
   */
d77c26fce   Mike Day   KVM: CodingStyle ...
342
  #define DEBUG_REG_ACCESS_NUM            0x7     /* 2:0, number of debug reg. */
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
343
344
345
  #define DEBUG_REG_ACCESS_TYPE           0x10    /* 4, direction of access */
  #define TYPE_MOV_TO_DR                  (0 << 4)
  #define TYPE_MOV_FROM_DR                (1 << 4)
42dbaa5a0   Jan Kiszka   KVM: x86: Virtual...
346
  #define DEBUG_REG_ACCESS_REG(eq)        (((eq) >> 8) & 0xf) /* 11:8, general purpose reg. */
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
347

58fbbf26e   Kevin Tian   KVM: APIC: avoid ...
348
349
350
351
352
353
354
355
356
357
358
  /*
   * Exit Qualifications for APIC-Access
   */
  #define APIC_ACCESS_OFFSET              0xfff   /* 11:0, offset within the APIC page */
  #define APIC_ACCESS_TYPE                0xf000  /* 15:12, access type */
  #define TYPE_LINEAR_APIC_INST_READ      (0 << 12)
  #define TYPE_LINEAR_APIC_INST_WRITE     (1 << 12)
  #define TYPE_LINEAR_APIC_INST_FETCH     (2 << 12)
  #define TYPE_LINEAR_APIC_EVENT          (3 << 12)
  #define TYPE_PHYSICAL_APIC_EVENT        (10 << 12)
  #define TYPE_PHYSICAL_APIC_INST         (15 << 12)
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
359
360
  /* segment AR */
  #define SEGMENT_AR_L_MASK (1 << 13)
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
  #define AR_TYPE_ACCESSES_MASK 1
  #define AR_TYPE_READABLE_MASK (1 << 1)
  #define AR_TYPE_WRITEABLE_MASK (1 << 2)
  #define AR_TYPE_CODE_MASK (1 << 3)
  #define AR_TYPE_MASK 0x0f
  #define AR_TYPE_BUSY_64_TSS 11
  #define AR_TYPE_BUSY_32_TSS 11
  #define AR_TYPE_BUSY_16_TSS 3
  #define AR_TYPE_LDT 2
  
  #define AR_UNUSABLE_MASK (1 << 16)
  #define AR_S_MASK (1 << 4)
  #define AR_P_MASK (1 << 7)
  #define AR_L_MASK (1 << 13)
  #define AR_DB_MASK (1 << 14)
  #define AR_G_MASK (1 << 15)
  #define AR_DPL_SHIFT 5
  #define AR_DPL(ar) (((ar) >> AR_DPL_SHIFT) & 3)
  
  #define AR_RESERVD_MASK 0xfffe0f00
6fe639792   Sheng Yang   KVM: VMX: Move pr...
381
382
383
  #define TSS_PRIVATE_MEMSLOT			(KVM_MEMORY_SLOTS + 0)
  #define APIC_ACCESS_PAGE_PRIVATE_MEMSLOT	(KVM_MEMORY_SLOTS + 1)
  #define IDENTITY_PAGETABLE_PRIVATE_MEMSLOT	(KVM_MEMORY_SLOTS + 2)
f78e0e2ee   Sheng Yang   KVM: VMX: Enable ...
384

2384d2b32   Sheng Yang   KVM: VMX: Enable ...
385
386
387
  #define VMX_NR_VPIDS				(1 << 16)
  #define VMX_VPID_EXTENT_SINGLE_CONTEXT		1
  #define VMX_VPID_EXTENT_ALL_CONTEXT		2
d56f546db   Sheng Yang   KVM: VMX: EPT Fea...
388
389
390
  #define VMX_EPT_EXTENT_INDIVIDUAL_ADDR		0
  #define VMX_EPT_EXTENT_CONTEXT			1
  #define VMX_EPT_EXTENT_GLOBAL			2
e799794e0   Marcelo Tosatti   KVM: VMX: more MS...
391
392
393
394
395
396
  
  #define VMX_EPT_EXECUTE_ONLY_BIT		(1ull)
  #define VMX_EPT_PAGE_WALK_4_BIT			(1ull << 6)
  #define VMX_EPTP_UC_BIT				(1ull << 8)
  #define VMX_EPTP_WB_BIT				(1ull << 14)
  #define VMX_EPT_2MB_PAGE_BIT			(1ull << 16)
878403b78   Sheng Yang   KVM: VMX: Enable ...
397
  #define VMX_EPT_1GB_PAGE_BIT			(1ull << 17)
d56f546db   Sheng Yang   KVM: VMX: EPT Fea...
398
399
400
  #define VMX_EPT_EXTENT_INDIVIDUAL_BIT		(1ull << 24)
  #define VMX_EPT_EXTENT_CONTEXT_BIT		(1ull << 25)
  #define VMX_EPT_EXTENT_GLOBAL_BIT		(1ull << 26)
e799794e0   Marcelo Tosatti   KVM: VMX: more MS...
401

518c8aee5   Gui Jianfeng   KVM: VMX: Make su...
402
  #define VMX_VPID_EXTENT_SINGLE_CONTEXT_BIT      (1ull << 9) /* (41 - 32) */
b9d762fa7   Gui Jianfeng   KVM: VMX: Add all...
403
  #define VMX_VPID_EXTENT_GLOBAL_CONTEXT_BIT      (1ull << 10) /* (42 - 32) */
518c8aee5   Gui Jianfeng   KVM: VMX: Make su...
404

67253af52   Sheng Yang   KVM: Add kvm_x86_...
405
  #define VMX_EPT_DEFAULT_GAW			3
1439442c7   Sheng Yang   KVM: VMX: Enable ...
406
407
408
409
410
411
412
  #define VMX_EPT_MAX_GAW				0x4
  #define VMX_EPT_MT_EPTE_SHIFT			3
  #define VMX_EPT_GAW_EPTP_SHIFT			3
  #define VMX_EPT_DEFAULT_MT			0x6ull
  #define VMX_EPT_READABLE_MASK			0x1ull
  #define VMX_EPT_WRITABLE_MASK			0x2ull
  #define VMX_EPT_EXECUTABLE_MASK			0x4ull
a19a6d113   Sheng Yang   KVM: VMX: Rename ...
413
  #define VMX_EPT_IPAT_BIT    			(1ull << 6)
d56f546db   Sheng Yang   KVM: VMX: EPT Fea...
414

b7ebfb050   Sheng Yang   KVM: VMX: Prepare...
415
  #define VMX_EPT_IDENTITY_PAGETABLE_ADDR		0xfffbc000ul
eca70fc56   Eduardo Habkost   KVM: VMX: move AS...
416
417
418
419
420
421
422
423
424
425
426
427
  
  #define ASM_VMX_VMCLEAR_RAX       ".byte 0x66, 0x0f, 0xc7, 0x30"
  #define ASM_VMX_VMLAUNCH          ".byte 0x0f, 0x01, 0xc2"
  #define ASM_VMX_VMRESUME          ".byte 0x0f, 0x01, 0xc3"
  #define ASM_VMX_VMPTRLD_RAX       ".byte 0x0f, 0xc7, 0x30"
  #define ASM_VMX_VMREAD_RDX_RAX    ".byte 0x0f, 0x78, 0xd0"
  #define ASM_VMX_VMWRITE_RAX_RDX   ".byte 0x0f, 0x79, 0xd0"
  #define ASM_VMX_VMWRITE_RSP_RDX   ".byte 0x0f, 0x79, 0xd4"
  #define ASM_VMX_VMXOFF            ".byte 0x0f, 0x01, 0xc4"
  #define ASM_VMX_VMXON_RAX         ".byte 0xf3, 0x0f, 0xc7, 0x30"
  #define ASM_VMX_INVEPT		  ".byte 0x66, 0x0f, 0x38, 0x80, 0x08"
  #define ASM_VMX_INVVPID		  ".byte 0x66, 0x0f, 0x38, 0x81, 0x08"
19b95dba0   Avi Kivity   KVM: VMX: Add def...
428
429
430
431
432
  struct vmx_msr_entry {
  	u32 index;
  	u32 reserved;
  	u64 value;
  } __aligned(16);
eca70fc56   Eduardo Habkost   KVM: VMX: move AS...
433

0140caea3   Nadav Har'El   KVM: nVMX: Succes...
434
  /*
7c1779384   Nadav Har'El   KVM: nVMX: vmcs12...
435
436
437
438
439
440
441
442
   * Exit Qualifications for entry failure during or after loading guest state
   */
  #define ENTRY_FAIL_DEFAULT		0
  #define ENTRY_FAIL_PDPTE		2
  #define ENTRY_FAIL_NMI			3
  #define ENTRY_FAIL_VMCS_LINK_PTR	4
  
  /*
0140caea3   Nadav Har'El   KVM: nVMX: Succes...
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
   * VM-instruction error numbers
   */
  enum vm_instruction_error_number {
  	VMXERR_VMCALL_IN_VMX_ROOT_OPERATION = 1,
  	VMXERR_VMCLEAR_INVALID_ADDRESS = 2,
  	VMXERR_VMCLEAR_VMXON_POINTER = 3,
  	VMXERR_VMLAUNCH_NONCLEAR_VMCS = 4,
  	VMXERR_VMRESUME_NONLAUNCHED_VMCS = 5,
  	VMXERR_VMRESUME_AFTER_VMXOFF = 6,
  	VMXERR_ENTRY_INVALID_CONTROL_FIELD = 7,
  	VMXERR_ENTRY_INVALID_HOST_STATE_FIELD = 8,
  	VMXERR_VMPTRLD_INVALID_ADDRESS = 9,
  	VMXERR_VMPTRLD_VMXON_POINTER = 10,
  	VMXERR_VMPTRLD_INCORRECT_VMCS_REVISION_ID = 11,
  	VMXERR_UNSUPPORTED_VMCS_COMPONENT = 12,
  	VMXERR_VMWRITE_READ_ONLY_VMCS_COMPONENT = 13,
  	VMXERR_VMXON_IN_VMX_ROOT_OPERATION = 15,
  	VMXERR_ENTRY_INVALID_EXECUTIVE_VMCS_POINTER = 16,
  	VMXERR_ENTRY_NONLAUNCHED_EXECUTIVE_VMCS = 17,
  	VMXERR_ENTRY_EXECUTIVE_VMCS_POINTER_NOT_VMXON_POINTER = 18,
  	VMXERR_VMCALL_NONCLEAR_VMCS = 19,
  	VMXERR_VMCALL_INVALID_VM_EXIT_CONTROL_FIELDS = 20,
  	VMXERR_VMCALL_INCORRECT_MSEG_REVISION_ID = 22,
  	VMXERR_VMXOFF_UNDER_DUAL_MONITOR_TREATMENT_OF_SMIS_AND_SMM = 23,
  	VMXERR_VMCALL_INVALID_SMM_MONITOR_FEATURES = 24,
  	VMXERR_ENTRY_INVALID_VM_EXECUTION_CONTROL_FIELDS_IN_EXECUTIVE_VMCS = 25,
  	VMXERR_ENTRY_EVENTS_BLOCKED_BY_MOV_SS = 26,
  	VMXERR_INVALID_OPERAND_TO_INVEPT_INVVPID = 28,
  };
6aa8b732c   Avi Kivity   [PATCH] kvm: user...
472
  #endif