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
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
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
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
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
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
//! Virtual-machine control structure fields.
//!
//! See Intel SDM, Volume 3D, Appendix B.

/// VM-execution, VM-exit, and VM-entry control fields.
pub mod control {
    use bitflags::bitflags;

    // B.1.1.: 16-bit control fields
    /// Virtual-processor identifier (VPID).
    pub const VPID: u32 = 0x0;
    /// Posted-interrupt notification vector.
    pub const POSTED_INTERRUPT_NOTIFICATION_VECTOR: u32 = 0x2;
    /// EPTP index.
    pub const EPTP_INDEX: u32 = 0x4;

    // B.2.1.: 64-bit control fields
    /// Address of I/O bitmap A (full).
    pub const IO_BITMAP_A_ADDR_FULL: u32 = 0x2000;
    /// Address of I/O bitmap A (high).
    pub const IO_BITMAP_A_ADDR_HIGH: u32 = 0x2001;
    /// Address of I/O bitmap B (full).
    pub const IO_BITMAP_B_ADDR_FULL: u32 = 0x2002;
    /// Address of I/O bitmap B (high).
    pub const IO_BITMAP_B_ADDR_HIGH: u32 = 0x2003;
    /// Address of MSR bitmaps (full).
    pub const MSR_BITMAPS_ADDR_FULL: u32 = 0x2004;
    /// Address of MSR bitmaps (high).
    pub const MSR_BITMAPS_ADDR_HIGH: u32 = 0x2005;
    /// VM-exit MSR-store address (full).
    pub const VMEXIT_MSR_STORE_ADDR_FULL: u32 = 0x2006;
    /// VM-exit MSR-store address (high).
    pub const VMEXIT_MSR_STORE_ADDR_HIGH: u32 = 0x2007;
    /// VM-exit MSR-load address (full).
    pub const VMEXIT_MSR_LOAD_ADDR_FULL: u32 = 0x2008;
    /// VM-exit MSR-load address (high).
    pub const VMEXIT_MSR_LOAD_ADDR_HIGH: u32 = 0x2009;
    /// VM-entry MSR-load address (full).
    pub const VMENTRY_MSR_LOAD_ADDR_FULL: u32 = 0x200A;
    /// VM-entry MSR-load address (high).
    pub const VMENTRY_MSR_LOAD_ADDR_HIGH: u32 = 0x200B;
    /// Executive-VMCS pointer (full).
    pub const EXECUTIVE_VMCS_PTR_FULL: u32 = 0x200C;
    /// Executive-VMCS pointer (high).
    pub const EXECUTIVE_VMCS_PTR_HIGH: u32 = 0x200D;
    /// PML address (full).
    pub const PML_ADDR_FULL: u32 = 0x200E;
    /// PML address (high).
    pub const PML_ADDR_HIGH: u32 = 0x200F;
    /// TSC offset (full).
    pub const TSC_OFFSET_FULL: u32 = 0x2010;
    /// TSC offset (high).
    pub const TSC_OFFSET_HIGH: u32 = 0x2011;
    /// Virtual-APIC address (full).
    pub const VIRT_APIC_ADDR_FULL: u32 = 0x2012;
    /// Virtual-APIC address (high).
    pub const VIRT_APIC_ADDR_HIGH: u32 = 0x2013;
    /// APIC-access address (full).
    pub const APIC_ACCESS_ADDR_FULL: u32 = 0x2014;
    /// APIC-access address (high).
    pub const APIC_ACCESS_ADDR_HIGH: u32 = 0x2015;
    /// Posted-interrupt descriptor address (full).
    pub const POSTED_INTERRUPT_DESC_ADDR_FULL: u32 = 0x2016;
    /// Posted-interrupt descriptor address (high).
    pub const POSTED_INTERRUPT_DESC_ADDR_HIGH: u32 = 0x2017;
    /// VM-function controls (full).
    pub const VM_FUNCTION_CONTROLS_FULL: u32 = 0x2018;
    /// VM-function controls (high).
    pub const VM_FUNCTION_CONTROLS_HIGH: u32 = 0x2019;
    /// EPT pointer (full).
    pub const EPTP_FULL: u32 = 0x201A;
    /// EPT pointer (high).
    pub const EPTP_HIGH: u32 = 0x201B;
    /// EOI-exit bitmap 0 (full).
    pub const EOI_EXIT0_FULL: u32 = 0x201C;
    /// EOI-exit bitmap 0 (high).
    pub const EOI_EXIT0_HIGH: u32 = 0x201D;
    /// EOI-exit bitmap 1 (full).
    pub const EOI_EXIT1_FULL: u32 = 0x201E;
    /// EOI-exit bitmap 1 (high).
    pub const EOI_EXIT1_HIGH: u32 = 0x201F;
    /// EOI-exit bitmap 2 (full).
    pub const EOI_EXIT2_FULL: u32 = 0x2020;
    /// EOI-exit bitmap 2 (high).
    pub const EOI_EXIT2_HIGH: u32 = 0x2021;
    /// EOI-exit bitmap 3 (full).
    pub const EOI_EXIT3_FULL: u32 = 0x2022;
    /// EOI-exit bitmap 3 (high).
    pub const EOI_EXIT3_HIGH: u32 = 0x2023;
    /// EPTP-list address (full).
    pub const EPTP_LIST_ADDR_FULL: u32 = 0x2024;
    /// EPTP-list address (high).
    pub const EPTP_LIST_ADDR_HIGH: u32 = 0x2025;
    /// VMREAD-bitmap address (full).
    pub const VMREAD_BITMAP_ADDR_FULL: u32 = 0x2026;
    /// VMREAD-bitmap address (high).
    pub const VMREAD_BITMAP_ADDR_HIGH: u32 = 0x2027;
    /// VMWRITE-bitmap address (full).
    pub const VMWRITE_BITMAP_ADDR_FULL: u32 = 0x2028;
    /// VMWRITE-bitmap address (high).
    pub const VMWRITE_BITMAP_ADDR_HIGH: u32 = 0x2029;
    /// Virtualization-exception information address (full).
    pub const VIRT_EXCEPTION_INFO_ADDR_FULL: u32 = 0x202A;
    /// Virtualization-exception information address (high).
    pub const VIRT_EXCEPTION_INFO_ADDR_HIGH: u32 = 0x202B;
    /// XSS-exiting bitmap (full).
    pub const XSS_EXITING_BITMAP_FULL: u32 = 0x202C;
    /// XSS-exiting bitmap (high).
    pub const XSS_EXITING_BITMAP_HIGH: u32 = 0x202D;
    /// ENCLS-exiting bitmap (full).
    pub const ENCLS_EXITING_BITMAP_FULL: u32 = 0x202E;
    /// ENCLS-exiting bitmap (high).
    pub const ENCLS_EXITING_BITMAP_HIGH: u32 = 0x202F;
    /// Sub-page-permission-table pointer (full).
    pub const SUBPAGE_PERM_TABLE_PTR_FULL: u32 = 0x2030;
    /// Sub-page-permission-table pointer (high).
    pub const SUBPAGE_PERM_TABLE_PTR_HIGH: u32 = 0x2031;
    /// TSC multiplier (full).
    pub const TSC_MULTIPLIER_FULL: u32 = 0x2032;
    /// TSC multiplier (high).
    pub const TSC_MULTIPLIER_HIGH: u32 = 0x2033;

