From 36e57f434859d96f3749c61414cf5eee6723f706 Mon Sep 17 00:00:00 2001 From: Jan Sikorski Date: Tue, 14 Nov 2023 16:09:13 +0100 Subject: [PATCH] Fix MVKBitArray::getIndexOfFirstSetBit() skipping over entries. Reset startIndex so that we only skip over bits in the section that contains it. --- MoltenVK/MoltenVK/Utility/MVKBitArray.h | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/MoltenVK/MoltenVK/Utility/MVKBitArray.h b/MoltenVK/MoltenVK/Utility/MVKBitArray.h index 46bf41cdf..a1441bc5e 100755 --- a/MoltenVK/MoltenVK/Utility/MVKBitArray.h +++ b/MoltenVK/MoltenVK/Utility/MVKBitArray.h @@ -90,7 +90,11 @@ class MVKBitArray { * and optionally clears that bit. If no bits are set, returns the size() of this bit array. */ size_t getIndexOfFirstSetBit(size_t startIndex, bool shouldClear) { - size_t startSecIdx = std::max(getIndexOfSection(startIndex), _clearedSectionCount); + size_t startSecIdx = getIndexOfSection(startIndex); + if (startSecIdx < _clearedSectionCount) { + startSecIdx = _clearedSectionCount; + startIndex = 0; + } size_t bitIdx = startSecIdx << SectionMaskSize; size_t secCnt = getSectionCount(); for (size_t secIdx = startSecIdx; secIdx < secCnt; secIdx++) { @@ -101,6 +105,7 @@ class MVKBitArray { if (shouldClear) { clearBit(bitIdx); } return std::min(bitIdx, _bitCount); } + startIndex = 0; } return std::min(bitIdx, _bitCount); }