diff options
author | Diego Caballero <diego.caballero@intel.com> | 2019-08-05 23:02:12 +0000 |
---|---|---|
committer | Diego Caballero <diego.caballero@intel.com> | 2019-08-05 23:02:12 +0000 |
commit | 16477588824f5347b18cb4778a16472a8317355b (patch) | |
tree | c53b3bc52318e4744f22ae0a0078e9030552d263 /llvm/lib/ExecutionEngine/Orc | |
parent | 295d4b7727caba392ff3fdf1dbd9006b1ee1a1a2 (diff) | |
download | bcm5719-llvm-16477588824f5347b18cb4778a16472a8317355b.tar.gz bcm5719-llvm-16477588824f5347b18cb4778a16472a8317355b.zip |
[ORC] Add CPU name and sub-target features to detectHost
This commit adds host CPU name and sub-target features to the
`JITTargetMachineBuilder` created by `JITTargetMachineBuilder::detectHost()`.
Differential Revision: https://reviews.llvm.org/D65760
llvm-svn: 367944
Diffstat (limited to 'llvm/lib/ExecutionEngine/Orc')
-rw-r--r-- | llvm/lib/ExecutionEngine/Orc/JITTargetMachineBuilder.cpp | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/llvm/lib/ExecutionEngine/Orc/JITTargetMachineBuilder.cpp b/llvm/lib/ExecutionEngine/Orc/JITTargetMachineBuilder.cpp index df23547a9de..91295da1e17 100644 --- a/llvm/lib/ExecutionEngine/Orc/JITTargetMachineBuilder.cpp +++ b/llvm/lib/ExecutionEngine/Orc/JITTargetMachineBuilder.cpp @@ -22,7 +22,21 @@ JITTargetMachineBuilder::JITTargetMachineBuilder(Triple TT) Expected<JITTargetMachineBuilder> JITTargetMachineBuilder::detectHost() { // FIXME: getProcessTriple is bogus. It returns the host LLVM was compiled on, // rather than a valid triple for the current process. - return JITTargetMachineBuilder(Triple(sys::getProcessTriple())); + JITTargetMachineBuilder TMBuilder(Triple(sys::getProcessTriple())); + + // Retrieve host CPU name and sub-target features and add them to builder. + // Relocation model, code model and codegen opt level are kept to default + // values. + llvm::SubtargetFeatures SubtargetFeatures; + llvm::StringMap<bool> FeatureMap; + llvm::sys::getHostCPUFeatures(FeatureMap); + for (auto &Feature : FeatureMap) + SubtargetFeatures.AddFeature(Feature.first(), Feature.second); + + TMBuilder.setCPU(llvm::sys::getHostCPUName()); + TMBuilder.addFeatures(SubtargetFeatures.getFeatures()); + + return TMBuilder; } Expected<std::unique_ptr<TargetMachine>> |