[FFmpeg-cvslog] libstagefright: set the correct frame size
Mohamed Naufal
git at videolan.org
Fri Oct 7 15:38:33 CEST 2011
ffmpeg | branch: master | Mohamed Naufal <naufal22 at gmail.com> | Fri Oct 7 17:19:08 2011 +0530| [09a49e8919ddd31d0255f46ad1c3d19be7bb5ed1] | committer: Mohamed Naufal
libstagefright: set the correct frame size
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=09a49e8919ddd31d0255f46ad1c3d19be7bb5ed1
---
libavcodec/libstagefright.cpp | 6 ++++--
1 files changed, 4 insertions(+), 2 deletions(-)
diff --git a/libavcodec/libstagefright.cpp b/libavcodec/libstagefright.cpp
index 2022bab..6989357 100644
--- a/libavcodec/libstagefright.cpp
+++ b/libavcodec/libstagefright.cpp
@@ -311,7 +311,7 @@ static int Stagefright_decode_frame(AVCodecContext *avctx, void *data,
frame = (Frame*)av_mallocz(sizeof(Frame));
if (avpkt->data) {
frame->status = OK;
- frame->size = orig_size;
+ frame->size = avpkt->size;
// Stagefright can't handle negative timestamps -
// if needed, work around this by offsetting them manually?
if (avpkt->pts >= 0)
@@ -324,8 +324,10 @@ static int Stagefright_decode_frame(AVCodecContext *avctx, void *data,
}
uint8_t *ptr = avpkt->data;
// The OMX.SEC decoder fails without this.
- if (avpkt->size == orig_size + avctx->extradata_size)
+ if (avpkt->size == orig_size + avctx->extradata_size) {
ptr += avctx->extradata_size;
+ frame->size = orig_size;
+ }
memcpy(frame->buffer, ptr, orig_size);
} else {
frame->status = ERROR_END_OF_STREAM;
More information about the ffmpeg-cvslog
mailing list