diff options
| author | Jethro Beekman <jethro@fortanix.com> | 2020-01-09 16:40:40 +0100 |
|---|---|---|
| committer | Jethro Beekman <jethro@fortanix.com> | 2020-01-10 08:12:55 +0100 |
| commit | afced941555ecaa7fff2e11c8396bca58384d760 (patch) | |
| tree | b4a3e43460b5a154c3f09e83cd5b796eb62ce942 /src/librustc_codegen_llvm | |
| parent | adc65725004c8aac16392fe4052c3e347181157d (diff) | |
| download | rust-afced941555ecaa7fff2e11c8396bca58384d760.tar.gz rust-afced941555ecaa7fff2e11c8396bca58384d760.zip | |
Allow specifying LLVM args in target specifications
Diffstat (limited to 'src/librustc_codegen_llvm')
| -rw-r--r-- | src/librustc_codegen_llvm/llvm_util.rs | 15 |
1 files changed, 6 insertions, 9 deletions
diff --git a/src/librustc_codegen_llvm/llvm_util.rs b/src/librustc_codegen_llvm/llvm_util.rs index b3c58b24020..52613fef7e6 100644 --- a/src/librustc_codegen_llvm/llvm_util.rs +++ b/src/librustc_codegen_llvm/llvm_util.rs @@ -46,7 +46,7 @@ fn require_inited() { } unsafe fn configure_llvm(sess: &Session) { - let n_args = sess.opts.cg.llvm_args.len(); + let n_args = sess.opts.cg.llvm_args.len() + sess.target.target.options.llvm_args.len(); let mut llvm_c_strs = Vec::with_capacity(n_args + 1); let mut llvm_args = Vec::with_capacity(n_args + 1); @@ -56,14 +56,11 @@ unsafe fn configure_llvm(sess: &Session) { full_arg.trim().split(|c: char| c == '=' || c.is_whitespace()).next().unwrap_or("") } - let user_specified_args: FxHashSet<_> = sess - .opts - .cg - .llvm_args - .iter() - .map(|s| llvm_arg_to_arg_name(s)) - .filter(|s| s.len() > 0) - .collect(); + let cg_opts = sess.opts.cg.llvm_args.iter(); + let tg_opts = sess.target.target.options.llvm_args.iter(); + + let user_specified_args: FxHashSet<_> = + cg_opts.chain(tg_opts).map(|s| llvm_arg_to_arg_name(s)).filter(|s| s.len() > 0).collect(); { // This adds the given argument to LLVM. Unless `force` is true |
