diff options
| -rw-r--r-- | clang/Driver/Backend.cpp | 28 | ||||
| -rw-r--r-- | clang/Driver/clang.cpp | 12 | ||||
| -rw-r--r-- | clang/include/clang/Driver/CompileOptions.h | 9 | 
3 files changed, 38 insertions, 11 deletions
| diff --git a/clang/Driver/Backend.cpp b/clang/Driver/Backend.cpp index a0e102af09f..6eaffe9d9ae 100644 --- a/clang/Driver/Backend.cpp +++ b/clang/Driver/Backend.cpp @@ -29,6 +29,7 @@  #include "llvm/Support/Compiler.h"  #include "llvm/System/Path.h"  #include "llvm/System/Program.h" +#include "llvm/Target/SubtargetFeature.h"  #include "llvm/Target/TargetData.h"  #include "llvm/Target/TargetMachine.h"  #include "llvm/Target/TargetMachineRegistry.h" @@ -74,7 +75,7 @@ namespace {    public:        BackendConsumer(BackendAction action, Diagnostic &Diags,  -                    const LangOptions &Features, const CompileOptions &compopts, +                    const LangOptions &langopts, const CompileOptions &compopts,                      const std::string& infile, const std::string& outfile,                      bool debug)  :        Action(action),  @@ -82,7 +83,7 @@ namespace {        InputFile(infile),         OutputFile(outfile),         GenerateDebugInfo(debug), -      Gen(CreateLLVMCodeGen(Diags, Features, InputFile, GenerateDebugInfo)), +      Gen(CreateLLVMCodeGen(Diags, langopts, InputFile, GenerateDebugInfo)),        TheModule(0), TheTargetData(0), AsmOutStream(0), ModuleProvider(0),        CodeGenPasses(0), PerModulePasses(0), PerFunctionPasses(0) {} @@ -187,10 +188,18 @@ bool BackendConsumer::AddEmitPasses(std::string &Error) {        Error = std::string("Unable to get target machine: ") + Error;        return false;      } -       -    // FIXME: Support features? -    std::string FeatureStr; -    TargetMachine *TM = TME->CtorFn(*TheModule, FeatureStr); + +    std::string FeaturesStr; +    if (CompileOpts.CPU.size() || CompileOpts.Features.size()) { +      SubtargetFeatures Features; +      Features.setCPU(CompileOpts.CPU); +      for (std::vector<std::string>::iterator  +             it = CompileOpts.Features.begin(), +             ie = CompileOpts.Features.end(); it != ie; ++it) +        Features.AddFeature(*it); +      FeaturesStr = Features.getString(); +    } +    TargetMachine *TM = TME->CtorFn(*TheModule, FeaturesStr);      // Set register scheduler & allocation policy.      RegisterScheduler::setDefault(createDefaultScheduler); @@ -364,7 +373,7 @@ void BackendConsumer::EmitAssembly() {  ASTConsumer *clang::CreateBackendConsumer(BackendAction Action,                                            Diagnostic &Diags, -                                          const LangOptions &Features, +                                          const LangOptions &LangOpts,                                            const CompileOptions &CompileOpts,                                            const std::string& InFile,                                            const std::string& OutFile, @@ -374,8 +383,7 @@ ASTConsumer *clang::CreateBackendConsumer(BackendAction Action,    // are enabled.    if (CompileOpts.OptimizationLevel > 0)      GenerateDebugInfo = false; -   -   -  return new BackendConsumer(Action, Diags, Features, CompileOpts, +     +  return new BackendConsumer(Action, Diags, LangOpts, CompileOpts,                               InFile, OutFile, GenerateDebugInfo);    } diff --git a/clang/Driver/clang.cpp b/clang/Driver/clang.cpp index 1fdfde4318e..24c4d7fe09f 100644 --- a/clang/Driver/clang.cpp +++ b/clang/Driver/clang.cpp @@ -1204,6 +1204,14 @@ OptLevel("O", llvm::cl::Prefix,           llvm::cl::desc("Optimization level"),           llvm::cl::init(0)); +static llvm::cl::opt<std::string> +TargetCPU("mcpu", +         llvm::cl::desc("Target a specific cpu type (-mcpu=help for details)")); + +static llvm::cl::list<std::string> +TargetFeatures("mattr", +        llvm::cl::desc("Target specific attributes (-mattr=help for details)")); +  static void InitializeCompileOptions(CompileOptions &Opts) {    Opts.OptimizeSize = OptSize;    if (OptSize) { @@ -1222,6 +1230,10 @@ static void InitializeCompileOptions(CompileOptions &Opts) {  #ifdef NDEBUG    Opts.VerifyModule = 0;  #endif + +  Opts.CPU = TargetCPU; +  Opts.Features.insert(Opts.Features.end(), +                       TargetFeatures.begin(), TargetFeatures.end());  }  //===----------------------------------------------------------------------===// diff --git a/clang/include/clang/Driver/CompileOptions.h b/clang/include/clang/Driver/CompileOptions.h index 50865536dca..354df43aeac 100644 --- a/clang/include/clang/Driver/CompileOptions.h +++ b/clang/include/clang/Driver/CompileOptions.h @@ -30,6 +30,13 @@ struct CompileOptions {    unsigned VerifyModule      : 1; /// Control whether the module                                    /// should be run through the LLVM Verifier. +  /// CPU - An optional CPU to target. +  std::string CPU; + +  /// Features - A list of subtarget features to pass to the code +  /// generator. +  std::vector<std::string> Features; +  public:    CompileOptions() {      OptimizationLevel = 0; @@ -37,7 +44,7 @@ public:      UnitAtATime = 1;      InlineFunctions = SimplifyLibCalls = UnrollLoops = 0;      VerifyModule = 1; -  } +  }    };  }  // end namespace clang | 

