diff --git a/llvm/include/llvm/Target/TargetMachine.h b/llvm/include/llvm/Target/TargetMachine.h --- a/llvm/include/llvm/Target/TargetMachine.h +++ b/llvm/include/llvm/Target/TargetMachine.h @@ -223,6 +223,7 @@ /// Returns the code model. The choices are small, kernel, medium, large, and /// target default. CodeModel::Model getCodeModel() const; + void setCodeModel(CodeModel::Model CM); bool isPositionIndependent() const; diff --git a/llvm/lib/Target/TargetMachine.cpp b/llvm/lib/Target/TargetMachine.cpp --- a/llvm/lib/Target/TargetMachine.cpp +++ b/llvm/lib/Target/TargetMachine.cpp @@ -71,6 +71,9 @@ /// target default. CodeModel::Model TargetMachine::getCodeModel() const { return CMModel; } +/// Set the code model. +void TargetMachine::setCodeModel(CodeModel::Model CM) { CMModel = CM; } + /// Get the IR-specified TLS model for Var. static TLSModel::Model getSelectedTLSModel(const GlobalValue *GV) { switch (GV->getThreadLocalMode()) { diff --git a/llvm/tools/llc/llc.cpp b/llvm/tools/llc/llc.cpp --- a/llvm/tools/llc/llc.cpp +++ b/llvm/tools/llc/llc.cpp @@ -520,6 +520,7 @@ }; Optional RM = codegen::getExplicitRelocModel(); + Optional CM = codegen::getExplicitCodeModel(); const Target *TheTarget = nullptr; std::unique_ptr Target; @@ -552,8 +553,7 @@ InitializeOptions(TheTriple); Target = std::unique_ptr(TheTarget->createTargetMachine( - TheTriple.getTriple(), CPUStr, FeaturesStr, Options, RM, - codegen::getExplicitCodeModel(), OLvl)); + TheTriple.getTriple(), CPUStr, FeaturesStr, Options, RM, CM, OLvl)); assert(Target && "Could not allocate target machine!"); return Target->createDataLayout().getStringRepresentation(); @@ -573,6 +573,10 @@ } if (!TargetTriple.empty()) M->setTargetTriple(Triple::normalize(TargetTriple)); + + Optional CM_IR = M->getCodeModel(); + if (!CM && CM_IR) + Target->setCodeModel(CM_IR.getValue()); } else { TheTriple = Triple(Triple::normalize(TargetTriple)); if (TheTriple.getTriple().empty()) @@ -597,8 +601,7 @@ InitializeOptions(TheTriple); Target = std::unique_ptr(TheTarget->createTargetMachine( - TheTriple.getTriple(), CPUStr, FeaturesStr, Options, RM, - codegen::getExplicitCodeModel(), OLvl)); + TheTriple.getTriple(), CPUStr, FeaturesStr, Options, RM, CM, OLvl)); assert(Target && "Could not allocate target machine!"); // If we don't have a module then just exit now. We do this down