Jonas Maebe
|
67b8aceaee
* synchronized with privatetrunk till r30095
|
před 10 roky |
sergei
|
31fddaafe8
+ New subtype of tai_regalloc, "ra_markused". It marks a physical register as used in procedure, triggering saving/restoring that register if it is non-volatile.
|
před 10 roky |
Jonas Maebe
|
5c75b6dd6b
* synchronised with trunk up till r28402
|
před 11 roky |
sergei
|
9b9ea15d68
+ m68k: initial implementation of do_spill_replace (supports only MOVE instructions for now). Tested with qemu for Coldfire target.
|
před 11 roky |
Jonas Maebe
|
bacd303208
* synchronized with trunk up to r27758
|
před 11 roky |
Jonas Maebe
|
246caf3526
* never alias/coalesce cpu registers that are not usable by the register
|
před 11 roky |
Jonas Maebe
|
e9268a0a14
* synchronised with trunk up till r26975
|
před 11 roky |
florian
|
23c724f885
* prevent a temp. register allocated during spilling being immediately spilled again, resolves #25164
|
před 11 roky |
florian
|
829764e96b
+ replace registers to spill in mov instructions and convert them into ldr/str
|
před 11 roky |
Károly Balogh
|
587acf6452
fix infinite spilling on m68k, patch by Florian, additional IE workaround by me, based on a similar hack in the ARM cg...
|
před 11 roky |
Károly Balogh
|
70f9b098e0
no longer define a segment field for m68k
|
před 11 roky |
sergei
|
d2a9308181
+ SPARC: implemented register spill replacement.
|
před 11 roky |
Jonas Maebe
|
b7803ab974
+ llvm support for the register allocator. While llvm works with virtual
|
před 12 roky |
Jonas Maebe
|
5ef93e85b8
+ added extra "orgsupreg" parameter to do_spill_read/do_spill_written/
|
před 12 roky |
Jonas Maebe
|
5599870a4e
* moved the register colouring and spill temp allocation to a virtual method,
|
před 12 roky |
svenbarth
|
32a18199c5
Print aX or aregX for address registers if DEBUG_REGISTERLIFE is defined.
|
před 12 roky |
florian
|
dc567acc9a
* accumulate register weight instead of taking only the maximum
|
před 12 roky |
florian
|
c2f7ccb253
* coalesce more aggressive
|
před 12 roky |
sergei
|
8b8553991a
+ MIPS: prevent coalescing written-to registers with $sp,$fp,$zero and $at.
|
před 12 roky |
florian
|
23c84fd27c
* more fixes for segment register usage
|
před 12 roky |
florian
|
b85addb451
+ color segment register
|
před 12 roky |
svenbarth
|
d15304c25e
Also check for the type of the register when replacing it. In certain circumstances this can still lead to access to invalid memory resulting either in an access violation or invalid registers.
|
před 13 roky |
pierre
|
322b793506
Try to do something for m68k integer/address registers; not working yet :!(
|
před 13 roky |
svenbarth
|
2ada9a528b
Fix a critical bug in the register allocator (at least for CPUs with seperate address
|
před 13 roky |
florian
|
95830d5a4a
+ DEBUG_REGISTERLIFE define
|
před 13 roky |
florian
|
f75e39e660
+ aliasing of registers, allows to split live ranges
|
před 13 roky |
florian
|
f9dd5bf5e6
+ live_start and live_end_properties
|
před 13 roky |
florian
|
c2d067940a
* get rid of hash chars, modern tools and IDEs can use normal comments as documentation if needed
|
před 13 roky |
florian
|
b78f9826fb
* call AllocMem instead of GetMem/FillChar
|
před 13 roky |
florian
|
ecdec2e431
* disable reg. allocator optimization introduced in r21812 for now because it caused some trouble, see #22405
|
před 13 roky |