mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 04:30:23 +00:00
Implement requiredTransitive
The PassManager did not implement the transitivity of requiredTransitive. This was unnoticed since 2006. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@123942 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5839614d97
commit
e906921480
@ -500,6 +500,10 @@ PMTopLevelManager::PMTopLevelManager(PMDataManager *PMDM) {
|
|||||||
void
|
void
|
||||||
PMTopLevelManager::setLastUser(const SmallVectorImpl<Pass *> &AnalysisPasses,
|
PMTopLevelManager::setLastUser(const SmallVectorImpl<Pass *> &AnalysisPasses,
|
||||||
Pass *P) {
|
Pass *P) {
|
||||||
|
unsigned PDepth = 0;
|
||||||
|
if (P->getResolver())
|
||||||
|
PDepth = P->getResolver()->getPMDataManager().getDepth();
|
||||||
|
|
||||||
for (SmallVectorImpl<Pass *>::const_iterator I = AnalysisPasses.begin(),
|
for (SmallVectorImpl<Pass *>::const_iterator I = AnalysisPasses.begin(),
|
||||||
E = AnalysisPasses.end(); I != E; ++I) {
|
E = AnalysisPasses.end(); I != E; ++I) {
|
||||||
Pass *AP = *I;
|
Pass *AP = *I;
|
||||||
@ -508,13 +512,40 @@ PMTopLevelManager::setLastUser(const SmallVectorImpl<Pass *> &AnalysisPasses,
|
|||||||
if (P == AP)
|
if (P == AP)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
// Update the last users of passes that are required transitive by AP.
|
||||||
|
AnalysisUsage *AnUsage = findAnalysisUsage(AP);
|
||||||
|
const AnalysisUsage::VectorType &IDs = AnUsage->getRequiredTransitiveSet();
|
||||||
|
SmallVector<Pass *, 12> LastUses;
|
||||||
|
SmallVector<Pass *, 12> LastPMUses;
|
||||||
|
for (AnalysisUsage::VectorType::const_iterator I = IDs.begin(),
|
||||||
|
E = IDs.end(); I != E; ++I) {
|
||||||
|
Pass *AnalysisPass = findAnalysisPass(*I);
|
||||||
|
assert(AnalysisPass && "Expected analysis pass to exist.");
|
||||||
|
AnalysisResolver *AR = AnalysisPass->getResolver();
|
||||||
|
assert(AR && "Expected analysis resolver to exist.");
|
||||||
|
unsigned APDepth = AR->getPMDataManager().getDepth();
|
||||||
|
|
||||||
|
if (PDepth == APDepth)
|
||||||
|
LastUses.push_back(AnalysisPass);
|
||||||
|
else if (PDepth > APDepth)
|
||||||
|
LastPMUses.push_back(AnalysisPass);
|
||||||
|
}
|
||||||
|
|
||||||
|
setLastUser(LastUses, P);
|
||||||
|
|
||||||
|
// If this pass has a corresponding pass manager, push higher level
|
||||||
|
// analysis to this pass manager.
|
||||||
|
if (P->getResolver())
|
||||||
|
setLastUser(LastPMUses, P->getResolver()->getPMDataManager().getAsPass());
|
||||||
|
|
||||||
|
|
||||||
// If AP is the last user of other passes then make P last user of
|
// If AP is the last user of other passes then make P last user of
|
||||||
// such passes.
|
// such passes.
|
||||||
for (DenseMap<Pass *, Pass *>::iterator LUI = LastUser.begin(),
|
for (DenseMap<Pass *, Pass *>::iterator LUI = LastUser.begin(),
|
||||||
LUE = LastUser.end(); LUI != LUE; ++LUI) {
|
LUE = LastUser.end(); LUI != LUE; ++LUI) {
|
||||||
if (LUI->second == AP)
|
if (LUI->second == AP)
|
||||||
// DenseMap iterator is not invalidated here because
|
// DenseMap iterator is not invalidated here because
|
||||||
// this is just updating exisitng entry.
|
// this is just updating existing entries.
|
||||||
LastUser[LUI->first] = P;
|
LastUser[LUI->first] = P;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,24 @@
|
|||||||
|
; RUN: opt -indvars -scalar-evolution -analyze %s
|
||||||
|
; This test checks if the SCEV analysis is printed out at all.
|
||||||
|
; It failed once as the RequiredTransitive option was not implemented
|
||||||
|
; correctly.
|
||||||
|
|
||||||
|
define i32 @main() nounwind {
|
||||||
|
entry:
|
||||||
|
br label %for.cond
|
||||||
|
|
||||||
|
for.cond: ; preds = %for.inc, %entry
|
||||||
|
%indvar1 = phi i64 [ %indvar.next2, %for.inc ], [ 0, %entry ] ; <i64> [#uses=3]
|
||||||
|
%exitcond = icmp ne i64 %indvar1, 1024 ; <i1> [#uses=1]
|
||||||
|
br i1 %exitcond, label %for.body, label %for.end
|
||||||
|
|
||||||
|
for.body: ; preds = %for.cond
|
||||||
|
br label %for.inc
|
||||||
|
|
||||||
|
for.inc: ; preds = %for.body
|
||||||
|
%indvar.next2 = add i64 %indvar1, 1 ; <i64> [#uses=1]
|
||||||
|
br label %for.cond
|
||||||
|
|
||||||
|
for.end: ; preds = %for.cond
|
||||||
|
ret i32 0
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user