aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndreas Rheinhardt <andreas.rheinhardt@gmail.com>2020-10-10 20:11:49 +0200
committerAndreas Rheinhardt <andreas.rheinhardt@gmail.com>2020-10-10 20:49:26 +0200
commit8969b9aa061790a5e87694aab17741cc7647d099 (patch)
tree880987e3c50da4c9fd2e7e4030d1e95d120f74ec
parent07185f331e2414ddff80df342f2ff7aaca08e26d (diff)
downloadffmpeg-8969b9aa061790a5e87694aab17741cc7647d099.tar.gz
avcodec/sheervideo: Don't leave context in inconsistent state upon error
This has happened if the format changed midstream and if the new packet is so small that it is instantaneously rejected: In this case the VLC tables were for the new format, although the context says that they are still the ones for the old format. It can also happen if the format changed midstream and the allocation of the new tables fails. If the next packet is a packet for the old format, the decoder thinks it already has the correct VLC tables, leading to a segfault. Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@gmail.com>
-rw-r--r--libavcodec/sheervideo.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/libavcodec/sheervideo.c b/libavcodec/sheervideo.c
index e1a203d361..099e5fdf22 100644
--- a/libavcodec/sheervideo.c
+++ b/libavcodec/sheervideo.c
@@ -2034,16 +2034,17 @@ static int decode_frame(AVCodecContext *avctx,
return AVERROR_PATCHWELCOME;
}
- if (avpkt->size < 20 + avctx->width * avctx->height / 16) {
- av_log(avctx, AV_LOG_ERROR, "Input packet too small\n");
- return AVERROR_INVALIDDATA;
- }
-
if (s->format != format) {
- if (ret < 0)
+ if (ret < 0) {
+ s->format = 0;
return ret;
+ }
s->format = format;
}
+ if (avpkt->size < 20 + avctx->width * avctx->height / 16) {
+ av_log(avctx, AV_LOG_ERROR, "Input packet too small\n");
+ return AVERROR_INVALIDDATA;
+ }
p->pict_type = AV_PICTURE_TYPE_I;
p->key_frame = 1;