[FFmpeg-cvslog] swscale: use Nbit code to handle !is16BPS(c->srcFormat) && is16BPS(c-> dstFormat)

Michael Niedermayer git at videolan.org
Tue May 10 00:44:20 CEST 2011


ffmpeg | branch: master | Michael Niedermayer <michaelni at gmx.at> | Tue May 10 00:37:20 2011 +0200| [53789a27f8a2ca06563d9555013e20b191b2a705] | committer: Michael Niedermayer

swscale: use Nbit code to handle !is16BPS(c->srcFormat) && is16BPS(c->dstFormat)

Signed-off-by: Michael Niedermayer <michaelni at gmx.at>

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

 libswscale/swscale.c |   11 +----------
 1 files changed, 1 insertions(+), 10 deletions(-)

diff --git a/libswscale/swscale.c b/libswscale/swscale.c
index 6379bc1..521ed8e 100644
--- a/libswscale/swscale.c
+++ b/libswscale/swscale.c
@@ -1898,7 +1898,7 @@ static int planarCopyWrapper(SwsContext *c, const uint8_t* src[], int srcStride[
             fillPlane(dst[plane], dstStride[plane], length, height, y, (plane==3) ? 255 : 128);
         } else {
             if(isNBPS(c->srcFormat) || isNBPS(c->dstFormat)
-               || (is16BPS(c->srcFormat) && !is16BPS(c->dstFormat))
+               || (is16BPS(c->srcFormat) != is16BPS(c->dstFormat))
             ) {
                 const int src_depth = av_pix_fmt_descriptors[c->srcFormat].comp[plane].depth_minus1+1;
                 const int dst_depth = av_pix_fmt_descriptors[c->dstFormat].comp[plane].depth_minus1+1;
@@ -1940,15 +1940,6 @@ static int planarCopyWrapper(SwsContext *c, const uint8_t* src[], int srcStride[
                         DITHER_COPY(dstPtr2, dstStride[plane]/2, srcPtr2, srcStride[plane]/2, av_bswap16)
                     }
                 }
-            } else if(!is16BPS(c->srcFormat) && is16BPS(c->dstFormat)) {
-                for (i=0; i<height; i++) {
-                    for (j=0; j<length; j++) {
-                        dstPtr[ j<<1   ] = srcPtr[j];
-                        dstPtr[(j<<1)+1] = srcPtr[j];
-                    }
-                    srcPtr+= srcStride[plane];
-                    dstPtr+= dstStride[plane];
-                }
             } else if(is16BPS(c->srcFormat) && is16BPS(c->dstFormat)
                   && isBE(c->srcFormat) != isBE(c->dstFormat)) {
 



More information about the ffmpeg-cvslog mailing list