    // B.3.1.: 32-bit control fields
    /// Pin-based VM-execution controls.
    pub const PINBASED_EXEC_CONTROLS: u32 = 0x4000;
    /// Primary processor-based VM-execution controls.
    pub const PRIMARY_PROCBASED_EXEC_CONTROLS: u32 = 0x4002;
    /// Exception bitmap.
    pub const EXCEPTION_BITMAP: u32 = 0x4004;
    /// Page-fault error-code mask.
    pub const PAGE_FAULT_ERR_CODE_MASK: u32 = 0x4006;
    /// Page-fault error-code match.
    pub const PAGE_FAULT_ERR_CODE_MATCH: u32 = 0x4008;
    /// CR3-target count.
    pub const CR3_TARGET_COUNT: u32 = 0x400A;
    /// VM-exit controls.
    pub const VMEXIT_CONTROLS: u32 = 0x400C;
    /// VM-exit MSR-store count.
    pub const VMEXIT_MSR_STORE_COUNT: u32 = 0x400E;
    /// VM-exit MSR-load count.
    pub const VMEXIT_MSR_LOAD_COUNT: u32 = 0x4010;
    /// VM-entry controls.
    pub const VMENTRY_CONTROLS: u32 = 0x4012;
    /// VM-entry MSR-load count.
    pub const VMENTRY_MSR_LOAD_COUNT: u32 = 0x4014;
    /// VM-entry interruption-information field.
    pub const VMENTRY_INTERRUPTION_INFO_FIELD: u32 = 0x4016;
    /// VM-entry exception error code.
    pub const VMENTRY_EXCEPTION_ERR_CODE: u32 = 0x4018;
    /// VM-entry instruction length.
    pub const VMENTRY_INSTRUCTION_LEN: u32 = 0x401A;
    /// TPR threshold.
    pub const TPR_THRESHOLD: u32 = 0x401C;
    /// Secondary processor-based VM-execution controls.
    pub const SECONDARY_PROCBASED_EXEC_CONTROLS: u32 = 0x401E;
    /// PLE_Gap.
    pub const PLE_GAP: u32 = 0x4020;
    /// PLE_Window.
    pub const PLE_WINDOW: u32 = 0x4022;

