aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLuca Barbato <lu_zero@gentoo.org>2013-08-12 00:16:12 +0200
committerLuca Barbato <lu_zero@gentoo.org>2013-08-13 13:09:22 +0200
commitaae159a7cc4df7d0521901022b778c9da251c24e (patch)
tree7d201911bef235e427c3e2e268961ec7dd2e8a25
parent46dee21a3238a5d9dfeeb1108dbad0beaa677035 (diff)
downloadffmpeg-aae159a7cc4df7d0521901022b778c9da251c24e.tar.gz
nuv: Do not ignore lzo decompression failures
Update the fate reference since the last broken frame is not decoded anymore. Reported-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind CC: libav-stable@libav.org
-rw-r--r--libavcodec/nuv.c4
-rw-r--r--tests/ref/fate/nuv-rtjpeg1
2 files changed, 3 insertions, 2 deletions
diff --git a/libavcodec/nuv.c b/libavcodec/nuv.c
index 4d5063fad7..269bf8bfbb 100644
--- a/libavcodec/nuv.c
+++ b/libavcodec/nuv.c
@@ -200,8 +200,10 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *got_frame,
buf_size -= 12;
if (comptype == NUV_RTJPEG_IN_LZO || comptype == NUV_LZO) {
int outlen = c->decomp_size, inlen = buf_size;
- if (av_lzo1x_decode(c->decomp_buf, &outlen, buf, &inlen))
+ if (av_lzo1x_decode(c->decomp_buf, &outlen, buf, &inlen)) {
av_log(avctx, AV_LOG_ERROR, "error during lzo decompression\n");
+ return AVERROR_INVALIDDATA;
+ }
buf = c->decomp_buf;
buf_size = c->decomp_size;
}
diff --git a/tests/ref/fate/nuv-rtjpeg b/tests/ref/fate/nuv-rtjpeg
index e9286d6a6d..a5c9c4a6f3 100644
--- a/tests/ref/fate/nuv-rtjpeg
+++ b/tests/ref/fate/nuv-rtjpeg
@@ -7,4 +7,3 @@
0, 269, 269, 0, 460800, 0x4e091ee2
0, 302, 302, 0, 460800, 0x2ea88828
0, 335, 335, 0, 460800, 0x4b7f4df0
-0, 369, 369, 0, 460800, 0xb30eb322