diff --git a/src/bgfx.cpp b/src/bgfx.cpp index c9cbfaa29c..936d2df0f3 100644 --- a/src/bgfx.cpp +++ b/src/bgfx.cpp @@ -1247,11 +1247,7 @@ namespace bgfx UniformBuffer* uniformBuffer = m_frame->m_uniformBuffer[m_uniformIdx]; m_uniformEnd = uniformBuffer->getPos(); - m_key.m_program = isValid(_program) - ? _program - : ProgramHandle{0} - ; - + m_key.m_program = _program; m_key.m_view = _id; SortKey::Enum type = SortKey::SortProgram; diff --git a/src/bgfx_p.h b/src/bgfx_p.h index 17f0a1aa68..1e85955035 100644 --- a/src/bgfx_p.h +++ b/src/bgfx_p.h @@ -1161,23 +1161,33 @@ namespace bgfx uint64_t type = _key & kSortKeyDrawTypeMask; if (type == kSortKeyDrawTypeDepth) { - m_program.idx = uint16_t( (_key & kSortKeyDraw1ProgramMask) >> kSortKeyDraw1ProgramShift); + m_program = decodeProgram( _key, kSortKeyDraw1ProgramMask, kSortKeyDraw1ProgramShift); return false; } else if (type == kSortKeyDrawTypeSequence) { - m_program.idx = uint16_t( (_key & kSortKeyDraw2ProgramMask) >> kSortKeyDraw2ProgramShift); + m_program = decodeProgram( _key, kSortKeyDraw2ProgramMask, kSortKeyDraw2ProgramShift); return false; } - m_program.idx = uint16_t( (_key & kSortKeyDraw0ProgramMask) >> kSortKeyDraw0ProgramShift); + m_program = decodeProgram( _key, kSortKeyDraw0ProgramMask, kSortKeyDraw0ProgramShift); return false; // draw } - m_program.idx = uint16_t( (_key & kSortKeyComputeProgramMask) >> kSortKeyComputeProgramShift); + m_program = decodeProgram( _key, kSortKeyComputeProgramMask, kSortKeyComputeProgramShift); return true; // compute } + static ProgramHandle decodeProgram(uint64_t _key, uint64_t _mask, uint8_t _shift) + { + uint16_t idx = uint16_t( (_key & _mask) >> _shift); + if (idx == (_mask >> _shift)) + { + return ProgramHandle{kInvalidHandle}; + } + return ProgramHandle{idx}; + } + static ViewId decodeView(uint64_t _key) { return ViewId( (_key & kSortKeyViewMask) >> kSortKeyViewBitShift);