2 // Pull in jemalloc when enabled.
4 // Note that we're pulling in a static copy of jemalloc which means that to
5 // pull it in we need to actually reference its symbols for it to get
6 // linked. The two crates we link to here, std and rustc_driver, are both
7 // dynamic libraries. That means to pull in jemalloc we need to actually
8 // reference allocation symbols one way or another (as this file is the only
9 // object code in the rustc executable).
10 #[cfg(feature = "jemalloc-sys")]
12 use std::os::raw::{c_int, c_void};
15 static _F1: unsafe extern "C" fn(usize, usize) -> *mut c_void = jemalloc_sys::calloc;
17 static _F2: unsafe extern "C" fn(*mut *mut c_void, usize, usize) -> c_int =
18 jemalloc_sys::posix_memalign;
20 static _F3: unsafe extern "C" fn(usize, usize) -> *mut c_void = jemalloc_sys::aligned_alloc;
22 static _F4: unsafe extern "C" fn(usize) -> *mut c_void = jemalloc_sys::malloc;
24 static _F5: unsafe extern "C" fn(*mut c_void, usize) -> *mut c_void = jemalloc_sys::realloc;
26 static _F6: unsafe extern "C" fn(*mut c_void) = jemalloc_sys::free;
29 rustc_driver::set_sigpipe_handler();