summaryrefslogtreecommitdiffstats
path: root/media/libstagefright/codecs
diff options
context:
space:
mode:
authorMarco Nelissen <marcone@google.com>2013-04-15 16:28:49 -0700
committerMarco Nelissen <marcone@google.com>2013-04-15 16:28:49 -0700
commit94b66227ff5a57dd810aafa7b3aa810b9a185b8d (patch)
tree8bd962566759d631c8182d07e23bcd253f6b2cae /media/libstagefright/codecs
parentf4c873a64db2d5d2d74ca596e7482627dd6b4238 (diff)
downloadframeworks_av-94b66227ff5a57dd810aafa7b3aa810b9a185b8d.zip
frameworks_av-94b66227ff5a57dd810aafa7b3aa810b9a185b8d.tar.gz
frameworks_av-94b66227ff5a57dd810aafa7b3aa810b9a185b8d.tar.bz2
Fix Vorbis decoder reset
b/8543366 Change-Id: I9f32e96fdfc355cf444259a7c40554e2de184728
Diffstat (limited to 'media/libstagefright/codecs')
-rw-r--r--media/libstagefright/codecs/vorbis/dec/SoftVorbis.cpp13
1 files changed, 12 insertions, 1 deletions
diff --git a/media/libstagefright/codecs/vorbis/dec/SoftVorbis.cpp b/media/libstagefright/codecs/vorbis/dec/SoftVorbis.cpp
index 922ac61..4115324 100644
--- a/media/libstagefright/codecs/vorbis/dec/SoftVorbis.cpp
+++ b/media/libstagefright/codecs/vorbis/dec/SoftVorbis.cpp
@@ -411,8 +411,19 @@ void SoftVorbis::onPortFlushCompleted(OMX_U32 portIndex) {
}
void SoftVorbis::onReset() {
+ mInputBufferCount = 0;
mNumFramesOutput = 0;
- vorbis_dsp_restart(mState);
+ if (mState != NULL) {
+ vorbis_dsp_clear(mState);
+ delete mState;
+ mState = NULL;
+ }
+
+ if (mVi != NULL) {
+ vorbis_info_clear(mVi);
+ delete mVi;
+ mVi = NULL;
+ }
}
void SoftVorbis::onPortEnableCompleted(OMX_U32 portIndex, bool enabled) {