register state for pause-loop exiting
This commit is contained in:
parent
9c3a4b8dab
commit
1e2c7de064
@ -13,6 +13,7 @@ Bochs repository moved to the SVN version control !
|
|||||||
- Added emulation of AVX float16 convert instructions, the feature can be
|
- Added emulation of AVX float16 convert instructions, the feature can be
|
||||||
enabled using .bochsrc CPUID option.
|
enabled using .bochsrc CPUID option.
|
||||||
- Implemented VMX preemption timer VMEXIT control (patch by Jianan Hao)
|
- Implemented VMX preemption timer VMEXIT control (patch by Jianan Hao)
|
||||||
|
- Implemented Pause-Loop Exiting Secondary VMEXIT control
|
||||||
- Redefined/Updated/Fixed instrumentation callbacks.
|
- Redefined/Updated/Fixed instrumentation callbacks.
|
||||||
- Bugfixes for CPU emulation correctness and stability.
|
- Bugfixes for CPU emulation correctness and stability.
|
||||||
|
|
||||||
|
@ -470,6 +470,11 @@ VMX_error_code BX_CPU_C::VMenterLoadCheckVmControls(void)
|
|||||||
return VMXERR_VMENTRY_INVALID_VM_CONTROL_FIELD;
|
return VMXERR_VMENTRY_INVALID_VM_CONTROL_FIELD;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (vm->vmexec_ctrls3 & VMX_VM_EXEC_CTRL3_PAUSE_LOOP_VMEXIT) {
|
||||||
|
vm->pause_loop_exiting_gap = VMread32(VMCS_32BIT_CONTROL_PAUSE_LOOP_EXITING_GAP);
|
||||||
|
vm->pause_loop_exiting_window = VMread32(VMCS_32BIT_CONTROL_PAUSE_LOOP_EXITING_WINDOW);
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//
|
//
|
||||||
@ -528,13 +533,6 @@ VMX_error_code BX_CPU_C::VMenterLoadCheckVmControls(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if BX_SUPPORT_VMX >= 2
|
|
||||||
if (vm->vmexec_ctrls3 & VMX_VM_EXEC_CTRL3_PAUSE_LOOP_VMEXIT) {
|
|
||||||
vm->pause_loop_exiting_gap = VMread32(VMCS_32BIT_CONTROL_PAUSE_LOOP_EXITING_GAP);
|
|
||||||
vm->pause_loop_exiting_window = VMread32(VMCS_32BIT_CONTROL_PAUSE_LOOP_EXITING_WINDOW);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Load VM-entry control fields to VMCS Cache
|
// Load VM-entry control fields to VMCS Cache
|
||||||
//
|
//
|
||||||
@ -3035,7 +3033,7 @@ void BX_CPU_C::register_vmx_state(bx_param_c *parent)
|
|||||||
// VM-Execution Control Fields
|
// VM-Execution Control Fields
|
||||||
//
|
//
|
||||||
|
|
||||||
bx_list_c *vmexec_ctrls = new bx_list_c(vmcache, "VMEXEC_CTRLS", 25);
|
bx_list_c *vmexec_ctrls = new bx_list_c(vmcache, "VMEXEC_CTRLS", 29);
|
||||||
|
|
||||||
BXRS_HEX_PARAM_FIELD(vmexec_ctrls, vmexec_ctrls1, BX_CPU_THIS_PTR vmcs.vmexec_ctrls1);
|
BXRS_HEX_PARAM_FIELD(vmexec_ctrls, vmexec_ctrls1, BX_CPU_THIS_PTR vmcs.vmexec_ctrls1);
|
||||||
BXRS_HEX_PARAM_FIELD(vmexec_ctrls, vmexec_ctrls2, BX_CPU_THIS_PTR vmcs.vmexec_ctrls2);
|
BXRS_HEX_PARAM_FIELD(vmexec_ctrls, vmexec_ctrls2, BX_CPU_THIS_PTR vmcs.vmexec_ctrls2);
|
||||||
@ -3064,6 +3062,12 @@ void BX_CPU_C::register_vmx_state(bx_param_c *parent)
|
|||||||
BXRS_HEX_PARAM_FIELD(vmexec_ctrls, vpid, BX_CPU_THIS_PTR vmcs.vpid);
|
BXRS_HEX_PARAM_FIELD(vmexec_ctrls, vpid, BX_CPU_THIS_PTR vmcs.vpid);
|
||||||
#endif
|
#endif
|
||||||
BXRS_HEX_PARAM_FIELD(vmexec_ctrls, executive_vmcsptr, BX_CPU_THIS_PTR vmcs.executive_vmcsptr);
|
BXRS_HEX_PARAM_FIELD(vmexec_ctrls, executive_vmcsptr, BX_CPU_THIS_PTR vmcs.executive_vmcsptr);
|
||||||
|
#if BX_SUPPORT_VMX >= 2
|
||||||
|
BXRS_HEX_PARAM_FIELD(vmexec_ctrls, pause_loop_exiting_gap, BX_CPU_THIS_PTR vmcs.pause_loop_exiting_gap);
|
||||||
|
BXRS_HEX_PARAM_FIELD(vmexec_ctrls, pause_loop_exiting_window, BX_CPU_THIS_PTR vmcs.pause_loop_exiting_window);
|
||||||
|
BXRS_HEX_PARAM_FIELD(vmexec_ctrls, first_pause_time, BX_CPU_THIS_PTR vmcs.first_pause_time);
|
||||||
|
BXRS_HEX_PARAM_FIELD(vmexec_ctrls, last_pause_time, BX_CPU_THIS_PTR vmcs.last_pause_time);
|
||||||
|
#endif
|
||||||
|
|
||||||
//
|
//
|
||||||
// VM-Exit Control Fields
|
// VM-Exit Control Fields
|
||||||
@ -3076,7 +3080,7 @@ void BX_CPU_C::register_vmx_state(bx_param_c *parent)
|
|||||||
BXRS_HEX_PARAM_FIELD(vmexit_ctrls, vmexit_msr_store_addr, BX_CPU_THIS_PTR vmcs.vmexit_msr_store_addr);
|
BXRS_HEX_PARAM_FIELD(vmexit_ctrls, vmexit_msr_store_addr, BX_CPU_THIS_PTR vmcs.vmexit_msr_store_addr);
|
||||||
BXRS_DEC_PARAM_FIELD(vmexit_ctrls, vmexit_msr_load_cnt, BX_CPU_THIS_PTR vmcs.vmexit_msr_load_cnt);
|
BXRS_DEC_PARAM_FIELD(vmexit_ctrls, vmexit_msr_load_cnt, BX_CPU_THIS_PTR vmcs.vmexit_msr_load_cnt);
|
||||||
BXRS_HEX_PARAM_FIELD(vmexit_ctrls, vmexit_msr_load_addr, BX_CPU_THIS_PTR vmcs.vmexit_msr_load_addr);
|
BXRS_HEX_PARAM_FIELD(vmexit_ctrls, vmexit_msr_load_addr, BX_CPU_THIS_PTR vmcs.vmexit_msr_load_addr);
|
||||||
|
|
||||||
//
|
//
|
||||||
// VM-Entry Control Fields
|
// VM-Entry Control Fields
|
||||||
//
|
//
|
||||||
|
@ -640,6 +640,13 @@ typedef struct bx_VMCS
|
|||||||
|
|
||||||
Bit64u executive_vmcsptr;
|
Bit64u executive_vmcsptr;
|
||||||
|
|
||||||
|
#if BX_SUPPORT_VMX >= 2
|
||||||
|
Bit32u pause_loop_exiting_gap;
|
||||||
|
Bit32u pause_loop_exiting_window;
|
||||||
|
Bit64u last_pause_time; // used for pause loop exiting
|
||||||
|
Bit32u first_pause_time;
|
||||||
|
#endif
|
||||||
|
|
||||||
//
|
//
|
||||||
// VM-Exit Control Fields
|
// VM-Exit Control Fields
|
||||||
//
|
//
|
||||||
@ -679,13 +686,6 @@ typedef struct bx_VMCS
|
|||||||
Bit32u vmexit_msr_load_cnt;
|
Bit32u vmexit_msr_load_cnt;
|
||||||
bx_phy_address vmexit_msr_load_addr;
|
bx_phy_address vmexit_msr_load_addr;
|
||||||
|
|
||||||
#if BX_SUPPORT_VMX >= 2
|
|
||||||
Bit32u pause_loop_exiting_gap;
|
|
||||||
Bit32u pause_loop_exiting_window;
|
|
||||||
Bit64u last_pause_time; // used for pause loop exiting
|
|
||||||
Bit32u first_pause_time;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// VM-Entry Control Fields
|
// VM-Entry Control Fields
|
||||||
//
|
//
|
||||||
|
Loading…
Reference in New Issue
Block a user