Auto merge of #52847 - upsuper:thread-stack-reserve, r=alexcrichton

Don't commit thread stack on Windows

On Windows, there is a system level resource limitation called commit limit, which is roughly the sum of physical memory + paging files[1]. `CreateThread` by default commits the stack size[2], which unnecessarily takes such resource from the shared limit.

This PR changes it to only reserve the stack size rather than commit it. Reserved memory would only take the address space of the current process until it's actually accessed.

This should make the behavior on Windows match other platforms, and is also a pretty standard practice on Windows nowadays.

[1] https://blogs.technet.microsoft.com/markrussinovich/2008/11/17/pushing-the-limits-of-windows-virtual-memory/
[2] https://docs.microsoft.com/zh-cn/windows/desktop/api/processthreadsapi/nf-processthreadsapi-createthread
This commit is contained in:
bors
2018-08-02 04:22:23 +00:00
2 changed files with 4 additions and 1 deletions
+2
View File
@@ -296,6 +296,8 @@ pub struct ipv6_mreq {
pub const FD_SETSIZE: usize = 64;
pub const STACK_SIZE_PARAM_IS_A_RESERVATION: DWORD = 0x00010000;
#[repr(C)]
#[cfg(not(target_pointer_width = "64"))]
pub struct WSADATA {
+2 -1
View File
@@ -42,7 +42,8 @@ pub unsafe fn new<'a>(stack: usize, p: Box<dyn FnBox() + 'a>)
let stack_size = (stack + 0xfffe) & (!0xfffe);
let ret = c::CreateThread(ptr::null_mut(), stack_size,
thread_start, &*p as *const _ as *mut _,
0, ptr::null_mut());
c::STACK_SIZE_PARAM_IS_A_RESERVATION,
ptr::null_mut());
return if ret as usize == 0 {
Err(io::Error::last_os_error())