[FFmpeg-cvslog] tiffdec: support predictor type 2 with RGB48 pixel format

Jean First git at videolan.org
Sun Apr 13 04:03:39 CEST 2014


ffmpeg | branch: master | Jean First <jeanfirst at gmail.com> | Sun Sep 25 16:00:04 2011 +0200| [e75ef2b7f48b96a9b6c8646058713899d5ea5731] | committer: Justin Ruggles

tiffdec: support predictor type 2 with RGB48 pixel format

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

 libavcodec/tiff.c |   22 ++++++++++++++++++----
 1 file changed, 18 insertions(+), 4 deletions(-)

diff --git a/libavcodec/tiff.c b/libavcodec/tiff.c
index d801302..6c72dc8 100644
--- a/libavcodec/tiff.c
+++ b/libavcodec/tiff.c
@@ -635,10 +635,24 @@ static int decode_frame(AVCodecContext *avctx,
         dst   = p->data[0];
         soff  = s->bpp >> 3;
         ssize = s->width * soff;
-        for (i = 0; i < s->height; i++) {
-            for (j = soff; j < ssize; j++)
-                dst[j] += dst[j - soff];
-            dst += stride;
+        if (s->avctx->pix_fmt == PIX_FMT_RGB48LE) {
+            for (i = 0; i < s->height; i++) {
+                for (j = soff; j < ssize; j += 2)
+                    AV_WL16(dst + j, AV_RL16(dst + j) + AV_RL16(dst + j - soff));
+                dst += stride;
+            }
+        } else if (s->avctx->pix_fmt == PIX_FMT_RGB48BE) {
+            for (i = 0; i < s->height; i++) {
+                for (j = soff; j < ssize; j += 2)
+                    AV_WB16(dst + j, AV_RB16(dst + j) + AV_RB16(dst + j - soff));
+                dst += stride;
+            }
+        } else {
+            for (i = 0; i < s->height; i++) {
+                for (j = soff; j < ssize; j++)
+                    dst[j] += dst[j - soff];
+                dst += stride;
+            }
         }
     }
 



More information about the ffmpeg-cvslog mailing list