Skip to content

Commit 6208fea

Browse files
author
Jorge Aparicio
committed
move the alloc_jemalloc allocator out of tree, default to alloc_system
See rust-lang#36963 for rationale closes rust-lang#36963 fixes rust-lang#36488 (indirectly) closes rust-lang#37975
1 parent 8f62c29 commit 6208fea

27 files changed

+9
-534
lines changed

.gitmodules

-3
Original file line numberDiff line numberDiff line change
@@ -8,9 +8,6 @@
88
[submodule "src/rt/hoedown"]
99
path = src/rt/hoedown
1010
url = https://github.com/rust-lang/hoedown.git
11-
[submodule "src/jemalloc"]
12-
path = src/jemalloc
13-
url = https://github.com/rust-lang/jemalloc.git
1411
[submodule "src/rust-installer"]
1512
path = src/rust-installer
1613
url = https://github.com/rust-lang/rust-installer.git

configure

-16
Original file line numberDiff line numberDiff line change
@@ -647,7 +647,6 @@ opt_nosave debug-assertions 0 "build with debugging assertions"
647647
opt_nosave llvm-release-debuginfo 0 "build LLVM with debugger metadata"
648648
opt_nosave debuginfo 0 "build with debugger metadata"
649649
opt_nosave debuginfo-lines 0 "build with line number debugger metadata"
650-
opt_nosave debug-jemalloc 0 "build jemalloc with --enable-debug --enable-fill"
651650

652651
valopt localstatedir "/var/lib" "local state directory"
653652
valopt sysconfdir "/etc" "install system configuration files"
@@ -656,7 +655,6 @@ valopt datadir "${CFG_PREFIX}/share" "install data"
656655
valopt infodir "${CFG_PREFIX}/share/info" "install additional info"
657656
valopt llvm-root "" "set LLVM root"
658657
valopt python "" "set path to python"
659-
valopt jemalloc-root "" "set directory where libjemalloc_pic.a is located"
660658
valopt build "${DEFAULT_BUILD}" "GNUs ./configure syntax LLVM build triple"
661659
valopt android-cross-path "" "Android NDK standalone path (deprecated)"
662660
valopt i686-linux-android-ndk "" "i686-linux-android NDK standalone path"
@@ -691,7 +689,6 @@ valopt default-ar "ar" "the default ar"
691689
# (others are conditionally saved).
692690
opt_nosave manage-submodules 1 "let the build manage the git submodules"
693691
opt_nosave clang 0 "prefer clang to gcc for building the runtime"
694-
opt_nosave jemalloc 1 "build liballoc with jemalloc"
695692
opt elf-tls 1 "elf thread local storage on platforms where supported"
696693
opt full-bootstrap 0 "build three compilers instead of two"
697694

@@ -771,7 +768,6 @@ if [ -n "$CFG_ENABLE_DEBUG" ]; then
771768

772769
# Set following variables to 1 unless setting already provided
773770
enable_if_not_disabled debug-assertions
774-
enable_if_not_disabled debug-jemalloc
775771
enable_if_not_disabled debuginfo
776772
enable_if_not_disabled llvm-assertions
777773
fi
@@ -785,7 +781,6 @@ if [ -n "$CFG_ENABLE_DEBUG_ASSERTIONS" ]; then putvar CFG_ENABLE_DEBUG_ASSERTION
785781
if [ -n "$CFG_ENABLE_LLVM_RELEASE_DEBUGINFO" ]; then putvar CFG_ENABLE_LLVM_RELEASE_DEBUGINFO; fi
786782
if [ -n "$CFG_ENABLE_DEBUGINFO" ]; then putvar CFG_ENABLE_DEBUGINFO; fi
787783
if [ -n "$CFG_ENABLE_DEBUGINFO_LINES" ]; then putvar CFG_ENABLE_DEBUGINFO_LINES; fi
788-
if [ -n "$CFG_ENABLE_DEBUG_JEMALLOC" ]; then putvar CFG_ENABLE_DEBUG_JEMALLOC; fi
789784

790785
step_msg "looking for build programs"
791786

@@ -1065,12 +1060,6 @@ else
10651060
CFG_USING_LIBCPP="0"
10661061
fi
10671062

