MerryMage
|
b34c6616d4
|
A64/decoder: Split decoder data from header
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
72a793f5b0
|
ir_opt: Split off A32 specific passes
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
595f157e5e
|
A64: Implement LDP, STP
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
511215342b
|
A64/location_descriptor: Fix -fpermissive warning on GCC
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
243f06c613
|
A64: Implement LDP, STP
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
25411da838
|
A32: Implement load stores (immediate)
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
2aadeec291
|
A64: Implement SVC
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
9e27e4d250
|
imm: bug: SignExtend wasn't working for T with bit size > 32
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
10c60dda97
|
a64_emit_x64: Don't use far code for now
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
593a569b53
|
EmitA64SetW: bug: should zero extend to entire 64-bit register
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
6bd9f02911
|
EmitA64SetNZCV: bug: to_store is scratch
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
f0276dd53b
|
emit_x86: Fix nzcv for EmitSub
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
68391b0a05
|
A64: Implement SVC
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
e5ace37560
|
a64_emit_x64: Call interpreter
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
b12dead76a
|
A64: Add batch register retrieval to interface
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
cb481a3a48
|
A64: Implement compare and branch
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
e8bcf72ee5
|
A64: PSTATE access and tests
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
23f3afe0b3
|
A64: Implement branch (register)
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
86d1095df7
|
A64: Implement branch
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
0641445e51
|
A64: Implement logical
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
5a1d88c5dc
|
A64: Implement pcrel
|
2020-04-22 20:42:45 +01:00 |
|
MerryMage
|
c09e69bb97
|
A64: Implement addsub instructions
|
2020-04-22 20:42:44 +01:00 |
|
MerryMage
|
d1cef6ffb0
|
A64: Implement ADD_shifted
|
2020-04-22 20:42:44 +01:00 |
|
MerryMage
|
d1eb757f93
|
A64: Backend framework
|
2020-04-22 20:42:44 +01:00 |
|
MerryMage
|
e161cf16f5
|
A64: Initial framework
|
2020-04-22 20:42:44 +01:00 |
|
MerryMage
|
cde2d48eb9
|
CMakeLists: CMAKE_CXX_STANDARD as no effect on MSVC until CMake 3.10
We add the /std:c++latest flag to DYNARMIC_CXX_FLAGS to fix this.
|
2020-04-22 20:39:27 +01:00 |
|
MerryMage
|
f61da0b5a9
|
IR: Compile-time type-checking of IR
|
2020-04-22 20:39:27 +01:00 |
|
MerryMage
|
44f7f04b5c
|
IR/Value: Rename RegRef and ExtRegRef to A32Reg and A32ExtReg
|
2020-04-22 20:39:27 +01:00 |
|
MerryMage
|
83022322d1
|
Make IR->A32 LocationDescriptor conversion explicit
|
2020-04-22 20:39:27 +01:00 |
|
MerryMage
|
9d15e0a8e1
|
Final A32 refactor
|
2020-04-22 20:39:27 +01:00 |
|
MerryMage
|
455757d7b6
|
EmitX64: JitState type as template parameter
|
2020-04-22 20:39:26 +01:00 |
|
MerryMage
|
2d164d9345
|
Package up emit context
|
2020-04-22 20:38:31 +01:00 |
|
MerryMage
|
7bf421dd38
|
Rename JitState to A32JitState
|
2020-04-22 20:38:31 +01:00 |
|
MerryMage
|
63bd1ece23
|
backend_x64: Split A32 specific emission into separate class
|
2020-04-22 20:38:29 +01:00 |
|
MerryMage
|
8bef20c24d
|
IR: Split off A32 specific opcodes
|
2020-04-22 20:33:32 +01:00 |
|
MerryMage
|
b1f0cf9278
|
A32: Split off A32 specific IREmitter
|
2020-04-22 20:33:32 +01:00 |
|
MerryMage
|
b3c73e2622
|
Label A32 specific code appropriately
|
2020-04-22 20:33:30 +01:00 |
|
MerryMage
|
89e9ce8aff
|
Bump requirements to C++17
|
2020-04-22 20:27:15 +01:00 |
|
MerryMage
|
dc357c780d
|
EmitPackedHalvingSub{U,S}16: SSE2 implementation
|
2020-04-22 20:27:15 +01:00 |
|
MerryMage
|
a98821da41
|
Merge branch 'misc'
These commits introduce context save and restore, and a small number of
optimizations that depend on their use for performance.
|
2020-04-22 20:27:15 +01:00 |
|
MerryMage
|
fc885ac80f
|
EmitPackedHalvingAddU8: Add SSE2 implementation
|
2020-04-22 20:27:15 +01:00 |
|
MerryMage
|
4682211729
|
EmitPackedHalvingAdd{U,S}16: Add SSE2 implementation
|
2020-04-22 20:27:15 +01:00 |
|
MerryMage
|
9ac1c87a51
|
emit_x64: EmitSet{Register,ExtendedRegister32,ExtendedRegister64}: Store from current source
|
2020-04-22 20:27:15 +01:00 |
|
MerryMage
|
6e834de072
|
Add re-entry prediction to avoid std::unordered_map lookups
|
2020-04-22 20:26:40 +01:00 |
|
MerryMage
|
984ce22431
|
emit_x64: Arguments to MostSignificantBit and IsZero are 32-bit
|
2020-04-22 20:26:40 +01:00 |
|
MerryMage
|
5c6fcf378f
|
emit_x64: Optimize code emitted by EmitGetCpsr
|
2020-04-22 20:26:40 +01:00 |
|
MerryMage
|
f595f85039
|
block_of_code: Remove vzeroupper
|
2020-04-22 20:26:40 +01:00 |
|
MerryMage
|
4393473d06
|
interface: Allow saving and storing of contexts
|
2020-04-22 20:26:40 +01:00 |
|
MerryMage
|
05f3f07704
|
emit_x64: Reduce mxscr operations in EmitGetFpscr and EmitSetFpscr
|
2020-04-22 20:26:40 +01:00 |
|
MerryMage
|
19a7fb8992
|
jit_state: Split off CPSR.NZCV
|
2020-04-22 20:26:40 +01:00 |
|