2006-08-21 05:37:03 +00:00
|
|
|
//===- llvm/LinkAllPasses.h ------------ Reference All Passes ---*- C++ -*-===//
|
2005-04-21 20:59:05 +00:00
|
|
|
//
|
2005-01-07 07:46:40 +00:00
|
|
|
// The LLVM Compiler Infrastructure
|
2005-01-06 06:02:53 +00:00
|
|
|
//
|
2007-12-29 19:59:42 +00:00
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
2005-04-21 20:59:05 +00:00
|
|
|
//
|
2005-01-06 06:02:53 +00:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
2006-08-21 05:37:03 +00:00
|
|
|
// This header file pulls in all transformation and analysis passes for tools
|
|
|
|
// like opt and bugpoint that need this functionality.
|
2005-01-06 06:02:53 +00:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2006-08-21 05:34:03 +00:00
|
|
|
#ifndef LLVM_LINKALLPASSES_H
|
|
|
|
#define LLVM_LINKALLPASSES_H
|
2005-01-06 06:02:53 +00:00
|
|
|
|
2006-08-21 05:34:03 +00:00
|
|
|
#include "llvm/Analysis/AliasSetTracker.h"
|
2008-10-12 06:49:21 +00:00
|
|
|
#include "llvm/Analysis/EscapeAnalysis.h"
|
2006-08-21 05:34:03 +00:00
|
|
|
#include "llvm/Analysis/FindUsedTypes.h"
|
|
|
|
#include "llvm/Analysis/IntervalPartition.h"
|
2008-06-30 00:04:21 +00:00
|
|
|
#include "llvm/Analysis/LoopVR.h"
|
2006-08-21 05:34:03 +00:00
|
|
|
#include "llvm/Analysis/Passes.h"
|
|
|
|
#include "llvm/Analysis/PostDominators.h"
|
|
|
|
#include "llvm/Analysis/ScalarEvolution.h"
|
2008-10-21 23:33:38 +00:00
|
|
|
#include "llvm/Assembly/PrintModulePass.h"
|
2005-01-08 18:15:23 +00:00
|
|
|
#include "llvm/CodeGen/Passes.h"
|
2006-08-21 05:34:03 +00:00
|
|
|
#include "llvm/Function.h"
|
2005-01-06 06:02:53 +00:00
|
|
|
#include "llvm/Transforms/Instrumentation.h"
|
|
|
|
#include "llvm/Transforms/IPO.h"
|
|
|
|
#include "llvm/Transforms/Scalar.h"
|
|
|
|
#include "llvm/Transforms/Utils/UnifyFunctionExitNodes.h"
|
2005-10-24 00:08:51 +00:00
|
|
|
#include <cstdlib>
|
2005-01-06 06:02:53 +00:00
|
|
|
|
|
|
|
namespace {
|
2005-01-08 22:01:16 +00:00
|
|
|
struct ForcePassLinking {
|
|
|
|
ForcePassLinking() {
|
2005-10-24 00:08:51 +00:00
|
|
|
// We must reference the passes in such a way that compilers will not
|
2005-01-07 07:44:02 +00:00
|
|
|
// delete it all as dead code, even with whole program optimization,
|
|
|
|
// yet is effectively a NO-OP. As the compiler isn't smart enough
|
2005-10-24 00:08:51 +00:00
|
|
|
// to know that getenv() never returns -1, this will do the job.
|
|
|
|
if (std::getenv("bar") != (char*) -1)
|
2005-01-07 07:44:02 +00:00
|
|
|
return;
|
2005-01-06 06:02:53 +00:00
|
|
|
|
2005-01-08 22:01:16 +00:00
|
|
|
(void) llvm::createAAEvalPass();
|
2005-01-07 07:44:02 +00:00
|
|
|
(void) llvm::createAggressiveDCEPass();
|
2005-01-08 22:01:16 +00:00
|
|
|
(void) llvm::createAliasAnalysisCounterPass();
|
2006-11-14 05:21:04 +00:00
|
|
|
(void) llvm::createAliasDebugger();
|
2005-01-08 22:01:16 +00:00
|
|
|
(void) llvm::createAndersensPass();
|
2005-01-07 07:44:02 +00:00
|
|
|
(void) llvm::createArgumentPromotionPass();
|
2008-03-07 21:07:34 +00:00
|
|
|
(void) llvm::createStructRetPromotionPass();
|
2005-01-08 22:01:16 +00:00
|
|
|
(void) llvm::createBasicAliasAnalysisPass();
|
2008-05-07 19:53:05 +00:00
|
|
|
(void) llvm::createLibCallAliasAnalysisPass(0);
|
2005-01-08 17:21:40 +00:00
|
|
|
(void) llvm::createBlockPlacementPass();
|
2005-01-07 07:44:02 +00:00
|
|
|
(void) llvm::createBlockProfilerPass();
|
|
|
|
(void) llvm::createBreakCriticalEdgesPass();
|
|
|
|
(void) llvm::createCFGSimplificationPass();
|
|
|
|
(void) llvm::createConstantMergePass();
|
|
|
|
(void) llvm::createConstantPropagationPass();
|
|
|
|
(void) llvm::createDeadArgEliminationPass();
|
|
|
|
(void) llvm::createDeadCodeEliminationPass();
|
|
|
|
(void) llvm::createDeadInstEliminationPass();
|
|
|
|
(void) llvm::createDeadStoreEliminationPass();
|
|
|
|
(void) llvm::createDeadTypeEliminationPass();
|
|
|
|
(void) llvm::createEdgeProfilerPass();
|
|
|
|
(void) llvm::createFunctionInliningPass();
|
2008-09-03 20:24:05 +00:00
|
|
|
(void) llvm::createAlwaysInlinerPass();
|
2005-01-07 07:44:02 +00:00
|
|
|
(void) llvm::createFunctionProfilerPass();
|
|
|
|
(void) llvm::createGlobalDCEPass();
|
|
|
|
(void) llvm::createGlobalOptimizerPass();
|
2005-01-08 18:15:23 +00:00
|
|
|
(void) llvm::createGlobalsModRefPass();
|
2007-05-29 23:36:32 +00:00
|
|
|
(void) llvm::createGVNPREPass();
|
2005-01-07 07:44:02 +00:00
|
|
|
(void) llvm::createIPConstantPropagationPass();
|
|
|
|
(void) llvm::createIPSCCPPass();
|
|
|
|
(void) llvm::createIndVarSimplifyPass();
|
|
|
|
(void) llvm::createInstructionCombiningPass();
|
2005-10-19 01:41:47 +00:00
|
|
|
(void) llvm::createInternalizePass(false);
|
2006-05-26 13:58:26 +00:00
|
|
|
(void) llvm::createLCSSAPass();
|
2005-01-07 07:44:02 +00:00
|
|
|
(void) llvm::createLICMPass();
|
2005-01-08 17:21:40 +00:00
|
|
|
(void) llvm::createLoopExtractorPass();
|
2005-01-07 07:44:02 +00:00
|
|
|
(void) llvm::createLoopSimplifyPass();
|
|
|
|
(void) llvm::createLoopStrengthReducePass();
|
|
|
|
(void) llvm::createLoopUnrollPass();
|
|
|
|
(void) llvm::createLoopUnswitchPass();
|
2007-04-07 04:43:02 +00:00
|
|
|
(void) llvm::createLoopRotatePass();
|
2007-08-07 00:25:56 +00:00
|
|
|
(void) llvm::createLoopIndexSplitPass();
|
2005-01-07 07:44:02 +00:00
|
|
|
(void) llvm::createLowerAllocationsPass();
|
|
|
|
(void) llvm::createLowerInvokePass();
|
|
|
|
(void) llvm::createLowerSetJmpPass();
|
|
|
|
(void) llvm::createLowerSwitchPass();
|
2005-01-08 22:01:16 +00:00
|
|
|
(void) llvm::createNoAAPass();
|
|
|
|
(void) llvm::createNoProfileInfoPass();
|
2005-01-10 03:56:27 +00:00
|
|
|
(void) llvm::createProfileLoaderPass();
|
2005-03-28 02:52:28 +00:00
|
|
|
(void) llvm::createPromoteMemoryToRegisterPass();
|
2005-11-10 02:07:45 +00:00
|
|
|
(void) llvm::createDemoteRegisterToMemoryPass();
|
2005-01-07 07:44:02 +00:00
|
|
|
(void) llvm::createPruneEHPass();
|
|
|
|
(void) llvm::createRaiseAllocationsPass();
|
|
|
|
(void) llvm::createReassociatePass();
|
|
|
|
(void) llvm::createSCCPPass();
|
|
|
|
(void) llvm::createScalarReplAggregatesPass();
|
2005-04-26 02:57:49 +00:00
|
|
|
(void) llvm::createSimplifyLibCallsPass();
|
2005-01-07 07:44:02 +00:00
|
|
|
(void) llvm::createSingleLoopExtractorPass();
|
2005-01-08 17:21:40 +00:00
|
|
|
(void) llvm::createStripSymbolsPass();
|
2008-02-22 18:39:29 +00:00
|
|
|
(void) llvm::createStripDeadPrototypesPass();
|
2005-01-07 07:44:02 +00:00
|
|
|
(void) llvm::createTailCallEliminationPass();
|
|
|
|
(void) llvm::createTailDuplicationPass();
|
2008-04-20 20:35:01 +00:00
|
|
|
(void) llvm::createJumpThreadingPass();
|
2005-01-08 17:21:40 +00:00
|
|
|
(void) llvm::createUnifyFunctionExitNodesPass();
|
2005-04-15 21:13:16 +00:00
|
|
|
(void) llvm::createCondPropagationPass();
|
Random sampling (aka Arnold and Ryder) profiling. This is still preliminary, but it works on spec on x86 and alpha. The idea is to allow profiling passes to remember what profiling they inserted, then a random sampling framework is inserted which consists of duplicated basic blocks (without profiling), such that at each backedge in the program and entry into every function, the framework chooses whether to use the instrumented code or the instrumentation free code. The goal of such a framework is to make it reasonably cheap to do random sampling of very expensive profiling products (such as load-value profiling).
The code is organized into 3 parts (2 passes)
1) a linked set of profiling passes, which implement an analysis group (linked, like alias analysis are). These insert profiling into the program, and remember what they inserted, so that at a later time they can be queried about any instruction.
2) a pass that handles inserting the random sampling framework. This also has options to control how random samples are choosen. Currently implemented are Global counters, register allocated global counters, and read cycle counter (see? there was a reason for it).
The profiling passes are almost identical to the existing ones (block, function, and null profiling is supported right now), and they are valid passes without the sampling framework (hence the existing passes can be unified with the new ones, not done yet).
Some things are a bit ugly still, but that should be fixed up soon enough.
Other todo? making the counter values not "magic 2^16 -1" values, but dynamically choosable.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@24493 91177308-0d34-0410-b5e6-96231b3b80d8
2005-11-28 00:58:09 +00:00
|
|
|
(void) llvm::createNullProfilerRSPass();
|
|
|
|
(void) llvm::createRSProfilingPass();
|
2006-04-10 19:26:09 +00:00
|
|
|
(void) llvm::createIndMemRemPass();
|
2006-08-21 05:34:03 +00:00
|
|
|
(void) llvm::createInstCountPass();
|
2006-08-28 22:44:55 +00:00
|
|
|
(void) llvm::createPredicateSimplifierPass();
|
2007-03-31 04:06:36 +00:00
|
|
|
(void) llvm::createCodeGenPreparePass();
|
2007-07-24 17:55:58 +00:00
|
|
|
(void) llvm::createGVNPass();
|
2008-04-09 08:23:16 +00:00
|
|
|
(void) llvm::createMemCpyOptPass();
|
2008-04-29 20:06:54 +00:00
|
|
|
(void) llvm::createLoopDeletionPass();
|
2008-05-29 17:00:13 +00:00
|
|
|
(void) llvm::createPostDomTree();
|
|
|
|
(void) llvm::createPostDomFrontier();
|
2008-08-23 06:07:02 +00:00
|
|
|
(void) llvm::createInstructionNamerPass();
|
2008-09-03 21:00:28 +00:00
|
|
|
(void) llvm::createPartialSpecializationPass();
|
2008-09-19 08:17:05 +00:00
|
|
|
(void) llvm::createAddReadAttrsPass();
|
2008-10-21 23:33:38 +00:00
|
|
|
(void) llvm::createPrintModulePass(0);
|
|
|
|
(void) llvm::createPrintFunctionPass("", 0);
|
2006-08-21 05:34:03 +00:00
|
|
|
|
|
|
|
(void)new llvm::IntervalPartition();
|
|
|
|
(void)new llvm::FindUsedTypes();
|
|
|
|
(void)new llvm::ScalarEvolution();
|
2008-06-30 00:04:21 +00:00
|
|
|
(void)new llvm::LoopVR();
|
2008-10-12 06:49:21 +00:00
|
|
|
(void)new llvm::EscapeAnalysis();
|
2006-08-21 05:34:03 +00:00
|
|
|
((llvm::Function*)0)->viewCFGOnly();
|
|
|
|
llvm::AliasSetTracker X(*(llvm::AliasAnalysis*)0);
|
|
|
|
X.add((llvm::Value*)0, 0); // for -print-alias-sets
|
2005-01-07 07:44:02 +00:00
|
|
|
}
|
2006-08-01 14:21:23 +00:00
|
|
|
} ForcePassLinking; // Force link by creating a global definition.
|
2006-02-22 16:23:43 +00:00
|
|
|
}
|
2005-01-06 06:02:53 +00:00
|
|
|
|
|
|
|
#endif
|