Type-2 Intel hypervisor for Windows 10 systems
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
_xeroxz 8d2c85b886
Update README.md
4 years ago
README.md Update README.md 4 years ago
bluepill.sln init commit 4 years ago
bluepill.vcxproj getting rekted by vmxerror 7 (invalid control fields) 4 years ago
bluepill.vcxproj.filters getting rekted by vmxerror 7 (invalid control fields) 4 years ago
bluepill.vcxproj.user init commit 4 years ago
entry.cpp getting rekted by vmxerror 7 (invalid control fields) 4 years ago
exit_handler.cpp getting rekted by vmxerror 7 (invalid control fields) 4 years ago
hv_types.hpp getting rekted by vmxerror 7 (invalid control fields) 4 years ago
ia32.hpp getting rekted by vmxerror 7 (invalid control fields) 4 years ago
segment.cpp getting rekted by vmxerror 7 (invalid control fields) 4 years ago
segment_intrin.asm getting rekted by vmxerror 7 (invalid control fields) 4 years ago
segment_intrin.h getting rekted by vmxerror 7 (invalid control fields) 4 years ago
vmcs.cpp getting rekted by vmxerror 7 (invalid control fields) 4 years ago
vmcs.hpp getting rekted by vmxerror 7 (invalid control fields) 4 years ago
vmxexit_handler.asm getting rekted by vmxerror 7 (invalid control fields) 4 years ago
vmxexit_handler.h init commit 4 years ago
vmxlaunch.cpp getting rekted by vmxerror 7 (invalid control fields) 4 years ago
vmxlaunch.hpp getting rekted by vmxerror 7 (invalid control fields) 4 years ago
vmxon.cpp getting rekted by vmxerror 7 (invalid control fields) 4 years ago
vmxon.hpp init commit 4 years ago

README.md

when in doubt, print it out

debug print of vmcs control fields after reserved bits are set high and low.

pinbased vm-exit controls

============================== pinbased vm-exit controls ==============================
		- pinbased_ctls.activate_vmx_preemption_timer: 0
		- pinbased_ctls.external_interrupt_exiting: 0
		- pinbased_ctls.nmi_exiting: 0
		- pinbased_ctls.process_posted_interrupts: 0
		- pinbased_ctls.virtual_nmi: 0
			- pinbased_ctls.flags: 0x16
			- IA32_VMX_TRUE_PINBASED_CTLS high bits mask: 0x3f
			- IA32_VMX_TRUE_PINBASED_CTLS low bits mask: 0x16

processor based vm-exit controls

============================== processor based vm-exit controls ==============================
		- procbased_ctls.activate_secondary_controls: 1
		- procbased_ctls.cr3_load_exiting: 0
		- procbased_ctls.cr3_store_exiting: 0
		- procbased_ctls.cr8_load_exiting: 0
		- procbased_ctls.cr8_store_exiting: 0
		- procbased_ctls.hlt_exiting: 0
		- procbased_ctls.interrupt_window_exiting: 0
		- procbased_ctls.invlpg_exiting: 0
		- procbased_ctls.monitor_exiting: 0
		- procbased_ctls.monitor_trap_flag: 0
		- procbased_ctls.mov_dr_exiting: 0
		- procbased_ctls.mwait_exiting: 0
		- procbased_ctls.nmi_window_exiting: 0
		- procbased_ctls.pause_exiting: 0
		- procbased_ctls.rdpmc_exiting: 0
		- procbased_ctls.rdtsc_exiting: 0
		- procbased_ctls.unconditional_io_exiting: 0
		- procbased_ctls.use_io_bitmaps: 0
		- procbased_ctls.use_msr_bitmaps: 0
		- procbased_ctls.use_tpr_shadow: 0
		- procbased_ctls.use_tsc_offsetting: 0
			- procbased_ctls.flags: 0x84006172
			- IA32_VMX_TRUE_PROCBASED_CTLS high bits mask: 0xfff9fffe
			- IA32_VMX_TRUE_PROCBASED_CTLS low bits mask: 0x4006172

vm-entry controls

============================== vm-entry controls ==============================
		- entry_ctls.conceal_vmx_from_pt: 0
		- entry_ctls.deactivate_dual_monitor_treatment: 0
		- entry_ctls.entry_to_smm: 0
		- entry_ctls.ia32e_mode_guest: 1
		- entry_ctls.load_cet_state: 0
		- entry_ctls.load_debug_controls: 0
		- entry_ctls.load_ia32_bndcfgs: 0
		- entry_ctls.load_ia32_efer: 0
		- entry_ctls.load_ia32_pat: 0
		- entry_ctls.load_ia32_perf_global_ctrl: 0
		- entry_ctls.load_ia32_rtit_ctl: 0
			- entry_ctls.flags: 0x13fb
			- IA32_VMX_TRUE_ENTRY_CTLS high bits mask: 0xf3ff
			- IA32_VMX_TRUE_ENTRY_CTLS low bits mask: 0x11fb

vm-exit controls

============================== vm-exit controls ==============================
		- exit_ctls.acknowledge_interrupt_on_exit: 0
		- exit_ctls.clear_ia32_bndcfgs: 0
		- exit_ctls.conceal_vmx_from_pt: 0
		- exit_ctls.host_address_space_size: 1
		- exit_ctls.load_ia32_efer: 0
		- exit_ctls.load_ia32_pat: 0
		- exit_ctls.load_ia32_perf_global_ctrl: 0
		- exit_ctls.save_debug_controls: 0
		- exit_ctls.save_ia32_efer: 0
		- exit_ctls.save_ia32_pat: 0
		- exit_ctls.save_vmx_preemption_timer_value: 0
			- exit_ctls.flags: 0x36ffb
			- IA32_VMX_TRUE_EXIT_CTLS high bits mask: 0x3fffff
			- IA32_VMX_TRUE_EXIT_CTLS low bits mask: 0x36dfb
			

secondary processor based vm-exec controls

============================== secondary processor based vm-exec controls ==============================
		- procbased_ctls2.apic_register_virtualization: 0
		- procbased_ctls2.conceal_vmx_from_pt: 0
		- procbased_ctls2.descriptor_table_exiting: 0
		- procbased_ctls2.enable_encls_exiting: 0
		- procbased_ctls2.enable_ept: 0
		- procbased_ctls2.enable_invpcid: 0
		- procbased_ctls2.enable_pml: 0
		- procbased_ctls2.enable_rdtscp: 1
		- procbased_ctls2.enable_vm_functions: 0
		- procbased_ctls2.enable_vpid: 0
		- procbased_ctls2.enable_xsaves: 0
		- procbased_ctls2.ept_violation: 0
		- procbased_ctls2.mode_based_execute_control_for_ept: 0
		- procbased_ctls2.pause_loop_exiting: 0
		- procbased_ctls2.rdrand_exiting: 0
		- procbased_ctls2.rdseed_exiting: 0
		- procbased_ctls2.unrestricted_guest: 0
		- procbased_ctls2.use_tsc_scaling: 0
		- procbased_ctls2.virtualize_apic_accesses: 0
		- procbased_ctls2.virtualize_x2apic_mode: 0
		- procbased_ctls2.virtual_interrupt_delivery: 0
		- procbased_ctls2.vmcs_shadowing: 0
		- procbased_ctls2.wbinvd_exiting: 0
			- procbased_ctls2.flags: 0x8
			- IA32_VMX_PROCBASED_CTLS2 high bits mask: 0x404fe
			- IA32_VMX_PROCBASED_CTLS2 low bits mask: 0x0