[LLVMdev] Patch for transform dependencies
Domagoj Babic
babic.domagoj at gmail.com
Wed May 3 11:11:25 PDT 2006
Hi,
A number of transforms are actually independent, so here's a partial fix. I
updated the
dependencies in a cluster of transforms: LowerSwitch, Mem2Reg, LowerSelect,
LowerAllocations, UnifyFunctionExitNodes.
The patch has been tested, but not extensively. PassManager doesn't
complain, and
the result of a test pass that requires all these (except for
LowerAllocations) together
works fine.
Domagoj
***************************** PATCH BEGIN
**********************************************
Index: ./lib/Transforms/Scalar/LowerSwitch.cpp
===================================================================
RCS file: /var/cvs/llvm/llvm/lib/Transforms/Scalar/LowerSwitch.cpp,v
retrieving revision 1.19
diff -u -p -r1.19 LowerSwitch.cpp
--- ./lib/Transforms/Scalar/LowerSwitch.cpp 2 May 2006 04:24:36
-0000 1.19
+++ ./lib/Transforms/Scalar/LowerSwitch.cpp 3 May 2006 18:01:53 -0000
@@ -14,6 +14,7 @@
//===----------------------------------------------------------------------===//
#include "llvm/Transforms/Scalar.h"
+#include "llvm/Transforms/Utils/UnifyFunctionExitNodes.h"
#include "llvm/Constants.h"
#include "llvm/Function.h"
#include "llvm/Instructions.h"
@@ -32,7 +33,15 @@ namespace {
/// modifies the CFG!
class LowerSwitch : public FunctionPass {
public:
- bool runOnFunction(Function &F);
+ virtual bool runOnFunction(Function &F);
+
+ virtual void getAnalysisUsage(AnalysisUsage &AU) const {
+ // This is a cluster of orthogonal Transforms
+ AU.addPreserved<UnifyFunctionExitNodes>();
+ AU.addPreservedID(PromoteMemoryToRegisterID);
+ AU.addPreservedID(LowerSelectID);
+ }
+
typedef std::pair<Constant*, BasicBlock*> Case;
typedef std::vector<Case>::iterator CaseItr;
private:
Index: ./lib/Transforms/Scalar/Mem2Reg.cpp
===================================================================
RCS file: /var/cvs/llvm/llvm/lib/Transforms/Scalar/Mem2Reg.cpp,v
retrieving revision 1.15
diff -u -p -r1.15 Mem2Reg.cpp
--- ./lib/Transforms/Scalar/Mem2Reg.cpp 2 May 2006 04:24:36 -0000 1.15
+++ ./lib/Transforms/Scalar/Mem2Reg.cpp 3 May 2006 18:01:53 -0000
@@ -14,6 +14,7 @@
#include "llvm/Transforms/Scalar.h"
#include "llvm/Transforms/Utils/PromoteMemToReg.h"
+#include "llvm/Transforms/Utils/UnifyFunctionExitNodes.h"
#include "llvm/Analysis/Dominators.h"
#include "llvm/Instructions.h"
#include "llvm/Function.h"
@@ -37,6 +38,10 @@ namespace {
AU.addRequired<DominanceFrontier>();
AU.addRequired<TargetData>();
AU.setPreservesCFG();
+ // This is a cluster of orthogonal Transforms
+ AU.addPreserved<UnifyFunctionExitNodes>();
+ AU.addPreservedID(LowerSelectID);
+ AU.addPreservedID(LowerSwitchID);
}
};
Index: ./lib/Transforms/Scalar/LowerSelect.cpp
===================================================================
RCS file: /var/cvs/llvm/llvm/lib/Transforms/Scalar/LowerSelect.cpp,v
retrieving revision 1.4
diff -u -p -r1.4 LowerSelect.cpp
--- ./lib/Transforms/Scalar/LowerSelect.cpp 2 May 2006 04:24:36
-0000 1.4
+++ ./lib/Transforms/Scalar/LowerSelect.cpp 3 May 2006 18:01:53 -0000
@@ -19,6 +19,7 @@
//===----------------------------------------------------------------------===//
#include "llvm/Transforms/Scalar.h"
+#include "llvm/Transforms/Utils/UnifyFunctionExitNodes.h"
#include "llvm/Function.h"
#include "llvm/Instructions.h"
#include "llvm/Pass.h"
@@ -38,6 +39,12 @@ namespace {
virtual void getAnalysisUsage(AnalysisUsage &AU) const {
// Doesn't really preserve anything. It can certainly destroy the
CFG.
+ // But it preserves some Transforms.
+
+ // This is a cluster of orthogonal Transforms:
+ AU.addPreserved<UnifyFunctionExitNodes>();
+ AU.addPreservedID(PromoteMemoryToRegisterID);
+ AU.addPreservedID(LowerSwitchID);
}
bool runOnFunction(Function &F);
Index: ./lib/Transforms/Scalar/LowerAllocations.cpp
===================================================================
RCS file: /var/cvs/llvm/llvm/lib/Transforms/Scalar/LowerAllocations.cpp,v
retrieving revision 1.56
diff -u -p -r1.56 LowerAllocations.cpp
--- ./lib/Transforms/Scalar/LowerAllocations.cpp 2 May 2006 04:24:36
-0000 1.56
+++ ./lib/Transforms/Scalar/LowerAllocations.cpp 3 May 2006 18:01:53
-0000
@@ -13,6 +13,7 @@
//===----------------------------------------------------------------------===//
#include "llvm/Transforms/Scalar.h"
+#include "llvm/Transforms/Utils/UnifyFunctionExitNodes.h"
#include "llvm/Module.h"
#include "llvm/DerivedTypes.h"
#include "llvm/Instructions.h"
@@ -39,6 +40,12 @@ namespace {
virtual void getAnalysisUsage(AnalysisUsage &AU) const {
AU.addRequired<TargetData>();
AU.setPreservesCFG();
+
+ // This is a cluster of orthogonal Transforms:
+ AU.addPreserved<UnifyFunctionExitNodes>();
+ AU.addPreservedID(PromoteMemoryToRegisterID);
+ AU.addPreservedID(LowerSelectID);
+ AU.addPreservedID(LowerSwitchID);
}
/// doPassInitialization - For the lower allocations pass, this ensures
that
Index: ./lib/Transforms/Utils/UnifyFunctionExitNodes.cpp
===================================================================
RCS file:
/var/cvs/llvm/llvm/lib/Transforms/Utils/UnifyFunctionExitNodes.cpp,v
retrieving revision 1.33
diff -u -p -r1.33 UnifyFunctionExitNodes.cpp
--- ./lib/Transforms/Utils/UnifyFunctionExitNodes.cpp 21 Apr 2005 23:45:34
-0000 1.33
+++ ./lib/Transforms/Utils/UnifyFunctionExitNodes.cpp 3 May 2006 18:01:53
-0000
@@ -32,6 +32,10 @@ Pass *llvm::createUnifyFunctionExitNodes
void UnifyFunctionExitNodes::getAnalysisUsage(AnalysisUsage &AU) const{
// We preserve the non-critical-edgeness property
AU.addPreservedID(BreakCriticalEdgesID);
+ // This is a cluster of orthogonal Transforms
+ AU.addPreservedID(PromoteMemoryToRegisterID);
+ AU.addPreservedID(LowerSelectID);
+ AU.addPreservedID(LowerSwitchID);
}
// UnifyAllExitNodes - Unify all exit nodes of the CFG by creating a new
***************************** PATCH END
**********************************************
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20060503/cf312149/attachment.html>
More information about the llvm-dev
mailing list