- 8451744 Let callers decide the sub-register index on the def operand of rematerialized instructions. by Evan Cheng · 16 years ago
- 08954aa Fix assert(0) conversion, as suggested by Chris. by Torok Edwin · 16 years ago
- ccb29cd Convert more assert(0)+abort() -> LLVM_UNREACHABLE, by Torok Edwin · 16 years ago
- dab7b06 Improved tracking of value number kills. VN kills are now represented by Lang Hames · 16 years ago
- 16cab19 VNInfo cleanup. by Lang Hames · 16 years ago
- 210fc62 In some rare cases, the register allocator can spill registers but end up not utilizing registers at all. The fundamental problem is linearscan's backtracking can end up freeing more than one allocated registers. However, reloads and restores might be folded into uses / defs and freed registers might not be used at all. by Evan Cheng · 17 years ago
- 5185617 Fix pr3954. The register scavenger asserts for inline assembly with by Bob Wilson · 17 years ago
- 4486c1f Remove the "fast" cases for spill and restore point determination, as these were subtlely wrong in obscure cases. Patch the testcase by Owen Anderson · 17 years ago
- 0422efc Give the pre-alloc splitter access to the VirtRegMap. It doesn't do anything by Owen Anderson · 17 years ago
- 380b383 (Hopefully) silence a warning. by Owen Anderson · 17 years ago
- ad50398 Be more careful about choosing restore points when doing restore folding. This fixes some subtle miscompilations. by Owen Anderson · 17 years ago
- 0dedc11 Add a restore folder, which shaves a dozen or so machineinstrs off oggenc. Update a testcase to check this. by Owen Anderson · 17 years ago
- f138201 Fix a crash in the pre-alloc splitter exposed by recent codegen changes. by Owen Anderson · 17 years ago
- b5f0ec3 Add TargetInstrInfo::isSafeToMoveRegisterClassDefs. It returns true if it's safe to move an instruction which defines a value in the register class. Replace pre-splitting specific IgnoreRegisterClassBarriers with this new hook. by Evan Cheng · 17 years ago
- 7411523 Pre-alloc splitting needs to be more careful to avoid inserting spills/restores by Owen Anderson · 17 years ago
- 4eda2cb MergeValueInto is too smart: it might choose to do the merge the opposite direction. by Owen Anderson · 17 years ago
- 03f8625 Refactor PerformPHIConstruction, no functionality changes. by Evan Cheng · 17 years ago
- 19616c0 Fix test failures causes by my previous commit. by Owen Anderson · 17 years ago
- 66838e9 Fix an issue in PHI construction that was exposed by GCC 4.2 producing a different set iteration order for the reg_iterator. by Owen Anderson · 17 years ago
- bf77d2e Correct the algorithms for choosing spill and restore points so that we don't try to insert loads/stores between call frame setup and the actual call. by Owen Anderson · 17 years ago
- c0924a0 Fix an issue where restores could be inserted after a terminator instruction, by Owen Anderson · 17 years ago
- a590802 Comments are good. :-) by Owen Anderson · 17 years ago
- b05ce78 Add support for aggressive load-use-store folding. This takes care of the by Owen Anderson · 17 years ago
- 431053e Make the pre-split-limit option more useful by using a per-function counter. by Owen Anderson · 17 years ago
- e84c3f2 Reapply r63025 and r63026, with fixes for the failing testcases. by Owen Anderson · 17 years ago
- e7fa3c3 Also revert r63206 by Bill Wendling · 17 years ago
- a39c83d Temporarily revert r63025 until the testsuite failures can be fixed. by Bill Wendling · 17 years ago
- 5e235d3 Get rid of a bunch of dead code now that interval reconstruction is enabled. by Owen Anderson · 17 years ago
- feffdec Fix an issue where LiveIntervals was trying to be smart about removing kill by Owen Anderson · 17 years ago
- 72287a5 Silence a bogus compiler warning. by Evan Cheng · 17 years ago
- ee34b8f Some cleanups. No functional changes. by Owen Anderson · 17 years ago
- a2ca64a Stage two of fixing pre-alloc-splitting's code size issues: filter out restores that are just by Owen Anderson · 17 years ago
- 48abf23 Add an initial pass at dead spill/restore removal for pre alloc splitting. by Owen Anderson · 17 years ago
- fe48dfa I accidentally removed this check in an earlier commit, which cause breakage in the pre alloc splitter. by Owen Anderson · 17 years ago
- be7a29d Be more aggressive about renumbering vregs after splitting them. by Owen Anderson · 17 years ago
- c544cb0 Change TargetInstrInfo::isMoveInstr to return source and destination sub-register indices as well. by Evan Cheng · 17 years ago
- 45cfef2 More two-address fixes. This gets lua working with join-creation enabled. by Owen Anderson · 17 years ago
- f04100a The phi construction algorithm used for interval reconstruction is complicated by by Owen Anderson · 17 years ago
- 96fce00 Get rid of sentinel insertion in interval reconstruction. It just masked the by Owen Anderson · 17 years ago
- 8b86b9c Get live interval reconstruction several steps closer to working. by Owen Anderson · 17 years ago
- 43b1824 Add braces, as suggested by a gcc warning. by Duncan Sands · 17 years ago
- b523228 Fix up kill/dead marking in the new live interval reconstruction code. by Owen Anderson · 17 years ago
- 37751bb Add prototype code for recomputing a live interval's ranges and valnos through recursive phi construction. by Owen Anderson · 17 years ago
- ad4d2ab Re-apply r61158 in a form that no longer breaks tests. by Owen Anderson · 17 years ago
- 59727c0 Revert r61158 for now, as it caused some test failures. by Owen Anderson · 17 years ago
- 9389176 Fix miscompilations caused by renumbering, and enable it as part of prealloc splitting. by Owen Anderson · 17 years ago
- 5121ec3 Add code to renumber split intervals into new vregs. This is disabled for now until I finish working out some iterator invalidation issues. by Owen Anderson · 17 years ago
- 1267947 Switch to top-down mode and fix a crasher this exposed caused by an error in the by Owen Anderson · 17 years ago
- 0bcbe8f Factor out some common code. by Owen Anderson · 17 years ago
- ecd5b5f Add support for folding spills into preceding defs when doing pre-alloc splitting. by Owen Anderson · 17 years ago
- 1af37c2 Add support for rematerialization in pre-alloc-splitting. by Owen Anderson · 17 years ago
- 896512a Fix a bug introduced by my previous patch. With this change, SPEC is now clean with prealloc splitting enabled. by Owen Anderson · 17 years ago
- d36b4c1 Don't allow the restore point to be placed after terminators. With this change, by Owen Anderson · 17 years ago
- fd395eb Don't walk into predecessors in which the vreg is not live when doing shrinkwrapping. by Owen Anderson · 17 years ago
- 26c10f1 Use the new predicate to control when we do prealloc splitting. Fix a small bug. by Owen Anderson · 17 years ago
- a926ed4 First pass at checking for the creation of a new join point when doing pre-alloc splitting. This is not turned on yet. by Owen Anderson · 17 years ago
- b067843 Revert my last patch until I consult with Evan about it. by Owen Anderson · 17 years ago
- 2bb2aaa Don't do pre-splitting if doing so would create a value join that did not by Owen Anderson · 17 years ago
- d1f8c9f Add a fixme. by Evan Cheng · 17 years ago
- ce3ccc1 - More pre-split fixes: spill slot live interval computation bug; restore point bug. by Evan Cheng · 17 years ago
- 938e201 - Rewrite code that update register live interval that's split. by Evan Cheng · 17 years ago
- 5e88d90 If def is in the same mbb as the barrier, spilt the value after the last use before the barrier. by Evan Cheng · 17 years ago
- 9f85469 Add command line option to limit the number splits to help debugging. by Evan Cheng · 17 years ago
- fab3168 Avoid putting a split past the end of the live range; always shrink wrap live interval in the barrier mbb. by Evan Cheng · 17 years ago
- e67ad47 Silence a bogus compile time warning. by Evan Cheng · 17 years ago
- f46642a Remove val# defined by a remat'ed def that is now dead. by Evan Cheng · 17 years ago
- f713722 For now, don't split live intervals around x87 stack register barriers. FpGET_ST0_80 must be right after a call instruction (and ADJCALLSTACKUP) so we need to find a way to prevent reload of x87 registers between them. by Evan Cheng · 17 years ago
- ed033ed Do not shrink wrap live interval in a mbb if it's livein any of its successor blocks. The mbb can be revisited again after all of the successors are processed. by Evan Cheng · 17 years ago
- f48367b Handle cases where there aren't uses in the barrier mbb. by Evan Cheng · 17 years ago
- 85d71d4 If val# def is ~0U, meaning it's defined by a PHI, and it's previously split, spill before the barrier because it's impossible to determine if all the defs are spilled in the same spill slot. by Evan Cheng · 17 years ago
- cd160f9 Fix a pasto. by Evan Cheng · 17 years ago
- f8b09d4 Fix a end() dereference; remove an abort() that wasn't meant to be left in. by Evan Cheng · 17 years ago
- 4bac4d0 Avoid splitting an interval multiple times; avoid splitting re-materializable val# (for now). by Evan Cheng · 17 years ago
- d0d0317 Committing a good chunk of the pre-register allocation live interval splitting pass. It's handling simple cases and appear to do good things. Next: avoid splitting an interval multiple times; renumber registers when possible; record stack slot live intervals for coloring; rematerialize defs when possible. by Evan Cheng · 17 years ago
- 7e721ec Add skeleton for the pre-register allocation live interval splitting pass. by Evan Cheng · 17 years ago