Compare commits

..

2 commits

Author SHA1 Message Date
_ClearEdge
6a300fd462
Merge ab4ecac1ec into 61f3ffd2a6 2025-05-02 09:41:18 +00:00
_ClearEdge
ab4ecac1ec 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
2025-05-02 18:41:12 +09:00

View file

@ -236,9 +236,9 @@ 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 = MI_SIZE_BITS;
if (x!=0) { mi_msc_builtinz(_BitScanForward)(&idx, x); }
return (size_t)idx;
unsigned long idx = MI_SIZE_BITS;
if (x != 0) { 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");
@ -261,9 +261,9 @@ 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 = MI_SIZE_BITS;
if (x != 0) { mi_msc_builtinz(_BitScanReverse)(&idx, x); }
return idx ? (MI_SIZE_BITS - 1 - idx) : MI_SIZE_BITS;
unsigned long idx = MI_SIZE_BITS;
if (x != 0) { 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;