1068-
# Same with jemalloc. save the setting here.
1069-
if [ -n "$CFG_DISABLE_JEMALLOC" ]
1070-
then
1071-
putvar CFG_DISABLE_JEMALLOC
1072-
fi
1073-
10741063
if [ -n "$CFG_LLVM_ROOT" -a -z "$CFG_DISABLE_LLVM_VERSION_CHECK" -a -e "$CFG_LLVM_ROOT/bin/llvm-config" ]
10751064
then
10761065
step_msg "using custom LLVM at $CFG_LLVM_ROOT"
@@ -1415,7 +1404,6 @@ if [ -n "$CFG_DISABLE_RUSTBUILD" ]; then
14151404
for s in 0 1 2 3
14161405
do
14171406
make_dir $t/rt/stage$s
1418-
make_dir $t/rt/jemalloc
14191407
make_dir $t/rt/compiler-rt
14201408
for i in \
14211409
isaac sync test \
@@ -1503,10 +1491,6 @@ then
15031491
msg "git: submodule deinit src/llvm"
15041492
"${CFG_GIT}" submodule deinit src/llvm
15051493
fi
1506-
if [ -n "${CFG_JEMALLOC_ROOT}" ]; then
1507-
msg "git: submodule deinit src/jemalloc"
1508-
"${CFG_GIT}" submodule deinit src/jemalloc
1509-
fi
15101494

15111495
msg "git: submodule update"
15121496
"${CFG_GIT}" submodule update

src/Cargo.lock

-11
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

src/bootstrap/check.rs

