summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Analysis/AliasAnalysisEvaluator.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-07-17 06:28:49 +0000
committerChris Lattner <sabre@nondot.org>2004-07-17 06:28:49 +0000
commiteed1a6f3dc3b419044dc0b5abc108164639b95ad (patch)
tree6a27cc5fe438b15ea801d2067d09cfdeda425f12 /llvm/lib/Analysis/AliasAnalysisEvaluator.cpp
parent1dd789d775da1637446d74bc488f0836272c34ea (diff)
downloadbcm5719-llvm-eed1a6f3dc3b419044dc0b5abc108164639b95ad.tar.gz
bcm5719-llvm-eed1a6f3dc3b419044dc0b5abc108164639b95ad.zip
Cleanups: fold two loops into one
New features: -print-all-alias-modref-info option, print more info llvm-svn: 14906
Diffstat (limited to 'llvm/lib/Analysis/AliasAnalysisEvaluator.cpp')
-rw-r--r--llvm/lib/Analysis/AliasAnalysisEvaluator.cpp12
1 files changed, 9 insertions, 3 deletions
diff --git a/llvm/lib/Analysis/AliasAnalysisEvaluator.cpp b/llvm/lib/Analysis/AliasAnalysisEvaluator.cpp
index e5ac43658b1..f30ea43096d 100644
--- a/llvm/lib/Analysis/AliasAnalysisEvaluator.cpp
+++ b/llvm/lib/Analysis/AliasAnalysisEvaluator.cpp
@@ -32,6 +32,8 @@
using namespace llvm;
namespace {
+ cl::opt<bool> PrintAll("print-all-alias-modref-info", cl::ReallyHidden);
+
cl::opt<bool> PrintNoAlias("print-no-aliases", cl::ReallyHidden);
cl::opt<bool> PrintMayAlias("print-may-aliases", cl::ReallyHidden);
cl::opt<bool> PrintMustAlias("print-must-aliases", cl::ReallyHidden);
@@ -54,6 +56,11 @@ namespace {
bool doInitialization(Module &M) {
NoAlias = MayAlias = MustAlias = 0;
NoModRef = Mod = Ref = ModRef = 0;
+
+ if (PrintAll) {
+ PrintNoAlias = PrintMayAlias = PrintMustAlias = true;
+ PrintNoModRef = PrintMod = PrintRef = PrintModRef = true;
+ }
return false;
}
@@ -90,16 +97,15 @@ bool AAEval::runOnFunction(Function &F) {
for (User::op_iterator OI = (*I).op_begin(); OI != (*I).op_end(); ++OI)
if (isa<PointerType>((*OI)->getType()))
Pointers.insert(*OI);
- }
- for (inst_iterator I = inst_begin(F), E = inst_end(F); I != E; ++I) {
CallSite CS = CallSite::get(&*I);
if (CS.getInstruction()) CallSites.insert(CS);
}
if (PrintNoAlias || PrintMayAlias || PrintMustAlias ||
PrintNoModRef || PrintMod || PrintRef || PrintModRef)
- std::cerr << "Function: " << F.getName() << "\n";
+ std::cerr << "Function: " << F.getName() << ": " << Pointers.size()
+ << " pointers, " << CallSites.size() << " call sites\n";
// iterate over the worklist, and run the full (n^2)/2 disambiguations
for (std::set<Value *>::iterator I1 = Pointers.begin(), E = Pointers.end();
OpenPOWER on IntegriCloud