summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2010-10-18 18:50:27 +0000
committerDan Gohman <gohman@apple.com>2010-10-18 18:50:27 +0000
commit52dacc0d7f392c7066d3bac0f6ca83288e1227eb (patch)
tree7839bec86ac7d18cd14f9464b87b8318a780a307
parentf7a5e20372fa4fea5d95bfad60088b8274008f24 (diff)
downloadbcm5719-llvm-52dacc0d7f392c7066d3bac0f6ca83288e1227eb.tar.gz
bcm5719-llvm-52dacc0d7f392c7066d3bac0f6ca83288e1227eb.zip
Add TypeBasedAliasAnalysis to the standard pass lists. Note that it
is currently inert by default. llvm-svn: 116732
-rw-r--r--llvm/include/llvm/Support/StandardPasses.h14
-rw-r--r--llvm/lib/CodeGen/LLVMTargetMachine.cpp4
2 files changed, 13 insertions, 5 deletions
diff --git a/llvm/include/llvm/Support/StandardPasses.h b/llvm/include/llvm/Support/StandardPasses.h
index deee00e686a..a608f2ceaba 100644
--- a/llvm/include/llvm/Support/StandardPasses.h
+++ b/llvm/include/llvm/Support/StandardPasses.h
@@ -69,10 +69,18 @@ namespace llvm {
// Implementations
+ static inline void createStandardAliasAnalysisPasses(PassManagerBase *PM) {
+ // Add TypeBasedAliasAnalysis before BasicAliasAnalysis so that
+ // BasicAliasAnalysis wins if they disagree. This is intended to help
+ // support "obvious" type-punning idioms.
+ PM->add(createTypeBasedAliasAnalysisPass());
+ PM->add(createBasicAliasAnalysisPass());
+ }
+
static inline void createStandardFunctionPasses(PassManagerBase *PM,
unsigned OptimizationLevel) {
if (OptimizationLevel > 0) {
- PM->add(createBasicAliasAnalysisPass());
+ createStandardAliasAnalysisPasses(PM);
PM->add(createCFGSimplificationPass());
if (OptimizationLevel == 1)
PM->add(createPromoteMemoryToRegisterPass());
@@ -92,7 +100,7 @@ namespace llvm {
bool SimplifyLibCalls,
bool HaveExceptions,
Pass *InliningPass) {
- PM->add(createBasicAliasAnalysisPass());
+ createStandardAliasAnalysisPasses(PM);
if (OptimizationLevel == 0) {
if (InliningPass)
@@ -181,7 +189,7 @@ namespace llvm {
bool RunInliner,
bool VerifyEach) {
// Provide AliasAnalysis services for optimizations.
- PM->add(createBasicAliasAnalysisPass());
+ createStandardAliasAnalysisPasses(PM);
// Now that composite has been compiled, scan through the module, looking
// for a main function. If main is defined, mark all other functions
diff --git a/llvm/lib/CodeGen/LLVMTargetMachine.cpp b/llvm/lib/CodeGen/LLVMTargetMachine.cpp
index a3b605238ab..60aa1e5c984 100644
--- a/llvm/lib/CodeGen/LLVMTargetMachine.cpp
+++ b/llvm/lib/CodeGen/LLVMTargetMachine.cpp
@@ -14,7 +14,6 @@
#include "llvm/Target/TargetMachine.h"
#include "llvm/PassManager.h"
#include "llvm/Analysis/Verifier.h"
-#include "llvm/Analysis/Passes.h"
#include "llvm/Assembly/PrintModulePass.h"
#include "llvm/CodeGen/AsmPrinter.h"
#include "llvm/CodeGen/MachineFunctionAnalysis.h"
@@ -31,6 +30,7 @@
#include "llvm/Support/CommandLine.h"
#include "llvm/Support/Debug.h"
#include "llvm/Support/FormattedStream.h"
+#include "llvm/Support/StandardPasses.h"
using namespace llvm;
namespace llvm {
@@ -256,7 +256,7 @@ bool LLVMTargetMachine::addCommonCodeGenPasses(PassManagerBase &PM,
// Standard LLVM-Level Passes.
// Basic AliasAnalysis support.
- PM.add(createBasicAliasAnalysisPass());
+ createStandardAliasAnalysisPasses(&PM);
// Before running any passes, run the verifier to determine if the input
// coming from the front-end and/or optimizer is valid.
OpenPOWER on IntegriCloud