[FFmpeg-cvslog] Support solid gray frames when decoding Lagarith.

Carl Eugen Hoyos git at videolan.org
Tue Jan 22 20:20:49 CET 2013


ffmpeg | branch: master | Carl Eugen Hoyos <cehoyos at ag.or.at> | Tue Jan 22 20:17:53 2013 +0100| [40297a8bdb69844aef780f7e9f2e23700d9d6005] | committer: Carl Eugen Hoyos

Support solid gray frames when decoding Lagarith.

Fixes bug 431.

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

 libavcodec/lagarith.c |   15 +++++++++++++++
 1 file changed, 15 insertions(+)

diff --git a/libavcodec/lagarith.c b/libavcodec/lagarith.c
index 486e326..d5470a5 100644
--- a/libavcodec/lagarith.c
+++ b/libavcodec/lagarith.c
@@ -535,6 +535,14 @@ static int lag_decode_frame(AVCodecContext *avctx,
     switch (frametype) {
     case FRAME_SOLID_RGBA:
         avctx->pix_fmt = AV_PIX_FMT_RGB32;
+    case FRAME_SOLID_GRAY:
+        if (frametype == FRAME_SOLID_GRAY)
+            if (avctx->bits_per_coded_sample == 24) {
+                avctx->pix_fmt = AV_PIX_FMT_RGB24;
+            } else {
+                avctx->pix_fmt = AV_PIX_FMT_0RGB32;
+                planes = 4;
+            }
 
         if (ff_thread_get_buffer(avctx, p) < 0) {
             av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
@@ -542,11 +550,18 @@ static int lag_decode_frame(AVCodecContext *avctx,
         }
 
         dst = p->data[0];
+        if (frametype == FRAME_SOLID_RGBA) {
         for (j = 0; j < avctx->height; j++) {
             for (i = 0; i < avctx->width; i++)
                 AV_WN32(dst + i * 4, offset_gu);
             dst += p->linesize[0];
         }
+        } else {
+            for (j = 0; j < avctx->height; j++) {
+                memset(dst, buf[1], avctx->width * planes);
+                dst += p->linesize[0];
+            }
+        }
         break;
     case FRAME_ARITH_RGBA:
         avctx->pix_fmt = AV_PIX_FMT_RGB32;



More information about the ffmpeg-cvslog mailing list