Bochs/bochs/cpu
Stanislav Shwartsman 47b05e55e1 revert lock handling change
after checking agains Intel reference decoder (Xed) it shown few mismatches.
The mismatches are not functionally important - some very long instructions with lock prefix would cause #UD (due to badly placed lock prefix) insetad of #GP due to excessive opcode length
Seems like Xed evaluates entire instruction to the end and only then converts it to #UD due to lock prefix
2024-10-30 06:18:46 +02:00
..
avx rename all EVEX opcodes from BX_IA_V512_* to BX_IA_EVEX_* 2024-10-28 20:28:53 +02:00
cpudb simplify AMD CPUDB definitions reusing generic function for leaf 0x80000001.ECX 2024-10-24 21:39:57 +03:00
decoder revert lock handling change 2024-10-30 06:18:46 +02:00
fpu extract EVEX opcodes definitions to separate file ia_opcodes_evex.def 2024-10-23 21:34:03 +03:00
softfloat3e rename: 2024-08-22 08:55:56 +03:00
3dnow.cc remove fpu/softfloat.h, reduce include deprendencies, fix warnings 2024-04-25 11:50:48 +03:00
access2.cc rewritten LASS implementation to fix failures under ArrowLake model 2024-10-23 14:30:44 +03:00
access.cc rewritten LASS implementation to fix failures under ArrowLake model 2024-10-23 14:30:44 +03:00
access.h keep def of YMM/ZMM register even if AVX or EVEX are not compiled in and let reading/writing them to MEM 2018-04-04 19:31:56 +00:00
aes.cc remove trailing whitespace from source files 2022-08-23 21:46:04 +03:00
apic.cc Fixed spelling of word "destination" in log message (#324) 2024-05-31 14:54:13 +02:00
apic.h fixed compilation for VMX=1 X86_64=1 2023-11-28 10:36:56 +02:00
arith8.cc addressing issue Possible Undefined Behavior in NEG_EdR() and NEG_EdM() #227 2024-01-20 08:19:43 +02:00
arith16.cc addressing issue Possible Undefined Behavior in NEG_EdR() and NEG_EdM() #227 2024-01-20 08:19:43 +02:00
arith32.cc addressing issue Possible Undefined Behavior in NEG_EdR() and NEG_EdM() #227 2024-01-20 08:19:43 +02:00
arith64.cc addressing issue Possible Undefined Behavior in NEG_EdR() and NEG_EdM() #227 2024-01-20 08:19:43 +02:00
bcd.cc remove trailing whitespace from source files 2022-08-23 21:46:04 +03:00
bit16.cc remove trailing whitespace from source files 2022-08-23 21:46:04 +03:00
bit32.cc remove trailing whitespace from source files 2022-08-23 21:46:04 +03:00
bit64.cc remove trailing whitespace from source files 2022-08-23 21:46:04 +03:00
bit.cc cleanup return value of all instruction handlers 2018-02-16 07:57:32 +00:00
bmi32.cc Fixed OF flag for ADOX instruction 2024-01-19 20:30:47 +02:00
bmi64.cc Fixed OF flag for ADOX instruction 2024-01-19 20:30:47 +02:00
call_far.cc Implemented VMX 'Shadow Stack Prematurely Busy' and secondary VMEXIT controls 2024-01-27 13:34:51 +02:00
cet.cc fixed permission check for CET 2024-01-28 17:25:21 +02:00
cmpccxadd32.cc added a comment for future: some memory operations must be done atomically 2023-11-17 23:18:43 +02:00
cmpccxadd64.cc added a comment for future: some memory operations must be done atomically 2023-11-17 23:18:43 +02:00
cpu_templates_pfp.h simplify code for AVX-512 masked merges 2024-10-26 23:49:04 +03:00
cpu_templates.h rename/simplify names of BF16 instruction handlers 2024-10-26 22:26:13 +03:00
cpu.cc rewritten LASS implementation to fix failures under ArrowLake model 2024-10-23 14:30:44 +03:00
cpu.h rename/simplify names of BF16 instruction handlers 2024-10-26 22:26:13 +03:00
cpuid.cc simplify AMD CPUDB definitions reusing generic function for leaf 0x80000001.ECX 2024-10-24 21:39:57 +03:00
cpuid.h simplify AMD CPUDB definitions reusing generic function for leaf 0x80000001.ECX 2024-10-24 21:39:57 +03:00
cpustats.h remove trailing whitespace from source files 2022-08-23 21:46:04 +03:00
crc32.cc change a bit more defines to const with type 2019-12-26 16:48:33 +00:00
crregs.cc create classes for Vmexec controls for robustness 2024-01-27 18:04:00 +02:00
crregs.h updates for CPUID definitions 2024-10-12 18:07:28 +03:00
ctrl_xfer16.cc create class for Pin-Based VMEXEC controls for robustness 2024-01-27 15:14:29 +02:00
ctrl_xfer32.cc create class for Pin-Based VMEXEC controls for robustness 2024-01-27 15:14:29 +02:00
ctrl_xfer64.cc create class for Pin-Based VMEXEC controls for robustness 2024-01-27 15:14:29 +02:00
ctrl_xfer_pro.cc implemented WAITPKG instruction set (#150) 2023-12-01 18:00:03 +02:00
data_xfer8.cc added a comment for future: some memory operations must be done atomically 2023-11-17 23:18:43 +02:00
data_xfer16.cc added a comment for future: some memory operations must be done atomically 2023-11-17 23:18:43 +02:00
data_xfer32.cc added a comment for future: some memory operations must be done atomically 2023-11-17 23:18:43 +02:00
data_xfer64.cc added a comment for future: some memory operations must be done atomically 2023-11-17 23:18:43 +02:00
debugstuff.cc added helper function to stringify EFLAGS as well and reuse it in Bochs debugger 2024-10-23 12:43:50 +03:00
descriptor.h convert many consts from #define to enum or const variables (#23) 2022-07-27 23:20:47 +03:00
event.cc Implemented SVM VM_CR_MSR and INIT redirection feature (#220) 2024-01-16 07:42:28 +02:00
exception.cc Implemented SVM VM_CR_MSR and INIT redirection feature (#220) 2024-01-16 07:42:28 +02:00
faststring.cc Removed SVN property "executable" from some files. 2021-02-21 09:25:33 +00:00
flag_ctrl_pro.cc create class for Pin-Based VMEXEC controls for robustness 2024-01-27 15:14:29 +02:00
flag_ctrl.cc dynamically allocate VMCB_CACHE only if SVM is actually enabled by CPU model 2024-01-12 00:56:09 +02:00
fpu_emu.cc optimize handling of allowed_to_run_FPU_MMX instructios common block 2023-11-08 06:48:53 +02:00
generic_cpuid.cc simplify AMD CPUDB definitions reusing generic function for leaf 0x80000001.ECX 2024-10-24 21:39:57 +03:00
generic_cpuid.h simplify AMD CPUDB definitions reusing generic function for leaf 0x80000001.ECX 2024-10-24 21:39:57 +03:00
gf2.cc fix GFNI instructions emulation 2023-11-18 20:15:29 +02:00
i387.h FXRSTOR/XRSTOR: do not change x87 state if restore of entire state cannot be completed 2024-04-25 19:57:38 +03:00
icache.cc make assignHandler member function for cleaner code 2024-10-22 21:09:16 +03:00
icache.h resolve github issue #57 + more clear variable name 2023-11-07 16:10:41 +02:00
init.cc Support for disabling of one of more CPU feature from CPUID configuration (see "exclude_features" in bochsrc sample and documentation) 2024-10-24 20:48:53 +03:00
io.cc dynamically allocate VMCB_CACHE only if SVM is actually enabled by CPU model 2024-01-12 00:56:09 +02:00
iret.cc correct clear_busy for shadow stack in case of IRET - should use old SSP 2024-01-29 15:08:54 +02:00
jmp_far.cc coding style, cleanups and optimizations 2023-11-19 20:31:05 +02:00
lazy_flags.h remove trailing whitespace from source files 2022-08-23 21:46:04 +03:00
load.cc add softfloat3e library to Bochs to replace old softfloat2 (to get fp… (#259) 2024-03-10 17:10:55 +02:00
logical8.cc cleanup return value of all instruction handlers 2018-02-16 07:57:32 +00:00
logical16.cc more faststring cleanup 2019-10-14 14:54:07 +00:00
logical32.cc more faststring cleanup 2019-10-14 14:54:07 +00:00
logical64.cc cleanup return value of all instruction handlers 2018-02-16 07:57:32 +00:00
Makefile.in extract EVEX opcodes definitions to separate file ia_opcodes_evex.def 2024-10-23 21:34:03 +03:00
mmx.cc added a comment for future: some memory operations must be done atomically 2023-11-17 23:18:43 +02:00
msr.cc enable more bits in MSR IA32_SPEC_CTRL to support Win11 boot in Sapphire Rapids and Arrow Lake CPU models 2024-10-23 11:14:23 +03:00
msr.h add fields and bits for newly announced x86 features and vmx state 2024-04-26 22:13:08 +03:00
mult8.cc cleanup return value of all instruction handlers 2018-02-16 07:57:32 +00:00
mult16.cc cleanup return value of all instruction handlers 2018-02-16 07:57:32 +00:00
mult32.cc introduce GET64_FROM_HI32_LO32 to form 64-bit integer from 2 32-bit 2023-11-17 23:31:38 +02:00
mult64.cc extract Bit128 arithmetic to separate wide_int.cc/wide_int.h compiled independently of long mode emulation 2020-05-19 16:01:23 +00:00
mwait.cc fixed TPAUSE implementation and close issue #366 2024-10-23 15:02:54 +03:00
paging.cc rewritten LASS implementation to fix failures under ArrowLake model 2024-10-23 14:30:44 +03:00
proc_ctrl.cc fixed bug in MOVDIR64B - source and destination were swapped 2024-01-28 21:38:57 +02:00
protect_ctrl.cc create classes for Vmexec controls for robustness 2024-01-27 18:04:00 +02:00
rdrand.cc create classes for Vmexec controls for robustness 2024-01-27 18:04:00 +02:00
ret_far.cc implemented WAITPKG instruction set (#150) 2023-12-01 18:00:03 +02:00
scalar_arith.h added most_significant_bit* methods to scalar_arith.h 2023-11-23 19:03:08 +02:00
segment_ctrl_pro.cc use true/false instead of 0/1 for bool in the cpu code 2023-12-19 20:44:56 +02:00
segment_ctrl.cc VMX: save guest CET state to VMCS on vmexit 2019-12-27 13:02:30 +00:00
sha512.cc SHA512 instructions implemented (#88) 2023-10-10 21:33:16 +03:00
sha.cc fixed implementation of SHA1RNDS4 instruction 2024-08-31 17:29:10 +03:00
shift8.cc implemented SM3 instructions (#84) 2023-10-07 21:34:04 +03:00
shift16.cc implemented SM3 instructions (#84) 2023-10-07 21:34:04 +03:00
shift32.cc implemented SM3 instructions (#84) 2023-10-07 21:34:04 +03:00
shift64.cc implemented SM3 instructions (#84) 2023-10-07 21:34:04 +03:00
simd_compare.h Implement AVX512BW and AVX512DQ extensions published in recently published Intel Archtecture Extensions manual rev20. 2014-07-18 11:14:25 +00:00
simd_int.h make CPU to use C++ template for implementation of CPU methods (#115) 2023-10-30 06:57:16 +02:00
simd_pfp.h remove fpu/softfloat16.h 2024-04-25 12:36:27 +03:00
simd_vnni.h make CPU to use C++ template for implementation of CPU methods (#115) 2023-10-30 06:57:16 +02:00
sm3.cc implemented SM3 instructions (#84) 2023-10-07 21:34:04 +03:00
sm4.cc implemented SM3 instructions (#84) 2023-10-07 21:34:04 +03:00
smm.cc fixed permission check for CET 2024-01-28 17:25:21 +02:00
smm.h fixed permission check for CET 2024-01-28 17:25:21 +02:00
soft_int.cc dynamically allocate VMCB_CACHE only if SVM is actually enabled by CPU model 2024-01-12 00:56:09 +02:00
sse_move.cc fixed err message format string 2024-09-01 22:33:11 +03:00
sse_pfp.cc remove fpu/softfloat.h, reduce include deprendencies, fix warnings 2024-04-25 11:50:48 +03:00
sse_rcp.cc remove fpu/softfloat.h, reduce include deprendencies, fix warnings 2024-04-25 11:50:48 +03:00
sse_string.cc use boolean constants true/false instead of 0/1 (#26) 2022-07-30 18:38:22 +03:00
sse.cc AMX support (#212) 2024-01-10 20:13:25 +02:00
stack16.cc added a comment for future: some memory operations must be done atomically 2023-11-17 23:18:43 +02:00
stack32.cc added a comment for future: some memory operations must be done atomically 2023-11-17 23:18:43 +02:00
stack64.cc added a comment for future: some memory operations must be done atomically 2023-11-17 23:18:43 +02:00
stack.cc remove trailing whitespace from source files 2022-08-23 21:46:04 +03:00
stack.h Add initial implementation of the CET (Control Flow Enforcement Technology) emulation according to SDM071 2019-12-20 07:42:07 +00:00
string.cc remove pc_system.h from bochs.h and include it only where required 2021-01-30 18:29:28 +00:00
svm.cc Implemented SVM VM_CR_MSR and INIT redirection feature (#220) 2024-01-16 07:42:28 +02:00
svm.h Implemented SVM VM_CR_MSR and INIT redirection feature (#220) 2024-01-16 07:42:28 +02:00
tasking.cc dynamically allocate VMCB_CACHE only if SVM is actually enabled by CPU model 2024-01-12 00:56:09 +02:00
tlb.h fixed some MSVC wannings in CPU code 2021-02-08 13:06:44 +00:00
todo fixed compilation with CET not compiled in 2023-11-20 15:24:57 +02:00
uintr.cc implement Flexible UIRET (AKA UIRET_UIF) announced in 319433-052 2024-04-26 21:53:03 +03:00
vapic.cc create classes for Vmexec controls for robustness 2024-01-27 18:04:00 +02:00
vm8086.cc use true/false instead of 0/1 for bool in the cpu code 2023-12-19 20:44:56 +02:00
vmcs.cc add AVX10.256 emulation VMX control 2024-10-22 22:15:41 +03:00
vmexit.cc create classes for Vmexec controls for robustness 2024-01-27 18:04:00 +02:00
vmfunc.cc create classes for Vmexec controls for robustness 2024-01-27 18:04:00 +02:00
vmx_ctrls.h add AVX10.256 emulation VMX control 2024-10-22 22:15:41 +03:00
vmx.cc implement VMX SUPPORT FOR THE IA32_SPEC_CTRL MSR announced in 319433-052 2024-04-27 09:44:48 +03:00
vmx.h implement VMX SUPPORT FOR THE IA32_SPEC_CTRL MSR announced in 319433-052 2024-04-27 09:44:48 +03:00
wide_int.cc replace long_mul function in wide_int.cc with much faster code from softfloat3e 2024-10-19 18:26:07 +03:00
wide_int.h remove trailing whitespace from source files 2022-08-23 21:46:04 +03:00
xmm.h remove fpu/softfloat.h, reduce include deprendencies, fix warnings 2024-04-25 11:50:48 +03:00
xsave.cc add AVX10.256 emulation VMX control 2024-10-22 22:15:41 +03:00