+1-7
Original file line numberDiff line numberDiff line change
@@ -338,7 +338,7 @@ pub fn krate(build: &Build,
338338
("libtest", "src/rustc/test_shim", String::new(), "test_shim")
339339
}
340340
Mode::Librustc => {
341-
("librustc", "src/rustc", build.rustc_features(), "rustc-main")
341+
("librustc", "src/rustc", String::new(), "rustc-main")
342342
}
343343
_ => panic!("can only test libraries"),
344344
};
@@ -373,12 +373,6 @@ pub fn krate(build: &Build,
373373
let mut visited = HashSet::new();
374374
let mut next = vec![root];
375375
while let Some(name) = next.pop() {
376-
// Right now jemalloc is our only target-specific crate in the sense
377-
// that it's not present on all platforms. Custom skip it here for now,
378-
// but if we add more this probably wants to get more generalized.
379-
if !name.contains("jemalloc") {
380-
cargo.arg("-p").arg(name);
381-
}
382376
for dep in build.crates[name].deps.iter() {
383377
if visited.insert(dep) {
384378
next.push(dep);

src/bootstrap/compile.rs

+1-7
Original file line numberDiff line numberDiff line change
@@ -47,11 +47,6 @@ pub fn std(build: &Build, target: &str, compiler: &Compiler) {
4747
.arg("--manifest-path")
4848
.arg(build.src.join("src/rustc/std_shim/Cargo.toml"));
4949

50-
if let Some(target) = build.config.target_config.get(target) {
51-
if let Some(ref jemalloc) = target.jemalloc {
52-
cargo.env("JEMALLOC_OVERRIDE", jemalloc);
53-
}
54-
}
5550
if target.contains("musl") {
5651
if let Some(p) = build.musl_root(target) {
5752
cargo.env("MUSL_ROOT", p);
@@ -177,8 +172,7 @@ pub fn rustc(build: &Build, target: &str, compiler: &Compiler) {
177172
build.clear_if_dirty(&out_dir, &libtest_stamp(build, compiler, target));
178173

179174
let mut cargo = build.cargo(compiler, Mode::Librustc, target, "build");
180-
cargo.arg("--features").arg(build.rustc_features())
181-
.arg("--manifest-path")
175+
cargo.arg("--manifest-path")
182176
.arg(build.src.join("src/rustc/Cargo.toml"));
183177

184178
// Set some configuration variables picked up by build scripts and

src/bootstrap/config.rs

-19
Original file line numberDiff line numberDiff line change
@@ -77,8 +77,6 @@ pub struct Config {
7777
pub local_rebuild: bool,
7878

7979
// libstd features
80-
pub debug_jemalloc: bool,
81-
pub use_jemalloc: bool,
8280
pub backtrace: bool, // support for RUST_BACKTRACE
8381

8482
// misc
@@ -101,7 +99,6 @@ pub struct Config {
10199
#[derive(Default)]
102100
pub struct Target {
103101
pub llvm_config: Option<PathBuf>,
104-
pub jemalloc: Option<PathBuf>,
105102
pub cc: Option<PathBuf>,
106103
pub cxx: Option<PathBuf>,
107104
pub ndk: Option<PathBuf>,
@@ -179,8 +176,6 @@ struct Rust {
179176
debug_assertions: Option<bool>,
180177
debuginfo: Option<bool>,
181178
debuginfo_lines: Option<bool>,
182-
debug_jemalloc: Option<bool>,
183-
use_jemalloc: Option<bool>,
184179
backtrace: Option<bool>,
185180
default_linker: Option<String>,
186181
default_ar: Option<String>,
@@ -196,7 +191,6 @@ struct Rust {
196191
#[derive(RustcDecodable, Default)]
197192
struct TomlTarget {
198193
llvm_config: Option<String>,
199-
jemalloc: Option<String>,
200194
cc: Option<String>,
201195
cxx: Option<String>,
202196
android_ndk: Option<String>,
@@ -207,7 +201,6 @@ impl Config {
207201
pub fn parse(build: &str, file: Option<PathBuf>) -> Config {
208202
let mut config = Config::default();
209203
config.llvm_optimize = true;
210-
config.use_jemalloc = true;
211204
config.backtrace = true;
212205
config.rust_optimize = true;
213206
config.rust_optimize_tests = true;
@@ -303,8 +296,6 @@ impl Config {
303296
set(&mut config.rust_debuginfo_tests, rust.debuginfo_tests);
304297
set(&mut config.codegen_tests, rust.codegen_tests);
305298
set(&mut config.rust_rpath, rust.rpath);
306-
set(&mut config.debug_jemalloc, rust.debug_jemalloc);
307-
set(&mut config.use_jemalloc, rust.use_jemalloc);
308299
set(&mut config.backtrace, rust.backtrace);
309300
set(&mut config.channel, rust.channel.clone());
310301
config.rustc_default_linker = rust.default_linker.clone();
@@ -325,9 +316,6 @@ impl Config {
325316
if let Some(ref s) = cfg.llvm_config {
326317
target.llvm_config = Some(env::current_dir().unwrap().join(s));
327318
}
328-
if let Some(ref s) = cfg.jemalloc {
329-
target.jemalloc = Some(env::current_dir().unwrap().join(s));
330-
}
331319
if let Some(ref s) = cfg.android_ndk {
332320
target.ndk = Some(env::current_dir().unwrap().join(s));
333321
}
@@ -390,8 +378,6 @@ impl Config {
390378
("DEBUG_ASSERTIONS", self.rust_debug_assertions),
391379
("DEBUGINFO", self.rust_debuginfo),
392380
("DEBUGINFO_LINES", self.rust_debuginfo_lines),
393-
("JEMALLOC", self.use_jemalloc),
394-
("DEBUG_JEMALLOC", self.debug_jemalloc),
395381
("RPATH", self.rust_rpath),
396382
("OPTIMIZE_TESTS", self.rust_optimize_tests),
397383
("DEBUGINFO_TESTS", self.rust_debuginfo_tests),
@@ -476,11 +462,6 @@ impl Config {
476462
let root = parse_configure_path(value);
477463
target.llvm_config = Some(push_exe_path(root, &["bin", "llvm-config"]));
478464
}
479-
"CFG_JEMALLOC_ROOT" if value.len() > 0 => {
480-
let target = self.target_config.entry(self.build.clone())
481-
.or_insert(Target::default());
482-
target.jemalloc = Some(parse_configure_path(value));
483-
}
484465
"CFG_ARM_LINUX_ANDROIDEABI_NDK" if value.len() > 0 => {
485466
let target = "arm-linux-androideabi".to_string();
486467
let target = self.target_config.entry(target)

src/bootstrap/config.toml.example

-10
Original file line numberDiff line numberDiff line change
@@ -149,12 +149,6 @@
149149
# Whether or not line number debug information is emitted
150150
#debuginfo-lines = false
151151

152-
# Whether or not jemalloc is built and enabled
153-
#use-jemalloc = true
154-
155-
# Whether or not jemalloc is built with its debug option set
156-
#debug-jemalloc = false
157-
158152
# Whether or not `panic!`s generate backtraces (RUST_BACKTRACE)
159153
#backtrace = true
160154

@@ -208,10 +202,6 @@
208202
# target.
209203
#llvm-config = "../path/to/llvm/root/bin/llvm-config"
210204

211-
# Path to the custom jemalloc static library to link into the standard library
212-
# by default. This is only used if jemalloc is still enabled above
213-
#jemalloc = "/path/to/jemalloc/libjemalloc_pic.a"
214-
215205
# If this target is for Android, this option will be required to specify where
216206
# the NDK for the target lives. This is used to find the C compiler to link and
217207
# build native code.

src/bootstrap/doc.rs

+1-2
Original file line numberDiff line numberDiff line change
@@ -206,8 +206,7 @@ pub fn rustc(build: &Build, stage: u32, target: &str) {
206206
}
207207
let mut cargo = build.cargo(&compiler, Mode::Librustc, target, "doc");
208208
cargo.arg("--manifest-path")
209-
.arg(build.src.join("src/rustc/Cargo.toml"))
210-
.arg("--features").arg(build.rustc_features());
209+
.arg(build.src.join("src/rustc/Cargo.toml"));
211210
build.run(&mut cargo);
212211
cp_r(&out_dir, &out)
213212
}

src/bootstrap/lib.rs

-21
Original file line numberDiff line numberDiff line change
@@ -386,12 +386,6 @@ impl Build {
386386
continue
387387
}
388388

389-
if submodule.path.components().any(|c| c == Component::Normal("jemalloc".as_ref())) &&
390-
!self.config.use_jemalloc
391-
{
392-
continue
393-
}
394-
395389
// `submodule.path` is the relative path to a submodule (from the repository root)
396390
// `submodule_path` is the path to a submodule from the cwd
397391

@@ -609,27 +603,12 @@ impl Build {
609603
/// library.
610604
fn std_features(&self) -> String {
611605
let mut features = "panic-unwind".to_string();
612-
if self.config.debug_jemalloc {
613-
features.push_str(" debug-jemalloc");
614-
}
615-
if self.config.use_jemalloc {
616-
features.push_str(" jemalloc");
617-
}
618606
if self.config.backtrace {
619607
features.push_str(" backtrace");
620608
}
621609
return features
622610
}
623611

624-
/// Get the space-separated set of activated features for the compiler.
625-
fn rustc_features(&self) -> String {
626-
let mut features = String::new();
627-
if self.config.use_jemalloc {
628-
features.push_str(" jemalloc");
629-
}
630-
return features
631-
}
632-
633612
/// Component directory that Cargo will produce output into (e.g.
634613
/// release/debug)
635614
fn cargo_dir(&self) -> &'static str {

src/bootstrap/sanity.rs

-8
Original file line numberDiff line numberDiff line change
@@ -136,14 +136,6 @@ pub fn check(build: &mut Build) {
136136
need_cmd(build.cxx(host).as_ref());
137137
}
138138

139-
// The msvc hosts don't use jemalloc, turn it off globally to
140-
// avoid packaging the dummy liballoc_jemalloc on that platform.
141-
for host in build.config.host.iter() {
142-
if host.contains("msvc") {
143-
build.config.use_jemalloc = false;
144-
}
145-
}
146-
147139
// Externally configured LLVM requires FileCheck to exist
148140
let filecheck = build.llvm_filecheck(&build.config.build);
149141
if !filecheck.starts_with(&build.out) && !filecheck.exists() && build.config.codegen_tests {

src/jemalloc

-1
This file was deleted.

src/liballoc_jemalloc/Cargo.toml

-23
This file was deleted.

0 commit comments

Comments
 (0)