2001-06-30 04:34:07 +00:00
|
|
|
//===-- ConstantProp.h - Functions for Constant Propogation ------*- C++ -*--=//
|
|
|
|
//
|
|
|
|
// This family of functions are useful for performing constant propogation.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLVM_OPT_CONSTANT_PROPOGATION_H
|
|
|
|
#define LLVM_OPT_CONSTANT_PROPOGATION_H
|
|
|
|
|
2001-10-18 01:31:58 +00:00
|
|
|
#include "llvm/Transforms/Pass.h"
|
2001-06-30 04:34:07 +00:00
|
|
|
class TerminatorInst;
|
|
|
|
|
|
|
|
namespace opt {
|
|
|
|
|
2001-10-18 05:21:56 +00:00
|
|
|
struct ConstantPropogation : public Pass {
|
2001-10-18 01:31:58 +00:00
|
|
|
// doConstantPropogation - Do trivial constant propogation and expression
|
|
|
|
// folding
|
|
|
|
static bool doConstantPropogation(Method *M);
|
|
|
|
|
2001-10-18 05:21:56 +00:00
|
|
|
inline bool doPerMethodWork(Method *M) {
|
2001-10-18 01:31:58 +00:00
|
|
|
return doConstantPropogation(M);
|
|
|
|
}
|
|
|
|
};
|
2001-06-30 04:34:07 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// ConstantFoldTerminator - If a terminator instruction is predicated on a
|
|
|
|
// constant value, convert it into an unconditional branch to the constant
|
|
|
|
// destination.
|
|
|
|
//
|
|
|
|
bool ConstantFoldTerminator(TerminatorInst *T);
|
|
|
|
|
|
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Sparse Conditional Constant Propogation Pass
|
|
|
|
//
|
2001-10-18 05:21:56 +00:00
|
|
|
struct SCCPPass : public Pass {
|
2001-10-18 01:31:58 +00:00
|
|
|
static bool doSCCP(Method *M);
|
|
|
|
|
2001-10-18 05:21:56 +00:00
|
|
|
inline bool doPerMethodWork(Method *M) {
|
2001-10-18 01:31:58 +00:00
|
|
|
return doSCCP(M);
|
|
|
|
}
|
|
|
|
};
|
2001-06-30 04:34:07 +00:00
|
|
|
|
|
|
|
} // End Namespace opt
|
|
|
|
|
|
|
|
#endif
|