From 142c550963cc6a144dbd9e36ee17c4e1dc494ba9 Mon Sep 17 00:00:00 2001 From: _ClearEdge <97910292+0x-FADED@users.noreply.github.com> Date: Fri, 2 May 2025 09:52:45 +0900 Subject: [PATCH] fix mi_clz and mi_ctz having undefined behavior due to uninitialized variable fixes: - issues while compiled with /os(like frozen program at startup) - sometimes mi_bchunk_try_clearNX or mi_bchunk_try_find_and_clearNX fails even if it's compiled without /os while program is running --- include/mimalloc/bits.h | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/include/mimalloc/bits.h b/include/mimalloc/bits.h index 1814853a..d0f27821 100644 --- a/include/mimalloc/bits.h +++ b/include/mimalloc/bits.h @@ -236,8 +236,8 @@ static inline size_t mi_ctz(size_t x) { #elif defined(_MSC_VER) && MI_ARCH_X64 && defined(__BMI1__) return (x!=0 ? _tzcnt_u64(x) : MI_SIZE_BITS); // ensure it still works on non-BMI1 cpu's as well #elif defined(_MSC_VER) && (MI_ARCH_X64 || MI_ARCH_X86 || MI_ARCH_ARM64 || MI_ARCH_ARM32) - unsigned long idx; - return (mi_msc_builtinz(_BitScanForward)(&idx, x) ? (size_t)idx : MI_SIZE_BITS); + if (x != 0) { unsigned long idx; mi_msc_builtinz(_BitScanForward)(&idx, x); return (size_t)idx; } + return MI_SIZE_BITS; #elif defined(__GNUC__) && MI_ARCH_X86 size_t r = MI_SIZE_BITS; __asm ("bsf\t%1, %0" : "+r"(r) : "r"(x) : "cc"); @@ -260,8 +260,8 @@ static inline size_t mi_clz(size_t x) { #elif mi_has_builtinz(clz) return (x!=0 ? (size_t)mi_builtinz(clz)(x) : MI_SIZE_BITS); #elif defined(_MSC_VER) && (MI_ARCH_X64 || MI_ARCH_X86 || MI_ARCH_ARM64 || MI_ARCH_ARM32) - unsigned long idx; - return (mi_msc_builtinz(_BitScanReverse)(&idx, x) ? MI_SIZE_BITS - 1 - (size_t)idx : MI_SIZE_BITS); + if (x != 0) { unsigned long idx; mi_msc_builtinz(_BitScanReverse)(&idx, x); return (size_t)(MI_SIZE_BITS - 1 - idx); } + return MI_SIZE_BITS; #elif defined(__GNUC__) && (MI_ARCH_X64 || MI_ARCH_X86) if (x==0) return MI_SIZE_BITS; size_t r; @@ -363,4 +363,4 @@ static inline uint32_t mi_rotl32(uint32_t x, uint32_t r) { } -#endif // MI_BITS_H +#endif // MI_BITS_H \ No newline at end of file