[LLVMdev] Patch for transform dependencies
    Chris Lattner 
    sabre at nondot.org
       
    Mon May  8 21:14:56 PDT 2006
    
    
  
Applied, thanks:
http://lists.cs.uiuc.edu/pipermail/llvm-commits/Week-of-Mon-20060508/034683.html
http://lists.cs.uiuc.edu/pipermail/llvm-commits/Week-of-Mon-20060508/034684.html
Sorry for the delay.  :(
In the future, please attach the patch to the email (instead of including 
it inline) as it makes it easier to apply and reduces the chance of the 
mail program mangling it.
-Chris
On Wed, 3 May 2006, Domagoj Babic wrote:
> 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
> **********************************************
>
-Chris
-- 
http://nondot.org/sabre/
http://llvm.org/
    
    
More information about the llvm-dev
mailing list