    // B.4.1.: natural-width control fields
    /// CR0 guest/host mask.
    pub const CR0_GUEST_HOST_MASK: u32 = 0x6000;
    /// CR4 guest/host mask.
    pub const CR4_GUEST_HOST_MASK: u32 = 0x6002;
    /// CR0 read shadow.
    pub const CR0_READ_SHADOW: u32 = 0x6004;
    /// CR4 read shadow.
    pub const CR4_READ_SHADOW: u32 = 0x6006;
    /// CR3-target value 0.
    pub const CR3_TARGET_VALUE0: u32 = 0x6008;
    /// CR3-target value 1.
    pub const CR3_TARGET_VALUE1: u32 = 0x600A;
    /// CR3-target value 2.
    pub const CR3_TARGET_VALUE2: u32 = 0x600C;
    /// CR3-target value 3.
    pub const CR3_TARGET_VALUE3: u32 = 0x600E;

    bitflags! {
        /// Pin-based VM-execution controls.
        ///
        /// A set of bitmask flags useful when setting up [`PINBASED_EXEC_CONTROLS`] VMCS field.
        ///
        /// See Intel SDM, Volume 3C, Section 24.6.1.
        pub struct PinbasedControls: u32 {
            /// External-interrupt exiting.
            const EXTERNAL_INTERRUPT_EXITING = 1 << 0;
            /// NMI exiting.
            const NMI_EXITING = 1 << 3;
            /// Virtual NMIs.
            const VIRTUAL_NMIS = 1 << 5;
            /// Activate VMX-preemption timer.
            const VMX_PREEMPTION_TIMER = 1 << 6;
            /// Process posted interrupts.
            const POSTED_INTERRUPTS = 1 << 7;
        }
    }

