]> git.lizzy.rs Git - rust.git/commitdiff
Add support for different relocation models
authorFlavio Percoco <flaper87@gmail.com>
Sat, 5 Apr 2014 12:10:13 +0000 (14:10 +0200)
committerFlavio Percoco <flaper87@gmail.com>
Sun, 6 Apr 2014 13:06:44 +0000 (15:06 +0200)
Rust currently defaults to `RelocPIC` regardless. This patch adds a new
codegen option that allows choosing different relocation-model. The
available models are:

    - default (Use the target-specific default model)
    - static
    - pic
    - no-pic

For a more detailed information use `llc --help`

src/etc/zsh/_rust
src/librustc/back/link.rs
src/librustc/driver/session.rs
src/test/run-make/relocation-model/Makefile [new file with mode: 0644]
src/test/run-make/relocation-model/foo.rs [new file with mode: 0644]

index f1f9e88f7c92643c270b217f514dbff6dfdc8674..0a5bfdb4ebb9d1e3e9d6d19bf9f6aca5bdb97a1b 100644 (file)
@@ -36,6 +36,7 @@ _rustc_opts_switches=(
     --target'[Target triple cpu-manufacturer-kernel\[-os\] to compile]'
     --target-cpu'[Select target processor (llc -mcpu=help for details)]'
     --target-feature'[Target specific attributes (llc -mattr=help for details)]'
+    --relocation-model'[Relocation model (llc --help for details)]'
     {-v,--version}'[Print version info and exit]'
 )
 _rustc_opts_lint=(
index e9292f54a4b266f6c7c27152f130d44596087416..9e9602556d49b500b2982e8d25dbbd5e3de98177 100644 (file)
@@ -152,13 +152,26 @@ pub fn run_passes(sess: &Session,
                              (sess.targ_cfg.os == abi::OsMacos &&
                               sess.targ_cfg.arch == abi::X86_64);
 
+            let reloc_model = match sess.opts.cg.relocation_model.as_slice() {
+                "pic" => lib::llvm::RelocPIC,
+                "static" => lib::llvm::RelocStatic,
+                "default" => lib::llvm::RelocDefault,
+                "dynamic-no-pic" => lib::llvm::RelocDynamicNoPic,
+                _ => {
+                    sess.err(format!("{} is not a valid relocation mode",
+                             sess.opts.cg.relocation_model));
+                    sess.abort_if_errors();
+                    return;
+                }
+            };
+
             let tm = sess.targ_cfg.target_strs.target_triple.with_c_str(|t| {
                 sess.opts.cg.target_cpu.with_c_str(|cpu| {
                     target_feature(sess).with_c_str(|features| {
                         llvm::LLVMRustCreateTargetMachine(
                             t, cpu, features,
                             lib::llvm::CodeModelDefault,
-                            lib::llvm::RelocPIC,
+                            reloc_model,
                             opt_level,
                             true,
                             use_softfp,
index c2fec3871abcdbd82ed909df873f925e668c4188..80003892301d584bbbd070450f1662989faa97db 100644 (file)
@@ -455,6 +455,8 @@ fn parse_list(slot: &mut Vec<~str>, v: Option<&str>)
         "prefer dynamic linking to static linking"),
     no_integrated_as: bool = (false, parse_bool,
         "use an external assembler rather than LLVM's integrated one"),
+    relocation_model: ~str = (~"pic", parse_string,
+         "choose the relocation model to use (llc -relocation-model for details)"),
 )
 
 // Seems out of place, but it uses session, so I'm putting it here
diff --git a/src/test/run-make/relocation-model/Makefile b/src/test/run-make/relocation-model/Makefile
new file mode 100644 (file)
index 0000000..2fcdd32
--- /dev/null
@@ -0,0 +1,15 @@
+-include ../tools.mk
+
+all:
+       $(RUSTC) -C relocation-model=dynamic-no-pic foo.rs
+       $(call RUN,foo)
+
+       $(RUSTC) -C relocation-model=default foo.rs
+       $(call RUN,foo)
+
+       $(RUSTC) -C relocation-model=static foo.rs
+       $(call RUN,foo)
+
+       $(RUSTC) -C relocation-model=default --crate-type=dylib foo.rs
+       $(RUSTC) -C relocation-model=static --crate-type=dylib foo.rs
+       $(RUSTC) -C relocation-model=dynamic-no-pic --crate-type=dylib foo.rs
diff --git a/src/test/run-make/relocation-model/foo.rs b/src/test/run-make/relocation-model/foo.rs
new file mode 100644 (file)
index 0000000..e06d81c
--- /dev/null
@@ -0,0 +1,11 @@
+// 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.
+
+pub fn main() {}