aboutsummaryrefslogtreecommitdiffstats
path: root/al/source.cpp
diff options
context:
space:
mode:
authorChris Robinson <[email protected]>2022-02-14 04:18:48 -0800
committerChris Robinson <[email protected]>2022-02-14 04:18:48 -0800
commite0f87c44c0fe320b1d6ad706033459d27e06a458 (patch)
tree1974f52b87b6797e11a26b7b48497772b4e5c709 /al/source.cpp
parentf9ed6f85c89a8ee194a56449eafbdcb311abd534 (diff)
Don't access a playing voice's mFlags outside of the mixer thread
It's updated asynchronously, and it's non-atomic, so it's unsafe to even read since the mixer thread may be modifying it.
Diffstat (limited to 'al/source.cpp')
-rw-r--r--al/source.cpp10
1 files changed, 2 insertions, 8 deletions
diff --git a/al/source.cpp b/al/source.cpp
index 9817674f..4e3fb3b5 100644
--- a/al/source.cpp
+++ b/al/source.cpp
@@ -427,7 +427,7 @@ al::optional<VoicePos> GetSampleOffset(al::deque<ALbufferQueueItem> &BufferList,
BufferFmt = item.mBuffer;
if(BufferFmt) break;
}
- if(!BufferFmt)
+ if(!BufferFmt || BufferFmt->mCallback)
return al::nullopt;
/* Get sample frame offset */
@@ -477,7 +477,7 @@ al::optional<VoicePos> GetSampleOffset(al::deque<ALbufferQueueItem> &BufferList,
if(item.mSampleLen > offset-totalBufferLen)
{
/* Offset is in this buffer */
- return al::make_optional(VoicePos{offset-totalBufferLen, frac, &item});
+ return VoicePos{offset-totalBufferLen, frac, &item};
}
totalBufferLen += item.mSampleLen;
}
@@ -1283,9 +1283,6 @@ void SetSourcefv(ALsource *Source, ALCcontext *Context, SourceProp prop,
if(Voice *voice{GetSourceVoice(Source, Context)})
{
- if(voice->mFlags.test(VoiceIsCallback))
- SETERR_RETURN(Context, AL_INVALID_VALUE,,
- "Source offset for callback is invalid");
auto vpos = GetSampleOffset(Source->mQueue, prop, values[0]);
if(!vpos) SETERR_RETURN(Context, AL_INVALID_VALUE,, "Invalid offset");
@@ -1506,9 +1503,6 @@ void SetSourceiv(ALsource *Source, ALCcontext *Context, SourceProp prop,
if(Voice *voice{GetSourceVoice(Source, Context)})
{
- if(voice->mFlags.test(VoiceIsCallback))
- SETERR_RETURN(Context, AL_INVALID_VALUE,,
- "Source offset for callback is invalid");
auto vpos = GetSampleOffset(Source->mQueue, prop, values[0]);
if(!vpos) SETERR_RETURN(Context, AL_INVALID_VALUE,, "Invalid source offset");