Skip to content

Commit ebe8411

Browse files
committed
rollup merge of #20237: RustOS-Fork-Holding-Ground/master
libc is only used when the heap allocations are not defined externally, or defined in another crate. I assume these extern* configurations were added for the sake of those of us experimenting with freestanding Rust. Avoiding libc where possible is often very important for us.
2 parents 9f1ead8 + b1b4bc9 commit ebe8411

File tree

2 files changed

+29
-16
lines changed

2 files changed

+29
-16
lines changed

src/liballoc/heap.rs

Lines changed: 27 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -115,16 +115,20 @@ unsafe fn exchange_free(ptr: *mut u8, old_size: uint, align: uint) {
115115
// The minimum alignment guaranteed by the architecture. This value is used to
116116
// add fast paths for low alignment values. In practice, the alignment is a
117117
// constant at the call site and the branch will be optimized out.
118-
#[cfg(any(target_arch = "arm",
119-
target_arch = "mips",
120-
target_arch = "mipsel"))]
118+
#[cfg(all(not(feature = "external_funcs"),
119+
not(feature = "external_crate"),
120+
any(target_arch = "arm",
121+
target_arch = "mips",
122+
target_arch = "mipsel")))]
121123
const MIN_ALIGN: uint = 8;
122-
#[cfg(any(target_arch = "x86",
123-
target_arch = "x86_64",
124-
target_arch = "aarch64"))]
124+
#[cfg(all(not(feature = "external_funcs"),
125+
not(feature = "external_crate"),
126+
any(target_arch = "x86",
127+
target_arch = "x86_64",
128+
target_arch = "aarch64"))]
125129
const MIN_ALIGN: uint = 16;
126130

127-
#[cfg(external_funcs)]
131+
#[cfg(feature = "external_funcs")]
128132
mod imp {
129133
extern {
130134
fn rust_allocate(size: uint, align: uint) -> *mut u8;
@@ -142,14 +146,13 @@ mod imp {
142146
}
143147

144148
#[inline]
145-
pub unsafe fn reallocate_inplace(ptr: *mut u8, old_size: uint, size: uint,
146-
align: uint) -> uint {
147-
rust_reallocate_inplace(ptr, old_size, size, align)
149+
pub unsafe fn deallocate(ptr: *mut u8, old_size: uint, align: uint) {
150+
rust_deallocate(ptr, old_size, align)
148151
}
149152

150153
#[inline]
151-
pub unsafe fn deallocate(ptr: *mut u8, old_size: uint, align: uint) {
152-
rust_deallocate(ptr, old_size, align)
154+
pub unsafe fn reallocate(ptr: *mut u8, old_size: uint, size: uint, align: uint) -> *mut u8 {
155+
rust_reallocate(ptr, old_size, size, align)
153156
}
154157

155158
#[inline]
@@ -169,14 +172,16 @@ mod imp {
169172
}
170173
}
171174

172-
#[cfg(external_crate)]
175+
#[cfg(feature = "external_crate")]
173176
mod imp {
174177
extern crate external;
175178
pub use self::external::{allocate, deallocate, reallocate_inplace, reallocate};
176179
pub use self::external::{usable_size, stats_print};
177180
}
178181

179-
#[cfg(all(not(external_funcs), not(external_crate), jemalloc))]
182+
#[cfg(all(not(feature = "external_funcs"),
183+
not(feature = "external_crate"),
184+
jemalloc))]
180185
mod imp {
181186
use core::option::Option;
182187
use core::option::Option::None;
@@ -253,7 +258,10 @@ mod imp {
253258
}
254259
}
255260

256-
#[cfg(all(not(external_funcs), not(external_crate), not(jemalloc), unix))]
261+
#[cfg(all(not(feature = "external_funcs"),
262+
not(feature = "external_crate"),
263+
not(jemalloc),
264+
unix))]
257265
mod imp {
258266
use core::cmp;
259267
use core::ptr;
@@ -314,7 +322,10 @@ mod imp {
314322
pub fn stats_print() {}
315323
}
316324

317-
#[cfg(all(not(external_funcs), not(external_crate), not(jemalloc), windows))]
325+
#[cfg(all(not(feature = "external_funcs"),
326+
not(feature = "external_crate"),
327+
not(jemalloc),
328+
windows))]
318329
mod imp {
319330
use libc::{c_void, size_t};
320331
use libc;

src/liballoc/lib.rs

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -69,6 +69,8 @@
6969

7070
#[macro_use]
7171
extern crate core;
72+
73+
#[cfg(all(not(feature = "external_funcs"), not(feature = "external_crate")))]
7274
extern crate libc;
7375

7476
// Allow testing this library

0 commit comments

Comments
 (0)