    bitflags! {
        /// Primary processor-based VM-execution controls.
        ///
        /// A set of bitmask flags useful when setting up [`PRIMARY_PROCBASED_EXEC_CONTROLS`] VMCS field.
        ///
        /// See Intel SDM, Volume 3C, Section 24.6.2, Table 24-6.
        pub struct PrimaryControls: u32 {
            /// Interrupt-window exiting.
            const INTERRUPT_WINDOW_EXITING = 1 << 2;
            /// Use TSC offsetting.
            const USE_TSC_OFFSETTING = 1 << 3;
            /// HLT exiting.
            const HLT_EXITING = 1 << 7;
            /// INVLPG exiting.
            const INVLPG_EXITING = 1 << 9;
            /// MWAIT exiting.
            const MWAIT_EXITING = 1 << 10;
            /// RDPMC exiting.
            const RDPMC_EXITING = 1 << 11;
            /// RDTSC exiting.
            const RDTSC_EXITING = 1 << 12;
            /// CR3-load exiting.
            const CR3_LOAD_EXITING = 1 << 15;
            /// CR3-store exiting.
            const CR3_STORE_EXITING = 1 << 16;
            /// CR8-load exiting.
            const CR8_LOAD_EXITING = 1 << 19;
            /// CR8-store exiting.
            const CR8_STORE_EXITING = 1 << 20;
            /// Use TPR shadow.
            const USE_TPR_SHADOW = 1 << 21;
            /// NMI-window exiting.
            const NMI_WINDOW_EXITING = 1 << 22;
            /// MOV-DR exiting
            const MOV_DR_EXITING = 1 << 23;
            /// Unconditional I/O exiting.
            const UNCOND_IO_EXITING = 1 << 24;
            /// Use I/O bitmaps.
            const USE_IO_BITMAPS = 1 << 25;
            /// Monitor trap flag.
            const MONITOR_TRAP_FLAG = 1 << 27;
            /// Use MSR bitmaps.
            const USE_MSR_BITMAPS = 1 << 28;
            /// MONITOR exiting.
            const MONITOR_EXITING = 1 << 29;
            /// PAUSE exiting.
            const PAUSE_EXITING = 1 << 30;
            /// Activate secondary controls.
            const SECONDARY_CONTROLS = 1 << 31;
        }
    }

    bitflags! {
        /// Secondary processor-based VM-execution controls.
        ///
        /// A set of bitmask flags useful when setting up [`SECONDARY_PROCBASED_EXEC_CONTROLS`] VMCS field.
        ///
        /// See Intel SDM, Volume 3C, Section 24.6.2, Table 24-7.
        pub struct SecondaryControls: u32 {
            /// Virtualize APIC accesses.
            const VIRTUALIZE_APIC = 1 << 0;
            /// Enable EPT.
            const ENABLE_EPT = 1 << 1;
            /// Descriptor-table exiting.
            const DTABLE_EXITING = 1 << 2;
            /// Enable RDTSCP.
            const ENABLE_RDTSCP = 1 << 3;
            /// Virtualize x2APIC mode.
            const VIRTUALIZE_X2APIC = 1 << 4;
            /// Enable VPID.
            const ENABLE_VPID = 1 << 5;
            /// WBINVD exiting.
            const WBINVD_EXITING = 1 << 6;
            /// Unrestricted guest.
            const UNRESTRICTED_GUEST = 1 << 7;
            /// APIC-register virtualization.
            const VIRTUALIZE_APIC_REGISTER = 1 << 8;
            /// Virtual-interrupt delivery.
            const VIRTUAL_INTERRUPT_DELIVERY = 1 << 9;
            /// PAUSE-loop exiting.
            const PAUSE_LOOP_EXITING = 1 << 10;
            /// RDRAND exiting.
            const RDRAND_EXITING = 1 << 11;
            /// Enable INVPCID.
            const ENABLE_INVPCID = 1 << 12;
            /// Enable VM functions.
            const ENABLE_VM_FUNCTIONS = 1 << 13;
            /// VMCS shadowing.
            const VMCS_SHADOWING = 1 << 14;
            /// Enable ENCLS exiting.
            const ENCLS_EXITING = 1 << 15;
            /// RDSEED exiting.
            const RDSEED_EXITING = 1 << 16;
            /// Enable PML.
            const ENABLE_PML = 1 << 17;
            /// EPT-violation #VE.
            const EPT_VIOLATION_VE = 1 << 18;
            /// Conceal VMX from PT.
            const CONCEAL_VMX_FROM_PT = 1 << 19;
            /// Enable XSAVES/XRSTORS.
            const ENABLE_XSAVES_XRSTORS = 1 << 20;
            /// Mode-based execute control for EPT.
            const MODE_BASED_EPT = 1 << 22;
            /// Sub-page write permissions for EPT.
            const SUB_PAGE_EPT = 1 << 23;
            /// Intel PT uses guest physical addresses.
            const INTEL_PT_GUEST_PHYSICAL = 1 << 24;
            /// Use TSC scaling.
            const USE_TSC_SCALING = 1 << 25;
            /// Enable user wait and pause.
            const ENABLE_USER_WAIT_PAUSE = 1 << 26;
            /// Enable ENCLV exiting.
            const ENCLV_EXITING = 1 << 28;
        }
    }

