From ff5d06d797f2423877aea61304e0089353964131 Mon Sep 17 00:00:00 2001 From: Devang Patel Date: Wed, 27 Aug 2008 20:51:49 +0000 Subject: [PATCH] Backout 55429 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@55432 91177308-0d34-0410-b5e6-96231b3b80d8 --- tools/opt/opt.cpp | 52 ++++------------------------------------------- 1 file changed, 4 insertions(+), 48 deletions(-) diff --git a/tools/opt/opt.cpp b/tools/opt/opt.cpp index fcf98ae1bb1..1d8ce576d6a 100644 --- a/tools/opt/opt.cpp +++ b/tools/opt/opt.cpp @@ -22,8 +22,6 @@ #include "llvm/Analysis/CallGraph.h" #include "llvm/Target/TargetData.h" #include "llvm/Target/TargetMachine.h" -#include "llvm/Target/TargetMachineRegistry.h" -#include "llvm/Target/SubtargetFeature.h" #include "llvm/Support/PassNameParser.h" #include "llvm/System/Signals.h" #include "llvm/Support/ManagedStatic.h" @@ -95,22 +93,6 @@ QuietA("quiet", cl::desc("Alias for -q"), cl::aliasopt(Quiet)); static cl::opt AnalyzeOnly("analyze", cl::desc("Only perform analysis, no optimization")); -static cl::opt -MArch("march", cl::desc("Architecture to generate code for:")); - -static cl::opt -MCPU("mcpu", - cl::desc("Target a specific cpu type (-mcpu=help for details)"), - cl::value_desc("cpu-name"), - cl::init("")); - -static cl::list -MAttrs("mattr", - cl::CommaSeparated, - cl::desc("Target specific attributes (-mattr=help for details)"), - cl::value_desc("a1,+a2,-a3,...")); - // ---------- Define Printers for module and function passes ------------ namespace { @@ -326,36 +308,6 @@ void AddStandardCompilePasses(PassManager &PM) { //===----------------------------------------------------------------------===// // main for opt // - -TargetMachine *getTargetMachine(Module &Mod) { - - if (MArch == 0) { - std::string Err; - MArch = - TargetMachineRegistry::getClosestStaticTargetForModule(Mod, Err); - if (MArch == 0) { - std::cerr << "Error auto-selecting target for module '" - << Err << "'. Please use the -march option to explicitly " - << "pick a target.\n"; - return NULL; - } - } - - // Package up features to be passed to target/subtarget - std::string FeaturesStr; - if (MCPU.size() || MAttrs.size()) { - SubtargetFeatures Features; - Features.setCPU(MCPU); - for (unsigned i = 0; i != MAttrs.size(); ++i) - Features.AddFeature(MAttrs[i]); - FeaturesStr = Features.getString(); - } - - TargetMachine *Target = MArch->CtorFn(Mod, FeaturesStr); - assert(Target && "Could not allocate target machine!"); - return Target; -} - int main(int argc, char **argv) { llvm_shutdown_obj X; // Call llvm_shutdown() on exit. try { @@ -363,6 +315,10 @@ int main(int argc, char **argv) { "llvm .bc -> .bc modular optimizer and analysis printer\n"); sys::PrintStackTraceOnErrorSignal(); + // Allocate a full target machine description only if necessary. + // FIXME: The choice of target should be controllable on the command line. + std::auto_ptr target; + std::string ErrorMessage; // Load the input module...