Index: include/polly/ScopInfo.h =================================================================== --- include/polly/ScopInfo.h +++ include/polly/ScopInfo.h @@ -1818,14 +1818,17 @@ /// block in the @p FinishedExitBlocks set so we can later skip edges from /// within the region to that block. /// - /// @param BB The block for which the domain is currently propagated. - /// @param BBLoop The innermost affine loop surrounding @p BB. + /// @param BB The block for which the domain is currently + /// propagated. + /// @param BBLoop The innermost affine loop surrounding @p BB. /// @param FinishedExitBlocks Set of region exits the domain was set for. - /// @param LI The LoopInfo for the current function. - /// + /// @param LI The LoopInfo for the current function. + /// @param InvalidDomainMap BB to InvalidDomain map for the BB of current + /// region. void propagateDomainConstraintsToRegionExit( BasicBlock *BB, Loop *BBLoop, - SmallPtrSetImpl &FinishedExitBlocks, LoopInfo &LI); + SmallPtrSetImpl &FinishedExitBlocks, LoopInfo &LI, + DenseMap &InvalidDomainMap); /// Compute the union of predecessor domains for @p BB. /// @@ -1845,30 +1848,43 @@ /// Add loop carried constraints to the header block of the loop @p L. /// - /// @param L The loop to process. - /// @param LI The LoopInfo for the current function. + /// @param L The loop to process. + /// @param LI The LoopInfo for the current function. + /// @param InvalidDomainMap BB to InvalidDomain map for the BB of current + /// region. /// /// @returns True if there was no problem and false otherwise. - bool addLoopBoundsToHeaderDomain(Loop *L, LoopInfo &LI); + bool addLoopBoundsToHeaderDomain( + Loop *L, LoopInfo &LI, + DenseMap &InvalidDomainMap); /// Compute the branching constraints for each basic block in @p R. /// - /// @param R The region we currently build branching conditions for. - /// @param DT The DominatorTree for the current function. - /// @param LI The LoopInfo for the current function. + /// @param R The region we currently build branching conditions + /// for. + /// @param DT The DominatorTree for the current function. + /// @param LI The LoopInfo for the current function. + /// @param InvalidDomainMap BB to InvalidDomain map for the BB of current + /// region. /// /// @returns True if there was no problem and false otherwise. - bool buildDomainsWithBranchConstraints(Region *R, DominatorTree &DT, - LoopInfo &LI); + bool buildDomainsWithBranchConstraints( + Region *R, DominatorTree &DT, LoopInfo &LI, + DenseMap &InvalidDomainMap); /// Propagate the domain constraints through the region @p R. /// - /// @param R The region we currently build branching conditions for. - /// @param DT The DominatorTree for the current function. - /// @param LI The LoopInfo for the current function. + /// @param R The region we currently build branching conditions + /// for. + /// @param DT The DominatorTree for the current function. + /// @param LI The LoopInfo for the current function. + /// @param InvalidDomainMap BB to InvalidDomain map for the BB of current + /// region. /// /// @returns True if there was no problem and false otherwise. - bool propagateDomainConstraints(Region *R, DominatorTree &DT, LoopInfo &LI); + bool propagateDomainConstraints( + Region *R, DominatorTree &DT, LoopInfo &LI, + DenseMap &InvalidDomainMap); /// Propagate invalid domains of statements through @p R. /// @@ -1877,21 +1893,28 @@ /// of error statements and those only reachable via error statements will be /// replaced by an empty set. Later those will be removed completely. /// - /// @param R The currently traversed region. - /// @param DT The DominatorTree for the current function. - /// @param LI The LoopInfo for the current function. - /// + /// @param R The currently traversed region. + /// @param DT The DominatorTree for the current function. + /// @param LI The LoopInfo for the current function. + /// @param InvalidDomainMap BB to InvalidDomain map for the BB of current + /// region. + // /// @returns True if there was no problem and false otherwise. - bool propagateInvalidStmtDomains(Region *R, DominatorTree &DT, LoopInfo &LI); + bool propagateInvalidStmtDomains( + Region *R, DominatorTree &DT, LoopInfo &LI, + DenseMap &InvalidDomainMap); /// Compute the domain for each basic block in @p R. /// - /// @param R The region we currently traverse. - /// @param DT The DominatorTree for the current function. - /// @param LI The LoopInfo for the current function. + /// @param R The region we currently traverse. + /// @param DT The DominatorTree for the current function. + /// @param LI The LoopInfo for the current function. + /// @param InvalidDomainMap BB to InvalidDomain map for the BB of current + /// region. /// /// @returns True if there was no problem and false otherwise. - bool buildDomains(Region *R, DominatorTree &DT, LoopInfo &LI); + bool buildDomains(Region *R, DominatorTree &DT, LoopInfo &LI, + DenseMap &InvalidDomainMap); /// Add parameter constraints to @p C that imply a non-empty domain. __isl_give isl_set *addNonEmptyDomainConstraints(__isl_take isl_set *C) const; @@ -1999,7 +2022,8 @@ void buildContext(); /// Add user provided parameter constraints to context (source code). - void addUserAssumptions(AssumptionCache &AC, DominatorTree &DT, LoopInfo &LI); + void addUserAssumptions(AssumptionCache &AC, DominatorTree &DT, LoopInfo &LI, + DenseMap &InvalidDomainMap); /// Add user provided parameter constraints to context (command line). void addUserContext(); Index: lib/Analysis/ScopBuilder.cpp =================================================================== --- lib/Analysis/ScopBuilder.cpp +++ lib/Analysis/ScopBuilder.cpp @@ -947,10 +947,13 @@ scop->buildInvariantEquivalenceClasses(); - if (!scop->buildDomains(&R, DT, LI)) + /// A map from basic blocks to their invalid domains. + DenseMap InvalidDomainMap; + + if (!scop->buildDomains(&R, DT, LI, InvalidDomainMap)) return; - scop->addUserAssumptions(AC, DT, LI); + scop->addUserAssumptions(AC, DT, LI, InvalidDomainMap); // Remove empty statements. // Exit early in case there are no executable statements left in this scop. Index: lib/Analysis/ScopInfo.cpp =================================================================== --- lib/Analysis/ScopInfo.cpp +++ lib/Analysis/ScopInfo.cpp @@ -1466,23 +1466,32 @@ return setDimensionIds(Domain, ConsequenceCondSet); } +__isl_give isl_pw_aff * +getPwAff(Scop &S, BasicBlock *BB, + DenseMap &InvalidDomainMap, const SCEV *E, + bool NonNegative = false) { + PWACtx PWAC = S.getPwAff(E, S.getEntry(), NonNegative); + InvalidDomainMap[BB] = isl_set_union(InvalidDomainMap[BB], PWAC.second); + return PWAC.first; +} + /// Build the conditions sets for the switch @p SI in the @p Domain. /// /// This will fill @p ConditionSets with the conditions under which control /// will be moved from @p SI to its successors. Hence, @p ConditionSets will /// have as many elements as @p SI has successors. static bool -buildConditionSets(ScopStmt &Stmt, SwitchInst *SI, Loop *L, +buildConditionSets(Scop &S, BasicBlock *BB, SwitchInst *SI, Loop *L, __isl_keep isl_set *Domain, + DenseMap &InvalidDomainMap, SmallVectorImpl<__isl_give isl_set *> &ConditionSets) { Value *Condition = getConditionFromTerminator(SI); assert(Condition && "No condition for switch"); - Scop &S = *Stmt.getParent(); ScalarEvolution &SE = *S.getSE(); isl_pw_aff *LHS, *RHS; - LHS = Stmt.getPwAff(SE.getSCEVAtScope(Condition, L)); + LHS = getPwAff(S, BB, InvalidDomainMap, SE.getSCEVAtScope(Condition, L)); unsigned NumSuccessors = SI->getNumSuccessors(); ConditionSets.resize(NumSuccessors); @@ -1490,7 +1499,7 @@ unsigned Idx = Case.getSuccessorIndex(); ConstantInt *CaseValue = Case.getCaseValue(); - RHS = Stmt.getPwAff(SE.getSCEV(CaseValue)); + RHS = getPwAff(S, BB, InvalidDomainMap, SE.getSCEV(CaseValue)); isl_set *CaseConditionSet = buildConditionSet(ICmpInst::ICMP_EQ, isl_pw_aff_copy(LHS), RHS, Domain); ConditionSets[Idx] = isl_set_coalesce( @@ -1519,11 +1528,11 @@ /// context under which @p Condition is true/false will be returned as the /// new elements of @p ConditionSets. static bool -buildConditionSets(ScopStmt &Stmt, Value *Condition, TerminatorInst *TI, - Loop *L, __isl_keep isl_set *Domain, +buildConditionSets(Scop &S, BasicBlock *BB, Value *Condition, + TerminatorInst *TI, Loop *L, __isl_keep isl_set *Domain, + DenseMap &InvalidDomainMap, SmallVectorImpl<__isl_give isl_set *> &ConditionSets) { - Scop &S = *Stmt.getParent(); isl_set *ConsequenceCondSet = nullptr; if (auto *CCond = dyn_cast(Condition)) { if (CCond->isZero()) @@ -1534,10 +1543,10 @@ auto Opcode = BinOp->getOpcode(); assert(Opcode == Instruction::And || Opcode == Instruction::Or); - bool Valid = buildConditionSets(Stmt, BinOp->getOperand(0), TI, L, Domain, - ConditionSets) && - buildConditionSets(Stmt, BinOp->getOperand(1), TI, L, Domain, - ConditionSets); + bool Valid = buildConditionSets(S, BB, BinOp->getOperand(0), TI, L, Domain, + InvalidDomainMap, ConditionSets) && + buildConditionSets(S, BB, BinOp->getOperand(1), TI, L, Domain, + InvalidDomainMap, ConditionSets); if (!Valid) { while (!ConditionSets.empty()) isl_set_free(ConditionSets.pop_back_val()); @@ -1564,8 +1573,10 @@ // to be set. The comparison is equal to a signed comparison under this // assumption. bool NonNeg = ICond->isUnsigned(); - LHS = Stmt.getPwAff(SE.getSCEVAtScope(ICond->getOperand(0), L), NonNeg); - RHS = Stmt.getPwAff(SE.getSCEVAtScope(ICond->getOperand(1), L), NonNeg); + LHS = getPwAff(S, BB, InvalidDomainMap, + SE.getSCEVAtScope(ICond->getOperand(0), L), NonNeg); + RHS = getPwAff(S, BB, InvalidDomainMap, + SE.getSCEVAtScope(ICond->getOperand(1), L), NonNeg); ConsequenceCondSet = buildConditionSet(ICond->getPredicate(), LHS, RHS, Domain); } @@ -1608,12 +1619,14 @@ /// will be moved from @p TI to its successors. Hence, @p ConditionSets will /// have as many elements as @p TI has successors. static bool -buildConditionSets(ScopStmt &Stmt, TerminatorInst *TI, Loop *L, +buildConditionSets(Scop &S, BasicBlock *BB, TerminatorInst *TI, Loop *L, __isl_keep isl_set *Domain, + DenseMap &InvalidDomainMap, SmallVectorImpl<__isl_give isl_set *> &ConditionSets) { if (SwitchInst *SI = dyn_cast(TI)) - return buildConditionSets(Stmt, SI, L, Domain, ConditionSets); + return buildConditionSets(S, BB, SI, L, Domain, InvalidDomainMap, + ConditionSets); assert(isa(TI) && "Terminator was neither branch nor switch."); @@ -1625,7 +1638,8 @@ Value *Condition = getConditionFromTerminator(TI); assert(Condition && "No condition for Terminator"); - return buildConditionSets(Stmt, Condition, TI, L, Domain, ConditionSets); + return buildConditionSets(S, BB, Condition, TI, L, Domain, InvalidDomainMap, + ConditionSets); } void ScopStmt::buildDomain() { @@ -2092,8 +2106,9 @@ return DT.dominates(BB, getEntry()); } -void Scop::addUserAssumptions(AssumptionCache &AC, DominatorTree &DT, - LoopInfo &LI) { +void Scop::addUserAssumptions( + AssumptionCache &AC, DominatorTree &DT, LoopInfo &LI, + DenseMap &InvalidDomainMap) { auto &F = getFunction(); for (auto &Assumption : AC.assumptions()) { auto *CI = dyn_cast_or_null(Assumption); @@ -2128,7 +2143,8 @@ auto *TI = InScop ? CI->getParent()->getTerminator() : nullptr; auto &Stmt = InScop ? *getStmtFor(CI->getParent()) : *Stmts.begin(); auto *Dom = InScop ? getDomainConditions(&Stmt) : isl_set_copy(Context); - bool Valid = buildConditionSets(Stmt, Val, TI, L, Dom, ConditionSets); + bool Valid = buildConditionSets(*this, Stmt.getBasicBlock(), Val, TI, L, + Dom, InvalidDomainMap, ConditionSets); isl_set_free(Dom); if (!Valid) @@ -2607,7 +2623,8 @@ return getDomainConditions(BBR->getEntry()); } -bool Scop::buildDomains(Region *R, DominatorTree &DT, LoopInfo &LI) { +bool Scop::buildDomains(Region *R, DominatorTree &DT, LoopInfo &LI, + DenseMap &InvalidDomainMap) { bool IsOnlyNonAffineRegion = isNonAffineSubRegion(R); auto *EntryBB = R->getEntry(); @@ -2620,19 +2637,16 @@ L = L->getParentLoop(); } - // Initialize the invalid domain. - auto *EntryStmt = getStmtFor(EntryBB); - EntryStmt->setInvalidDomain(isl_set_empty(isl_set_get_space(S))); - + InvalidDomainMap[EntryBB] = isl_set_empty(isl_set_get_space(S)); DomainMap[EntryBB] = S; if (IsOnlyNonAffineRegion) return !containsErrorBlock(R->getNode(), *R, LI, DT); - if (!buildDomainsWithBranchConstraints(R, DT, LI)) + if (!buildDomainsWithBranchConstraints(R, DT, LI, InvalidDomainMap)) return false; - if (!propagateDomainConstraints(R, DT, LI)) + if (!propagateDomainConstraints(R, DT, LI, InvalidDomainMap)) return false; // Error blocks and blocks dominated by them have been assumed to never be @@ -2647,9 +2661,13 @@ // with an empty set. Additionally, we will record for each block under which // parameter combination it would be reached via an error block in its // InvalidDomain. This information is needed during load hoisting. - if (!propagateInvalidStmtDomains(R, DT, LI)) + if (!propagateInvalidStmtDomains(R, DT, LI, InvalidDomainMap)) return false; + // Initialize the invalid domain. + for (ScopStmt &Stmt : Stmts) + Stmt.setInvalidDomain(InvalidDomainMap[Stmt.getEntryBlock()]); + return true; } @@ -2703,8 +2721,10 @@ return Dom; } -bool Scop::propagateInvalidStmtDomains(Region *R, DominatorTree &DT, - LoopInfo &LI) { +bool Scop::propagateInvalidStmtDomains( + Region *R, DominatorTree &DT, LoopInfo &LI, + DenseMap &InvalidDomainMap) { + ReversePostOrderTraversal RTraversal(R); for (auto *RN : RTraversal) { @@ -2713,18 +2733,17 @@ if (RN->isSubRegion()) { Region *SubRegion = RN->getNodeAs(); if (!isNonAffineSubRegion(SubRegion)) { - propagateInvalidStmtDomains(SubRegion, DT, LI); + propagateInvalidStmtDomains(SubRegion, DT, LI, InvalidDomainMap); continue; } } bool ContainsErrorBlock = containsErrorBlock(RN, getRegion(), LI, DT); BasicBlock *BB = getRegionNodeBasicBlock(RN); - ScopStmt *Stmt = getStmtFor(BB); isl_set *&Domain = DomainMap[BB]; assert(Domain && "Cannot propagate a nullptr"); - auto *InvalidDomain = Stmt->getInvalidDomain(); + auto *InvalidDomain = InvalidDomainMap[BB]; bool IsInvalidBlock = ContainsErrorBlock || isl_set_is_subset(Domain, InvalidDomain); @@ -2740,7 +2759,7 @@ } if (isl_set_is_empty(InvalidDomain)) { - Stmt->setInvalidDomain(InvalidDomain); + InvalidDomainMap[BB] = InvalidDomain; continue; } @@ -2749,25 +2768,28 @@ unsigned NumSuccs = RN->isSubRegion() ? 1 : TI->getNumSuccessors(); for (unsigned u = 0; u < NumSuccs; u++) { auto *SuccBB = getRegionNodeSuccessor(RN, TI, u); - auto *SuccStmt = getStmtFor(SuccBB); // Skip successors outside the SCoP. - if (!SuccStmt) + if (!contains(SuccBB)) continue; // Skip backedges. if (DT.dominates(SuccBB, BB)) continue; - auto *SuccBBLoop = SuccStmt->getSurroundingLoop(); + auto *SuccBBLoop = LI.getLoopFor(SuccBB); + auto &BoxedLoops = getBoxedLoops(); + while (BoxedLoops.count(SuccBBLoop)) + SuccBBLoop = SuccBBLoop->getParentLoop(); + auto *AdjustedInvalidDomain = adjustDomainDimensions( *this, isl_set_copy(InvalidDomain), BBLoop, SuccBBLoop); - auto *SuccInvalidDomain = SuccStmt->getInvalidDomain(); + auto *SuccInvalidDomain = InvalidDomainMap[SuccBB]; SuccInvalidDomain = isl_set_union(SuccInvalidDomain, AdjustedInvalidDomain); SuccInvalidDomain = isl_set_coalesce(SuccInvalidDomain); unsigned NumConjucts = isl_set_n_basic_set(SuccInvalidDomain); - SuccStmt->setInvalidDomain(SuccInvalidDomain); + InvalidDomainMap[SuccBB] = SuccInvalidDomain; // Check if the maximal number of domain disjunctions was reached. // In case this happens we will bail. @@ -2778,16 +2800,15 @@ invalidate(COMPLEXITY, TI->getDebugLoc()); return false; } - - Stmt->setInvalidDomain(InvalidDomain); + InvalidDomainMap[BB] = InvalidDomain; } - return true; } void Scop::propagateDomainConstraintsToRegionExit( BasicBlock *BB, Loop *BBLoop, - SmallPtrSetImpl &FinishedExitBlocks, LoopInfo &LI) { + SmallPtrSetImpl &FinishedExitBlocks, LoopInfo &LI, + DenseMap &InvalidDomainMap) { // Check if the block @p BB is the entry of a region. If so we propagate it's // domain to the exit block of the region. Otherwise we are done. @@ -2812,8 +2833,10 @@ auto *Domain = DomainMap[BB]; assert(Domain && "Cannot propagate a nullptr"); - auto *ExitStmt = getStmtFor(ExitBB); - auto *ExitBBLoop = ExitStmt->getSurroundingLoop(); + auto *ExitBBLoop = LI.getLoopFor(ExitBB); + auto &BoxedLoops = getBoxedLoops(); + while (BoxedLoops.count(ExitBBLoop)) + ExitBBLoop = ExitBBLoop->getParentLoop(); // Since the dimensions of @p BB and @p ExitBB might be different we have to // adjust the domain before we can propagate it. @@ -2827,13 +2850,15 @@ ExitDomain ? isl_set_union(AdjustedDomain, ExitDomain) : AdjustedDomain; // Initialize the invalid domain. - ExitStmt->setInvalidDomain(isl_set_empty(isl_set_get_space(ExitDomain))); + InvalidDomainMap[ExitBB] = isl_set_empty(isl_set_get_space(ExitDomain)); FinishedExitBlocks.insert(ExitBB); } -bool Scop::buildDomainsWithBranchConstraints(Region *R, DominatorTree &DT, - LoopInfo &LI) { +bool Scop::buildDomainsWithBranchConstraints( + Region *R, DominatorTree &DT, LoopInfo &LI, + DenseMap &InvalidDomainMap) { + // To create the domain for each block in R we iterate over all blocks and // subregions in R and propagate the conditions under which the current region // element is executed. To this end we iterate in reverse post order over R as @@ -2854,7 +2879,8 @@ if (RN->isSubRegion()) { Region *SubRegion = RN->getNodeAs(); if (!isNonAffineSubRegion(SubRegion)) { - if (!buildDomainsWithBranchConstraints(SubRegion, DT, LI)) + if (!buildDomainsWithBranchConstraints(SubRegion, DT, LI, + InvalidDomainMap)) return false; continue; } @@ -2877,7 +2903,8 @@ auto *BBLoop = getRegionNodeLoop(RN, LI); // Propagate the domain from BB directly to blocks that have a superset // domain, at the moment only region exit nodes of regions that start in BB. - propagateDomainConstraintsToRegionExit(BB, BBLoop, FinishedExitBlocks, LI); + propagateDomainConstraintsToRegionExit(BB, BBLoop, FinishedExitBlocks, LI, + InvalidDomainMap); // If all successors of BB have been set a domain through the propagation // above we do not need to build condition sets but can just skip this @@ -2897,8 +2924,8 @@ SmallVector ConditionSets; if (RN->isSubRegion()) ConditionSets.push_back(isl_set_copy(Domain)); - else if (!buildConditionSets(*getStmtFor(BB), TI, BBLoop, Domain, - ConditionSets)) + else if (!buildConditionSets(*this, BB, TI, BBLoop, Domain, + InvalidDomainMap, ConditionSets)) return false; // Now iterate over the successors and set their initial domain based on @@ -2910,9 +2937,8 @@ isl_set *CondSet = ConditionSets[u]; BasicBlock *SuccBB = getRegionNodeSuccessor(RN, TI, u); - auto *SuccStmt = getStmtFor(SuccBB); // Skip blocks outside the region. - if (!SuccStmt) { + if (!contains(SuccBB)) { isl_set_free(CondSet); continue; } @@ -2930,7 +2956,11 @@ continue; } - auto *SuccBBLoop = SuccStmt->getSurroundingLoop(); + auto *SuccBBLoop = LI.getLoopFor(SuccBB); + auto &BoxedLoops = getBoxedLoops(); + while (BoxedLoops.count(SuccBBLoop)) + SuccBBLoop = SuccBBLoop->getParentLoop(); + CondSet = adjustDomainDimensions(*this, CondSet, BBLoop, SuccBBLoop); // Set the domain for the successor or merge it with an existing domain in @@ -2942,7 +2972,7 @@ SuccDomain = isl_set_coalesce(isl_set_union(SuccDomain, CondSet)); } else { // Initialize the invalid domain. - SuccStmt->setInvalidDomain(isl_set_empty(isl_set_get_space(CondSet))); + InvalidDomainMap[SuccBB] = isl_set_empty(isl_set_get_space(CondSet)); SuccDomain = CondSet; } @@ -2974,7 +3004,10 @@ // The region info of this function. auto &RI = *R.getRegionInfo(); - auto *BBLoop = getStmtFor(BB)->getSurroundingLoop(); + auto *BBLoop = LI.getLoopFor(BB); + auto &BoxedLoops = getBoxedLoops(); + while (BoxedLoops.count(BBLoop)) + BBLoop = BBLoop->getParentLoop(); // A domain to collect all predecessor domains, thus all conditions under // which the block is executed. To this end we start with the empty domain. @@ -3010,7 +3043,11 @@ } auto *PredBBDom = getDomainConditions(PredBB); - auto *PredBBLoop = getStmtFor(PredBB)->getSurroundingLoop(); + auto *PredBBLoop = LI.getLoopFor(PredBB); + auto &BoxedLoops = getBoxedLoops(); + while (BoxedLoops.count(PredBBLoop)) + PredBBLoop = PredBBLoop->getParentLoop(); + PredBBDom = adjustDomainDimensions(*this, PredBBDom, PredBBLoop, BBLoop); PredDom = isl_set_union(PredDom, PredBBDom); @@ -3019,8 +3056,9 @@ return PredDom; } -bool Scop::propagateDomainConstraints(Region *R, DominatorTree &DT, - LoopInfo &LI) { +bool Scop::propagateDomainConstraints( + Region *R, DominatorTree &DT, LoopInfo &LI, + DenseMap &InvalidDomainMap) { // Iterate over the region R and propagate the domain constrains from the // predecessors to the current node. In contrast to the // buildDomainsWithBranchConstraints function, this one will pull the domain @@ -3038,7 +3076,7 @@ if (RN->isSubRegion()) { Region *SubRegion = RN->getNodeAs(); if (!isNonAffineSubRegion(SubRegion)) { - if (!propagateDomainConstraints(SubRegion, DT, LI)) + if (!propagateDomainConstraints(SubRegion, DT, LI, InvalidDomainMap)) return false; continue; } @@ -3055,7 +3093,7 @@ Loop *BBLoop = getRegionNodeLoop(RN, LI); if (BBLoop && BBLoop->getHeader() == BB && contains(BBLoop)) - if (!addLoopBoundsToHeaderDomain(BBLoop, LI)) + if (!addLoopBoundsToHeaderDomain(BBLoop, LI, InvalidDomainMap)) return false; } @@ -3085,7 +3123,9 @@ return NextIterationMap; } -bool Scop::addLoopBoundsToHeaderDomain(Loop *L, LoopInfo &LI) { +bool Scop::addLoopBoundsToHeaderDomain( + Loop *L, LoopInfo &LI, + DenseMap &InvalidDomainMap) { int LoopDepth = getRelativeLoopDepth(L); assert(LoopDepth >= 0 && "Loop in region should have at least depth one"); @@ -3120,8 +3160,8 @@ else { SmallVector ConditionSets; int idx = BI->getSuccessor(0) != HeaderBB; - if (!buildConditionSets(*getStmtFor(LatchBB), TI, L, LatchBBDom, - ConditionSets)) { + if (!buildConditionSets(*this, LatchBB, TI, L, LatchBBDom, + InvalidDomainMap, ConditionSets)) { isl_map_free(NextIterationMap); isl_set_free(UnionBackedgeCondition); return false;