    bitflags! {
        /// VM-entry controls.
        ///
        /// A set of bitmask flags useful when setting up [`VMENTRY_CONTROLS`] VMCS field.
        ///
        /// See Intel SDM, Volume 3C, Section 24.8.
        pub struct EntryControls: u32 {
            /// Load debug controls.
            const LOAD_DEBUG_CONTROLS = 1 << 2;
            /// IA-32e mode guest.
            const IA32E_MODE_GUEST = 1 << 9;
            /// Entry to SMM.
            const ENTRY_TO_SMM = 1 << 10;
            /// Deactivate dual-monitor treatment.
            const DEACTIVATE_DUAL_MONITOR = 1 << 11;
            /// Load IA32_PERF_GLOBAL_CTRL.
            const LOAD_IA32_PERF_GLOBAL_CTRL = 1 << 13;
            /// Load IA32_PAT.
            const LOAD_IA32_PAT = 1 << 14;
            /// Load IA32_EFER.
            const LOAD_IA32_EFER = 1 << 15;
            /// Load IA32_BNDCFGS.
            const LOAD_IA32_BNDCFGS = 1 << 16;
            /// Conceal VMX from PT.
            const CONCEAL_VMX_FROM_PT = 1 << 17;
            /// Load IA32_RTIT_CTL.
            const LOAD_IA32_RTIT_CTL = 1 << 18;
        }
    }

    bitflags! {
        /// VM-exit controls.
        ///
        /// A set of bitmask flags useful when setting up [`VMEXIT_CONTROLS`] VMCS field.
        ///
        /// See Intel SDM, Volume 3C, Section 24.7.
        pub struct ExitControls: u32 {
            /// Save debug controls.
            const SAVE_DEBUG_CONTROLS = 1 << 2;
            /// Host address-space size.
            const HOST_ADDRESS_SPACE_SIZE = 1 << 9;
            /// Load IA32_PERF_GLOBAL_CTRL.
            const LOAD_IA32_PERF_GLOBAL_CTRL = 1 << 12;
            /// Acknowledge interrupt on exit.
            const ACK_INTERRUPT_ON_EXIT = 1 << 15;
            /// Save IA32_PAT.
            const SAVE_IA32_PAT = 1 << 18;
            /// Load IA32_PAT.
            const LOAD_IA32_PAT = 1 << 19;
            /// Save IA32_EFER.
            const SAVE_IA32_EFER = 1 << 20;
            /// Load IA32_EFER.
            const LOAD_IA32_EFER = 1 << 21;
            /// Save VMX-preemption timer.
            const SAVE_VMX_PREEMPTION_TIMER = 1 << 22;
            /// Clear IA32_BNDCFGS.
            const CLEAR_IA32_BNDCFGS = 1 << 23;
            /// Conceal VMX from PT.
            const CONCEAL_VMX_FROM_PT = 1 << 24;
            /// Clear IA32_RTIT_CTL.
            const CLEAR_IA32_RTIT_CTL = 1 << 25;
        }
    }
}

/// Fields used to access guest-state area.
pub mod guest {
    // B.1.2.: 16-bit guest-state fields
    /// Guest ES selector.
    pub const ES_SELECTOR: u32 = 0x800;
    /// Guest CS selector.
    pub const CS_SELECTOR: u32 = 0x802;
    /// Guest SS selector.
    pub const SS_SELECTOR: u32 = 0x804;
    /// Guest DS selector.
    pub const DS_SELECTOR: u32 = 0x806;
    /// Guest FS selector.
    pub const FS_SELECTOR: u32 = 0x808;
    /// Guest GS selector.
    pub const GS_SELECTOR: u32 = 0x80A;
    /// Guest LDTR selector.
    pub const LDTR_SELECTOR: u32 = 0x80C;
    /// Guest TR selector.
    pub const TR_SELECTOR: u32 = 0x80E;
    /// Guest interrupt status.
    pub const INTERRUPT_STATUS: u32 = 0x810;
    /// PML index.
    pub const PML_INDEX: u32 = 0x812;

