Add prototype for the PiNodeInserter pass
authorChris Lattner <sabre@nondot.org>
Fri, 10 May 2002 05:40:37 +0000 (05:40 +0000)
committerChris Lattner <sabre@nondot.org>
Fri, 10 May 2002 05:40:37 +0000 (05:40 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2592 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/Transforms/Scalar.h

index ba8b90ca47dc70f9f045d03909ec7a7df207fed9..b649deec1089b0960f1034ef01a83234ace20747 100644 (file)
@@ -96,6 +96,29 @@ Pass *createIndVarSimplifyPass();
 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