diff options
Diffstat (limited to 'al')
-rw-r--r-- | al/auxeffectslot.cpp | 11 | ||||
-rw-r--r-- | al/auxeffectslot.h | 3 |
2 files changed, 3 insertions, 11 deletions
diff --git a/al/auxeffectslot.cpp b/al/auxeffectslot.cpp index 7c20ec64..00da51f6 100644 --- a/al/auxeffectslot.cpp +++ b/al/auxeffectslot.cpp @@ -640,7 +640,6 @@ ALeffectslot::~ALeffectslot() ALeffectslotProps *props{Params.Update.load()}; if(props) { - if(props->State) props->State->release(); TRACE("Freed unapplied AuxiliaryEffectSlot update %p\n", decltype(std::declval<void*>()){props}); delete props; @@ -707,8 +706,6 @@ ALenum ALeffectslot::initEffect(ALeffect *effect, ALCcontext *context) ALeffectslotProps *props{context->mFreeEffectslotProps.load()}; while(props) { - if(props->State) - props->State->release(); props->State = nullptr; props = props->next.load(std::memory_order_relaxed); } @@ -741,9 +738,8 @@ void ALeffectslot::updateProps(ALCcontext *context) /* Swap out any stale effect state object there may be in the container, to * delete it. */ - EffectState *oldstate{props->State}; Effect.State->add_ref(); - props->State = Effect.State; + props->State.reset(Effect.State); /* Set the new container for updating internal parameters. */ props = Params.Update.exchange(props, std::memory_order_acq_rel); @@ -752,14 +748,9 @@ void ALeffectslot::updateProps(ALCcontext *context) /* If there was an unused update container, put it back in the * freelist. */ - if(props->State) - props->State->release(); props->State = nullptr; AtomicReplaceHead(context->mFreeEffectslotProps, props); } - - if(oldstate) - oldstate->release(); } void UpdateAllEffectSlotProps(ALCcontext *context) diff --git a/al/auxeffectslot.h b/al/auxeffectslot.h index 5f1e6aa8..12411ede 100644 --- a/al/auxeffectslot.h +++ b/al/auxeffectslot.h @@ -12,6 +12,7 @@ #include "almalloc.h" #include "atomic.h" #include "effects/base.h" +#include "intrusive_ptr.h" #include "vector.h" struct ALeffect; @@ -29,7 +30,7 @@ struct ALeffectslotProps { ALenum Type; EffectProps Props; - EffectState *State; + al::intrusive_ptr<EffectState> State; std::atomic<ALeffectslotProps*> next; |