From: Steven Johnson <> Date: Fri, 24 Nov 2006 00:16:32 +0000 (+0000) Subject: Implement DELTA_FLI opcodes correctly. Patch by Steven Johnson X-Git-Tag: v0.5~10913 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=fce2200da05d66d59f3e34e5af836a7c7550cb44;p=platform%2Fupstream%2Flibav.git Implement DELTA_FLI opcodes correctly. Patch by Steven Johnson Originally committed as revision 7165 to svn://svn.ffmpeg.org/ffmpeg/trunk --- diff --git a/libavcodec/flicvideo.c b/libavcodec/flicvideo.c index 6a80a15..9cbc4f3 100644 --- a/libavcodec/flicvideo.c +++ b/libavcodec/flicvideo.c @@ -246,9 +246,15 @@ static int flic_decode_frame_8BPP(AVCodecContext *avctx, while (compressed_lines > 0) { line_packets = LE_16(&buf[stream_ptr]); stream_ptr += 2; - if (line_packets < 0) { + if ((line_packets & 0xC000) == 0xC000) { + // line skip opcode line_packets = -line_packets; y_ptr += line_packets * s->frame.linesize[0]; + } else if ((line_packets & 0xC000) == 0x4000) { + av_log(avctx, AV_LOG_ERROR, "Undefined opcode (%x) in DELTA_FLI\n", line_packets); + } else if ((line_packets & 0xC000) == 0x8000) { + // "last byte" opcode + pixels[y_ptr + s->frame.linesize[0] - 1] = line_packets & 0xff; } else { compressed_lines--; pixel_ptr = y_ptr;