2018-04-03 14:36:57 +02:00
|
|
|
use boxed::FnBox;
|
2017-10-22 20:01:00 -07:00
|
|
|
use env;
|
2017-09-09 11:09:34 +02:00
|
|
|
use sync::atomic::{self, Ordering};
|
2015-03-12 20:21:17 -07:00
|
|
|
use sys::stack_overflow;
|
2017-09-09 11:09:34 +02:00
|
|
|
use sys::thread as imp;
|
2014-11-23 19:21:17 -08:00
|
|
|
|
2017-10-22 20:01:00 -07:00
|
|
|
#[allow(dead_code)]
|
2017-11-01 13:04:03 -07:00
|
|
|
pub unsafe fn start_thread(main: *mut u8) {
|
2015-04-14 22:13:57 -07:00
|
|
|
// Next, set up our stack overflow handler which may get triggered if we run
|
|
|
|
// out of stack.
|
|
|
|
let _handler = stack_overflow::Handler::new();
|
|
|
|
|
|
|
|
// Finally, let's run some code.
|
2018-07-10 20:35:36 +02:00
|
|
|
Box::from_raw(main as *mut Box<dyn FnBox()>)()
|
2014-11-23 19:21:17 -08:00
|
|
|
}
|
2017-09-09 11:09:34 +02:00
|
|
|
|
|
|
|
pub fn min_stack() -> usize {
|
|
|
|
static MIN: atomic::AtomicUsize = atomic::AtomicUsize::new(0);
|
|
|
|
match MIN.load(Ordering::SeqCst) {
|
|
|
|
0 => {}
|
|
|
|
n => return n - 1,
|
|
|
|
}
|
|
|
|
let amt = env::var("RUST_MIN_STACK").ok().and_then(|s| s.parse().ok());
|
|
|
|
let amt = amt.unwrap_or(imp::DEFAULT_MIN_STACK_SIZE);
|
|
|
|
|
|
|
|
// 0 is our sentinel value, so ensure that we'll never see 0 after
|
|
|
|
// initialization has run
|
|
|
|
MIN.store(amt + 1, Ordering::SeqCst);
|
|
|
|
amt
|
|
|
|
}
|