[FFmpeg-cvslog] jpegdec: be less picky on padding

Michael Niedermayer git at videolan.org
Thu Mar 14 22:17:22 CET 2013


ffmpeg | branch: release/1.2 | Michael Niedermayer <michaelni at gmx.at> | Thu Mar 14 17:20:44 2013 +0100| [7c6c5767eb6fc45a67dd7930fa5567b8c40d5950] | committer: Carl Eugen Hoyos

jpegdec: be less picky on padding

Fixes Ticket2353

Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
(cherry picked from commit 3c24fbbf651d4ec28eccfd7ef05a2595a11dd55a)

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=7c6c5767eb6fc45a67dd7930fa5567b8c40d5950
---

 libavcodec/mjpegdec.c |    5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

diff --git a/libavcodec/mjpegdec.c b/libavcodec/mjpegdec.c
index f3080d9..54090e5 100644
--- a/libavcodec/mjpegdec.c
+++ b/libavcodec/mjpegdec.c
@@ -747,7 +747,9 @@ static void handle_rstn(MJpegDecodeContext *s, int nb_components)
 
         i = 8 + ((-get_bits_count(&s->gb)) & 7);
         /* skip RSTn */
-        if (s->restart_count == 0 && show_bits(&s->gb, i) == (1 << i) - 1) {
+        if (s->restart_count == 0) {
+          if(   show_bits(&s->gb, i) == (1 << i) - 1
+             || show_bits(&s->gb, i) == 0xFF) {
             int pos = get_bits_count(&s->gb);
             align_get_bits(&s->gb);
             while (get_bits_left(&s->gb) >= 8 && show_bits(&s->gb, 8) == 0xFF)
@@ -757,6 +759,7 @@ static void handle_rstn(MJpegDecodeContext *s, int nb_components)
                     s->last_dc[i] = 1024;
             } else
                 skip_bits_long(&s->gb, pos - get_bits_count(&s->gb));
+          }
         }
     }
 }



More information about the ffmpeg-cvslog mailing list