]> git.sesse.net Git - ffmpeg/commitdiff
avcodec/cavsdec: Set ret on errors in decode_pic()
authorMichael Niedermayer <michael@niedermayer.cc>
Thu, 17 Oct 2019 11:05:24 +0000 (13:05 +0200)
committerMichael Niedermayer <michael@niedermayer.cc>
Thu, 17 Oct 2019 11:17:18 +0000 (13:17 +0200)
Fixes regression and fate failure on some machienes

Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
libavcodec/cavsdec.c
tests/ref/fate/cavs

index 436f902ab30840bba91876e938c18f100976ad70..aaed8071961f33db6c4c45da95f50906673dd931 100644 (file)
@@ -1102,15 +1102,19 @@ static int decode_pic(AVSContext *h)
             if (check_for_slice(h))
                 skip_count = -1;
             if (h->skip_mode_flag && (skip_count < 0)) {
-                if (get_bits_left(&h->gb) < 1)
+                if (get_bits_left(&h->gb) < 1) {
+                    ret = AVERROR_INVALIDDATA;
                     break;
+                }
                 skip_count = get_ue_golomb(&h->gb);
             }
             if (h->skip_mode_flag && skip_count--) {
                 decode_mb_p(h, P_SKIP);
             } else {
-                if (get_bits_left(&h->gb) < 1)
+                if (get_bits_left(&h->gb) < 1) {
+                    ret = AVERROR_INVALIDDATA;
                     break;
+                }
                 mb_type = get_ue_golomb(&h->gb) + P_SKIP + h->skip_mode_flag;
                 if (mb_type > P_8X8)
                     ret = decode_mb_i(h, mb_type - P_8X8 - 1);
@@ -1125,15 +1129,19 @@ static int decode_pic(AVSContext *h)
             if (check_for_slice(h))
                 skip_count = -1;
             if (h->skip_mode_flag && (skip_count < 0)) {
-                if (get_bits_left(&h->gb) < 1)
+                if (get_bits_left(&h->gb) < 1) {
+                    ret = AVERROR_INVALIDDATA;
                     break;
+                }
                 skip_count = get_ue_golomb(&h->gb);
             }
             if (h->skip_mode_flag && skip_count--) {
                 ret = decode_mb_b(h, B_SKIP);
             } else {
-                if (get_bits_left(&h->gb) < 1)
+                if (get_bits_left(&h->gb) < 1) {
+                    ret = AVERROR_INVALIDDATA;
                     break;
+                }
                 mb_type = get_ue_golomb(&h->gb) + B_SKIP + h->skip_mode_flag;
                 if (mb_type > B_8X8)
                     ret = decode_mb_i(h, mb_type - B_8X8 - 1);
index 4c3d127fa3acba2d00939f03cbf7bdca65e68a48..89c2b4b0b4f232f2cf19dc36b59d37068ae978d5 100644 (file)
 0,        166,        166,        1,   622080, 0x05496a5d
 0,        167,        167,        1,   622080, 0xdcb4cee8
 0,        168,        168,        1,   622080, 0xb41172e5
-0,        169,        169,        1,   622080, 0x26146e0b
+0,        169,        169,        1,   622080, 0x84ff3af9