diff options
| author | Chandler Carruth <chandlerc@gmail.com> | 2014-03-09 03:16:01 +0000 | 
|---|---|---|
| committer | Chandler Carruth <chandlerc@gmail.com> | 2014-03-09 03:16:01 +0000 | 
| commit | cdf4788401afff02e12279fc1fded94d6180639c (patch) | |
| tree | 4b7b22b5e5b9ee152848a85ca3a911566532ecef /llvm/lib/Transforms/Scalar/LICM.cpp | |
| parent | c980afc578f9c1af3b8916b4a503ea26ebaee018 (diff) | |
| download | bcm5719-llvm-cdf4788401afff02e12279fc1fded94d6180639c.tar.gz bcm5719-llvm-cdf4788401afff02e12279fc1fded94d6180639c.zip | |
[C++11] Add range based accessors for the Use-Def chain of a Value.
This requires a number of steps.
1) Move value_use_iterator into the Value class as an implementation
   detail
2) Change it to actually be a *Use* iterator rather than a *User*
   iterator.
3) Add an adaptor which is a User iterator that always looks through the
   Use to the User.
4) Wrap these in Value::use_iterator and Value::user_iterator typedefs.
5) Add the range adaptors as Value::uses() and Value::users().
6) Update *all* of the callers to correctly distinguish between whether
   they wanted a use_iterator (and to explicitly dig out the User when
   needed), or a user_iterator which makes the Use itself totally
   opaque.
Because #6 requires churning essentially everything that walked the
Use-Def chains, I went ahead and added all of the range adaptors and
switched them to range-based loops where appropriate. Also because the
renaming requires at least churning every line of code, it didn't make
any sense to split these up into multiple commits -- all of which would
touch all of the same lies of code.
The result is still not quite optimal. The Value::use_iterator is a nice
regular iterator, but Value::user_iterator is an iterator over User*s
rather than over the User objects themselves. As a consequence, it fits
a bit awkwardly into the range-based world and it has the weird
extra-dereferencing 'operator->' that so many of our iterators have.
I think this could be fixed by providing something which transforms
a range of T&s into a range of T*s, but that *can* be separated into
another patch, and it isn't yet 100% clear whether this is the right
move.
However, this change gets us most of the benefit and cleans up
a substantial amount of code around Use and User. =]
llvm-svn: 203364
Diffstat (limited to 'llvm/lib/Transforms/Scalar/LICM.cpp')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/LICM.cpp | 35 | 
1 files changed, 17 insertions, 18 deletions
| diff --git a/llvm/lib/Transforms/Scalar/LICM.cpp b/llvm/lib/Transforms/Scalar/LICM.cpp index 354131f374b..b69f2dc5829 100644 --- a/llvm/lib/Transforms/Scalar/LICM.cpp +++ b/llvm/lib/Transforms/Scalar/LICM.cpp @@ -500,9 +500,9 @@ static bool isTriviallyReplacablePHI(PHINode &PN, Instruction &I) {  /// exit blocks of the loop.  ///  bool LICM::isNotUsedInLoop(Instruction &I) { -  for (Value::use_iterator UI = I.use_begin(), E = I.use_end(); UI != E; ++UI) { -    Instruction *User = cast<Instruction>(*UI); -    if (PHINode *PN = dyn_cast<PHINode>(User)) { +  for (User *U : I.users()) { +    Instruction *UI = cast<Instruction>(U); +    if (PHINode *PN = dyn_cast<PHINode>(UI)) {        // A PHI node where all of the incoming values are this instruction are        // special -- they can just be RAUW'ed with the instruction and thus        // don't require a use in the predecessor. This is a particular important @@ -524,7 +524,7 @@ bool LICM::isNotUsedInLoop(Instruction &I) {        continue;      } -    if (CurLoop->contains(User)) +    if (CurLoop->contains(UI))        return false;    }    return true; @@ -554,7 +554,7 @@ void LICM::sink(Instruction &I) {    // the instruction.    while (!I.use_empty()) {      // The user must be a PHI node. -    PHINode *PN = cast<PHINode>(I.use_back()); +    PHINode *PN = cast<PHINode>(I.user_back());      BasicBlock *ExitBlock = PN->getParent();      assert(ExitBlockSet.count(ExitBlock) && @@ -789,23 +789,22 @@ void LICM::PromoteAliasSet(AliasSet &AS,      if (SomePtr->getType() != ASIV->getType())        return; -    for (Value::use_iterator UI = ASIV->use_begin(), UE = ASIV->use_end(); -         UI != UE; ++UI) { +    for (User *U : ASIV->users()) {        // Ignore instructions that are outside the loop. -      Instruction *Use = dyn_cast<Instruction>(*UI); -      if (!Use || !CurLoop->contains(Use)) +      Instruction *UI = dyn_cast<Instruction>(U); +      if (!UI || !CurLoop->contains(UI))          continue;        // If there is an non-load/store instruction in the loop, we can't promote        // it. -      if (LoadInst *load = dyn_cast<LoadInst>(Use)) { +      if (LoadInst *load = dyn_cast<LoadInst>(UI)) {          assert(!load->isVolatile() && "AST broken");          if (!load->isSimple())            return; -      } else if (StoreInst *store = dyn_cast<StoreInst>(Use)) { +      } else if (StoreInst *store = dyn_cast<StoreInst>(UI)) {          // Stores *of* the pointer are not interesting, only stores *to* the          // pointer. -        if (Use->getOperand(1) != ASIV) +        if (UI->getOperand(1) != ASIV)            continue;          assert(!store->isVolatile() && "AST broken");          if (!store->isSimple()) @@ -821,13 +820,13 @@ void LICM::PromoteAliasSet(AliasSet &AS,          // Larger is better, with the exception of 0 being the best alignment.          unsigned InstAlignment = store->getAlignment();          if ((InstAlignment > Alignment || InstAlignment == 0) && Alignment != 0) -          if (isGuaranteedToExecute(*Use)) { +          if (isGuaranteedToExecute(*UI)) {              GuaranteedToExecute = true;              Alignment = InstAlignment;            }          if (!GuaranteedToExecute) -          GuaranteedToExecute = isGuaranteedToExecute(*Use); +          GuaranteedToExecute = isGuaranteedToExecute(*UI);        } else          return; // Not a load or store. @@ -835,13 +834,13 @@ void LICM::PromoteAliasSet(AliasSet &AS,        // Merge the TBAA tags.        if (LoopUses.empty()) {          // On the first load/store, just take its TBAA tag. -        TBAATag = Use->getMetadata(LLVMContext::MD_tbaa); +        TBAATag = UI->getMetadata(LLVMContext::MD_tbaa);        } else if (TBAATag) {          TBAATag = MDNode::getMostGenericTBAA(TBAATag, -                                       Use->getMetadata(LLVMContext::MD_tbaa)); +                                       UI->getMetadata(LLVMContext::MD_tbaa));        } -       -      LoopUses.push_back(Use); + +      LoopUses.push_back(UI);      }    } | 

