VirtualBox

source: vbox/trunk/include/VBox/hwacc_svm.h@ 32824

Last change on this file since 32824 was 30791, checked in by vboxsync, 14 years ago

fixed HWACCM structure assertions.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 25.1 KB
Line 
1/** @file
2 * HWACCM - SVM Structures and Definitions. (VMM)
3 */
4
5/*
6 * Copyright (C) 2006-2007 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26#ifndef ___VBox_svm_h
27#define ___VBox_svm_h
28
29#include <VBox/types.h>
30#include <VBox/err.h>
31#include <iprt/assert.h>
32#include <iprt/asm.h>
33
34/** @defgroup grp_svm svm Types and Definitions
35 * @ingroup grp_hwaccm
36 * @{
37 */
38
39/** @name SVM features for cpuid 0x8000000a
40 * @{
41 */
42#define AMD_CPUID_SVM_FEATURE_EDX_NESTED_PAGING RT_BIT(0)
43#define AMD_CPUID_SVM_FEATURE_EDX_LBR_VIRT RT_BIT(1)
44#define AMD_CPUID_SVM_FEATURE_EDX_SVM_LOCK RT_BIT(2)
45#define AMD_CPUID_SVM_FEATURE_EDX_NRIP_SAVE RT_BIT(3)
46#define AMD_CPUID_SVM_FEATURE_EDX_SSE_3_5_DISABLE RT_BIT(9)
47#define AMD_CPUID_SVM_FEATURE_EDX_PAUSE_FILTER RT_BIT(10)
48/** @} */
49
50
51/** @name SVM Basic Exit Reasons.
52 * @{
53 */
54/** Invalid guest state in VMCB. */
55#define SVM_EXIT_INVALID -1
56/** Read from CR0-CR15. */
57#define SVM_EXIT_READ_CR0 0x0
58#define SVM_EXIT_READ_CR1 0x1
59#define SVM_EXIT_READ_CR2 0x2
60#define SVM_EXIT_READ_CR3 0x3
61#define SVM_EXIT_READ_CR4 0x4
62#define SVM_EXIT_READ_CR5 0x5
63#define SVM_EXIT_READ_CR6 0x6
64#define SVM_EXIT_READ_CR7 0x7
65#define SVM_EXIT_READ_CR8 0x8
66#define SVM_EXIT_READ_CR9 0x9
67#define SVM_EXIT_READ_CR10 0xA
68#define SVM_EXIT_READ_CR11 0xB
69#define SVM_EXIT_READ_CR12 0xC
70#define SVM_EXIT_READ_CR13 0xD
71#define SVM_EXIT_READ_CR14 0xE
72#define SVM_EXIT_READ_CR15 0xF
73/** Writes to CR0-CR15. */
74#define SVM_EXIT_WRITE_CR0 0x10
75#define SVM_EXIT_WRITE_CR1 0x11
76#define SVM_EXIT_WRITE_CR2 0x12
77#define SVM_EXIT_WRITE_CR3 0x13
78#define SVM_EXIT_WRITE_CR4 0x14
79#define SVM_EXIT_WRITE_CR5 0x15
80#define SVM_EXIT_WRITE_CR6 0x16
81#define SVM_EXIT_WRITE_CR7 0x17
82#define SVM_EXIT_WRITE_CR8 0x18
83#define SVM_EXIT_WRITE_CR9 0x19
84#define SVM_EXIT_WRITE_CR10 0x1A
85#define SVM_EXIT_WRITE_CR11 0x1B
86#define SVM_EXIT_WRITE_CR12 0x1C
87#define SVM_EXIT_WRITE_CR13 0x1D
88#define SVM_EXIT_WRITE_CR14 0x1E
89#define SVM_EXIT_WRITE_CR15 0x1F
90/** Read from DR0-DR15. */
91#define SVM_EXIT_READ_DR0 0x20
92#define SVM_EXIT_READ_DR1 0x21
93#define SVM_EXIT_READ_DR2 0x22
94#define SVM_EXIT_READ_DR3 0x23
95#define SVM_EXIT_READ_DR4 0x24
96#define SVM_EXIT_READ_DR5 0x25
97#define SVM_EXIT_READ_DR6 0x26
98#define SVM_EXIT_READ_DR7 0x27
99#define SVM_EXIT_READ_DR8 0x28
100#define SVM_EXIT_READ_DR9 0x29
101#define SVM_EXIT_READ_DR10 0x2A
102#define SVM_EXIT_READ_DR11 0x2B
103#define SVM_EXIT_READ_DR12 0x2C
104#define SVM_EXIT_READ_DR13 0x2D
105#define SVM_EXIT_READ_DR14 0x2E
106#define SVM_EXIT_READ_DR15 0x2F
107/** Writes to DR0-DR15. */
108#define SVM_EXIT_WRITE_DR0 0x30
109#define SVM_EXIT_WRITE_DR1 0x31
110#define SVM_EXIT_WRITE_DR2 0x32
111#define SVM_EXIT_WRITE_DR3 0x33
112#define SVM_EXIT_WRITE_DR4 0x34
113#define SVM_EXIT_WRITE_DR5 0x35
114#define SVM_EXIT_WRITE_DR6 0x36
115#define SVM_EXIT_WRITE_DR7 0x37
116#define SVM_EXIT_WRITE_DR8 0x38
117#define SVM_EXIT_WRITE_DR9 0x39
118#define SVM_EXIT_WRITE_DR10 0x3A
119#define SVM_EXIT_WRITE_DR11 0x3B
120#define SVM_EXIT_WRITE_DR12 0x3C
121#define SVM_EXIT_WRITE_DR13 0x3D
122#define SVM_EXIT_WRITE_DR14 0x3E
123#define SVM_EXIT_WRITE_DR15 0x3F
124/* Exception 0-31. */
125#define SVM_EXIT_EXCEPTION_0 0x40
126#define SVM_EXIT_EXCEPTION_1 0x41
127#define SVM_EXIT_EXCEPTION_2 0x42
128#define SVM_EXIT_EXCEPTION_3 0x43
129#define SVM_EXIT_EXCEPTION_4 0x44
130#define SVM_EXIT_EXCEPTION_5 0x45
131#define SVM_EXIT_EXCEPTION_6 0x46
132#define SVM_EXIT_EXCEPTION_7 0x47
133#define SVM_EXIT_EXCEPTION_8 0x48
134#define SVM_EXIT_EXCEPTION_9 0x49
135#define SVM_EXIT_EXCEPTION_A 0x4A
136#define SVM_EXIT_EXCEPTION_B 0x4B
137#define SVM_EXIT_EXCEPTION_C 0x4C
138#define SVM_EXIT_EXCEPTION_D 0x4D
139#define SVM_EXIT_EXCEPTION_E 0x4E
140#define SVM_EXIT_EXCEPTION_F 0x4F
141#define SVM_EXIT_EXCEPTION_10 0x50
142#define SVM_EXIT_EXCEPTION_11 0x51
143#define SVM_EXIT_EXCEPTION_12 0x52
144#define SVM_EXIT_EXCEPTION_13 0x53
145#define SVM_EXIT_EXCEPTION_14 0x54
146#define SVM_EXIT_EXCEPTION_15 0x55
147#define SVM_EXIT_EXCEPTION_16 0x56
148#define SVM_EXIT_EXCEPTION_17 0x57
149#define SVM_EXIT_EXCEPTION_18 0x58
150#define SVM_EXIT_EXCEPTION_19 0x59
151#define SVM_EXIT_EXCEPTION_1A 0x5A
152#define SVM_EXIT_EXCEPTION_1B 0x5B
153#define SVM_EXIT_EXCEPTION_1C 0x5C
154#define SVM_EXIT_EXCEPTION_1D 0x5D
155#define SVM_EXIT_EXCEPTION_1E 0x5E
156#define SVM_EXIT_EXCEPTION_1F 0x5F
157/** Physical maskable interrupt. */
158#define SVM_EXIT_INTR 0x60
159/** Non-maskable interrupt. */
160#define SVM_EXIT_NMI 0x61
161/** System Management interrupt. */
162#define SVM_EXIT_SMI 0x62
163/** Physical INIT signal. */
164#define SVM_EXIT_INIT 0x63
165/** Virtual interrupt. */
166#define SVM_EXIT_VINTR 0x64
167/** Write to CR0 that changed any bits other than CR0.TS or CR0.MP. */
168#define SVM_EXIT_CR0_SEL_WRITE 0x65
169/** IDTR read. */
170#define SVM_EXIT_IDTR_READ 0x66
171/** GDTR read. */
172#define SVM_EXIT_GDTR_READ 0x67
173/** LDTR read. */
174#define SVM_EXIT_LDTR_READ 0x68
175/** TR read. */
176#define SVM_EXIT_TR_READ 0x69
177/** IDTR write. */
178#define SVM_EXIT_IDTR_WRITE 0x6A
179/** GDTR write. */
180#define SVM_EXIT_GDTR_WRITE 0x6B
181/** LDTR write. */
182#define SVM_EXIT_LDTR_WRITE 0x6C
183/** TR write. */
184#define SVM_EXIT_TR_WRITE 0x6D
185/** RDTSC instruction. */
186#define SVM_EXIT_RDTSC 0x6E
187/** RDPMC instruction. */
188#define SVM_EXIT_RDPMC 0x6F
189/** PUSHF instruction. */
190#define SVM_EXIT_PUSHF 0x70
191/** POPF instruction. */
192#define SVM_EXIT_POPF 0x71
193/** CPUID instruction. */
194#define SVM_EXIT_CPUID 0x72
195/** RSM instruction. */
196#define SVM_EXIT_RSM 0x73
197/** IRET instruction. */
198#define SVM_EXIT_IRET 0x74
199/** software interrupt (INTn instructions). */
200#define SVM_EXIT_SWINT 0x75
201/** INVD instruction. */
202#define SVM_EXIT_INVD 0x76
203/** PAUSE instruction. */
204#define SVM_EXIT_PAUSE 0x77
205/** HLT instruction. */
206#define SVM_EXIT_HLT 0x78
207/** INVLPG instructions. */
208#define SVM_EXIT_INVLPG 0x79
209/** INVLPGA instruction. */
210#define SVM_EXIT_INVLPGA 0x7A
211/** IN or OUT accessing protected port (the EXITINFO1 field provides more information). */
212#define SVM_EXIT_IOIO 0x7B
213/** RDMSR or WRMSR access to protected MSR. */
214#define SVM_EXIT_MSR 0x7C
215/** task switch. */
216#define SVM_EXIT_TASK_SWITCH 0x7D
217/** FP legacy handling enabled, and processor is frozen in an x87/mmx instruction waiting for an interrupt. */
218#define SVM_EXIT_FERR_FREEZE 0x7E
219/** Shutdown. */
220#define SVM_EXIT_SHUTDOWN 0x7F
221/** VMRUN instruction. */
222#define SVM_EXIT_VMRUN 0x80
223/** VMMCALL instruction. */
224#define SVM_EXIT_VMMCALL 0x81
225/** VMLOAD instruction. */
226#define SVM_EXIT_VMLOAD 0x82
227/** VMSAVE instruction. */
228#define SVM_EXIT_VMSAVE 0x83
229/** STGI instruction. */
230#define SVM_EXIT_STGI 0x84
231/** CLGI instruction. */
232#define SVM_EXIT_CLGI 0x85
233/** SKINIT instruction. */
234#define SVM_EXIT_SKINIT 0x86
235/** RDTSCP instruction. */
236#define SVM_EXIT_RDTSCP 0x87
237/** ICEBP instruction. */
238#define SVM_EXIT_ICEBP 0x88
239/** WBINVD instruction. */
240#define SVM_EXIT_WBINVD 0x89
241/** MONITOR instruction. */
242#define SVM_EXIT_MONITOR 0x8A
243/** MWAIT instruction uncond. */
244#define SVM_EXIT_MWAIT_UNCOND 0x8B
245/** MWAIT instruction when armed. */
246#define SVM_EXIT_MWAIT_ARMED 0x8C
247/** Nested paging: host-level page fault occurred (EXITINFO1 contains fault errorcode; EXITINFO2 contains the guest physical address causing the fault). */
248#define SVM_EXIT_NPF 0x400
249
250/** @} */
251
252
253/** @name SVM_VMCB.u64ExitInfo2
254 * @{
255 */
256/** Set to 1 if the task switch was caused by an IRET; else cleared to 0. */
257#define SVM_EXIT2_TASK_SWITCH_IRET RT_BIT_64(36)
258/** Set to 1 if the task switch was caused by a far jump; else cleared to 0. */
259#define SVM_EXIT2_TASK_SWITCH_JMP RT_BIT_64(38)
260/** Set to 1 if the task switch has an error code; else cleared to 0. */
261#define SVM_EXIT2_TASK_SWITCH_HAS_ERROR_CODE RT_BIT_64(44)
262/** The value of EFLAGS.RF that would be saved in the outgoing TSS if the task switch were not intercepted. */
263#define SVM_EXIT2_TASK_SWITCH_EFLAGS_RF RT_BIT_64(48)
264/** @} */
265
266/** @name SVM_VMCB.ctrl.u32InterceptCtrl1
267 * @{
268 */
269/** 0 Intercept INTR (physical maskable interrupt) */
270#define SVM_CTRL1_INTERCEPT_INTR RT_BIT(0)
271/** 1 Intercept NMI */
272#define SVM_CTRL1_INTERCEPT_NMI RT_BIT(1)
273/** 2 Intercept SMI */
274#define SVM_CTRL1_INTERCEPT_SMI RT_BIT(2)
275/** 3 Intercept INIT */
276#define SVM_CTRL1_INTERCEPT_INIT RT_BIT(3)
277/** 4 Intercept VINTR (virtual maskable interrupt) */
278#define SVM_CTRL1_INTERCEPT_VINTR RT_BIT(4)
279/** 5 Intercept CR0 writes that change bits other than CR0.TS or CR0.MP */
280#define SVM_CTRL1_INTERCEPT_CR0 RT_BIT(5)
281/** 6 Intercept reads of IDTR */
282#define SVM_CTRL1_INTERCEPT_IDTR_READS RT_BIT(6)
283/** 7 Intercept reads of GDTR */
284#define SVM_CTRL1_INTERCEPT_GDTR_READS RT_BIT(7)
285/** 8 Intercept reads of LDTR */
286#define SVM_CTRL1_INTERCEPT_LDTR_READS RT_BIT(8)
287/** 9 Intercept reads of TR */
288#define SVM_CTRL1_INTERCEPT_TR_READS RT_BIT(9)
289/** 10 Intercept writes of IDTR */
290#define SVM_CTRL1_INTERCEPT_IDTR_WRITES RT_BIT(10)
291/** 11 Intercept writes of GDTR */
292#define SVM_CTRL1_INTERCEPT_GDTR_WRITES RT_BIT(11)
293/** 12 Intercept writes of LDTR */
294#define SVM_CTRL1_INTERCEPT_LDTR_WRITES RT_BIT(12)
295/** 13 Intercept writes of TR */
296#define SVM_CTRL1_INTERCEPT_TR_WRITES RT_BIT(13)
297/** 14 Intercept RDTSC instruction */
298#define SVM_CTRL1_INTERCEPT_RDTSC RT_BIT(14)
299/** 15 Intercept RDPMC instruction */
300#define SVM_CTRL1_INTERCEPT_RDPMC RT_BIT(15)
301/** 16 Intercept PUSHF instruction */
302#define SVM_CTRL1_INTERCEPT_PUSHF RT_BIT(16)
303/** 17 Intercept POPF instruction */
304#define SVM_CTRL1_INTERCEPT_POPF RT_BIT(17)
305/** 18 Intercept CPUID instruction */
306#define SVM_CTRL1_INTERCEPT_CPUID RT_BIT(18)
307/** 19 Intercept RSM instruction */
308#define SVM_CTRL1_INTERCEPT_RSM RT_BIT(19)
309/** 20 Intercept IRET instruction */
310#define SVM_CTRL1_INTERCEPT_IRET RT_BIT(20)
311/** 21 Intercept INTn instruction */
312#define SVM_CTRL1_INTERCEPT_INTN RT_BIT(21)
313/** 22 Intercept INVD instruction */
314#define SVM_CTRL1_INTERCEPT_INVD RT_BIT(22)
315/** 23 Intercept PAUSE instruction */
316#define SVM_CTRL1_INTERCEPT_PAUSE RT_BIT(23)
317/** 24 Intercept HLT instruction */
318#define SVM_CTRL1_INTERCEPT_HLT RT_BIT(24)
319/** 25 Intercept INVLPG instruction */
320#define SVM_CTRL1_INTERCEPT_INVLPG RT_BIT(25)
321/** 26 Intercept INVLPGA instruction */
322#define SVM_CTRL1_INTERCEPT_INVLPGA RT_BIT(26)
323/** 27 IOIO_PROT Intercept IN/OUT accesses to selected ports. */
324#define SVM_CTRL1_INTERCEPT_INOUT_BITMAP RT_BIT(27)
325/** 28 MSR_PROT Intercept RDMSR or WRMSR accesses to selected MSRs. */
326#define SVM_CTRL1_INTERCEPT_MSR_SHADOW RT_BIT(28)
327/** 29 Intercept task switches. */
328#define SVM_CTRL1_INTERCEPT_TASK_SWITCH RT_BIT(29)
329/** 30 FERR_FREEZE: intercept processor "freezing" during legacy FERR handling. */
330#define SVM_CTRL1_INTERCEPT_FERR_FREEZE RT_BIT(30)
331/** 31 Intercept shutdown events. */
332#define SVM_CTRL1_INTERCEPT_SHUTDOWN RT_BIT(31)
333/** @} */
334
335
336/** @name SVM_VMCB.ctrl.u32InterceptCtrl2
337 * @{
338 */
339/** 0 Intercept VMRUN instruction */
340#define SVM_CTRL2_INTERCEPT_VMRUN RT_BIT(0)
341/** 1 Intercept VMMCALL instruction */
342#define SVM_CTRL2_INTERCEPT_VMMCALL RT_BIT(1)
343/** 2 Intercept VMLOAD instruction */
344#define SVM_CTRL2_INTERCEPT_VMLOAD RT_BIT(2)
345/** 3 Intercept VMSAVE instruction */
346#define SVM_CTRL2_INTERCEPT_VMSAVE RT_BIT(3)
347/** 4 Intercept STGI instruction */
348#define SVM_CTRL2_INTERCEPT_STGI RT_BIT(4)
349/** 5 Intercept CLGI instruction */
350#define SVM_CTRL2_INTERCEPT_CLGI RT_BIT(5)
351/** 6 Intercept SKINIT instruction */
352#define SVM_CTRL2_INTERCEPT_SKINIT RT_BIT(6)
353/** 7 Intercept RDTSCP instruction */
354#define SVM_CTRL2_INTERCEPT_RDTSCP RT_BIT(7)
355/** 8 Intercept ICEBP instruction */
356#define SVM_CTRL2_INTERCEPT_ICEBP RT_BIT(8)
357/** 9 Intercept WBINVD instruction */
358#define SVM_CTRL2_INTERCEPT_WBINVD RT_BIT(9)
359/** 10 Intercept MONITOR instruction */
360#define SVM_CTRL2_INTERCEPT_MONITOR RT_BIT(10)
361/** 11 Intercept MWAIT instruction unconditionally */
362#define SVM_CTRL2_INTERCEPT_MWAIT_UNCOND RT_BIT(11)
363/** 12 Intercept MWAIT instruction when armed */
364#define SVM_CTRL2_INTERCEPT_MWAIT_ARMED RT_BIT(12)
365/** @} */
366
367/** @name SVM_VMCB.ctrl.u64NestedPaging
368 * @{
369 */
370#define SVM_NESTED_PAGING_ENABLE RT_BIT(0)
371/** @} */
372
373/** @name SVM_VMCB.ctrl.u64IntShadow
374 * @{
375 */
376#define SVM_INTERRUPT_SHADOW_ACTIVE RT_BIT(0)
377/** @} */
378
379
380/** @name SVM_INTCTRL.u3Type
381 * @{
382 */
383/** External or virtual interrupt. */
384#define SVM_EVENT_EXTERNAL_IRQ 0
385/** Non-maskable interrupt. */
386#define SVM_EVENT_NMI 2
387/** Exception; fault or trap. */
388#define SVM_EVENT_EXCEPTION 3
389/** Software interrupt. */
390#define SVM_EVENT_SOFTWARE_INT 4
391/** @} */
392
393
394
395
396/**
397 * SVM Selector type; includes hidden parts
398 */
399#pragma pack(1)
400typedef struct
401{
402 uint16_t u16Sel;
403 uint16_t u16Attr;
404 uint32_t u32Limit;
405 uint64_t u64Base; /**< Only lower 32 bits are implemented for CS, DS, ES & SS. */
406} SVMSEL;
407#pragma pack()
408
409/**
410 * SVM GDTR/IDTR type
411 */
412#pragma pack(1)
413typedef struct
414{
415 uint16_t u16Reserved1;
416 uint16_t u16Reserved2;
417 uint32_t u32Limit; /**< Only lower 16 bits are implemented. */
418 uint64_t u64Base;
419} SVMGDTR;
420#pragma pack()
421
422typedef SVMGDTR SVMIDTR;
423
424/**
425 * SVM Event injection structure
426 */
427#pragma pack(1)
428typedef union
429{
430 struct
431 {
432 uint32_t u8Vector : 8;
433 uint32_t u3Type : 3;
434 uint32_t u1ErrorCodeValid : 1;
435 uint32_t u19Reserved : 19;
436 uint32_t u1Valid : 1;
437 uint32_t u32ErrorCode : 32;
438 } n;
439 uint64_t au64[1];
440} SVM_EVENT;
441#pragma pack()
442
443
444/**
445 * SVM Interrupt control structure
446 */
447#pragma pack(1)
448typedef union
449{
450 struct
451 {
452 uint32_t u8VTPR : 8;
453 uint32_t u1VIrqValid : 1;
454 uint32_t u7Reserved : 7;
455 uint32_t u4VIrqPriority : 4;
456 uint32_t u1IgnoreTPR : 1;
457 uint32_t u3Reserved : 3;
458 uint32_t u1VIrqMasking : 1;
459 uint32_t u7Reserved2 : 7;
460 uint32_t u8VIrqVector : 8;
461 uint32_t u24Reserved : 24;
462 } n;
463 uint64_t au64[1];
464} SVM_INTCTRL;
465#pragma pack()
466
467
468/**
469 * SVM TLB control structure
470 */
471#pragma pack(1)
472typedef union
473{
474 struct
475 {
476 uint32_t u32ASID : 32;
477 uint32_t u1TLBFlush : 1;
478 uint32_t u7Reserved : 7;
479 uint32_t u24Reserved : 24;
480 } n;
481 uint64_t au64[1];
482} SVM_TLBCTRL;
483#pragma pack()
484
485
486/**
487 * SVM IOIO exit structure
488 */
489#pragma pack(1)
490typedef union
491{
492 struct
493 {
494 uint32_t u1Type : 1; /**< 0 = out, 1 = in */
495 uint32_t u1Reserved : 1;
496 uint32_t u1STR : 1;
497 uint32_t u1REP : 1;
498 uint32_t u1OP8 : 1;
499 uint32_t u1OP16 : 1;
500 uint32_t u1OP32 : 1;
501 uint32_t u1ADDR16 : 1;
502 uint32_t u1ADDR32 : 1;
503 uint32_t u1ADDR64 : 1;
504 uint32_t u6Reserved : 6;
505 uint32_t u16Port : 16;
506 } n;
507 uint32_t au32[1];
508} SVM_IOIO_EXIT;
509#pragma pack()
510
511/**
512 * SVM nested paging structure
513 */
514#pragma pack(1)
515typedef union
516{
517 struct
518 {
519 uint32_t u1NestedPaging : 1; /**< enabled/disabled */
520 } n;
521 uint64_t au64[1];
522} SVM_NPCTRL;
523#pragma pack()
524
525/**
526 * SVM VM Control Block. (VMCB)
527 */
528#pragma pack(1)
529typedef struct _SVM_VMCB
530{
531 /** Control Area. */
532 struct
533 {
534 /** Offset 0x00 - Intercept reads of CR0-15. */
535 uint16_t u16InterceptRdCRx;
536 /** Offset 0x02 - Intercept writes to CR0-15. */
537 uint16_t u16InterceptWrCRx;
538 /** Offset 0x04 - Intercept reads of DR0-15. */
539 uint16_t u16InterceptRdDRx;
540 /** Offset 0x06 - Intercept writes to DR0-15. */
541 uint16_t u16InterceptWrDRx;
542 /** Offset 0x08 - Intercept exception vectors 0-31. */
543 uint32_t u32InterceptException;
544 /** Offset 0x0C - Intercept control field 1. */
545 uint32_t u32InterceptCtrl1;
546 /** Offset 0x0C - Intercept control field 2. */
547 uint32_t u32InterceptCtrl2;
548 /** Offset 0x14-0x3F - Reserved. */
549 uint8_t u8Reserved[0x40-0x14];
550 /** Offset 0x40 - Physical address of IOPM. */
551 uint64_t u64IOPMPhysAddr;
552 /** Offset 0x48 - Physical address of MSRPM. */
553 uint64_t u64MSRPMPhysAddr;
554 /** Offset 0x50 - TSC Offset. */
555 uint64_t u64TSCOffset;
556 /** Offset 0x58 - TLB control field. */
557 SVM_TLBCTRL TLBCtrl;
558 /** Offset 0x60 - Interrupt control field. */
559 SVM_INTCTRL IntCtrl;
560 /** Offset 0x68 - Interrupt shadow. */
561 uint64_t u64IntShadow;
562 /** Offset 0x70 - Exit code. */
563 uint64_t u64ExitCode;
564 /** Offset 0x78 - Exit info 1. */
565 uint64_t u64ExitInfo1;
566 /** Offset 0x80 - Exit info 2. */
567 uint64_t u64ExitInfo2;
568 /** Offset 0x88 - Exit Interrupt info. */
569 SVM_EVENT ExitIntInfo;
570 /** Offset 0x90 - Nested Paging. */
571 SVM_NPCTRL NestedPaging;
572 /** Offset 0x98-0xA7 - Reserved. */
573 uint8_t u8Reserved2[0xA8-0x98];
574 /** Offset 0xA8 - Event injection. */
575 SVM_EVENT EventInject;
576 /** Offset 0xB0 - Host CR3 for nested paging. */
577 uint64_t u64NestedPagingCR3;
578 /** Offset 0xB8 - LBR Virtualization. */
579 uint64_t u64LBRVirt;
580 /** Offset 0xC0 - VMCB Clean Bits. */
581 uint64_t u64VMCBCleanBits;
582 /** Offset 0xC8 - Next sequential instruction pointer. */
583 uint64_t u64NextRIP;
584 /** Offset 0xD0 - Number of bytes fetched. */
585 uint8_t cbInstrFetched;
586 /** Offset 0xD1 - Number of bytes fetched. */
587 uint8_t abInstr[15];
588 } ctrl;
589
590 /** Offset 0xC0-0x3FF - Reserved. */
591 uint8_t u8Reserved3[0x400-0xE0];
592
593 /** State Save Area. Starts at offset 0x400. */
594 struct
595 {
596 /** Offset 0x400 - Guest ES register + hidden parts. */
597 SVMSEL ES;
598 /** Offset 0x410 - Guest CS register + hidden parts. */
599 SVMSEL CS;
600 /** Offset 0x420 - Guest SS register + hidden parts. */
601 SVMSEL SS;
602 /** Offset 0x430 - Guest DS register + hidden parts. */
603 SVMSEL DS;
604 /** Offset 0x440 - Guest FS register + hidden parts. */
605 SVMSEL FS;
606 /** Offset 0x450 - Guest GS register + hidden parts. */
607 SVMSEL GS;
608 /** Offset 0x460 - Guest GDTR register. */
609 SVMGDTR GDTR;
610 /** Offset 0x470 - Guest LDTR register + hidden parts. */
611 SVMSEL LDTR;
612 /** Offset 0x480 - Guest IDTR register. */
613 SVMIDTR IDTR;
614 /** Offset 0x490 - Guest TR register + hidden parts. */
615 SVMSEL TR;
616 /** Offset 0x4A0-0x4CA - Reserved. */
617 uint8_t u8Reserved4[0x4CB-0x4A0];
618 /** Offset 0x4CB - CPL. */
619 uint8_t u8CPL;
620 /** Offset 0x4CC-0x4CF - Reserved. */
621 uint8_t u8Reserved5[0x4D0-0x4CC];
622 /** Offset 0x4D0 - EFER. */
623 uint64_t u64EFER;
624 /** Offset 0x4D8-0x547 - Reserved. */
625 uint8_t u8Reserved6[0x548-0x4D8];
626 /** Offset 0x548 - CR4. */
627 uint64_t u64CR4;
628 /** Offset 0x550 - CR3. */
629 uint64_t u64CR3;
630 /** Offset 0x558 - CR0. */
631 uint64_t u64CR0;
632 /** Offset 0x560 - DR7. */
633 uint64_t u64DR7;
634 /** Offset 0x568 - DR6. */
635 uint64_t u64DR6;
636 /** Offset 0x570 - RFLAGS. */
637 uint64_t u64RFlags;
638 /** Offset 0x578 - RIP. */
639 uint64_t u64RIP;
640 /** Offset 0x580-0x5D7 - Reserved. */
641 uint8_t u8Reserved7[0x5D8-0x580];
642 /** Offset 0x5D8 - RSP. */
643 uint64_t u64RSP;
644 /** Offset 0x5E0-0x5F7 - Reserved. */
645 uint8_t u8Reserved8[0x5F8-0x5E0];
646 /** Offset 0x5F8 - RAX. */
647 uint64_t u64RAX;
648 /** Offset 0x600 - STAR. */
649 uint64_t u64STAR;
650 /** Offset 0x608 - LSTAR. */
651 uint64_t u64LSTAR;
652 /** Offset 0x610 - CSTAR. */
653 uint64_t u64CSTAR;
654 /** Offset 0x618 - SFMASK. */
655 uint64_t u64SFMASK;
656 /** Offset 0x620 - KernelGSBase. */
657 uint64_t u64KernelGSBase;
658 /** Offset 0x628 - SYSENTER_CS. */
659 uint64_t u64SysEnterCS;
660 /** Offset 0x630 - SYSENTER_ESP. */
661 uint64_t u64SysEnterESP;
662 /** Offset 0x638 - SYSENTER_EIP. */
663 uint64_t u64SysEnterEIP;
664 /** Offset 0x640 - CR2. */
665 uint64_t u64CR2;
666 /** Offset 0x648-0x667 - Reserved. */
667 uint8_t u8Reserved9[0x668-0x648];
668 /** Offset 0x668 - G_PAT. */
669 uint64_t u64GPAT;
670 /** Offset 0x670 - DBGCTL. */
671 uint64_t u64DBGCTL;
672 /** Offset 0x678 - BR_FROM. */
673 uint64_t u64BR_FROM;
674 /** Offset 0x680 - BR_TO. */
675 uint64_t u64BR_TO;
676 /** Offset 0x688 - LASTEXCPFROM. */
677 uint64_t u64LASTEXCPFROM;
678 /** Offset 0x690 - LASTEXCPTO. */
679 uint64_t u64LASTEXCPTO;
680 } guest;
681
682 /** Offset 0x698-0xFFF- Reserved. */
683 uint8_t u8Reserved10[0x1000-0x698];
684} SVM_VMCB;
685#pragma pack()
686AssertCompileSize(SVM_VMCB, 0x1000);
687AssertCompileMemberOffset(SVM_VMCB, ctrl.u16InterceptRdCRx, 0x000);
688AssertCompileMemberOffset(SVM_VMCB, ctrl.TLBCtrl, 0x058);
689AssertCompileMemberOffset(SVM_VMCB, ctrl.ExitIntInfo, 0x088);
690AssertCompileMemberOffset(SVM_VMCB, ctrl.EventInject, 0x0A8);
691AssertCompileMemberOffset(SVM_VMCB, ctrl.abInstr, 0x0D1);
692AssertCompileMemberOffset(SVM_VMCB, guest, 0x400);
693AssertCompileMemberOffset(SVM_VMCB, guest.ES, 0x400);
694AssertCompileMemberOffset(SVM_VMCB, guest.u8Reserved4, 0x4A0);
695AssertCompileMemberOffset(SVM_VMCB, guest.u8CPL, 0x4CB);
696AssertCompileMemberOffset(SVM_VMCB, guest.u8Reserved6, 0x4D8);
697AssertCompileMemberOffset(SVM_VMCB, guest.u8Reserved7, 0x580);
698AssertCompileMemberOffset(SVM_VMCB, guest.u8Reserved9, 0x648);
699AssertCompileMemberOffset(SVM_VMCB, guest.u64GPAT, 0x668);
700AssertCompileMemberOffset(SVM_VMCB, guest.u64LASTEXCPTO, 0x690);
701AssertCompileMemberOffset(SVM_VMCB, u8Reserved10, 0x698);
702
703#ifdef IN_RING0
704VMMR0DECL(int) SVMR0InvalidatePage(PVM pVM, PVMCPU pVCpu, RTGCPTR GCVirt);
705#endif /* IN_RING0 */
706
707/** @} */
708
709#endif
710
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette