From 1e687ebc8b3f2fe7042978a343a77a67ee7db40d Mon Sep 17 00:00:00 2001 From: Chris Robinson Date: Sun, 13 Feb 2022 21:13:13 -0800 Subject: [PATCH] Force EAX calls to defer when the AL context is deferring --- alc/context.cpp | 25 ++++++++++++------------- 1 file changed, 12 insertions(+), 13 deletions(-) diff --git a/alc/context.cpp b/alc/context.cpp index c21bd1b9..69e42731 100644 --- a/alc/context.cpp +++ b/alc/context.cpp @@ -465,10 +465,11 @@ ALenum ALCcontext::eax_eax_set( { eax_initialize(); + constexpr auto deferred_flag = 0x80000000u; const auto eax_call = create_eax_call( false, property_set_id, - property_id, + property_id | (mDeferUpdates ? deferred_flag : 0u), property_source_id, property_value, property_value_size @@ -1281,22 +1282,20 @@ void ALCcontext::eax_set( eax_fail("Unsupported property id."); } - if (!eax_call.is_deferred()) + if(!eax_call.is_deferred()) { eax_apply_deferred(); - if(!mDeferUpdates) - { - mHoldUpdates.store(true, std::memory_order_release); - while((mUpdateCount.load(std::memory_order_acquire)&1) != 0) { - /* busy-wait */ - } - if(std::exchange(mPropsDirty, false)) - UpdateContextProps(this); - UpdateAllSourceProps(this); - - mHoldUpdates.store(false, std::memory_order_release); + mHoldUpdates.store(true, std::memory_order_release); + while((mUpdateCount.load(std::memory_order_acquire)&1) != 0) { + /* busy-wait */ } + + if(std::exchange(mPropsDirty, false)) + UpdateContextProps(this); + UpdateAllSourceProps(this); + + mHoldUpdates.store(false, std::memory_order_release); } }