aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tools/analyze/analyze.cpp4
-rw-r--r--tools/bugpoint/OptimizerDriver.cpp3
-rw-r--r--tools/gccas/gccas.cpp5
-rw-r--r--tools/gccld/gccld.cpp4
-rw-r--r--tools/opt/opt.cpp3
5 files changed, 18 insertions, 1 deletions
diff --git a/tools/analyze/analyze.cpp b/tools/analyze/analyze.cpp
index 83cfda2..1119fcc 100644
--- a/tools/analyze/analyze.cpp
+++ b/tools/analyze/analyze.cpp
@@ -15,6 +15,7 @@
#include "llvm/Bytecode/Reader.h"
#include "llvm/Assembly/Parser.h"
#include "llvm/Analysis/Verifier.h"
+#include "llvm/Target/TargetData.h"
#include "llvm/Support/PassNameParser.h"
#include "Support/Timer.h"
#include <algorithm>
@@ -126,6 +127,9 @@ int main(int argc, char **argv) {
//
PassManager Passes;
+ // Add an appropriate TargetData instance for this module...
+ Passes.add(new TargetData("analyze", CurMod));
+
// Make sure the input LLVM is well formed.
Passes.add(createVerifierPass());
diff --git a/tools/bugpoint/OptimizerDriver.cpp b/tools/bugpoint/OptimizerDriver.cpp
index 7c6e7c0..fefca73 100644
--- a/tools/bugpoint/OptimizerDriver.cpp
+++ b/tools/bugpoint/OptimizerDriver.cpp
@@ -74,6 +74,9 @@ static void RunChild(Module *Program,const std::vector<const PassInfo*> &Passes,
}
PassManager PM;
+ // Make sure that the appropriate target data is always used...
+ PM.add(new TargetData("bugpoint", Program));
+
for (unsigned i = 0, e = Passes.size(); i != e; ++i) {
if (Passes[i]->getNormalCtor())
PM.add(Passes[i]->getNormalCtor()());
diff --git a/tools/gccas/gccas.cpp b/tools/gccas/gccas.cpp
index 043b0d2..273e071 100644
--- a/tools/gccas/gccas.cpp
+++ b/tools/gccas/gccas.cpp
@@ -66,8 +66,8 @@ void AddConfiguredTransformationPasses(PassManager &PM) {
addPass(PM, createGlobalDCEPass()); // Kill unused uinit g-vars
addPass(PM, createDeadTypeEliminationPass()); // Eliminate dead types
addPass(PM, createConstantMergePass()); // Merge dup global constants
- addPass(PM, createVerifierPass()); // Verify that input is correct
addPass(PM, createCFGSimplificationPass()); // Merge & remove BBs
+ addPass(PM, createVerifierPass()); // Verify that input is correct
addPass(PM, createDeadInstEliminationPass()); // Remove Dead code/vars
addPass(PM, createRaiseAllocationsPass()); // call %malloc -> malloc inst
addPass(PM, createIndVarSimplifyPass()); // Simplify indvars
@@ -145,6 +145,9 @@ int main(int argc, char **argv) {
//
PassManager Passes;
+ // Add an appropriate TargetData instance for this module...
+ Passes.add(new TargetData("gccas", M.get()));
+
// Add all of the transformation passes to the pass manager to do the cleanup
// and optimization of the GCC output.
//
diff --git a/tools/gccld/gccld.cpp b/tools/gccld/gccld.cpp
index 1d61d13..24c624e 100644
--- a/tools/gccld/gccld.cpp
+++ b/tools/gccld/gccld.cpp
@@ -18,6 +18,7 @@
#include "llvm/PassManager.h"
#include "llvm/Bytecode/Reader.h"
#include "llvm/Bytecode/WriteBytecodePass.h"
+#include "llvm/Target/TargetData.h"
#include "llvm/Transforms/IPO.h"
#include "llvm/Transforms/Scalar.h"
#include "Support/CommandLine.h"
@@ -326,6 +327,9 @@ int main(int argc, char **argv) {
//
PassManager Passes;
+ // Add an appropriate TargetData instance for this module...
+ Passes.add(new TargetData("gccas", Composite.get()));
+
// Linking modules together can lead to duplicated global constants, only keep
// one copy of each constant...
//
diff --git a/tools/opt/opt.cpp b/tools/opt/opt.cpp
index d03a650..0127c53 100644
--- a/tools/opt/opt.cpp
+++ b/tools/opt/opt.cpp
@@ -113,6 +113,9 @@ int main(int argc, char **argv) {
//
PassManager Passes;
+ // Add an appropriate TargetData instance for this module...
+ Passes.add(new TargetData("opt", M.get()));
+
// Create a new optimization pass for each one specified on the command line
for (unsigned i = 0; i < OptimizationList.size(); ++i) {
const PassInfo *Opt = OptimizationList[i];