aboutsummaryrefslogtreecommitdiffstats
path: root/include/llvm/Transforms
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2002-05-10 05:40:37 +0000
committerChris Lattner <sabre@nondot.org>2002-05-10 05:40:37 +0000
commit531823f125af948098ef5e1131bf54ce287fb553 (patch)
tree122f2467051723f96fa724e7f1a67936ee122651 /include/llvm/Transforms
parent38fc13149ce3b1d6d398013c03da84e7b8df992a (diff)
downloadexternal_llvm-531823f125af948098ef5e1131bf54ce287fb553.zip
external_llvm-531823f125af948098ef5e1131bf54ce287fb553.tar.gz
external_llvm-531823f125af948098ef5e1131bf54ce287fb553.tar.bz2
Add prototype for the PiNodeInserter pass
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2592 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/Transforms')
-rw-r--r--include/llvm/Transforms/Scalar.h23
1 files changed, 23 insertions, 0 deletions
diff --git a/include/llvm/Transforms/Scalar.h b/include/llvm/Transforms/Scalar.h
index ba8b90c..b649dee 100644
--- a/include/llvm/Transforms/Scalar.h
+++ b/include/llvm/Transforms/Scalar.h
@@ -98,6 +98,29 @@ Pass *createInstructionCombiningPass();
//===----------------------------------------------------------------------===//
//
+// PiNodeInsertion - This pass inserts single entry Phi nodes into basic blocks
+// that are preceeded by a conditional branch, where the branch gives
+// information about the operands of the condition. For example, this C code:
+// if (x == 0) { ... = x + 4;
+// becomes:
+// if (x == 0) {
+// x2 = phi(x); // Node that can hold data flow information about X
+// ... = x2 + 4;
+//
+// Since the direction of the condition branch gives information about X itself
+// (whether or not it is zero), some passes (like value numbering or ABCD) can
+// use the inserted Phi/Pi nodes as a place to attach information, in this case
+// saying that X has a value of 0 in this scope. The power of this analysis
+// information is that "in the scope" translates to "for all uses of x2".
+//
+// This special form of Phi node is refered to as a Pi node, following the
+// terminology defined in the "Array Bounds Checks on Demand" paper.
+//
+Pass *createPiNodeInsertionPass();
+
+
+//===----------------------------------------------------------------------===//
+//
// This pass is used to promote memory references to be register references. A
// simple example of the transformation performed by this pass is:
//