Merry
ec3c597591
backend/arm64: Implement LeastSignificantByte
2022-10-18 15:04:30 +01:00
Merry
a33d186fea
backend/arm64: Implement LeastSignificantHalf
2022-10-18 15:04:30 +01:00
Merry
163ed9b185
backend/arm64: Implement LeastSignificantWord
2022-10-18 15:04:30 +01:00
Merry
7c86b06233
backend/arm64: Implement Pack2x64To1x128
2022-10-18 15:04:30 +01:00
Merry
98806139a5
backend/arm64/reg_alloc: Argument HostLoc location
2022-10-18 15:04:30 +01:00
Merry
fe4e864e4c
backend/arm64: Implement Pack2x32To1x64
2022-10-18 15:04:30 +01:00
Merry
ff9b92c791
backend/arm64: Implement NZCVFromPackedFlags
2022-10-18 15:04:30 +01:00
Merry
7ea97f7629
backend/arm64: Implement GetLowerFromOp
2022-10-18 15:04:30 +01:00
Merry
92026a456a
backend/arm64: Implement GetUpperFromOp
2022-10-18 15:04:30 +01:00
Merry
8c4ea10a38
backend/arm64: Implement GetNZCVFromOp
2022-10-18 15:04:30 +01:00
Merry
e34749336a
backend/arm64: Implement GetGEFromOp
2022-10-18 15:04:30 +01:00
Merry
fbcbc1d90d
backend/arm64: Implement GetOverflowFromOp
2022-10-18 15:04:30 +01:00
Merry
fb3b828158
backend/arm64: Implement Identity
2022-10-18 15:04:30 +01:00
Merry
97ba8a0f14
backend/arm64: Implement Void
2022-10-18 15:04:30 +01:00
Merry
2a24bb2c1e
backend/arm64: Implement Breakpoint
2022-10-18 15:04:30 +01:00
Merry
3a11467220
backend/arm64: Stub all IR instruction implementations
2022-10-18 15:04:30 +01:00
Merry
402abf5ea3
backend/arm64: Implement A32GetExtendedRegister
2022-10-18 15:04:30 +01:00
Merry
84cad9f831
backend/arm64: Implement A32SetCheckBit
2022-10-18 15:04:30 +01:00
Merry
3e5309bd96
tests: Add test generator
2022-10-18 15:04:30 +01:00
Merry
52a46d841b
backend/arm64: Implement A32BXWritePC
2022-10-18 15:04:30 +01:00
Merry
67dc7f2e4e
backend/arm64: Implement A32UpdateUpperLocationDescriptor
2022-10-18 15:04:30 +01:00
Merry
00ad84b7ab
backend/arm64: Initial implementation of terminals
2022-10-18 15:04:30 +01:00
Merry
80c89401b9
a32_address_space: Add StackLayout to stack
2022-10-18 15:04:30 +01:00
Merry
9b2391ec7b
backend/arm64/reg_alloc: Implement AssertNoMoreUses
2022-10-18 15:04:30 +01:00
Merry
ecacb6cdc6
tests/rand_int: Expose PRNG
2022-10-18 15:04:30 +01:00
Merry
8e6467bf45
backend/arm64/reg_alloc: Add flag handling
2022-10-18 15:04:30 +01:00
Merry
77436bbbbb
backend/arm64: Toy implementation of enough to execute LSLS
2022-10-18 15:04:30 +01:00
Merry
7e046357ff
backend/arm64: Initial implementation of register allocator
2022-10-18 15:04:30 +01:00
Merry
3bf2b0aba9
backend/arm64: Adjust how relocations are stored
2022-10-18 15:04:30 +01:00
Merry
e0f091b6a6
backend/arm64: void* -> CodePtr
2022-10-18 15:04:30 +01:00
Merry
f6e80f1e0e
backend/arm64: First dummy code execution
2022-10-18 15:04:30 +01:00
Merry
d877777c50
backend/arm64: Initial framework
2022-10-18 15:04:30 +01:00
Merry
e7b2eb2c7c
Add aarch64 CI
2022-10-18 15:04:30 +01:00
Wunkolo
e886bfb7c1
backend/x64: Fix FixupLUT
argument order
...
The last two arguments(fixup response response for finite values) are
neg-pos, not pos-neg. Found this out while re-using this function for
some math stuff. Thankfully nothing currently uses this fixup response
at the moment.
2022-09-30 23:10:21 +01:00
Merry
af51845a53
decoder_detail: Workaround #708
2022-09-02 21:16:43 +01:00
Bart Ribbers
e49fee0ca1
block_of_code: rename PAGE_SIZE to DYNARMIC_PAGE_SIZE to prevent use of reserved name
...
PAGE_SIZE is a kernel symbol and depending on the libc in use, it will
"leak". In this case dynarmic was using it's own PAGE_SIZE and in
combination with the Musl libc the compiler would complain it was overwriting
the kernel symbol
2022-08-25 23:32:18 +01:00
Merry
bf422a190a
decoder_detail: Simplify DYNARMIC_DECODER_GET_MATCHER
2022-08-21 18:22:14 +01:00
GPUCode
a62dc19605
cmake: Bump minimum required cmake version
...
Version 3.12 is the minimum that supports the value of 20 for CMAKE_CXX_STANDARD. Also remove /std:c++latest to get rid of compiler logspam
2022-08-15 21:00:01 +01:00
merry
3cb939e70b
fuzz_arm: Avoid backwards jumps that may jump into code
2022-08-08 21:05:00 +01:00
Merry
c60fd3f0ac
block_of_code: Fix running under Rosetta
...
Rosetta doesn't have accurate emulation of the sahf instruction
2022-08-05 23:43:01 +01:00
Merry
a38966a874
block_of_code: Extract flag loading into a function
...
LoadRequiredFlagsForCondFromRax
2022-08-05 23:42:19 +01:00
Merry
d7bd5bb7a7
emit_x64: Use movzx(eax, ah) instead of emitting byte equivalent
...
Emission fixed in xbyak v6.61
2022-07-31 17:52:35 +01:00
Merry
5b6e3d8b54
Squashed 'externals/xbyak/' changes from 913099fc8..88f2f771f
...
88f2f771f Merge branch 'dev'
8623616e0 v6.61
1b911598d mingw uses __thread instead of __declspec(thread)
d224701f4 fix movzx eax, ah on 64bit and test it
1c35e34ab Merge branch 'dev'
4fb0e58aa test of cpuid
913c798ff update doc
8f6dee319 v6.60.2
21419721e Merge branch 'Wunkolo-standalone-cpuid' into dev
1b2e7c7da Fix detection of `GFNI`,`VAES`, and `VPCLMULQDQ`
git-subtree-dir: externals/xbyak
git-subtree-split: 88f2f771f179a3d856ecd0b07a20598bd06ba21d
2022-07-31 17:50:57 +01:00
Merry
8f890d327a
externals: Update xbyak to 6.61
...
Merge commit '5b6e3d8b54e428fceedd907cf5c0f52ca98eb003'
2022-07-31 17:50:57 +01:00
Merry
f33c6f062b
Revert "block_of_code: Refactor MConst
to Xmm{B}Const
"
...
This reverts commit 5d9b720189
.
Obscure bugs resulting from this commit due to assumptions regarding zero-extension of higher bits.
2022-07-27 20:31:08 +01:00
Merry
fbdcfeab99
emit_x64_packed: Do not use XmmBConst here
...
Broadcasting is inappropriate
2022-07-27 20:14:49 +01:00
Merry
2d4602a651
6.2.3
2022-07-26 13:06:05 +01:00
Merry
b002419993
tests/{a32,a64}_unicorn: Avoid use of deprecated fmt API
2022-07-26 12:04:52 +01:00
Merry
64e6546827
github: Rename build-and-test to x86-64
...
Prepare for non x64 backends
2022-07-26 11:50:45 +01:00
Merry
35b1da4b1f
6.2.2
2022-07-26 11:21:37 +01:00