diff options
author | Chris Robinson <[email protected]> | 2011-07-16 02:41:02 -0700 |
---|---|---|
committer | Chris Robinson <[email protected]> | 2011-07-16 02:41:02 -0700 |
commit | da2429a1d0ad184abe24f61aa7e064b81026651c (patch) | |
tree | 0f11fd679964b02b318a9e556e3051c9c91b5aad /Alc | |
parent | 54b5f35125d1b85c3e16c292a9829e9d652d2e38 (diff) |
Allow effect slots to be updated asynchronously
Updates when the slot changes effect type is still sychronous, however, to
ensure a proper state for the Process method call. Fixing this would
essentially require all effects to work from the same state.
Diffstat (limited to 'Alc')
-rw-r--r-- | Alc/ALc.c | 5 | ||||
-rw-r--r-- | Alc/ALu.c | 6 |
2 files changed, 9 insertions, 2 deletions
@@ -1414,6 +1414,7 @@ static ALCboolean UpdateDeviceParams(ALCdevice *device, const ALCint *attrList) ALCcontext *context = device->Contexts[i]; ALsizei pos; + context->UpdateSources = AL_FALSE; for(pos = 0;pos < context->EffectSlotMap.size;pos++) { ALeffectslot *slot = context->EffectSlotMap.array[pos].value; @@ -1425,6 +1426,7 @@ static ALCboolean UpdateDeviceParams(ALCdevice *device, const ALCint *attrList) device->Flags &= ~DEVICE_RUNNING; return ALC_FALSE; } + slot->NeedsUpdate = AL_FALSE; ALEffect_Update(slot->EffectState, context, &slot->effect); } @@ -1441,10 +1443,9 @@ static ALCboolean UpdateDeviceParams(ALCdevice *device, const ALCint *attrList) source->Send[s].WetFilter.filter = 0; s++; } - ALsource_Update(source, context); source->NeedsUpdate = AL_FALSE; + ALsource_Update(source, context); } - context->UpdateSources = AL_FALSE; } UnlockDevice(device); @@ -1031,6 +1031,12 @@ ALvoid aluMixData(ALCdevice *device, ALvoid *buffer, ALsizei size) ALEffectSlot->PendingClicks[i] = 0.0f; } + if(ALEffectSlot->NeedsUpdate) + { + ALEffectSlot->NeedsUpdate = AL_FALSE; + ALEffect_Update(ALEffectSlot->EffectState, *ctx, &ALEffectSlot->effect); + } + ALEffect_Process(ALEffectSlot->EffectState, ALEffectSlot, SamplesToDo, ALEffectSlot->WetBuffer, device->DryBuffer); |