Rollup merge of #23238 - mahkoh:nativecpu, r=dotdash

This commit is contained in:
Manish Goregaokar 2015-03-12 09:14:03 +05:30
commit 9e2cf11c89
3 changed files with 24 additions and 1 deletions

View File

@ -14,6 +14,7 @@
#include "llvm/Support/CBindingWrapping.h"
#include "llvm/Support/FileSystem.h"
#include "llvm/Support/Host.h"
#include "llvm/Target/TargetLibraryInfo.h"
#include "llvm/Transforms/IPO/PassManagerBuilder.h"
@ -83,6 +84,11 @@ LLVMRustCreateTargetMachine(const char *triple,
return NULL;
}
StringRef real_cpu = cpu;
if (real_cpu == "native") {
real_cpu = sys::getHostCPUName();
}
TargetOptions Options;
Options.PositionIndependentExecutable = PositionIndependentExecutable;
Options.NoFramePointerElim = NoFramePointerElim;
@ -96,7 +102,7 @@ LLVMRustCreateTargetMachine(const char *triple,
}
TargetMachine *TM = TheTarget->createTargetMachine(Trip.getTriple(),
cpu,
real_cpu,
feature,
Options,
RM,

View File

@ -0,0 +1,5 @@
-include ../tools.mk
all:
$(RUSTC) foo.rs -C target-cpu=native
$(call RUN,foo)

View File

@ -0,0 +1,12 @@
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
// file at the top-level directory of this distribution and at
// http://rust-lang.org/COPYRIGHT.
//
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
// option. This file may not be copied, modified, or distributed
// except according to those terms.
fn main() {
}