    // B.2.3.: 64-bit guest-state fields
    /// VMCS link pointer (full).
    pub const LINK_PTR_FULL: u32 = 0x2800;
    /// VMCS link pointer (high).
    pub const LINK_PTR_HIGH: u32 = 0x2801;
    /// Guest IA32_DEBUGCTL (full).
    pub const IA32_DEBUGCTL_FULL: u32 = 0x2802;
    /// Guest IA32_DEBUGCTL (high).
    pub const IA32_DEBUGCTL_HIGH: u32 = 0x2803;
    /// Guest IA32_PAT (full).
    pub const IA32_PAT_FULL: u32 = 0x2804;
    /// Guest IA32_PAT (high).
    pub const IA32_PAT_HIGH: u32 = 0x2805;
    /// Guest IA32_EFER (full).
    pub const IA32_EFER_FULL: u32 = 0x2806;
    /// Guest IA32_EFER (high).
    pub const IA32_EFER_HIGH: u32 = 0x2807;
    /// Guest IA32_PERF_GLOBAL_CTRL (full).
    pub const IA32_PERF_GLOBAL_CTRL_FULL: u32 = 0x2808;
    /// Guest IA32_PERF_GLOBAL_CTRL (high).
    pub const IA32_PERF_GLOBAL_CTRL_HIGH: u32 = 0x2809;
    /// Guest PDPTE0 (full).
    pub const PDPTE0_FULL: u32 = 0x280A;
    /// Guest PDPTE0 (high).
    pub const PDPTE0_HIGH: u32 = 0x280B;
    /// Guest PDPTE1 (full).
    pub const PDPTE1_FULL: u32 = 0x280C;
    /// Guest PDPTE1 (high).
    pub const PDPTE1_HIGH: u32 = 0x280D;
    /// Guest PDPTE2 (full).
    pub const PDPTE2_FULL: u32 = 0x280E;
    /// Guest PDPTE2 (high).
    pub const PDPTE2_HIGH: u32 = 0x280F;
    /// Guest PDPTE3 (full).
    pub const PDPTE3_FULL: u32 = 0x2810;
    /// Guest PDPTE3 (high).
    pub const PDPTE3_HIGH: u32 = 0x2811;
    /// Guest IA32_BNDCFGS (full).
    pub const IA32_BNDCFGS_FULL: u32 = 0x2812;
    /// Guest IA32_BNDCFGS (high).
    pub const IA32_BNDCFGS_HIGH: u32 = 0x2813;
    /// Guest IA32_RTIT_CTL (full).
    pub const IA32_RTIT_CTL_FULL: u32 = 0x2814;
    /// Guest IA32_RTIT_CTL (high).
    pub const IA32_RTIT_CTL_HIGH: u32 = 0x2815;

