L4Re Operating System Framework
Interface and Usage Documentation
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
__vm-svm.h
1
6/*
7 * (c) 2008-2009 Adam Lackorzynski <adam@os.inf.tu-dresden.de>,
8 * Alexander Warg <warg@os.inf.tu-dresden.de>
9 * economic rights: Technische Universität Dresden (Germany)
10 *
11 * License: see LICENSE.spdx (in this directory or the directories above)
12 */
13#pragma once
14
15#include <l4/sys/types.h>
16
29{
30 l4_uint16_t intercept_rd_crX;
31 l4_uint16_t intercept_wr_crX;
32
33 l4_uint16_t intercept_rd_drX;
34 l4_uint16_t intercept_wr_drX;
35
36 l4_uint32_t intercept_exceptions;
37
38 l4_uint32_t intercept_instruction0;
39 l4_uint32_t intercept_instruction1;
40
41 l4_uint8_t _reserved0[40];
42
43 l4_uint16_t pause_filter_threshold;
44 l4_uint16_t pause_filter_count;
45
46 l4_uint64_t iopm_base_pa;
47 l4_uint64_t msrpm_base_pa;
48 l4_uint64_t tsc_offset;
49 l4_uint64_t guest_asid_tlb_ctl;
50 l4_uint64_t interrupt_ctl;
51 l4_uint64_t interrupt_shadow;
52 l4_uint64_t exitcode;
53 l4_uint64_t exitinfo1;
54 l4_uint64_t exitinfo2;
55 l4_uint64_t exitintinfo;
56 l4_uint64_t np_enable;
57
58 l4_uint8_t _reserved1[16];
59
60 l4_uint64_t eventinj;
61 l4_uint64_t n_cr3;
62 l4_uint64_t lbr_virtualization_enable;
63 l4_uint64_t clean_bits;
64 l4_uint64_t n_rip;
65
66 l4_uint8_t _reserved2[816];
67} __attribute__((packed)) l4_vm_svm_vmcb_control_area_t;
68
74{
75 l4_uint16_t selector;
76 l4_uint16_t attrib;
77 l4_uint32_t limit;
78 l4_uint64_t base;
79} __attribute__((packed)) l4_vm_svm_vmcb_state_save_area_seg_t;
80
86{
97
98 l4_uint8_t _reserved0[43];
99
100 l4_uint8_t cpl;
101
102 l4_uint32_t _reserved1;
103
104 l4_uint64_t efer;
105
106 l4_uint8_t _reserved2[112];
107
108 l4_uint64_t cr4;
109 l4_uint64_t cr3;
110 l4_uint64_t cr0;
111 l4_uint64_t dr7;
112 l4_uint64_t dr6;
113 l4_uint64_t rflags;
114 l4_uint64_t rip;
115
116 l4_uint8_t _reserved3[88];
117
118 l4_uint64_t rsp;
119
120 l4_uint8_t _reserved4[24];
121
122 l4_uint64_t rax;
123 l4_uint64_t star;
124 l4_uint64_t lstar;
125 l4_uint64_t cstar;
126 l4_uint64_t sfmask;
127 l4_uint64_t kernelgsbase;
128 l4_uint64_t sysenter_cs;
129 l4_uint64_t sysenter_esp;
130 l4_uint64_t sysenter_eip;
131 l4_uint64_t cr2;
132
133 l4_uint8_t _reserved5[32];
134
135 l4_uint64_t g_pat;
136 l4_uint64_t dbgctl;
137 l4_uint64_t br_from;
138 l4_uint64_t br_to;
139 l4_uint64_t lastexcpfrom;
140 l4_uint64_t last_excpto;
141
142 // this field is _NOT_ part of the official VMCB specification
143 // a (userlevel) VMM needs this for proper FPU state virtualization
144 l4_uint64_t xcr0;
145
146 l4_uint8_t _reserved6[2400];
147} __attribute__((packed)) l4_vm_svm_vmcb_state_save_area_t;
148
149
unsigned char l4_uint8_t
Unsigned 8bit value.
Definition l4int.h:25
unsigned int l4_uint32_t
Unsigned 32bit value.
Definition l4int.h:29
unsigned short int l4_uint16_t
Unsigned 16bit value.
Definition l4int.h:27
unsigned long long l4_uint64_t
Unsigned 64bit value.
Definition l4int.h:31
struct l4_vm_svm_vmcb_state_save_area_seg l4_vm_svm_vmcb_state_save_area_seg_t
State save area segment selector struct.
struct l4_vm_svm_vmcb_state_save_area l4_vm_svm_vmcb_state_save_area_t
State save area structure for SVM VMs.
struct l4_vm_svm_vmcb_control_area l4_vm_svm_vmcb_control_area_t
VMCB structure for SVM VMs.
Common L4 ABI Data Types.
VMCB structure for SVM VMs.
Definition __vm-svm.h:29
State save area segment selector struct.
Definition __vm-svm.h:74
State save area structure for SVM VMs.
Definition __vm-svm.h:86
Control structure for SVM VMs.
Definition __vm-svm.h:155