about summary refs log tree commit diff
path: root/src/libstd/sys/unix/thread.rs
diff options
context:
space:
mode:
authorVytautas Astrauskas <astrauv@amazon.com>2020-03-31 12:35:07 -0700
committerVytautas Astrauskas <astrauv@amazon.com>2020-03-31 15:15:14 -0700
commit753bc7ddf8a0f00acf039731947a12d06ad30884 (patch)
treebffcaacea7b479327fa5c058c32f79e1c8cdcc5c /src/libstd/sys/unix/thread.rs
parent64e5327b6e7ad79f4a3ca7de17ac105c8c59277e (diff)
downloadrust-753bc7ddf8a0f00acf039731947a12d06ad30884.tar.gz
rust-753bc7ddf8a0f00acf039731947a12d06ad30884.zip
Inline start_thread into its callers.
Diffstat (limited to 'src/libstd/sys/unix/thread.rs')
-rw-r--r--src/libstd/sys/unix/thread.rs10
1 files changed, 6 insertions, 4 deletions
diff --git a/src/libstd/sys/unix/thread.rs b/src/libstd/sys/unix/thread.rs
index efcd6142024..513a1fde331 100644
--- a/src/libstd/sys/unix/thread.rs
+++ b/src/libstd/sys/unix/thread.rs
@@ -3,11 +3,9 @@ use crate::ffi::CStr;
 use crate::io;
 use crate::mem;
 use crate::ptr;
-use crate::sys::os;
+use crate::sys::{os, stack_overflow};
 use crate::time::Duration;
 
-use crate::sys_common::thread::*;
-
 #[cfg(not(target_os = "l4re"))]
 pub const DEFAULT_MIN_STACK_SIZE: usize = 2 * 1024 * 1024;
 #[cfg(target_os = "l4re")]
@@ -84,7 +82,11 @@ impl Thread {
 
         extern "C" fn thread_start(main: *mut libc::c_void) -> *mut libc::c_void {
             unsafe {
-                start_thread(main as *mut u8);
+                // 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.
+                Box::from_raw(main as *mut Box<dyn FnOnce()>)();
             }
             ptr::null_mut()
         }