[llvm-commits] CVS: llvm/include/llvm/Analysis/LinkAllAnalyses.h

Chris Lattner lattner at cs.uiuc.edu
Sun Oct 23 18:00:00 PDT 2005



Changes in directory llvm/include/llvm/Analysis:

LinkAllAnalyses.h added (r1.1)
---
Log message:

new header


---
Diffs of the changes:  (+64 -0)

 LinkAllAnalyses.h |   64 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 64 insertions(+)


Index: llvm/include/llvm/Analysis/LinkAllAnalyses.h
diff -c /dev/null llvm/include/llvm/Analysis/LinkAllAnalyses.h:1.1
*** /dev/null	Sun Oct 23 19:59:59 2005
--- llvm/include/llvm/Analysis/LinkAllAnalyses.h	Sun Oct 23 19:59:49 2005
***************
*** 0 ****
--- 1,64 ----
+ //===- LinkAllAnalyses.h - Reference All Analysis Passes --------*- C++ -*-===//
+ //
+ //                      The LLVM Compiler Infrastructure
+ //
+ // This file was developed by Chris Lattner and is distributed under the
+ // University of Illinois Open Source License. See LICENSE.TXT for details.
+ //
+ //===----------------------------------------------------------------------===//
+ //
+ // This header file pulls in all analysis passes for tools like analyze and
+ // bugpoint that need this functionality.
+ //
+ //===----------------------------------------------------------------------===//
+ 
+ #ifndef LLVM_ANALYSIS_LINKALLANALYSES_H
+ #define LLVM_ANALYSIS_LINKALLANALYSES_H
+ 
+ #include "llvm/Analysis/AliasSetTracker.h"
+ #include "llvm/Analysis/CallGraph.h"
+ #include "llvm/Analysis/FindUnsafePointerTypes.h"
+ #include "llvm/Analysis/FindUsedTypes.h"
+ #include "llvm/Analysis/IntervalPartition.h"
+ #include "llvm/Analysis/PostDominators.h"
+ #include "llvm/Analysis/Passes.h"
+ #include "llvm/Analysis/ScalarEvolution.h"
+ #include "llvm/Analysis/DataStructure/DataStructure.h"
+ #include "llvm/Function.h"
+ #include <cstdlib>
+ 
+ namespace {
+   struct ForceAnalysisPassLinking {
+     ForceAnalysisPassLinking() {
+       // We must reference the passes in such a way that compilers will not
+       // delete it all as dead code, even with whole program optimization,
+       // yet is effectively a NO-OP. As the compiler isn't smart enough
+       // to know that getenv() never returns -1, this will do the job.
+       if (std::getenv("bar") != (char*) -1)
+         return;
+ 
+       (void)new llvm::LocalDataStructures();
+       (void)new llvm::BUDataStructures();
+       (void)new llvm::TDDataStructures();
+       (void)new llvm::CompleteBUDataStructures();
+       (void)new llvm::EquivClassGraphs();
+       (void)llvm::createDataStructureStatsPass();
+       (void)llvm::createDataStructureGraphCheckerPass();
+       (void)llvm::createProfileLoaderPass();
+       (void)llvm::createNoProfileInfoPass();
+       (void)llvm::createInstCountPass();
+       (void)new llvm::IntervalPartition();
+       (void)new llvm::ImmediateDominators();
+       (void)new llvm::PostDominatorSet();
+       (void)new llvm::CallGraph();
+       (void)new llvm::FindUsedTypes();
+       (void)new llvm::FindUnsafePointerTypes();
+       (void)new llvm::ScalarEvolution();
+       ((llvm::Function*)0)->viewCFGOnly();
+       llvm::AliasSetTracker X(*(llvm::AliasAnalysis*)0);
+       X.add((llvm::Value*)0, 0);  // for -print-alias-sets
+     }
+   } ForceAnalysisPassLinking;
+ };
+ 
+ #endif






More information about the llvm-commits mailing list