https://git.reactos.org/?p=reactos.git;a=commitdiff;h=4ca68ffb1c8adef6484005ce457bfed7db82b8c3
commit 4ca68ffb1c8adef6484005ce457bfed7db82b8c3 Author: Timo Kreuzer <timo.kreu...@reactos.org> AuthorDate: Sat Nov 9 19:21:11 2024 +0200 Commit: Timo Kreuzer <timo.kreu...@reactos.org> CommitDate: Thu Jan 30 11:30:32 2025 +0200 [UCRT] Make __local_stdio_printf/scanf_options GCC compatible --- sdk/include/ucrt/corecrt_stdio_config.h | 16 ++++++---------- 1 file changed, 6 insertions(+), 10 deletions(-) diff --git a/sdk/include/ucrt/corecrt_stdio_config.h b/sdk/include/ucrt/corecrt_stdio_config.h index 88e041260d5..360a45824d6 100644 --- a/sdk/include/ucrt/corecrt_stdio_config.h +++ b/sdk/include/ucrt/corecrt_stdio_config.h @@ -82,24 +82,20 @@ _CRT_BEGIN_C_HEADER #endif #if _CRT_FUNCTIONS_REQUIRED - // This function must not be inlined into callers to avoid ODR violations. The - // static local variable has different names in C and in C++ translation units. + __declspec(selectany) unsigned __int64 __local_stdio_printf_options_storage; _Check_return_ _Ret_notnull_ _CRT_INLINE_PURE_SECURITYCRITICAL_ATTRIBUTE - __declspec(noinline) __inline unsigned __int64* __CRTDECL __local_stdio_printf_options(void) + __inline unsigned __int64* __CRTDECL __local_stdio_printf_options(void) { - static unsigned __int64 _OptionsStorage; - return &_OptionsStorage; + return &__local_stdio_printf_options_storage; } - // This function must not be inlined into callers to avoid ODR violations. The - // static local variable has different names in C and in C++ translation units. + __declspec(selectany) unsigned __int64 __local_stdio_scanf_options_storage; _Check_return_ _Ret_notnull_ _CRT_INLINE_PURE_SECURITYCRITICAL_ATTRIBUTE - __declspec(noinline) __inline unsigned __int64* __CRTDECL __local_stdio_scanf_options(void) + __inline unsigned __int64* __CRTDECL __local_stdio_scanf_options(void) { - static unsigned __int64 _OptionsStorage; - return &_OptionsStorage; + return &__local_stdio_scanf_options_storage; } #endif