    // B.3.3.: 32-bit guest-state fields
    /// Guest ES limit.
    pub const ES_LIMIT: u32 = 0x4800;
    /// Guest CS limit.
    pub const CS_LIMIT: u32 = 0x4802;
    /// Guest SS limit.
    pub const SS_LIMIT: u32 = 0x4804;
    /// Guest DS limit.
    pub const DS_LIMIT: u32 = 0x4806;
    /// Guest FS limit.
    pub const FS_LIMIT: u32 = 0x4808;
    /// Guest GS limit.
    pub const GS_LIMIT: u32 = 0x480A;
    /// Guest LDTR limit.
    pub const LDTR_LIMIT: u32 = 0x480C;
    /// Guest TR limit.
    pub const TR_LIMIT: u32 = 0x480E;
    /// Guest GDTR limit.
    pub const GDTR_LIMIT: u32 = 0x4810;
    /// Guest IDTR limit.
    pub const IDTR_LIMIT: u32 = 0x4812;
    /// Guest ES access rights.
    pub const ES_ACCESS_RIGHTS: u32 = 0x4814;
    /// Guest CS access rights.
    pub const CS_ACCESS_RIGHTS: u32 = 0x4816;
    /// Guest SS access rights.
    pub const SS_ACCESS_RIGHTS: u32 = 0x4818;
    /// Guest DS access rights.
    pub const DS_ACCESS_RIGHTS: u32 = 0x481A;
    /// Guest FS access rights.
    pub const FS_ACCESS_RIGHTS: u32 = 0x481C;
    /// Guest GS access rights.
    pub const GS_ACCESS_RIGHTS: u32 = 0x481E;
    /// Guest LDTR access rights.
    pub const LDTR_ACCESS_RIGHTS: u32 = 0x4820;
    /// Guest TR access rights.
    pub const TR_ACCESS_RIGHTS: u32 = 0x4822;
    /// Guest interruptibility state.
    pub const INTERRUPTIBILITY_STATE: u32 = 0x4824;
    /// Guest activity state.
    pub const ACTIVITY_STATE: u32 = 0x4826;
    /// Guest SMBASE.
    pub const SMBASE: u32 = 0x4828;
    /// Guest IA32_SYSENTER_CS.
    pub const IA32_SYSENTER_CS: u32 = 0x482A;
    /// VMX-preemption timer value.
    pub const VMX_PREEMPTION_TIMER_VALUE: u32 = 0x482E;

    // B.4.3.: natural-width guest-state fields
    /// Guest CR0.
    pub const CR0: u32 = 0x6800;
    /// Guest CR3.
    pub const CR3: u32 = 0x6802;
    /// Guest CR4.
    pub const CR4: u32 = 0x6804;
    /// Guest ES base.
    pub const ES_BASE: u32 = 0x6806;
    /// Guest CS base.
    pub const CS_BASE: u32 = 0x6808;
    /// Guest SS base.
    pub const SS_BASE: u32 = 0x680A;
    /// Guest DS base.
    pub const DS_BASE: u32 = 0x680C;
    /// Guest FS base.
    pub const FS_BASE: u32 = 0x680E;
    /// Guest GS base.
    pub const GS_BASE: u32 = 0x6810;
    /// Guest LDTR base.
    pub const LDTR_BASE: u32 = 0x6812;
    /// Guest TR base.
    pub const TR_BASE: u32 = 0x6814;
    /// Guest GDTR base.
    pub const GDTR_BASE: u32 = 0x6816;
    /// Guest IDTR base.
    pub const IDTR_BASE: u32 = 0x6818;
    /// Guest DR7.
    pub const DR7: u32 = 0x681A;
    /// Guest RSP.
    pub const RSP: u32 = 0x681C;
    /// Guest RIP.
    pub const RIP: u32 = 0x681E;
    /// Guest RFLAGS.
    pub const RFLAGS: u32 = 0x6820;
    /// Guest pending debug exceptions.
    pub const PENDING_DBG_EXCEPTIONS: u32 = 0x6822;
    /// Guest IA32_SYSENTER_ESP.
    pub const IA32_SYSENTER_ESP: u32 = 0x6824;
    /// Guest IA32_SYSENTER_EIP.
    pub const IA32_SYSENTER_EIP: u32 = 0x6826;
}

/// Fields used to access host-state area.
pub mod host {
    // B.1.3.: 16-bit host-state fields
    /// Host ES selector.
    pub const ES_SELECTOR: u32 = 0xC00;
    /// Host CS selector.
    pub const CS_SELECTOR: u32 = 0xC02;
    /// Host SS selector.
    pub const SS_SELECTOR: u32 = 0xC04;
    /// Host DS selector.
    pub const DS_SELECTOR: u32 = 0xC06;
    /// Host FS selector.
    pub const FS_SELECTOR: u32 = 0xC08;
    /// Host GS selector.
    pub const GS_SELECTOR: u32 = 0xC0A;
    /// Host TR selector.
    pub const TR_SELECTOR: u32 = 0xC0C;

