Skip to content

Commit

Permalink
rustc: Fix regression where jemalloc isn't used
Browse files Browse the repository at this point in the history
In #56986 the linkage of jemalloc to the compiler was switched from the
driver library to the rustc binary to ensure that only rustc itself uses
jemalloc. In doing so, however, it turns out jemalloc wasn't actually
linked in at all! None of the symbols were referenced so the static
library wasn't used. This means that jemalloc wasn't pulled in at all.

This commit performs a bit of a dance to reference jemalloc symbols,
attempting to pull it in despite LLVM's optimizations.

Closes #57115
  • Loading branch information
alexcrichton committed Jan 2, 2019
1 parent a36b960 commit 5265c31
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 11 deletions.
1 change: 1 addition & 0 deletions src/rustc/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
authors = ["The Rust Project Developers"]
name = "rustc-main"
version = "0.0.0"
edition = '2018'

[[bin]]
name = "rustc_binary"
Expand Down
36 changes: 25 additions & 11 deletions src/rustc/rustc.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
#![feature(rustc_private)]
#![feature(link_args)]

// Set the stack size at link time on Windows. See rustc_driver::in_rustc_thread
Expand All @@ -11,17 +10,32 @@
// Also, don't forget to set this for rustdoc.
extern {}

extern crate rustc_driver;

// Note that the linkage here should be all that we need, on Linux we're not
// prefixing the symbols here so this should naturally override our default
// allocator. On OSX it should override via the zone allocator. We shouldn't
// enable this by default on other platforms, so other platforms aren't handled
// here yet.
#[cfg(feature = "jemalloc-sys")]
extern crate jemalloc_sys;

fn main() {
// Pull in jemalloc when enabled.
//
// Note that we're pulling in a static copy of jemalloc which means that to
// pull it in we need to actually reference its symbols for it to get
// linked. The two crates we link to here, std and rustc_driver, are both
// dynamic libraries. That means to pull in jemalloc we need to actually
// reference allocation symbols one way or another (as this file is the only
// object code in the rustc executable).
//
// As such, here's an interprative dance to slip under LLVM's radar yet
// please the linker.
#[cfg(feature = "jemalloc-sys")] {
if std::env::var("__RUSTC_NEVER_PRESENT_ENV_VAR").is_ok() {
unsafe {
jemalloc_sys::calloc(1, 4);
jemalloc_sys::posix_memalign(&mut std::ptr::null_mut(), 1, 10);
jemalloc_sys::aligned_alloc(1, 10);
let a = jemalloc_sys::malloc(3);
let b = jemalloc_sys::realloc(a, 100);
println!("{:?}", b);
jemalloc_sys::free(b);
}
}
}

rustc_driver::set_sigpipe_handler();
rustc_driver::main()
}

0 comments on commit 5265c31

Please sign in to comment.