# HG changeset patch # User lu_zero # Date 1215314792 0 # Node ID 1a35c35a631e3bfb9041de6f3c8eb1d20b4c8dd5 # Parent 77b12b0470e43541cd42c7af759593de3353dc1e Split simpleCopy into packedCopy and planarCopy. SoC Patch from Keiji Costantini diff -r 77b12b0470e4 -r 1a35c35a631e libswscale/swscale.c --- a/libswscale/swscale.c Sat Jul 05 18:02:17 2008 +0000 +++ b/libswscale/swscale.c Sun Jul 06 03:26:32 2008 +0000 @@ -1731,11 +1731,10 @@ } /* unscaled copy like stuff (assumes nearly identical formats) */ -static int simpleCopy(SwsContext *c, uint8_t* src[], int srcStride[], int srcSliceY, +static int packedCopy(SwsContext *c, uint8_t* src[], int srcStride[], int srcSliceY, int srcSliceH, uint8_t* dst[], int dstStride[]){ - if (isPacked(c->srcFormat)) - { + if (dstStride[0]==srcStride[0] && srcStride[0] > 0) memcpy(dst[0] + dstStride[0]*srcSliceY, src[0], srcSliceH*dstStride[0]); else @@ -1757,9 +1756,13 @@ dstPtr+= dstStride[0]; } } - } - else - { /* Planar YUV or gray */ + + return srcSliceH; +} +static int planarCopy(SwsContext *c, uint8_t* src[], int srcStride[], int srcSliceY, + int srcSliceH, uint8_t* dst[], int dstStride[]) +{ + int plane; for (plane=0; plane<3; plane++) { @@ -1790,7 +1793,7 @@ } } } - } + return srcSliceH; } @@ -2208,7 +2211,10 @@ || (isPlanarYUV(srcFormat) && isGray(dstFormat)) || (isPlanarYUV(dstFormat) && isGray(srcFormat))) { - c->swScale= simpleCopy; + if (isPacked(c->srcFormat)) + c->swScale= packedCopy; + else /* Planar YUV or gray */ + c->swScale= planarCopy; } /* gray16{le,be} conversions */