mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-14 11:32:34 +00:00
CaptureTracking: Plug a loophole in the "too many uses" heuristic.
The heuristic was added to avoid spending too much compile time A specially crafted test case (PR17461, PR16474) with many uses on a select or bitcast instruction can still trigger the slow case. Add a check for that case. This only affects compile time, don't have a good way to test it. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@191896 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
20357662a0
commit
4d63c8daec
@ -146,8 +146,14 @@ void llvm::PointerMayBeCaptured(const Value *V, CaptureTracker *Tracker) {
|
|||||||
case Instruction::PHI:
|
case Instruction::PHI:
|
||||||
case Instruction::Select:
|
case Instruction::Select:
|
||||||
// The original value is not captured via this if the new value isn't.
|
// The original value is not captured via this if the new value isn't.
|
||||||
|
Count = 0;
|
||||||
for (Instruction::use_iterator UI = I->use_begin(), UE = I->use_end();
|
for (Instruction::use_iterator UI = I->use_begin(), UE = I->use_end();
|
||||||
UI != UE; ++UI) {
|
UI != UE; ++UI) {
|
||||||
|
// If there are lots of uses, conservatively say that the value
|
||||||
|
// is captured to avoid taking too much compile time.
|
||||||
|
if (Count++ >= Threshold)
|
||||||
|
return Tracker->tooManyUses();
|
||||||
|
|
||||||
Use *U = &UI.getUse();
|
Use *U = &UI.getUse();
|
||||||
if (Visited.insert(U))
|
if (Visited.insert(U))
|
||||||
if (Tracker->shouldExplore(U))
|
if (Tracker->shouldExplore(U))
|
||||||
|
Loading…
Reference in New Issue
Block a user