    // B.2.4.: 64-bit host-state fields
    /// Host IA32_PAT (full).
    pub const IA32_PAT_FULL: u32 = 0x2C00;
    /// Host IA32_PAT (high).
    pub const IA32_PAT_HIGH: u32 = 0x2C01;
    /// Host IA32_EFER (full).
    pub const IA32_EFER_FULL: u32 = 0x2C02;
    /// Host IA32_EFER (high).
    pub const IA32_EFER_HIGH: u32 = 0x2C03;
    /// Host IA32_PERF_GLOBAL_CTRL (full).
    pub const IA32_PERF_GLOBAL_CTRL_FULL: u32 = 0x2C04;
    /// Host IA32_PERF_GLOBAL_CTRL (high).
    pub const IA32_PERF_GLOBAL_CTRL_HIGH: u32 = 0x2C05;

    // B.3.4.: 32-bit host-state field
    /// Host IA32_SYSENTER_CS.
    pub const IA32_SYSENTER_CS: u32 = 0x4C00;

    // B.4.4.: natural-width host-state fields
    /// Host CR0.
    pub const CR0: u32 = 0x6C00;
    /// Host CR3.
    pub const CR3: u32 = 0x6C02;
    /// Host CR4.
    pub const CR4: u32 = 0x6C04;
    /// Host FS base.
    pub const FS_BASE: u32 = 0x6C06;
    /// Host GS base.
    pub const GS_BASE: u32 = 0x6C08;
    /// Host TR base.
    pub const TR_BASE: u32 = 0x6C0A;
    /// Host GDTR base.
    pub const GDTR_BASE: u32 = 0x6C0C;
    /// Host IDTR base.
    pub const IDTR_BASE: u32 = 0x6C0E;
    /// Host IA32_SYSENTER_ESP.
    pub const IA32_SYSENTER_ESP: u32 = 0x6C10;
    /// Host IA32_SYSENTER_EIP.
    pub const IA32_SYSENTER_EIP: u32 = 0x6C12;
    /// Host RSP.
    pub const RSP: u32 = 0x6C14;
    /// Host RIP.
    pub const RIP: u32 = 0x6C16;
}

/// VM-exit information fields.
pub mod ro {
    // B.2.2.: 64-bit read-only data fields
    /// Guest-physical address (full).
    pub const GUEST_PHYSICAL_ADDR_FULL: u32 = 0x2400;
    /// Guest-physical address (high).
    pub const GUEST_PHYSICAL_ADDR_HIGH: u32 = 0x2401;

    // B.3.2.: 32-bit read-only data fields
    /// VM-instruction error.
    pub const VM_INSTRUCTION_ERROR: u32 = 0x4400;
    /// Exit reason.
    pub const EXIT_REASON: u32 = 0x4402;
    /// VM-exit interruption information.
    pub const VMEXIT_INTERRUPTION_INFO: u32 = 0x4404;
    /// VM-exit interruption error code.
    pub const VMEXIT_INTERRUPTION_ERR_CODE: u32 = 0x4406;
    /// IDT-vectoring information field.
    pub const IDT_VECTORING_INFO: u32 = 0x4408;
    /// IDT-vectoring error code.
    pub const IDT_VECTORING_ERR_CODE: u32 = 0x440A;
    /// VM-exit instruction length.
    pub const VMEXIT_INSTRUCTION_LEN: u32 = 0x440C;
    /// VM-exit instruction information.
    pub const VMEXIT_INSTRUCTION_INFO: u32 = 0x440E;

    // B.4.2.: natural-width read-only data fields
    /// Exit qualification.
    pub const EXIT_QUALIFICATION: u32 = 0x6400;
    /// I/O RCX.
    pub const IO_RCX: u32 = 0x6402;
    /// I/O RSI.
    pub const IO_RSI: u32 = 0x6404;
    /// I/O RDI.
    pub const IO_RDI: u32 = 0x6406;
    /// I/O RIP.
    pub const IO_RIP: u32 = 0x6408;
    /// Guest-linear address.
    pub const GUEST_LINEAR_ADDR: u32 = 0x640A;
}