Fix JPEG-LS encoder 0xff-escaping writing too much or uninitialized data.
authorReimar Döffinger <Reimar.Doeffinger@gmx.de>
Mon, 11 Dec 2006 20:18:36 +0000 (20:18 +0000)
committerReimar Döffinger <Reimar.Doeffinger@gmx.de>
Mon, 11 Dec 2006 20:18:36 +0000 (20:18 +0000)
Originally committed as revision 7284 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavcodec/jpeg_ls.c
tests/ffmpeg.regression.ref
tests/rotozoom.regression.ref

index 1b4df2b1a00e8511ba2e2bbe54542546fb1c9114..4629176ada723e4d385e264b5af61d69dd4de662 100644 (file)
@@ -804,11 +804,16 @@ static int encode_picture_ls(AVCodecContext *avctx, unsigned char *buf, int buf_
     av_free(zero);
     av_free(state);
 
+    // the specification says that after doing 0xff escaping unused bits in the
+    // last byte must be set to 0, so just append 7 "optional" zero-bits to
+    // avoid special-casing.
+    put_bits(&pb2, 7, 0);
+    size = put_bits_count(&pb2);
     flush_put_bits(&pb2);
     /* do escape coding */
-    size = put_bits_count(&pb2) >> 3;
     init_get_bits(&gb, buf2, size);
-    while(get_bits_count(&gb) < size * 8){
+    size -= 7;
+    while(get_bits_count(&gb) < size){
         int v;
         v = get_bits(&gb, 8);
         put_bits(&pb, 8, v);
index 9db847a1fc3a1fbbc9be577186f6bfd496148455..3c6f9f7a1e675933cb2eb7e846e821a1491ef883 100644 (file)
@@ -105,8 +105,8 @@ stddev:  7.93 PSNR:30.13 bytes:7602176
 6264498 ./data/a-ljpeg.avi
 799d3db687f6cdd7a837ec156efc171f *./data/out.yuv
 stddev:  0.00 PSNR:99.99 bytes:7602176
-8b9359781a7e87d09af1b1c9a536cb75 *./data/a-jpegls.avi
-9086694 ./data/a-jpegls.avi
+dca9d700da7857217408c310c501b9bc *./data/a-jpegls.avi
+9086676 ./data/a-jpegls.avi
 0f8637e9b861230aff9894825af83720 *./data/out.yuv
 stddev:  2.84 PSNR:39.04 bytes:7602176
 7eee6367442884321e27d15a26bc032a *./data/a-rv10.rm
index 91dbe27d9bf9e601891bb89f8a58c8234abedd11..8e7ec32f25bbd305c625031ac22baf78fceba2b2 100644 (file)
@@ -105,8 +105,8 @@ bc0d8c868c1a05db0ff03f41768f6c5e *./data/a-ljpeg.avi
 4766558 ./data/a-ljpeg.avi
 dde5895817ad9d219f79a52d0bdfb001 *./data/out.yuv
 stddev:  0.00 PSNR:99.99 bytes:7602176
-8a2f3984a27a7513545cf98bc05fd066 *./data/a-jpegls.avi
-8334508 ./data/a-jpegls.avi
+f67cd488dfd06c03ad1d6d94d81b80c8 *./data/a-jpegls.avi
+8334488 ./data/a-jpegls.avi
 a63d4e3ea1f0b0c0d44821da9e09b8f4 *./data/out.yuv
 stddev:  0.67 PSNR:51.57 bytes:7602176
 989a42671603dc1a7e6b156dccf0e820 *./data/a-rv10.rm