From 66cacf04d1e6c19c5898bf6397789097922e2f8e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Michal=20Strehovsk=C3=BD?= Date: Fri, 25 Jul 2025 11:55:17 +0200 Subject: [PATCH] Delete `DEFAULT_STACK_SIZE` https://github.com/dotnet/runtime/pull/110455#discussion_r2230673840 --- src/coreclr/vm/corhost.cpp | 6 ------ src/coreclr/vm/threads.cpp | 28 +--------------------------- 2 files changed, 1 insertion(+), 33 deletions(-) diff --git a/src/coreclr/vm/corhost.cpp b/src/coreclr/vm/corhost.cpp index 2537e0bf3d5a33..455e622d8b8fa3 100644 --- a/src/coreclr/vm/corhost.cpp +++ b/src/coreclr/vm/corhost.cpp @@ -608,12 +608,6 @@ HRESULT CorHost2::CreateAppDomainWithManager( pwzAppPaths = pPropertyValues[i]; } else - if (u16_strcmp(pPropertyNames[i], W("DEFAULT_STACK_SIZE")) == 0) - { - extern void ParseDefaultStackSize(LPCWSTR value); - ParseDefaultStackSize(pPropertyValues[i]); - } - else if (u16_strcmp(pPropertyNames[i], W("USE_ENTRYPOINT_FILTER")) == 0) { extern void ParseUseEntryPointFilter(LPCWSTR value); diff --git a/src/coreclr/vm/threads.cpp b/src/coreclr/vm/threads.cpp index 72a14b5a81b84d..ca44a56f3dab81 100644 --- a/src/coreclr/vm/threads.cpp +++ b/src/coreclr/vm/threads.cpp @@ -2052,38 +2052,12 @@ HANDLE Thread::CreateUtilityThread(Thread::StackSizeBucket stackSizeBucket, LPTH return hThread; } -// Represent the value of DEFAULT_STACK_SIZE as passed in the property bag to the host during construction -static unsigned long s_defaultStackSizeProperty = 0; - -void ParseDefaultStackSize(LPCWSTR valueStr) -{ - if (valueStr) - { - LPWSTR end; - errno = 0; - unsigned long value = u16_strtoul(valueStr, &end, 16); // Base 16 without a prefix - - if ((errno == ERANGE) // Parsed value doesn't fit in an unsigned long - || (valueStr == end) // No characters parsed - || (end == nullptr) // Unexpected condition (should never happen) - || (end[0] != 0)) // Unprocessed terminal characters - { - ThrowHR(E_INVALIDARG); - } - else - { - s_defaultStackSizeProperty = value; - } - } -} - SIZE_T GetDefaultStackSizeSetting() { static DWORD s_defaultStackSizeEnv = CLRConfig::GetConfigValue(CLRConfig::EXTERNAL_Thread_DefaultStackSize); static DWORD s_defaultStackSizeProp = Configuration::GetKnobDWORDValue(W("System.Threading.DefaultStackSize"), 0); - uint64_t value = s_defaultStackSizeEnv ? s_defaultStackSizeEnv - : (s_defaultStackSizeProperty ? s_defaultStackSizeProperty : s_defaultStackSizeProp); + uint64_t value = s_defaultStackSizeEnv ? s_defaultStackSizeEnv : s_defaultStackSizeProp; SIZE_T minStack = 0x10000; // 64K - Somewhat arbitrary minimum thread stack size SIZE_T maxStack = 0x80000000; // 2G - Somewhat arbitrary maximum thread stack size