vmcb->exitcode, vmcb->exit_int_info.raw);
printk("exitinfo1 = %#"PRIx64" exitinfo2 = %#"PRIx64"\n",
vmcb->exitinfo1, vmcb->exitinfo2);
- printk("np_enable = %#"PRIx64" guest_asid = %#x\n",
- vmcb_get_np_enable(vmcb), vmcb_get_guest_asid(vmcb));
+ printk("np_ctrl = %#"PRIx64" guest_asid = %#x\n",
+ vmcb_get_np_ctrl(vmcb), vmcb_get_guest_asid(vmcb));
printk("virtual vmload/vmsave = %d, virt_ext = %#"PRIx64"\n",
vmcb->virt_ext.fields.vloadsave_enable, vmcb->virt_ext.bytes);
printk("cpl = %d efer = %#"PRIx64" star = %#"PRIx64" lstar = %#"PRIx64"\n",
} ei;
};
intinfo_t exit_int_info; /* offset 0x88 */
- u64 _np_enable; /* offset 0x90 - cleanbit 4 */
+ union { /* offset 0x90 - cleanbit 4 */
+ struct {
+ bool _np_enable :1;
+ bool _sev_enable :1;
+ bool _sev_es_enable :1;
+ bool _gmet :1;
+ bool :1;
+ bool _vte :1;
+ };
+ uint64_t _np_ctrl;
+ };
u64 res08[2];
intinfo_t event_inj; /* offset 0xA8 */
u64 _h_cr3; /* offset 0xB0 - cleanbit 4 */
* VMCB accessor functions.
*/
-#define VMCB_ACCESSORS(name, cleanbit) \
+#define VMCB_ACCESSORS_(name, type, cleanbit) \
static inline void \
vmcb_set_ ## name(struct vmcb_struct *vmcb, \
- typeof(vmcb->_ ## name) value) \
+ type value) \
{ \
vmcb->_ ## name = value; \
vmcb->cleanbits.fields.cleanbit = 0; \
} \
-static inline typeof(alloc_vmcb()->_ ## name) \
+static inline type \
vmcb_get_ ## name(const struct vmcb_struct *vmcb) \
{ \
return vmcb->_ ## name; \
}
+#define VMCB_ACCESSORS(name, cleanbit) \
+ VMCB_ACCESSORS_(name, typeof(alloc_vmcb()->_ ## name), cleanbit)
+
VMCB_ACCESSORS(cr_intercepts, intercepts)
VMCB_ACCESSORS(dr_intercepts, intercepts)
VMCB_ACCESSORS(exception_intercepts, intercepts)
VMCB_ACCESSORS(msrpm_base_pa, iopm)
VMCB_ACCESSORS(guest_asid, asid)
VMCB_ACCESSORS(vintr, tpr)
-VMCB_ACCESSORS(np_enable, np)
+VMCB_ACCESSORS(np_ctrl, np)
+VMCB_ACCESSORS_(np_enable, bool, np)
+VMCB_ACCESSORS_(sev_enable, bool, np)
+VMCB_ACCESSORS_(sev_es_enable, bool, np)
+VMCB_ACCESSORS_(gmet, bool, np)
+VMCB_ACCESSORS_(vte, bool, np)
VMCB_ACCESSORS(h_cr3, np)
VMCB_ACCESSORS(g_pat, np)
VMCB_ACCESSORS(cr0, cr)