Commit Graph

1426 Commits

Author SHA1 Message Date
acb1eec35d Windows CI: Install MSYS2 with chocolatey 2020-07-25 20:26:36 +02:00
116d831cfd Fix 16-bit DSi ARM9 read 2020-07-23 20:06:44 +00:00
f5130f82eb Arisotura isn't the only derp 2020-07-23 19:56:09 +00:00
ac8f44125b I'm a derp 2020-07-23 21:27:45 +02:00
e85d2e2cf3 Use the correct slow path for block read/write 2020-07-23 19:12:25 +00:00
961b4252e2 Make it buildable on aarch64 2020-07-23 19:07:33 +00:00
e63bd7e38c for some reason tabs and spaces were mixed 2020-07-23 17:43:25 +02:00
2f9a6b7c03 SPU: delay channel start until whenever it can actually start. fixes maxmod interpolated mode. 2020-07-23 12:59:19 +02:00
3827fa562f another try 2020-07-09 00:11:47 +02:00
1519b3d5fa attempt at fixing aarch64 linux yet again 2020-07-08 23:57:43 +02:00
8f5d8d1e12 fix for fastmem when pc is used as immediate
and (hopefully) make SIGSEGV handler work for aarch64 linux
2020-07-08 23:47:24 +02:00
3786660099 misc JIT changes 2020-07-08 23:08:25 +02:00
778623a8b7 make linux work and fix a few bugs 2020-07-04 18:58:00 +02:00
62c6e2f703 Merge pull request #667 from Arisotura/generic_jit
merge jit
2020-07-01 00:01:11 +02:00
c5381d2911 reconcile DSi and JIT, fastmem for x64 and Windows 2020-06-30 23:50:41 +02:00
ea6d03581b make literal optimisation work again
enable single register block load/store optimisations for x64 aswell
2020-06-16 12:11:20 +02:00
e335a8ca76 first steps in bringing over the JIT refactor/fastmem 2020-06-16 12:11:19 +02:00
fea9f95bba fix inlined IO register access 2020-06-16 12:06:43 +02:00
e7d076403d Merge branch 'generic_jit' of https://github.com/Arisotura/melonDS into generic_jit 2020-06-16 12:06:42 +02:00
c17f7b100e allow allocating caller saved regs on windows 2020-06-16 12:01:10 +02:00
efb796640b use instr hash as key for restore candidates
makes Golden Sun burn a little slower through the JIT memory
2020-06-16 12:01:10 +02:00
80b88dbd05 allow allocating caller saved registers
currently system-v only
2020-06-16 12:01:09 +02:00
052ff73672 rewrite JIT memory emulation 2020-06-16 12:01:08 +02:00
b902cd1b8e fix regression from last commit
also a small mistake with msr
2020-06-16 11:59:10 +02:00
5a3607bc68 don't use param registers for ReadBanked/WriteBanked
should fix linux build
2020-06-16 11:59:09 +02:00
6d217e1010 fix build with JIT disabled and set default JIT maxblock size to 32 2020-06-16 11:59:09 +02:00
dc86bac83d hopefully fix stack handling for linux 2020-06-16 11:59:08 +02:00
c2dd6a186d implement msr and mrs for the x64 JIT 2020-06-16 11:59:07 +02:00
1c98cefcee compile UMULLs and some fixes 2020-06-16 11:59:06 +02:00
1c07932b40 implement block linking + some refactoring
currently only supported for x64
2020-06-16 11:59:06 +02:00
1ad90cb334 include more information in DataRegion 2020-06-16 11:58:46 +02:00
3ab9e4a4c9 arm64 fix itcm invalidation and ldm^/stm^ 2020-06-16 11:57:58 +02:00
3098c6a9a0 preparations for block linking 2020-06-16 11:57:57 +02:00
5ab56cef5f this mistake was phenomally stupid 2020-06-16 11:57:57 +02:00
225f90cced the time of good commit names is long gone 2020-06-16 11:57:56 +02:00
c8b7a34383 git played a prank on me haha very funny 2020-06-16 11:57:55 +02:00
262dc7ad00 this it should work 2020-06-16 11:57:55 +02:00
d2acceb367 fixup for aarch64 JIT 2020-06-16 11:57:54 +02:00
2725429727 fix LDM usermode for aarch64 as well 2020-06-16 11:57:53 +02:00
3173e6e25d re add error for unsupported JIT platforms 2020-06-16 11:57:52 +02:00
0d83e98e04 apply fixes for aarch64 linux by @nadiaholmquist 2020-06-16 11:57:52 +02:00
99b34efe2d move ARM64 JIT backend here 2020-06-16 11:57:51 +02:00
baed0ac0d5 remove debug leftovers 2020-06-16 11:57:50 +02:00
ec965c6014 improve nop handling and proper behaviour for LDM^
fixes dslinux
2020-06-16 11:57:49 +02:00
000c03c9d6 disable literal optimations in DTCM 2020-06-16 11:57:48 +02:00
1cfbbcbb2a make savestates 100% compatible again 2020-06-16 11:57:48 +02:00
3e7483636f make literal optimisation more reliable
fixes spanish Pokemon HeartGold
2020-06-16 11:57:47 +02:00
d1d96d2236 fix config key for jit literal optimisations 2020-06-16 11:57:46 +02:00
441869a105 integrate changes from ARM64 backend and more
- better handle LDM/STM in reg alloc
- unify Halted and IRQ in anticipation for branch inlining
- literal optimisations can be disabled in gui
- jit blocks follow simple returns
- fix idle loop detection
- break jit blocks on IRQ (fixes saving in Pokemon White)
2020-06-16 11:57:45 +02:00
9cf7780e46 decrease jit block cache address granularity
fixes Dragon Quest IX
move code with side effects out of assert, fixes release build
(thanks to m4wx for this one)
also remove some leftovers of jit pipelining
2020-06-16 11:56:45 +02:00