[PATCH] D78133: [PredicateInfo] Set OriginalOp to the renamed value it refers to (WIP).
    Florian Hahn via Phabricator via llvm-commits 
    llvm-commits at lists.llvm.org
       
    Wed Jun  3 13:11:10 PDT 2020
    
    
  
fhahn updated this revision to Diff 268282.
fhahn added a comment.
Update to add option to set OriginalOp to the renamed value it refers to. I will update the description shortly.
Repository:
  rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D78133/new/
https://reviews.llvm.org/D78133
Files:
  llvm/include/llvm/Transforms/Utils/PredicateInfo.h
  llvm/lib/Transforms/Utils/PredicateInfo.cpp
Index: llvm/lib/Transforms/Utils/PredicateInfo.cpp
===================================================================
--- llvm/lib/Transforms/Utils/PredicateInfo.cpp
+++ llvm/lib/Transforms/Utils/PredicateInfo.cpp
@@ -270,6 +270,11 @@
   // edges.
   DenseSet<std::pair<BasicBlock *, BasicBlock *>> EdgeUsesOnly;
 
+  // If set to true, the directly renamed value is used as OriginalOp, rather
+  // than the original IR value that has been renamed. This is only relevant for
+  // nested predicates of the same value.
+  bool UseDirectRenamedValue;
+
   ValueInfo &getOrCreateValueInfo(Value *);
   const ValueInfo &getValueInfo(Value *) const;
 
@@ -291,8 +296,9 @@
 
 public:
   PredicateInfoBuilder(PredicateInfo &PI, Function &F, DominatorTree &DT,
-                       AssumptionCache &AC)
-      : PI(PI), F(F), DT(DT), AC(AC) {
+                       AssumptionCache &AC, bool UseDirectRenamedValue)
+      : PI(PI), F(F), DT(DT), AC(AC),
+        UseDirectRenamedValue(UseDirectRenamedValue) {
     // Push an empty operand info so that we can detect 0 as not finding one
     ValueInfos.resize(1);
   }
@@ -599,6 +605,11 @@
         RenameIter == RenameStack.begin() ? OrigOp : (RenameIter - 1)->Def;
     ValueDFS &Result = *RenameIter;
     auto *ValInfo = Result.PInfo;
+    // Update OriginalOp to latest entry on the rename stack.
+    if (UseDirectRenamedValue)
+      ValInfo->OriginalOp = (RenameStack.end() - Start) == RenameStack.begin()
+                                ? OrigOp
+                                : (RenameStack.end() - Start - 1)->Def;
     // For edge predicates, we can just place the operand in the block before
     // the terminator.  For assume, we have to place it right before the assume
     // to ensure we dominate all of our uses.  Always insert right before the
@@ -793,9 +804,9 @@
 }
 
 PredicateInfo::PredicateInfo(Function &F, DominatorTree &DT,
-                             AssumptionCache &AC)
+                             AssumptionCache &AC, bool UseDirectRenamedValue)
     : F(F) {
-  PredicateInfoBuilder Builder(*this, F, DT, AC);
+  PredicateInfoBuilder Builder(*this, F, DT, AC, UseDirectRenamedValue);
   Builder.buildPredicateInfo();
 }
 
Index: llvm/include/llvm/Transforms/Utils/PredicateInfo.h
===================================================================
--- llvm/include/llvm/Transforms/Utils/PredicateInfo.h
+++ llvm/include/llvm/Transforms/Utils/PredicateInfo.h
@@ -169,7 +169,8 @@
 /// accesses.
 class PredicateInfo {
 public:
-  PredicateInfo(Function &, DominatorTree &, AssumptionCache &);
+  PredicateInfo(Function &, DominatorTree &, AssumptionCache &,
+                bool UseDirectRenamedValue = false);
   ~PredicateInfo();
 
   void verifyPredicateInfo() const;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D78133.268282.patch
Type: text/x-patch
Size: 2759 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20200603/69a88347/attachment.bin>
    
    
More information about the llvm-commits
mailing list