summaryrefslogtreecommitdiff
path: root/indra/llaudio
diff options
context:
space:
mode:
authorcallum <none@none>2013-04-19 16:29:11 -0700
committercallum <none@none>2013-04-19 16:29:11 -0700
commitd9de58b46ab4c5e248b8dd7b3f79e1672f1f215a (patch)
treedb85ce20dff43cf3d8143aa966cc9b2107b4cff8 /indra/llaudio
parenta1ca90f89327c6423acb7328eebf9d8afd49668d (diff)
OPEN-173 FIX FMODEx Music stutters once every few seconds (OSS patch via Latif Khalifa & Siana Gearz)
Diffstat (limited to 'indra/llaudio')
-rw-r--r--indra/llaudio/llstreamingaudio_fmodex.cpp39
-rw-r--r--indra/llaudio/llstreamingaudio_fmodex.h2
2 files changed, 29 insertions, 12 deletions
diff --git a/indra/llaudio/llstreamingaudio_fmodex.cpp b/indra/llaudio/llstreamingaudio_fmodex.cpp
index 4a74267650..266fa2f57b 100644
--- a/indra/llaudio/llstreamingaudio_fmodex.cpp
+++ b/indra/llaudio/llstreamingaudio_fmodex.cpp
@@ -153,7 +153,6 @@ void LLStreamingAudio_FMODEX::update()
// Reset volume to previously set volume
setGain(getGain());
mFMODInternetStreamChannelp->setPaused(false);
- mLastStarved.stop();
}
}
else if(open_state == FMOD_OPENSTATE_ERROR)
@@ -168,21 +167,43 @@ void LLStreamingAudio_FMODEX::update()
if(mFMODInternetStreamChannelp->getCurrentSound(&sound) == FMOD_OK && sound)
{
+ FMOD_TAG tag;
+ S32 tagcount, dirtytagcount;
+
+ if(sound->getNumTags(&tagcount, &dirtytagcount) == FMOD_OK && dirtytagcount)
+ {
+ for(S32 i = 0; i < tagcount; ++i)
+ {
+ if(sound->getTag(NULL, i, &tag)!=FMOD_OK)
+ continue;
+
+ if (tag.type == FMOD_TAGTYPE_FMOD)
+ {
+ if (!strcmp(tag.name, "Sample Rate Change"))
+ {
+ llinfos << "Stream forced changing sample rate to " << *((float *)tag.data) << llendl;
+ mFMODInternetStreamChannelp->setFrequency(*((float *)tag.data));
+ }
+ continue;
+ }
+ }
+ }
+
if(starving)
{
- if(!mLastStarved.getStarted())
+ bool paused = false;
+ mFMODInternetStreamChannelp->getPaused(&paused);
+ if(!paused)
{
- llinfos << "Stream starvation detected! Muting stream audio until it clears." << llendl;
+ llinfos << "Stream starvation detected! Pausing stream until buffer nearly full." << llendl;
llinfos << " (diskbusy="<<diskbusy<<")" << llendl;
llinfos << " (progress="<<progress<<")" << llendl;
- mFMODInternetStreamChannelp->setMute(true);
+ mFMODInternetStreamChannelp->setPaused(true);
}
- mLastStarved.start();
}
- else if(mLastStarved.getStarted() && mLastStarved.getElapsedTimeF32() > 1.f)
+ else if(progress > 80)
{
- mLastStarved.stop();
- mFMODInternetStreamChannelp->setMute(false);
+ mFMODInternetStreamChannelp->setPaused(false);
}
}
}
@@ -190,8 +211,6 @@ void LLStreamingAudio_FMODEX::update()
void LLStreamingAudio_FMODEX::stop()
{
- mLastStarved.stop();
-
if (mFMODInternetStreamChannelp)
{
mFMODInternetStreamChannelp->setPaused(true);
diff --git a/indra/llaudio/llstreamingaudio_fmodex.h b/indra/llaudio/llstreamingaudio_fmodex.h
index 42b6b3aaa8..1dee18ae7d 100644
--- a/indra/llaudio/llstreamingaudio_fmodex.h
+++ b/indra/llaudio/llstreamingaudio_fmodex.h
@@ -67,8 +67,6 @@ private:
std::string mURL;
F32 mGain;
-
- LLTimer mLastStarved;
};