diff options
author | Marco Nelissen <marcone@google.com> | 2013-04-15 16:28:49 -0700 |
---|---|---|
committer | Marco Nelissen <marcone@google.com> | 2013-04-15 16:28:49 -0700 |
commit | 98391d3e9c0188d477fab6044d5259eeb0014113 (patch) | |
tree | 26ff27f545bd6dbf9276410bdd95f7bd9f6de533 /media/libstagefright/codecs | |
parent | d961ae47cbc741b0e3d6f038ae0018b7f2a7424e (diff) | |
download | frameworks_av-98391d3e9c0188d477fab6044d5259eeb0014113.zip frameworks_av-98391d3e9c0188d477fab6044d5259eeb0014113.tar.gz frameworks_av-98391d3e9c0188d477fab6044d5259eeb0014113.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.cpp | 13 |
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) { |